From 9e1a20cd3a5cfc9d5244706ccadafc4529d600c7 Mon Sep 17 00:00:00 2001
From: Henk Kalkwater <chris+dev@netsoj.nl>
Date: Thu, 13 Mar 2025 02:39:07 +0100
Subject: [PATCH] [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.
---
 core/GeneratedSources.cmake                   |  1156 +-
 core/include/JellyfinQt/dto/accessschedule.h  |     8 +-
 .../include/JellyfinQt/dto/activitylogentry.h |     8 +-
 .../JellyfinQt/dto/activitylogentrymessage.h  |   123 +
 .../dto/activitylogentryqueryresult.h         |    13 +-
 .../dto/activitylogentrystartmessage.h        |   109 +
 .../dto/activitylogentrystopmessage.h         |    96 +
 core/include/JellyfinQt/dto/albuminfo.h       |    25 +-
 .../dto/albuminforemotesearchquery.h          |     4 +-
 core/include/JellyfinQt/dto/artistinfo.h      |    19 +-
 .../dto/artistinforemotesearchquery.h         |     4 +-
 .../JellyfinQt/dto/audiospatialformat.h       |    77 +
 .../JellyfinQt/dto/authenticateuserbyname.h   |    12 -
 .../dto/authenticationinfoqueryresult.h       |    13 +-
 .../JellyfinQt/dto/authenticationresult.h     |    26 +-
 core/include/JellyfinQt/dto/baseitem.h        |   179 -
 core/include/JellyfinQt/dto/baseitemdto.h     |   136 +-
 .../JellyfinQt/dto/baseitemdtoqueryresult.h   |    13 +-
 core/include/JellyfinQt/dto/baseitemkind.h    |   111 +
 core/include/JellyfinQt/dto/baseitemperson.h  |    30 +-
 core/include/JellyfinQt/dto/bookinfo.h        |    14 +-
 .../dto/bookinforemotesearchquery.h           |     4 +-
 core/include/JellyfinQt/dto/boxsetinfo.h      |    14 +-
 .../dto/boxsetinforemotesearchquery.h         |     4 +-
 core/include/JellyfinQt/dto/brandingoptions.h |    20 +-
 ...rofileinfo.h => castreceiverapplication.h} |    48 +-
 core/include/JellyfinQt/dto/channelfeatures.h |    27 +-
 .../JellyfinQt/dto/channelmappingoptionsdto.h |    18 +-
 .../JellyfinQt/dto/clientcapabilities.h       |   169 -
 .../JellyfinQt/dto/clientcapabilitiesdto.h    |    49 +-
 .../dto/clientlogdocumentresponsedto.h        |   100 +
 core/include/JellyfinQt/dto/codecprofile.h    |    52 +-
 core/include/JellyfinQt/dto/collectiontype.h  |    87 +
 .../JellyfinQt/dto/collectiontypeoptions.h    |    82 +
 .../{responseprofile.h => configimagetypes.h} |   100 +-
 .../JellyfinQt/dto/configurationpageinfo.h    |    15 +-
 .../include/JellyfinQt/dto/containerprofile.h |    33 +-
 .../JellyfinQt/dto/createplaylistdto.h        |    48 +-
 .../include/JellyfinQt/dto/createuserbyname.h |    12 +-
 core/include/JellyfinQt/dto/culturedto.h      |    37 +-
 ...eviceprofiletype.h => deinterlacemethod.h} |    22 +-
 .../JellyfinQt/dto/deviceidentification.h     |   195 -
 .../dto/{deviceinfo.h => deviceinfodto.h}     |    82 +-
 ...eryresult.h => deviceinfodtoqueryresult.h} |    45 +-
 .../include/JellyfinQt/dto/deviceoptionsdto.h |   124 +
 core/include/JellyfinQt/dto/deviceprofile.h   |   378 +-
 .../JellyfinQt/dto/directplayprofile.h        |    29 +-
 .../JellyfinQt/dto/displaypreferencesdto.h    |     5 +-
 core/include/JellyfinQt/dto/dlnaprofiletype.h |     2 +
 .../JellyfinQt/dto/downmixstereoalgorithms.h  |    79 +
 .../JellyfinQt/dto/embeddedsubtitleoptions.h  |    78 +
 core/include/JellyfinQt/dto/encoderpreset.h   |    85 +
 core/include/JellyfinQt/dto/encodingoptions.h |   595 +
 core/include/JellyfinQt/dto/externalidinfo.h  |     8 +-
 .../JellyfinQt/dto/externalidmediatype.h      |     1 +
 core/include/JellyfinQt/dto/extratype.h       |    86 +
 .../JellyfinQt/dto/filesystementryinfo.h      |     8 +-
 .../JellyfinQt/dto/forcekeepalivemessage.h    |   119 +
 ...{xmlattribute.h => forgotpasswordpindto.h} |    54 +-
 core/include/JellyfinQt/dto/generalcommand.h  |     5 +-
 .../JellyfinQt/dto/generalcommandmessage.h    |   117 +
 .../JellyfinQt/dto/generalcommandtype.h       |     2 +
 core/include/JellyfinQt/dto/getprogramsdto.h  |   160 +-
 core/include/JellyfinQt/dto/groupinfodto.h    |    10 +-
 .../JellyfinQt/dto/groupinfodtogroupupdate.h  |   117 +
 .../include/JellyfinQt/dto/groupstateupdate.h |   104 +
 .../dto/groupstateupdategroupupdate.h         |   117 +
 .../dto/{controlresponse.h => groupupdate.h}  |    60 +-
 .../JellyfinQt/dto/hardwareaccelerationtype.h |    82 +
 core/include/JellyfinQt/dto/imageformat.h     |     1 +
 .../JellyfinQt/dto/imageproviderinfo.h        |    15 +-
 core/include/JellyfinQt/dto/imageresolution.h |    83 +
 .../JellyfinQt/dto/inboundkeepalivemessage.h  |    96 +
 .../inboundwebsocketmessage.h}                |    22 +-
 .../include/JellyfinQt/dto/installationinfo.h |    28 +-
 core/include/JellyfinQt/dto/iplugin.h         |    21 +-
 core/include/JellyfinQt/dto/itemfields.h      |     3 +-
 core/include/JellyfinQt/dto/itemsortby.h      |   106 +
 .../JellyfinQt/dto/librarychangedmessage.h    |   117 +
 core/include/JellyfinQt/dto/libraryoptions.h  |   144 +-
 .../JellyfinQt/dto/libraryoptionsresultdto.h  |    32 +-
 .../JellyfinQt/dto/librarytypeoptionsdto.h    |    21 +-
 .../JellyfinQt/dto/libraryupdateinfo.h        |    20 +-
 core/include/JellyfinQt/dto/livetvinfo.h      |    10 +-
 core/include/JellyfinQt/dto/livetvoptions.h   |   207 +
 core/include/JellyfinQt/dto/logfile.h         |     5 +-
 core/include/JellyfinQt/dto/lyricdto.h        |   111 +
 .../dto/{httpheaderinfo.h => lyricline.h}     |    69 +-
 core/include/JellyfinQt/dto/lyricmetadata.h   |   204 +
 core/include/JellyfinQt/dto/mediapathinfo.h   |    20 +-
 core/include/JellyfinQt/dto/mediasegmentdto.h |   141 +
 .../dto/mediasegmentdtoqueryresult.h          |   124 +
 .../include/JellyfinQt/dto/mediasegmenttype.h |    80 +
 core/include/JellyfinQt/dto/mediasourceinfo.h |    42 +-
 core/include/JellyfinQt/dto/mediastream.h     |   197 +-
 .../JellyfinQt/dto/mediastreamprotocol.h      |    76 +
 core/include/JellyfinQt/dto/mediastreamtype.h |     2 +
 .../dto/{architecture.h => mediatype.h}       |    28 +-
 .../JellyfinQt/dto/mediaupdateinfodto.h       |    40 +-
 ...oderpathdto.h => mediaupdateinfopathdto.h} |    42 +-
 .../dto/{version.h => messagecommand.h}       |    74 +-
 .../JellyfinQt/dto/metadataconfiguration.h    |    95 +
 .../JellyfinQt/dto/metadataeditorinfo.h       |    35 +-
 core/include/JellyfinQt/dto/movieinfo.h       |    14 +-
 .../dto/movieinforemotesearchquery.h          |     4 +-
 core/include/JellyfinQt/dto/musicvideoinfo.h  |    14 +-
 .../dto/musicvideoinforemotesearchquery.h     |     4 +-
 .../JellyfinQt/dto/networkconfiguration.h     |   346 +
 .../JellyfinQt/dto/newgrouprequestdto.h       |    12 +-
 core/include/JellyfinQt/dto/notificationdto.h |   180 -
 .../JellyfinQt/dto/notificationssummarydto.h  |   107 -
 .../JellyfinQt/dto/openlivestreamdto.h        |    19 +-
 .../JellyfinQt/dto/outboundkeepalivemessage.h |   108 +
 .../JellyfinQt/dto/outboundwebsocketmessage.h |    48 +
 core/include/JellyfinQt/dto/packageinfo.h     |    30 +-
 core/include/JellyfinQt/dto/parentalrating.h  |    18 +-
 .../include/JellyfinQt/dto/pathsubstitution.h |    15 +-
 core/include/JellyfinQt/dto/personkind.h      |    99 +
 .../include/JellyfinQt/dto/personlookupinfo.h |    14 +-
 .../dto/personlookupinforemotesearchquery.h   |     4 +-
 core/include/JellyfinQt/dto/pinredeemresult.h |     5 +-
 core/include/JellyfinQt/dto/playbackinfodto.h |    14 +-
 .../JellyfinQt/dto/playbackinforesponse.h     |     5 +-
 .../{headermatchtype.h => playbackorder.h}    |    23 +-
 .../JellyfinQt/dto/playbackprogressinfo.h     |    10 +-
 .../JellyfinQt/dto/playbackrequesttype.h      |    91 +
 .../JellyfinQt/dto/playbackstartinfo.h        |    10 +-
 core/include/JellyfinQt/dto/playerstateinfo.h |    22 +-
 .../JellyfinQt/dto/playlistcreationresult.h   |    12 +-
 core/include/JellyfinQt/dto/playlistdto.h     |   124 +
 ...curityinfo.h => playlistuserpermissions.h} |    51 +-
 core/include/JellyfinQt/dto/playmessage.h     |   117 +
 core/include/JellyfinQt/dto/playqueueupdate.h |   171 +
 .../dto/playqueueupdategroupupdate.h          |   117 +
 .../JellyfinQt/dto/playqueueupdatereason.h    |    84 +
 core/include/JellyfinQt/dto/playrequestdto.h  |     5 +-
 .../include/JellyfinQt/dto/playstatemessage.h |   117 +
 core/include/JellyfinQt/dto/plugininfo.h      |    26 +-
 .../dto/plugininstallationcancelledmessage.h  |   117 +
 .../dto/plugininstallationcompletedmessage.h  |   117 +
 .../dto/plugininstallationfailedmessage.h     |   117 +
 .../JellyfinQt/dto/plugininstallingmessage.h  |   117 +
 .../JellyfinQt/dto/pluginuninstalledmessage.h |   117 +
 ...ficationlevel.h => processpriorityclass.h} |    25 +-
 .../JellyfinQt/dto/profileconditionvalue.h    |     1 +
 core/include/JellyfinQt/dto/queuerequestdto.h |     5 +-
 core/include/JellyfinQt/dto/quickconnectdto.h |    12 +-
 .../JellyfinQt/dto/quickconnectresult.h       |    71 +-
 .../JellyfinQt/dto/quickconnectstate.h        |    77 -
 .../JellyfinQt/dto/refreshprogressmessage.h   |   120 +
 core/include/JellyfinQt/dto/remoteimageinfo.h |     4 +-
 .../JellyfinQt/dto/remotelyricinfodto.h       |   120 +
 .../JellyfinQt/dto/remotesubtitleinfo.h       |    40 +
 .../dto/removefromplaylistrequestdto.h        |    38 +-
 .../JellyfinQt/dto/restartrequiredmessage.h   |   108 +
 .../dto/scheduledtaskendedmessage.h           |   117 +
 .../dto/scheduledtasksinfomessage.h           |   123 +
 .../dto/scheduledtasksinfostartmessage.h      |   109 +
 .../dto/scheduledtasksinfostopmessage.h       |    96 +
 core/include/JellyfinQt/dto/searchhint.h      |    94 +-
 .../include/JellyfinQt/dto/searchhintresult.h |    13 +-
 core/include/JellyfinQt/dto/seriesinfo.h      |    14 +-
 .../dto/seriesinforemotesearchquery.h         |     4 +-
 core/include/JellyfinQt/dto/seriesstatus.h    |     1 +
 .../dto/seriestimercancelledmessage.h         |   117 +
 .../dto/seriestimercreatedmessage.h           |   117 +
 .../JellyfinQt/dto/seriestimerinfodto.h       |    32 +-
 .../dto/seriestimerinfodtoqueryresult.h       |    13 +-
 .../JellyfinQt/dto/serverconfiguration.h      |   574 +-
 ...ereasypassword.h => serverdiscoveryinfo.h} |    76 +-
 .../JellyfinQt/dto/serverrestartingmessage.h  |   108 +
 .../dto/servershuttingdownmessage.h           |   108 +
 .../dto/{sessioninfo.h => sessioninfodto.h}   |   153 +-
 .../JellyfinQt/dto/sessionmessagetype.h       |   108 +
 ...ificationresultdto.h => sessionsmessage.h} |    63 +-
 .../JellyfinQt/dto/sessionsstartmessage.h     |   109 +
 ...{deviceoptions.h => sessionsstopmessage.h} |    40 +-
 core/include/JellyfinQt/dto/songinfo.h        |    14 +-
 ...bjectgroupupdate.h => stringgroupupdate.h} |    35 +-
 .../JellyfinQt/dto/subtitledeliverymethod.h   |     1 +
 core/include/JellyfinQt/dto/subtitleoptions.h |   157 +
 core/include/JellyfinQt/dto/subtitleprofile.h |    32 +-
 .../JellyfinQt/dto/syncplaycommandmessage.h   |   117 +
 .../dto/syncplaygroupupdatecommandmessage.h   |   117 +
 .../JellyfinQt/dto/syncplayqueueitem.h        |   111 +
 core/include/JellyfinQt/dto/systeminfo.h      |    61 +-
 .../include/JellyfinQt/dto/thememediaresult.h |    13 +-
 .../JellyfinQt/dto/timercancelledmessage.h    |   117 +
 .../JellyfinQt/dto/timercreatedmessage.h      |   117 +
 core/include/JellyfinQt/dto/timereventinfo.h  |    12 +-
 core/include/JellyfinQt/dto/timerinfodto.h    |    32 +-
 .../JellyfinQt/dto/timerinfodtoqueryresult.h  |    13 +-
 ...ationpagetype.h => tonemappingalgorithm.h} |    26 +-
 core/include/JellyfinQt/dto/tonemappingmode.h |    79 +
 .../include/JellyfinQt/dto/tonemappingrange.h |    77 +
 core/include/JellyfinQt/dto/trailerinfo.h     |    14 +-
 .../dto/trailerinforemotesearchquery.h        |     4 +-
 core/include/JellyfinQt/dto/transcodereason.h |    33 +-
 core/include/JellyfinQt/dto/transcodinginfo.h |   107 +-
 .../JellyfinQt/dto/transcodingprofile.h       |   188 +-
 core/include/JellyfinQt/dto/trickplayinfo.h   |   165 +
 .../include/JellyfinQt/dto/trickplayoptions.h |   218 +
 .../JellyfinQt/dto/trickplayscanbehavior.h    |    76 +
 core/include/JellyfinQt/dto/tunerhostinfo.h   |    30 +-
 ...typeinfo.h => updatemediapathrequestdto.h} |    70 +-
 ...{imagebynameinfo.h => updateplaylistdto.h} |    89 +-
 .../JellyfinQt/dto/updateplaylistuserdto.h    |    95 +
 .../JellyfinQt/dto/updateuseritemdatadto.h    |   217 +
 .../JellyfinQt/dto/uploadsubtitledto.h        |    11 +
 .../JellyfinQt/dto/userconfiguration.h        |    30 +-
 .../JellyfinQt/dto/userdatachangedmessage.h   |   117 +
 .../JellyfinQt/dto/userdatachangeinfo.h       |   114 +
 .../JellyfinQt/dto/userdeletedmessage.h       |   119 +
 core/include/JellyfinQt/dto/useritemdatadto.h |     8 +-
 core/include/JellyfinQt/dto/userpolicy.h      |    51 +-
 .../JellyfinQt/dto/userupdatedmessage.h       |   117 +
 core/include/JellyfinQt/dto/versioninfo.h     |    29 +-
 .../dto/{ffmpeglocation.h => videorange.h}    |    25 +-
 core/include/JellyfinQt/dto/videorangetype.h  |    83 +
 .../JellyfinQt/dto/virtualfolderinfo.h        |    20 +-
 .../include/JellyfinQt/dto/websocketmessage.h |    48 +
 .../JellyfinQt/dto/xbmcmetadataoptions.h      |   125 +
 .../JellyfinQt/loader/http/clientlog.h        |    69 +
 .../JellyfinQt/loader/http/configuration.h    |    14 -
 core/include/JellyfinQt/loader/http/devices.h |    12 +-
 core/include/JellyfinQt/loader/http/dlna.h    |   141 -
 core/include/JellyfinQt/loader/http/image.h   |    57 +-
 .../JellyfinQt/loader/http/imagebyname.h      |    99 -
 .../JellyfinQt/loader/http/instantmix.h       |    47 +-
 .../JellyfinQt/loader/http/itemrefresh.h      |    10 +-
 core/include/JellyfinQt/loader/http/items.h   |    29 +-
 core/include/JellyfinQt/loader/http/lyrics.h  |   143 +
 .../JellyfinQt/loader/http/mediasegments.h    |    69 +
 .../JellyfinQt/loader/http/notifications.h    |   156 -
 .../JellyfinQt/loader/http/playlists.h        |   107 +-
 .../JellyfinQt/loader/http/playstate.h        |    84 +-
 core/include/JellyfinQt/loader/http/plugins.h |    14 -
 .../JellyfinQt/loader/http/quickconnect.h     |   101 +-
 core/include/JellyfinQt/loader/http/search.h  |    10 +-
 core/include/JellyfinQt/loader/http/session.h |     4 +-
 core/include/JellyfinQt/loader/http/tmdb.h    |    69 +
 .../loader/http/{videohls.h => trickplay.h}   |     6 +-
 core/include/JellyfinQt/loader/http/user.h    |   113 +-
 .../JellyfinQt/loader/http/userlibrary.h      |   122 +-
 .../JellyfinQt/loader/http/userviews.h        |    30 +-
 core/include/JellyfinQt/loader/requesttypes.h |  6452 ++-
 core/openapi.json                             | 43597 +++++++++-------
 core/src/dto/activitylogentry.cpp             |    30 +-
 core/src/dto/activitylogentrymessage.cpp      |   129 +
 core/src/dto/activitylogentryqueryresult.cpp  |    15 +-
 core/src/dto/activitylogentrystartmessage.cpp |   117 +
 core/src/dto/activitylogentrystopmessage.cpp  |    96 +
 core/src/dto/albuminfo.cpp                    |    70 +-
 core/src/dto/artistinfo.cpp                   |    40 +-
 ...ionpagetype.cpp => audiospatialformat.cpp} |    35 +-
 core/src/dto/authenticateuserbyname.cpp       |    23 +-
 .../src/dto/authenticationinfoqueryresult.cpp |    15 +-
 core/src/dto/authenticationresult.cpp         |    10 +-
 core/src/dto/baseitem.cpp                     |   261 -
 core/src/dto/baseitemdto.cpp                  |   166 +-
 core/src/dto/baseitemdtoqueryresult.cpp       |    15 +-
 core/src/dto/baseitemkind.cpp                 |   248 +
 core/src/dto/baseitemperson.cpp               |    40 +-
 core/src/dto/bookinfo.cpp                     |    21 +
 core/src/dto/boxsetinfo.cpp                   |    21 +
 core/src/dto/brandingoptions.cpp              |    20 +-
 ...ribute.cpp => castreceiverapplication.cpp} |    86 +-
 core/src/dto/channelfeatures.cpp              |    75 +-
 core/src/dto/channelmappingoptionsdto.cpp     |    49 +-
 core/src/dto/clientcapabilities.cpp           |   249 -
 core/src/dto/clientcapabilitiesdto.cpp        |    81 +-
 core/src/dto/clientlogdocumentresponsedto.cpp |    96 +
 core/src/dto/codecprofile.cpp                 |    57 +-
 core/src/dto/collectiontype.cpp               |   128 +
 core/src/dto/collectiontypeoptions.cpp        |   103 +
 core/src/dto/configimagetypes.cpp             |   227 +
 core/src/dto/configurationpageinfo.cpp        |    31 +-
 core/src/dto/containerprofile.cpp             |    42 +-
 core/src/dto/controlresponse.cpp              |   138 -
 core/src/dto/createplaylistdto.cpp            |    75 +-
 core/src/dto/createuserbyname.cpp             |    19 +-
 core/src/dto/culturedto.cpp                   |    64 +-
 ...eprofiletype.cpp => deinterlacemethod.cpp} |    32 +-
 core/src/dto/deviceidentification.cpp         |   269 -
 .../dto/{deviceinfo.cpp => deviceinfodto.cpp} |   170 +-
 ...esult.cpp => deviceinfodtoqueryresult.cpp} |    55 +-
 core/src/dto/deviceoptionsdto.cpp             |   138 +
 core/src/dto/deviceprofile.cpp                |   564 +-
 core/src/dto/deviceprofileinfo.cpp            |   138 -
 core/src/dto/directplayprofile.cpp            |    15 +-
 core/src/dto/displaypreferencesdto.cpp        |    15 +-
 core/src/dto/dlnaprofiletype.cpp              |    10 +
 core/src/dto/downmixstereoalgorithms.cpp      |    88 +
 ...cation.cpp => embeddedsubtitleoptions.cpp} |    48 +-
 core/src/dto/encoderpreset.cpp                |   118 +
 core/src/dto/encodingoptions.cpp              |   720 +
 core/src/dto/externalidinfo.cpp               |    30 +-
 core/src/dto/externalidmediatype.cpp          |     5 +
 core/src/dto/extratype.cpp                    |   123 +
 core/src/dto/filesystementryinfo.cpp          |    30 +-
 core/src/dto/forcekeepalivemessage.cpp        |   120 +
 ...ceoptions.cpp => forgotpasswordpindto.cpp} |    59 +-
 core/src/dto/generalcommand.cpp               |    19 +-
 core/src/dto/generalcommandmessage.cpp        |   120 +
 core/src/dto/generalcommandtype.cpp           |    10 +
 core/src/dto/getprogramsdto.cpp               |    66 +-
 core/src/dto/groupinfodto.cpp                 |    30 +-
 core/src/dto/groupinfodtogroupupdate.cpp      |   120 +
 core/src/dto/groupstateupdate.cpp             |   108 +
 core/src/dto/groupstateupdategroupupdate.cpp  |   120 +
 core/src/dto/groupupdate.cpp                  |   108 +
 core/src/dto/hardwareaccelerationtype.cpp     |   103 +
 core/src/dto/httpheaderinfo.cpp               |   138 -
 core/src/dto/imagebynameinfo.cpp              |   180 -
 core/src/dto/imageformat.cpp                  |     5 +
 core/src/dto/imageproviderinfo.cpp            |    34 +-
 core/src/dto/imageresolution.cpp              |   108 +
 core/src/dto/inboundkeepalivemessage.cpp      |    96 +
 .../inboundwebsocketmessage.cpp}              |    10 +-
 core/src/dto/installationinfo.cpp             |    37 +-
 core/src/dto/iplugin.cpp                      |    21 +-
 core/src/dto/itemfields.cpp                   |    15 +-
 core/src/dto/itemsortby.cpp                   |   223 +
 core/src/dto/librarychangedmessage.cpp        |   120 +
 core/src/dto/libraryoptions.cpp               |   292 +-
 core/src/dto/libraryoptionsresultdto.cpp      |    74 +-
 core/src/dto/librarytypeoptionsdto.cpp        |    64 +-
 core/src/dto/libraryupdateinfo.cpp            |    90 +-
 core/src/dto/livetvinfo.cpp                   |    34 +-
 core/src/dto/livetvoptions.cpp                |   345 +
 core/src/dto/logfile.cpp                      |    19 +-
 core/src/dto/lyricdto.cpp                     |   108 +
 core/src/dto/lyricline.cpp                    |   117 +
 core/src/dto/lyricmetadata.cpp                |   290 +
 core/src/dto/mediapathinfo.cpp                |    42 +-
 core/src/dto/mediasegmentdto.cpp              |   144 +
 core/src/dto/mediasegmentdtoqueryresult.cpp   |   120 +
 core/src/dto/mediasegmenttype.cpp             |    93 +
 core/src/dto/mediasourceinfo.cpp              |    74 +-
 core/src/dto/mediastream.cpp                  |   330 +-
 core/src/dto/mediastreamprotocol.cpp          |    73 +
 core/src/dto/mediastreamtype.cpp              |    10 +
 .../{quickconnectstate.cpp => mediatype.cpp}  |    50 +-
 core/src/dto/mediaupdateinfodto.cpp           |    52 +-
 ...pathdto.cpp => mediaupdateinfopathdto.cpp} |    56 +-
 core/src/dto/messagecommand.cpp               |   138 +
 core/src/dto/metadataconfiguration.cpp        |    96 +
 core/src/dto/metadataeditorinfo.cpp           |   100 +-
 core/src/dto/movieinfo.cpp                    |    21 +
 core/src/dto/musicvideoinfo.cpp               |    21 +
 core/src/dto/networkconfiguration.cpp         |   360 +
 core/src/dto/newgrouprequestdto.cpp           |    19 +-
 core/src/dto/notificationdto.cpp              |   225 -
 core/src/dto/notificationresultdto.cpp        |   117 -
 core/src/dto/notificationssummarydto.cpp      |   108 -
 core/src/dto/notificationtypeinfo.cpp         |   171 -
 core/src/dto/openlivestreamdto.cpp            |    38 +-
 core/src/dto/outboundkeepalivemessage.cpp     |   108 +
 core/src/dto/outboundwebsocketmessage.cpp     |    37 +
 core/src/dto/packageinfo.cpp                  |   109 +-
 core/src/dto/parentalrating.cpp               |    25 +-
 core/src/dto/pathsubstitution.cpp             |    34 +-
 core/src/dto/personkind.cpp                   |   188 +
 core/src/dto/personlookupinfo.cpp             |    21 +
 core/src/dto/pinredeemresult.cpp              |    19 +-
 core/src/dto/playbackinfodto.cpp              |    23 +-
 core/src/dto/playbackinforesponse.cpp         |    15 +-
 core/src/dto/playbackorder.cpp                |    73 +
 core/src/dto/playbackprogressinfo.cpp         |    16 +-
 core/src/dto/playbackrequesttype.cpp          |   148 +
 core/src/dto/playbackstartinfo.cpp            |    16 +-
 core/src/dto/playerstateinfo.cpp              |    41 +-
 core/src/dto/playlistcreationresult.cpp       |    19 +-
 core/src/dto/playlistdto.cpp                  |   120 +
 core/src/dto/playlistuserpermissions.cpp      |   108 +
 core/src/dto/playmessage.cpp                  |   120 +
 core/src/dto/playqueueupdate.cpp              |   180 +
 core/src/dto/playqueueupdategroupupdate.cpp   |   120 +
 core/src/dto/playqueueupdatereason.cpp        |   113 +
 core/src/dto/playrequestdto.cpp               |    15 +-
 core/src/dto/playstatemessage.cpp             |   120 +
 core/src/dto/plugininfo.cpp                   |    40 +-
 .../plugininstallationcancelledmessage.cpp    |   120 +
 .../plugininstallationcompletedmessage.cpp    |   120 +
 .../dto/plugininstallationfailedmessage.cpp   |   120 +
 core/src/dto/plugininstallingmessage.cpp      |   120 +
 core/src/dto/pluginsecurityinfo.cpp           |   117 -
 core/src/dto/pluginuninstalledmessage.cpp     |   120 +
 core/src/dto/processpriorityclass.cpp         |    93 +
 core/src/dto/profileconditionvalue.cpp        |     5 +
 core/src/dto/queuerequestdto.cpp              |    15 +-
 core/src/dto/quickconnectdto.cpp              |    18 +-
 core/src/dto/quickconnectresult.cpp           |   121 +-
 core/src/dto/refreshprogressmessage.cpp       |   129 +
 core/src/dto/remotelyricinfodto.cpp           |   120 +
 core/src/dto/remotesubtitleinfo.cpp           |   107 +-
 core/src/dto/removefromplaylistrequestdto.cpp |    39 +-
 core/src/dto/responseprofile.cpp              |   222 -
 core/src/dto/restartrequiredmessage.cpp       |   108 +
 core/src/dto/scheduledtaskendedmessage.cpp    |   120 +
 core/src/dto/scheduledtasksinfomessage.cpp    |   129 +
 .../dto/scheduledtasksinfostartmessage.cpp    |   117 +
 .../src/dto/scheduledtasksinfostopmessage.cpp |    96 +
 core/src/dto/searchhint.cpp                   |   102 +-
 core/src/dto/searchhintresult.cpp             |    15 +-
 core/src/dto/seriesinfo.cpp                   |    21 +
 core/src/dto/seriesstatus.cpp                 |     5 +
 core/src/dto/seriestimercancelledmessage.cpp  |   120 +
 core/src/dto/seriestimercreatedmessage.cpp    |   120 +
 .../src/dto/seriestimerinfodtoqueryresult.cpp |    15 +-
 core/src/dto/serverconfiguration.cpp          |   909 +-
 core/src/dto/serverdiscoveryinfo.cpp          |   141 +
 core/src/dto/serverrestartingmessage.cpp      |   108 +
 core/src/dto/servershuttingdownmessage.cpp    |   108 +
 .../{sessioninfo.cpp => sessioninfodto.cpp}   |   282 +-
 core/src/dto/sessionmessagetype.cpp           |   233 +
 core/src/dto/sessionsmessage.cpp              |   129 +
 core/src/dto/sessionsstartmessage.cpp         |   117 +
 core/src/dto/sessionsstopmessage.cpp          |    96 +
 core/src/dto/songinfo.cpp                     |    21 +
 ...tgroupupdate.cpp => stringgroupupdate.cpp} |    44 +-
 core/src/dto/subtitledeliverymethod.cpp       |     5 +
 core/src/dto/subtitleoptions.cpp              |   219 +
 core/src/dto/syncplaycommandmessage.cpp       |   120 +
 .../dto/syncplaygroupupdatecommandmessage.cpp |   120 +
 core/src/dto/syncplayqueueitem.cpp            |   108 +
 core/src/dto/systeminfo.cpp                   |   101 +-
 core/src/dto/thememediaresult.cpp             |    15 +-
 core/src/dto/timercancelledmessage.cpp        |   120 +
 core/src/dto/timercreatedmessage.cpp          |   120 +
 core/src/dto/timereventinfo.cpp               |    19 +-
 core/src/dto/timerinfodtoqueryresult.cpp      |    15 +-
 core/src/dto/tonemappingalgorithm.cpp         |   103 +
 .../{architecture.cpp => tonemappingmode.cpp} |    56 +-
 ...adermatchtype.cpp => tonemappingrange.cpp} |    40 +-
 core/src/dto/trailerinfo.cpp                  |    21 +
 core/src/dto/transcodereason.cpp              |   145 +-
 core/src/dto/transcodinginfo.cpp              |    31 +-
 core/src/dto/transcodingprofile.cpp           |   164 +-
 core/src/dto/trickplayinfo.cpp                |   168 +
 core/src/dto/trickplayoptions.cpp             |   228 +
 core/src/dto/trickplayscanbehavior.cpp        |    73 +
 core/src/dto/tunerhostinfo.cpp                |    56 +-
 core/src/dto/updatemediapathrequestdto.cpp    |   108 +
 core/src/dto/updateplaylistdto.cpp            |   164 +
 core/src/dto/updateplaylistuserdto.cpp        |   101 +
 core/src/dto/updateusereasypassword.cpp       |   138 -
 core/src/dto/updateuseritemdatadto.cpp        |   311 +
 core/src/dto/uploadsubtitledto.cpp            |    12 +
 core/src/dto/userconfiguration.cpp            |    85 +-
 core/src/dto/userdatachangedmessage.cpp       |   120 +
 core/src/dto/userdatachangeinfo.cpp           |   108 +
 core/src/dto/userdeletedmessage.cpp           |   120 +
 core/src/dto/useritemdatadto.cpp              |    34 +-
 core/src/dto/userpolicy.cpp                   |    87 +-
 core/src/dto/userupdatedmessage.cpp           |   120 +
 core/src/dto/version.cpp                      |   156 -
 core/src/dto/versioninfo.cpp                  |    57 +-
 .../{notificationlevel.cpp => videorange.cpp} |    40 +-
 core/src/dto/videorangetype.cpp               |   108 +
 core/src/dto/virtualfolderinfo.cpp            |    21 +-
 core/src/dto/websocketmessage.cpp             |    37 +
 core/src/dto/xbmcmetadataoptions.cpp          |   153 +
 core/src/loader/http/artists.cpp              |    24 +-
 core/src/loader/http/channels.cpp             |     4 +-
 core/src/loader/http/clientlog.cpp            |    70 +
 core/src/loader/http/configuration.cpp        |    31 +-
 core/src/loader/http/dashboard.cpp            |     3 -
 core/src/loader/http/devices.cpp              |    11 +-
 core/src/loader/http/displaypreferences.cpp   |     8 +-
 core/src/loader/http/dlna.cpp                 |   215 -
 core/src/loader/http/filter.cpp               |     6 +-
 core/src/loader/http/genres.cpp               |    10 +-
 core/src/loader/http/hlssegment.cpp           |     8 +-
 core/src/loader/http/image.cpp                |   138 +-
 core/src/loader/http/imagebyname.cpp          |   128 -
 core/src/loader/http/instantmix.cpp           |   174 +-
 core/src/loader/http/itemrefresh.cpp          |    15 +-
 core/src/loader/http/items.cpp                |   326 +-
 core/src/loader/http/library.cpp              |    26 +-
 core/src/loader/http/librarystructure.cpp     |     7 +-
 core/src/loader/http/livetv.cpp               |     6 +-
 core/src/loader/http/lyrics.cpp               |   216 +
 core/src/loader/http/mediainfo.cpp            |     7 +-
 core/src/loader/http/mediasegments.cpp        |    73 +
 core/src/loader/http/musicgenres.cpp          |    10 +-
 core/src/loader/http/notifications.cpp        |   256 -
 core/src/loader/http/playlists.cpp            |   204 +-
 core/src/loader/http/playstate.cpp            |   326 +-
 core/src/loader/http/plugins.cpp              |    35 +-
 core/src/loader/http/quickconnect.cpp         |   149 +-
 core/src/loader/http/search.cpp               |    18 +-
 core/src/loader/http/session.cpp              |    18 +-
 core/src/loader/http/studios.cpp              |     4 +-
 core/src/loader/http/suggestions.cpp          |     9 +-
 core/src/loader/http/tmdb.cpp                 |    70 +
 core/src/loader/http/trailers.cpp             |    23 +-
 .../http/{videohls.cpp => trickplay.cpp}      |     2 +-
 core/src/loader/http/tvshows.cpp              |    19 +-
 core/src/loader/http/user.cpp                 |   247 +-
 core/src/loader/http/userlibrary.cpp          |   282 +-
 core/src/loader/http/userviews.cpp            |    68 +-
 core/src/loader/http/years.cpp                |    10 +-
 core/src/loader/requesttypes.cpp              |  9619 ++--
 504 files changed, 62190 insertions(+), 41202 deletions(-)
 create mode 100644 core/include/JellyfinQt/dto/activitylogentrymessage.h
 create mode 100644 core/include/JellyfinQt/dto/activitylogentrystartmessage.h
 create mode 100644 core/include/JellyfinQt/dto/activitylogentrystopmessage.h
 create mode 100644 core/include/JellyfinQt/dto/audiospatialformat.h
 delete mode 100644 core/include/JellyfinQt/dto/baseitem.h
 create mode 100644 core/include/JellyfinQt/dto/baseitemkind.h
 rename core/include/JellyfinQt/dto/{deviceprofileinfo.h => castreceiverapplication.h} (66%)
 delete mode 100644 core/include/JellyfinQt/dto/clientcapabilities.h
 create mode 100644 core/include/JellyfinQt/dto/clientlogdocumentresponsedto.h
 create mode 100644 core/include/JellyfinQt/dto/collectiontype.h
 create mode 100644 core/include/JellyfinQt/dto/collectiontypeoptions.h
 rename core/include/JellyfinQt/dto/{responseprofile.h => configimagetypes.h} (50%)
 rename core/include/JellyfinQt/dto/{deviceprofiletype.h => deinterlacemethod.h} (76%)
 delete mode 100644 core/include/JellyfinQt/dto/deviceidentification.h
 rename core/include/JellyfinQt/dto/{deviceinfo.h => deviceinfodto.h} (68%)
 rename core/include/JellyfinQt/dto/{deviceinfoqueryresult.h => deviceinfodtoqueryresult.h} (66%)
 create mode 100644 core/include/JellyfinQt/dto/deviceoptionsdto.h
 create mode 100644 core/include/JellyfinQt/dto/downmixstereoalgorithms.h
 create mode 100644 core/include/JellyfinQt/dto/embeddedsubtitleoptions.h
 create mode 100644 core/include/JellyfinQt/dto/encoderpreset.h
 create mode 100644 core/include/JellyfinQt/dto/encodingoptions.h
 create mode 100644 core/include/JellyfinQt/dto/extratype.h
 create mode 100644 core/include/JellyfinQt/dto/forcekeepalivemessage.h
 rename core/include/JellyfinQt/dto/{xmlattribute.h => forgotpasswordpindto.h} (65%)
 create mode 100644 core/include/JellyfinQt/dto/generalcommandmessage.h
 create mode 100644 core/include/JellyfinQt/dto/groupinfodtogroupupdate.h
 create mode 100644 core/include/JellyfinQt/dto/groupstateupdate.h
 create mode 100644 core/include/JellyfinQt/dto/groupstateupdategroupupdate.h
 rename core/include/JellyfinQt/dto/{controlresponse.h => groupupdate.h} (66%)
 create mode 100644 core/include/JellyfinQt/dto/hardwareaccelerationtype.h
 create mode 100644 core/include/JellyfinQt/dto/imageresolution.h
 create mode 100644 core/include/JellyfinQt/dto/inboundkeepalivemessage.h
 rename core/include/JellyfinQt/{loader/http/dlnaserver.h => dto/inboundwebsocketmessage.h} (79%)
 create mode 100644 core/include/JellyfinQt/dto/itemsortby.h
 create mode 100644 core/include/JellyfinQt/dto/librarychangedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/livetvoptions.h
 create mode 100644 core/include/JellyfinQt/dto/lyricdto.h
 rename core/include/JellyfinQt/dto/{httpheaderinfo.h => lyricline.h} (65%)
 create mode 100644 core/include/JellyfinQt/dto/lyricmetadata.h
 create mode 100644 core/include/JellyfinQt/dto/mediasegmentdto.h
 create mode 100644 core/include/JellyfinQt/dto/mediasegmentdtoqueryresult.h
 create mode 100644 core/include/JellyfinQt/dto/mediasegmenttype.h
 create mode 100644 core/include/JellyfinQt/dto/mediastreamprotocol.h
 rename core/include/JellyfinQt/dto/{architecture.h => mediatype.h} (78%)
 rename core/include/JellyfinQt/dto/{mediaencoderpathdto.h => mediaupdateinfopathdto.h} (66%)
 rename core/include/JellyfinQt/dto/{version.h => messagecommand.h} (63%)
 create mode 100644 core/include/JellyfinQt/dto/metadataconfiguration.h
 create mode 100644 core/include/JellyfinQt/dto/networkconfiguration.h
 delete mode 100644 core/include/JellyfinQt/dto/notificationdto.h
 delete mode 100644 core/include/JellyfinQt/dto/notificationssummarydto.h
 create mode 100644 core/include/JellyfinQt/dto/outboundkeepalivemessage.h
 create mode 100644 core/include/JellyfinQt/dto/outboundwebsocketmessage.h
 create mode 100644 core/include/JellyfinQt/dto/personkind.h
 rename core/include/JellyfinQt/dto/{headermatchtype.h => playbackorder.h} (77%)
 create mode 100644 core/include/JellyfinQt/dto/playbackrequesttype.h
 create mode 100644 core/include/JellyfinQt/dto/playlistdto.h
 rename core/include/JellyfinQt/dto/{pluginsecurityinfo.h => playlistuserpermissions.h} (62%)
 create mode 100644 core/include/JellyfinQt/dto/playmessage.h
 create mode 100644 core/include/JellyfinQt/dto/playqueueupdate.h
 create mode 100644 core/include/JellyfinQt/dto/playqueueupdategroupupdate.h
 create mode 100644 core/include/JellyfinQt/dto/playqueueupdatereason.h
 create mode 100644 core/include/JellyfinQt/dto/playstatemessage.h
 create mode 100644 core/include/JellyfinQt/dto/plugininstallationcancelledmessage.h
 create mode 100644 core/include/JellyfinQt/dto/plugininstallationcompletedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/plugininstallationfailedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/plugininstallingmessage.h
 create mode 100644 core/include/JellyfinQt/dto/pluginuninstalledmessage.h
 rename core/include/JellyfinQt/dto/{notificationlevel.h => processpriorityclass.h} (74%)
 delete mode 100644 core/include/JellyfinQt/dto/quickconnectstate.h
 create mode 100644 core/include/JellyfinQt/dto/refreshprogressmessage.h
 create mode 100644 core/include/JellyfinQt/dto/remotelyricinfodto.h
 create mode 100644 core/include/JellyfinQt/dto/restartrequiredmessage.h
 create mode 100644 core/include/JellyfinQt/dto/scheduledtaskendedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/scheduledtasksinfomessage.h
 create mode 100644 core/include/JellyfinQt/dto/scheduledtasksinfostartmessage.h
 create mode 100644 core/include/JellyfinQt/dto/scheduledtasksinfostopmessage.h
 create mode 100644 core/include/JellyfinQt/dto/seriestimercancelledmessage.h
 create mode 100644 core/include/JellyfinQt/dto/seriestimercreatedmessage.h
 rename core/include/JellyfinQt/dto/{updateusereasypassword.h => serverdiscoveryinfo.h} (57%)
 create mode 100644 core/include/JellyfinQt/dto/serverrestartingmessage.h
 create mode 100644 core/include/JellyfinQt/dto/servershuttingdownmessage.h
 rename core/include/JellyfinQt/dto/{sessioninfo.h => sessioninfodto.h} (70%)
 create mode 100644 core/include/JellyfinQt/dto/sessionmessagetype.h
 rename core/include/JellyfinQt/dto/{notificationresultdto.h => sessionsmessage.h} (59%)
 create mode 100644 core/include/JellyfinQt/dto/sessionsstartmessage.h
 rename core/include/JellyfinQt/dto/{deviceoptions.h => sessionsstopmessage.h} (65%)
 rename core/include/JellyfinQt/dto/{objectgroupupdate.h => stringgroupupdate.h} (76%)
 create mode 100644 core/include/JellyfinQt/dto/subtitleoptions.h
 create mode 100644 core/include/JellyfinQt/dto/syncplaycommandmessage.h
 create mode 100644 core/include/JellyfinQt/dto/syncplaygroupupdatecommandmessage.h
 create mode 100644 core/include/JellyfinQt/dto/syncplayqueueitem.h
 create mode 100644 core/include/JellyfinQt/dto/timercancelledmessage.h
 create mode 100644 core/include/JellyfinQt/dto/timercreatedmessage.h
 rename core/include/JellyfinQt/dto/{configurationpagetype.h => tonemappingalgorithm.h} (74%)
 create mode 100644 core/include/JellyfinQt/dto/tonemappingmode.h
 create mode 100644 core/include/JellyfinQt/dto/tonemappingrange.h
 create mode 100644 core/include/JellyfinQt/dto/trickplayinfo.h
 create mode 100644 core/include/JellyfinQt/dto/trickplayoptions.h
 create mode 100644 core/include/JellyfinQt/dto/trickplayscanbehavior.h
 rename core/include/JellyfinQt/dto/{notificationtypeinfo.h => updatemediapathrequestdto.h} (61%)
 rename core/include/JellyfinQt/dto/{imagebynameinfo.h => updateplaylistdto.h} (55%)
 create mode 100644 core/include/JellyfinQt/dto/updateplaylistuserdto.h
 create mode 100644 core/include/JellyfinQt/dto/updateuseritemdatadto.h
 create mode 100644 core/include/JellyfinQt/dto/userdatachangedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/userdatachangeinfo.h
 create mode 100644 core/include/JellyfinQt/dto/userdeletedmessage.h
 create mode 100644 core/include/JellyfinQt/dto/userupdatedmessage.h
 rename core/include/JellyfinQt/dto/{ffmpeglocation.h => videorange.h} (77%)
 create mode 100644 core/include/JellyfinQt/dto/videorangetype.h
 create mode 100644 core/include/JellyfinQt/dto/websocketmessage.h
 create mode 100644 core/include/JellyfinQt/dto/xbmcmetadataoptions.h
 create mode 100644 core/include/JellyfinQt/loader/http/clientlog.h
 delete mode 100644 core/include/JellyfinQt/loader/http/dlna.h
 delete mode 100644 core/include/JellyfinQt/loader/http/imagebyname.h
 create mode 100644 core/include/JellyfinQt/loader/http/lyrics.h
 create mode 100644 core/include/JellyfinQt/loader/http/mediasegments.h
 delete mode 100644 core/include/JellyfinQt/loader/http/notifications.h
 create mode 100644 core/include/JellyfinQt/loader/http/tmdb.h
 rename core/include/JellyfinQt/loader/http/{videohls.h => trickplay.h} (93%)
 create mode 100644 core/src/dto/activitylogentrymessage.cpp
 create mode 100644 core/src/dto/activitylogentrystartmessage.cpp
 create mode 100644 core/src/dto/activitylogentrystopmessage.cpp
 rename core/src/dto/{configurationpagetype.cpp => audiospatialformat.cpp} (64%)
 delete mode 100644 core/src/dto/baseitem.cpp
 create mode 100644 core/src/dto/baseitemkind.cpp
 rename core/src/dto/{xmlattribute.cpp => castreceiverapplication.cpp} (52%)
 delete mode 100644 core/src/dto/clientcapabilities.cpp
 create mode 100644 core/src/dto/clientlogdocumentresponsedto.cpp
 create mode 100644 core/src/dto/collectiontype.cpp
 create mode 100644 core/src/dto/collectiontypeoptions.cpp
 create mode 100644 core/src/dto/configimagetypes.cpp
 delete mode 100644 core/src/dto/controlresponse.cpp
 rename core/src/dto/{deviceprofiletype.cpp => deinterlacemethod.cpp} (66%)
 delete mode 100644 core/src/dto/deviceidentification.cpp
 rename core/src/dto/{deviceinfo.cpp => deviceinfodto.cpp} (50%)
 rename core/src/dto/{deviceinfoqueryresult.cpp => deviceinfodtoqueryresult.cpp} (59%)
 create mode 100644 core/src/dto/deviceoptionsdto.cpp
 delete mode 100644 core/src/dto/deviceprofileinfo.cpp
 create mode 100644 core/src/dto/downmixstereoalgorithms.cpp
 rename core/src/dto/{ffmpeglocation.cpp => embeddedsubtitleoptions.cpp} (55%)
 create mode 100644 core/src/dto/encoderpreset.cpp
 create mode 100644 core/src/dto/encodingoptions.cpp
 create mode 100644 core/src/dto/extratype.cpp
 create mode 100644 core/src/dto/forcekeepalivemessage.cpp
 rename core/src/dto/{deviceoptions.cpp => forgotpasswordpindto.cpp} (57%)
 create mode 100644 core/src/dto/generalcommandmessage.cpp
 create mode 100644 core/src/dto/groupinfodtogroupupdate.cpp
 create mode 100644 core/src/dto/groupstateupdate.cpp
 create mode 100644 core/src/dto/groupstateupdategroupupdate.cpp
 create mode 100644 core/src/dto/groupupdate.cpp
 create mode 100644 core/src/dto/hardwareaccelerationtype.cpp
 delete mode 100644 core/src/dto/httpheaderinfo.cpp
 delete mode 100644 core/src/dto/imagebynameinfo.cpp
 create mode 100644 core/src/dto/imageresolution.cpp
 create mode 100644 core/src/dto/inboundkeepalivemessage.cpp
 rename core/src/{loader/http/dlnaserver.cpp => dto/inboundwebsocketmessage.cpp} (90%)
 create mode 100644 core/src/dto/itemsortby.cpp
 create mode 100644 core/src/dto/librarychangedmessage.cpp
 create mode 100644 core/src/dto/livetvoptions.cpp
 create mode 100644 core/src/dto/lyricdto.cpp
 create mode 100644 core/src/dto/lyricline.cpp
 create mode 100644 core/src/dto/lyricmetadata.cpp
 create mode 100644 core/src/dto/mediasegmentdto.cpp
 create mode 100644 core/src/dto/mediasegmentdtoqueryresult.cpp
 create mode 100644 core/src/dto/mediasegmenttype.cpp
 create mode 100644 core/src/dto/mediastreamprotocol.cpp
 rename core/src/dto/{quickconnectstate.cpp => mediatype.cpp} (60%)
 rename core/src/dto/{mediaencoderpathdto.cpp => mediaupdateinfopathdto.cpp} (54%)
 create mode 100644 core/src/dto/messagecommand.cpp
 create mode 100644 core/src/dto/metadataconfiguration.cpp
 create mode 100644 core/src/dto/networkconfiguration.cpp
 delete mode 100644 core/src/dto/notificationdto.cpp
 delete mode 100644 core/src/dto/notificationresultdto.cpp
 delete mode 100644 core/src/dto/notificationssummarydto.cpp
 delete mode 100644 core/src/dto/notificationtypeinfo.cpp
 create mode 100644 core/src/dto/outboundkeepalivemessage.cpp
 create mode 100644 core/src/dto/outboundwebsocketmessage.cpp
 create mode 100644 core/src/dto/personkind.cpp
 create mode 100644 core/src/dto/playbackorder.cpp
 create mode 100644 core/src/dto/playbackrequesttype.cpp
 create mode 100644 core/src/dto/playlistdto.cpp
 create mode 100644 core/src/dto/playlistuserpermissions.cpp
 create mode 100644 core/src/dto/playmessage.cpp
 create mode 100644 core/src/dto/playqueueupdate.cpp
 create mode 100644 core/src/dto/playqueueupdategroupupdate.cpp
 create mode 100644 core/src/dto/playqueueupdatereason.cpp
 create mode 100644 core/src/dto/playstatemessage.cpp
 create mode 100644 core/src/dto/plugininstallationcancelledmessage.cpp
 create mode 100644 core/src/dto/plugininstallationcompletedmessage.cpp
 create mode 100644 core/src/dto/plugininstallationfailedmessage.cpp
 create mode 100644 core/src/dto/plugininstallingmessage.cpp
 delete mode 100644 core/src/dto/pluginsecurityinfo.cpp
 create mode 100644 core/src/dto/pluginuninstalledmessage.cpp
 create mode 100644 core/src/dto/processpriorityclass.cpp
 create mode 100644 core/src/dto/refreshprogressmessage.cpp
 create mode 100644 core/src/dto/remotelyricinfodto.cpp
 delete mode 100644 core/src/dto/responseprofile.cpp
 create mode 100644 core/src/dto/restartrequiredmessage.cpp
 create mode 100644 core/src/dto/scheduledtaskendedmessage.cpp
 create mode 100644 core/src/dto/scheduledtasksinfomessage.cpp
 create mode 100644 core/src/dto/scheduledtasksinfostartmessage.cpp
 create mode 100644 core/src/dto/scheduledtasksinfostopmessage.cpp
 create mode 100644 core/src/dto/seriestimercancelledmessage.cpp
 create mode 100644 core/src/dto/seriestimercreatedmessage.cpp
 create mode 100644 core/src/dto/serverdiscoveryinfo.cpp
 create mode 100644 core/src/dto/serverrestartingmessage.cpp
 create mode 100644 core/src/dto/servershuttingdownmessage.cpp
 rename core/src/dto/{sessioninfo.cpp => sessioninfodto.cpp} (58%)
 create mode 100644 core/src/dto/sessionmessagetype.cpp
 create mode 100644 core/src/dto/sessionsmessage.cpp
 create mode 100644 core/src/dto/sessionsstartmessage.cpp
 create mode 100644 core/src/dto/sessionsstopmessage.cpp
 rename core/src/dto/{objectgroupupdate.cpp => stringgroupupdate.cpp} (65%)
 create mode 100644 core/src/dto/subtitleoptions.cpp
 create mode 100644 core/src/dto/syncplaycommandmessage.cpp
 create mode 100644 core/src/dto/syncplaygroupupdatecommandmessage.cpp
 create mode 100644 core/src/dto/syncplayqueueitem.cpp
 create mode 100644 core/src/dto/timercancelledmessage.cpp
 create mode 100644 core/src/dto/timercreatedmessage.cpp
 create mode 100644 core/src/dto/tonemappingalgorithm.cpp
 rename core/src/dto/{architecture.cpp => tonemappingmode.cpp} (58%)
 rename core/src/dto/{headermatchtype.cpp => tonemappingrange.cpp} (63%)
 create mode 100644 core/src/dto/trickplayinfo.cpp
 create mode 100644 core/src/dto/trickplayoptions.cpp
 create mode 100644 core/src/dto/trickplayscanbehavior.cpp
 create mode 100644 core/src/dto/updatemediapathrequestdto.cpp
 create mode 100644 core/src/dto/updateplaylistdto.cpp
 create mode 100644 core/src/dto/updateplaylistuserdto.cpp
 delete mode 100644 core/src/dto/updateusereasypassword.cpp
 create mode 100644 core/src/dto/updateuseritemdatadto.cpp
 create mode 100644 core/src/dto/userdatachangedmessage.cpp
 create mode 100644 core/src/dto/userdatachangeinfo.cpp
 create mode 100644 core/src/dto/userdeletedmessage.cpp
 create mode 100644 core/src/dto/userupdatedmessage.cpp
 delete mode 100644 core/src/dto/version.cpp
 rename core/src/dto/{notificationlevel.cpp => videorange.cpp} (62%)
 create mode 100644 core/src/dto/videorangetype.cpp
 create mode 100644 core/src/dto/websocketmessage.cpp
 create mode 100644 core/src/dto/xbmcmetadataoptions.cpp
 create mode 100644 core/src/loader/http/clientlog.cpp
 delete mode 100644 core/src/loader/http/dlna.cpp
 delete mode 100644 core/src/loader/http/imagebyname.cpp
 create mode 100644 core/src/loader/http/lyrics.cpp
 create mode 100644 core/src/loader/http/mediasegments.cpp
 delete mode 100644 core/src/loader/http/notifications.cpp
 create mode 100644 core/src/loader/http/tmdb.cpp
 rename core/src/loader/http/{videohls.cpp => trickplay.cpp} (96%)

diff --git a/core/GeneratedSources.cmake b/core/GeneratedSources.cmake
index de283d0..4abcb60 100644
--- a/core/GeneratedSources.cmake
+++ b/core/GeneratedSources.cmake
@@ -31,291 +31,367 @@ cmake_minimum_required(VERSION 3.0)
 
 ]]
 set(openapi_HEADERS
-	./include/JellyfinQt/dto/loglevel.h
+	./include/JellyfinQt/dto/accessschedule.h
 	./include/JellyfinQt/dto/activitylogentry.h
+	./include/JellyfinQt/dto/activitylogentrymessage.h
 	./include/JellyfinQt/dto/activitylogentryqueryresult.h
+	./include/JellyfinQt/dto/activitylogentrystartmessage.h
+	./include/JellyfinQt/dto/activitylogentrystopmessage.h
+	./include/JellyfinQt/dto/addvirtualfolderdto.h
+	./include/JellyfinQt/dto/albuminfo.h
+	./include/JellyfinQt/dto/albuminforemotesearchquery.h
+	./include/JellyfinQt/dto/allthememediaresult.h
+	./include/JellyfinQt/dto/artistinfo.h
+	./include/JellyfinQt/dto/artistinforemotesearchquery.h
+	./include/JellyfinQt/dto/audiospatialformat.h
+	./include/JellyfinQt/dto/authenticateuserbyname.h
 	./include/JellyfinQt/dto/authenticationinfo.h
 	./include/JellyfinQt/dto/authenticationinfoqueryresult.h
-	./include/JellyfinQt/dto/itemfields.h
-	./include/JellyfinQt/dto/itemfilter.h
-	./include/JellyfinQt/dto/imagetype.h
-	./include/JellyfinQt/dto/video3dformat.h
-	./include/JellyfinQt/dto/externalurl.h
-	./include/JellyfinQt/dto/mediaprotocol.h
-	./include/JellyfinQt/dto/mediasourcetype.h
-	./include/JellyfinQt/dto/videotype.h
-	./include/JellyfinQt/dto/isotype.h
-	./include/JellyfinQt/dto/mediastreamtype.h
-	./include/JellyfinQt/dto/subtitledeliverymethod.h
-	./include/JellyfinQt/dto/mediastream.h
-	./include/JellyfinQt/dto/mediaattachment.h
-	./include/JellyfinQt/dto/transportstreamtimestamp.h
-	./include/JellyfinQt/dto/mediasourceinfo.h
-	./include/JellyfinQt/dto/playaccess.h
-	./include/JellyfinQt/dto/mediaurl.h
-	./include/JellyfinQt/dto/baseitemperson.h
-	./include/JellyfinQt/dto/nameguidpair.h
-	./include/JellyfinQt/dto/useritemdatadto.h
-	./include/JellyfinQt/dto/dayofweek.h
-	./include/JellyfinQt/dto/chapterinfo.h
-	./include/JellyfinQt/dto/locationtype.h
-	./include/JellyfinQt/dto/metadatafield.h
-	./include/JellyfinQt/dto/imageorientation.h
-	./include/JellyfinQt/dto/channeltype.h
-	./include/JellyfinQt/dto/programaudio.h
+	./include/JellyfinQt/dto/authenticationresult.h
 	./include/JellyfinQt/dto/baseitemdto.h
 	./include/JellyfinQt/dto/baseitemdtoqueryresult.h
-	./include/JellyfinQt/dto/encodingcontext.h
-	./include/JellyfinQt/dto/brandingoptions.h
-	./include/JellyfinQt/dto/channelmediatype.h
-	./include/JellyfinQt/dto/channelmediacontenttype.h
-	./include/JellyfinQt/dto/channelitemsortfield.h
-	./include/JellyfinQt/dto/channelfeatures.h
-	./include/JellyfinQt/dto/collectioncreationresult.h
-	./include/JellyfinQt/dto/version.h
-	./include/JellyfinQt/dto/imagesavingconvention.h
-	./include/JellyfinQt/dto/metadataoptions.h
-	./include/JellyfinQt/dto/namevaluepair.h
-	./include/JellyfinQt/dto/repositoryinfo.h
-	./include/JellyfinQt/dto/pathsubstitution.h
-	./include/JellyfinQt/dto/serverconfiguration.h
-	./include/JellyfinQt/dto/mediaencoderpathdto.h
-	./include/JellyfinQt/dto/problemdetails.h
-	./include/JellyfinQt/dto/configurationpagetype.h
-	./include/JellyfinQt/dto/configurationpageinfo.h
-	./include/JellyfinQt/dto/generalcommandtype.h
-	./include/JellyfinQt/dto/headermatchtype.h
-	./include/JellyfinQt/dto/httpheaderinfo.h
-	./include/JellyfinQt/dto/deviceidentification.h
-	./include/JellyfinQt/dto/xmlattribute.h
-	./include/JellyfinQt/dto/dlnaprofiletype.h
-	./include/JellyfinQt/dto/directplayprofile.h
-	./include/JellyfinQt/dto/transcodeseekinfo.h
-	./include/JellyfinQt/dto/transcodingprofile.h
-	./include/JellyfinQt/dto/profileconditiontype.h
-	./include/JellyfinQt/dto/profileconditionvalue.h
-	./include/JellyfinQt/dto/profilecondition.h
-	./include/JellyfinQt/dto/containerprofile.h
-	./include/JellyfinQt/dto/codectype.h
-	./include/JellyfinQt/dto/codecprofile.h
-	./include/JellyfinQt/dto/responseprofile.h
-	./include/JellyfinQt/dto/subtitleprofile.h
-	./include/JellyfinQt/dto/deviceprofile.h
-	./include/JellyfinQt/dto/clientcapabilities.h
-	./include/JellyfinQt/dto/deviceinfo.h
-	./include/JellyfinQt/dto/deviceinfoqueryresult.h
-	./include/JellyfinQt/dto/deviceoptions.h
-	./include/JellyfinQt/dto/scrolldirection.h
-	./include/JellyfinQt/dto/sortorder.h
-	./include/JellyfinQt/dto/displaypreferencesdto.h
-	./include/JellyfinQt/dto/deviceprofiletype.h
-	./include/JellyfinQt/dto/deviceprofileinfo.h
-	./include/JellyfinQt/dto/controlresponse.h
-	./include/JellyfinQt/dto/defaultdirectorybrowserinfodto.h
-	./include/JellyfinQt/dto/filesystementrytype.h
-	./include/JellyfinQt/dto/filesystementryinfo.h
-	./include/JellyfinQt/dto/validatepathdto.h
-	./include/JellyfinQt/dto/queryfilterslegacy.h
-	./include/JellyfinQt/dto/queryfilters.h
-	./include/JellyfinQt/dto/imageformat.h
-	./include/JellyfinQt/dto/imageinfo.h
-	./include/JellyfinQt/dto/imagebynameinfo.h
-	./include/JellyfinQt/dto/externalidmediatype.h
-	./include/JellyfinQt/dto/externalidinfo.h
-	./include/JellyfinQt/dto/remotesearchresult.h
+	./include/JellyfinQt/dto/baseitemkind.h
+	./include/JellyfinQt/dto/baseitemperson.h
+	./include/JellyfinQt/dto/basepluginconfiguration.h
 	./include/JellyfinQt/dto/bookinfo.h
 	./include/JellyfinQt/dto/bookinforemotesearchquery.h
 	./include/JellyfinQt/dto/boxsetinfo.h
 	./include/JellyfinQt/dto/boxsetinforemotesearchquery.h
+	./include/JellyfinQt/dto/brandingoptions.h
+	./include/JellyfinQt/dto/bufferrequestdto.h
+	./include/JellyfinQt/dto/castreceiverapplication.h
+	./include/JellyfinQt/dto/channelfeatures.h
+	./include/JellyfinQt/dto/channelitemsortfield.h
+	./include/JellyfinQt/dto/channelmappingoptionsdto.h
+	./include/JellyfinQt/dto/channelmediacontenttype.h
+	./include/JellyfinQt/dto/channelmediatype.h
+	./include/JellyfinQt/dto/channeltype.h
+	./include/JellyfinQt/dto/chapterinfo.h
+	./include/JellyfinQt/dto/clientcapabilitiesdto.h
+	./include/JellyfinQt/dto/clientlogdocumentresponsedto.h
+	./include/JellyfinQt/dto/codecprofile.h
+	./include/JellyfinQt/dto/codectype.h
+	./include/JellyfinQt/dto/collectioncreationresult.h
+	./include/JellyfinQt/dto/collectiontype.h
+	./include/JellyfinQt/dto/collectiontypeoptions.h
+	./include/JellyfinQt/dto/configimagetypes.h
+	./include/JellyfinQt/dto/configurationpageinfo.h
+	./include/JellyfinQt/dto/containerprofile.h
+	./include/JellyfinQt/dto/countryinfo.h
+	./include/JellyfinQt/dto/createplaylistdto.h
+	./include/JellyfinQt/dto/createuserbyname.h
+	./include/JellyfinQt/dto/culturedto.h
+	./include/JellyfinQt/dto/dayofweek.h
+	./include/JellyfinQt/dto/daypattern.h
+	./include/JellyfinQt/dto/defaultdirectorybrowserinfodto.h
+	./include/JellyfinQt/dto/deinterlacemethod.h
+	./include/JellyfinQt/dto/deviceinfodto.h
+	./include/JellyfinQt/dto/deviceinfodtoqueryresult.h
+	./include/JellyfinQt/dto/deviceoptionsdto.h
+	./include/JellyfinQt/dto/deviceprofile.h
+	./include/JellyfinQt/dto/directplayprofile.h
+	./include/JellyfinQt/dto/displaypreferencesdto.h
+	./include/JellyfinQt/dto/dlnaprofiletype.h
+	./include/JellyfinQt/dto/downmixstereoalgorithms.h
+	./include/JellyfinQt/dto/dynamicdayofweek.h
+	./include/JellyfinQt/dto/embeddedsubtitleoptions.h
+	./include/JellyfinQt/dto/encoderpreset.h
+	./include/JellyfinQt/dto/encodingcontext.h
+	./include/JellyfinQt/dto/encodingoptions.h
+	./include/JellyfinQt/dto/endpointinfo.h
+	./include/JellyfinQt/dto/externalidinfo.h
+	./include/JellyfinQt/dto/externalidmediatype.h
+	./include/JellyfinQt/dto/externalurl.h
+	./include/JellyfinQt/dto/extratype.h
+	./include/JellyfinQt/dto/filesystementryinfo.h
+	./include/JellyfinQt/dto/filesystementrytype.h
+	./include/JellyfinQt/dto/fontfile.h
+	./include/JellyfinQt/dto/forcekeepalivemessage.h
+	./include/JellyfinQt/dto/forgotpasswordaction.h
+	./include/JellyfinQt/dto/forgotpassworddto.h
+	./include/JellyfinQt/dto/forgotpasswordpindto.h
+	./include/JellyfinQt/dto/forgotpasswordresult.h
+	./include/JellyfinQt/dto/generalcommand.h
+	./include/JellyfinQt/dto/generalcommandmessage.h
+	./include/JellyfinQt/dto/generalcommandtype.h
+	./include/JellyfinQt/dto/getprogramsdto.h
+	./include/JellyfinQt/dto/groupinfodto.h
+	./include/JellyfinQt/dto/groupinfodtogroupupdate.h
+	./include/JellyfinQt/dto/groupqueuemode.h
+	./include/JellyfinQt/dto/grouprepeatmode.h
+	./include/JellyfinQt/dto/groupshufflemode.h
+	./include/JellyfinQt/dto/groupstatetype.h
+	./include/JellyfinQt/dto/groupstateupdate.h
+	./include/JellyfinQt/dto/groupstateupdategroupupdate.h
+	./include/JellyfinQt/dto/groupupdate.h
+	./include/JellyfinQt/dto/groupupdatetype.h
+	./include/JellyfinQt/dto/guideinfo.h
+	./include/JellyfinQt/dto/hardwareaccelerationtype.h
+	./include/JellyfinQt/dto/ignorewaitrequestdto.h
+	./include/JellyfinQt/dto/imageformat.h
+	./include/JellyfinQt/dto/imageinfo.h
+	./include/JellyfinQt/dto/imageoption.h
+	./include/JellyfinQt/dto/imageorientation.h
+	./include/JellyfinQt/dto/imageproviderinfo.h
+	./include/JellyfinQt/dto/imageresolution.h
+	./include/JellyfinQt/dto/imagesavingconvention.h
+	./include/JellyfinQt/dto/imagetype.h
+	./include/JellyfinQt/dto/inboundkeepalivemessage.h
+	./include/JellyfinQt/dto/inboundwebsocketmessage.h
+	./include/JellyfinQt/dto/installationinfo.h
+	./include/JellyfinQt/dto/iplugin.h
+	./include/JellyfinQt/dto/isotype.h
+	./include/JellyfinQt/dto/itemcounts.h
+	./include/JellyfinQt/dto/itemfields.h
+	./include/JellyfinQt/dto/itemfilter.h
+	./include/JellyfinQt/dto/itemsortby.h
+	./include/JellyfinQt/dto/joingrouprequestdto.h
+	./include/JellyfinQt/dto/keepuntil.h
+	./include/JellyfinQt/dto/librarychangedmessage.h
+	./include/JellyfinQt/dto/libraryoptioninfodto.h
+	./include/JellyfinQt/dto/libraryoptions.h
+	./include/JellyfinQt/dto/libraryoptionsresultdto.h
+	./include/JellyfinQt/dto/librarytypeoptionsdto.h
+	./include/JellyfinQt/dto/libraryupdateinfo.h
+	./include/JellyfinQt/dto/listingsproviderinfo.h
+	./include/JellyfinQt/dto/livestreamresponse.h
+	./include/JellyfinQt/dto/livetvinfo.h
+	./include/JellyfinQt/dto/livetvoptions.h
+	./include/JellyfinQt/dto/livetvserviceinfo.h
+	./include/JellyfinQt/dto/livetvservicestatus.h
+	./include/JellyfinQt/dto/localizationoption.h
+	./include/JellyfinQt/dto/locationtype.h
+	./include/JellyfinQt/dto/logfile.h
+	./include/JellyfinQt/dto/loglevel.h
+	./include/JellyfinQt/dto/lyricdto.h
+	./include/JellyfinQt/dto/lyricline.h
+	./include/JellyfinQt/dto/lyricmetadata.h
+	./include/JellyfinQt/dto/mediaattachment.h
+	./include/JellyfinQt/dto/mediapathdto.h
+	./include/JellyfinQt/dto/mediapathinfo.h
+	./include/JellyfinQt/dto/mediaprotocol.h
+	./include/JellyfinQt/dto/mediasegmentdto.h
+	./include/JellyfinQt/dto/mediasegmentdtoqueryresult.h
+	./include/JellyfinQt/dto/mediasegmenttype.h
+	./include/JellyfinQt/dto/mediasourceinfo.h
+	./include/JellyfinQt/dto/mediasourcetype.h
+	./include/JellyfinQt/dto/mediastream.h
+	./include/JellyfinQt/dto/mediastreamprotocol.h
+	./include/JellyfinQt/dto/mediastreamtype.h
+	./include/JellyfinQt/dto/mediatype.h
+	./include/JellyfinQt/dto/mediaupdateinfodto.h
+	./include/JellyfinQt/dto/mediaupdateinfopathdto.h
+	./include/JellyfinQt/dto/mediaurl.h
+	./include/JellyfinQt/dto/messagecommand.h
+	./include/JellyfinQt/dto/metadataconfiguration.h
+	./include/JellyfinQt/dto/metadataeditorinfo.h
+	./include/JellyfinQt/dto/metadatafield.h
+	./include/JellyfinQt/dto/metadataoptions.h
+	./include/JellyfinQt/dto/metadatarefreshmode.h
+	./include/JellyfinQt/dto/moveplaylistitemrequestdto.h
 	./include/JellyfinQt/dto/movieinfo.h
 	./include/JellyfinQt/dto/movieinforemotesearchquery.h
-	./include/JellyfinQt/dto/songinfo.h
-	./include/JellyfinQt/dto/albuminfo.h
-	./include/JellyfinQt/dto/albuminforemotesearchquery.h
-	./include/JellyfinQt/dto/artistinfo.h
-	./include/JellyfinQt/dto/artistinforemotesearchquery.h
 	./include/JellyfinQt/dto/musicvideoinfo.h
 	./include/JellyfinQt/dto/musicvideoinforemotesearchquery.h
-	./include/JellyfinQt/dto/personlookupinfo.h
-	./include/JellyfinQt/dto/personlookupinforemotesearchquery.h
-	./include/JellyfinQt/dto/seriesinfo.h
-	./include/JellyfinQt/dto/seriesinforemotesearchquery.h
-	./include/JellyfinQt/dto/trailerinfo.h
-	./include/JellyfinQt/dto/trailerinforemotesearchquery.h
-	./include/JellyfinQt/dto/metadatarefreshmode.h
-	./include/JellyfinQt/dto/seriesstatus.h
-	./include/JellyfinQt/dto/parentalrating.h
-	./include/JellyfinQt/dto/countryinfo.h
-	./include/JellyfinQt/dto/culturedto.h
-	./include/JellyfinQt/dto/metadataeditorinfo.h
-	./include/JellyfinQt/dto/thememediaresult.h
-	./include/JellyfinQt/dto/allthememediaresult.h
-	./include/JellyfinQt/dto/itemcounts.h
-	./include/JellyfinQt/dto/libraryoptioninfodto.h
-	./include/JellyfinQt/dto/imageoption.h
-	./include/JellyfinQt/dto/librarytypeoptionsdto.h
-	./include/JellyfinQt/dto/libraryoptionsresultdto.h
-	./include/JellyfinQt/dto/mediaupdateinfodto.h
-	./include/JellyfinQt/dto/mediapathinfo.h
-	./include/JellyfinQt/dto/typeoptions.h
-	./include/JellyfinQt/dto/libraryoptions.h
-	./include/JellyfinQt/dto/virtualfolderinfo.h
-	./include/JellyfinQt/dto/addvirtualfolderdto.h
-	./include/JellyfinQt/dto/updatelibraryoptionsdto.h
-	./include/JellyfinQt/dto/mediapathdto.h
-	./include/JellyfinQt/dto/tunerchannelmapping.h
+	./include/JellyfinQt/dto/nameguidpair.h
 	./include/JellyfinQt/dto/nameidpair.h
-	./include/JellyfinQt/dto/channelmappingoptionsdto.h
-	./include/JellyfinQt/dto/setchannelmappingdto.h
-	./include/JellyfinQt/dto/guideinfo.h
-	./include/JellyfinQt/dto/livetvservicestatus.h
-	./include/JellyfinQt/dto/livetvserviceinfo.h
-	./include/JellyfinQt/dto/livetvinfo.h
-	./include/JellyfinQt/dto/listingsproviderinfo.h
-	./include/JellyfinQt/dto/getprogramsdto.h
-	./include/JellyfinQt/dto/recordingstatus.h
-	./include/JellyfinQt/dto/keepuntil.h
-	./include/JellyfinQt/dto/daypattern.h
-	./include/JellyfinQt/dto/seriestimerinfodto.h
-	./include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h
-	./include/JellyfinQt/dto/timerinfodto.h
-	./include/JellyfinQt/dto/timerinfodtoqueryresult.h
-	./include/JellyfinQt/dto/tunerhostinfo.h
-	./include/JellyfinQt/dto/localizationoption.h
-	./include/JellyfinQt/dto/playbackerrorcode.h
-	./include/JellyfinQt/dto/playbackinforesponse.h
-	./include/JellyfinQt/dto/playbackinfodto.h
-	./include/JellyfinQt/dto/openlivestreamdto.h
-	./include/JellyfinQt/dto/livestreamresponse.h
-	./include/JellyfinQt/dto/recommendationtype.h
-	./include/JellyfinQt/dto/recommendationdto.h
-	./include/JellyfinQt/dto/notificationlevel.h
-	./include/JellyfinQt/dto/notificationdto.h
-	./include/JellyfinQt/dto/notificationresultdto.h
-	./include/JellyfinQt/dto/notificationssummarydto.h
-	./include/JellyfinQt/dto/notificationtypeinfo.h
-	./include/JellyfinQt/dto/versioninfo.h
-	./include/JellyfinQt/dto/packageinfo.h
-	./include/JellyfinQt/dto/createplaylistdto.h
-	./include/JellyfinQt/dto/playlistcreationresult.h
-	./include/JellyfinQt/dto/playmethod.h
-	./include/JellyfinQt/dto/repeatmode.h
-	./include/JellyfinQt/dto/queueitem.h
-	./include/JellyfinQt/dto/playbackstartinfo.h
-	./include/JellyfinQt/dto/playbackprogressinfo.h
-	./include/JellyfinQt/dto/playbackstopinfo.h
-	./include/JellyfinQt/dto/pluginstatus.h
-	./include/JellyfinQt/dto/plugininfo.h
-	./include/JellyfinQt/dto/basepluginconfiguration.h
-	./include/JellyfinQt/dto/pluginsecurityinfo.h
-	./include/JellyfinQt/dto/quickconnectstate.h
-	./include/JellyfinQt/dto/quickconnectresult.h
-	./include/JellyfinQt/dto/ratingtype.h
-	./include/JellyfinQt/dto/remoteimageinfo.h
-	./include/JellyfinQt/dto/remoteimageresult.h
-	./include/JellyfinQt/dto/imageproviderinfo.h
-	./include/JellyfinQt/dto/taskstate.h
-	./include/JellyfinQt/dto/taskcompletionstatus.h
-	./include/JellyfinQt/dto/taskresult.h
-	./include/JellyfinQt/dto/tasktriggerinfo.h
-	./include/JellyfinQt/dto/taskinfo.h
-	./include/JellyfinQt/dto/searchhint.h
-	./include/JellyfinQt/dto/searchhintresult.h
-	./include/JellyfinQt/dto/playerstateinfo.h
-	./include/JellyfinQt/dto/sessionuserinfo.h
-	./include/JellyfinQt/dto/baseitem.h
-	./include/JellyfinQt/dto/transcodereason.h
-	./include/JellyfinQt/dto/transcodinginfo.h
-	./include/JellyfinQt/dto/sessioninfo.h
-	./include/JellyfinQt/dto/generalcommand.h
-	./include/JellyfinQt/dto/playcommand.h
-	./include/JellyfinQt/dto/playstatecommand.h
-	./include/JellyfinQt/dto/clientcapabilitiesdto.h
-	./include/JellyfinQt/dto/startupconfigurationdto.h
-	./include/JellyfinQt/dto/startupuserdto.h
-	./include/JellyfinQt/dto/startupremoteaccessdto.h
-	./include/JellyfinQt/dto/fontfile.h
-	./include/JellyfinQt/dto/remotesubtitleinfo.h
-	./include/JellyfinQt/dto/uploadsubtitledto.h
-	./include/JellyfinQt/dto/bufferrequestdto.h
-	./include/JellyfinQt/dto/joingrouprequestdto.h
-	./include/JellyfinQt/dto/groupstatetype.h
-	./include/JellyfinQt/dto/groupinfodto.h
-	./include/JellyfinQt/dto/moveplaylistitemrequestdto.h
+	./include/JellyfinQt/dto/namevaluepair.h
+	./include/JellyfinQt/dto/networkconfiguration.h
 	./include/JellyfinQt/dto/newgrouprequestdto.h
 	./include/JellyfinQt/dto/nextitemrequestdto.h
+	./include/JellyfinQt/dto/openlivestreamdto.h
+	./include/JellyfinQt/dto/outboundkeepalivemessage.h
+	./include/JellyfinQt/dto/outboundwebsocketmessage.h
+	./include/JellyfinQt/dto/packageinfo.h
+	./include/JellyfinQt/dto/parentalrating.h
+	./include/JellyfinQt/dto/pathsubstitution.h
+	./include/JellyfinQt/dto/personkind.h
+	./include/JellyfinQt/dto/personlookupinfo.h
+	./include/JellyfinQt/dto/personlookupinforemotesearchquery.h
 	./include/JellyfinQt/dto/pingrequestdto.h
-	./include/JellyfinQt/dto/previousitemrequestdto.h
-	./include/JellyfinQt/dto/groupqueuemode.h
-	./include/JellyfinQt/dto/queuerequestdto.h
-	./include/JellyfinQt/dto/readyrequestdto.h
-	./include/JellyfinQt/dto/removefromplaylistrequestdto.h
-	./include/JellyfinQt/dto/seekrequestdto.h
-	./include/JellyfinQt/dto/ignorewaitrequestdto.h
-	./include/JellyfinQt/dto/playrequestdto.h
-	./include/JellyfinQt/dto/setplaylistitemrequestdto.h
-	./include/JellyfinQt/dto/grouprepeatmode.h
-	./include/JellyfinQt/dto/setrepeatmoderequestdto.h
-	./include/JellyfinQt/dto/groupshufflemode.h
-	./include/JellyfinQt/dto/setshufflemoderequestdto.h
-	./include/JellyfinQt/dto/endpointinfo.h
-	./include/JellyfinQt/dto/installationinfo.h
-	./include/JellyfinQt/dto/ffmpeglocation.h
-	./include/JellyfinQt/dto/architecture.h
-	./include/JellyfinQt/dto/systeminfo.h
-	./include/JellyfinQt/dto/publicsysteminfo.h
-	./include/JellyfinQt/dto/logfile.h
-	./include/JellyfinQt/dto/wakeonlaninfo.h
-	./include/JellyfinQt/dto/utctimeresponse.h
-	./include/JellyfinQt/dto/subtitleplaybackmode.h
-	./include/JellyfinQt/dto/userconfiguration.h
-	./include/JellyfinQt/dto/dynamicdayofweek.h
-	./include/JellyfinQt/dto/accessschedule.h
-	./include/JellyfinQt/dto/unrateditem.h
-	./include/JellyfinQt/dto/syncplayuseraccesstype.h
-	./include/JellyfinQt/dto/userpolicy.h
-	./include/JellyfinQt/dto/userdto.h
-	./include/JellyfinQt/dto/authenticationresult.h
-	./include/JellyfinQt/dto/updateusereasypassword.h
-	./include/JellyfinQt/dto/updateuserpassword.h
-	./include/JellyfinQt/dto/authenticateuserbyname.h
-	./include/JellyfinQt/dto/quickconnectdto.h
-	./include/JellyfinQt/dto/forgotpassworddto.h
-	./include/JellyfinQt/dto/forgotpasswordaction.h
-	./include/JellyfinQt/dto/forgotpasswordresult.h
 	./include/JellyfinQt/dto/pinredeemresult.h
-	./include/JellyfinQt/dto/createuserbyname.h
-	./include/JellyfinQt/dto/specialviewoptiondto.h
-	./include/JellyfinQt/dto/libraryupdateinfo.h
-	./include/JellyfinQt/dto/iplugin.h
+	./include/JellyfinQt/dto/playaccess.h
+	./include/JellyfinQt/dto/playbackerrorcode.h
+	./include/JellyfinQt/dto/playbackinfodto.h
+	./include/JellyfinQt/dto/playbackinforesponse.h
+	./include/JellyfinQt/dto/playbackorder.h
+	./include/JellyfinQt/dto/playbackprogressinfo.h
+	./include/JellyfinQt/dto/playbackrequesttype.h
+	./include/JellyfinQt/dto/playbackstartinfo.h
+	./include/JellyfinQt/dto/playbackstopinfo.h
+	./include/JellyfinQt/dto/playcommand.h
+	./include/JellyfinQt/dto/playerstateinfo.h
+	./include/JellyfinQt/dto/playlistcreationresult.h
+	./include/JellyfinQt/dto/playlistdto.h
+	./include/JellyfinQt/dto/playlistuserpermissions.h
+	./include/JellyfinQt/dto/playmessage.h
+	./include/JellyfinQt/dto/playmethod.h
+	./include/JellyfinQt/dto/playqueueupdate.h
+	./include/JellyfinQt/dto/playqueueupdategroupupdate.h
+	./include/JellyfinQt/dto/playqueueupdatereason.h
 	./include/JellyfinQt/dto/playrequest.h
+	./include/JellyfinQt/dto/playrequestdto.h
+	./include/JellyfinQt/dto/playstatecommand.h
+	./include/JellyfinQt/dto/playstatemessage.h
 	./include/JellyfinQt/dto/playstaterequest.h
-	./include/JellyfinQt/dto/timereventinfo.h
-	./include/JellyfinQt/dto/sendcommandtype.h
+	./include/JellyfinQt/dto/plugininfo.h
+	./include/JellyfinQt/dto/plugininstallationcancelledmessage.h
+	./include/JellyfinQt/dto/plugininstallationcompletedmessage.h
+	./include/JellyfinQt/dto/plugininstallationfailedmessage.h
+	./include/JellyfinQt/dto/plugininstallingmessage.h
+	./include/JellyfinQt/dto/pluginstatus.h
+	./include/JellyfinQt/dto/pluginuninstalledmessage.h
+	./include/JellyfinQt/dto/previousitemrequestdto.h
+	./include/JellyfinQt/dto/problemdetails.h
+	./include/JellyfinQt/dto/processpriorityclass.h
+	./include/JellyfinQt/dto/profilecondition.h
+	./include/JellyfinQt/dto/profileconditiontype.h
+	./include/JellyfinQt/dto/profileconditionvalue.h
+	./include/JellyfinQt/dto/programaudio.h
+	./include/JellyfinQt/dto/publicsysteminfo.h
+	./include/JellyfinQt/dto/queryfilters.h
+	./include/JellyfinQt/dto/queryfilterslegacy.h
+	./include/JellyfinQt/dto/queueitem.h
+	./include/JellyfinQt/dto/queuerequestdto.h
+	./include/JellyfinQt/dto/quickconnectdto.h
+	./include/JellyfinQt/dto/quickconnectresult.h
+	./include/JellyfinQt/dto/ratingtype.h
+	./include/JellyfinQt/dto/readyrequestdto.h
+	./include/JellyfinQt/dto/recommendationdto.h
+	./include/JellyfinQt/dto/recommendationtype.h
+	./include/JellyfinQt/dto/recordingstatus.h
+	./include/JellyfinQt/dto/refreshprogressmessage.h
+	./include/JellyfinQt/dto/remoteimageinfo.h
+	./include/JellyfinQt/dto/remoteimageresult.h
+	./include/JellyfinQt/dto/remotelyricinfodto.h
+	./include/JellyfinQt/dto/remotesearchresult.h
+	./include/JellyfinQt/dto/remotesubtitleinfo.h
+	./include/JellyfinQt/dto/removefromplaylistrequestdto.h
+	./include/JellyfinQt/dto/repeatmode.h
+	./include/JellyfinQt/dto/repositoryinfo.h
+	./include/JellyfinQt/dto/restartrequiredmessage.h
+	./include/JellyfinQt/dto/scheduledtaskendedmessage.h
+	./include/JellyfinQt/dto/scheduledtasksinfomessage.h
+	./include/JellyfinQt/dto/scheduledtasksinfostartmessage.h
+	./include/JellyfinQt/dto/scheduledtasksinfostopmessage.h
+	./include/JellyfinQt/dto/scrolldirection.h
+	./include/JellyfinQt/dto/searchhint.h
+	./include/JellyfinQt/dto/searchhintresult.h
+	./include/JellyfinQt/dto/seekrequestdto.h
 	./include/JellyfinQt/dto/sendcommand.h
-	./include/JellyfinQt/dto/groupupdatetype.h
-	./include/JellyfinQt/dto/objectgroupupdate.h
+	./include/JellyfinQt/dto/sendcommandtype.h
+	./include/JellyfinQt/dto/seriesinfo.h
+	./include/JellyfinQt/dto/seriesinforemotesearchquery.h
+	./include/JellyfinQt/dto/seriesstatus.h
+	./include/JellyfinQt/dto/seriestimercancelledmessage.h
+	./include/JellyfinQt/dto/seriestimercreatedmessage.h
+	./include/JellyfinQt/dto/seriestimerinfodto.h
+	./include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h
+	./include/JellyfinQt/dto/serverconfiguration.h
+	./include/JellyfinQt/dto/serverdiscoveryinfo.h
+	./include/JellyfinQt/dto/serverrestartingmessage.h
+	./include/JellyfinQt/dto/servershuttingdownmessage.h
+	./include/JellyfinQt/dto/sessioninfodto.h
+	./include/JellyfinQt/dto/sessionmessagetype.h
+	./include/JellyfinQt/dto/sessionsmessage.h
+	./include/JellyfinQt/dto/sessionsstartmessage.h
+	./include/JellyfinQt/dto/sessionsstopmessage.h
+	./include/JellyfinQt/dto/sessionuserinfo.h
+	./include/JellyfinQt/dto/setchannelmappingdto.h
+	./include/JellyfinQt/dto/setplaylistitemrequestdto.h
+	./include/JellyfinQt/dto/setrepeatmoderequestdto.h
+	./include/JellyfinQt/dto/setshufflemoderequestdto.h
+	./include/JellyfinQt/dto/songinfo.h
+	./include/JellyfinQt/dto/sortorder.h
+	./include/JellyfinQt/dto/specialviewoptiondto.h
+	./include/JellyfinQt/dto/startupconfigurationdto.h
+	./include/JellyfinQt/dto/startupremoteaccessdto.h
+	./include/JellyfinQt/dto/startupuserdto.h
+	./include/JellyfinQt/dto/stringgroupupdate.h
+	./include/JellyfinQt/dto/subtitledeliverymethod.h
+	./include/JellyfinQt/dto/subtitleoptions.h
+	./include/JellyfinQt/dto/subtitleplaybackmode.h
+	./include/JellyfinQt/dto/subtitleprofile.h
+	./include/JellyfinQt/dto/syncplaycommandmessage.h
+	./include/JellyfinQt/dto/syncplaygroupupdatecommandmessage.h
+	./include/JellyfinQt/dto/syncplayqueueitem.h
+	./include/JellyfinQt/dto/syncplayuseraccesstype.h
+	./include/JellyfinQt/dto/systeminfo.h
+	./include/JellyfinQt/dto/taskcompletionstatus.h
+	./include/JellyfinQt/dto/taskinfo.h
+	./include/JellyfinQt/dto/taskresult.h
+	./include/JellyfinQt/dto/taskstate.h
+	./include/JellyfinQt/dto/tasktriggerinfo.h
+	./include/JellyfinQt/dto/thememediaresult.h
+	./include/JellyfinQt/dto/timercancelledmessage.h
+	./include/JellyfinQt/dto/timercreatedmessage.h
+	./include/JellyfinQt/dto/timereventinfo.h
+	./include/JellyfinQt/dto/timerinfodto.h
+	./include/JellyfinQt/dto/timerinfodtoqueryresult.h
+	./include/JellyfinQt/dto/tonemappingalgorithm.h
+	./include/JellyfinQt/dto/tonemappingmode.h
+	./include/JellyfinQt/dto/tonemappingrange.h
+	./include/JellyfinQt/dto/trailerinfo.h
+	./include/JellyfinQt/dto/trailerinforemotesearchquery.h
+	./include/JellyfinQt/dto/transcodereason.h
+	./include/JellyfinQt/dto/transcodeseekinfo.h
+	./include/JellyfinQt/dto/transcodinginfo.h
+	./include/JellyfinQt/dto/transcodingprofile.h
+	./include/JellyfinQt/dto/transportstreamtimestamp.h
+	./include/JellyfinQt/dto/trickplayinfo.h
+	./include/JellyfinQt/dto/trickplayoptions.h
+	./include/JellyfinQt/dto/trickplayscanbehavior.h
+	./include/JellyfinQt/dto/tunerchannelmapping.h
+	./include/JellyfinQt/dto/tunerhostinfo.h
+	./include/JellyfinQt/dto/typeoptions.h
+	./include/JellyfinQt/dto/unrateditem.h
+	./include/JellyfinQt/dto/updatelibraryoptionsdto.h
+	./include/JellyfinQt/dto/updatemediapathrequestdto.h
+	./include/JellyfinQt/dto/updateplaylistdto.h
+	./include/JellyfinQt/dto/updateplaylistuserdto.h
+	./include/JellyfinQt/dto/updateuseritemdatadto.h
+	./include/JellyfinQt/dto/updateuserpassword.h
+	./include/JellyfinQt/dto/uploadsubtitledto.h
+	./include/JellyfinQt/dto/userconfiguration.h
+	./include/JellyfinQt/dto/userdatachangedmessage.h
+	./include/JellyfinQt/dto/userdatachangeinfo.h
+	./include/JellyfinQt/dto/userdeletedmessage.h
+	./include/JellyfinQt/dto/userdto.h
+	./include/JellyfinQt/dto/useritemdatadto.h
+	./include/JellyfinQt/dto/userpolicy.h
+	./include/JellyfinQt/dto/userupdatedmessage.h
+	./include/JellyfinQt/dto/utctimeresponse.h
+	./include/JellyfinQt/dto/validatepathdto.h
+	./include/JellyfinQt/dto/versioninfo.h
+	./include/JellyfinQt/dto/video3dformat.h
+	./include/JellyfinQt/dto/videorange.h
+	./include/JellyfinQt/dto/videorangetype.h
+	./include/JellyfinQt/dto/videotype.h
+	./include/JellyfinQt/dto/virtualfolderinfo.h
+	./include/JellyfinQt/dto/wakeonlaninfo.h
+	./include/JellyfinQt/dto/websocketmessage.h
+	./include/JellyfinQt/dto/xbmcmetadataoptions.h
 	./include/JellyfinQt/loader/http/subtitle.h
 	./include/JellyfinQt/loader/http/activitylog.h
 	./include/JellyfinQt/loader/http/library.h
 	./include/JellyfinQt/loader/http/items.h
 	./include/JellyfinQt/loader/http/dynamichls.h
-	./include/JellyfinQt/loader/http/videoattachments.h
+	./include/JellyfinQt/loader/http/clientlog.h
+	./include/JellyfinQt/loader/http/mediasegments.h
 	./include/JellyfinQt/loader/http/itemupdate.h
+	./include/JellyfinQt/loader/http/videoattachments.h
 	./include/JellyfinQt/loader/http/audio.h
 	./include/JellyfinQt/loader/http/persons.h
 	./include/JellyfinQt/loader/http/collection.h
-	./include/JellyfinQt/loader/http/dlnaserver.h
+	./include/JellyfinQt/loader/http/startup.h
 	./include/JellyfinQt/loader/http/movies.h
 	./include/JellyfinQt/loader/http/dashboard.h
 	./include/JellyfinQt/loader/http/hlssegment.h
 	./include/JellyfinQt/loader/http/branding.h
-	./include/JellyfinQt/loader/http/startup.h
+	./include/JellyfinQt/loader/http/system.h
 	./include/JellyfinQt/loader/http/channels.h
 	./include/JellyfinQt/loader/http/localization.h
-	./include/JellyfinQt/loader/http/videohls.h
 	./include/JellyfinQt/loader/http/itemlookup.h
-	./include/JellyfinQt/loader/http/system.h
 	./include/JellyfinQt/loader/http/mediainfo.h
 	./include/JellyfinQt/loader/http/genres.h
 	./include/JellyfinQt/loader/http/syncplay.h
@@ -323,7 +399,6 @@ set(openapi_HEADERS
 	./include/JellyfinQt/loader/http/suggestions.h
 	./include/JellyfinQt/loader/http/itemrefresh.h
 	./include/JellyfinQt/loader/http/scheduledtasks.h
-	./include/JellyfinQt/loader/http/imagebyname.h
 	./include/JellyfinQt/loader/http/musicgenres.h
 	./include/JellyfinQt/loader/http/user.h
 	./include/JellyfinQt/loader/http/playlists.h
@@ -333,7 +408,6 @@ set(openapi_HEADERS
 	./include/JellyfinQt/loader/http/trailers.h
 	./include/JellyfinQt/loader/http/image.h
 	./include/JellyfinQt/loader/http/librarystructure.h
-	./include/JellyfinQt/loader/http/notifications.h
 	./include/JellyfinQt/loader/http/videos.h
 	./include/JellyfinQt/loader/http/package.h
 	./include/JellyfinQt/loader/http/artists.h
@@ -341,308 +415,386 @@ set(openapi_HEADERS
 	./include/JellyfinQt/loader/http/quickconnect.h
 	./include/JellyfinQt/loader/http/remoteimage.h
 	./include/JellyfinQt/loader/http/userlibrary.h
-	./include/JellyfinQt/loader/http/dlna.h
+	./include/JellyfinQt/loader/http/tmdb.h
 	./include/JellyfinQt/loader/http/configuration.h
 	./include/JellyfinQt/loader/http/livetv.h
 	./include/JellyfinQt/loader/http/timesync.h
 	./include/JellyfinQt/loader/http/session.h
 	./include/JellyfinQt/loader/http/displaypreferences.h
 	./include/JellyfinQt/loader/http/instantmix.h
+	./include/JellyfinQt/loader/http/trickplay.h
 	./include/JellyfinQt/loader/http/apikey.h
 	./include/JellyfinQt/loader/http/devices.h
 	./include/JellyfinQt/loader/http/filter.h
 	./include/JellyfinQt/loader/http/tvshows.h
-	./include/JellyfinQt/loader/http/plugins.h
+	./include/JellyfinQt/loader/http/lyrics.h
 	./include/JellyfinQt/loader/http/environment.h
 	./include/JellyfinQt/loader/http/search.h
+	./include/JellyfinQt/loader/http/plugins.h
 	./include/JellyfinQt/loader/requesttypes.h)
 
 set(openapi_SOURCES
-	./src/dto/loglevel.cpp
+	./src/dto/accessschedule.cpp
 	./src/dto/activitylogentry.cpp
+	./src/dto/activitylogentrymessage.cpp
 	./src/dto/activitylogentryqueryresult.cpp
+	./src/dto/activitylogentrystartmessage.cpp
+	./src/dto/activitylogentrystopmessage.cpp
+	./src/dto/addvirtualfolderdto.cpp
+	./src/dto/albuminfo.cpp
+	./src/dto/albuminforemotesearchquery.cpp
+	./src/dto/allthememediaresult.cpp
+	./src/dto/artistinfo.cpp
+	./src/dto/artistinforemotesearchquery.cpp
+	./src/dto/audiospatialformat.cpp
+	./src/dto/authenticateuserbyname.cpp
 	./src/dto/authenticationinfo.cpp
 	./src/dto/authenticationinfoqueryresult.cpp
-	./src/dto/itemfields.cpp
-	./src/dto/itemfilter.cpp
-	./src/dto/imagetype.cpp
-	./src/dto/video3dformat.cpp
-	./src/dto/externalurl.cpp
-	./src/dto/mediaprotocol.cpp
-	./src/dto/mediasourcetype.cpp
-	./src/dto/videotype.cpp
-	./src/dto/isotype.cpp
-	./src/dto/mediastreamtype.cpp
-	./src/dto/subtitledeliverymethod.cpp
-	./src/dto/mediastream.cpp
-	./src/dto/mediaattachment.cpp
-	./src/dto/transportstreamtimestamp.cpp
-	./src/dto/mediasourceinfo.cpp
-	./src/dto/playaccess.cpp
-	./src/dto/mediaurl.cpp
-	./src/dto/baseitemperson.cpp
-	./src/dto/nameguidpair.cpp
-	./src/dto/useritemdatadto.cpp
-	./src/dto/dayofweek.cpp
-	./src/dto/chapterinfo.cpp
-	./src/dto/locationtype.cpp
-	./src/dto/metadatafield.cpp
-	./src/dto/imageorientation.cpp
-	./src/dto/channeltype.cpp
-	./src/dto/programaudio.cpp
+	./src/dto/authenticationresult.cpp
 	./src/dto/baseitemdto.cpp
 	./src/dto/baseitemdtoqueryresult.cpp
-	./src/dto/encodingcontext.cpp
-	./src/dto/brandingoptions.cpp
-	./src/dto/channelmediatype.cpp
-	./src/dto/channelmediacontenttype.cpp
-	./src/dto/channelitemsortfield.cpp
-	./src/dto/channelfeatures.cpp
-	./src/dto/collectioncreationresult.cpp
-	./src/dto/version.cpp
-	./src/dto/imagesavingconvention.cpp
-	./src/dto/metadataoptions.cpp
-	./src/dto/namevaluepair.cpp
-	./src/dto/repositoryinfo.cpp
-	./src/dto/pathsubstitution.cpp
-	./src/dto/serverconfiguration.cpp
-	./src/dto/mediaencoderpathdto.cpp
-	./src/dto/problemdetails.cpp
-	./src/dto/configurationpagetype.cpp
-	./src/dto/configurationpageinfo.cpp
-	./src/dto/generalcommandtype.cpp
-	./src/dto/headermatchtype.cpp
-	./src/dto/httpheaderinfo.cpp
-	./src/dto/deviceidentification.cpp
-	./src/dto/xmlattribute.cpp
-	./src/dto/dlnaprofiletype.cpp
-	./src/dto/directplayprofile.cpp
-	./src/dto/transcodeseekinfo.cpp
-	./src/dto/transcodingprofile.cpp
-	./src/dto/profileconditiontype.cpp
-	./src/dto/profileconditionvalue.cpp
-	./src/dto/profilecondition.cpp
-	./src/dto/containerprofile.cpp
-	./src/dto/codectype.cpp
-	./src/dto/codecprofile.cpp
-	./src/dto/responseprofile.cpp
-	./src/dto/subtitleprofile.cpp
-	./src/dto/deviceprofile.cpp
-	./src/dto/clientcapabilities.cpp
-	./src/dto/deviceinfo.cpp
-	./src/dto/deviceinfoqueryresult.cpp
-	./src/dto/deviceoptions.cpp
-	./src/dto/scrolldirection.cpp
-	./src/dto/sortorder.cpp
-	./src/dto/displaypreferencesdto.cpp
-	./src/dto/deviceprofiletype.cpp
-	./src/dto/deviceprofileinfo.cpp
-	./src/dto/controlresponse.cpp
-	./src/dto/defaultdirectorybrowserinfodto.cpp
-	./src/dto/filesystementrytype.cpp
-	./src/dto/filesystementryinfo.cpp
-	./src/dto/validatepathdto.cpp
-	./src/dto/queryfilterslegacy.cpp
-	./src/dto/queryfilters.cpp
-	./src/dto/imageformat.cpp
-	./src/dto/imageinfo.cpp
-	./src/dto/imagebynameinfo.cpp
-	./src/dto/externalidmediatype.cpp
-	./src/dto/externalidinfo.cpp
-	./src/dto/remotesearchresult.cpp
+	./src/dto/baseitemkind.cpp
+	./src/dto/baseitemperson.cpp
+	./src/dto/basepluginconfiguration.cpp
 	./src/dto/bookinfo.cpp
 	./src/dto/bookinforemotesearchquery.cpp
 	./src/dto/boxsetinfo.cpp
 	./src/dto/boxsetinforemotesearchquery.cpp
+	./src/dto/brandingoptions.cpp
+	./src/dto/bufferrequestdto.cpp
+	./src/dto/castreceiverapplication.cpp
+	./src/dto/channelfeatures.cpp
+	./src/dto/channelitemsortfield.cpp
+	./src/dto/channelmappingoptionsdto.cpp
+	./src/dto/channelmediacontenttype.cpp
+	./src/dto/channelmediatype.cpp
+	./src/dto/channeltype.cpp
+	./src/dto/chapterinfo.cpp
+	./src/dto/clientcapabilitiesdto.cpp
+	./src/dto/clientlogdocumentresponsedto.cpp
+	./src/dto/codecprofile.cpp
+	./src/dto/codectype.cpp
+	./src/dto/collectioncreationresult.cpp
+	./src/dto/collectiontype.cpp
+	./src/dto/collectiontypeoptions.cpp
+	./src/dto/configimagetypes.cpp
+	./src/dto/configurationpageinfo.cpp
+	./src/dto/containerprofile.cpp
+	./src/dto/countryinfo.cpp
+	./src/dto/createplaylistdto.cpp
+	./src/dto/createuserbyname.cpp
+	./src/dto/culturedto.cpp
+	./src/dto/dayofweek.cpp
+	./src/dto/daypattern.cpp
+	./src/dto/defaultdirectorybrowserinfodto.cpp
+	./src/dto/deinterlacemethod.cpp
+	./src/dto/deviceinfodto.cpp
+	./src/dto/deviceinfodtoqueryresult.cpp
+	./src/dto/deviceoptionsdto.cpp
+	./src/dto/deviceprofile.cpp
+	./src/dto/directplayprofile.cpp
+	./src/dto/displaypreferencesdto.cpp
+	./src/dto/dlnaprofiletype.cpp
+	./src/dto/downmixstereoalgorithms.cpp
+	./src/dto/dynamicdayofweek.cpp
+	./src/dto/embeddedsubtitleoptions.cpp
+	./src/dto/encoderpreset.cpp
+	./src/dto/encodingcontext.cpp
+	./src/dto/encodingoptions.cpp
+	./src/dto/endpointinfo.cpp
+	./src/dto/externalidinfo.cpp
+	./src/dto/externalidmediatype.cpp
+	./src/dto/externalurl.cpp
+	./src/dto/extratype.cpp
+	./src/dto/filesystementryinfo.cpp
+	./src/dto/filesystementrytype.cpp
+	./src/dto/fontfile.cpp
+	./src/dto/forcekeepalivemessage.cpp
+	./src/dto/forgotpasswordaction.cpp
+	./src/dto/forgotpassworddto.cpp
+	./src/dto/forgotpasswordpindto.cpp
+	./src/dto/forgotpasswordresult.cpp
+	./src/dto/generalcommand.cpp
+	./src/dto/generalcommandmessage.cpp
+	./src/dto/generalcommandtype.cpp
+	./src/dto/getprogramsdto.cpp
+	./src/dto/groupinfodto.cpp
+	./src/dto/groupinfodtogroupupdate.cpp
+	./src/dto/groupqueuemode.cpp
+	./src/dto/grouprepeatmode.cpp
+	./src/dto/groupshufflemode.cpp
+	./src/dto/groupstatetype.cpp
+	./src/dto/groupstateupdate.cpp
+	./src/dto/groupstateupdategroupupdate.cpp
+	./src/dto/groupupdate.cpp
+	./src/dto/groupupdatetype.cpp
+	./src/dto/guideinfo.cpp
+	./src/dto/hardwareaccelerationtype.cpp
+	./src/dto/ignorewaitrequestdto.cpp
+	./src/dto/imageformat.cpp
+	./src/dto/imageinfo.cpp
+	./src/dto/imageoption.cpp
+	./src/dto/imageorientation.cpp
+	./src/dto/imageproviderinfo.cpp
+	./src/dto/imageresolution.cpp
+	./src/dto/imagesavingconvention.cpp
+	./src/dto/imagetype.cpp
+	./src/dto/inboundkeepalivemessage.cpp
+	./src/dto/inboundwebsocketmessage.cpp
+	./src/dto/installationinfo.cpp
+	./src/dto/iplugin.cpp
+	./src/dto/isotype.cpp
+	./src/dto/itemcounts.cpp
+	./src/dto/itemfields.cpp
+	./src/dto/itemfilter.cpp
+	./src/dto/itemsortby.cpp
+	./src/dto/joingrouprequestdto.cpp
+	./src/dto/keepuntil.cpp
+	./src/dto/librarychangedmessage.cpp
+	./src/dto/libraryoptioninfodto.cpp
+	./src/dto/libraryoptions.cpp
+	./src/dto/libraryoptionsresultdto.cpp
+	./src/dto/librarytypeoptionsdto.cpp
+	./src/dto/libraryupdateinfo.cpp
+	./src/dto/listingsproviderinfo.cpp
+	./src/dto/livestreamresponse.cpp
+	./src/dto/livetvinfo.cpp
+	./src/dto/livetvoptions.cpp
+	./src/dto/livetvserviceinfo.cpp
+	./src/dto/livetvservicestatus.cpp
+	./src/dto/localizationoption.cpp
+	./src/dto/locationtype.cpp
+	./src/dto/logfile.cpp
+	./src/dto/loglevel.cpp
+	./src/dto/lyricdto.cpp
+	./src/dto/lyricline.cpp
+	./src/dto/lyricmetadata.cpp
+	./src/dto/mediaattachment.cpp
+	./src/dto/mediapathdto.cpp
+	./src/dto/mediapathinfo.cpp
+	./src/dto/mediaprotocol.cpp
+	./src/dto/mediasegmentdto.cpp
+	./src/dto/mediasegmentdtoqueryresult.cpp
+	./src/dto/mediasegmenttype.cpp
+	./src/dto/mediasourceinfo.cpp
+	./src/dto/mediasourcetype.cpp
+	./src/dto/mediastream.cpp
+	./src/dto/mediastreamprotocol.cpp
+	./src/dto/mediastreamtype.cpp
+	./src/dto/mediatype.cpp
+	./src/dto/mediaupdateinfodto.cpp
+	./src/dto/mediaupdateinfopathdto.cpp
+	./src/dto/mediaurl.cpp
+	./src/dto/messagecommand.cpp
+	./src/dto/metadataconfiguration.cpp
+	./src/dto/metadataeditorinfo.cpp
+	./src/dto/metadatafield.cpp
+	./src/dto/metadataoptions.cpp
+	./src/dto/metadatarefreshmode.cpp
+	./src/dto/moveplaylistitemrequestdto.cpp
 	./src/dto/movieinfo.cpp
 	./src/dto/movieinforemotesearchquery.cpp
-	./src/dto/songinfo.cpp
-	./src/dto/albuminfo.cpp
-	./src/dto/albuminforemotesearchquery.cpp
-	./src/dto/artistinfo.cpp
-	./src/dto/artistinforemotesearchquery.cpp
 	./src/dto/musicvideoinfo.cpp
 	./src/dto/musicvideoinforemotesearchquery.cpp
-	./src/dto/personlookupinfo.cpp
-	./src/dto/personlookupinforemotesearchquery.cpp
-	./src/dto/seriesinfo.cpp
-	./src/dto/seriesinforemotesearchquery.cpp
-	./src/dto/trailerinfo.cpp
-	./src/dto/trailerinforemotesearchquery.cpp
-	./src/dto/metadatarefreshmode.cpp
-	./src/dto/seriesstatus.cpp
-	./src/dto/parentalrating.cpp
-	./src/dto/countryinfo.cpp
-	./src/dto/culturedto.cpp
-	./src/dto/metadataeditorinfo.cpp
-	./src/dto/thememediaresult.cpp
-	./src/dto/allthememediaresult.cpp
-	./src/dto/itemcounts.cpp
-	./src/dto/libraryoptioninfodto.cpp
-	./src/dto/imageoption.cpp
-	./src/dto/librarytypeoptionsdto.cpp
-	./src/dto/libraryoptionsresultdto.cpp
-	./src/dto/mediaupdateinfodto.cpp
-	./src/dto/mediapathinfo.cpp
-	./src/dto/typeoptions.cpp
-	./src/dto/libraryoptions.cpp
-	./src/dto/virtualfolderinfo.cpp
-	./src/dto/addvirtualfolderdto.cpp
-	./src/dto/updatelibraryoptionsdto.cpp
-	./src/dto/mediapathdto.cpp
-	./src/dto/tunerchannelmapping.cpp
+	./src/dto/nameguidpair.cpp
 	./src/dto/nameidpair.cpp
-	./src/dto/channelmappingoptionsdto.cpp
-	./src/dto/setchannelmappingdto.cpp
-	./src/dto/guideinfo.cpp
-	./src/dto/livetvservicestatus.cpp
-	./src/dto/livetvserviceinfo.cpp
-	./src/dto/livetvinfo.cpp
-	./src/dto/listingsproviderinfo.cpp
-	./src/dto/getprogramsdto.cpp
-	./src/dto/recordingstatus.cpp
-	./src/dto/keepuntil.cpp
-	./src/dto/daypattern.cpp
-	./src/dto/seriestimerinfodto.cpp
-	./src/dto/seriestimerinfodtoqueryresult.cpp
-	./src/dto/timerinfodto.cpp
-	./src/dto/timerinfodtoqueryresult.cpp
-	./src/dto/tunerhostinfo.cpp
-	./src/dto/localizationoption.cpp
-	./src/dto/playbackerrorcode.cpp
-	./src/dto/playbackinforesponse.cpp
-	./src/dto/playbackinfodto.cpp
-	./src/dto/openlivestreamdto.cpp
-	./src/dto/livestreamresponse.cpp
-	./src/dto/recommendationtype.cpp
-	./src/dto/recommendationdto.cpp
-	./src/dto/notificationlevel.cpp
-	./src/dto/notificationdto.cpp
-	./src/dto/notificationresultdto.cpp
-	./src/dto/notificationssummarydto.cpp
-	./src/dto/notificationtypeinfo.cpp
-	./src/dto/versioninfo.cpp
-	./src/dto/packageinfo.cpp
-	./src/dto/createplaylistdto.cpp
-	./src/dto/playlistcreationresult.cpp
-	./src/dto/playmethod.cpp
-	./src/dto/repeatmode.cpp
-	./src/dto/queueitem.cpp
-	./src/dto/playbackstartinfo.cpp
-	./src/dto/playbackprogressinfo.cpp
-	./src/dto/playbackstopinfo.cpp
-	./src/dto/pluginstatus.cpp
-	./src/dto/plugininfo.cpp
-	./src/dto/basepluginconfiguration.cpp
-	./src/dto/pluginsecurityinfo.cpp
-	./src/dto/quickconnectstate.cpp
-	./src/dto/quickconnectresult.cpp
-	./src/dto/ratingtype.cpp
-	./src/dto/remoteimageinfo.cpp
-	./src/dto/remoteimageresult.cpp
-	./src/dto/imageproviderinfo.cpp
-	./src/dto/taskstate.cpp
-	./src/dto/taskcompletionstatus.cpp
-	./src/dto/taskresult.cpp
-	./src/dto/tasktriggerinfo.cpp
-	./src/dto/taskinfo.cpp
-	./src/dto/searchhint.cpp
-	./src/dto/searchhintresult.cpp
-	./src/dto/playerstateinfo.cpp
-	./src/dto/sessionuserinfo.cpp
-	./src/dto/baseitem.cpp
-	./src/dto/transcodereason.cpp
-	./src/dto/transcodinginfo.cpp
-	./src/dto/sessioninfo.cpp
-	./src/dto/generalcommand.cpp
-	./src/dto/playcommand.cpp
-	./src/dto/playstatecommand.cpp
-	./src/dto/clientcapabilitiesdto.cpp
-	./src/dto/startupconfigurationdto.cpp
-	./src/dto/startupuserdto.cpp
-	./src/dto/startupremoteaccessdto.cpp
-	./src/dto/fontfile.cpp
-	./src/dto/remotesubtitleinfo.cpp
-	./src/dto/uploadsubtitledto.cpp
-	./src/dto/bufferrequestdto.cpp
-	./src/dto/joingrouprequestdto.cpp
-	./src/dto/groupstatetype.cpp
-	./src/dto/groupinfodto.cpp
-	./src/dto/moveplaylistitemrequestdto.cpp
+	./src/dto/namevaluepair.cpp
+	./src/dto/networkconfiguration.cpp
 	./src/dto/newgrouprequestdto.cpp
 	./src/dto/nextitemrequestdto.cpp
+	./src/dto/openlivestreamdto.cpp
+	./src/dto/outboundkeepalivemessage.cpp
+	./src/dto/outboundwebsocketmessage.cpp
+	./src/dto/packageinfo.cpp
+	./src/dto/parentalrating.cpp
+	./src/dto/pathsubstitution.cpp
+	./src/dto/personkind.cpp
+	./src/dto/personlookupinfo.cpp
+	./src/dto/personlookupinforemotesearchquery.cpp
 	./src/dto/pingrequestdto.cpp
-	./src/dto/previousitemrequestdto.cpp
-	./src/dto/groupqueuemode.cpp
-	./src/dto/queuerequestdto.cpp
-	./src/dto/readyrequestdto.cpp
-	./src/dto/removefromplaylistrequestdto.cpp
-	./src/dto/seekrequestdto.cpp
-	./src/dto/ignorewaitrequestdto.cpp
-	./src/dto/playrequestdto.cpp
-	./src/dto/setplaylistitemrequestdto.cpp
-	./src/dto/grouprepeatmode.cpp
-	./src/dto/setrepeatmoderequestdto.cpp
-	./src/dto/groupshufflemode.cpp
-	./src/dto/setshufflemoderequestdto.cpp
-	./src/dto/endpointinfo.cpp
-	./src/dto/installationinfo.cpp
-	./src/dto/ffmpeglocation.cpp
-	./src/dto/architecture.cpp
-	./src/dto/systeminfo.cpp
-	./src/dto/publicsysteminfo.cpp
-	./src/dto/logfile.cpp
-	./src/dto/wakeonlaninfo.cpp
-	./src/dto/utctimeresponse.cpp
-	./src/dto/subtitleplaybackmode.cpp
-	./src/dto/userconfiguration.cpp
-	./src/dto/dynamicdayofweek.cpp
-	./src/dto/accessschedule.cpp
-	./src/dto/unrateditem.cpp
-	./src/dto/syncplayuseraccesstype.cpp
-	./src/dto/userpolicy.cpp
-	./src/dto/userdto.cpp
-	./src/dto/authenticationresult.cpp
-	./src/dto/updateusereasypassword.cpp
-	./src/dto/updateuserpassword.cpp
-	./src/dto/authenticateuserbyname.cpp
-	./src/dto/quickconnectdto.cpp
-	./src/dto/forgotpassworddto.cpp
-	./src/dto/forgotpasswordaction.cpp
-	./src/dto/forgotpasswordresult.cpp
 	./src/dto/pinredeemresult.cpp
-	./src/dto/createuserbyname.cpp
-	./src/dto/specialviewoptiondto.cpp
-	./src/dto/libraryupdateinfo.cpp
-	./src/dto/iplugin.cpp
+	./src/dto/playaccess.cpp
+	./src/dto/playbackerrorcode.cpp
+	./src/dto/playbackinfodto.cpp
+	./src/dto/playbackinforesponse.cpp
+	./src/dto/playbackorder.cpp
+	./src/dto/playbackprogressinfo.cpp
+	./src/dto/playbackrequesttype.cpp
+	./src/dto/playbackstartinfo.cpp
+	./src/dto/playbackstopinfo.cpp
+	./src/dto/playcommand.cpp
+	./src/dto/playerstateinfo.cpp
+	./src/dto/playlistcreationresult.cpp
+	./src/dto/playlistdto.cpp
+	./src/dto/playlistuserpermissions.cpp
+	./src/dto/playmessage.cpp
+	./src/dto/playmethod.cpp
+	./src/dto/playqueueupdate.cpp
+	./src/dto/playqueueupdategroupupdate.cpp
+	./src/dto/playqueueupdatereason.cpp
 	./src/dto/playrequest.cpp
+	./src/dto/playrequestdto.cpp
+	./src/dto/playstatecommand.cpp
+	./src/dto/playstatemessage.cpp
 	./src/dto/playstaterequest.cpp
-	./src/dto/timereventinfo.cpp
-	./src/dto/sendcommandtype.cpp
+	./src/dto/plugininfo.cpp
+	./src/dto/plugininstallationcancelledmessage.cpp
+	./src/dto/plugininstallationcompletedmessage.cpp
+	./src/dto/plugininstallationfailedmessage.cpp
+	./src/dto/plugininstallingmessage.cpp
+	./src/dto/pluginstatus.cpp
+	./src/dto/pluginuninstalledmessage.cpp
+	./src/dto/previousitemrequestdto.cpp
+	./src/dto/problemdetails.cpp
+	./src/dto/processpriorityclass.cpp
+	./src/dto/profilecondition.cpp
+	./src/dto/profileconditiontype.cpp
+	./src/dto/profileconditionvalue.cpp
+	./src/dto/programaudio.cpp
+	./src/dto/publicsysteminfo.cpp
+	./src/dto/queryfilters.cpp
+	./src/dto/queryfilterslegacy.cpp
+	./src/dto/queueitem.cpp
+	./src/dto/queuerequestdto.cpp
+	./src/dto/quickconnectdto.cpp
+	./src/dto/quickconnectresult.cpp
+	./src/dto/ratingtype.cpp
+	./src/dto/readyrequestdto.cpp
+	./src/dto/recommendationdto.cpp
+	./src/dto/recommendationtype.cpp
+	./src/dto/recordingstatus.cpp
+	./src/dto/refreshprogressmessage.cpp
+	./src/dto/remoteimageinfo.cpp
+	./src/dto/remoteimageresult.cpp
+	./src/dto/remotelyricinfodto.cpp
+	./src/dto/remotesearchresult.cpp
+	./src/dto/remotesubtitleinfo.cpp
+	./src/dto/removefromplaylistrequestdto.cpp
+	./src/dto/repeatmode.cpp
+	./src/dto/repositoryinfo.cpp
+	./src/dto/restartrequiredmessage.cpp
+	./src/dto/scheduledtaskendedmessage.cpp
+	./src/dto/scheduledtasksinfomessage.cpp
+	./src/dto/scheduledtasksinfostartmessage.cpp
+	./src/dto/scheduledtasksinfostopmessage.cpp
+	./src/dto/scrolldirection.cpp
+	./src/dto/searchhint.cpp
+	./src/dto/searchhintresult.cpp
+	./src/dto/seekrequestdto.cpp
 	./src/dto/sendcommand.cpp
-	./src/dto/groupupdatetype.cpp
-	./src/dto/objectgroupupdate.cpp
+	./src/dto/sendcommandtype.cpp
+	./src/dto/seriesinfo.cpp
+	./src/dto/seriesinforemotesearchquery.cpp
+	./src/dto/seriesstatus.cpp
+	./src/dto/seriestimercancelledmessage.cpp
+	./src/dto/seriestimercreatedmessage.cpp
+	./src/dto/seriestimerinfodto.cpp
+	./src/dto/seriestimerinfodtoqueryresult.cpp
+	./src/dto/serverconfiguration.cpp
+	./src/dto/serverdiscoveryinfo.cpp
+	./src/dto/serverrestartingmessage.cpp
+	./src/dto/servershuttingdownmessage.cpp
+	./src/dto/sessioninfodto.cpp
+	./src/dto/sessionmessagetype.cpp
+	./src/dto/sessionsmessage.cpp
+	./src/dto/sessionsstartmessage.cpp
+	./src/dto/sessionsstopmessage.cpp
+	./src/dto/sessionuserinfo.cpp
+	./src/dto/setchannelmappingdto.cpp
+	./src/dto/setplaylistitemrequestdto.cpp
+	./src/dto/setrepeatmoderequestdto.cpp
+	./src/dto/setshufflemoderequestdto.cpp
+	./src/dto/songinfo.cpp
+	./src/dto/sortorder.cpp
+	./src/dto/specialviewoptiondto.cpp
+	./src/dto/startupconfigurationdto.cpp
+	./src/dto/startupremoteaccessdto.cpp
+	./src/dto/startupuserdto.cpp
+	./src/dto/stringgroupupdate.cpp
+	./src/dto/subtitledeliverymethod.cpp
+	./src/dto/subtitleoptions.cpp
+	./src/dto/subtitleplaybackmode.cpp
+	./src/dto/subtitleprofile.cpp
+	./src/dto/syncplaycommandmessage.cpp
+	./src/dto/syncplaygroupupdatecommandmessage.cpp
+	./src/dto/syncplayqueueitem.cpp
+	./src/dto/syncplayuseraccesstype.cpp
+	./src/dto/systeminfo.cpp
+	./src/dto/taskcompletionstatus.cpp
+	./src/dto/taskinfo.cpp
+	./src/dto/taskresult.cpp
+	./src/dto/taskstate.cpp
+	./src/dto/tasktriggerinfo.cpp
+	./src/dto/thememediaresult.cpp
+	./src/dto/timercancelledmessage.cpp
+	./src/dto/timercreatedmessage.cpp
+	./src/dto/timereventinfo.cpp
+	./src/dto/timerinfodto.cpp
+	./src/dto/timerinfodtoqueryresult.cpp
+	./src/dto/tonemappingalgorithm.cpp
+	./src/dto/tonemappingmode.cpp
+	./src/dto/tonemappingrange.cpp
+	./src/dto/trailerinfo.cpp
+	./src/dto/trailerinforemotesearchquery.cpp
+	./src/dto/transcodereason.cpp
+	./src/dto/transcodeseekinfo.cpp
+	./src/dto/transcodinginfo.cpp
+	./src/dto/transcodingprofile.cpp
+	./src/dto/transportstreamtimestamp.cpp
+	./src/dto/trickplayinfo.cpp
+	./src/dto/trickplayoptions.cpp
+	./src/dto/trickplayscanbehavior.cpp
+	./src/dto/tunerchannelmapping.cpp
+	./src/dto/tunerhostinfo.cpp
+	./src/dto/typeoptions.cpp
+	./src/dto/unrateditem.cpp
+	./src/dto/updatelibraryoptionsdto.cpp
+	./src/dto/updatemediapathrequestdto.cpp
+	./src/dto/updateplaylistdto.cpp
+	./src/dto/updateplaylistuserdto.cpp
+	./src/dto/updateuseritemdatadto.cpp
+	./src/dto/updateuserpassword.cpp
+	./src/dto/uploadsubtitledto.cpp
+	./src/dto/userconfiguration.cpp
+	./src/dto/userdatachangedmessage.cpp
+	./src/dto/userdatachangeinfo.cpp
+	./src/dto/userdeletedmessage.cpp
+	./src/dto/userdto.cpp
+	./src/dto/useritemdatadto.cpp
+	./src/dto/userpolicy.cpp
+	./src/dto/userupdatedmessage.cpp
+	./src/dto/utctimeresponse.cpp
+	./src/dto/validatepathdto.cpp
+	./src/dto/versioninfo.cpp
+	./src/dto/video3dformat.cpp
+	./src/dto/videorange.cpp
+	./src/dto/videorangetype.cpp
+	./src/dto/videotype.cpp
+	./src/dto/virtualfolderinfo.cpp
+	./src/dto/wakeonlaninfo.cpp
+	./src/dto/websocketmessage.cpp
+	./src/dto/xbmcmetadataoptions.cpp
 	./src/loader/http/subtitle.cpp
 	./src/loader/http/activitylog.cpp
 	./src/loader/http/library.cpp
 	./src/loader/http/items.cpp
 	./src/loader/http/dynamichls.cpp
-	./src/loader/http/videoattachments.cpp
+	./src/loader/http/clientlog.cpp
+	./src/loader/http/mediasegments.cpp
 	./src/loader/http/itemupdate.cpp
+	./src/loader/http/videoattachments.cpp
 	./src/loader/http/audio.cpp
 	./src/loader/http/persons.cpp
 	./src/loader/http/collection.cpp
-	./src/loader/http/dlnaserver.cpp
+	./src/loader/http/startup.cpp
 	./src/loader/http/movies.cpp
 	./src/loader/http/dashboard.cpp
 	./src/loader/http/hlssegment.cpp
 	./src/loader/http/branding.cpp
-	./src/loader/http/startup.cpp
+	./src/loader/http/system.cpp
 	./src/loader/http/channels.cpp
 	./src/loader/http/localization.cpp
-	./src/loader/http/videohls.cpp
 	./src/loader/http/itemlookup.cpp
-	./src/loader/http/system.cpp
 	./src/loader/http/mediainfo.cpp
 	./src/loader/http/genres.cpp
 	./src/loader/http/syncplay.cpp
@@ -650,7 +802,6 @@ set(openapi_SOURCES
 	./src/loader/http/suggestions.cpp
 	./src/loader/http/itemrefresh.cpp
 	./src/loader/http/scheduledtasks.cpp
-	./src/loader/http/imagebyname.cpp
 	./src/loader/http/musicgenres.cpp
 	./src/loader/http/user.cpp
 	./src/loader/http/playlists.cpp
@@ -660,7 +811,6 @@ set(openapi_SOURCES
 	./src/loader/http/trailers.cpp
 	./src/loader/http/image.cpp
 	./src/loader/http/librarystructure.cpp
-	./src/loader/http/notifications.cpp
 	./src/loader/http/videos.cpp
 	./src/loader/http/package.cpp
 	./src/loader/http/artists.cpp
@@ -668,18 +818,20 @@ set(openapi_SOURCES
 	./src/loader/http/quickconnect.cpp
 	./src/loader/http/remoteimage.cpp
 	./src/loader/http/userlibrary.cpp
-	./src/loader/http/dlna.cpp
+	./src/loader/http/tmdb.cpp
 	./src/loader/http/configuration.cpp
 	./src/loader/http/livetv.cpp
 	./src/loader/http/timesync.cpp
 	./src/loader/http/session.cpp
 	./src/loader/http/displaypreferences.cpp
 	./src/loader/http/instantmix.cpp
+	./src/loader/http/trickplay.cpp
 	./src/loader/http/apikey.cpp
 	./src/loader/http/devices.cpp
 	./src/loader/http/filter.cpp
 	./src/loader/http/tvshows.cpp
-	./src/loader/http/plugins.cpp
+	./src/loader/http/lyrics.cpp
 	./src/loader/http/environment.cpp
 	./src/loader/http/search.cpp
+	./src/loader/http/plugins.cpp
 	./src/loader/requesttypes.cpp)
diff --git a/core/include/JellyfinQt/dto/accessschedule.h b/core/include/JellyfinQt/dto/accessschedule.h
index 7208df7..768cb7b 100644
--- a/core/include/JellyfinQt/dto/accessschedule.h
+++ b/core/include/JellyfinQt/dto/accessschedule.h
@@ -69,20 +69,20 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the id of this instance.
+	 * @brief Gets the id of this instance.
 	 */
 	qint32 jellyfinId() const;
 	/**
-	* @brief Gets or sets the id of this instance.
+	* @brief Gets the id of this instance.
 	*/
 	void setJellyfinId(qint32 newJellyfinId);
 
 	/**
-	 * @brief Gets or sets the id of the associated user.
+	 * @brief Gets the id of the associated user.
 	 */
 	QString userId() const;
 	/**
-	* @brief Gets or sets the id of the associated user.
+	* @brief Gets the id of the associated user.
 	*/
 	void setUserId(QString newUserId);
 
diff --git a/core/include/JellyfinQt/dto/activitylogentry.h b/core/include/JellyfinQt/dto/activitylogentry.h
index f0a438b..f5f0ebf 100644
--- a/core/include/JellyfinQt/dto/activitylogentry.h
+++ b/core/include/JellyfinQt/dto/activitylogentry.h
@@ -50,7 +50,9 @@ namespace DTO {
 class ActivityLogEntry {
 public:
 	ActivityLogEntry(	
-		qint64 jellyfinId,													
+		qint64 jellyfinId,			
+		QString name,							
+		QString type,					
 		QDateTime date,			
 		QString userId,					
 		LogLevel severity		
@@ -85,8 +87,6 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets the overview.
@@ -118,8 +118,6 @@ public:
 	* @brief Gets or sets the type.
 	*/
 	void setType(QString newType);
-	bool typeNull() const;
-	void setTypeNull();
 
 	/**
 	 * @brief Gets or sets the item identifier.
diff --git a/core/include/JellyfinQt/dto/activitylogentrymessage.h b/core/include/JellyfinQt/dto/activitylogentrymessage.h
new file mode 100644
index 0000000..023d43a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/activitylogentrymessage.h
@@ -0,0 +1,123 @@
+/*
+ * 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_DTO_ACTIVITYLOGENTRYMESSAGE_H
+#define JELLYFIN_DTO_ACTIVITYLOGENTRYMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/activitylogentry.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ActivityLogEntryMessage {
+public:
+	ActivityLogEntryMessage(			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ActivityLogEntryMessage(const ActivityLogEntryMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ActivityLogEntryMessage &other);
+	
+	static ActivityLogEntryMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QList<ActivityLogEntry> data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QList<ActivityLogEntry> newData);
+	bool dataNull() const;
+	void setDataNull();
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QList<ActivityLogEntry> m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ActivityLogEntryMessage::fromJson();
+	ActivityLogEntryMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryMessage = Jellyfin::DTO::ActivityLogEntryMessage;
+
+template <>
+ActivityLogEntryMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryMessage>);
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryMessage &source, convertType<ActivityLogEntryMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ACTIVITYLOGENTRYMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/activitylogentryqueryresult.h b/core/include/JellyfinQt/dto/activitylogentryqueryresult.h
index fc04908..e4e27c6 100644
--- a/core/include/JellyfinQt/dto/activitylogentryqueryresult.h
+++ b/core/include/JellyfinQt/dto/activitylogentryqueryresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class ActivityLogEntryQueryResult {
 public:
-	ActivityLogEntryQueryResult(			
+	ActivityLogEntryQueryResult(	
+		QList<ActivityLogEntry> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
@@ -74,24 +75,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<ActivityLogEntry> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/activitylogentrystartmessage.h b/core/include/JellyfinQt/dto/activitylogentrystartmessage.h
new file mode 100644
index 0000000..165f409
--- /dev/null
+++ b/core/include/JellyfinQt/dto/activitylogentrystartmessage.h
@@ -0,0 +1,109 @@
+/*
+ * 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_DTO_ACTIVITYLOGENTRYSTARTMESSAGE_H
+#define JELLYFIN_DTO_ACTIVITYLOGENTRYSTARTMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ActivityLogEntryStartMessage {
+public:
+	ActivityLogEntryStartMessage(			
+		SessionMessageType messageType		
+	);
+
+	ActivityLogEntryStartMessage(const ActivityLogEntryStartMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ActivityLogEntryStartMessage &other);
+	
+	static ActivityLogEntryStartMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QString data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QString newData);
+	bool dataNull() const;
+	void setDataNull();
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_data;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ActivityLogEntryStartMessage::fromJson();
+	ActivityLogEntryStartMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryStartMessage = Jellyfin::DTO::ActivityLogEntryStartMessage;
+
+template <>
+ActivityLogEntryStartMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryStartMessage>);
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryStartMessage &source, convertType<ActivityLogEntryStartMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ACTIVITYLOGENTRYSTARTMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/activitylogentrystopmessage.h b/core/include/JellyfinQt/dto/activitylogentrystopmessage.h
new file mode 100644
index 0000000..ce87f1b
--- /dev/null
+++ b/core/include/JellyfinQt/dto/activitylogentrystopmessage.h
@@ -0,0 +1,96 @@
+/*
+ * 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_DTO_ACTIVITYLOGENTRYSTOPMESSAGE_H
+#define JELLYFIN_DTO_ACTIVITYLOGENTRYSTOPMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ActivityLogEntryStopMessage {
+public:
+	ActivityLogEntryStopMessage(	
+		SessionMessageType messageType		
+	);
+
+	ActivityLogEntryStopMessage(const ActivityLogEntryStopMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ActivityLogEntryStopMessage &other);
+	
+	static ActivityLogEntryStopMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ActivityLogEntryStopMessage::fromJson();
+	ActivityLogEntryStopMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryStopMessage = Jellyfin::DTO::ActivityLogEntryStopMessage;
+
+template <>
+ActivityLogEntryStopMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryStopMessage>);
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryStopMessage &source, convertType<ActivityLogEntryStopMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ACTIVITYLOGENTRYSTOPMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/albuminfo.h b/core/include/JellyfinQt/dto/albuminfo.h
index 1a37414..a07b7a5 100644
--- a/core/include/JellyfinQt/dto/albuminfo.h
+++ b/core/include/JellyfinQt/dto/albuminfo.h
@@ -51,8 +51,11 @@ namespace DTO {
 
 class AlbumInfo {
 public:
-	AlbumInfo(																			
-		bool isAutomated								
+	AlbumInfo(																					
+		bool isAutomated,			
+		QStringList albumArtists,			
+		QJsonObject artistProviderIds,			
+		QList<SongInfo> songInfos		
 	);
 
 	AlbumInfo(const AlbumInfo &other);
@@ -78,6 +81,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -167,8 +181,6 @@ public:
 	* @brief Gets or sets the album artist.
 	*/
 	void setAlbumArtists(QStringList newAlbumArtists);
-	bool albumArtistsNull() const;
-	void setAlbumArtistsNull();
 
 	/**
 	 * @brief Gets or sets the artist provider ids.
@@ -178,19 +190,16 @@ public:
 	* @brief Gets or sets the artist provider ids.
 	*/
 	void setArtistProviderIds(QJsonObject newArtistProviderIds);
-	bool artistProviderIdsNull() const;
-	void setArtistProviderIdsNull();
 
 
 	QList<SongInfo> songInfos() const;
 
 	void setSongInfos(QList<SongInfo> newSongInfos);
-	bool songInfosNull() const;
-	void setSongInfosNull();
 
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/albuminforemotesearchquery.h b/core/include/JellyfinQt/dto/albuminforemotesearchquery.h
index a7ea9ef..649c2b8 100644
--- a/core/include/JellyfinQt/dto/albuminforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/albuminforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/artistinfo.h b/core/include/JellyfinQt/dto/artistinfo.h
index 148c7c4..db35b20 100644
--- a/core/include/JellyfinQt/dto/artistinfo.h
+++ b/core/include/JellyfinQt/dto/artistinfo.h
@@ -51,8 +51,9 @@ namespace DTO {
 
 class ArtistInfo {
 public:
-	ArtistInfo(																			
-		bool isAutomated				
+	ArtistInfo(																					
+		bool isAutomated,			
+		QList<SongInfo> songInfos		
 	);
 
 	ArtistInfo(const ArtistInfo &other);
@@ -78,6 +79,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -163,12 +175,11 @@ public:
 	QList<SongInfo> songInfos() const;
 
 	void setSongInfos(QList<SongInfo> newSongInfos);
-	bool songInfosNull() const;
-	void setSongInfosNull();
 
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/artistinforemotesearchquery.h b/core/include/JellyfinQt/dto/artistinforemotesearchquery.h
index 87a24e6..cf96985 100644
--- a/core/include/JellyfinQt/dto/artistinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/artistinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/audiospatialformat.h b/core/include/JellyfinQt/dto/audiospatialformat.h
new file mode 100644
index 0000000..f9c9a33
--- /dev/null
+++ b/core/include/JellyfinQt/dto/audiospatialformat.h
@@ -0,0 +1,77 @@
+/*
+ * 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_DTO_AUDIOSPATIALFORMAT_H
+#define JELLYFIN_DTO_AUDIOSPATIALFORMAT_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class AudioSpatialFormatClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		None,
+		DolbyAtmos,
+		DTSX,
+	};
+	Q_ENUM(Value)
+private:
+	explicit AudioSpatialFormatClass();
+};
+
+using AudioSpatialFormat = AudioSpatialFormatClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using AudioSpatialFormat = Jellyfin::DTO::AudioSpatialFormat;
+
+template <>
+AudioSpatialFormat fromJsonValue(const QJsonValue &source, convertType<AudioSpatialFormat>);
+
+template <>
+QJsonValue toJsonValue(const AudioSpatialFormat &source, convertType<AudioSpatialFormat>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_AUDIOSPATIALFORMAT_H
diff --git a/core/include/JellyfinQt/dto/authenticateuserbyname.h b/core/include/JellyfinQt/dto/authenticateuserbyname.h
index a282b4c..e15e469 100644
--- a/core/include/JellyfinQt/dto/authenticateuserbyname.h
+++ b/core/include/JellyfinQt/dto/authenticateuserbyname.h
@@ -81,22 +81,10 @@ public:	AuthenticateUserByName();
 	bool pwNull() const;
 	void setPwNull();
 
-	/**
-	 * @brief Gets or sets the sha1-hashed password.
-	 */
-	QString password() const;
-	/**
-	* @brief Gets or sets the sha1-hashed password.
-	*/
-	void setPassword(QString newPassword);
-	bool passwordNull() const;
-	void setPasswordNull();
-
 
 protected:
 	QString m_username;
 	QString m_pw;
-	QString m_password;
 
 
 };
diff --git a/core/include/JellyfinQt/dto/authenticationinfoqueryresult.h b/core/include/JellyfinQt/dto/authenticationinfoqueryresult.h
index b9ac7aa..f04132c 100644
--- a/core/include/JellyfinQt/dto/authenticationinfoqueryresult.h
+++ b/core/include/JellyfinQt/dto/authenticationinfoqueryresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class AuthenticationInfoQueryResult {
 public:
-	AuthenticationInfoQueryResult(			
+	AuthenticationInfoQueryResult(	
+		QList<AuthenticationInfo> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
@@ -74,24 +75,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<AuthenticationInfo> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/authenticationresult.h b/core/include/JellyfinQt/dto/authenticationresult.h
index e03c9ad..624fef8 100644
--- a/core/include/JellyfinQt/dto/authenticationresult.h
+++ b/core/include/JellyfinQt/dto/authenticationresult.h
@@ -36,7 +36,7 @@
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/sessioninfo.h"
+#include "JellyfinQt/dto/sessioninfodto.h"
 #include "JellyfinQt/dto/userdto.h"
 #include "JellyfinQt/support/jsonconv.h"
 
@@ -52,7 +52,7 @@ class AuthenticationResult {
 public:
 	AuthenticationResult(	
 		QSharedPointer<UserDto> user,			
-		QSharedPointer<SessionInfo> sessionInfo						
+		QSharedPointer<SessionInfoDto> sessionInfo						
 	);
 
 	AuthenticationResult(const AuthenticationResult &other);
@@ -73,20 +73,28 @@ public:
 	void setUser(QSharedPointer<UserDto> newUser);
 
 
-	QSharedPointer<SessionInfo> sessionInfo() const;
-
-	void setSessionInfo(QSharedPointer<SessionInfo> newSessionInfo);
+	QSharedPointer<SessionInfoDto> sessionInfo() const;
 
+	void setSessionInfo(QSharedPointer<SessionInfoDto> newSessionInfo);
 
+	/**
+	 * @brief Gets or sets the access token.
+	 */
 	QString accessToken() const;
-
+	/**
+	* @brief Gets or sets the access token.
+	*/
 	void setAccessToken(QString newAccessToken);
 	bool accessTokenNull() const;
 	void setAccessTokenNull();
 
-
+	/**
+	 * @brief Gets or sets the server id.
+	 */
 	QString serverId() const;
-
+	/**
+	* @brief Gets or sets the server id.
+	*/
 	void setServerId(QString newServerId);
 	bool serverIdNull() const;
 	void setServerIdNull();
@@ -94,7 +102,7 @@ public:
 
 protected:
 	QSharedPointer<UserDto> m_user = QSharedPointer<UserDto>();
-	QSharedPointer<SessionInfo> m_sessionInfo = QSharedPointer<SessionInfo>();
+	QSharedPointer<SessionInfoDto> m_sessionInfo = QSharedPointer<SessionInfoDto>();
 	QString m_accessToken;
 	QString m_serverId;
 
diff --git a/core/include/JellyfinQt/dto/baseitem.h b/core/include/JellyfinQt/dto/baseitem.h
deleted file mode 100644
index f2e8de6..0000000
--- a/core/include/JellyfinQt/dto/baseitem.h
+++ /dev/null
@@ -1,179 +0,0 @@
-/*
- * 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_DTO_BASEITEM_H
-#define JELLYFIN_DTO_BASEITEM_H
-
-#include <QDateTime>
-#include <QJsonObject>
-#include <QJsonValue>
-#include <QList>
-#include <QString>
-#include <QStringList>
-#include <optional>
-
-#include "JellyfinQt/dto/mediaurl.h"
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-
-class BaseItem {
-public:
-	BaseItem(					
-		QDateTime dateLastSaved,					
-		bool isHD,			
-		bool isShortcut,					
-		qint32 width,			
-		qint32 height,					
-		bool supportsExternalTransfer		
-	);
-
-	BaseItem(const BaseItem &other);
-	
-	/**
-	 * Replaces the data being hold by this class with that of the other.
-	 */
-	void replaceData(BaseItem &other);
-	
-	static BaseItem fromJson(QJsonObject source);
-	void setFromJson(QJsonObject source);
-	QJsonObject toJson() const;
-	
-	// Properties
-
-	std::optional<qint64> size() const;
-
-	void setSize(std::optional<qint64> newSize);
-	bool sizeNull() const;
-	void setSizeNull();
-
-
-	QString container() const;
-
-	void setContainer(QString newContainer);
-	bool containerNull() const;
-	void setContainerNull();
-
-
-	QDateTime dateLastSaved() const;
-
-	void setDateLastSaved(QDateTime newDateLastSaved);
-
-	/**
-	 * @brief Gets or sets the remote trailers.
-	 */
-	QList<MediaUrl> remoteTrailers() const;
-	/**
-	* @brief Gets or sets the remote trailers.
-	*/
-	void setRemoteTrailers(QList<MediaUrl> newRemoteTrailers);
-	bool remoteTrailersNull() const;
-	void setRemoteTrailersNull();
-
-
-	bool isHD() const;
-
-	void setIsHD(bool newIsHD);
-
-
-	bool isShortcut() const;
-
-	void setIsShortcut(bool newIsShortcut);
-
-
-	QString shortcutPath() const;
-
-	void setShortcutPath(QString newShortcutPath);
-	bool shortcutPathNull() const;
-	void setShortcutPathNull();
-
-
-	qint32 width() const;
-
-	void setWidth(qint32 newWidth);
-
-
-	qint32 height() const;
-
-	void setHeight(qint32 newHeight);
-
-
-	QStringList extraIds() const;
-
-	void setExtraIds(QStringList newExtraIds);
-	bool extraIdsNull() const;
-	void setExtraIdsNull();
-
-
-	bool supportsExternalTransfer() const;
-
-	void setSupportsExternalTransfer(bool newSupportsExternalTransfer);
-
-
-protected:
-	std::optional<qint64> m_size = std::nullopt;
-	QString m_container;
-	QDateTime m_dateLastSaved;
-	QList<MediaUrl> m_remoteTrailers;
-	bool m_isHD;
-	bool m_isShortcut;
-	QString m_shortcutPath;
-	qint32 m_width;
-	qint32 m_height;
-	QStringList m_extraIds;
-	bool m_supportsExternalTransfer;
-
-private:
-	// Private constructor which generates an invalid object, for use withing BaseItem::fromJson();
-	BaseItem();
-};
-
-
-} // NS DTO
-
-namespace Support {
-
-using BaseItem = Jellyfin::DTO::BaseItem;
-
-template <>
-BaseItem fromJsonValue(const QJsonValue &source, convertType<BaseItem>);
-
-template<>
-QJsonValue toJsonValue(const BaseItem &source, convertType<BaseItem>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_BASEITEM_H
diff --git a/core/include/JellyfinQt/dto/baseitemdto.h b/core/include/JellyfinQt/dto/baseitemdto.h
index 9804928..bf177af 100644
--- a/core/include/JellyfinQt/dto/baseitemdto.h
+++ b/core/include/JellyfinQt/dto/baseitemdto.h
@@ -39,16 +39,20 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/baseitemkind.h"
 #include "JellyfinQt/dto/baseitemperson.h"
 #include "JellyfinQt/dto/channeltype.h"
 #include "JellyfinQt/dto/chapterinfo.h"
+#include "JellyfinQt/dto/collectiontype.h"
 #include "JellyfinQt/dto/dayofweek.h"
 #include "JellyfinQt/dto/externalurl.h"
+#include "JellyfinQt/dto/extratype.h"
 #include "JellyfinQt/dto/imageorientation.h"
 #include "JellyfinQt/dto/isotype.h"
 #include "JellyfinQt/dto/locationtype.h"
 #include "JellyfinQt/dto/mediasourceinfo.h"
 #include "JellyfinQt/dto/mediastream.h"
+#include "JellyfinQt/dto/mediatype.h"
 #include "JellyfinQt/dto/mediaurl.h"
 #include "JellyfinQt/dto/metadatafield.h"
 #include "JellyfinQt/dto/nameguidpair.h"
@@ -70,16 +74,20 @@ namespace DTO {
 class BaseItemDto {
 public:
 	BaseItemDto(							
-		QString jellyfinId,																																							
+		QString jellyfinId,													
+		ExtraType extraType,																											
 		Video3DFormat video3DFormat,																																					
-		PlayAccess playAccess,																																													
-		QSharedPointer<UserItemDataDto> userData,																																																			
-		VideoType videoType,																																			
+		PlayAccess playAccess,																													
+		BaseItemKind type,																	
+		QSharedPointer<UserItemDataDto> userData,																																	
+		CollectionType collectionType,																			
+		VideoType videoType,																																					
 		LocationType locationType,			
-		IsoType isoType,																																											
+		IsoType isoType,			
+		MediaType mediaType,																																									
 		ImageOrientation imageOrientation,																													
 		ChannelType channelType,			
-		ProgramAudio audio,																			
+		ProgramAudio audio,																					
 		QSharedPointer<BaseItemDto> currentProgram		
 	);
 
@@ -185,11 +193,9 @@ public:
 	void setDateLastMediaAddedNull();
 
 
-	QString extraType() const;
+	ExtraType extraType() const;
 
-	void setExtraType(QString newExtraType);
-	bool extraTypeNull() const;
-	void setExtraTypeNull();
+	void setExtraType(ExtraType newExtraType);
 
 
 	std::optional<qint32> airsBeforeSeasonNumber() const;
@@ -227,6 +233,13 @@ public:
 	void setCanDownloadNull();
 
 
+	std::optional<bool> hasLyrics() const;
+
+	void setHasLyrics(std::optional<bool> newHasLyrics);
+	bool hasLyricsNull() const;
+	void setHasLyricsNull();
+
+
 	std::optional<bool> hasSubtitles() const;
 
 	void setHasSubtitles(std::optional<bool> newHasSubtitles);
@@ -247,17 +260,6 @@ public:
 	bool preferredMetadataCountryCodeNull() const;
 	void setPreferredMetadataCountryCodeNull();
 
-	/**
-	 * @brief Gets or sets a value indicating whether [supports synchronize].
-	 */
-	std::optional<bool> supportsSync() const;
-	/**
-	* @brief Gets or sets a value indicating whether [supports synchronize].
-	*/
-	void setSupportsSync(std::optional<bool> newSupportsSync);
-	bool supportsSyncNull() const;
-	void setSupportsSyncNull();
-
 
 	QString container() const;
 
@@ -607,16 +609,10 @@ public:
 	bool parentIdNull() const;
 	void setParentIdNull();
 
-	/**
-	 * @brief Gets or sets the type.
-	 */
-	QString type() const;
-	/**
-	* @brief Gets or sets the type.
-	*/
-	void setType(QString newType);
-	bool typeNull() const;
-	void setTypeNull();
+
+	BaseItemKind type() const;
+
+	void setType(BaseItemKind newType);
 
 	/**
 	 * @brief Gets or sets the people.
@@ -648,22 +644,22 @@ public:
 	void setGenreItemsNull();
 
 	/**
-	 * @brief If the item does not have a logo, this will hold the Id of the Parent that has one.
+	 * @brief Gets or sets whether the item has a logo, this will hold the Id of the Parent that has one.
 	 */
 	QString parentLogoItemId() const;
 	/**
-	* @brief If the item does not have a logo, this will hold the Id of the Parent that has one.
+	* @brief Gets or sets whether the item has a logo, this will hold the Id of the Parent that has one.
 	*/
 	void setParentLogoItemId(QString newParentLogoItemId);
 	bool parentLogoItemIdNull() const;
 	void setParentLogoItemIdNull();
 
 	/**
-	 * @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	 * @brief Gets or sets whether the item has any backdrops, this will hold the Id of the Parent that has one.
 	 */
 	QString parentBackdropItemId() const;
 	/**
-	* @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	* @brief Gets or sets whether the item has any backdrops, this will hold the Id of the Parent that has one.
 	*/
 	void setParentBackdropItemId(QString newParentBackdropItemId);
 	bool parentBackdropItemIdNull() const;
@@ -861,16 +857,10 @@ public:
 	bool albumNull() const;
 	void setAlbumNull();
 
-	/**
-	 * @brief Gets or sets the type of the collection.
-	 */
-	QString collectionType() const;
-	/**
-	* @brief Gets or sets the type of the collection.
-	*/
-	void setCollectionType(QString newCollectionType);
-	bool collectionTypeNull() const;
-	void setCollectionTypeNull();
+
+	CollectionType collectionType() const;
+
+	void setCollectionType(CollectionType newCollectionType);
 
 	/**
 	 * @brief Gets or sets the display order.
@@ -1028,11 +1018,11 @@ public:
 	void setParentLogoImageTagNull();
 
 	/**
-	 * @brief If the item does not have a art, this will hold the Id of the Parent that has one.
+	 * @brief Gets or sets whether the item has fan art, this will hold the Id of the Parent that has one.
 	 */
 	QString parentArtItemId() const;
 	/**
-	* @brief If the item does not have a art, this will hold the Id of the Parent that has one.
+	* @brief Gets or sets whether the item has fan art, this will hold the Id of the Parent that has one.
 	*/
 	void setParentArtItemId(QString newParentArtItemId);
 	bool parentArtItemIdNull() const;
@@ -1139,6 +1129,17 @@ Maps image type to dictionary mapping image tag to blurhash value.
 	bool chaptersNull() const;
 	void setChaptersNull();
 
+	/**
+	 * @brief Gets or sets the trickplay manifest.
+	 */
+	QJsonObject trickplay() const;
+	/**
+	* @brief Gets or sets the trickplay manifest.
+	*/
+	void setTrickplay(QJsonObject newTrickplay);
+	bool trickplayNull() const;
+	void setTrickplayNull();
+
 
 	LocationType locationType() const;
 
@@ -1149,16 +1150,10 @@ Maps image type to dictionary mapping image tag to blurhash value.
 
 	void setIsoType(IsoType newIsoType);
 
-	/**
-	 * @brief Gets or sets the type of the media.
-	 */
-	QString mediaType() const;
-	/**
-	* @brief Gets or sets the type of the media.
-	*/
-	void setMediaType(QString newMediaType);
-	bool mediaTypeNull() const;
-	void setMediaTypeNull();
+
+	MediaType mediaType() const;
+
+	void setMediaType(MediaType newMediaType);
 
 	/**
 	 * @brief Gets or sets the end date.
@@ -1414,11 +1409,11 @@ Maps image type to dictionary mapping image tag to blurhash value.
 	void setChannelPrimaryImageTagNull();
 
 	/**
-	 * @brief The start date of the recording, in UTC.
+	 * @brief Gets or sets the start date of the recording, in UTC.
 	 */
 	QDateTime startDate() const;
 	/**
-	* @brief The start date of the recording, in UTC.
+	* @brief Gets or sets the start date of the recording, in UTC.
 	*/
 	void setStartDate(QDateTime newStartDate);
 	bool startDateNull() const;
@@ -1555,6 +1550,17 @@ Maps image type to dictionary mapping image tag to blurhash value.
 	bool timerIdNull() const;
 	void setTimerIdNull();
 
+	/**
+	 * @brief Gets or sets the gain required for audio normalization.
+	 */
+	std::optional<float> normalizationGain() const;
+	/**
+	* @brief Gets or sets the gain required for audio normalization.
+	*/
+	void setNormalizationGain(std::optional<float> newNormalizationGain);
+	bool normalizationGainNull() const;
+	void setNormalizationGainNull();
+
 
 	QSharedPointer<BaseItemDto> currentProgram() const;
 
@@ -1571,16 +1577,16 @@ protected:
 	QString m_playlistItemId;
 	QDateTime m_dateCreated;
 	QDateTime m_dateLastMediaAdded;
-	QString m_extraType;
+	ExtraType m_extraType;
 	std::optional<qint32> m_airsBeforeSeasonNumber = std::nullopt;
 	std::optional<qint32> m_airsAfterSeasonNumber = std::nullopt;
 	std::optional<qint32> m_airsBeforeEpisodeNumber = std::nullopt;
 	std::optional<bool> m_canDelete = std::nullopt;
 	std::optional<bool> m_canDownload = std::nullopt;
+	std::optional<bool> m_hasLyrics = std::nullopt;
 	std::optional<bool> m_hasSubtitles = std::nullopt;
 	QString m_preferredMetadataLanguage;
 	QString m_preferredMetadataCountryCode;
-	std::optional<bool> m_supportsSync = std::nullopt;
 	QString m_container;
 	QString m_sortName;
 	QString m_forcedSortName;
@@ -1616,7 +1622,7 @@ protected:
 	std::optional<bool> m_isHD = std::nullopt;
 	std::optional<bool> m_isFolder = std::nullopt;
 	QString m_parentId;
-	QString m_type;
+	BaseItemKind m_type;
 	QList<BaseItemPerson> m_people;
 	QList<NameGuidPair> m_studios;
 	QList<NameGuidPair> m_genreItems;
@@ -1640,7 +1646,7 @@ protected:
 	QStringList m_artists;
 	QList<NameGuidPair> m_artistItems;
 	QString m_album;
-	QString m_collectionType;
+	CollectionType m_collectionType;
 	QString m_displayOrder;
 	QString m_albumId;
 	QString m_albumPrimaryImageTag;
@@ -1666,9 +1672,10 @@ protected:
 	QString m_parentPrimaryImageItemId;
 	QString m_parentPrimaryImageTag;
 	QList<ChapterInfo> m_chapters;
+	QJsonObject m_trickplay;
 	LocationType m_locationType;
 	IsoType m_isoType;
-	QString m_mediaType;
+	MediaType m_mediaType;
 	QDateTime m_endDate;
 	QList<MetadataField> m_lockedFields;
 	std::optional<qint32> m_trailerCount = std::nullopt;
@@ -1712,6 +1719,7 @@ protected:
 	std::optional<bool> m_isKids = std::nullopt;
 	std::optional<bool> m_isPremiere = std::nullopt;
 	QString m_timerId;
+	std::optional<float> m_normalizationGain = std::nullopt;
 	QSharedPointer<BaseItemDto> m_currentProgram = QSharedPointer<BaseItemDto>();
 
 private:
diff --git a/core/include/JellyfinQt/dto/baseitemdtoqueryresult.h b/core/include/JellyfinQt/dto/baseitemdtoqueryresult.h
index dd8c818..9f08189 100644
--- a/core/include/JellyfinQt/dto/baseitemdtoqueryresult.h
+++ b/core/include/JellyfinQt/dto/baseitemdtoqueryresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class BaseItemDtoQueryResult {
 public:
-	BaseItemDtoQueryResult(			
+	BaseItemDtoQueryResult(	
+		QList<BaseItemDto> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
@@ -74,24 +75,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<BaseItemDto> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/baseitemkind.h b/core/include/JellyfinQt/dto/baseitemkind.h
new file mode 100644
index 0000000..3d86f58
--- /dev/null
+++ b/core/include/JellyfinQt/dto/baseitemkind.h
@@ -0,0 +1,111 @@
+/*
+ * 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_DTO_BASEITEMKIND_H
+#define JELLYFIN_DTO_BASEITEMKIND_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class BaseItemKindClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		AggregateFolder,
+		Audio,
+		AudioBook,
+		BasePluginFolder,
+		Book,
+		BoxSet,
+		Channel,
+		ChannelFolderItem,
+		CollectionFolder,
+		Episode,
+		Folder,
+		Genre,
+		ManualPlaylistsFolder,
+		Movie,
+		LiveTvChannel,
+		LiveTvProgram,
+		MusicAlbum,
+		MusicArtist,
+		MusicGenre,
+		MusicVideo,
+		Person,
+		Photo,
+		PhotoAlbum,
+		Playlist,
+		PlaylistsFolder,
+		Program,
+		Recording,
+		Season,
+		Series,
+		Studio,
+		Trailer,
+		TvChannel,
+		TvProgram,
+		UserRootFolder,
+		UserView,
+		Video,
+		Year,
+	};
+	Q_ENUM(Value)
+private:
+	explicit BaseItemKindClass();
+};
+
+using BaseItemKind = BaseItemKindClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using BaseItemKind = Jellyfin::DTO::BaseItemKind;
+
+template <>
+BaseItemKind fromJsonValue(const QJsonValue &source, convertType<BaseItemKind>);
+
+template <>
+QJsonValue toJsonValue(const BaseItemKind &source, convertType<BaseItemKind>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_BASEITEMKIND_H
diff --git a/core/include/JellyfinQt/dto/baseitemperson.h b/core/include/JellyfinQt/dto/baseitemperson.h
index d4e99d8..b4fa1b7 100644
--- a/core/include/JellyfinQt/dto/baseitemperson.h
+++ b/core/include/JellyfinQt/dto/baseitemperson.h
@@ -35,6 +35,7 @@
 #include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/personkind.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -46,7 +47,12 @@ namespace DTO {
 
 
 class BaseItemPerson {
-public:	BaseItemPerson();
+public:
+	BaseItemPerson(			
+		QString jellyfinId,					
+		PersonKind type						
+	);
+
 	BaseItemPerson(const BaseItemPerson &other);
 	
 	/**
@@ -78,8 +84,6 @@ public:	BaseItemPerson();
 	* @brief Gets or sets the identifier.
 	*/
 	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
 
 	/**
 	 * @brief Gets or sets the role.
@@ -92,16 +96,10 @@ public:	BaseItemPerson();
 	bool roleNull() const;
 	void setRoleNull();
 
-	/**
-	 * @brief Gets or sets the type.
-	 */
-	QString type() const;
-	/**
-	* @brief Gets or sets the type.
-	*/
-	void setType(QString newType);
-	bool typeNull() const;
-	void setTypeNull();
+
+	PersonKind type() const;
+
+	void setType(PersonKind newType);
 
 	/**
 	 * @brief Gets or sets the primary image tag.
@@ -130,11 +128,13 @@ protected:
 	QString m_name;
 	QString m_jellyfinId;
 	QString m_role;
-	QString m_type;
+	PersonKind m_type;
 	QString m_primaryImageTag;
 	QJsonObject m_imageBlurHashes;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing BaseItemPerson::fromJson();
+	BaseItemPerson();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/bookinfo.h b/core/include/JellyfinQt/dto/bookinfo.h
index 3cfcc7f..2d559f3 100644
--- a/core/include/JellyfinQt/dto/bookinfo.h
+++ b/core/include/JellyfinQt/dto/bookinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class BookInfo {
 public:
-	BookInfo(																			
+	BookInfo(																					
 		bool isAutomated				
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -166,6 +177,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/bookinforemotesearchquery.h b/core/include/JellyfinQt/dto/bookinforemotesearchquery.h
index 54c232d..f47e4b1 100644
--- a/core/include/JellyfinQt/dto/bookinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/bookinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/boxsetinfo.h b/core/include/JellyfinQt/dto/boxsetinfo.h
index 259f616..f039340 100644
--- a/core/include/JellyfinQt/dto/boxsetinfo.h
+++ b/core/include/JellyfinQt/dto/boxsetinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class BoxSetInfo {
 public:
-	BoxSetInfo(																			
+	BoxSetInfo(																					
 		bool isAutomated		
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -159,6 +170,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/boxsetinforemotesearchquery.h b/core/include/JellyfinQt/dto/boxsetinforemotesearchquery.h
index 8ca4c67..8e4e68e 100644
--- a/core/include/JellyfinQt/dto/boxsetinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/boxsetinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/brandingoptions.h b/core/include/JellyfinQt/dto/brandingoptions.h
index ef7f052..95c385b 100644
--- a/core/include/JellyfinQt/dto/brandingoptions.h
+++ b/core/include/JellyfinQt/dto/brandingoptions.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class BrandingOptions {
-public:	BrandingOptions();
+public:
+	BrandingOptions(					
+		bool splashscreenEnabled		
+	);
+
 	BrandingOptions(const BrandingOptions &other);
 	
 	/**
@@ -81,12 +85,24 @@ public:	BrandingOptions();
 	bool customCssNull() const;
 	void setCustomCssNull();
 
+	/**
+	 * @brief Gets or sets a value indicating whether to enable the splashscreen.
+	 */
+	bool splashscreenEnabled() const;
+	/**
+	* @brief Gets or sets a value indicating whether to enable the splashscreen.
+	*/
+	void setSplashscreenEnabled(bool newSplashscreenEnabled);
+
 
 protected:
 	QString m_loginDisclaimer;
 	QString m_customCss;
+	bool m_splashscreenEnabled;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing BrandingOptions::fromJson();
+	BrandingOptions();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/deviceprofileinfo.h b/core/include/JellyfinQt/dto/castreceiverapplication.h
similarity index 66%
rename from core/include/JellyfinQt/dto/deviceprofileinfo.h
rename to core/include/JellyfinQt/dto/castreceiverapplication.h
index 559f46f..eee6449 100644
--- a/core/include/JellyfinQt/dto/deviceprofileinfo.h
+++ b/core/include/JellyfinQt/dto/castreceiverapplication.h
@@ -27,15 +27,14 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_DEVICEPROFILEINFO_H
-#define JELLYFIN_DTO_DEVICEPROFILEINFO_H
+#ifndef JELLYFIN_DTO_CASTRECEIVERAPPLICATION_H
+#define JELLYFIN_DTO_CASTRECEIVERAPPLICATION_H
 
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/deviceprofiletype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -46,60 +45,51 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class DeviceProfileInfo {
+class CastReceiverApplication {
 public:
-	DeviceProfileInfo(					
-		DeviceProfileType type		
+	CastReceiverApplication(	
+		QString jellyfinId,			
+		QString name		
 	);
 
-	DeviceProfileInfo(const DeviceProfileInfo &other);
+	CastReceiverApplication(const CastReceiverApplication &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(DeviceProfileInfo &other);
+	void replaceData(CastReceiverApplication &other);
 	
-	static DeviceProfileInfo fromJson(QJsonObject source);
+	static CastReceiverApplication fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the identifier.
+	 * @brief Gets or sets the cast receiver application id.
 	 */
 	QString jellyfinId() const;
 	/**
-	* @brief Gets or sets the identifier.
+	* @brief Gets or sets the cast receiver application id.
 	*/
 	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
 
 	/**
-	 * @brief Gets or sets the name.
+	 * @brief Gets or sets the cast receiver application name.
 	 */
 	QString name() const;
 	/**
-	* @brief Gets or sets the name.
+	* @brief Gets or sets the cast receiver application name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-
-
-	DeviceProfileType type() const;
-
-	void setType(DeviceProfileType newType);
 
 
 protected:
 	QString m_jellyfinId;
 	QString m_name;
-	DeviceProfileType m_type;
 
 private:
-	// Private constructor which generates an invalid object, for use withing DeviceProfileInfo::fromJson();
-	DeviceProfileInfo();
+	// Private constructor which generates an invalid object, for use withing CastReceiverApplication::fromJson();
+	CastReceiverApplication();
 };
 
 
@@ -107,15 +97,15 @@ private:
 
 namespace Support {
 
-using DeviceProfileInfo = Jellyfin::DTO::DeviceProfileInfo;
+using CastReceiverApplication = Jellyfin::DTO::CastReceiverApplication;
 
 template <>
-DeviceProfileInfo fromJsonValue(const QJsonValue &source, convertType<DeviceProfileInfo>);
+CastReceiverApplication fromJsonValue(const QJsonValue &source, convertType<CastReceiverApplication>);
 
 template<>
-QJsonValue toJsonValue(const DeviceProfileInfo &source, convertType<DeviceProfileInfo>);
+QJsonValue toJsonValue(const CastReceiverApplication &source, convertType<CastReceiverApplication>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_DEVICEPROFILEINFO_H
+#endif // JELLYFIN_DTO_CASTRECEIVERAPPLICATION_H
diff --git a/core/include/JellyfinQt/dto/channelfeatures.h b/core/include/JellyfinQt/dto/channelfeatures.h
index f08958f..c8426cb 100644
--- a/core/include/JellyfinQt/dto/channelfeatures.h
+++ b/core/include/JellyfinQt/dto/channelfeatures.h
@@ -52,8 +52,13 @@ namespace DTO {
 
 class ChannelFeatures {
 public:
-	ChannelFeatures(					
-		bool canSearch,													
+	ChannelFeatures(	
+		QString name,			
+		QString jellyfinId,			
+		bool canSearch,			
+		QList<ChannelMediaType> mediaTypes,			
+		QList<ChannelMediaContentType> contentTypes,							
+		QList<ChannelItemSortField> defaultSortFields,			
 		bool supportsSortOrderToggle,			
 		bool supportsLatestMedia,			
 		bool canFilter,			
@@ -80,8 +85,6 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets the identifier.
@@ -91,8 +94,6 @@ public:
 	* @brief Gets or sets the identifier.
 	*/
 	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
 
 	/**
 	 * @brief Gets or sets a value indicating whether this instance can search.
@@ -111,8 +112,6 @@ public:
 	* @brief Gets or sets the media types.
 	*/
 	void setMediaTypes(QList<ChannelMediaType> newMediaTypes);
-	bool mediaTypesNull() const;
-	void setMediaTypesNull();
 
 	/**
 	 * @brief Gets or sets the content types.
@@ -122,15 +121,13 @@ public:
 	* @brief Gets or sets the content types.
 	*/
 	void setContentTypes(QList<ChannelMediaContentType> newContentTypes);
-	bool contentTypesNull() const;
-	void setContentTypesNull();
 
 	/**
-	 * @brief Represents the maximum number of records the channel allows retrieving at a time.
+	 * @brief Gets or sets the maximum number of records the channel allows retrieving at a time.
 	 */
 	std::optional<qint32> maxPageSize() const;
 	/**
-	* @brief Represents the maximum number of records the channel allows retrieving at a time.
+	* @brief Gets or sets the maximum number of records the channel allows retrieving at a time.
 	*/
 	void setMaxPageSize(std::optional<qint32> newMaxPageSize);
 	bool maxPageSizeNull() const;
@@ -155,15 +152,13 @@ public:
 	* @brief Gets or sets the default sort orders.
 	*/
 	void setDefaultSortFields(QList<ChannelItemSortField> newDefaultSortFields);
-	bool defaultSortFieldsNull() const;
-	void setDefaultSortFieldsNull();
 
 	/**
-	 * @brief Indicates if a sort ascending/descending toggle is supported or not.
+	 * @brief Gets or sets a value indicating whether a sort ascending/descending toggle is supported.
 	 */
 	bool supportsSortOrderToggle() const;
 	/**
-	* @brief Indicates if a sort ascending/descending toggle is supported or not.
+	* @brief Gets or sets a value indicating whether a sort ascending/descending toggle is supported.
 	*/
 	void setSupportsSortOrderToggle(bool newSupportsSortOrderToggle);
 
diff --git a/core/include/JellyfinQt/dto/channelmappingoptionsdto.h b/core/include/JellyfinQt/dto/channelmappingoptionsdto.h
index a09f0bf..6ad1148 100644
--- a/core/include/JellyfinQt/dto/channelmappingoptionsdto.h
+++ b/core/include/JellyfinQt/dto/channelmappingoptionsdto.h
@@ -51,7 +51,13 @@ namespace DTO {
 
 
 class ChannelMappingOptionsDto {
-public:	ChannelMappingOptionsDto();
+public:
+	ChannelMappingOptionsDto(	
+		QList<TunerChannelMapping> tunerChannels,			
+		QList<NameIdPair> providerChannels,			
+		QList<NameValuePair> mappings				
+	);
+
 	ChannelMappingOptionsDto(const ChannelMappingOptionsDto &other);
 	
 	/**
@@ -72,8 +78,6 @@ public:	ChannelMappingOptionsDto();
 	* @brief Gets or sets list of tuner channels.
 	*/
 	void setTunerChannels(QList<TunerChannelMapping> newTunerChannels);
-	bool tunerChannelsNull() const;
-	void setTunerChannelsNull();
 
 	/**
 	 * @brief Gets or sets list of provider channels.
@@ -83,8 +87,6 @@ public:	ChannelMappingOptionsDto();
 	* @brief Gets or sets list of provider channels.
 	*/
 	void setProviderChannels(QList<NameIdPair> newProviderChannels);
-	bool providerChannelsNull() const;
-	void setProviderChannelsNull();
 
 	/**
 	 * @brief Gets or sets list of mappings.
@@ -94,8 +96,6 @@ public:	ChannelMappingOptionsDto();
 	* @brief Gets or sets list of mappings.
 	*/
 	void setMappings(QList<NameValuePair> newMappings);
-	bool mappingsNull() const;
-	void setMappingsNull();
 
 	/**
 	 * @brief Gets or sets provider name.
@@ -115,7 +115,9 @@ protected:
 	QList<NameValuePair> m_mappings;
 	QString m_providerName;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing ChannelMappingOptionsDto::fromJson();
+	ChannelMappingOptionsDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/clientcapabilities.h b/core/include/JellyfinQt/dto/clientcapabilities.h
deleted file mode 100644
index 9a97f1a..0000000
--- a/core/include/JellyfinQt/dto/clientcapabilities.h
+++ /dev/null
@@ -1,169 +0,0 @@
-/*
- * 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_DTO_CLIENTCAPABILITIES_H
-#define JELLYFIN_DTO_CLIENTCAPABILITIES_H
-
-#include <QJsonObject>
-#include <QJsonValue>
-#include <QList>
-#include <QSharedPointer>
-#include <QString>
-#include <QStringList>
-#include <optional>
-
-#include "JellyfinQt/dto/deviceprofile.h"
-#include "JellyfinQt/dto/generalcommandtype.h"
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-
-class ClientCapabilities {
-public:
-	ClientCapabilities(					
-		bool supportsMediaControl,			
-		bool supportsContentUploading,					
-		bool supportsPersistentIdentifier,			
-		bool supportsSync,			
-		QSharedPointer<DeviceProfile> deviceProfile						
-	);
-
-	ClientCapabilities(const ClientCapabilities &other);
-	
-	/**
-	 * Replaces the data being hold by this class with that of the other.
-	 */
-	void replaceData(ClientCapabilities &other);
-	
-	static ClientCapabilities fromJson(QJsonObject source);
-	void setFromJson(QJsonObject source);
-	QJsonObject toJson() const;
-	
-	// Properties
-
-	QStringList playableMediaTypes() const;
-
-	void setPlayableMediaTypes(QStringList newPlayableMediaTypes);
-	bool playableMediaTypesNull() const;
-	void setPlayableMediaTypesNull();
-
-
-	QList<GeneralCommandType> supportedCommands() const;
-
-	void setSupportedCommands(QList<GeneralCommandType> newSupportedCommands);
-	bool supportedCommandsNull() const;
-	void setSupportedCommandsNull();
-
-
-	bool supportsMediaControl() const;
-
-	void setSupportsMediaControl(bool newSupportsMediaControl);
-
-
-	bool supportsContentUploading() const;
-
-	void setSupportsContentUploading(bool newSupportsContentUploading);
-
-
-	QString messageCallbackUrl() const;
-
-	void setMessageCallbackUrl(QString newMessageCallbackUrl);
-	bool messageCallbackUrlNull() const;
-	void setMessageCallbackUrlNull();
-
-
-	bool supportsPersistentIdentifier() const;
-
-	void setSupportsPersistentIdentifier(bool newSupportsPersistentIdentifier);
-
-
-	bool supportsSync() const;
-
-	void setSupportsSync(bool newSupportsSync);
-
-
-	QSharedPointer<DeviceProfile> deviceProfile() const;
-
-	void setDeviceProfile(QSharedPointer<DeviceProfile> newDeviceProfile);
-
-
-	QString appStoreUrl() const;
-
-	void setAppStoreUrl(QString newAppStoreUrl);
-	bool appStoreUrlNull() const;
-	void setAppStoreUrlNull();
-
-
-	QString iconUrl() const;
-
-	void setIconUrl(QString newIconUrl);
-	bool iconUrlNull() const;
-	void setIconUrlNull();
-
-
-protected:
-	QStringList m_playableMediaTypes;
-	QList<GeneralCommandType> m_supportedCommands;
-	bool m_supportsMediaControl;
-	bool m_supportsContentUploading;
-	QString m_messageCallbackUrl;
-	bool m_supportsPersistentIdentifier;
-	bool m_supportsSync;
-	QSharedPointer<DeviceProfile> m_deviceProfile = QSharedPointer<DeviceProfile>();
-	QString m_appStoreUrl;
-	QString m_iconUrl;
-
-private:
-	// Private constructor which generates an invalid object, for use withing ClientCapabilities::fromJson();
-	ClientCapabilities();
-};
-
-
-} // NS DTO
-
-namespace Support {
-
-using ClientCapabilities = Jellyfin::DTO::ClientCapabilities;
-
-template <>
-ClientCapabilities fromJsonValue(const QJsonValue &source, convertType<ClientCapabilities>);
-
-template<>
-QJsonValue toJsonValue(const ClientCapabilities &source, convertType<ClientCapabilities>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_CLIENTCAPABILITIES_H
diff --git a/core/include/JellyfinQt/dto/clientcapabilitiesdto.h b/core/include/JellyfinQt/dto/clientcapabilitiesdto.h
index 59c8ed4..1194d6a 100644
--- a/core/include/JellyfinQt/dto/clientcapabilitiesdto.h
+++ b/core/include/JellyfinQt/dto/clientcapabilitiesdto.h
@@ -40,6 +40,7 @@
 
 #include "JellyfinQt/dto/deviceprofile.h"
 #include "JellyfinQt/dto/generalcommandtype.h"
+#include "JellyfinQt/dto/mediatype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -52,11 +53,11 @@ namespace DTO {
 
 class ClientCapabilitiesDto {
 public:
-	ClientCapabilitiesDto(					
+	ClientCapabilitiesDto(	
+		QList<MediaType> playableMediaTypes,			
+		QList<GeneralCommandType> supportedCommands,			
 		bool supportsMediaControl,			
-		bool supportsContentUploading,					
 		bool supportsPersistentIdentifier,			
-		bool supportsSync,			
 		QSharedPointer<DeviceProfile> deviceProfile						
 	);
 
@@ -75,13 +76,11 @@ public:
 	/**
 	 * @brief Gets or sets the list of playable media types.
 	 */
-	QStringList playableMediaTypes() const;
+	QList<MediaType> playableMediaTypes() const;
 	/**
 	* @brief Gets or sets the list of playable media types.
 	*/
-	void setPlayableMediaTypes(QStringList newPlayableMediaTypes);
-	bool playableMediaTypesNull() const;
-	void setPlayableMediaTypesNull();
+	void setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes);
 
 	/**
 	 * @brief Gets or sets the list of supported commands.
@@ -91,8 +90,6 @@ public:
 	* @brief Gets or sets the list of supported commands.
 	*/
 	void setSupportedCommands(QList<GeneralCommandType> newSupportedCommands);
-	bool supportedCommandsNull() const;
-	void setSupportedCommandsNull();
 
 	/**
 	 * @brief Gets or sets a value indicating whether session supports media control.
@@ -103,26 +100,6 @@ public:
 	*/
 	void setSupportsMediaControl(bool newSupportsMediaControl);
 
-	/**
-	 * @brief Gets or sets a value indicating whether session supports content uploading.
-	 */
-	bool supportsContentUploading() const;
-	/**
-	* @brief Gets or sets a value indicating whether session supports content uploading.
-	*/
-	void setSupportsContentUploading(bool newSupportsContentUploading);
-
-	/**
-	 * @brief Gets or sets the message callback url.
-	 */
-	QString messageCallbackUrl() const;
-	/**
-	* @brief Gets or sets the message callback url.
-	*/
-	void setMessageCallbackUrl(QString newMessageCallbackUrl);
-	bool messageCallbackUrlNull() const;
-	void setMessageCallbackUrlNull();
-
 	/**
 	 * @brief Gets or sets a value indicating whether session supports a persistent identifier.
 	 */
@@ -132,15 +109,6 @@ public:
 	*/
 	void setSupportsPersistentIdentifier(bool newSupportsPersistentIdentifier);
 
-	/**
-	 * @brief Gets or sets a value indicating whether session supports sync.
-	 */
-	bool supportsSync() const;
-	/**
-	* @brief Gets or sets a value indicating whether session supports sync.
-	*/
-	void setSupportsSync(bool newSupportsSync);
-
 
 	QSharedPointer<DeviceProfile> deviceProfile() const;
 
@@ -170,13 +138,10 @@ public:
 
 
 protected:
-	QStringList m_playableMediaTypes;
+	QList<MediaType> m_playableMediaTypes;
 	QList<GeneralCommandType> m_supportedCommands;
 	bool m_supportsMediaControl;
-	bool m_supportsContentUploading;
-	QString m_messageCallbackUrl;
 	bool m_supportsPersistentIdentifier;
-	bool m_supportsSync;
 	QSharedPointer<DeviceProfile> m_deviceProfile = QSharedPointer<DeviceProfile>();
 	QString m_appStoreUrl;
 	QString m_iconUrl;
diff --git a/core/include/JellyfinQt/dto/clientlogdocumentresponsedto.h b/core/include/JellyfinQt/dto/clientlogdocumentresponsedto.h
new file mode 100644
index 0000000..0f84752
--- /dev/null
+++ b/core/include/JellyfinQt/dto/clientlogdocumentresponsedto.h
@@ -0,0 +1,100 @@
+/*
+ * 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_DTO_CLIENTLOGDOCUMENTRESPONSEDTO_H
+#define JELLYFIN_DTO_CLIENTLOGDOCUMENTRESPONSEDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ClientLogDocumentResponseDto {
+public:
+	ClientLogDocumentResponseDto(	
+		QString fileName		
+	);
+
+	ClientLogDocumentResponseDto(const ClientLogDocumentResponseDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ClientLogDocumentResponseDto &other);
+	
+	static ClientLogDocumentResponseDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets the resulting filename.
+	 */
+	QString fileName() const;
+	/**
+	* @brief Gets the resulting filename.
+	*/
+	void setFileName(QString newFileName);
+
+
+protected:
+	QString m_fileName;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ClientLogDocumentResponseDto::fromJson();
+	ClientLogDocumentResponseDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ClientLogDocumentResponseDto = Jellyfin::DTO::ClientLogDocumentResponseDto;
+
+template <>
+ClientLogDocumentResponseDto fromJsonValue(const QJsonValue &source, convertType<ClientLogDocumentResponseDto>);
+
+template<>
+QJsonValue toJsonValue(const ClientLogDocumentResponseDto &source, convertType<ClientLogDocumentResponseDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_CLIENTLOGDOCUMENTRESPONSEDTO_H
diff --git a/core/include/JellyfinQt/dto/codecprofile.h b/core/include/JellyfinQt/dto/codecprofile.h
index 59d1f8c..94d616a 100644
--- a/core/include/JellyfinQt/dto/codecprofile.h
+++ b/core/include/JellyfinQt/dto/codecprofile.h
@@ -52,7 +52,9 @@ namespace DTO {
 class CodecProfile {
 public:
 	CodecProfile(	
-		CodecType type										
+		CodecType type,			
+		QList<ProfileCondition> conditions,			
+		QList<ProfileCondition> applyConditions								
 	);
 
 	CodecProfile(const CodecProfile &other);
@@ -72,34 +74,57 @@ public:
 
 	void setType(CodecType newType);
 
-
+	/**
+	 * @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this profile must meet.
+	 */
 	QList<ProfileCondition> conditions() const;
-
+	/**
+	* @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this profile must meet.
+	*/
 	void setConditions(QList<ProfileCondition> newConditions);
-	bool conditionsNull() const;
-	void setConditionsNull();
-
 
+	/**
+	 * @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition to apply if this profile is met.
+	 */
 	QList<ProfileCondition> applyConditions() const;
-
+	/**
+	* @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition to apply if this profile is met.
+	*/
 	void setApplyConditions(QList<ProfileCondition> newApplyConditions);
-	bool applyConditionsNull() const;
-	void setApplyConditionsNull();
-
 
+	/**
+	 * @brief Gets or sets the codec(s) that this profile applies to.
+	 */
 	QString codec() const;
-
+	/**
+	* @brief Gets or sets the codec(s) that this profile applies to.
+	*/
 	void setCodec(QString newCodec);
 	bool codecNull() const;
 	void setCodecNull();
 
-
+	/**
+	 * @brief Gets or sets the container(s) which this profile will be applied to.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the container(s) which this profile will be applied to.
+	*/
 	void setContainer(QString newContainer);
 	bool containerNull() const;
 	void setContainerNull();
 
+	/**
+	 * @brief Gets or sets the sub-container(s) which this profile will be applied to.
+	 */
+	QString subContainer() const;
+	/**
+	* @brief Gets or sets the sub-container(s) which this profile will be applied to.
+	*/
+	void setSubContainer(QString newSubContainer);
+	bool subContainerNull() const;
+	void setSubContainerNull();
+
 
 protected:
 	CodecType m_type;
@@ -107,6 +132,7 @@ protected:
 	QList<ProfileCondition> m_applyConditions;
 	QString m_codec;
 	QString m_container;
+	QString m_subContainer;
 
 private:
 	// Private constructor which generates an invalid object, for use withing CodecProfile::fromJson();
diff --git a/core/include/JellyfinQt/dto/collectiontype.h b/core/include/JellyfinQt/dto/collectiontype.h
new file mode 100644
index 0000000..2a9942a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/collectiontype.h
@@ -0,0 +1,87 @@
+/*
+ * 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_DTO_COLLECTIONTYPE_H
+#define JELLYFIN_DTO_COLLECTIONTYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class CollectionTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Unknown,
+		Movies,
+		Tvshows,
+		Music,
+		Musicvideos,
+		Trailers,
+		Homevideos,
+		Boxsets,
+		Books,
+		Photos,
+		Livetv,
+		Playlists,
+		Folders,
+	};
+	Q_ENUM(Value)
+private:
+	explicit CollectionTypeClass();
+};
+
+using CollectionType = CollectionTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using CollectionType = Jellyfin::DTO::CollectionType;
+
+template <>
+CollectionType fromJsonValue(const QJsonValue &source, convertType<CollectionType>);
+
+template <>
+QJsonValue toJsonValue(const CollectionType &source, convertType<CollectionType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_COLLECTIONTYPE_H
diff --git a/core/include/JellyfinQt/dto/collectiontypeoptions.h b/core/include/JellyfinQt/dto/collectiontypeoptions.h
new file mode 100644
index 0000000..4e4c7e5
--- /dev/null
+++ b/core/include/JellyfinQt/dto/collectiontypeoptions.h
@@ -0,0 +1,82 @@
+/*
+ * 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_DTO_COLLECTIONTYPEOPTIONS_H
+#define JELLYFIN_DTO_COLLECTIONTYPEOPTIONS_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class CollectionTypeOptionsClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Movies,
+		Tvshows,
+		Music,
+		Musicvideos,
+		Homevideos,
+		Boxsets,
+		Books,
+		Mixed,
+	};
+	Q_ENUM(Value)
+private:
+	explicit CollectionTypeOptionsClass();
+};
+
+using CollectionTypeOptions = CollectionTypeOptionsClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using CollectionTypeOptions = Jellyfin::DTO::CollectionTypeOptions;
+
+template <>
+CollectionTypeOptions fromJsonValue(const QJsonValue &source, convertType<CollectionTypeOptions>);
+
+template <>
+QJsonValue toJsonValue(const CollectionTypeOptions &source, convertType<CollectionTypeOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_COLLECTIONTYPEOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/responseprofile.h b/core/include/JellyfinQt/dto/configimagetypes.h
similarity index 50%
rename from core/include/JellyfinQt/dto/responseprofile.h
rename to core/include/JellyfinQt/dto/configimagetypes.h
index 46194ef..10fb663 100644
--- a/core/include/JellyfinQt/dto/responseprofile.h
+++ b/core/include/JellyfinQt/dto/configimagetypes.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_RESPONSEPROFILE_H
-#define JELLYFIN_DTO_RESPONSEPROFILE_H
+#ifndef JELLYFIN_DTO_CONFIGIMAGETYPES_H
+#define JELLYFIN_DTO_CONFIGIMAGETYPES_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -37,8 +37,6 @@
 #include <QStringList>
 #include <optional>
 
-#include "JellyfinQt/dto/dlnaprofiletype.h"
-#include "JellyfinQt/dto/profilecondition.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -49,84 +47,80 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class ResponseProfile {
-public:
-	ResponseProfile(							
-		DlnaProfileType type								
-	);
-
-	ResponseProfile(const ResponseProfile &other);
+class ConfigImageTypes {
+public:	ConfigImageTypes();
+	ConfigImageTypes(const ConfigImageTypes &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(ResponseProfile &other);
+	void replaceData(ConfigImageTypes &other);
 	
-	static ResponseProfile fromJson(QJsonObject source);
+	static ConfigImageTypes fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 
-	QString container() const;
+	QStringList backdropSizes() const;
 
-	void setContainer(QString newContainer);
-	bool containerNull() const;
-	void setContainerNull();
+	void setBackdropSizes(QStringList newBackdropSizes);
+	bool backdropSizesNull() const;
+	void setBackdropSizesNull();
 
 
-	QString audioCodec() const;
+	QString baseUrl() const;
 
-	void setAudioCodec(QString newAudioCodec);
-	bool audioCodecNull() const;
-	void setAudioCodecNull();
+	void setBaseUrl(QString newBaseUrl);
+	bool baseUrlNull() const;
+	void setBaseUrlNull();
 
 
-	QString videoCodec() const;
+	QStringList logoSizes() const;
 
-	void setVideoCodec(QString newVideoCodec);
-	bool videoCodecNull() const;
-	void setVideoCodecNull();
+	void setLogoSizes(QStringList newLogoSizes);
+	bool logoSizesNull() const;
+	void setLogoSizesNull();
 
 
-	DlnaProfileType type() const;
+	QStringList posterSizes() const;
 
-	void setType(DlnaProfileType newType);
+	void setPosterSizes(QStringList newPosterSizes);
+	bool posterSizesNull() const;
+	void setPosterSizesNull();
 
 
-	QString orgPn() const;
+	QStringList profileSizes() const;
 
-	void setOrgPn(QString newOrgPn);
-	bool orgPnNull() const;
-	void setOrgPnNull();
+	void setProfileSizes(QStringList newProfileSizes);
+	bool profileSizesNull() const;
+	void setProfileSizesNull();
 
 
-	QString mimeType() const;
+	QString secureBaseUrl() const;
 
-	void setMimeType(QString newMimeType);
-	bool mimeTypeNull() const;
-	void setMimeTypeNull();
+	void setSecureBaseUrl(QString newSecureBaseUrl);
+	bool secureBaseUrlNull() const;
+	void setSecureBaseUrlNull();
 
 
-	QList<ProfileCondition> conditions() const;
+	QStringList stillSizes() const;
 
-	void setConditions(QList<ProfileCondition> newConditions);
-	bool conditionsNull() const;
-	void setConditionsNull();
+	void setStillSizes(QStringList newStillSizes);
+	bool stillSizesNull() const;
+	void setStillSizesNull();
 
 
 protected:
-	QString m_container;
-	QString m_audioCodec;
-	QString m_videoCodec;
-	DlnaProfileType m_type;
-	QString m_orgPn;
-	QString m_mimeType;
-	QList<ProfileCondition> m_conditions;
+	QStringList m_backdropSizes;
+	QString m_baseUrl;
+	QStringList m_logoSizes;
+	QStringList m_posterSizes;
+	QStringList m_profileSizes;
+	QString m_secureBaseUrl;
+	QStringList m_stillSizes;
+
 
-private:
-	// Private constructor which generates an invalid object, for use withing ResponseProfile::fromJson();
-	ResponseProfile();
 };
 
 
@@ -134,15 +128,15 @@ private:
 
 namespace Support {
 
-using ResponseProfile = Jellyfin::DTO::ResponseProfile;
+using ConfigImageTypes = Jellyfin::DTO::ConfigImageTypes;
 
 template <>
-ResponseProfile fromJsonValue(const QJsonValue &source, convertType<ResponseProfile>);
+ConfigImageTypes fromJsonValue(const QJsonValue &source, convertType<ConfigImageTypes>);
 
 template<>
-QJsonValue toJsonValue(const ResponseProfile &source, convertType<ResponseProfile>);
+QJsonValue toJsonValue(const ConfigImageTypes &source, convertType<ConfigImageTypes>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_RESPONSEPROFILE_H
+#endif // JELLYFIN_DTO_CONFIGIMAGETYPES_H
diff --git a/core/include/JellyfinQt/dto/configurationpageinfo.h b/core/include/JellyfinQt/dto/configurationpageinfo.h
index a57d202..03ef29e 100644
--- a/core/include/JellyfinQt/dto/configurationpageinfo.h
+++ b/core/include/JellyfinQt/dto/configurationpageinfo.h
@@ -35,7 +35,6 @@
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/configurationpagetype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -48,9 +47,9 @@ namespace DTO {
 
 class ConfigurationPageInfo {
 public:
-	ConfigurationPageInfo(			
-		bool enableInMainMenu,									
-		ConfigurationPageType configurationPageType				
+	ConfigurationPageInfo(	
+		QString name,			
+		bool enableInMainMenu										
 	);
 
 	ConfigurationPageInfo(const ConfigurationPageInfo &other);
@@ -73,8 +72,6 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets a value indicating whether the configurations page is enabled in the main menu.
@@ -118,11 +115,6 @@ public:
 	bool displayNameNull() const;
 	void setDisplayNameNull();
 
-
-	ConfigurationPageType configurationPageType() const;
-
-	void setConfigurationPageType(ConfigurationPageType newConfigurationPageType);
-
 	/**
 	 * @brief Gets or sets the plugin id.
 	 */
@@ -141,7 +133,6 @@ protected:
 	QString m_menuSection;
 	QString m_menuIcon;
 	QString m_displayName;
-	ConfigurationPageType m_configurationPageType;
 	QString m_pluginId;
 
 private:
diff --git a/core/include/JellyfinQt/dto/containerprofile.h b/core/include/JellyfinQt/dto/containerprofile.h
index b2f7f1f..adda04b 100644
--- a/core/include/JellyfinQt/dto/containerprofile.h
+++ b/core/include/JellyfinQt/dto/containerprofile.h
@@ -52,7 +52,8 @@ namespace DTO {
 class ContainerProfile {
 public:
 	ContainerProfile(	
-		DlnaProfileType type						
+		DlnaProfileType type,			
+		QList<ProfileCondition> conditions						
 	);
 
 	ContainerProfile(const ContainerProfile &other);
@@ -72,25 +73,43 @@ public:
 
 	void setType(DlnaProfileType newType);
 
-
+	/**
+	 * @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this container will be applied to.
+	 */
 	QList<ProfileCondition> conditions() const;
-
+	/**
+	* @brief Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this container will be applied to.
+	*/
 	void setConditions(QList<ProfileCondition> newConditions);
-	bool conditionsNull() const;
-	void setConditionsNull();
-
 
+	/**
+	 * @brief Gets or sets the container(s) which this container must meet.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the container(s) which this container must meet.
+	*/
 	void setContainer(QString newContainer);
 	bool containerNull() const;
 	void setContainerNull();
 
+	/**
+	 * @brief Gets or sets the sub container(s) which this container must meet.
+	 */
+	QString subContainer() const;
+	/**
+	* @brief Gets or sets the sub container(s) which this container must meet.
+	*/
+	void setSubContainer(QString newSubContainer);
+	bool subContainerNull() const;
+	void setSubContainerNull();
+
 
 protected:
 	DlnaProfileType m_type;
 	QList<ProfileCondition> m_conditions;
 	QString m_container;
+	QString m_subContainer;
 
 private:
 	// Private constructor which generates an invalid object, for use withing ContainerProfile::fromJson();
diff --git a/core/include/JellyfinQt/dto/createplaylistdto.h b/core/include/JellyfinQt/dto/createplaylistdto.h
index 8cd13c8..d6a92ff 100644
--- a/core/include/JellyfinQt/dto/createplaylistdto.h
+++ b/core/include/JellyfinQt/dto/createplaylistdto.h
@@ -37,6 +37,8 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/mediatype.h"
+#include "JellyfinQt/dto/playlistuserpermissions.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -48,7 +50,15 @@ namespace DTO {
 
 
 class CreatePlaylistDto {
-public:	CreatePlaylistDto();
+public:
+	CreatePlaylistDto(	
+		QString name,			
+		QStringList ids,					
+		MediaType mediaType,			
+		QList<PlaylistUserPermissions> users,			
+		bool isPublic		
+	);
+
 	CreatePlaylistDto(const CreatePlaylistDto &other);
 	
 	/**
@@ -69,8 +79,6 @@ public:	CreatePlaylistDto();
 	* @brief Gets or sets the name of the new playlist.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets item ids to add to the playlist.
@@ -80,8 +88,6 @@ public:	CreatePlaylistDto();
 	* @brief Gets or sets item ids to add to the playlist.
 	*/
 	void setIds(QStringList newIds);
-	bool idsNull() const;
-	void setIdsNull();
 
 	/**
 	 * @brief Gets or sets the user id.
@@ -94,25 +100,41 @@ public:	CreatePlaylistDto();
 	bool userIdNull() const;
 	void setUserIdNull();
 
+
+	MediaType mediaType() const;
+
+	void setMediaType(MediaType newMediaType);
+
 	/**
-	 * @brief Gets or sets the media type.
+	 * @brief Gets or sets the playlist users.
 	 */
-	QString mediaType() const;
+	QList<PlaylistUserPermissions> users() const;
 	/**
-	* @brief Gets or sets the media type.
+	* @brief Gets or sets the playlist users.
 	*/
-	void setMediaType(QString newMediaType);
-	bool mediaTypeNull() const;
-	void setMediaTypeNull();
+	void setUsers(QList<PlaylistUserPermissions> newUsers);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the playlist is public.
+	 */
+	bool isPublic() const;
+	/**
+	* @brief Gets or sets a value indicating whether the playlist is public.
+	*/
+	void setIsPublic(bool newIsPublic);
 
 
 protected:
 	QString m_name;
 	QStringList m_ids;
 	QString m_userId;
-	QString m_mediaType;
-
+	MediaType m_mediaType;
+	QList<PlaylistUserPermissions> m_users;
+	bool m_isPublic;
 
+private:
+	// Private constructor which generates an invalid object, for use withing CreatePlaylistDto::fromJson();
+	CreatePlaylistDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/createuserbyname.h b/core/include/JellyfinQt/dto/createuserbyname.h
index ddce735..3a9ded1 100644
--- a/core/include/JellyfinQt/dto/createuserbyname.h
+++ b/core/include/JellyfinQt/dto/createuserbyname.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class CreateUserByName {
-public:	CreateUserByName();
+public:
+	CreateUserByName(	
+		QString name				
+	);
+
 	CreateUserByName(const CreateUserByName &other);
 	
 	/**
@@ -67,8 +71,6 @@ public:	CreateUserByName();
 	* @brief Gets or sets the username.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets the password.
@@ -86,7 +88,9 @@ protected:
 	QString m_name;
 	QString m_password;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing CreateUserByName::fromJson();
+	CreateUserByName();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/culturedto.h b/core/include/JellyfinQt/dto/culturedto.h
index 59f08e1..5844523 100644
--- a/core/include/JellyfinQt/dto/culturedto.h
+++ b/core/include/JellyfinQt/dto/culturedto.h
@@ -48,7 +48,14 @@ namespace DTO {
 
 
 class CultureDto {
-public:	CultureDto();
+public:
+	CultureDto(	
+		QString name,			
+		QString displayName,			
+		QString twoLetterISOLanguageName,					
+		QStringList threeLetterISOLanguageNames		
+	);
+
 	CultureDto(const CultureDto &other);
 	
 	/**
@@ -62,44 +69,38 @@ public:	CultureDto();
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the name.
+	 * @brief Gets the name.
 	 */
 	QString name() const;
 	/**
-	* @brief Gets or sets the name.
+	* @brief Gets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
-	 * @brief Gets or sets the display name.
+	 * @brief Gets the display name.
 	 */
 	QString displayName() const;
 	/**
-	* @brief Gets or sets the display name.
+	* @brief Gets the display name.
 	*/
 	void setDisplayName(QString newDisplayName);
-	bool displayNameNull() const;
-	void setDisplayNameNull();
 
 	/**
-	 * @brief Gets or sets the name of the two letter ISO language.
+	 * @brief Gets the name of the two letter ISO language.
 	 */
 	QString twoLetterISOLanguageName() const;
 	/**
-	* @brief Gets or sets the name of the two letter ISO language.
+	* @brief Gets the name of the two letter ISO language.
 	*/
 	void setTwoLetterISOLanguageName(QString newTwoLetterISOLanguageName);
-	bool twoLetterISOLanguageNameNull() const;
-	void setTwoLetterISOLanguageNameNull();
 
 	/**
-	 * @brief Gets or sets the name of the three letter ISO language.
+	 * @brief Gets the name of the three letter ISO language.
 	 */
 	QString threeLetterISOLanguageName() const;
 	/**
-	* @brief Gets or sets the name of the three letter ISO language.
+	* @brief Gets the name of the three letter ISO language.
 	*/
 	void setThreeLetterISOLanguageName(QString newThreeLetterISOLanguageName);
 	bool threeLetterISOLanguageNameNull() const;
@@ -109,8 +110,6 @@ public:	CultureDto();
 	QStringList threeLetterISOLanguageNames() const;
 
 	void setThreeLetterISOLanguageNames(QStringList newThreeLetterISOLanguageNames);
-	bool threeLetterISOLanguageNamesNull() const;
-	void setThreeLetterISOLanguageNamesNull();
 
 
 protected:
@@ -120,7 +119,9 @@ protected:
 	QString m_threeLetterISOLanguageName;
 	QStringList m_threeLetterISOLanguageNames;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing CultureDto::fromJson();
+	CultureDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/deviceprofiletype.h b/core/include/JellyfinQt/dto/deinterlacemethod.h
similarity index 76%
rename from core/include/JellyfinQt/dto/deviceprofiletype.h
rename to core/include/JellyfinQt/dto/deinterlacemethod.h
index e4351d6..6e0bbd5 100644
--- a/core/include/JellyfinQt/dto/deviceprofiletype.h
+++ b/core/include/JellyfinQt/dto/deinterlacemethod.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_DEVICEPROFILETYPE_H
-#define JELLYFIN_DTO_DEVICEPROFILETYPE_H
+#ifndef JELLYFIN_DTO_DEINTERLACEMETHOD_H
+#define JELLYFIN_DTO_DEINTERLACEMETHOD_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,34 +43,34 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class DeviceProfileTypeClass {
+class DeinterlaceMethodClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
-		System,
-		User,
+		Yadif,
+		Bwdif,
 	};
 	Q_ENUM(Value)
 private:
-	explicit DeviceProfileTypeClass();
+	explicit DeinterlaceMethodClass();
 };
 
-using DeviceProfileType = DeviceProfileTypeClass::Value;
+using DeinterlaceMethod = DeinterlaceMethodClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using DeviceProfileType = Jellyfin::DTO::DeviceProfileType;
+using DeinterlaceMethod = Jellyfin::DTO::DeinterlaceMethod;
 
 template <>
-DeviceProfileType fromJsonValue(const QJsonValue &source, convertType<DeviceProfileType>);
+DeinterlaceMethod fromJsonValue(const QJsonValue &source, convertType<DeinterlaceMethod>);
 
 template <>
-QJsonValue toJsonValue(const DeviceProfileType &source, convertType<DeviceProfileType>);
+QJsonValue toJsonValue(const DeinterlaceMethod &source, convertType<DeinterlaceMethod>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_DEVICEPROFILETYPE_H
+#endif // JELLYFIN_DTO_DEINTERLACEMETHOD_H
diff --git a/core/include/JellyfinQt/dto/deviceidentification.h b/core/include/JellyfinQt/dto/deviceidentification.h
deleted file mode 100644
index 94c1835..0000000
--- a/core/include/JellyfinQt/dto/deviceidentification.h
+++ /dev/null
@@ -1,195 +0,0 @@
-/*
- * 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_DTO_DEVICEIDENTIFICATION_H
-#define JELLYFIN_DTO_DEVICEIDENTIFICATION_H
-
-#include <QJsonObject>
-#include <QJsonValue>
-#include <QList>
-#include <QString>
-#include <QStringList>
-#include <optional>
-
-#include "JellyfinQt/dto/httpheaderinfo.h"
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-
-class DeviceIdentification {
-public:	DeviceIdentification();
-	DeviceIdentification(const DeviceIdentification &other);
-	
-	/**
-	 * Replaces the data being hold by this class with that of the other.
-	 */
-	void replaceData(DeviceIdentification &other);
-	
-	static DeviceIdentification fromJson(QJsonObject source);
-	void setFromJson(QJsonObject source);
-	QJsonObject toJson() const;
-	
-	// Properties
-	/**
-	 * @brief Gets or sets the name of the friendly.
-	 */
-	QString friendlyName() const;
-	/**
-	* @brief Gets or sets the name of the friendly.
-	*/
-	void setFriendlyName(QString newFriendlyName);
-	bool friendlyNameNull() const;
-	void setFriendlyNameNull();
-
-	/**
-	 * @brief Gets or sets the model number.
-	 */
-	QString modelNumber() const;
-	/**
-	* @brief Gets or sets the model number.
-	*/
-	void setModelNumber(QString newModelNumber);
-	bool modelNumberNull() const;
-	void setModelNumberNull();
-
-	/**
-	 * @brief Gets or sets the serial number.
-	 */
-	QString serialNumber() const;
-	/**
-	* @brief Gets or sets the serial number.
-	*/
-	void setSerialNumber(QString newSerialNumber);
-	bool serialNumberNull() const;
-	void setSerialNumberNull();
-
-	/**
-	 * @brief Gets or sets the name of the model.
-	 */
-	QString modelName() const;
-	/**
-	* @brief Gets or sets the name of the model.
-	*/
-	void setModelName(QString newModelName);
-	bool modelNameNull() const;
-	void setModelNameNull();
-
-	/**
-	 * @brief Gets or sets the model description.
-	 */
-	QString modelDescription() const;
-	/**
-	* @brief Gets or sets the model description.
-	*/
-	void setModelDescription(QString newModelDescription);
-	bool modelDescriptionNull() const;
-	void setModelDescriptionNull();
-
-	/**
-	 * @brief Gets or sets the model URL.
-	 */
-	QString modelUrl() const;
-	/**
-	* @brief Gets or sets the model URL.
-	*/
-	void setModelUrl(QString newModelUrl);
-	bool modelUrlNull() const;
-	void setModelUrlNull();
-
-	/**
-	 * @brief Gets or sets the manufacturer.
-	 */
-	QString manufacturer() const;
-	/**
-	* @brief Gets or sets the manufacturer.
-	*/
-	void setManufacturer(QString newManufacturer);
-	bool manufacturerNull() const;
-	void setManufacturerNull();
-
-	/**
-	 * @brief Gets or sets the manufacturer URL.
-	 */
-	QString manufacturerUrl() const;
-	/**
-	* @brief Gets or sets the manufacturer URL.
-	*/
-	void setManufacturerUrl(QString newManufacturerUrl);
-	bool manufacturerUrlNull() const;
-	void setManufacturerUrlNull();
-
-	/**
-	 * @brief Gets or sets the headers.
-	 */
-	QList<HttpHeaderInfo> headers() const;
-	/**
-	* @brief Gets or sets the headers.
-	*/
-	void setHeaders(QList<HttpHeaderInfo> newHeaders);
-	bool headersNull() const;
-	void setHeadersNull();
-
-
-protected:
-	QString m_friendlyName;
-	QString m_modelNumber;
-	QString m_serialNumber;
-	QString m_modelName;
-	QString m_modelDescription;
-	QString m_modelUrl;
-	QString m_manufacturer;
-	QString m_manufacturerUrl;
-	QList<HttpHeaderInfo> m_headers;
-
-
-};
-
-
-} // NS DTO
-
-namespace Support {
-
-using DeviceIdentification = Jellyfin::DTO::DeviceIdentification;
-
-template <>
-DeviceIdentification fromJsonValue(const QJsonValue &source, convertType<DeviceIdentification>);
-
-template<>
-QJsonValue toJsonValue(const DeviceIdentification &source, convertType<DeviceIdentification>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_DEVICEIDENTIFICATION_H
diff --git a/core/include/JellyfinQt/dto/deviceinfo.h b/core/include/JellyfinQt/dto/deviceinfodto.h
similarity index 68%
rename from core/include/JellyfinQt/dto/deviceinfo.h
rename to core/include/JellyfinQt/dto/deviceinfodto.h
index e880a95..6e9b044 100644
--- a/core/include/JellyfinQt/dto/deviceinfo.h
+++ b/core/include/JellyfinQt/dto/deviceinfodto.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_DEVICEINFO_H
-#define JELLYFIN_DTO_DEVICEINFO_H
+#ifndef JELLYFIN_DTO_DEVICEINFODTO_H
+#define JELLYFIN_DTO_DEVICEINFODTO_H
 
 #include <QDateTime>
 #include <QJsonObject>
@@ -37,7 +37,7 @@
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/clientcapabilities.h"
+#include "JellyfinQt/dto/clientcapabilitiesdto.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -48,33 +48,57 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class DeviceInfo {
+class DeviceInfoDto {
 public:
-	DeviceInfo(											
-		QString lastUserId,			
-		QDateTime dateLastActivity,			
-		QSharedPointer<ClientCapabilities> capabilities				
+	DeviceInfoDto(																			
+		QSharedPointer<ClientCapabilitiesDto> capabilities				
 	);
 
-	DeviceInfo(const DeviceInfo &other);
+	DeviceInfoDto(const DeviceInfoDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(DeviceInfo &other);
+	void replaceData(DeviceInfoDto &other);
 	
-	static DeviceInfo fromJson(QJsonObject source);
+	static DeviceInfoDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
-
+	/**
+	 * @brief Gets or sets the name.
+	 */
 	QString name() const;
-
+	/**
+	* @brief Gets or sets the name.
+	*/
 	void setName(QString newName);
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the custom name.
+	 */
+	QString customName() const;
+	/**
+	* @brief Gets or sets the custom name.
+	*/
+	void setCustomName(QString newCustomName);
+	bool customNameNull() const;
+	void setCustomNameNull();
+
+	/**
+	 * @brief Gets or sets the access token.
+	 */
+	QString accessToken() const;
+	/**
+	* @brief Gets or sets the access token.
+	*/
+	void setAccessToken(QString newAccessToken);
+	bool accessTokenNull() const;
+	void setAccessTokenNull();
+
 	/**
 	 * @brief Gets or sets the identifier.
 	 */
@@ -127,6 +151,8 @@ public:
 	* @brief Gets or sets the last user identifier.
 	*/
 	void setLastUserId(QString newLastUserId);
+	bool lastUserIdNull() const;
+	void setLastUserIdNull();
 
 	/**
 	 * @brief Gets or sets the date last modified.
@@ -136,15 +162,21 @@ public:
 	* @brief Gets or sets the date last modified.
 	*/
 	void setDateLastActivity(QDateTime newDateLastActivity);
+	bool dateLastActivityNull() const;
+	void setDateLastActivityNull();
 
 
-	QSharedPointer<ClientCapabilities> capabilities() const;
-
-	void setCapabilities(QSharedPointer<ClientCapabilities> newCapabilities);
+	QSharedPointer<ClientCapabilitiesDto> capabilities() const;
 
+	void setCapabilities(QSharedPointer<ClientCapabilitiesDto> newCapabilities);
 
+	/**
+	 * @brief Gets or sets the icon URL.
+	 */
 	QString iconUrl() const;
-
+	/**
+	* @brief Gets or sets the icon URL.
+	*/
 	void setIconUrl(QString newIconUrl);
 	bool iconUrlNull() const;
 	void setIconUrlNull();
@@ -152,18 +184,20 @@ public:
 
 protected:
 	QString m_name;
+	QString m_customName;
+	QString m_accessToken;
 	QString m_jellyfinId;
 	QString m_lastUserName;
 	QString m_appName;
 	QString m_appVersion;
 	QString m_lastUserId;
 	QDateTime m_dateLastActivity;
-	QSharedPointer<ClientCapabilities> m_capabilities = QSharedPointer<ClientCapabilities>();
+	QSharedPointer<ClientCapabilitiesDto> m_capabilities = QSharedPointer<ClientCapabilitiesDto>();
 	QString m_iconUrl;
 
 private:
-	// Private constructor which generates an invalid object, for use withing DeviceInfo::fromJson();
-	DeviceInfo();
+	// Private constructor which generates an invalid object, for use withing DeviceInfoDto::fromJson();
+	DeviceInfoDto();
 };
 
 
@@ -171,15 +205,15 @@ private:
 
 namespace Support {
 
-using DeviceInfo = Jellyfin::DTO::DeviceInfo;
+using DeviceInfoDto = Jellyfin::DTO::DeviceInfoDto;
 
 template <>
-DeviceInfo fromJsonValue(const QJsonValue &source, convertType<DeviceInfo>);
+DeviceInfoDto fromJsonValue(const QJsonValue &source, convertType<DeviceInfoDto>);
 
 template<>
-QJsonValue toJsonValue(const DeviceInfo &source, convertType<DeviceInfo>);
+QJsonValue toJsonValue(const DeviceInfoDto &source, convertType<DeviceInfoDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_DEVICEINFO_H
+#endif // JELLYFIN_DTO_DEVICEINFODTO_H
diff --git a/core/include/JellyfinQt/dto/deviceinfoqueryresult.h b/core/include/JellyfinQt/dto/deviceinfodtoqueryresult.h
similarity index 66%
rename from core/include/JellyfinQt/dto/deviceinfoqueryresult.h
rename to core/include/JellyfinQt/dto/deviceinfodtoqueryresult.h
index 41d7797..01269bb 100644
--- a/core/include/JellyfinQt/dto/deviceinfoqueryresult.h
+++ b/core/include/JellyfinQt/dto/deviceinfodtoqueryresult.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_DEVICEINFOQUERYRESULT_H
-#define JELLYFIN_DTO_DEVICEINFOQUERYRESULT_H
+#ifndef JELLYFIN_DTO_DEVICEINFODTOQUERYRESULT_H
+#define JELLYFIN_DTO_DEVICEINFODTOQUERYRESULT_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -36,7 +36,7 @@
 #include <QStringList>
 #include <optional>
 
-#include "JellyfinQt/dto/deviceinfo.h"
+#include "JellyfinQt/dto/deviceinfodto.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -47,21 +47,22 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class DeviceInfoQueryResult {
+class DeviceInfoDtoQueryResult {
 public:
-	DeviceInfoQueryResult(			
+	DeviceInfoDtoQueryResult(	
+		QList<DeviceInfoDto> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
 
-	DeviceInfoQueryResult(const DeviceInfoQueryResult &other);
+	DeviceInfoDtoQueryResult(const DeviceInfoDtoQueryResult &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(DeviceInfoQueryResult &other);
+	void replaceData(DeviceInfoDtoQueryResult &other);
 	
-	static DeviceInfoQueryResult fromJson(QJsonObject source);
+	static DeviceInfoDtoQueryResult fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
@@ -69,41 +70,39 @@ public:
 	/**
 	 * @brief Gets or sets the items.
 	 */
-	QList<DeviceInfo> items() const;
+	QList<DeviceInfoDto> items() const;
 	/**
 	* @brief Gets or sets the items.
 	*/
-	void setItems(QList<DeviceInfo> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
+	void setItems(QList<DeviceInfoDto> newItems);
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
 
 protected:
-	QList<DeviceInfo> m_items;
+	QList<DeviceInfoDto> m_items;
 	qint32 m_totalRecordCount;
 	qint32 m_startIndex;
 
 private:
-	// Private constructor which generates an invalid object, for use withing DeviceInfoQueryResult::fromJson();
-	DeviceInfoQueryResult();
+	// Private constructor which generates an invalid object, for use withing DeviceInfoDtoQueryResult::fromJson();
+	DeviceInfoDtoQueryResult();
 };
 
 
@@ -111,15 +110,15 @@ private:
 
 namespace Support {
 
-using DeviceInfoQueryResult = Jellyfin::DTO::DeviceInfoQueryResult;
+using DeviceInfoDtoQueryResult = Jellyfin::DTO::DeviceInfoDtoQueryResult;
 
 template <>
-DeviceInfoQueryResult fromJsonValue(const QJsonValue &source, convertType<DeviceInfoQueryResult>);
+DeviceInfoDtoQueryResult fromJsonValue(const QJsonValue &source, convertType<DeviceInfoDtoQueryResult>);
 
 template<>
-QJsonValue toJsonValue(const DeviceInfoQueryResult &source, convertType<DeviceInfoQueryResult>);
+QJsonValue toJsonValue(const DeviceInfoDtoQueryResult &source, convertType<DeviceInfoDtoQueryResult>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_DEVICEINFOQUERYRESULT_H
+#endif // JELLYFIN_DTO_DEVICEINFODTOQUERYRESULT_H
diff --git a/core/include/JellyfinQt/dto/deviceoptionsdto.h b/core/include/JellyfinQt/dto/deviceoptionsdto.h
new file mode 100644
index 0000000..8bd1b1b
--- /dev/null
+++ b/core/include/JellyfinQt/dto/deviceoptionsdto.h
@@ -0,0 +1,124 @@
+/*
+ * 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_DTO_DEVICEOPTIONSDTO_H
+#define JELLYFIN_DTO_DEVICEOPTIONSDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class DeviceOptionsDto {
+public:
+	DeviceOptionsDto(	
+		qint32 jellyfinId						
+	);
+
+	DeviceOptionsDto(const DeviceOptionsDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(DeviceOptionsDto &other);
+	
+	static DeviceOptionsDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the id.
+	 */
+	qint32 jellyfinId() const;
+	/**
+	* @brief Gets or sets the id.
+	*/
+	void setJellyfinId(qint32 newJellyfinId);
+
+	/**
+	 * @brief Gets or sets the device id.
+	 */
+	QString deviceId() const;
+	/**
+	* @brief Gets or sets the device id.
+	*/
+	void setDeviceId(QString newDeviceId);
+	bool deviceIdNull() const;
+	void setDeviceIdNull();
+
+	/**
+	 * @brief Gets or sets the custom name.
+	 */
+	QString customName() const;
+	/**
+	* @brief Gets or sets the custom name.
+	*/
+	void setCustomName(QString newCustomName);
+	bool customNameNull() const;
+	void setCustomNameNull();
+
+
+protected:
+	qint32 m_jellyfinId;
+	QString m_deviceId;
+	QString m_customName;
+
+private:
+	// Private constructor which generates an invalid object, for use withing DeviceOptionsDto::fromJson();
+	DeviceOptionsDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using DeviceOptionsDto = Jellyfin::DTO::DeviceOptionsDto;
+
+template <>
+DeviceOptionsDto fromJsonValue(const QJsonValue &source, convertType<DeviceOptionsDto>);
+
+template<>
+QJsonValue toJsonValue(const DeviceOptionsDto &source, convertType<DeviceOptionsDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_DEVICEOPTIONSDTO_H
diff --git a/core/include/JellyfinQt/dto/deviceprofile.h b/core/include/JellyfinQt/dto/deviceprofile.h
index 2013bd5..d9dc960 100644
--- a/core/include/JellyfinQt/dto/deviceprofile.h
+++ b/core/include/JellyfinQt/dto/deviceprofile.h
@@ -33,19 +33,15 @@
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QList>
-#include <QSharedPointer>
 #include <QString>
 #include <QStringList>
 #include <optional>
 
 #include "JellyfinQt/dto/codecprofile.h"
 #include "JellyfinQt/dto/containerprofile.h"
-#include "JellyfinQt/dto/deviceidentification.h"
 #include "JellyfinQt/dto/directplayprofile.h"
-#include "JellyfinQt/dto/responseprofile.h"
 #include "JellyfinQt/dto/subtitleprofile.h"
 #include "JellyfinQt/dto/transcodingprofile.h"
-#include "JellyfinQt/dto/xmlattribute.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -58,18 +54,12 @@ namespace DTO {
 
 class DeviceProfile {
 public:
-	DeviceProfile(					
-		QSharedPointer<DeviceIdentification> identification,																			
-		bool enableAlbumArtInDidl,			
-		bool enableSingleAlbumArtLimit,			
-		bool enableSingleSubtitleLimit,									
-		qint32 maxAlbumArtWidth,			
-		qint32 maxAlbumArtHeight,																			
-		qint32 timelineOffsetSeconds,			
-		bool requiresPlainVideoItems,			
-		bool requiresPlainFolders,			
-		bool enableMSMediaReceiverRegistrar,			
-		bool ignoreTranscodeByteRangeRequests																
+	DeviceProfile(													
+		QList<DirectPlayProfile> directPlayProfiles,			
+		QList<TranscodingProfile> transcodingProfiles,			
+		QList<ContainerProfile> containerProfiles,			
+		QList<CodecProfile> codecProfiles,			
+		QList<SubtitleProfile> subtitleProfiles		
 	);
 
 	DeviceProfile(const DeviceProfile &other);
@@ -85,342 +75,71 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the Name.
+	 * @brief Gets or sets the name of this device profile. User profiles must have a unique name.
 	 */
 	QString name() const;
 	/**
-	* @brief Gets or sets the Name.
+	* @brief Gets or sets the name of this device profile. User profiles must have a unique name.
 	*/
 	void setName(QString newName);
 	bool nameNull() const;
 	void setNameNull();
 
 	/**
-	 * @brief Gets or sets the Id.
+	 * @brief Gets or sets the unique internal identifier.
 	 */
 	QString jellyfinId() const;
 	/**
-	* @brief Gets or sets the Id.
+	* @brief Gets or sets the unique internal identifier.
 	*/
 	void setJellyfinId(QString newJellyfinId);
 	bool jellyfinIdNull() const;
 	void setJellyfinIdNull();
 
-
-	QSharedPointer<DeviceIdentification> identification() const;
-
-	void setIdentification(QSharedPointer<DeviceIdentification> newIdentification);
-
 	/**
-	 * @brief Gets or sets the FriendlyName.
-	 */
-	QString friendlyName() const;
-	/**
-	* @brief Gets or sets the FriendlyName.
-	*/
-	void setFriendlyName(QString newFriendlyName);
-	bool friendlyNameNull() const;
-	void setFriendlyNameNull();
-
-	/**
-	 * @brief Gets or sets the Manufacturer.
-	 */
-	QString manufacturer() const;
-	/**
-	* @brief Gets or sets the Manufacturer.
-	*/
-	void setManufacturer(QString newManufacturer);
-	bool manufacturerNull() const;
-	void setManufacturerNull();
-
-	/**
-	 * @brief Gets or sets the ManufacturerUrl.
-	 */
-	QString manufacturerUrl() const;
-	/**
-	* @brief Gets or sets the ManufacturerUrl.
-	*/
-	void setManufacturerUrl(QString newManufacturerUrl);
-	bool manufacturerUrlNull() const;
-	void setManufacturerUrlNull();
-
-	/**
-	 * @brief Gets or sets the ModelName.
-	 */
-	QString modelName() const;
-	/**
-	* @brief Gets or sets the ModelName.
-	*/
-	void setModelName(QString newModelName);
-	bool modelNameNull() const;
-	void setModelNameNull();
-
-	/**
-	 * @brief Gets or sets the ModelDescription.
-	 */
-	QString modelDescription() const;
-	/**
-	* @brief Gets or sets the ModelDescription.
-	*/
-	void setModelDescription(QString newModelDescription);
-	bool modelDescriptionNull() const;
-	void setModelDescriptionNull();
-
-	/**
-	 * @brief Gets or sets the ModelNumber.
-	 */
-	QString modelNumber() const;
-	/**
-	* @brief Gets or sets the ModelNumber.
-	*/
-	void setModelNumber(QString newModelNumber);
-	bool modelNumberNull() const;
-	void setModelNumberNull();
-
-	/**
-	 * @brief Gets or sets the ModelUrl.
-	 */
-	QString modelUrl() const;
-	/**
-	* @brief Gets or sets the ModelUrl.
-	*/
-	void setModelUrl(QString newModelUrl);
-	bool modelUrlNull() const;
-	void setModelUrlNull();
-
-	/**
-	 * @brief Gets or sets the SerialNumber.
-	 */
-	QString serialNumber() const;
-	/**
-	* @brief Gets or sets the SerialNumber.
-	*/
-	void setSerialNumber(QString newSerialNumber);
-	bool serialNumberNull() const;
-	void setSerialNumberNull();
-
-	/**
-	 * @brief Gets or sets a value indicating whether EnableAlbumArtInDidl.
-	 */
-	bool enableAlbumArtInDidl() const;
-	/**
-	* @brief Gets or sets a value indicating whether EnableAlbumArtInDidl.
-	*/
-	void setEnableAlbumArtInDidl(bool newEnableAlbumArtInDidl);
-
-	/**
-	 * @brief Gets or sets a value indicating whether EnableSingleAlbumArtLimit.
-	 */
-	bool enableSingleAlbumArtLimit() const;
-	/**
-	* @brief Gets or sets a value indicating whether EnableSingleAlbumArtLimit.
-	*/
-	void setEnableSingleAlbumArtLimit(bool newEnableSingleAlbumArtLimit);
-
-	/**
-	 * @brief Gets or sets a value indicating whether EnableSingleSubtitleLimit.
-	 */
-	bool enableSingleSubtitleLimit() const;
-	/**
-	* @brief Gets or sets a value indicating whether EnableSingleSubtitleLimit.
-	*/
-	void setEnableSingleSubtitleLimit(bool newEnableSingleSubtitleLimit);
-
-	/**
-	 * @brief Gets or sets the SupportedMediaTypes.
-	 */
-	QString supportedMediaTypes() const;
-	/**
-	* @brief Gets or sets the SupportedMediaTypes.
-	*/
-	void setSupportedMediaTypes(QString newSupportedMediaTypes);
-	bool supportedMediaTypesNull() const;
-	void setSupportedMediaTypesNull();
-
-	/**
-	 * @brief Gets or sets the UserId.
-	 */
-	QString userId() const;
-	/**
-	* @brief Gets or sets the UserId.
-	*/
-	void setUserId(QString newUserId);
-	bool userIdNull() const;
-	void setUserIdNull();
-
-	/**
-	 * @brief Gets or sets the AlbumArtPn.
-	 */
-	QString albumArtPn() const;
-	/**
-	* @brief Gets or sets the AlbumArtPn.
-	*/
-	void setAlbumArtPn(QString newAlbumArtPn);
-	bool albumArtPnNull() const;
-	void setAlbumArtPnNull();
-
-	/**
-	 * @brief Gets or sets the MaxAlbumArtWidth.
-	 */
-	qint32 maxAlbumArtWidth() const;
-	/**
-	* @brief Gets or sets the MaxAlbumArtWidth.
-	*/
-	void setMaxAlbumArtWidth(qint32 newMaxAlbumArtWidth);
-
-	/**
-	 * @brief Gets or sets the MaxAlbumArtHeight.
-	 */
-	qint32 maxAlbumArtHeight() const;
-	/**
-	* @brief Gets or sets the MaxAlbumArtHeight.
-	*/
-	void setMaxAlbumArtHeight(qint32 newMaxAlbumArtHeight);
-
-	/**
-	 * @brief Gets or sets the MaxIconWidth.
-	 */
-	std::optional<qint32> maxIconWidth() const;
-	/**
-	* @brief Gets or sets the MaxIconWidth.
-	*/
-	void setMaxIconWidth(std::optional<qint32> newMaxIconWidth);
-	bool maxIconWidthNull() const;
-	void setMaxIconWidthNull();
-
-	/**
-	 * @brief Gets or sets the MaxIconHeight.
-	 */
-	std::optional<qint32> maxIconHeight() const;
-	/**
-	* @brief Gets or sets the MaxIconHeight.
-	*/
-	void setMaxIconHeight(std::optional<qint32> newMaxIconHeight);
-	bool maxIconHeightNull() const;
-	void setMaxIconHeightNull();
-
-	/**
-	 * @brief Gets or sets the MaxStreamingBitrate.
+	 * @brief Gets or sets the maximum allowed bitrate for all streamed content.
 	 */
 	std::optional<qint32> maxStreamingBitrate() const;
 	/**
-	* @brief Gets or sets the MaxStreamingBitrate.
+	* @brief Gets or sets the maximum allowed bitrate for all streamed content.
 	*/
 	void setMaxStreamingBitrate(std::optional<qint32> newMaxStreamingBitrate);
 	bool maxStreamingBitrateNull() const;
 	void setMaxStreamingBitrateNull();
 
 	/**
-	 * @brief Gets or sets the MaxStaticBitrate.
+	 * @brief Gets or sets the maximum allowed bitrate for statically streamed content (= direct played files).
 	 */
 	std::optional<qint32> maxStaticBitrate() const;
 	/**
-	* @brief Gets or sets the MaxStaticBitrate.
+	* @brief Gets or sets the maximum allowed bitrate for statically streamed content (= direct played files).
 	*/
 	void setMaxStaticBitrate(std::optional<qint32> newMaxStaticBitrate);
 	bool maxStaticBitrateNull() const;
 	void setMaxStaticBitrateNull();
 
 	/**
-	 * @brief Gets or sets the MusicStreamingTranscodingBitrate.
+	 * @brief Gets or sets the maximum allowed bitrate for transcoded music streams.
 	 */
 	std::optional<qint32> musicStreamingTranscodingBitrate() const;
 	/**
-	* @brief Gets or sets the MusicStreamingTranscodingBitrate.
+	* @brief Gets or sets the maximum allowed bitrate for transcoded music streams.
 	*/
 	void setMusicStreamingTranscodingBitrate(std::optional<qint32> newMusicStreamingTranscodingBitrate);
 	bool musicStreamingTranscodingBitrateNull() const;
 	void setMusicStreamingTranscodingBitrateNull();
 
 	/**
-	 * @brief Gets or sets the MaxStaticMusicBitrate.
+	 * @brief Gets or sets the maximum allowed bitrate for statically streamed (= direct played) music files.
 	 */
 	std::optional<qint32> maxStaticMusicBitrate() const;
 	/**
-	* @brief Gets or sets the MaxStaticMusicBitrate.
+	* @brief Gets or sets the maximum allowed bitrate for statically streamed (= direct played) music files.
 	*/
 	void setMaxStaticMusicBitrate(std::optional<qint32> newMaxStaticMusicBitrate);
 	bool maxStaticMusicBitrateNull() const;
 	void setMaxStaticMusicBitrateNull();
 
-	/**
-	 * @brief Gets or sets the content of the aggregationFlags element in the urn:schemas-sonycom:av namespace.
-	 */
-	QString sonyAggregationFlags() const;
-	/**
-	* @brief Gets or sets the content of the aggregationFlags element in the urn:schemas-sonycom:av namespace.
-	*/
-	void setSonyAggregationFlags(QString newSonyAggregationFlags);
-	bool sonyAggregationFlagsNull() const;
-	void setSonyAggregationFlagsNull();
-
-	/**
-	 * @brief Gets or sets the ProtocolInfo.
-	 */
-	QString protocolInfo() const;
-	/**
-	* @brief Gets or sets the ProtocolInfo.
-	*/
-	void setProtocolInfo(QString newProtocolInfo);
-	bool protocolInfoNull() const;
-	void setProtocolInfoNull();
-
-	/**
-	 * @brief Gets or sets the TimelineOffsetSeconds.
-	 */
-	qint32 timelineOffsetSeconds() const;
-	/**
-	* @brief Gets or sets the TimelineOffsetSeconds.
-	*/
-	void setTimelineOffsetSeconds(qint32 newTimelineOffsetSeconds);
-
-	/**
-	 * @brief Gets or sets a value indicating whether RequiresPlainVideoItems.
-	 */
-	bool requiresPlainVideoItems() const;
-	/**
-	* @brief Gets or sets a value indicating whether RequiresPlainVideoItems.
-	*/
-	void setRequiresPlainVideoItems(bool newRequiresPlainVideoItems);
-
-	/**
-	 * @brief Gets or sets a value indicating whether RequiresPlainFolders.
-	 */
-	bool requiresPlainFolders() const;
-	/**
-	* @brief Gets or sets a value indicating whether RequiresPlainFolders.
-	*/
-	void setRequiresPlainFolders(bool newRequiresPlainFolders);
-
-	/**
-	 * @brief Gets or sets a value indicating whether EnableMSMediaReceiverRegistrar.
-	 */
-	bool enableMSMediaReceiverRegistrar() const;
-	/**
-	* @brief Gets or sets a value indicating whether EnableMSMediaReceiverRegistrar.
-	*/
-	void setEnableMSMediaReceiverRegistrar(bool newEnableMSMediaReceiverRegistrar);
-
-	/**
-	 * @brief Gets or sets a value indicating whether IgnoreTranscodeByteRangeRequests.
-	 */
-	bool ignoreTranscodeByteRangeRequests() const;
-	/**
-	* @brief Gets or sets a value indicating whether IgnoreTranscodeByteRangeRequests.
-	*/
-	void setIgnoreTranscodeByteRangeRequests(bool newIgnoreTranscodeByteRangeRequests);
-
-	/**
-	 * @brief Gets or sets the XmlRootAttributes.
-	 */
-	QList<XmlAttribute> xmlRootAttributes() const;
-	/**
-	* @brief Gets or sets the XmlRootAttributes.
-	*/
-	void setXmlRootAttributes(QList<XmlAttribute> newXmlRootAttributes);
-	bool xmlRootAttributesNull() const;
-	void setXmlRootAttributesNull();
-
 	/**
 	 * @brief Gets or sets the direct play profiles.
 	 */
@@ -429,8 +148,6 @@ public:
 	* @brief Gets or sets the direct play profiles.
 	*/
 	void setDirectPlayProfiles(QList<DirectPlayProfile> newDirectPlayProfiles);
-	bool directPlayProfilesNull() const;
-	void setDirectPlayProfilesNull();
 
 	/**
 	 * @brief Gets or sets the transcoding profiles.
@@ -440,93 +157,46 @@ public:
 	* @brief Gets or sets the transcoding profiles.
 	*/
 	void setTranscodingProfiles(QList<TranscodingProfile> newTranscodingProfiles);
-	bool transcodingProfilesNull() const;
-	void setTranscodingProfilesNull();
 
 	/**
-	 * @brief Gets or sets the ContainerProfiles.
+	 * @brief Gets or sets the container profiles. Failing to meet these optional conditions causes transcoding to occur.
 	 */
 	QList<ContainerProfile> containerProfiles() const;
 	/**
-	* @brief Gets or sets the ContainerProfiles.
+	* @brief Gets or sets the container profiles. Failing to meet these optional conditions causes transcoding to occur.
 	*/
 	void setContainerProfiles(QList<ContainerProfile> newContainerProfiles);
-	bool containerProfilesNull() const;
-	void setContainerProfilesNull();
 
 	/**
-	 * @brief Gets or sets the CodecProfiles.
+	 * @brief Gets or sets the codec profiles.
 	 */
 	QList<CodecProfile> codecProfiles() const;
 	/**
-	* @brief Gets or sets the CodecProfiles.
+	* @brief Gets or sets the codec profiles.
 	*/
 	void setCodecProfiles(QList<CodecProfile> newCodecProfiles);
-	bool codecProfilesNull() const;
-	void setCodecProfilesNull();
 
 	/**
-	 * @brief Gets or sets the ResponseProfiles.
-	 */
-	QList<ResponseProfile> responseProfiles() const;
-	/**
-	* @brief Gets or sets the ResponseProfiles.
-	*/
-	void setResponseProfiles(QList<ResponseProfile> newResponseProfiles);
-	bool responseProfilesNull() const;
-	void setResponseProfilesNull();
-
-	/**
-	 * @brief Gets or sets the SubtitleProfiles.
+	 * @brief Gets or sets the subtitle profiles.
 	 */
 	QList<SubtitleProfile> subtitleProfiles() const;
 	/**
-	* @brief Gets or sets the SubtitleProfiles.
+	* @brief Gets or sets the subtitle profiles.
 	*/
 	void setSubtitleProfiles(QList<SubtitleProfile> newSubtitleProfiles);
-	bool subtitleProfilesNull() const;
-	void setSubtitleProfilesNull();
 
 
 protected:
 	QString m_name;
 	QString m_jellyfinId;
-	QSharedPointer<DeviceIdentification> m_identification = QSharedPointer<DeviceIdentification>();
-	QString m_friendlyName;
-	QString m_manufacturer;
-	QString m_manufacturerUrl;
-	QString m_modelName;
-	QString m_modelDescription;
-	QString m_modelNumber;
-	QString m_modelUrl;
-	QString m_serialNumber;
-	bool m_enableAlbumArtInDidl;
-	bool m_enableSingleAlbumArtLimit;
-	bool m_enableSingleSubtitleLimit;
-	QString m_supportedMediaTypes;
-	QString m_userId;
-	QString m_albumArtPn;
-	qint32 m_maxAlbumArtWidth;
-	qint32 m_maxAlbumArtHeight;
-	std::optional<qint32> m_maxIconWidth = std::nullopt;
-	std::optional<qint32> m_maxIconHeight = std::nullopt;
 	std::optional<qint32> m_maxStreamingBitrate = std::nullopt;
 	std::optional<qint32> m_maxStaticBitrate = std::nullopt;
 	std::optional<qint32> m_musicStreamingTranscodingBitrate = std::nullopt;
 	std::optional<qint32> m_maxStaticMusicBitrate = std::nullopt;
-	QString m_sonyAggregationFlags;
-	QString m_protocolInfo;
-	qint32 m_timelineOffsetSeconds;
-	bool m_requiresPlainVideoItems;
-	bool m_requiresPlainFolders;
-	bool m_enableMSMediaReceiverRegistrar;
-	bool m_ignoreTranscodeByteRangeRequests;
-	QList<XmlAttribute> m_xmlRootAttributes;
 	QList<DirectPlayProfile> m_directPlayProfiles;
 	QList<TranscodingProfile> m_transcodingProfiles;
 	QList<ContainerProfile> m_containerProfiles;
 	QList<CodecProfile> m_codecProfiles;
-	QList<ResponseProfile> m_responseProfiles;
 	QList<SubtitleProfile> m_subtitleProfiles;
 
 private:
diff --git a/core/include/JellyfinQt/dto/directplayprofile.h b/core/include/JellyfinQt/dto/directplayprofile.h
index e4b0445..8ceac72 100644
--- a/core/include/JellyfinQt/dto/directplayprofile.h
+++ b/core/include/JellyfinQt/dto/directplayprofile.h
@@ -48,7 +48,8 @@ namespace DTO {
 
 class DirectPlayProfile {
 public:
-	DirectPlayProfile(							
+	DirectPlayProfile(	
+		QString container,							
 		DlnaProfileType type		
 	);
 
@@ -64,23 +65,33 @@ public:
 	QJsonObject toJson() const;
 	
 	// Properties
-
+	/**
+	 * @brief Gets or sets the container.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the container.
+	*/
 	void setContainer(QString newContainer);
-	bool containerNull() const;
-	void setContainerNull();
-
 
+	/**
+	 * @brief Gets or sets the audio codec.
+	 */
 	QString audioCodec() const;
-
+	/**
+	* @brief Gets or sets the audio codec.
+	*/
 	void setAudioCodec(QString newAudioCodec);
 	bool audioCodecNull() const;
 	void setAudioCodecNull();
 
-
+	/**
+	 * @brief Gets or sets the video codec.
+	 */
 	QString videoCodec() const;
-
+	/**
+	* @brief Gets or sets the video codec.
+	*/
 	void setVideoCodec(QString newVideoCodec);
 	bool videoCodecNull() const;
 	void setVideoCodecNull();
diff --git a/core/include/JellyfinQt/dto/displaypreferencesdto.h b/core/include/JellyfinQt/dto/displaypreferencesdto.h
index d9ef1dc..4099add 100644
--- a/core/include/JellyfinQt/dto/displaypreferencesdto.h
+++ b/core/include/JellyfinQt/dto/displaypreferencesdto.h
@@ -52,7 +52,8 @@ public:
 	DisplayPreferencesDto(									
 		bool rememberIndexing,			
 		qint32 primaryImageHeight,			
-		qint32 primaryImageWidth,					
+		qint32 primaryImageWidth,			
+		QJsonObject customPrefs,			
 		ScrollDirection scrollDirection,			
 		bool showBackdrop,			
 		bool rememberSorting,			
@@ -151,8 +152,6 @@ public:
 	* @brief Gets or sets the custom prefs.
 	*/
 	void setCustomPrefs(QJsonObject newCustomPrefs);
-	bool customPrefsNull() const;
-	void setCustomPrefsNull();
 
 
 	ScrollDirection scrollDirection() const;
diff --git a/core/include/JellyfinQt/dto/dlnaprofiletype.h b/core/include/JellyfinQt/dto/dlnaprofiletype.h
index 4003e43..41937c2 100644
--- a/core/include/JellyfinQt/dto/dlnaprofiletype.h
+++ b/core/include/JellyfinQt/dto/dlnaprofiletype.h
@@ -51,6 +51,8 @@ public:
 		Audio,
 		Video,
 		Photo,
+		Subtitle,
+		Lyric,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/downmixstereoalgorithms.h b/core/include/JellyfinQt/dto/downmixstereoalgorithms.h
new file mode 100644
index 0000000..729ab7c
--- /dev/null
+++ b/core/include/JellyfinQt/dto/downmixstereoalgorithms.h
@@ -0,0 +1,79 @@
+/*
+ * 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_DTO_DOWNMIXSTEREOALGORITHMS_H
+#define JELLYFIN_DTO_DOWNMIXSTEREOALGORITHMS_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class DownMixStereoAlgorithmsClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		None,
+		Dave750,
+		NightmodeDialogue,
+		Rfc7845,
+		Ac4,
+	};
+	Q_ENUM(Value)
+private:
+	explicit DownMixStereoAlgorithmsClass();
+};
+
+using DownMixStereoAlgorithms = DownMixStereoAlgorithmsClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using DownMixStereoAlgorithms = Jellyfin::DTO::DownMixStereoAlgorithms;
+
+template <>
+DownMixStereoAlgorithms fromJsonValue(const QJsonValue &source, convertType<DownMixStereoAlgorithms>);
+
+template <>
+QJsonValue toJsonValue(const DownMixStereoAlgorithms &source, convertType<DownMixStereoAlgorithms>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_DOWNMIXSTEREOALGORITHMS_H
diff --git a/core/include/JellyfinQt/dto/embeddedsubtitleoptions.h b/core/include/JellyfinQt/dto/embeddedsubtitleoptions.h
new file mode 100644
index 0000000..861764b
--- /dev/null
+++ b/core/include/JellyfinQt/dto/embeddedsubtitleoptions.h
@@ -0,0 +1,78 @@
+/*
+ * 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_DTO_EMBEDDEDSUBTITLEOPTIONS_H
+#define JELLYFIN_DTO_EMBEDDEDSUBTITLEOPTIONS_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class EmbeddedSubtitleOptionsClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		AllowAll,
+		AllowText,
+		AllowImage,
+		AllowNone,
+	};
+	Q_ENUM(Value)
+private:
+	explicit EmbeddedSubtitleOptionsClass();
+};
+
+using EmbeddedSubtitleOptions = EmbeddedSubtitleOptionsClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using EmbeddedSubtitleOptions = Jellyfin::DTO::EmbeddedSubtitleOptions;
+
+template <>
+EmbeddedSubtitleOptions fromJsonValue(const QJsonValue &source, convertType<EmbeddedSubtitleOptions>);
+
+template <>
+QJsonValue toJsonValue(const EmbeddedSubtitleOptions &source, convertType<EmbeddedSubtitleOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_EMBEDDEDSUBTITLEOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/encoderpreset.h b/core/include/JellyfinQt/dto/encoderpreset.h
new file mode 100644
index 0000000..fc5854d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/encoderpreset.h
@@ -0,0 +1,85 @@
+/*
+ * 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_DTO_ENCODERPRESET_H
+#define JELLYFIN_DTO_ENCODERPRESET_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class EncoderPresetClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Automatic,
+		Placebo,
+		Veryslow,
+		Slower,
+		Slow,
+		Medium,
+		Fast,
+		Faster,
+		Veryfast,
+		Superfast,
+		Ultrafast,
+	};
+	Q_ENUM(Value)
+private:
+	explicit EncoderPresetClass();
+};
+
+using EncoderPreset = EncoderPresetClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using EncoderPreset = Jellyfin::DTO::EncoderPreset;
+
+template <>
+EncoderPreset fromJsonValue(const QJsonValue &source, convertType<EncoderPreset>);
+
+template <>
+QJsonValue toJsonValue(const EncoderPreset &source, convertType<EncoderPreset>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ENCODERPRESET_H
diff --git a/core/include/JellyfinQt/dto/encodingoptions.h b/core/include/JellyfinQt/dto/encodingoptions.h
new file mode 100644
index 0000000..404114a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/encodingoptions.h
@@ -0,0 +1,595 @@
+/*
+ * 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_DTO_ENCODINGOPTIONS_H
+#define JELLYFIN_DTO_ENCODINGOPTIONS_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/deinterlacemethod.h"
+#include "JellyfinQt/dto/downmixstereoalgorithms.h"
+#include "JellyfinQt/dto/encoderpreset.h"
+#include "JellyfinQt/dto/hardwareaccelerationtype.h"
+#include "JellyfinQt/dto/tonemappingalgorithm.h"
+#include "JellyfinQt/dto/tonemappingmode.h"
+#include "JellyfinQt/dto/tonemappingrange.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class EncodingOptions {
+public:
+	EncodingOptions(	
+		qint32 encodingThreadCount,							
+		bool enableFallbackFont,			
+		bool enableAudioVbr,			
+		double downMixAudioBoost,			
+		DownMixStereoAlgorithms downMixStereoAlgorithm,			
+		qint32 maxMuxingQueueSize,			
+		bool enableThrottling,			
+		qint32 throttleDelaySeconds,			
+		bool enableSegmentDeletion,			
+		qint32 segmentKeepSeconds,			
+		HardwareAccelerationType hardwareAccelerationType,											
+		bool enableTonemapping,			
+		bool enableVppTonemapping,			
+		bool enableVideoToolboxTonemapping,			
+		TonemappingAlgorithm tonemappingAlgorithm,			
+		TonemappingMode tonemappingMode,			
+		TonemappingRange tonemappingRange,			
+		double tonemappingDesat,			
+		double tonemappingPeak,			
+		double tonemappingParam,			
+		double vppTonemappingBrightness,			
+		double vppTonemappingContrast,			
+		qint32 h264Crf,			
+		qint32 h265Crf,			
+		EncoderPreset encoderPreset,			
+		bool deinterlaceDoubleRate,			
+		DeinterlaceMethod deinterlaceMethod,			
+		bool enableDecodingColorDepth10Hevc,			
+		bool enableDecodingColorDepth10Vp9,			
+		bool enableDecodingColorDepth10HevcRext,			
+		bool enableDecodingColorDepth12HevcRext,			
+		bool enableEnhancedNvdecDecoder,			
+		bool preferSystemNativeHwDecoder,			
+		bool enableIntelLowPowerH264HwEncoder,			
+		bool enableIntelLowPowerHevcHwEncoder,			
+		bool enableHardwareEncoding,			
+		bool allowHevcEncoding,			
+		bool allowAv1Encoding,			
+		bool enableSubtitleExtraction						
+	);
+
+	EncodingOptions(const EncodingOptions &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(EncodingOptions &other);
+	
+	static EncodingOptions fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the thread count used for encoding.
+	 */
+	qint32 encodingThreadCount() const;
+	/**
+	* @brief Gets or sets the thread count used for encoding.
+	*/
+	void setEncodingThreadCount(qint32 newEncodingThreadCount);
+
+	/**
+	 * @brief Gets or sets the temporary transcoding path.
+	 */
+	QString transcodingTempPath() const;
+	/**
+	* @brief Gets or sets the temporary transcoding path.
+	*/
+	void setTranscodingTempPath(QString newTranscodingTempPath);
+	bool transcodingTempPathNull() const;
+	void setTranscodingTempPathNull();
+
+	/**
+	 * @brief Gets or sets the path to the fallback font.
+	 */
+	QString fallbackFontPath() const;
+	/**
+	* @brief Gets or sets the path to the fallback font.
+	*/
+	void setFallbackFontPath(QString newFallbackFontPath);
+	bool fallbackFontPathNull() const;
+	void setFallbackFontPathNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether to use the fallback font.
+	 */
+	bool enableFallbackFont() const;
+	/**
+	* @brief Gets or sets a value indicating whether to use the fallback font.
+	*/
+	void setEnableFallbackFont(bool newEnableFallbackFont);
+
+	/**
+	 * @brief Gets or sets a value indicating whether audio VBR is enabled.
+	 */
+	bool enableAudioVbr() const;
+	/**
+	* @brief Gets or sets a value indicating whether audio VBR is enabled.
+	*/
+	void setEnableAudioVbr(bool newEnableAudioVbr);
+
+	/**
+	 * @brief Gets or sets the audio boost applied when downmixing audio.
+	 */
+	double downMixAudioBoost() const;
+	/**
+	* @brief Gets or sets the audio boost applied when downmixing audio.
+	*/
+	void setDownMixAudioBoost(double newDownMixAudioBoost);
+
+
+	DownMixStereoAlgorithms downMixStereoAlgorithm() const;
+
+	void setDownMixStereoAlgorithm(DownMixStereoAlgorithms newDownMixStereoAlgorithm);
+
+	/**
+	 * @brief Gets or sets the maximum size of the muxing queue.
+	 */
+	qint32 maxMuxingQueueSize() const;
+	/**
+	* @brief Gets or sets the maximum size of the muxing queue.
+	*/
+	void setMaxMuxingQueueSize(qint32 newMaxMuxingQueueSize);
+
+	/**
+	 * @brief Gets or sets a value indicating whether throttling is enabled.
+	 */
+	bool enableThrottling() const;
+	/**
+	* @brief Gets or sets a value indicating whether throttling is enabled.
+	*/
+	void setEnableThrottling(bool newEnableThrottling);
+
+	/**
+	 * @brief Gets or sets the delay after which throttling happens.
+	 */
+	qint32 throttleDelaySeconds() const;
+	/**
+	* @brief Gets or sets the delay after which throttling happens.
+	*/
+	void setThrottleDelaySeconds(qint32 newThrottleDelaySeconds);
+
+	/**
+	 * @brief Gets or sets a value indicating whether segment deletion is enabled.
+	 */
+	bool enableSegmentDeletion() const;
+	/**
+	* @brief Gets or sets a value indicating whether segment deletion is enabled.
+	*/
+	void setEnableSegmentDeletion(bool newEnableSegmentDeletion);
+
+	/**
+	 * @brief Gets or sets seconds for which segments should be kept before being deleted.
+	 */
+	qint32 segmentKeepSeconds() const;
+	/**
+	* @brief Gets or sets seconds for which segments should be kept before being deleted.
+	*/
+	void setSegmentKeepSeconds(qint32 newSegmentKeepSeconds);
+
+
+	HardwareAccelerationType hardwareAccelerationType() const;
+
+	void setHardwareAccelerationType(HardwareAccelerationType newHardwareAccelerationType);
+
+	/**
+	 * @brief Gets or sets the FFmpeg path as set by the user via the UI.
+	 */
+	QString encoderAppPath() const;
+	/**
+	* @brief Gets or sets the FFmpeg path as set by the user via the UI.
+	*/
+	void setEncoderAppPath(QString newEncoderAppPath);
+	bool encoderAppPathNull() const;
+	void setEncoderAppPathNull();
+
+	/**
+	 * @brief Gets or sets the current FFmpeg path being used by the system and displayed on the transcode page.
+	 */
+	QString encoderAppPathDisplay() const;
+	/**
+	* @brief Gets or sets the current FFmpeg path being used by the system and displayed on the transcode page.
+	*/
+	void setEncoderAppPathDisplay(QString newEncoderAppPathDisplay);
+	bool encoderAppPathDisplayNull() const;
+	void setEncoderAppPathDisplayNull();
+
+	/**
+	 * @brief Gets or sets the VA-API device.
+	 */
+	QString vaapiDevice() const;
+	/**
+	* @brief Gets or sets the VA-API device.
+	*/
+	void setVaapiDevice(QString newVaapiDevice);
+	bool vaapiDeviceNull() const;
+	void setVaapiDeviceNull();
+
+	/**
+	 * @brief Gets or sets the QSV device.
+	 */
+	QString qsvDevice() const;
+	/**
+	* @brief Gets or sets the QSV device.
+	*/
+	void setQsvDevice(QString newQsvDevice);
+	bool qsvDeviceNull() const;
+	void setQsvDeviceNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether tonemapping is enabled.
+	 */
+	bool enableTonemapping() const;
+	/**
+	* @brief Gets or sets a value indicating whether tonemapping is enabled.
+	*/
+	void setEnableTonemapping(bool newEnableTonemapping);
+
+	/**
+	 * @brief Gets or sets a value indicating whether VPP tonemapping is enabled.
+	 */
+	bool enableVppTonemapping() const;
+	/**
+	* @brief Gets or sets a value indicating whether VPP tonemapping is enabled.
+	*/
+	void setEnableVppTonemapping(bool newEnableVppTonemapping);
+
+	/**
+	 * @brief Gets or sets a value indicating whether videotoolbox tonemapping is enabled.
+	 */
+	bool enableVideoToolboxTonemapping() const;
+	/**
+	* @brief Gets or sets a value indicating whether videotoolbox tonemapping is enabled.
+	*/
+	void setEnableVideoToolboxTonemapping(bool newEnableVideoToolboxTonemapping);
+
+
+	TonemappingAlgorithm tonemappingAlgorithm() const;
+
+	void setTonemappingAlgorithm(TonemappingAlgorithm newTonemappingAlgorithm);
+
+
+	TonemappingMode tonemappingMode() const;
+
+	void setTonemappingMode(TonemappingMode newTonemappingMode);
+
+
+	TonemappingRange tonemappingRange() const;
+
+	void setTonemappingRange(TonemappingRange newTonemappingRange);
+
+	/**
+	 * @brief Gets or sets the tone-mapping desaturation.
+	 */
+	double tonemappingDesat() const;
+	/**
+	* @brief Gets or sets the tone-mapping desaturation.
+	*/
+	void setTonemappingDesat(double newTonemappingDesat);
+
+	/**
+	 * @brief Gets or sets the tone-mapping peak.
+	 */
+	double tonemappingPeak() const;
+	/**
+	* @brief Gets or sets the tone-mapping peak.
+	*/
+	void setTonemappingPeak(double newTonemappingPeak);
+
+	/**
+	 * @brief Gets or sets the tone-mapping parameters.
+	 */
+	double tonemappingParam() const;
+	/**
+	* @brief Gets or sets the tone-mapping parameters.
+	*/
+	void setTonemappingParam(double newTonemappingParam);
+
+	/**
+	 * @brief Gets or sets the VPP tone-mapping brightness.
+	 */
+	double vppTonemappingBrightness() const;
+	/**
+	* @brief Gets or sets the VPP tone-mapping brightness.
+	*/
+	void setVppTonemappingBrightness(double newVppTonemappingBrightness);
+
+	/**
+	 * @brief Gets or sets the VPP tone-mapping contrast.
+	 */
+	double vppTonemappingContrast() const;
+	/**
+	* @brief Gets or sets the VPP tone-mapping contrast.
+	*/
+	void setVppTonemappingContrast(double newVppTonemappingContrast);
+
+	/**
+	 * @brief Gets or sets the H264 CRF.
+	 */
+	qint32 h264Crf() const;
+	/**
+	* @brief Gets or sets the H264 CRF.
+	*/
+	void setH264Crf(qint32 newH264Crf);
+
+	/**
+	 * @brief Gets or sets the H265 CRF.
+	 */
+	qint32 h265Crf() const;
+	/**
+	* @brief Gets or sets the H265 CRF.
+	*/
+	void setH265Crf(qint32 newH265Crf);
+
+
+	EncoderPreset encoderPreset() const;
+
+	void setEncoderPreset(EncoderPreset newEncoderPreset);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the framerate is doubled when deinterlacing.
+	 */
+	bool deinterlaceDoubleRate() const;
+	/**
+	* @brief Gets or sets a value indicating whether the framerate is doubled when deinterlacing.
+	*/
+	void setDeinterlaceDoubleRate(bool newDeinterlaceDoubleRate);
+
+
+	DeinterlaceMethod deinterlaceMethod() const;
+
+	void setDeinterlaceMethod(DeinterlaceMethod newDeinterlaceMethod);
+
+	/**
+	 * @brief Gets or sets a value indicating whether 10bit HEVC decoding is enabled.
+	 */
+	bool enableDecodingColorDepth10Hevc() const;
+	/**
+	* @brief Gets or sets a value indicating whether 10bit HEVC decoding is enabled.
+	*/
+	void setEnableDecodingColorDepth10Hevc(bool newEnableDecodingColorDepth10Hevc);
+
+	/**
+	 * @brief Gets or sets a value indicating whether 10bit VP9 decoding is enabled.
+	 */
+	bool enableDecodingColorDepth10Vp9() const;
+	/**
+	* @brief Gets or sets a value indicating whether 10bit VP9 decoding is enabled.
+	*/
+	void setEnableDecodingColorDepth10Vp9(bool newEnableDecodingColorDepth10Vp9);
+
+	/**
+	 * @brief Gets or sets a value indicating whether 8/10bit HEVC RExt decoding is enabled.
+	 */
+	bool enableDecodingColorDepth10HevcRext() const;
+	/**
+	* @brief Gets or sets a value indicating whether 8/10bit HEVC RExt decoding is enabled.
+	*/
+	void setEnableDecodingColorDepth10HevcRext(bool newEnableDecodingColorDepth10HevcRext);
+
+	/**
+	 * @brief Gets or sets a value indicating whether 12bit HEVC RExt decoding is enabled.
+	 */
+	bool enableDecodingColorDepth12HevcRext() const;
+	/**
+	* @brief Gets or sets a value indicating whether 12bit HEVC RExt decoding is enabled.
+	*/
+	void setEnableDecodingColorDepth12HevcRext(bool newEnableDecodingColorDepth12HevcRext);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the enhanced NVDEC is enabled.
+	 */
+	bool enableEnhancedNvdecDecoder() const;
+	/**
+	* @brief Gets or sets a value indicating whether the enhanced NVDEC is enabled.
+	*/
+	void setEnableEnhancedNvdecDecoder(bool newEnableEnhancedNvdecDecoder);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the system native hardware decoder should be used.
+	 */
+	bool preferSystemNativeHwDecoder() const;
+	/**
+	* @brief Gets or sets a value indicating whether the system native hardware decoder should be used.
+	*/
+	void setPreferSystemNativeHwDecoder(bool newPreferSystemNativeHwDecoder);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the Intel H264 low-power hardware encoder should be used.
+	 */
+	bool enableIntelLowPowerH264HwEncoder() const;
+	/**
+	* @brief Gets or sets a value indicating whether the Intel H264 low-power hardware encoder should be used.
+	*/
+	void setEnableIntelLowPowerH264HwEncoder(bool newEnableIntelLowPowerH264HwEncoder);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the Intel HEVC low-power hardware encoder should be used.
+	 */
+	bool enableIntelLowPowerHevcHwEncoder() const;
+	/**
+	* @brief Gets or sets a value indicating whether the Intel HEVC low-power hardware encoder should be used.
+	*/
+	void setEnableIntelLowPowerHevcHwEncoder(bool newEnableIntelLowPowerHevcHwEncoder);
+
+	/**
+	 * @brief Gets or sets a value indicating whether hardware encoding is enabled.
+	 */
+	bool enableHardwareEncoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether hardware encoding is enabled.
+	*/
+	void setEnableHardwareEncoding(bool newEnableHardwareEncoding);
+
+	/**
+	 * @brief Gets or sets a value indicating whether HEVC encoding is enabled.
+	 */
+	bool allowHevcEncoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether HEVC encoding is enabled.
+	*/
+	void setAllowHevcEncoding(bool newAllowHevcEncoding);
+
+	/**
+	 * @brief Gets or sets a value indicating whether AV1 encoding is enabled.
+	 */
+	bool allowAv1Encoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether AV1 encoding is enabled.
+	*/
+	void setAllowAv1Encoding(bool newAllowAv1Encoding);
+
+	/**
+	 * @brief Gets or sets a value indicating whether subtitle extraction is enabled.
+	 */
+	bool enableSubtitleExtraction() const;
+	/**
+	* @brief Gets or sets a value indicating whether subtitle extraction is enabled.
+	*/
+	void setEnableSubtitleExtraction(bool newEnableSubtitleExtraction);
+
+	/**
+	 * @brief Gets or sets the codecs hardware encoding is used for.
+	 */
+	QStringList hardwareDecodingCodecs() const;
+	/**
+	* @brief Gets or sets the codecs hardware encoding is used for.
+	*/
+	void setHardwareDecodingCodecs(QStringList newHardwareDecodingCodecs);
+	bool hardwareDecodingCodecsNull() const;
+	void setHardwareDecodingCodecsNull();
+
+	/**
+	 * @brief Gets or sets the file extensions on-demand metadata based keyframe extraction is enabled for.
+	 */
+	QStringList allowOnDemandMetadataBasedKeyframeExtractionForExtensions() const;
+	/**
+	* @brief Gets or sets the file extensions on-demand metadata based keyframe extraction is enabled for.
+	*/
+	void setAllowOnDemandMetadataBasedKeyframeExtractionForExtensions(QStringList newAllowOnDemandMetadataBasedKeyframeExtractionForExtensions);
+	bool allowOnDemandMetadataBasedKeyframeExtractionForExtensionsNull() const;
+	void setAllowOnDemandMetadataBasedKeyframeExtractionForExtensionsNull();
+
+
+protected:
+	qint32 m_encodingThreadCount;
+	QString m_transcodingTempPath;
+	QString m_fallbackFontPath;
+	bool m_enableFallbackFont;
+	bool m_enableAudioVbr;
+	double m_downMixAudioBoost;
+	DownMixStereoAlgorithms m_downMixStereoAlgorithm;
+	qint32 m_maxMuxingQueueSize;
+	bool m_enableThrottling;
+	qint32 m_throttleDelaySeconds;
+	bool m_enableSegmentDeletion;
+	qint32 m_segmentKeepSeconds;
+	HardwareAccelerationType m_hardwareAccelerationType;
+	QString m_encoderAppPath;
+	QString m_encoderAppPathDisplay;
+	QString m_vaapiDevice;
+	QString m_qsvDevice;
+	bool m_enableTonemapping;
+	bool m_enableVppTonemapping;
+	bool m_enableVideoToolboxTonemapping;
+	TonemappingAlgorithm m_tonemappingAlgorithm;
+	TonemappingMode m_tonemappingMode;
+	TonemappingRange m_tonemappingRange;
+	double m_tonemappingDesat;
+	double m_tonemappingPeak;
+	double m_tonemappingParam;
+	double m_vppTonemappingBrightness;
+	double m_vppTonemappingContrast;
+	qint32 m_h264Crf;
+	qint32 m_h265Crf;
+	EncoderPreset m_encoderPreset;
+	bool m_deinterlaceDoubleRate;
+	DeinterlaceMethod m_deinterlaceMethod;
+	bool m_enableDecodingColorDepth10Hevc;
+	bool m_enableDecodingColorDepth10Vp9;
+	bool m_enableDecodingColorDepth10HevcRext;
+	bool m_enableDecodingColorDepth12HevcRext;
+	bool m_enableEnhancedNvdecDecoder;
+	bool m_preferSystemNativeHwDecoder;
+	bool m_enableIntelLowPowerH264HwEncoder;
+	bool m_enableIntelLowPowerHevcHwEncoder;
+	bool m_enableHardwareEncoding;
+	bool m_allowHevcEncoding;
+	bool m_allowAv1Encoding;
+	bool m_enableSubtitleExtraction;
+	QStringList m_hardwareDecodingCodecs;
+	QStringList m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions;
+
+private:
+	// Private constructor which generates an invalid object, for use withing EncodingOptions::fromJson();
+	EncodingOptions();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using EncodingOptions = Jellyfin::DTO::EncodingOptions;
+
+template <>
+EncodingOptions fromJsonValue(const QJsonValue &source, convertType<EncodingOptions>);
+
+template<>
+QJsonValue toJsonValue(const EncodingOptions &source, convertType<EncodingOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ENCODINGOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/externalidinfo.h b/core/include/JellyfinQt/dto/externalidinfo.h
index f620490..bee9142 100644
--- a/core/include/JellyfinQt/dto/externalidinfo.h
+++ b/core/include/JellyfinQt/dto/externalidinfo.h
@@ -48,7 +48,9 @@ namespace DTO {
 
 class ExternalIdInfo {
 public:
-	ExternalIdInfo(					
+	ExternalIdInfo(	
+		QString name,			
+		QString key,			
 		ExternalIdMediaType type				
 	);
 
@@ -72,8 +74,6 @@ public:
 	* @brief Gets or sets the display name of the external id provider (IE: IMDB, MusicBrainz, etc).
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets the unique key for this id. This key should be unique across all providers.
@@ -83,8 +83,6 @@ public:
 	* @brief Gets or sets the unique key for this id. This key should be unique across all providers.
 	*/
 	void setKey(QString newKey);
-	bool keyNull() const;
-	void setKeyNull();
 
 
 	ExternalIdMediaType type() const;
diff --git a/core/include/JellyfinQt/dto/externalidmediatype.h b/core/include/JellyfinQt/dto/externalidmediatype.h
index cdf05a5..71e68b1 100644
--- a/core/include/JellyfinQt/dto/externalidmediatype.h
+++ b/core/include/JellyfinQt/dto/externalidmediatype.h
@@ -60,6 +60,7 @@ public:
 		Season,
 		Series,
 		Track,
+		Book,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/extratype.h b/core/include/JellyfinQt/dto/extratype.h
new file mode 100644
index 0000000..05fc773
--- /dev/null
+++ b/core/include/JellyfinQt/dto/extratype.h
@@ -0,0 +1,86 @@
+/*
+ * 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_DTO_EXTRATYPE_H
+#define JELLYFIN_DTO_EXTRATYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class ExtraTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Unknown,
+		Clip,
+		Trailer,
+		BehindTheScenes,
+		DeletedScene,
+		Interview,
+		Scene,
+		Sample,
+		ThemeSong,
+		ThemeVideo,
+		Featurette,
+		Short,
+	};
+	Q_ENUM(Value)
+private:
+	explicit ExtraTypeClass();
+};
+
+using ExtraType = ExtraTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using ExtraType = Jellyfin::DTO::ExtraType;
+
+template <>
+ExtraType fromJsonValue(const QJsonValue &source, convertType<ExtraType>);
+
+template <>
+QJsonValue toJsonValue(const ExtraType &source, convertType<ExtraType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_EXTRATYPE_H
diff --git a/core/include/JellyfinQt/dto/filesystementryinfo.h b/core/include/JellyfinQt/dto/filesystementryinfo.h
index 36a2467..386c483 100644
--- a/core/include/JellyfinQt/dto/filesystementryinfo.h
+++ b/core/include/JellyfinQt/dto/filesystementryinfo.h
@@ -48,7 +48,9 @@ namespace DTO {
 
 class FileSystemEntryInfo {
 public:
-	FileSystemEntryInfo(					
+	FileSystemEntryInfo(	
+		QString name,			
+		QString path,			
 		FileSystemEntryType type		
 	);
 
@@ -72,8 +74,6 @@ public:
 	* @brief Gets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets the path.
@@ -83,8 +83,6 @@ public:
 	* @brief Gets the path.
 	*/
 	void setPath(QString newPath);
-	bool pathNull() const;
-	void setPathNull();
 
 
 	FileSystemEntryType type() const;
diff --git a/core/include/JellyfinQt/dto/forcekeepalivemessage.h b/core/include/JellyfinQt/dto/forcekeepalivemessage.h
new file mode 100644
index 0000000..72c6c28
--- /dev/null
+++ b/core/include/JellyfinQt/dto/forcekeepalivemessage.h
@@ -0,0 +1,119 @@
+/*
+ * 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_DTO_FORCEKEEPALIVEMESSAGE_H
+#define JELLYFIN_DTO_FORCEKEEPALIVEMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ForceKeepAliveMessage {
+public:
+	ForceKeepAliveMessage(	
+		qint32 data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ForceKeepAliveMessage(const ForceKeepAliveMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ForceKeepAliveMessage &other);
+	
+	static ForceKeepAliveMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	qint32 data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(qint32 newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	qint32 m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ForceKeepAliveMessage::fromJson();
+	ForceKeepAliveMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ForceKeepAliveMessage = Jellyfin::DTO::ForceKeepAliveMessage;
+
+template <>
+ForceKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<ForceKeepAliveMessage>);
+
+template<>
+QJsonValue toJsonValue(const ForceKeepAliveMessage &source, convertType<ForceKeepAliveMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_FORCEKEEPALIVEMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/xmlattribute.h b/core/include/JellyfinQt/dto/forgotpasswordpindto.h
similarity index 65%
rename from core/include/JellyfinQt/dto/xmlattribute.h
rename to core/include/JellyfinQt/dto/forgotpasswordpindto.h
index 6becfe9..e074d6a 100644
--- a/core/include/JellyfinQt/dto/xmlattribute.h
+++ b/core/include/JellyfinQt/dto/forgotpasswordpindto.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_XMLATTRIBUTE_H
-#define JELLYFIN_DTO_XMLATTRIBUTE_H
+#ifndef JELLYFIN_DTO_FORGOTPASSWORDPINDTO_H
+#define JELLYFIN_DTO_FORGOTPASSWORDPINDTO_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -45,48 +45,40 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class XmlAttribute {
-public:	XmlAttribute();
-	XmlAttribute(const XmlAttribute &other);
+class ForgotPasswordPinDto {
+public:
+	ForgotPasswordPinDto(	
+		QString pin		
+	);
+
+	ForgotPasswordPinDto(const ForgotPasswordPinDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(XmlAttribute &other);
+	void replaceData(ForgotPasswordPinDto &other);
 	
-	static XmlAttribute fromJson(QJsonObject source);
+	static ForgotPasswordPinDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the name of the attribute.
+	 * @brief Gets or sets the entered pin to have the password reset.
 	 */
-	QString name() const;
+	QString pin() const;
 	/**
-	* @brief Gets or sets the name of the attribute.
+	* @brief Gets or sets the entered pin to have the password reset.
 	*/
-	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-
-	/**
-	 * @brief Gets or sets the value of the attribute.
-	 */
-	QString value() const;
-	/**
-	* @brief Gets or sets the value of the attribute.
-	*/
-	void setValue(QString newValue);
-	bool valueNull() const;
-	void setValueNull();
+	void setPin(QString newPin);
 
 
 protected:
-	QString m_name;
-	QString m_value;
-
+	QString m_pin;
 
+private:
+	// Private constructor which generates an invalid object, for use withing ForgotPasswordPinDto::fromJson();
+	ForgotPasswordPinDto();
 };
 
 
@@ -94,15 +86,15 @@ protected:
 
 namespace Support {
 
-using XmlAttribute = Jellyfin::DTO::XmlAttribute;
+using ForgotPasswordPinDto = Jellyfin::DTO::ForgotPasswordPinDto;
 
 template <>
-XmlAttribute fromJsonValue(const QJsonValue &source, convertType<XmlAttribute>);
+ForgotPasswordPinDto fromJsonValue(const QJsonValue &source, convertType<ForgotPasswordPinDto>);
 
 template<>
-QJsonValue toJsonValue(const XmlAttribute &source, convertType<XmlAttribute>);
+QJsonValue toJsonValue(const ForgotPasswordPinDto &source, convertType<ForgotPasswordPinDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_XMLATTRIBUTE_H
+#endif // JELLYFIN_DTO_FORGOTPASSWORDPINDTO_H
diff --git a/core/include/JellyfinQt/dto/generalcommand.h b/core/include/JellyfinQt/dto/generalcommand.h
index d4b8ca0..0019d49 100644
--- a/core/include/JellyfinQt/dto/generalcommand.h
+++ b/core/include/JellyfinQt/dto/generalcommand.h
@@ -50,7 +50,8 @@ class GeneralCommand {
 public:
 	GeneralCommand(	
 		GeneralCommandType name,			
-		QString controllingUserId				
+		QString controllingUserId,			
+		QJsonObject arguments		
 	);
 
 	GeneralCommand(const GeneralCommand &other);
@@ -79,8 +80,6 @@ public:
 	QJsonObject arguments() const;
 
 	void setArguments(QJsonObject newArguments);
-	bool argumentsNull() const;
-	void setArgumentsNull();
 
 
 protected:
diff --git a/core/include/JellyfinQt/dto/generalcommandmessage.h b/core/include/JellyfinQt/dto/generalcommandmessage.h
new file mode 100644
index 0000000..37bfb24
--- /dev/null
+++ b/core/include/JellyfinQt/dto/generalcommandmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_GENERALCOMMANDMESSAGE_H
+#define JELLYFIN_DTO_GENERALCOMMANDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/generalcommand.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class GeneralCommandMessage {
+public:
+	GeneralCommandMessage(	
+		QSharedPointer<GeneralCommand> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	GeneralCommandMessage(const GeneralCommandMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(GeneralCommandMessage &other);
+	
+	static GeneralCommandMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<GeneralCommand> data() const;
+
+	void setData(QSharedPointer<GeneralCommand> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<GeneralCommand> m_data = QSharedPointer<GeneralCommand>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing GeneralCommandMessage::fromJson();
+	GeneralCommandMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using GeneralCommandMessage = Jellyfin::DTO::GeneralCommandMessage;
+
+template <>
+GeneralCommandMessage fromJsonValue(const QJsonValue &source, convertType<GeneralCommandMessage>);
+
+template<>
+QJsonValue toJsonValue(const GeneralCommandMessage &source, convertType<GeneralCommandMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_GENERALCOMMANDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/generalcommandtype.h b/core/include/JellyfinQt/dto/generalcommandtype.h
index 05cb573..f5bbe39 100644
--- a/core/include/JellyfinQt/dto/generalcommandtype.h
+++ b/core/include/JellyfinQt/dto/generalcommandtype.h
@@ -89,6 +89,8 @@ public:
 		PlayNext,
 		ToggleOsdMenu,
 		Play,
+		SetMaxStreamingBitrate,
+		SetPlaybackOrder,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/getprogramsdto.h b/core/include/JellyfinQt/dto/getprogramsdto.h
index 3c481b0..ef7bffa 100644
--- a/core/include/JellyfinQt/dto/getprogramsdto.h
+++ b/core/include/JellyfinQt/dto/getprogramsdto.h
@@ -40,6 +40,8 @@
 
 #include "JellyfinQt/dto/imagetype.h"
 #include "JellyfinQt/dto/itemfields.h"
+#include "JellyfinQt/dto/itemsortby.h"
+#include "JellyfinQt/dto/sortorder.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -52,10 +54,8 @@ namespace DTO {
 
 class GetProgramsDto {
 public:
-	GetProgramsDto(			
-		QString userId,																																							
-		bool enableTotalRecordCount,											
-		QString librarySeriesId				
+	GetProgramsDto(																																									
+		std::optional<bool> enableTotalRecordCount														
 	);
 
 	GetProgramsDto(const GetProgramsDto &other);
@@ -89,197 +89,171 @@ public:
 	* @brief Gets or sets optional. Filter by user id.
 	*/
 	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
 
 	/**
-	 * @brief Gets or sets the minimum premiere start date.
-Optional.
+	 * @brief Gets or sets the minimum premiere start date.
 	 */
 	QDateTime minStartDate() const;
 	/**
-	* @brief Gets or sets the minimum premiere start date.
-Optional.
+	* @brief Gets or sets the minimum premiere start date.
 	*/
 	void setMinStartDate(QDateTime newMinStartDate);
 	bool minStartDateNull() const;
 	void setMinStartDateNull();
 
 	/**
-	 * @brief Gets or sets filter by programs that have completed airing, or not.
-Optional.
+	 * @brief Gets or sets filter by programs that have completed airing, or not.
 	 */
 	std::optional<bool> hasAired() const;
 	/**
-	* @brief Gets or sets filter by programs that have completed airing, or not.
-Optional.
+	* @brief Gets or sets filter by programs that have completed airing, or not.
 	*/
 	void setHasAired(std::optional<bool> newHasAired);
 	bool hasAiredNull() const;
 	void setHasAiredNull();
 
 	/**
-	 * @brief Gets or sets filter by programs that are currently airing, or not.
-Optional.
+	 * @brief Gets or sets filter by programs that are currently airing, or not.
 	 */
 	std::optional<bool> isAiring() const;
 	/**
-	* @brief Gets or sets filter by programs that are currently airing, or not.
-Optional.
+	* @brief Gets or sets filter by programs that are currently airing, or not.
 	*/
 	void setIsAiring(std::optional<bool> newIsAiring);
 	bool isAiringNull() const;
 	void setIsAiringNull();
 
 	/**
-	 * @brief Gets or sets the maximum premiere start date.
-Optional.
+	 * @brief Gets or sets the maximum premiere start date.
 	 */
 	QDateTime maxStartDate() const;
 	/**
-	* @brief Gets or sets the maximum premiere start date.
-Optional.
+	* @brief Gets or sets the maximum premiere start date.
 	*/
 	void setMaxStartDate(QDateTime newMaxStartDate);
 	bool maxStartDateNull() const;
 	void setMaxStartDateNull();
 
 	/**
-	 * @brief Gets or sets the minimum premiere end date.
-Optional.
+	 * @brief Gets or sets the minimum premiere end date.
 	 */
 	QDateTime minEndDate() const;
 	/**
-	* @brief Gets or sets the minimum premiere end date.
-Optional.
+	* @brief Gets or sets the minimum premiere end date.
 	*/
 	void setMinEndDate(QDateTime newMinEndDate);
 	bool minEndDateNull() const;
 	void setMinEndDateNull();
 
 	/**
-	 * @brief Gets or sets the maximum premiere end date.
-Optional.
+	 * @brief Gets or sets the maximum premiere end date.
 	 */
 	QDateTime maxEndDate() const;
 	/**
-	* @brief Gets or sets the maximum premiere end date.
-Optional.
+	* @brief Gets or sets the maximum premiere end date.
 	*/
 	void setMaxEndDate(QDateTime newMaxEndDate);
 	bool maxEndDateNull() const;
 	void setMaxEndDateNull();
 
 	/**
-	 * @brief Gets or sets filter for movies.
-Optional.
+	 * @brief Gets or sets filter for movies.
 	 */
 	std::optional<bool> isMovie() const;
 	/**
-	* @brief Gets or sets filter for movies.
-Optional.
+	* @brief Gets or sets filter for movies.
 	*/
 	void setIsMovie(std::optional<bool> newIsMovie);
 	bool isMovieNull() const;
 	void setIsMovieNull();
 
 	/**
-	 * @brief Gets or sets filter for series.
-Optional.
+	 * @brief Gets or sets filter for series.
 	 */
 	std::optional<bool> isSeries() const;
 	/**
-	* @brief Gets or sets filter for series.
-Optional.
+	* @brief Gets or sets filter for series.
 	*/
 	void setIsSeries(std::optional<bool> newIsSeries);
 	bool isSeriesNull() const;
 	void setIsSeriesNull();
 
 	/**
-	 * @brief Gets or sets filter for news.
-Optional.
+	 * @brief Gets or sets filter for news.
 	 */
 	std::optional<bool> isNews() const;
 	/**
-	* @brief Gets or sets filter for news.
-Optional.
+	* @brief Gets or sets filter for news.
 	*/
 	void setIsNews(std::optional<bool> newIsNews);
 	bool isNewsNull() const;
 	void setIsNewsNull();
 
 	/**
-	 * @brief Gets or sets filter for kids.
-Optional.
+	 * @brief Gets or sets filter for kids.
 	 */
 	std::optional<bool> isKids() const;
 	/**
-	* @brief Gets or sets filter for kids.
-Optional.
+	* @brief Gets or sets filter for kids.
 	*/
 	void setIsKids(std::optional<bool> newIsKids);
 	bool isKidsNull() const;
 	void setIsKidsNull();
 
 	/**
-	 * @brief Gets or sets filter for sports.
-Optional.
+	 * @brief Gets or sets filter for sports.
 	 */
 	std::optional<bool> isSports() const;
 	/**
-	* @brief Gets or sets filter for sports.
-Optional.
+	* @brief Gets or sets filter for sports.
 	*/
 	void setIsSports(std::optional<bool> newIsSports);
 	bool isSportsNull() const;
 	void setIsSportsNull();
 
 	/**
-	 * @brief Gets or sets the record index to start at. All items with a lower index will be dropped from the results.
-Optional.
+	 * @brief Gets or sets the record index to start at. All items with a lower index will be dropped from the results.
 	 */
 	std::optional<qint32> startIndex() const;
 	/**
-	* @brief Gets or sets the record index to start at. All items with a lower index will be dropped from the results.
-Optional.
+	* @brief Gets or sets the record index to start at. All items with a lower index will be dropped from the results.
 	*/
 	void setStartIndex(std::optional<qint32> newStartIndex);
 	bool startIndexNull() const;
 	void setStartIndexNull();
 
 	/**
-	 * @brief Gets or sets the maximum number of records to return.
-Optional.
+	 * @brief Gets or sets the maximum number of records to return.
 	 */
 	std::optional<qint32> limit() const;
 	/**
-	* @brief Gets or sets the maximum number of records to return.
-Optional.
+	* @brief Gets or sets the maximum number of records to return.
 	*/
 	void setLimit(std::optional<qint32> newLimit);
 	bool limitNull() const;
 	void setLimitNull();
 
 	/**
-	 * @brief Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.
-Optional.
+	 * @brief Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.
 	 */
-	QString sortBy() const;
+	QList<ItemSortBy> sortBy() const;
 	/**
-	* @brief Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.
-Optional.
+	* @brief Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.
 	*/
-	void setSortBy(QString newSortBy);
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 
 	/**
-	 * @brief Gets or sets sort Order - Ascending,Descending.
+	 * @brief Gets or sets sort order.
 	 */
-	QString sortOrder() const;
+	QList<SortOrder> sortOrder() const;
 	/**
-	* @brief Gets or sets sort Order - Ascending,Descending.
+	* @brief Gets or sets sort order.
 	*/
-	void setSortOrder(QString newSortOrder);
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 
@@ -306,13 +280,11 @@ Optional.
 	void setGenreIdsNull();
 
 	/**
-	 * @brief Gets or sets include image information in output.
-Optional.
+	 * @brief Gets or sets include image information in output.
 	 */
 	std::optional<bool> enableImages() const;
 	/**
-	* @brief Gets or sets include image information in output.
-Optional.
+	* @brief Gets or sets include image information in output.
 	*/
 	void setEnableImages(std::optional<bool> newEnableImages);
 	bool enableImagesNull() const;
@@ -321,83 +293,73 @@ Optional.
 	/**
 	 * @brief Gets or sets a value indicating whether retrieve total record count.
 	 */
-	bool enableTotalRecordCount() const;
+	std::optional<bool> enableTotalRecordCount() const;
 	/**
 	* @brief Gets or sets a value indicating whether retrieve total record count.
 	*/
-	void setEnableTotalRecordCount(bool newEnableTotalRecordCount);
+	void setEnableTotalRecordCount(std::optional<bool> newEnableTotalRecordCount);
 
 	/**
-	 * @brief Gets or sets the max number of images to return, per image type.
-Optional.
+	 * @brief Gets or sets the max number of images to return, per image type.
 	 */
 	std::optional<qint32> imageTypeLimit() const;
 	/**
-	* @brief Gets or sets the max number of images to return, per image type.
-Optional.
+	* @brief Gets or sets the max number of images to return, per image type.
 	*/
 	void setImageTypeLimit(std::optional<qint32> newImageTypeLimit);
 	bool imageTypeLimitNull() const;
 	void setImageTypeLimitNull();
 
 	/**
-	 * @brief Gets or sets the image types to include in the output.
-Optional.
+	 * @brief Gets or sets the image types to include in the output.
 	 */
 	QList<ImageType> enableImageTypes() const;
 	/**
-	* @brief Gets or sets the image types to include in the output.
-Optional.
+	* @brief Gets or sets the image types to include in the output.
 	*/
 	void setEnableImageTypes(QList<ImageType> newEnableImageTypes);
 	bool enableImageTypesNull() const;
 	void setEnableImageTypesNull();
 
 	/**
-	 * @brief Gets or sets include user data.
-Optional.
+	 * @brief Gets or sets include user data.
 	 */
 	std::optional<bool> enableUserData() const;
 	/**
-	* @brief Gets or sets include user data.
-Optional.
+	* @brief Gets or sets include user data.
 	*/
 	void setEnableUserData(std::optional<bool> newEnableUserData);
 	bool enableUserDataNull() const;
 	void setEnableUserDataNull();
 
 	/**
-	 * @brief Gets or sets filter by series timer id.
-Optional.
+	 * @brief Gets or sets filter by series timer id.
 	 */
 	QString seriesTimerId() const;
 	/**
-	* @brief Gets or sets filter by series timer id.
-Optional.
+	* @brief Gets or sets filter by series timer id.
 	*/
 	void setSeriesTimerId(QString newSeriesTimerId);
 	bool seriesTimerIdNull() const;
 	void setSeriesTimerIdNull();
 
 	/**
-	 * @brief Gets or sets filter by library series id.
-Optional.
+	 * @brief Gets or sets filter by library series id.
 	 */
 	QString librarySeriesId() const;
 	/**
-	* @brief Gets or sets filter by library series id.
-Optional.
+	* @brief Gets or sets filter by library series id.
 	*/
 	void setLibrarySeriesId(QString newLibrarySeriesId);
+	bool librarySeriesIdNull() const;
+	void setLibrarySeriesIdNull();
 
 	/**
-	 * @brief Gets or sets specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.
-Optional.
+	 * @brief Gets or sets specify additional fields of information to return in the output.
 	 */
 	QList<ItemFields> fields() const;
 	/**
-	* @brief Gets or sets specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.
-Optional.
+	* @brief Gets or sets specify additional fields of information to return in the output.
 	*/
 	void setFields(QList<ItemFields> newFields);
 	bool fieldsNull() const;
@@ -420,12 +382,12 @@ protected:
 	std::optional<bool> m_isSports = std::nullopt;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	QStringList m_genres;
 	QStringList m_genreIds;
 	std::optional<bool> m_enableImages = std::nullopt;
-	bool m_enableTotalRecordCount;
+	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
 	QList<ImageType> m_enableImageTypes;
 	std::optional<bool> m_enableUserData = std::nullopt;
diff --git a/core/include/JellyfinQt/dto/groupinfodto.h b/core/include/JellyfinQt/dto/groupinfodto.h
index 33414b0..d7e4358 100644
--- a/core/include/JellyfinQt/dto/groupinfodto.h
+++ b/core/include/JellyfinQt/dto/groupinfodto.h
@@ -52,8 +52,10 @@ namespace DTO {
 class GroupInfoDto {
 public:
 	GroupInfoDto(	
-		QString groupId,					
-		GroupStateType state,					
+		QString groupId,			
+		QString groupName,			
+		GroupStateType state,			
+		QStringList participants,			
 		QDateTime lastUpdatedAt		
 	);
 
@@ -86,8 +88,6 @@ public:
 	* @brief Gets the group name.
 	*/
 	void setGroupName(QString newGroupName);
-	bool groupNameNull() const;
-	void setGroupNameNull();
 
 
 	GroupStateType state() const;
@@ -102,8 +102,6 @@ public:
 	* @brief Gets the participants.
 	*/
 	void setParticipants(QStringList newParticipants);
-	bool participantsNull() const;
-	void setParticipantsNull();
 
 	/**
 	 * @brief Gets the date when this DTO has been created.
diff --git a/core/include/JellyfinQt/dto/groupinfodtogroupupdate.h b/core/include/JellyfinQt/dto/groupinfodtogroupupdate.h
new file mode 100644
index 0000000..b8afd24
--- /dev/null
+++ b/core/include/JellyfinQt/dto/groupinfodtogroupupdate.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_GROUPINFODTOGROUPUPDATE_H
+#define JELLYFIN_DTO_GROUPINFODTOGROUPUPDATE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/groupinfodto.h"
+#include "JellyfinQt/dto/groupupdatetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class GroupInfoDtoGroupUpdate {
+public:
+	GroupInfoDtoGroupUpdate(	
+		QString groupId,			
+		GroupUpdateType type,			
+		QSharedPointer<GroupInfoDto> data		
+	);
+
+	GroupInfoDtoGroupUpdate(const GroupInfoDtoGroupUpdate &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(GroupInfoDtoGroupUpdate &other);
+	
+	static GroupInfoDtoGroupUpdate fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets the group identifier.
+	 */
+	QString groupId() const;
+	/**
+	* @brief Gets the group identifier.
+	*/
+	void setGroupId(QString newGroupId);
+
+
+	GroupUpdateType type() const;
+
+	void setType(GroupUpdateType newType);
+
+
+	QSharedPointer<GroupInfoDto> data() const;
+
+	void setData(QSharedPointer<GroupInfoDto> newData);
+
+
+protected:
+	QString m_groupId;
+	GroupUpdateType m_type;
+	QSharedPointer<GroupInfoDto> m_data = QSharedPointer<GroupInfoDto>();
+
+private:
+	// Private constructor which generates an invalid object, for use withing GroupInfoDtoGroupUpdate::fromJson();
+	GroupInfoDtoGroupUpdate();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupInfoDtoGroupUpdate = Jellyfin::DTO::GroupInfoDtoGroupUpdate;
+
+template <>
+GroupInfoDtoGroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupInfoDtoGroupUpdate>);
+
+template<>
+QJsonValue toJsonValue(const GroupInfoDtoGroupUpdate &source, convertType<GroupInfoDtoGroupUpdate>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_GROUPINFODTOGROUPUPDATE_H
diff --git a/core/include/JellyfinQt/dto/groupstateupdate.h b/core/include/JellyfinQt/dto/groupstateupdate.h
new file mode 100644
index 0000000..358038e
--- /dev/null
+++ b/core/include/JellyfinQt/dto/groupstateupdate.h
@@ -0,0 +1,104 @@
+/*
+ * 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_DTO_GROUPSTATEUPDATE_H
+#define JELLYFIN_DTO_GROUPSTATEUPDATE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/dto/groupstatetype.h"
+#include "JellyfinQt/dto/playbackrequesttype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class GroupStateUpdate {
+public:
+	GroupStateUpdate(	
+		GroupStateType state,			
+		PlaybackRequestType reason		
+	);
+
+	GroupStateUpdate(const GroupStateUpdate &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(GroupStateUpdate &other);
+	
+	static GroupStateUpdate fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	GroupStateType state() const;
+
+	void setState(GroupStateType newState);
+
+
+	PlaybackRequestType reason() const;
+
+	void setReason(PlaybackRequestType newReason);
+
+
+protected:
+	GroupStateType m_state;
+	PlaybackRequestType m_reason;
+
+private:
+	// Private constructor which generates an invalid object, for use withing GroupStateUpdate::fromJson();
+	GroupStateUpdate();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupStateUpdate = Jellyfin::DTO::GroupStateUpdate;
+
+template <>
+GroupStateUpdate fromJsonValue(const QJsonValue &source, convertType<GroupStateUpdate>);
+
+template<>
+QJsonValue toJsonValue(const GroupStateUpdate &source, convertType<GroupStateUpdate>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_GROUPSTATEUPDATE_H
diff --git a/core/include/JellyfinQt/dto/groupstateupdategroupupdate.h b/core/include/JellyfinQt/dto/groupstateupdategroupupdate.h
new file mode 100644
index 0000000..263c52a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/groupstateupdategroupupdate.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_GROUPSTATEUPDATEGROUPUPDATE_H
+#define JELLYFIN_DTO_GROUPSTATEUPDATEGROUPUPDATE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/groupstateupdate.h"
+#include "JellyfinQt/dto/groupupdatetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class GroupStateUpdateGroupUpdate {
+public:
+	GroupStateUpdateGroupUpdate(	
+		QString groupId,			
+		GroupUpdateType type,			
+		QSharedPointer<GroupStateUpdate> data		
+	);
+
+	GroupStateUpdateGroupUpdate(const GroupStateUpdateGroupUpdate &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(GroupStateUpdateGroupUpdate &other);
+	
+	static GroupStateUpdateGroupUpdate fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets the group identifier.
+	 */
+	QString groupId() const;
+	/**
+	* @brief Gets the group identifier.
+	*/
+	void setGroupId(QString newGroupId);
+
+
+	GroupUpdateType type() const;
+
+	void setType(GroupUpdateType newType);
+
+
+	QSharedPointer<GroupStateUpdate> data() const;
+
+	void setData(QSharedPointer<GroupStateUpdate> newData);
+
+
+protected:
+	QString m_groupId;
+	GroupUpdateType m_type;
+	QSharedPointer<GroupStateUpdate> m_data = QSharedPointer<GroupStateUpdate>();
+
+private:
+	// Private constructor which generates an invalid object, for use withing GroupStateUpdateGroupUpdate::fromJson();
+	GroupStateUpdateGroupUpdate();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupStateUpdateGroupUpdate = Jellyfin::DTO::GroupStateUpdateGroupUpdate;
+
+template <>
+GroupStateUpdateGroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupStateUpdateGroupUpdate>);
+
+template<>
+QJsonValue toJsonValue(const GroupStateUpdateGroupUpdate &source, convertType<GroupStateUpdateGroupUpdate>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_GROUPSTATEUPDATEGROUPUPDATE_H
diff --git a/core/include/JellyfinQt/dto/controlresponse.h b/core/include/JellyfinQt/dto/groupupdate.h
similarity index 66%
rename from core/include/JellyfinQt/dto/controlresponse.h
rename to core/include/JellyfinQt/dto/groupupdate.h
index d8d9d06..773d518 100644
--- a/core/include/JellyfinQt/dto/controlresponse.h
+++ b/core/include/JellyfinQt/dto/groupupdate.h
@@ -27,14 +27,15 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_CONTROLRESPONSE_H
-#define JELLYFIN_DTO_CONTROLRESPONSE_H
+#ifndef JELLYFIN_DTO_GROUPUPDATE_H
+#define JELLYFIN_DTO_GROUPUPDATE_H
 
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/groupupdatetype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -45,52 +46,47 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class ControlResponse {
+class GroupUpdate {
 public:
-	ControlResponse(					
-		bool isSuccessful		
+	GroupUpdate(	
+		QString groupId,			
+		GroupUpdateType type		
 	);
 
-	ControlResponse(const ControlResponse &other);
+	GroupUpdate(const GroupUpdate &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(ControlResponse &other);
+	void replaceData(GroupUpdate &other);
 	
-	static ControlResponse fromJson(QJsonObject source);
+	static GroupUpdate fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
-
-	QJsonObject headers() const;
-
-	void setHeaders(QJsonObject newHeaders);
-	bool headersNull() const;
-	void setHeadersNull();
+	/**
+	 * @brief Gets the group identifier.
+	 */
+	QString groupId() const;
+	/**
+	* @brief Gets the group identifier.
+	*/
+	void setGroupId(QString newGroupId);
 
 
-	QString xml() const;
+	GroupUpdateType type() const;
 
-	void setXml(QString newXml);
-	bool xmlNull() const;
-	void setXmlNull();
-
-
-	bool isSuccessful() const;
-
-	void setIsSuccessful(bool newIsSuccessful);
+	void setType(GroupUpdateType newType);
 
 
 protected:
-	QJsonObject m_headers;
-	QString m_xml;
-	bool m_isSuccessful;
+	QString m_groupId;
+	GroupUpdateType m_type;
 
 private:
-	// Private constructor which generates an invalid object, for use withing ControlResponse::fromJson();
-	ControlResponse();
+	// Private constructor which generates an invalid object, for use withing GroupUpdate::fromJson();
+	GroupUpdate();
 };
 
 
@@ -98,15 +94,15 @@ private:
 
 namespace Support {
 
-using ControlResponse = Jellyfin::DTO::ControlResponse;
+using GroupUpdate = Jellyfin::DTO::GroupUpdate;
 
 template <>
-ControlResponse fromJsonValue(const QJsonValue &source, convertType<ControlResponse>);
+GroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupUpdate>);
 
 template<>
-QJsonValue toJsonValue(const ControlResponse &source, convertType<ControlResponse>);
+QJsonValue toJsonValue(const GroupUpdate &source, convertType<GroupUpdate>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_CONTROLRESPONSE_H
+#endif // JELLYFIN_DTO_GROUPUPDATE_H
diff --git a/core/include/JellyfinQt/dto/hardwareaccelerationtype.h b/core/include/JellyfinQt/dto/hardwareaccelerationtype.h
new file mode 100644
index 0000000..aa22d6d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/hardwareaccelerationtype.h
@@ -0,0 +1,82 @@
+/*
+ * 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_DTO_HARDWAREACCELERATIONTYPE_H
+#define JELLYFIN_DTO_HARDWAREACCELERATIONTYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class HardwareAccelerationTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		None,
+		Amf,
+		Qsv,
+		Nvenc,
+		V4l2m2m,
+		Vaapi,
+		Videotoolbox,
+		Rkmpp,
+	};
+	Q_ENUM(Value)
+private:
+	explicit HardwareAccelerationTypeClass();
+};
+
+using HardwareAccelerationType = HardwareAccelerationTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using HardwareAccelerationType = Jellyfin::DTO::HardwareAccelerationType;
+
+template <>
+HardwareAccelerationType fromJsonValue(const QJsonValue &source, convertType<HardwareAccelerationType>);
+
+template <>
+QJsonValue toJsonValue(const HardwareAccelerationType &source, convertType<HardwareAccelerationType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_HARDWAREACCELERATIONTYPE_H
diff --git a/core/include/JellyfinQt/dto/imageformat.h b/core/include/JellyfinQt/dto/imageformat.h
index 78a1f3d..4513506 100644
--- a/core/include/JellyfinQt/dto/imageformat.h
+++ b/core/include/JellyfinQt/dto/imageformat.h
@@ -53,6 +53,7 @@ public:
 		Jpg,
 		Png,
 		Webp,
+		Svg,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/imageproviderinfo.h b/core/include/JellyfinQt/dto/imageproviderinfo.h
index e64e461..bb3ca8a 100644
--- a/core/include/JellyfinQt/dto/imageproviderinfo.h
+++ b/core/include/JellyfinQt/dto/imageproviderinfo.h
@@ -49,7 +49,12 @@ namespace DTO {
 
 
 class ImageProviderInfo {
-public:	ImageProviderInfo();
+public:
+	ImageProviderInfo(	
+		QString name,			
+		QList<ImageType> supportedImages		
+	);
+
 	ImageProviderInfo(const ImageProviderInfo &other);
 	
 	/**
@@ -70,8 +75,6 @@ public:	ImageProviderInfo();
 	* @brief Gets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets the supported image types.
@@ -81,15 +84,15 @@ public:	ImageProviderInfo();
 	* @brief Gets the supported image types.
 	*/
 	void setSupportedImages(QList<ImageType> newSupportedImages);
-	bool supportedImagesNull() const;
-	void setSupportedImagesNull();
 
 
 protected:
 	QString m_name;
 	QList<ImageType> m_supportedImages;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing ImageProviderInfo::fromJson();
+	ImageProviderInfo();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/imageresolution.h b/core/include/JellyfinQt/dto/imageresolution.h
new file mode 100644
index 0000000..044d32d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/imageresolution.h
@@ -0,0 +1,83 @@
+/*
+ * 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_DTO_IMAGERESOLUTION_H
+#define JELLYFIN_DTO_IMAGERESOLUTION_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class ImageResolutionClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		MatchSource,
+		P144,
+		P240,
+		P360,
+		P480,
+		P720,
+		P1080,
+		P1440,
+		P2160,
+	};
+	Q_ENUM(Value)
+private:
+	explicit ImageResolutionClass();
+};
+
+using ImageResolution = ImageResolutionClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using ImageResolution = Jellyfin::DTO::ImageResolution;
+
+template <>
+ImageResolution fromJsonValue(const QJsonValue &source, convertType<ImageResolution>);
+
+template <>
+QJsonValue toJsonValue(const ImageResolution &source, convertType<ImageResolution>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_IMAGERESOLUTION_H
diff --git a/core/include/JellyfinQt/dto/inboundkeepalivemessage.h b/core/include/JellyfinQt/dto/inboundkeepalivemessage.h
new file mode 100644
index 0000000..b0d8cf4
--- /dev/null
+++ b/core/include/JellyfinQt/dto/inboundkeepalivemessage.h
@@ -0,0 +1,96 @@
+/*
+ * 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_DTO_INBOUNDKEEPALIVEMESSAGE_H
+#define JELLYFIN_DTO_INBOUNDKEEPALIVEMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class InboundKeepAliveMessage {
+public:
+	InboundKeepAliveMessage(	
+		SessionMessageType messageType		
+	);
+
+	InboundKeepAliveMessage(const InboundKeepAliveMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(InboundKeepAliveMessage &other);
+	
+	static InboundKeepAliveMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing InboundKeepAliveMessage::fromJson();
+	InboundKeepAliveMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using InboundKeepAliveMessage = Jellyfin::DTO::InboundKeepAliveMessage;
+
+template <>
+InboundKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<InboundKeepAliveMessage>);
+
+template<>
+QJsonValue toJsonValue(const InboundKeepAliveMessage &source, convertType<InboundKeepAliveMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_INBOUNDKEEPALIVEMESSAGE_H
diff --git a/core/include/JellyfinQt/loader/http/dlnaserver.h b/core/include/JellyfinQt/dto/inboundwebsocketmessage.h
similarity index 79%
rename from core/include/JellyfinQt/loader/http/dlnaserver.h
rename to core/include/JellyfinQt/dto/inboundwebsocketmessage.h
index ce854e7..0f93f45 100644
--- a/core/include/JellyfinQt/loader/http/dlnaserver.h
+++ b/core/include/JellyfinQt/dto/inboundwebsocketmessage.h
@@ -27,28 +27,22 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_LOADER_HTTP_DLNASERVER_H
-#define JELLYFIN_LOADER_HTTP_DLNASERVER_H
+#ifndef JELLYFIN_DTO_INBOUNDWEBSOCKETMESSAGE_H
+#define JELLYFIN_DTO_INBOUNDWEBSOCKETMESSAGE_H
 
-#include <optional>
-
-#include "JellyfinQt/support/jsonconv.h"
-#include "JellyfinQt/support/loader.h"
-#include "JellyfinQt/loader/requesttypes.h"
+#include <QJsonObject>
 
 namespace Jellyfin {
 // Forward declaration
 class ApiClient;
 }
 namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
+namespace DTO {
 
-using namespace Jellyfin::DTO;
+using InboundWebSocketMessage = QJsonObject;
 
-
-} // NS HTTP
-} // NS Loader
+} // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_LOADER_HTTP_DLNASERVER_H
+#endif // JELLYFIN_DTO_INBOUNDWEBSOCKETMESSAGE_H
+// No implementation needed
diff --git a/core/include/JellyfinQt/dto/installationinfo.h b/core/include/JellyfinQt/dto/installationinfo.h
index 2e57415..2819b2f 100644
--- a/core/include/JellyfinQt/dto/installationinfo.h
+++ b/core/include/JellyfinQt/dto/installationinfo.h
@@ -36,7 +36,7 @@
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/version.h"
+#include "JellyfinQt/dto/packageinfo.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -50,8 +50,8 @@ namespace DTO {
 class InstallationInfo {
 public:
 	InstallationInfo(	
-		QString guid,					
-		QSharedPointer<Version> version								
+		QString guid,													
+		QSharedPointer<PackageInfo> packageInfo		
 	);
 
 	InstallationInfo(const InstallationInfo &other);
@@ -86,10 +86,16 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
-
-	QSharedPointer<Version> version() const;
-
-	void setVersion(QSharedPointer<Version> newVersion);
+	/**
+	 * @brief Gets or sets the version.
+	 */
+	QString version() const;
+	/**
+	* @brief Gets or sets the version.
+	*/
+	void setVersion(QString newVersion);
+	bool versionNull() const;
+	void setVersionNull();
 
 	/**
 	 * @brief Gets or sets the changelog for this version.
@@ -125,13 +131,19 @@ public:
 	void setChecksumNull();
 
 
+	QSharedPointer<PackageInfo> packageInfo() const;
+
+	void setPackageInfo(QSharedPointer<PackageInfo> newPackageInfo);
+
+
 protected:
 	QString m_guid;
 	QString m_name;
-	QSharedPointer<Version> m_version = QSharedPointer<Version>();
+	QString m_version;
 	QString m_changelog;
 	QString m_sourceUrl;
 	QString m_checksum;
+	QSharedPointer<PackageInfo> m_packageInfo = QSharedPointer<PackageInfo>();
 
 private:
 	// Private constructor which generates an invalid object, for use withing InstallationInfo::fromJson();
diff --git a/core/include/JellyfinQt/dto/iplugin.h b/core/include/JellyfinQt/dto/iplugin.h
index c9213c8..e4c7a9f 100644
--- a/core/include/JellyfinQt/dto/iplugin.h
+++ b/core/include/JellyfinQt/dto/iplugin.h
@@ -32,11 +32,9 @@
 
 #include <QJsonObject>
 #include <QJsonValue>
-#include <QSharedPointer>
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/version.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -50,8 +48,7 @@ namespace DTO {
 class IPlugin {
 public:
 	IPlugin(					
-		QString jellyfinId,			
-		QSharedPointer<Version> version,					
+		QString jellyfinId,							
 		bool canUninstall				
 	);
 
@@ -98,10 +95,16 @@ public:
 	*/
 	void setJellyfinId(QString newJellyfinId);
 
-
-	QSharedPointer<Version> version() const;
-
-	void setVersion(QSharedPointer<Version> newVersion);
+	/**
+	 * @brief Gets the plugin version.
+	 */
+	QString version() const;
+	/**
+	* @brief Gets the plugin version.
+	*/
+	void setVersion(QString newVersion);
+	bool versionNull() const;
+	void setVersionNull();
 
 	/**
 	 * @brief Gets the path to the assembly file.
@@ -139,7 +142,7 @@ protected:
 	QString m_name;
 	QString m_description;
 	QString m_jellyfinId;
-	QSharedPointer<Version> m_version = QSharedPointer<Version>();
+	QString m_version;
 	QString m_assemblyFilePath;
 	bool m_canUninstall;
 	QString m_dataFolderPath;
diff --git a/core/include/JellyfinQt/dto/itemfields.h b/core/include/JellyfinQt/dto/itemfields.h
index 6cbe2d7..d7a4684 100644
--- a/core/include/JellyfinQt/dto/itemfields.h
+++ b/core/include/JellyfinQt/dto/itemfields.h
@@ -53,6 +53,7 @@ public:
 		CanDownload,
 		ChannelInfo,
 		Chapters,
+		Trickplay,
 		ChildCount,
 		CumulativeRunTimeTicks,
 		CustomRating,
@@ -83,8 +84,6 @@ public:
 		SortName,
 		SpecialEpisodeNumbers,
 		Studios,
-		BasicSyncInfo,
-		SyncInfo,
 		Taglines,
 		Tags,
 		RemoteTrailers,
diff --git a/core/include/JellyfinQt/dto/itemsortby.h b/core/include/JellyfinQt/dto/itemsortby.h
new file mode 100644
index 0000000..70de1bc
--- /dev/null
+++ b/core/include/JellyfinQt/dto/itemsortby.h
@@ -0,0 +1,106 @@
+/*
+ * 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_DTO_ITEMSORTBY_H
+#define JELLYFIN_DTO_ITEMSORTBY_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class ItemSortByClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Default,
+		AiredEpisodeOrder,
+		Album,
+		AlbumArtist,
+		Artist,
+		DateCreated,
+		OfficialRating,
+		DatePlayed,
+		PremiereDate,
+		StartDate,
+		SortName,
+		Name,
+		Random,
+		Runtime,
+		CommunityRating,
+		ProductionYear,
+		PlayCount,
+		CriticRating,
+		IsFolder,
+		IsUnplayed,
+		IsPlayed,
+		SeriesSortName,
+		VideoBitRate,
+		AirTime,
+		Studio,
+		IsFavoriteOrLiked,
+		DateLastContentAdded,
+		SeriesDatePlayed,
+		ParentIndexNumber,
+		IndexNumber,
+		SimilarityScore,
+		SearchScore,
+	};
+	Q_ENUM(Value)
+private:
+	explicit ItemSortByClass();
+};
+
+using ItemSortBy = ItemSortByClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using ItemSortBy = Jellyfin::DTO::ItemSortBy;
+
+template <>
+ItemSortBy fromJsonValue(const QJsonValue &source, convertType<ItemSortBy>);
+
+template <>
+QJsonValue toJsonValue(const ItemSortBy &source, convertType<ItemSortBy>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_ITEMSORTBY_H
diff --git a/core/include/JellyfinQt/dto/librarychangedmessage.h b/core/include/JellyfinQt/dto/librarychangedmessage.h
new file mode 100644
index 0000000..a271ac2
--- /dev/null
+++ b/core/include/JellyfinQt/dto/librarychangedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_LIBRARYCHANGEDMESSAGE_H
+#define JELLYFIN_DTO_LIBRARYCHANGEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/libraryupdateinfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class LibraryChangedMessage {
+public:
+	LibraryChangedMessage(	
+		QSharedPointer<LibraryUpdateInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	LibraryChangedMessage(const LibraryChangedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(LibraryChangedMessage &other);
+	
+	static LibraryChangedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<LibraryUpdateInfo> data() const;
+
+	void setData(QSharedPointer<LibraryUpdateInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<LibraryUpdateInfo> m_data = QSharedPointer<LibraryUpdateInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing LibraryChangedMessage::fromJson();
+	LibraryChangedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using LibraryChangedMessage = Jellyfin::DTO::LibraryChangedMessage;
+
+template <>
+LibraryChangedMessage fromJsonValue(const QJsonValue &source, convertType<LibraryChangedMessage>);
+
+template<>
+QJsonValue toJsonValue(const LibraryChangedMessage &source, convertType<LibraryChangedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_LIBRARYCHANGEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/libraryoptions.h b/core/include/JellyfinQt/dto/libraryoptions.h
index 742e0dc..08b8991 100644
--- a/core/include/JellyfinQt/dto/libraryoptions.h
+++ b/core/include/JellyfinQt/dto/libraryoptions.h
@@ -37,6 +37,7 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/embeddedsubtitleoptions.h"
 #include "JellyfinQt/dto/mediapathinfo.h"
 #include "JellyfinQt/dto/typeoptions.h"
 #include "JellyfinQt/support/jsonconv.h"
@@ -52,20 +53,43 @@ namespace DTO {
 class LibraryOptions {
 public:
 	LibraryOptions(	
+		bool enabled,			
 		bool enablePhotos,			
 		bool enableRealtimeMonitor,			
+		bool enableLUFSScan,			
 		bool enableChapterImageExtraction,			
-		bool extractChapterImagesDuringLibraryScan,					
+		bool extractChapterImagesDuringLibraryScan,			
+		bool enableTrickplayImageExtraction,			
+		bool extractTrickplayImagesDuringLibraryScan,			
+		QList<MediaPathInfo> pathInfos,			
 		bool saveLocalMetadata,			
 		bool enableInternetProviders,			
 		bool enableAutomaticSeriesGrouping,			
 		bool enableEmbeddedTitles,			
+		bool enableEmbeddedExtrasTitles,			
 		bool enableEmbeddedEpisodeInfos,			
-		qint32 automaticRefreshIntervalDays,																			
+		qint32 automaticRefreshIntervalDays,							
+		QString seasonZeroDisplayName,					
+		QStringList disabledLocalMetadataReaders,					
+		QStringList disabledSubtitleFetchers,			
+		QStringList subtitleFetcherOrder,			
+		QStringList disabledMediaSegmentProviders,			
+		QStringList mediaSegmentProvideOrder,			
 		bool skipSubtitlesIfEmbeddedSubtitlesPresent,			
 		bool skipSubtitlesIfAudioTrackMatches,					
 		bool requirePerfectSubtitleMatch,			
-		bool saveSubtitlesWithMedia				
+		bool saveSubtitlesWithMedia,			
+		std::optional<bool> saveLyricsWithMedia,			
+		std::optional<bool> saveTrickplayWithMedia,			
+		QStringList disabledLyricFetchers,			
+		QStringList lyricFetcherOrder,			
+		std::optional<bool> preferNonstandardArtistsTag,			
+		std::optional<bool> useCustomTagDelimiters,			
+		QStringList customTagDelimiters,			
+		QStringList delimiterWhitelist,			
+		bool automaticallyAddToCollection,			
+		EmbeddedSubtitleOptions allowEmbeddedSubtitles,			
+		QList<TypeOptions> typeOptions		
 	);
 
 	LibraryOptions(const LibraryOptions &other);
@@ -81,6 +105,11 @@ public:
 	
 	// Properties
 
+	bool enabled() const;
+
+	void setEnabled(bool newEnabled);
+
+
 	bool enablePhotos() const;
 
 	void setEnablePhotos(bool newEnablePhotos);
@@ -91,6 +120,11 @@ public:
 	void setEnableRealtimeMonitor(bool newEnableRealtimeMonitor);
 
 
+	bool enableLUFSScan() const;
+
+	void setEnableLUFSScan(bool newEnableLUFSScan);
+
+
 	bool enableChapterImageExtraction() const;
 
 	void setEnableChapterImageExtraction(bool newEnableChapterImageExtraction);
@@ -101,11 +135,19 @@ public:
 	void setExtractChapterImagesDuringLibraryScan(bool newExtractChapterImagesDuringLibraryScan);
 
 
+	bool enableTrickplayImageExtraction() const;
+
+	void setEnableTrickplayImageExtraction(bool newEnableTrickplayImageExtraction);
+
+
+	bool extractTrickplayImagesDuringLibraryScan() const;
+
+	void setExtractTrickplayImagesDuringLibraryScan(bool newExtractTrickplayImagesDuringLibraryScan);
+
+
 	QList<MediaPathInfo> pathInfos() const;
 
 	void setPathInfos(QList<MediaPathInfo> newPathInfos);
-	bool pathInfosNull() const;
-	void setPathInfosNull();
 
 
 	bool saveLocalMetadata() const;
@@ -128,6 +170,11 @@ public:
 	void setEnableEmbeddedTitles(bool newEnableEmbeddedTitles);
 
 
+	bool enableEmbeddedExtrasTitles() const;
+
+	void setEnableEmbeddedExtrasTitles(bool newEnableEmbeddedExtrasTitles);
+
+
 	bool enableEmbeddedEpisodeInfos() const;
 
 	void setEnableEmbeddedEpisodeInfos(bool newEnableEmbeddedEpisodeInfos);
@@ -163,8 +210,6 @@ public:
 	QString seasonZeroDisplayName() const;
 
 	void setSeasonZeroDisplayName(QString newSeasonZeroDisplayName);
-	bool seasonZeroDisplayNameNull() const;
-	void setSeasonZeroDisplayNameNull();
 
 
 	QStringList metadataSavers() const;
@@ -177,8 +222,6 @@ public:
 	QStringList disabledLocalMetadataReaders() const;
 
 	void setDisabledLocalMetadataReaders(QStringList newDisabledLocalMetadataReaders);
-	bool disabledLocalMetadataReadersNull() const;
-	void setDisabledLocalMetadataReadersNull();
 
 
 	QStringList localMetadataReaderOrder() const;
@@ -191,15 +234,21 @@ public:
 	QStringList disabledSubtitleFetchers() const;
 
 	void setDisabledSubtitleFetchers(QStringList newDisabledSubtitleFetchers);
-	bool disabledSubtitleFetchersNull() const;
-	void setDisabledSubtitleFetchersNull();
 
 
 	QStringList subtitleFetcherOrder() const;
 
 	void setSubtitleFetcherOrder(QStringList newSubtitleFetcherOrder);
-	bool subtitleFetcherOrderNull() const;
-	void setSubtitleFetcherOrderNull();
+
+
+	QStringList disabledMediaSegmentProviders() const;
+
+	void setDisabledMediaSegmentProviders(QStringList newDisabledMediaSegmentProviders);
+
+
+	QStringList mediaSegmentProvideOrder() const;
+
+	void setMediaSegmentProvideOrder(QStringList newMediaSegmentProvideOrder);
 
 
 	bool skipSubtitlesIfEmbeddedSubtitlesPresent() const;
@@ -229,23 +278,76 @@ public:
 	void setSaveSubtitlesWithMedia(bool newSaveSubtitlesWithMedia);
 
 
+	std::optional<bool> saveLyricsWithMedia() const;
+
+	void setSaveLyricsWithMedia(std::optional<bool> newSaveLyricsWithMedia);
+
+
+	std::optional<bool> saveTrickplayWithMedia() const;
+
+	void setSaveTrickplayWithMedia(std::optional<bool> newSaveTrickplayWithMedia);
+
+
+	QStringList disabledLyricFetchers() const;
+
+	void setDisabledLyricFetchers(QStringList newDisabledLyricFetchers);
+
+
+	QStringList lyricFetcherOrder() const;
+
+	void setLyricFetcherOrder(QStringList newLyricFetcherOrder);
+
+
+	std::optional<bool> preferNonstandardArtistsTag() const;
+
+	void setPreferNonstandardArtistsTag(std::optional<bool> newPreferNonstandardArtistsTag);
+
+
+	std::optional<bool> useCustomTagDelimiters() const;
+
+	void setUseCustomTagDelimiters(std::optional<bool> newUseCustomTagDelimiters);
+
+
+	QStringList customTagDelimiters() const;
+
+	void setCustomTagDelimiters(QStringList newCustomTagDelimiters);
+
+
+	QStringList delimiterWhitelist() const;
+
+	void setDelimiterWhitelist(QStringList newDelimiterWhitelist);
+
+
+	bool automaticallyAddToCollection() const;
+
+	void setAutomaticallyAddToCollection(bool newAutomaticallyAddToCollection);
+
+
+	EmbeddedSubtitleOptions allowEmbeddedSubtitles() const;
+
+	void setAllowEmbeddedSubtitles(EmbeddedSubtitleOptions newAllowEmbeddedSubtitles);
+
+
 	QList<TypeOptions> typeOptions() const;
 
 	void setTypeOptions(QList<TypeOptions> newTypeOptions);
-	bool typeOptionsNull() const;
-	void setTypeOptionsNull();
 
 
 protected:
+	bool m_enabled;
 	bool m_enablePhotos;
 	bool m_enableRealtimeMonitor;
+	bool m_enableLUFSScan;
 	bool m_enableChapterImageExtraction;
 	bool m_extractChapterImagesDuringLibraryScan;
+	bool m_enableTrickplayImageExtraction;
+	bool m_extractTrickplayImagesDuringLibraryScan;
 	QList<MediaPathInfo> m_pathInfos;
 	bool m_saveLocalMetadata;
 	bool m_enableInternetProviders;
 	bool m_enableAutomaticSeriesGrouping;
 	bool m_enableEmbeddedTitles;
+	bool m_enableEmbeddedExtrasTitles;
 	bool m_enableEmbeddedEpisodeInfos;
 	qint32 m_automaticRefreshIntervalDays;
 	QString m_preferredMetadataLanguage;
@@ -256,11 +358,23 @@ protected:
 	QStringList m_localMetadataReaderOrder;
 	QStringList m_disabledSubtitleFetchers;
 	QStringList m_subtitleFetcherOrder;
+	QStringList m_disabledMediaSegmentProviders;
+	QStringList m_mediaSegmentProvideOrder;
 	bool m_skipSubtitlesIfEmbeddedSubtitlesPresent;
 	bool m_skipSubtitlesIfAudioTrackMatches;
 	QStringList m_subtitleDownloadLanguages;
 	bool m_requirePerfectSubtitleMatch;
 	bool m_saveSubtitlesWithMedia;
+	std::optional<bool> m_saveLyricsWithMedia = std::nullopt;
+	std::optional<bool> m_saveTrickplayWithMedia = std::nullopt;
+	QStringList m_disabledLyricFetchers;
+	QStringList m_lyricFetcherOrder;
+	std::optional<bool> m_preferNonstandardArtistsTag = std::nullopt;
+	std::optional<bool> m_useCustomTagDelimiters = std::nullopt;
+	QStringList m_customTagDelimiters;
+	QStringList m_delimiterWhitelist;
+	bool m_automaticallyAddToCollection;
+	EmbeddedSubtitleOptions m_allowEmbeddedSubtitles;
 	QList<TypeOptions> m_typeOptions;
 
 private:
diff --git a/core/include/JellyfinQt/dto/libraryoptionsresultdto.h b/core/include/JellyfinQt/dto/libraryoptionsresultdto.h
index f9eb267..4da1df1 100644
--- a/core/include/JellyfinQt/dto/libraryoptionsresultdto.h
+++ b/core/include/JellyfinQt/dto/libraryoptionsresultdto.h
@@ -49,7 +49,15 @@ namespace DTO {
 
 
 class LibraryOptionsResultDto {
-public:	LibraryOptionsResultDto();
+public:
+	LibraryOptionsResultDto(	
+		QList<LibraryOptionInfoDto> metadataSavers,			
+		QList<LibraryOptionInfoDto> metadataReaders,			
+		QList<LibraryOptionInfoDto> subtitleFetchers,			
+		QList<LibraryOptionInfoDto> lyricFetchers,			
+		QList<LibraryTypeOptionsDto> typeOptions		
+	);
+
 	LibraryOptionsResultDto(const LibraryOptionsResultDto &other);
 	
 	/**
@@ -70,8 +78,6 @@ public:	LibraryOptionsResultDto();
 	* @brief Gets or sets the metadata savers.
 	*/
 	void setMetadataSavers(QList<LibraryOptionInfoDto> newMetadataSavers);
-	bool metadataSaversNull() const;
-	void setMetadataSaversNull();
 
 	/**
 	 * @brief Gets or sets the metadata readers.
@@ -81,8 +87,6 @@ public:	LibraryOptionsResultDto();
 	* @brief Gets or sets the metadata readers.
 	*/
 	void setMetadataReaders(QList<LibraryOptionInfoDto> newMetadataReaders);
-	bool metadataReadersNull() const;
-	void setMetadataReadersNull();
 
 	/**
 	 * @brief Gets or sets the subtitle fetchers.
@@ -92,8 +96,15 @@ public:	LibraryOptionsResultDto();
 	* @brief Gets or sets the subtitle fetchers.
 	*/
 	void setSubtitleFetchers(QList<LibraryOptionInfoDto> newSubtitleFetchers);
-	bool subtitleFetchersNull() const;
-	void setSubtitleFetchersNull();
+
+	/**
+	 * @brief Gets or sets the list of lyric fetchers.
+	 */
+	QList<LibraryOptionInfoDto> lyricFetchers() const;
+	/**
+	* @brief Gets or sets the list of lyric fetchers.
+	*/
+	void setLyricFetchers(QList<LibraryOptionInfoDto> newLyricFetchers);
 
 	/**
 	 * @brief Gets or sets the type options.
@@ -103,17 +114,18 @@ public:	LibraryOptionsResultDto();
 	* @brief Gets or sets the type options.
 	*/
 	void setTypeOptions(QList<LibraryTypeOptionsDto> newTypeOptions);
-	bool typeOptionsNull() const;
-	void setTypeOptionsNull();
 
 
 protected:
 	QList<LibraryOptionInfoDto> m_metadataSavers;
 	QList<LibraryOptionInfoDto> m_metadataReaders;
 	QList<LibraryOptionInfoDto> m_subtitleFetchers;
+	QList<LibraryOptionInfoDto> m_lyricFetchers;
 	QList<LibraryTypeOptionsDto> m_typeOptions;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing LibraryOptionsResultDto::fromJson();
+	LibraryOptionsResultDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/librarytypeoptionsdto.h b/core/include/JellyfinQt/dto/librarytypeoptionsdto.h
index b967971..e4fc9ec 100644
--- a/core/include/JellyfinQt/dto/librarytypeoptionsdto.h
+++ b/core/include/JellyfinQt/dto/librarytypeoptionsdto.h
@@ -51,7 +51,14 @@ namespace DTO {
 
 
 class LibraryTypeOptionsDto {
-public:	LibraryTypeOptionsDto();
+public:
+	LibraryTypeOptionsDto(			
+		QList<LibraryOptionInfoDto> metadataFetchers,			
+		QList<LibraryOptionInfoDto> imageFetchers,			
+		QList<ImageType> supportedImageTypes,			
+		QList<ImageOption> defaultImageOptions		
+	);
+
 	LibraryTypeOptionsDto(const LibraryTypeOptionsDto &other);
 	
 	/**
@@ -83,8 +90,6 @@ public:	LibraryTypeOptionsDto();
 	* @brief Gets or sets the metadata fetchers.
 	*/
 	void setMetadataFetchers(QList<LibraryOptionInfoDto> newMetadataFetchers);
-	bool metadataFetchersNull() const;
-	void setMetadataFetchersNull();
 
 	/**
 	 * @brief Gets or sets the image fetchers.
@@ -94,8 +99,6 @@ public:	LibraryTypeOptionsDto();
 	* @brief Gets or sets the image fetchers.
 	*/
 	void setImageFetchers(QList<LibraryOptionInfoDto> newImageFetchers);
-	bool imageFetchersNull() const;
-	void setImageFetchersNull();
 
 	/**
 	 * @brief Gets or sets the supported image types.
@@ -105,8 +108,6 @@ public:	LibraryTypeOptionsDto();
 	* @brief Gets or sets the supported image types.
 	*/
 	void setSupportedImageTypes(QList<ImageType> newSupportedImageTypes);
-	bool supportedImageTypesNull() const;
-	void setSupportedImageTypesNull();
 
 	/**
 	 * @brief Gets or sets the default image options.
@@ -116,8 +117,6 @@ public:	LibraryTypeOptionsDto();
 	* @brief Gets or sets the default image options.
 	*/
 	void setDefaultImageOptions(QList<ImageOption> newDefaultImageOptions);
-	bool defaultImageOptionsNull() const;
-	void setDefaultImageOptionsNull();
 
 
 protected:
@@ -127,7 +126,9 @@ protected:
 	QList<ImageType> m_supportedImageTypes;
 	QList<ImageOption> m_defaultImageOptions;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing LibraryTypeOptionsDto::fromJson();
+	LibraryTypeOptionsDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/libraryupdateinfo.h b/core/include/JellyfinQt/dto/libraryupdateinfo.h
index 8b7ed71..468b143 100644
--- a/core/include/JellyfinQt/dto/libraryupdateinfo.h
+++ b/core/include/JellyfinQt/dto/libraryupdateinfo.h
@@ -49,7 +49,13 @@ namespace DTO {
 
 class LibraryUpdateInfo {
 public:
-	LibraryUpdateInfo(													
+	LibraryUpdateInfo(	
+		QStringList foldersAddedTo,			
+		QStringList foldersRemovedFrom,			
+		QStringList itemsAdded,			
+		QStringList itemsRemoved,			
+		QStringList itemsUpdated,			
+		QStringList collectionFolders,			
 		bool isEmpty		
 	);
 
@@ -73,8 +79,6 @@ public:
 	* @brief Gets or sets the folders added to.
 	*/
 	void setFoldersAddedTo(QStringList newFoldersAddedTo);
-	bool foldersAddedToNull() const;
-	void setFoldersAddedToNull();
 
 	/**
 	 * @brief Gets or sets the folders removed from.
@@ -84,8 +88,6 @@ public:
 	* @brief Gets or sets the folders removed from.
 	*/
 	void setFoldersRemovedFrom(QStringList newFoldersRemovedFrom);
-	bool foldersRemovedFromNull() const;
-	void setFoldersRemovedFromNull();
 
 	/**
 	 * @brief Gets or sets the items added.
@@ -95,8 +97,6 @@ public:
 	* @brief Gets or sets the items added.
 	*/
 	void setItemsAdded(QStringList newItemsAdded);
-	bool itemsAddedNull() const;
-	void setItemsAddedNull();
 
 	/**
 	 * @brief Gets or sets the items removed.
@@ -106,8 +106,6 @@ public:
 	* @brief Gets or sets the items removed.
 	*/
 	void setItemsRemoved(QStringList newItemsRemoved);
-	bool itemsRemovedNull() const;
-	void setItemsRemovedNull();
 
 	/**
 	 * @brief Gets or sets the items updated.
@@ -117,15 +115,11 @@ public:
 	* @brief Gets or sets the items updated.
 	*/
 	void setItemsUpdated(QStringList newItemsUpdated);
-	bool itemsUpdatedNull() const;
-	void setItemsUpdatedNull();
 
 
 	QStringList collectionFolders() const;
 
 	void setCollectionFolders(QStringList newCollectionFolders);
-	bool collectionFoldersNull() const;
-	void setCollectionFoldersNull();
 
 
 	bool isEmpty() const;
diff --git a/core/include/JellyfinQt/dto/livetvinfo.h b/core/include/JellyfinQt/dto/livetvinfo.h
index 5d254d0..a2f9207 100644
--- a/core/include/JellyfinQt/dto/livetvinfo.h
+++ b/core/include/JellyfinQt/dto/livetvinfo.h
@@ -49,8 +49,10 @@ namespace DTO {
 
 class LiveTvInfo {
 public:
-	LiveTvInfo(			
-		bool isEnabled				
+	LiveTvInfo(	
+		QList<LiveTvServiceInfo> services,			
+		bool isEnabled,			
+		QStringList enabledUsers		
 	);
 
 	LiveTvInfo(const LiveTvInfo &other);
@@ -73,8 +75,6 @@ public:
 	* @brief Gets or sets the services.
 	*/
 	void setServices(QList<LiveTvServiceInfo> newServices);
-	bool servicesNull() const;
-	void setServicesNull();
 
 	/**
 	 * @brief Gets or sets a value indicating whether this instance is enabled.
@@ -93,8 +93,6 @@ public:
 	* @brief Gets or sets the enabled users.
 	*/
 	void setEnabledUsers(QStringList newEnabledUsers);
-	bool enabledUsersNull() const;
-	void setEnabledUsersNull();
 
 
 protected:
diff --git a/core/include/JellyfinQt/dto/livetvoptions.h b/core/include/JellyfinQt/dto/livetvoptions.h
new file mode 100644
index 0000000..21243f8
--- /dev/null
+++ b/core/include/JellyfinQt/dto/livetvoptions.h
@@ -0,0 +1,207 @@
+/*
+ * 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_DTO_LIVETVOPTIONS_H
+#define JELLYFIN_DTO_LIVETVOPTIONS_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/listingsproviderinfo.h"
+#include "JellyfinQt/dto/tunerhostinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class LiveTvOptions {
+public:
+	LiveTvOptions(									
+		bool enableRecordingSubfolders,			
+		bool enableOriginalAudioWithEncodedRecordings,							
+		qint32 prePaddingSeconds,			
+		qint32 postPaddingSeconds,									
+		bool saveRecordingNFO,			
+		bool saveRecordingImages		
+	);
+
+	LiveTvOptions(const LiveTvOptions &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(LiveTvOptions &other);
+	
+	static LiveTvOptions fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	std::optional<qint32> guideDays() const;
+
+	void setGuideDays(std::optional<qint32> newGuideDays);
+	bool guideDaysNull() const;
+	void setGuideDaysNull();
+
+
+	QString recordingPath() const;
+
+	void setRecordingPath(QString newRecordingPath);
+	bool recordingPathNull() const;
+	void setRecordingPathNull();
+
+
+	QString movieRecordingPath() const;
+
+	void setMovieRecordingPath(QString newMovieRecordingPath);
+	bool movieRecordingPathNull() const;
+	void setMovieRecordingPathNull();
+
+
+	QString seriesRecordingPath() const;
+
+	void setSeriesRecordingPath(QString newSeriesRecordingPath);
+	bool seriesRecordingPathNull() const;
+	void setSeriesRecordingPathNull();
+
+
+	bool enableRecordingSubfolders() const;
+
+	void setEnableRecordingSubfolders(bool newEnableRecordingSubfolders);
+
+
+	bool enableOriginalAudioWithEncodedRecordings() const;
+
+	void setEnableOriginalAudioWithEncodedRecordings(bool newEnableOriginalAudioWithEncodedRecordings);
+
+
+	QList<TunerHostInfo> tunerHosts() const;
+
+	void setTunerHosts(QList<TunerHostInfo> newTunerHosts);
+	bool tunerHostsNull() const;
+	void setTunerHostsNull();
+
+
+	QList<ListingsProviderInfo> listingProviders() const;
+
+	void setListingProviders(QList<ListingsProviderInfo> newListingProviders);
+	bool listingProvidersNull() const;
+	void setListingProvidersNull();
+
+
+	qint32 prePaddingSeconds() const;
+
+	void setPrePaddingSeconds(qint32 newPrePaddingSeconds);
+
+
+	qint32 postPaddingSeconds() const;
+
+	void setPostPaddingSeconds(qint32 newPostPaddingSeconds);
+
+
+	QStringList mediaLocationsCreated() const;
+
+	void setMediaLocationsCreated(QStringList newMediaLocationsCreated);
+	bool mediaLocationsCreatedNull() const;
+	void setMediaLocationsCreatedNull();
+
+
+	QString recordingPostProcessor() const;
+
+	void setRecordingPostProcessor(QString newRecordingPostProcessor);
+	bool recordingPostProcessorNull() const;
+	void setRecordingPostProcessorNull();
+
+
+	QString recordingPostProcessorArguments() const;
+
+	void setRecordingPostProcessorArguments(QString newRecordingPostProcessorArguments);
+	bool recordingPostProcessorArgumentsNull() const;
+	void setRecordingPostProcessorArgumentsNull();
+
+
+	bool saveRecordingNFO() const;
+
+	void setSaveRecordingNFO(bool newSaveRecordingNFO);
+
+
+	bool saveRecordingImages() const;
+
+	void setSaveRecordingImages(bool newSaveRecordingImages);
+
+
+protected:
+	std::optional<qint32> m_guideDays = std::nullopt;
+	QString m_recordingPath;
+	QString m_movieRecordingPath;
+	QString m_seriesRecordingPath;
+	bool m_enableRecordingSubfolders;
+	bool m_enableOriginalAudioWithEncodedRecordings;
+	QList<TunerHostInfo> m_tunerHosts;
+	QList<ListingsProviderInfo> m_listingProviders;
+	qint32 m_prePaddingSeconds;
+	qint32 m_postPaddingSeconds;
+	QStringList m_mediaLocationsCreated;
+	QString m_recordingPostProcessor;
+	QString m_recordingPostProcessorArguments;
+	bool m_saveRecordingNFO;
+	bool m_saveRecordingImages;
+
+private:
+	// Private constructor which generates an invalid object, for use withing LiveTvOptions::fromJson();
+	LiveTvOptions();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using LiveTvOptions = Jellyfin::DTO::LiveTvOptions;
+
+template <>
+LiveTvOptions fromJsonValue(const QJsonValue &source, convertType<LiveTvOptions>);
+
+template<>
+QJsonValue toJsonValue(const LiveTvOptions &source, convertType<LiveTvOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_LIVETVOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/logfile.h b/core/include/JellyfinQt/dto/logfile.h
index ea165a1..430cbef 100644
--- a/core/include/JellyfinQt/dto/logfile.h
+++ b/core/include/JellyfinQt/dto/logfile.h
@@ -51,7 +51,8 @@ public:
 	LogFile(	
 		QDateTime dateCreated,			
 		QDateTime dateModified,			
-		qint64 size				
+		qint64 size,			
+		QString name		
 	);
 
 	LogFile(const LogFile &other);
@@ -101,8 +102,6 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 
 protected:
diff --git a/core/include/JellyfinQt/dto/lyricdto.h b/core/include/JellyfinQt/dto/lyricdto.h
new file mode 100644
index 0000000..f67c221
--- /dev/null
+++ b/core/include/JellyfinQt/dto/lyricdto.h
@@ -0,0 +1,111 @@
+/*
+ * 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_DTO_LYRICDTO_H
+#define JELLYFIN_DTO_LYRICDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QSharedPointer>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/lyricline.h"
+#include "JellyfinQt/dto/lyricmetadata.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class LyricDto {
+public:
+	LyricDto(	
+		QSharedPointer<LyricMetadata> metadata,			
+		QList<LyricLine> lyrics		
+	);
+
+	LyricDto(const LyricDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(LyricDto &other);
+	
+	static LyricDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<LyricMetadata> metadata() const;
+
+	void setMetadata(QSharedPointer<LyricMetadata> newMetadata);
+
+	/**
+	 * @brief Gets or sets a collection of individual lyric lines.
+	 */
+	QList<LyricLine> lyrics() const;
+	/**
+	* @brief Gets or sets a collection of individual lyric lines.
+	*/
+	void setLyrics(QList<LyricLine> newLyrics);
+
+
+protected:
+	QSharedPointer<LyricMetadata> m_metadata = QSharedPointer<LyricMetadata>();
+	QList<LyricLine> m_lyrics;
+
+private:
+	// Private constructor which generates an invalid object, for use withing LyricDto::fromJson();
+	LyricDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using LyricDto = Jellyfin::DTO::LyricDto;
+
+template <>
+LyricDto fromJsonValue(const QJsonValue &source, convertType<LyricDto>);
+
+template<>
+QJsonValue toJsonValue(const LyricDto &source, convertType<LyricDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_LYRICDTO_H
diff --git a/core/include/JellyfinQt/dto/httpheaderinfo.h b/core/include/JellyfinQt/dto/lyricline.h
similarity index 65%
rename from core/include/JellyfinQt/dto/httpheaderinfo.h
rename to core/include/JellyfinQt/dto/lyricline.h
index ef4afb2..f89b83e 100644
--- a/core/include/JellyfinQt/dto/httpheaderinfo.h
+++ b/core/include/JellyfinQt/dto/lyricline.h
@@ -27,15 +27,14 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_HTTPHEADERINFO_H
-#define JELLYFIN_DTO_HTTPHEADERINFO_H
+#ifndef JELLYFIN_DTO_LYRICLINE_H
+#define JELLYFIN_DTO_LYRICLINE_H
 
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/headermatchtype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -46,52 +45,52 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class HttpHeaderInfo {
+class LyricLine {
 public:
-	HttpHeaderInfo(					
-		HeaderMatchType match		
+	LyricLine(	
+		QString text				
 	);
 
-	HttpHeaderInfo(const HttpHeaderInfo &other);
+	LyricLine(const LyricLine &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(HttpHeaderInfo &other);
+	void replaceData(LyricLine &other);
 	
-	static HttpHeaderInfo fromJson(QJsonObject source);
+	static LyricLine fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
+	/**
+	 * @brief Gets the text of this lyric line.
+	 */
+	QString text() const;
+	/**
+	* @brief Gets the text of this lyric line.
+	*/
+	void setText(QString newText);
 
-	QString name() const;
-
-	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-
-
-	QString value() const;
-
-	void setValue(QString newValue);
-	bool valueNull() const;
-	void setValueNull();
-
-
-	HeaderMatchType match() const;
-
-	void setMatch(HeaderMatchType newMatch);
+	/**
+	 * @brief Gets the start time in ticks.
+	 */
+	std::optional<qint64> start() const;
+	/**
+	* @brief Gets the start time in ticks.
+	*/
+	void setStart(std::optional<qint64> newStart);
+	bool startNull() const;
+	void setStartNull();
 
 
 protected:
-	QString m_name;
-	QString m_value;
-	HeaderMatchType m_match;
+	QString m_text;
+	std::optional<qint64> m_start = std::nullopt;
 
 private:
-	// Private constructor which generates an invalid object, for use withing HttpHeaderInfo::fromJson();
-	HttpHeaderInfo();
+	// Private constructor which generates an invalid object, for use withing LyricLine::fromJson();
+	LyricLine();
 };
 
 
@@ -99,15 +98,15 @@ private:
 
 namespace Support {
 
-using HttpHeaderInfo = Jellyfin::DTO::HttpHeaderInfo;
+using LyricLine = Jellyfin::DTO::LyricLine;
 
 template <>
-HttpHeaderInfo fromJsonValue(const QJsonValue &source, convertType<HttpHeaderInfo>);
+LyricLine fromJsonValue(const QJsonValue &source, convertType<LyricLine>);
 
 template<>
-QJsonValue toJsonValue(const HttpHeaderInfo &source, convertType<HttpHeaderInfo>);
+QJsonValue toJsonValue(const LyricLine &source, convertType<LyricLine>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_HTTPHEADERINFO_H
+#endif // JELLYFIN_DTO_LYRICLINE_H
diff --git a/core/include/JellyfinQt/dto/lyricmetadata.h b/core/include/JellyfinQt/dto/lyricmetadata.h
new file mode 100644
index 0000000..6b2bd16
--- /dev/null
+++ b/core/include/JellyfinQt/dto/lyricmetadata.h
@@ -0,0 +1,204 @@
+/*
+ * 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_DTO_LYRICMETADATA_H
+#define JELLYFIN_DTO_LYRICMETADATA_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class LyricMetadata {
+public:	LyricMetadata();
+	LyricMetadata(const LyricMetadata &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(LyricMetadata &other);
+	
+	static LyricMetadata fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the song artist.
+	 */
+	QString artist() const;
+	/**
+	* @brief Gets or sets the song artist.
+	*/
+	void setArtist(QString newArtist);
+	bool artistNull() const;
+	void setArtistNull();
+
+	/**
+	 * @brief Gets or sets the album this song is on.
+	 */
+	QString album() const;
+	/**
+	* @brief Gets or sets the album this song is on.
+	*/
+	void setAlbum(QString newAlbum);
+	bool albumNull() const;
+	void setAlbumNull();
+
+	/**
+	 * @brief Gets or sets the title of the song.
+	 */
+	QString title() const;
+	/**
+	* @brief Gets or sets the title of the song.
+	*/
+	void setTitle(QString newTitle);
+	bool titleNull() const;
+	void setTitleNull();
+
+	/**
+	 * @brief Gets or sets the author of the lyric data.
+	 */
+	QString author() const;
+	/**
+	* @brief Gets or sets the author of the lyric data.
+	*/
+	void setAuthor(QString newAuthor);
+	bool authorNull() const;
+	void setAuthorNull();
+
+	/**
+	 * @brief Gets or sets the length of the song in ticks.
+	 */
+	std::optional<qint64> length() const;
+	/**
+	* @brief Gets or sets the length of the song in ticks.
+	*/
+	void setLength(std::optional<qint64> newLength);
+	bool lengthNull() const;
+	void setLengthNull();
+
+	/**
+	 * @brief Gets or sets who the LRC file was created by.
+	 */
+	QString by() const;
+	/**
+	* @brief Gets or sets who the LRC file was created by.
+	*/
+	void setBy(QString newBy);
+	bool byNull() const;
+	void setByNull();
+
+	/**
+	 * @brief Gets or sets the lyric offset compared to audio in ticks.
+	 */
+	std::optional<qint64> offset() const;
+	/**
+	* @brief Gets or sets the lyric offset compared to audio in ticks.
+	*/
+	void setOffset(std::optional<qint64> newOffset);
+	bool offsetNull() const;
+	void setOffsetNull();
+
+	/**
+	 * @brief Gets or sets the software used to create the LRC file.
+	 */
+	QString creator() const;
+	/**
+	* @brief Gets or sets the software used to create the LRC file.
+	*/
+	void setCreator(QString newCreator);
+	bool creatorNull() const;
+	void setCreatorNull();
+
+	/**
+	 * @brief Gets or sets the version of the creator used.
+	 */
+	QString version() const;
+	/**
+	* @brief Gets or sets the version of the creator used.
+	*/
+	void setVersion(QString newVersion);
+	bool versionNull() const;
+	void setVersionNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether this lyric is synced.
+	 */
+	std::optional<bool> isSynced() const;
+	/**
+	* @brief Gets or sets a value indicating whether this lyric is synced.
+	*/
+	void setIsSynced(std::optional<bool> newIsSynced);
+	bool isSyncedNull() const;
+	void setIsSyncedNull();
+
+
+protected:
+	QString m_artist;
+	QString m_album;
+	QString m_title;
+	QString m_author;
+	std::optional<qint64> m_length = std::nullopt;
+	QString m_by;
+	std::optional<qint64> m_offset = std::nullopt;
+	QString m_creator;
+	QString m_version;
+	std::optional<bool> m_isSynced = std::nullopt;
+
+
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using LyricMetadata = Jellyfin::DTO::LyricMetadata;
+
+template <>
+LyricMetadata fromJsonValue(const QJsonValue &source, convertType<LyricMetadata>);
+
+template<>
+QJsonValue toJsonValue(const LyricMetadata &source, convertType<LyricMetadata>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_LYRICMETADATA_H
diff --git a/core/include/JellyfinQt/dto/mediapathinfo.h b/core/include/JellyfinQt/dto/mediapathinfo.h
index 69175a9..2187d62 100644
--- a/core/include/JellyfinQt/dto/mediapathinfo.h
+++ b/core/include/JellyfinQt/dto/mediapathinfo.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class MediaPathInfo {
-public:	MediaPathInfo();
+public:
+	MediaPathInfo(	
+		QString path		
+	);
+
 	MediaPathInfo(const MediaPathInfo &other);
 	
 	/**
@@ -63,22 +67,14 @@ public:	MediaPathInfo();
 	QString path() const;
 
 	void setPath(QString newPath);
-	bool pathNull() const;
-	void setPathNull();
-
-
-	QString networkPath() const;
-
-	void setNetworkPath(QString newNetworkPath);
-	bool networkPathNull() const;
-	void setNetworkPathNull();
 
 
 protected:
 	QString m_path;
-	QString m_networkPath;
-
 
+private:
+	// Private constructor which generates an invalid object, for use withing MediaPathInfo::fromJson();
+	MediaPathInfo();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/mediasegmentdto.h b/core/include/JellyfinQt/dto/mediasegmentdto.h
new file mode 100644
index 0000000..183b9c8
--- /dev/null
+++ b/core/include/JellyfinQt/dto/mediasegmentdto.h
@@ -0,0 +1,141 @@
+/*
+ * 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_DTO_MEDIASEGMENTDTO_H
+#define JELLYFIN_DTO_MEDIASEGMENTDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/mediasegmenttype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class MediaSegmentDto {
+public:
+	MediaSegmentDto(	
+		QString jellyfinId,			
+		QString itemId,			
+		MediaSegmentType type,			
+		qint64 startTicks,			
+		qint64 endTicks		
+	);
+
+	MediaSegmentDto(const MediaSegmentDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(MediaSegmentDto &other);
+	
+	static MediaSegmentDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the id of the media segment.
+	 */
+	QString jellyfinId() const;
+	/**
+	* @brief Gets or sets the id of the media segment.
+	*/
+	void setJellyfinId(QString newJellyfinId);
+
+	/**
+	 * @brief Gets or sets the id of the associated item.
+	 */
+	QString itemId() const;
+	/**
+	* @brief Gets or sets the id of the associated item.
+	*/
+	void setItemId(QString newItemId);
+
+
+	MediaSegmentType type() const;
+
+	void setType(MediaSegmentType newType);
+
+	/**
+	 * @brief Gets or sets the start of the segment.
+	 */
+	qint64 startTicks() const;
+	/**
+	* @brief Gets or sets the start of the segment.
+	*/
+	void setStartTicks(qint64 newStartTicks);
+
+	/**
+	 * @brief Gets or sets the end of the segment.
+	 */
+	qint64 endTicks() const;
+	/**
+	* @brief Gets or sets the end of the segment.
+	*/
+	void setEndTicks(qint64 newEndTicks);
+
+
+protected:
+	QString m_jellyfinId;
+	QString m_itemId;
+	MediaSegmentType m_type;
+	qint64 m_startTicks;
+	qint64 m_endTicks;
+
+private:
+	// Private constructor which generates an invalid object, for use withing MediaSegmentDto::fromJson();
+	MediaSegmentDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentDto = Jellyfin::DTO::MediaSegmentDto;
+
+template <>
+MediaSegmentDto fromJsonValue(const QJsonValue &source, convertType<MediaSegmentDto>);
+
+template<>
+QJsonValue toJsonValue(const MediaSegmentDto &source, convertType<MediaSegmentDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_MEDIASEGMENTDTO_H
diff --git a/core/include/JellyfinQt/dto/mediasegmentdtoqueryresult.h b/core/include/JellyfinQt/dto/mediasegmentdtoqueryresult.h
new file mode 100644
index 0000000..c8657af
--- /dev/null
+++ b/core/include/JellyfinQt/dto/mediasegmentdtoqueryresult.h
@@ -0,0 +1,124 @@
+/*
+ * 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_DTO_MEDIASEGMENTDTOQUERYRESULT_H
+#define JELLYFIN_DTO_MEDIASEGMENTDTOQUERYRESULT_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/mediasegmentdto.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class MediaSegmentDtoQueryResult {
+public:
+	MediaSegmentDtoQueryResult(	
+		QList<MediaSegmentDto> items,			
+		qint32 totalRecordCount,			
+		qint32 startIndex		
+	);
+
+	MediaSegmentDtoQueryResult(const MediaSegmentDtoQueryResult &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(MediaSegmentDtoQueryResult &other);
+	
+	static MediaSegmentDtoQueryResult fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the items.
+	 */
+	QList<MediaSegmentDto> items() const;
+	/**
+	* @brief Gets or sets the items.
+	*/
+	void setItems(QList<MediaSegmentDto> newItems);
+
+	/**
+	 * @brief Gets or sets the total number of records available.
+	 */
+	qint32 totalRecordCount() const;
+	/**
+	* @brief Gets or sets the total number of records available.
+	*/
+	void setTotalRecordCount(qint32 newTotalRecordCount);
+
+	/**
+	 * @brief Gets or sets the index of the first record in Items.
+	 */
+	qint32 startIndex() const;
+	/**
+	* @brief Gets or sets the index of the first record in Items.
+	*/
+	void setStartIndex(qint32 newStartIndex);
+
+
+protected:
+	QList<MediaSegmentDto> m_items;
+	qint32 m_totalRecordCount;
+	qint32 m_startIndex;
+
+private:
+	// Private constructor which generates an invalid object, for use withing MediaSegmentDtoQueryResult::fromJson();
+	MediaSegmentDtoQueryResult();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentDtoQueryResult = Jellyfin::DTO::MediaSegmentDtoQueryResult;
+
+template <>
+MediaSegmentDtoQueryResult fromJsonValue(const QJsonValue &source, convertType<MediaSegmentDtoQueryResult>);
+
+template<>
+QJsonValue toJsonValue(const MediaSegmentDtoQueryResult &source, convertType<MediaSegmentDtoQueryResult>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_MEDIASEGMENTDTOQUERYRESULT_H
diff --git a/core/include/JellyfinQt/dto/mediasegmenttype.h b/core/include/JellyfinQt/dto/mediasegmenttype.h
new file mode 100644
index 0000000..606f7a4
--- /dev/null
+++ b/core/include/JellyfinQt/dto/mediasegmenttype.h
@@ -0,0 +1,80 @@
+/*
+ * 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_DTO_MEDIASEGMENTTYPE_H
+#define JELLYFIN_DTO_MEDIASEGMENTTYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class MediaSegmentTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Unknown,
+		Commercial,
+		Preview,
+		Recap,
+		Outro,
+		Intro,
+	};
+	Q_ENUM(Value)
+private:
+	explicit MediaSegmentTypeClass();
+};
+
+using MediaSegmentType = MediaSegmentTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentType = Jellyfin::DTO::MediaSegmentType;
+
+template <>
+MediaSegmentType fromJsonValue(const QJsonValue &source, convertType<MediaSegmentType>);
+
+template <>
+QJsonValue toJsonValue(const MediaSegmentType &source, convertType<MediaSegmentType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_MEDIASEGMENTTYPE_H
diff --git a/core/include/JellyfinQt/dto/mediasourceinfo.h b/core/include/JellyfinQt/dto/mediasourceinfo.h
index a4990a9..a668eee 100644
--- a/core/include/JellyfinQt/dto/mediasourceinfo.h
+++ b/core/include/JellyfinQt/dto/mediasourceinfo.h
@@ -42,6 +42,7 @@
 #include "JellyfinQt/dto/mediaprotocol.h"
 #include "JellyfinQt/dto/mediasourcetype.h"
 #include "JellyfinQt/dto/mediastream.h"
+#include "JellyfinQt/dto/mediastreamprotocol.h"
 #include "JellyfinQt/dto/transportstreamtimestamp.h"
 #include "JellyfinQt/dto/video3dformat.h"
 #include "JellyfinQt/dto/videotype.h"
@@ -70,14 +71,17 @@ public:
 		bool supportsDirectStream,			
 		bool supportsDirectPlay,			
 		bool isInfiniteStream,			
+		std::optional<bool> useMostCompatibleTranscodingProfile,			
 		bool requiresOpening,					
 		bool requiresClosing,							
 		bool requiresLooping,			
 		bool supportsProbing,			
 		VideoType videoType,			
 		IsoType isoType,			
-		Video3DFormat video3DFormat,											
-		TransportStreamTimestamp timestamp																
+		Video3DFormat video3DFormat,													
+		TransportStreamTimestamp timestamp,							
+		MediaStreamProtocol transcodingSubProtocol,											
+		bool hasSegments		
 	);
 
 	MediaSourceInfo(const MediaSourceInfo &other);
@@ -150,11 +154,13 @@ public:
 	void setNameNull();
 
 	/**
-	 * @brief Differentiate internet url vs local network.
+	 * @brief Gets or sets a value indicating whether the media is remote.
+Differentiate internet url vs local network.
 	 */
 	bool isRemote() const;
 	/**
-	* @brief Differentiate internet url vs local network.
+	* @brief Gets or sets a value indicating whether the media is remote.
+Differentiate internet url vs local network.
 	*/
 	void setIsRemote(bool newIsRemote);
 
@@ -213,6 +219,11 @@ public:
 	void setIsInfiniteStream(bool newIsInfiniteStream);
 
 
+	std::optional<bool> useMostCompatibleTranscodingProfile() const;
+
+	void setUseMostCompatibleTranscodingProfile(std::optional<bool> newUseMostCompatibleTranscodingProfile);
+
+
 	bool requiresOpening() const;
 
 	void setRequiresOpening(bool newRequiresOpening);
@@ -297,6 +308,13 @@ public:
 	void setBitrateNull();
 
 
+	std::optional<qint32> fallbackMaxStreamingBitrate() const;
+
+	void setFallbackMaxStreamingBitrate(std::optional<qint32> newFallbackMaxStreamingBitrate);
+	bool fallbackMaxStreamingBitrateNull() const;
+	void setFallbackMaxStreamingBitrateNull();
+
+
 	TransportStreamTimestamp timestamp() const;
 
 	void setTimestamp(TransportStreamTimestamp newTimestamp);
@@ -316,11 +334,9 @@ public:
 	void setTranscodingUrlNull();
 
 
-	QString transcodingSubProtocol() const;
+	MediaStreamProtocol transcodingSubProtocol() const;
 
-	void setTranscodingSubProtocol(QString newTranscodingSubProtocol);
-	bool transcodingSubProtocolNull() const;
-	void setTranscodingSubProtocolNull();
+	void setTranscodingSubProtocol(MediaStreamProtocol newTranscodingSubProtocol);
 
 
 	QString transcodingContainer() const;
@@ -351,6 +367,11 @@ public:
 	void setDefaultSubtitleStreamIndexNull();
 
 
+	bool hasSegments() const;
+
+	void setHasSegments(bool newHasSegments);
+
+
 protected:
 	MediaProtocol m_protocol;
 	QString m_jellyfinId;
@@ -372,6 +393,7 @@ protected:
 	bool m_supportsDirectStream;
 	bool m_supportsDirectPlay;
 	bool m_isInfiniteStream;
+	std::optional<bool> m_useMostCompatibleTranscodingProfile = std::nullopt;
 	bool m_requiresOpening;
 	QString m_openToken;
 	bool m_requiresClosing;
@@ -386,14 +408,16 @@ protected:
 	QList<MediaAttachment> m_mediaAttachments;
 	QStringList m_formats;
 	std::optional<qint32> m_bitrate = std::nullopt;
+	std::optional<qint32> m_fallbackMaxStreamingBitrate = std::nullopt;
 	TransportStreamTimestamp m_timestamp;
 	QJsonObject m_requiredHttpHeaders;
 	QString m_transcodingUrl;
-	QString m_transcodingSubProtocol;
+	MediaStreamProtocol m_transcodingSubProtocol;
 	QString m_transcodingContainer;
 	std::optional<qint32> m_analyzeDurationMs = std::nullopt;
 	std::optional<qint32> m_defaultAudioStreamIndex = std::nullopt;
 	std::optional<qint32> m_defaultSubtitleStreamIndex = std::nullopt;
+	bool m_hasSegments;
 
 private:
 	// Private constructor which generates an invalid object, for use withing MediaSourceInfo::fromJson();
diff --git a/core/include/JellyfinQt/dto/mediastream.h b/core/include/JellyfinQt/dto/mediastream.h
index 429f7aa..64cd48b 100644
--- a/core/include/JellyfinQt/dto/mediastream.h
+++ b/core/include/JellyfinQt/dto/mediastream.h
@@ -35,8 +35,11 @@
 #include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/audiospatialformat.h"
 #include "JellyfinQt/dto/mediastreamtype.h"
 #include "JellyfinQt/dto/subtitledeliverymethod.h"
+#include "JellyfinQt/dto/videorange.h"
+#include "JellyfinQt/dto/videorangetype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -49,10 +52,14 @@ namespace DTO {
 
 class MediaStream {
 public:
-	MediaStream(																																			
+	MediaStream(																																									
+		VideoRange videoRange,			
+		VideoRangeType videoRangeType,					
+		AudioSpatialFormat audioSpatialFormat,																	
 		bool isInterlaced,																			
 		bool isDefault,			
-		bool isForced,													
+		bool isForced,			
+		bool isHearingImpaired,															
 		MediaStreamType type,					
 		qint32 index,					
 		bool isExternal,			
@@ -150,6 +157,105 @@ public:
 	bool colorPrimariesNull() const;
 	void setColorPrimariesNull();
 
+	/**
+	 * @brief Gets or sets the Dolby Vision version major.
+	 */
+	std::optional<qint32> dvVersionMajor() const;
+	/**
+	* @brief Gets or sets the Dolby Vision version major.
+	*/
+	void setDvVersionMajor(std::optional<qint32> newDvVersionMajor);
+	bool dvVersionMajorNull() const;
+	void setDvVersionMajorNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision version minor.
+	 */
+	std::optional<qint32> dvVersionMinor() const;
+	/**
+	* @brief Gets or sets the Dolby Vision version minor.
+	*/
+	void setDvVersionMinor(std::optional<qint32> newDvVersionMinor);
+	bool dvVersionMinorNull() const;
+	void setDvVersionMinorNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision profile.
+	 */
+	std::optional<qint32> dvProfile() const;
+	/**
+	* @brief Gets or sets the Dolby Vision profile.
+	*/
+	void setDvProfile(std::optional<qint32> newDvProfile);
+	bool dvProfileNull() const;
+	void setDvProfileNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision level.
+	 */
+	std::optional<qint32> dvLevel() const;
+	/**
+	* @brief Gets or sets the Dolby Vision level.
+	*/
+	void setDvLevel(std::optional<qint32> newDvLevel);
+	bool dvLevelNull() const;
+	void setDvLevelNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision rpu present flag.
+	 */
+	std::optional<qint32> rpuPresentFlag() const;
+	/**
+	* @brief Gets or sets the Dolby Vision rpu present flag.
+	*/
+	void setRpuPresentFlag(std::optional<qint32> newRpuPresentFlag);
+	bool rpuPresentFlagNull() const;
+	void setRpuPresentFlagNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision el present flag.
+	 */
+	std::optional<qint32> elPresentFlag() const;
+	/**
+	* @brief Gets or sets the Dolby Vision el present flag.
+	*/
+	void setElPresentFlag(std::optional<qint32> newElPresentFlag);
+	bool elPresentFlagNull() const;
+	void setElPresentFlagNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision bl present flag.
+	 */
+	std::optional<qint32> blPresentFlag() const;
+	/**
+	* @brief Gets or sets the Dolby Vision bl present flag.
+	*/
+	void setBlPresentFlag(std::optional<qint32> newBlPresentFlag);
+	bool blPresentFlagNull() const;
+	void setBlPresentFlagNull();
+
+	/**
+	 * @brief Gets or sets the Dolby Vision bl signal compatibility id.
+	 */
+	std::optional<qint32> dvBlSignalCompatibilityId() const;
+	/**
+	* @brief Gets or sets the Dolby Vision bl signal compatibility id.
+	*/
+	void setDvBlSignalCompatibilityId(std::optional<qint32> newDvBlSignalCompatibilityId);
+	bool dvBlSignalCompatibilityIdNull() const;
+	void setDvBlSignalCompatibilityIdNull();
+
+	/**
+	 * @brief Gets or sets the Rotation in degrees.
+	 */
+	std::optional<qint32> rotation() const;
+	/**
+	* @brief Gets or sets the Rotation in degrees.
+	*/
+	void setRotation(std::optional<qint32> newRotation);
+	bool rotationNull() const;
+	void setRotationNull();
+
 	/**
 	 * @brief Gets or sets the comment.
 	 */
@@ -194,16 +300,31 @@ public:
 	bool titleNull() const;
 	void setTitleNull();
 
+
+	VideoRange videoRange() const;
+
+	void setVideoRange(VideoRange newVideoRange);
+
+
+	VideoRangeType videoRangeType() const;
+
+	void setVideoRangeType(VideoRangeType newVideoRangeType);
+
 	/**
-	 * @brief Gets or sets the video range.
+	 * @brief Gets the video dovi title.
 	 */
-	QString videoRange() const;
+	QString videoDoViTitle() const;
 	/**
-	* @brief Gets or sets the video range.
+	* @brief Gets the video dovi title.
 	*/
-	void setVideoRange(QString newVideoRange);
-	bool videoRangeNull() const;
-	void setVideoRangeNull();
+	void setVideoDoViTitle(QString newVideoDoViTitle);
+	bool videoDoViTitleNull() const;
+	void setVideoDoViTitleNull();
+
+
+	AudioSpatialFormat audioSpatialFormat() const;
+
+	void setAudioSpatialFormat(AudioSpatialFormat newAudioSpatialFormat);
 
 
 	QString localizedUndefined() const;
@@ -227,6 +348,20 @@ public:
 	void setLocalizedForcedNull();
 
 
+	QString localizedExternal() const;
+
+	void setLocalizedExternal(QString newLocalizedExternal);
+	bool localizedExternalNull() const;
+	void setLocalizedExternalNull();
+
+
+	QString localizedHearingImpaired() const;
+
+	void setLocalizedHearingImpaired(QString newLocalizedHearingImpaired);
+	bool localizedHearingImpairedNull() const;
+	void setLocalizedHearingImpairedNull();
+
+
 	QString displayTitle() const;
 
 	void setDisplayTitle(QString newDisplayTitle);
@@ -351,6 +486,15 @@ public:
 	*/
 	void setIsForced(bool newIsForced);
 
+	/**
+	 * @brief Gets or sets a value indicating whether this instance is for the hearing impaired.
+	 */
+	bool isHearingImpaired() const;
+	/**
+	* @brief Gets or sets a value indicating whether this instance is for the hearing impaired.
+	*/
+	void setIsHearingImpaired(bool newIsHearingImpaired);
+
 	/**
 	 * @brief Gets or sets the height.
 	 */
@@ -395,6 +539,21 @@ public:
 	bool realFrameRateNull() const;
 	void setRealFrameRateNull();
 
+	/**
+	 * @brief Gets the framerate used as reference.
+Prefer AverageFrameRate, if that is null or an unrealistic value
+then fallback to RealFrameRate.
+	 */
+	std::optional<float> referenceFrameRate() const;
+	/**
+	* @brief Gets the framerate used as reference.
+Prefer AverageFrameRate, if that is null or an unrealistic value
+then fallback to RealFrameRate.
+	*/
+	void setReferenceFrameRate(std::optional<float> newReferenceFrameRate);
+	bool referenceFrameRateNull() const;
+	void setReferenceFrameRateNull();
+
 	/**
 	 * @brief Gets or sets the profile.
 	 */
@@ -526,11 +685,11 @@ public:
 	void setLevelNull();
 
 	/**
-	 * @brief Gets a value indicating whether this instance is anamorphic.
+	 * @brief Gets or sets whether this instance is anamorphic.
 	 */
 	std::optional<bool> isAnamorphic() const;
 	/**
-	* @brief Gets a value indicating whether this instance is anamorphic.
+	* @brief Gets or sets whether this instance is anamorphic.
 	*/
 	void setIsAnamorphic(std::optional<bool> newIsAnamorphic);
 	bool isAnamorphicNull() const;
@@ -545,14 +704,28 @@ protected:
 	QString m_colorSpace;
 	QString m_colorTransfer;
 	QString m_colorPrimaries;
+	std::optional<qint32> m_dvVersionMajor = std::nullopt;
+	std::optional<qint32> m_dvVersionMinor = std::nullopt;
+	std::optional<qint32> m_dvProfile = std::nullopt;
+	std::optional<qint32> m_dvLevel = std::nullopt;
+	std::optional<qint32> m_rpuPresentFlag = std::nullopt;
+	std::optional<qint32> m_elPresentFlag = std::nullopt;
+	std::optional<qint32> m_blPresentFlag = std::nullopt;
+	std::optional<qint32> m_dvBlSignalCompatibilityId = std::nullopt;
+	std::optional<qint32> m_rotation = std::nullopt;
 	QString m_comment;
 	QString m_timeBase;
 	QString m_codecTimeBase;
 	QString m_title;
-	QString m_videoRange;
+	VideoRange m_videoRange;
+	VideoRangeType m_videoRangeType;
+	QString m_videoDoViTitle;
+	AudioSpatialFormat m_audioSpatialFormat;
 	QString m_localizedUndefined;
 	QString m_localizedDefault;
 	QString m_localizedForced;
+	QString m_localizedExternal;
+	QString m_localizedHearingImpaired;
 	QString m_displayTitle;
 	QString m_nalLengthSize;
 	bool m_isInterlaced;
@@ -566,10 +739,12 @@ protected:
 	std::optional<qint32> m_sampleRate = std::nullopt;
 	bool m_isDefault;
 	bool m_isForced;
+	bool m_isHearingImpaired;
 	std::optional<qint32> m_height = std::nullopt;
 	std::optional<qint32> m_width = std::nullopt;
 	std::optional<float> m_averageFrameRate = std::nullopt;
 	std::optional<float> m_realFrameRate = std::nullopt;
+	std::optional<float> m_referenceFrameRate = std::nullopt;
 	QString m_profile;
 	MediaStreamType m_type;
 	QString m_aspectRatio;
diff --git a/core/include/JellyfinQt/dto/mediastreamprotocol.h b/core/include/JellyfinQt/dto/mediastreamprotocol.h
new file mode 100644
index 0000000..b0273f5
--- /dev/null
+++ b/core/include/JellyfinQt/dto/mediastreamprotocol.h
@@ -0,0 +1,76 @@
+/*
+ * 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_DTO_MEDIASTREAMPROTOCOL_H
+#define JELLYFIN_DTO_MEDIASTREAMPROTOCOL_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class MediaStreamProtocolClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Http,
+		Hls,
+	};
+	Q_ENUM(Value)
+private:
+	explicit MediaStreamProtocolClass();
+};
+
+using MediaStreamProtocol = MediaStreamProtocolClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using MediaStreamProtocol = Jellyfin::DTO::MediaStreamProtocol;
+
+template <>
+MediaStreamProtocol fromJsonValue(const QJsonValue &source, convertType<MediaStreamProtocol>);
+
+template <>
+QJsonValue toJsonValue(const MediaStreamProtocol &source, convertType<MediaStreamProtocol>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_MEDIASTREAMPROTOCOL_H
diff --git a/core/include/JellyfinQt/dto/mediastreamtype.h b/core/include/JellyfinQt/dto/mediastreamtype.h
index 876c7b7..ee234b4 100644
--- a/core/include/JellyfinQt/dto/mediastreamtype.h
+++ b/core/include/JellyfinQt/dto/mediastreamtype.h
@@ -52,6 +52,8 @@ public:
 		Video,
 		Subtitle,
 		EmbeddedImage,
+		Data,
+		Lyric,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/architecture.h b/core/include/JellyfinQt/dto/mediatype.h
similarity index 78%
rename from core/include/JellyfinQt/dto/architecture.h
rename to core/include/JellyfinQt/dto/mediatype.h
index bed8c1e..04ff7e6 100644
--- a/core/include/JellyfinQt/dto/architecture.h
+++ b/core/include/JellyfinQt/dto/mediatype.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_ARCHITECTURE_H
-#define JELLYFIN_DTO_ARCHITECTURE_H
+#ifndef JELLYFIN_DTO_MEDIATYPE_H
+#define JELLYFIN_DTO_MEDIATYPE_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,37 +43,37 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class ArchitectureClass {
+class MediaTypeClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
-		X86,
-		X64,
-		Arm,
-		Arm64,
-		Wasm,
+		Unknown,
+		Video,
+		Audio,
+		Photo,
+		Book,
 	};
 	Q_ENUM(Value)
 private:
-	explicit ArchitectureClass();
+	explicit MediaTypeClass();
 };
 
-using Architecture = ArchitectureClass::Value;
+using MediaType = MediaTypeClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using Architecture = Jellyfin::DTO::Architecture;
+using MediaType = Jellyfin::DTO::MediaType;
 
 template <>
-Architecture fromJsonValue(const QJsonValue &source, convertType<Architecture>);
+MediaType fromJsonValue(const QJsonValue &source, convertType<MediaType>);
 
 template <>
-QJsonValue toJsonValue(const Architecture &source, convertType<Architecture>);
+QJsonValue toJsonValue(const MediaType &source, convertType<MediaType>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_ARCHITECTURE_H
+#endif // JELLYFIN_DTO_MEDIATYPE_H
diff --git a/core/include/JellyfinQt/dto/mediaupdateinfodto.h b/core/include/JellyfinQt/dto/mediaupdateinfodto.h
index 5e15bda..05190fa 100644
--- a/core/include/JellyfinQt/dto/mediaupdateinfodto.h
+++ b/core/include/JellyfinQt/dto/mediaupdateinfodto.h
@@ -32,9 +32,11 @@
 
 #include <QJsonObject>
 #include <QJsonValue>
-#include <QString>
+#include <QList>
+#include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/mediaupdateinfopathdto.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -46,7 +48,11 @@ namespace DTO {
 
 
 class MediaUpdateInfoDto {
-public:	MediaUpdateInfoDto();
+public:
+	MediaUpdateInfoDto(	
+		QList<MediaUpdateInfoPathDto> updates		
+	);
+
 	MediaUpdateInfoDto(const MediaUpdateInfoDto &other);
 	
 	/**
@@ -60,35 +66,21 @@ public:	MediaUpdateInfoDto();
 	
 	// Properties
 	/**
-	 * @brief Gets or sets media path.
+	 * @brief Gets or sets the list of updates.
 	 */
-	QString path() const;
+	QList<MediaUpdateInfoPathDto> updates() const;
 	/**
-	* @brief Gets or sets media path.
+	* @brief Gets or sets the list of updates.
 	*/
-	void setPath(QString newPath);
-	bool pathNull() const;
-	void setPathNull();
-
-	/**
-	 * @brief Gets or sets media update type.
-Created, Modified, Deleted.
-	 */
-	QString updateType() const;
-	/**
-	* @brief Gets or sets media update type.
-Created, Modified, Deleted.
-	*/
-	void setUpdateType(QString newUpdateType);
-	bool updateTypeNull() const;
-	void setUpdateTypeNull();
+	void setUpdates(QList<MediaUpdateInfoPathDto> newUpdates);
 
 
 protected:
-	QString m_path;
-	QString m_updateType;
-
+	QList<MediaUpdateInfoPathDto> m_updates;
 
+private:
+	// Private constructor which generates an invalid object, for use withing MediaUpdateInfoDto::fromJson();
+	MediaUpdateInfoDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/mediaencoderpathdto.h b/core/include/JellyfinQt/dto/mediaupdateinfopathdto.h
similarity index 66%
rename from core/include/JellyfinQt/dto/mediaencoderpathdto.h
rename to core/include/JellyfinQt/dto/mediaupdateinfopathdto.h
index ac43c96..94ca5e7 100644
--- a/core/include/JellyfinQt/dto/mediaencoderpathdto.h
+++ b/core/include/JellyfinQt/dto/mediaupdateinfopathdto.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_MEDIAENCODERPATHDTO_H
-#define JELLYFIN_DTO_MEDIAENCODERPATHDTO_H
+#ifndef JELLYFIN_DTO_MEDIAUPDATEINFOPATHDTO_H
+#define JELLYFIN_DTO_MEDIAUPDATEINFOPATHDTO_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -45,46 +45,48 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class MediaEncoderPathDto {
-public:	MediaEncoderPathDto();
-	MediaEncoderPathDto(const MediaEncoderPathDto &other);
+class MediaUpdateInfoPathDto {
+public:	MediaUpdateInfoPathDto();
+	MediaUpdateInfoPathDto(const MediaUpdateInfoPathDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(MediaEncoderPathDto &other);
+	void replaceData(MediaUpdateInfoPathDto &other);
 	
-	static MediaEncoderPathDto fromJson(QJsonObject source);
+	static MediaUpdateInfoPathDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets media encoder path.
+	 * @brief Gets or sets media path.
 	 */
 	QString path() const;
 	/**
-	* @brief Gets or sets media encoder path.
+	* @brief Gets or sets media path.
 	*/
 	void setPath(QString newPath);
 	bool pathNull() const;
 	void setPathNull();
 
 	/**
-	 * @brief Gets or sets media encoder path type.
+	 * @brief Gets or sets media update type.
+Created, Modified, Deleted.
 	 */
-	QString pathType() const;
+	QString updateType() const;
 	/**
-	* @brief Gets or sets media encoder path type.
+	* @brief Gets or sets media update type.
+Created, Modified, Deleted.
 	*/
-	void setPathType(QString newPathType);
-	bool pathTypeNull() const;
-	void setPathTypeNull();
+	void setUpdateType(QString newUpdateType);
+	bool updateTypeNull() const;
+	void setUpdateTypeNull();
 
 
 protected:
 	QString m_path;
-	QString m_pathType;
+	QString m_updateType;
 
 
 };
@@ -94,15 +96,15 @@ protected:
 
 namespace Support {
 
-using MediaEncoderPathDto = Jellyfin::DTO::MediaEncoderPathDto;
+using MediaUpdateInfoPathDto = Jellyfin::DTO::MediaUpdateInfoPathDto;
 
 template <>
-MediaEncoderPathDto fromJsonValue(const QJsonValue &source, convertType<MediaEncoderPathDto>);
+MediaUpdateInfoPathDto fromJsonValue(const QJsonValue &source, convertType<MediaUpdateInfoPathDto>);
 
 template<>
-QJsonValue toJsonValue(const MediaEncoderPathDto &source, convertType<MediaEncoderPathDto>);
+QJsonValue toJsonValue(const MediaUpdateInfoPathDto &source, convertType<MediaUpdateInfoPathDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_MEDIAENCODERPATHDTO_H
+#endif // JELLYFIN_DTO_MEDIAUPDATEINFOPATHDTO_H
diff --git a/core/include/JellyfinQt/dto/version.h b/core/include/JellyfinQt/dto/messagecommand.h
similarity index 63%
rename from core/include/JellyfinQt/dto/version.h
rename to core/include/JellyfinQt/dto/messagecommand.h
index eac278d..a238947 100644
--- a/core/include/JellyfinQt/dto/version.h
+++ b/core/include/JellyfinQt/dto/messagecommand.h
@@ -27,11 +27,12 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_VERSION_H
-#define JELLYFIN_DTO_VERSION_H
+#ifndef JELLYFIN_DTO_MESSAGECOMMAND_H
+#define JELLYFIN_DTO_MESSAGECOMMAND_H
 
 #include <QJsonObject>
 #include <QJsonValue>
+#include <QString>
 #include <optional>
 
 #include "JellyfinQt/support/jsonconv.h"
@@ -44,71 +45,52 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class Version {
+class MessageCommand {
 public:
-	Version(	
-		qint32 major,			
-		qint32 minor,			
-		qint32 build,			
-		qint32 revision,			
-		qint32 majorRevision,			
-		qint32 minorRevision		
+	MessageCommand(			
+		QString text				
 	);
 
-	Version(const Version &other);
+	MessageCommand(const MessageCommand &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(Version &other);
+	void replaceData(MessageCommand &other);
 	
-	static Version fromJson(QJsonObject source);
+	static MessageCommand fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 
-	qint32 major() const;
+	QString header() const;
 
-	void setMajor(qint32 newMajor);
+	void setHeader(QString newHeader);
+	bool headerNull() const;
+	void setHeaderNull();
 
 
-	qint32 minor() const;
+	QString text() const;
 
-	void setMinor(qint32 newMinor);
+	void setText(QString newText);
 
 
-	qint32 build() const;
+	std::optional<qint64> timeoutMs() const;
 
-	void setBuild(qint32 newBuild);
-
-
-	qint32 revision() const;
-
-	void setRevision(qint32 newRevision);
-
-
-	qint32 majorRevision() const;
-
-	void setMajorRevision(qint32 newMajorRevision);
-
-
-	qint32 minorRevision() const;
-
-	void setMinorRevision(qint32 newMinorRevision);
+	void setTimeoutMs(std::optional<qint64> newTimeoutMs);
+	bool timeoutMsNull() const;
+	void setTimeoutMsNull();
 
 
 protected:
-	qint32 m_major;
-	qint32 m_minor;
-	qint32 m_build;
-	qint32 m_revision;
-	qint32 m_majorRevision;
-	qint32 m_minorRevision;
+	QString m_header;
+	QString m_text;
+	std::optional<qint64> m_timeoutMs = std::nullopt;
 
 private:
-	// Private constructor which generates an invalid object, for use withing Version::fromJson();
-	Version();
+	// Private constructor which generates an invalid object, for use withing MessageCommand::fromJson();
+	MessageCommand();
 };
 
 
@@ -116,15 +98,15 @@ private:
 
 namespace Support {
 
-using Version = Jellyfin::DTO::Version;
+using MessageCommand = Jellyfin::DTO::MessageCommand;
 
 template <>
-Version fromJsonValue(const QJsonValue &source, convertType<Version>);
+MessageCommand fromJsonValue(const QJsonValue &source, convertType<MessageCommand>);
 
 template<>
-QJsonValue toJsonValue(const Version &source, convertType<Version>);
+QJsonValue toJsonValue(const MessageCommand &source, convertType<MessageCommand>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_VERSION_H
+#endif // JELLYFIN_DTO_MESSAGECOMMAND_H
diff --git a/core/include/JellyfinQt/dto/metadataconfiguration.h b/core/include/JellyfinQt/dto/metadataconfiguration.h
new file mode 100644
index 0000000..60da7df
--- /dev/null
+++ b/core/include/JellyfinQt/dto/metadataconfiguration.h
@@ -0,0 +1,95 @@
+/*
+ * 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_DTO_METADATACONFIGURATION_H
+#define JELLYFIN_DTO_METADATACONFIGURATION_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class MetadataConfiguration {
+public:
+	MetadataConfiguration(	
+		bool useFileCreationTimeForDateAdded		
+	);
+
+	MetadataConfiguration(const MetadataConfiguration &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(MetadataConfiguration &other);
+	
+	static MetadataConfiguration fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	bool useFileCreationTimeForDateAdded() const;
+
+	void setUseFileCreationTimeForDateAdded(bool newUseFileCreationTimeForDateAdded);
+
+
+protected:
+	bool m_useFileCreationTimeForDateAdded;
+
+private:
+	// Private constructor which generates an invalid object, for use withing MetadataConfiguration::fromJson();
+	MetadataConfiguration();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using MetadataConfiguration = Jellyfin::DTO::MetadataConfiguration;
+
+template <>
+MetadataConfiguration fromJsonValue(const QJsonValue &source, convertType<MetadataConfiguration>);
+
+template<>
+QJsonValue toJsonValue(const MetadataConfiguration &source, convertType<MetadataConfiguration>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_METADATACONFIGURATION_H
diff --git a/core/include/JellyfinQt/dto/metadataeditorinfo.h b/core/include/JellyfinQt/dto/metadataeditorinfo.h
index 722dc05..60f806b 100644
--- a/core/include/JellyfinQt/dto/metadataeditorinfo.h
+++ b/core/include/JellyfinQt/dto/metadataeditorinfo.h
@@ -33,10 +33,10 @@
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QList>
-#include <QString>
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/collectiontype.h"
 #include "JellyfinQt/dto/countryinfo.h"
 #include "JellyfinQt/dto/culturedto.h"
 #include "JellyfinQt/dto/externalidinfo.h"
@@ -53,7 +53,16 @@ namespace DTO {
 
 
 class MetadataEditorInfo {
-public:	MetadataEditorInfo();
+public:
+	MetadataEditorInfo(	
+		QList<ParentalRating> parentalRatingOptions,			
+		QList<CountryInfo> countries,			
+		QList<CultureDto> cultures,			
+		QList<ExternalIdInfo> externalIdInfos,			
+		CollectionType contentType,			
+		QList<NameValuePair> contentTypeOptions		
+	);
+
 	MetadataEditorInfo(const MetadataEditorInfo &other);
 	
 	/**
@@ -70,43 +79,31 @@ public:	MetadataEditorInfo();
 	QList<ParentalRating> parentalRatingOptions() const;
 
 	void setParentalRatingOptions(QList<ParentalRating> newParentalRatingOptions);
-	bool parentalRatingOptionsNull() const;
-	void setParentalRatingOptionsNull();
 
 
 	QList<CountryInfo> countries() const;
 
 	void setCountries(QList<CountryInfo> newCountries);
-	bool countriesNull() const;
-	void setCountriesNull();
 
 
 	QList<CultureDto> cultures() const;
 
 	void setCultures(QList<CultureDto> newCultures);
-	bool culturesNull() const;
-	void setCulturesNull();
 
 
 	QList<ExternalIdInfo> externalIdInfos() const;
 
 	void setExternalIdInfos(QList<ExternalIdInfo> newExternalIdInfos);
-	bool externalIdInfosNull() const;
-	void setExternalIdInfosNull();
 
 
-	QString contentType() const;
+	CollectionType contentType() const;
 
-	void setContentType(QString newContentType);
-	bool contentTypeNull() const;
-	void setContentTypeNull();
+	void setContentType(CollectionType newContentType);
 
 
 	QList<NameValuePair> contentTypeOptions() const;
 
 	void setContentTypeOptions(QList<NameValuePair> newContentTypeOptions);
-	bool contentTypeOptionsNull() const;
-	void setContentTypeOptionsNull();
 
 
 protected:
@@ -114,10 +111,12 @@ protected:
 	QList<CountryInfo> m_countries;
 	QList<CultureDto> m_cultures;
 	QList<ExternalIdInfo> m_externalIdInfos;
-	QString m_contentType;
+	CollectionType m_contentType;
 	QList<NameValuePair> m_contentTypeOptions;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing MetadataEditorInfo::fromJson();
+	MetadataEditorInfo();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/movieinfo.h b/core/include/JellyfinQt/dto/movieinfo.h
index 48149a6..32d4942 100644
--- a/core/include/JellyfinQt/dto/movieinfo.h
+++ b/core/include/JellyfinQt/dto/movieinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class MovieInfo {
 public:
-	MovieInfo(																			
+	MovieInfo(																					
 		bool isAutomated		
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -159,6 +170,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/movieinforemotesearchquery.h b/core/include/JellyfinQt/dto/movieinforemotesearchquery.h
index f4f4e7c..41f77b1 100644
--- a/core/include/JellyfinQt/dto/movieinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/movieinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/musicvideoinfo.h b/core/include/JellyfinQt/dto/musicvideoinfo.h
index cb04ec3..7e372de 100644
--- a/core/include/JellyfinQt/dto/musicvideoinfo.h
+++ b/core/include/JellyfinQt/dto/musicvideoinfo.h
@@ -50,7 +50,7 @@ namespace DTO {
 
 class MusicVideoInfo {
 public:
-	MusicVideoInfo(																			
+	MusicVideoInfo(																					
 		bool isAutomated				
 	);
 
@@ -77,6 +77,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -168,6 +179,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/musicvideoinforemotesearchquery.h b/core/include/JellyfinQt/dto/musicvideoinforemotesearchquery.h
index 3f4faa5..a81c5f9 100644
--- a/core/include/JellyfinQt/dto/musicvideoinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/musicvideoinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/networkconfiguration.h b/core/include/JellyfinQt/dto/networkconfiguration.h
new file mode 100644
index 0000000..8ad006d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/networkconfiguration.h
@@ -0,0 +1,346 @@
+/*
+ * 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_DTO_NETWORKCONFIGURATION_H
+#define JELLYFIN_DTO_NETWORKCONFIGURATION_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class NetworkConfiguration {
+public:
+	NetworkConfiguration(	
+		QString baseUrl,			
+		bool enableHttps,			
+		bool requireHttps,			
+		QString certificatePath,			
+		QString certificatePassword,			
+		qint32 internalHttpPort,			
+		qint32 internalHttpsPort,			
+		qint32 publicHttpPort,			
+		qint32 publicHttpsPort,			
+		bool autoDiscovery,			
+		bool enableUPnP,			
+		bool enableIPv4,			
+		bool enableIPv6,			
+		bool enableRemoteAccess,			
+		QStringList localNetworkSubnets,			
+		QStringList localNetworkAddresses,			
+		QStringList knownProxies,			
+		bool ignoreVirtualInterfaces,			
+		QStringList virtualInterfaceNames,			
+		bool enablePublishedServerUriByRequest,			
+		QStringList publishedServerUriBySubnet,			
+		QStringList remoteIPFilter,			
+		bool isRemoteIPFilterBlacklist		
+	);
+
+	NetworkConfiguration(const NetworkConfiguration &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(NetworkConfiguration &other);
+	
+	static NetworkConfiguration fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets a value used to specify the URL prefix that your Jellyfin instance can be accessed at.
+	 */
+	QString baseUrl() const;
+	/**
+	* @brief Gets or sets a value used to specify the URL prefix that your Jellyfin instance can be accessed at.
+	*/
+	void setBaseUrl(QString newBaseUrl);
+
+	/**
+	 * @brief Gets or sets a value indicating whether to use HTTPS.
+	 */
+	bool enableHttps() const;
+	/**
+	* @brief Gets or sets a value indicating whether to use HTTPS.
+	*/
+	void setEnableHttps(bool newEnableHttps);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the server should force connections over HTTPS.
+	 */
+	bool requireHttps() const;
+	/**
+	* @brief Gets or sets a value indicating whether the server should force connections over HTTPS.
+	*/
+	void setRequireHttps(bool newRequireHttps);
+
+	/**
+	 * @brief Gets or sets the filesystem path of an X.509 certificate to use for SSL.
+	 */
+	QString certificatePath() const;
+	/**
+	* @brief Gets or sets the filesystem path of an X.509 certificate to use for SSL.
+	*/
+	void setCertificatePath(QString newCertificatePath);
+
+	/**
+	 * @brief Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Common.Net.NetworkConfiguration.CertificatePath.
+	 */
+	QString certificatePassword() const;
+	/**
+	* @brief Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Common.Net.NetworkConfiguration.CertificatePath.
+	*/
+	void setCertificatePassword(QString newCertificatePassword);
+
+	/**
+	 * @brief Gets or sets the internal HTTP server port.
+	 */
+	qint32 internalHttpPort() const;
+	/**
+	* @brief Gets or sets the internal HTTP server port.
+	*/
+	void setInternalHttpPort(qint32 newInternalHttpPort);
+
+	/**
+	 * @brief Gets or sets the internal HTTPS server port.
+	 */
+	qint32 internalHttpsPort() const;
+	/**
+	* @brief Gets or sets the internal HTTPS server port.
+	*/
+	void setInternalHttpsPort(qint32 newInternalHttpsPort);
+
+	/**
+	 * @brief Gets or sets the public HTTP port.
+	 */
+	qint32 publicHttpPort() const;
+	/**
+	* @brief Gets or sets the public HTTP port.
+	*/
+	void setPublicHttpPort(qint32 newPublicHttpPort);
+
+	/**
+	 * @brief Gets or sets the public HTTPS port.
+	 */
+	qint32 publicHttpsPort() const;
+	/**
+	* @brief Gets or sets the public HTTPS port.
+	*/
+	void setPublicHttpsPort(qint32 newPublicHttpsPort);
+
+	/**
+	 * @brief Gets or sets a value indicating whether Autodiscovery is enabled.
+	 */
+	bool autoDiscovery() const;
+	/**
+	* @brief Gets or sets a value indicating whether Autodiscovery is enabled.
+	*/
+	void setAutoDiscovery(bool newAutoDiscovery);
+
+	/**
+	 * @brief Gets or sets a value indicating whether to enable automatic port forwarding.
+	 */
+	bool enableUPnP() const;
+	/**
+	* @brief Gets or sets a value indicating whether to enable automatic port forwarding.
+	*/
+	void setEnableUPnP(bool newEnableUPnP);
+
+	/**
+	 * @brief Gets or sets a value indicating whether IPv6 is enabled.
+	 */
+	bool enableIPv4() const;
+	/**
+	* @brief Gets or sets a value indicating whether IPv6 is enabled.
+	*/
+	void setEnableIPv4(bool newEnableIPv4);
+
+	/**
+	 * @brief Gets or sets a value indicating whether IPv6 is enabled.
+	 */
+	bool enableIPv6() const;
+	/**
+	* @brief Gets or sets a value indicating whether IPv6 is enabled.
+	*/
+	void setEnableIPv6(bool newEnableIPv6);
+
+	/**
+	 * @brief Gets or sets a value indicating whether access from outside of the LAN is permitted.
+	 */
+	bool enableRemoteAccess() const;
+	/**
+	* @brief Gets or sets a value indicating whether access from outside of the LAN is permitted.
+	*/
+	void setEnableRemoteAccess(bool newEnableRemoteAccess);
+
+	/**
+	 * @brief Gets or sets the subnets that are deemed to make up the LAN.
+	 */
+	QStringList localNetworkSubnets() const;
+	/**
+	* @brief Gets or sets the subnets that are deemed to make up the LAN.
+	*/
+	void setLocalNetworkSubnets(QStringList newLocalNetworkSubnets);
+
+	/**
+	 * @brief Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used.
+	 */
+	QStringList localNetworkAddresses() const;
+	/**
+	* @brief Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used.
+	*/
+	void setLocalNetworkAddresses(QStringList newLocalNetworkAddresses);
+
+	/**
+	 * @brief Gets or sets the known proxies.
+	 */
+	QStringList knownProxies() const;
+	/**
+	* @brief Gets or sets the known proxies.
+	*/
+	void setKnownProxies(QStringList newKnownProxies);
+
+	/**
+	 * @brief Gets or sets a value indicating whether address names that match MediaBrowser.Common.Net.NetworkConfiguration.VirtualInterfaceNames should be ignored for the purposes of binding.
+	 */
+	bool ignoreVirtualInterfaces() const;
+	/**
+	* @brief Gets or sets a value indicating whether address names that match MediaBrowser.Common.Net.NetworkConfiguration.VirtualInterfaceNames should be ignored for the purposes of binding.
+	*/
+	void setIgnoreVirtualInterfaces(bool newIgnoreVirtualInterfaces);
+
+	/**
+	 * @brief Gets or sets a value indicating the interface name prefixes that should be ignored. The list can be comma separated and values are case-insensitive. <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.IgnoreVirtualInterfaces" />.
+	 */
+	QStringList virtualInterfaceNames() const;
+	/**
+	* @brief Gets or sets a value indicating the interface name prefixes that should be ignored. The list can be comma separated and values are case-insensitive. <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.IgnoreVirtualInterfaces" />.
+	*/
+	void setVirtualInterfaceNames(QStringList newVirtualInterfaceNames);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the published server uri is based on information in HTTP requests.
+	 */
+	bool enablePublishedServerUriByRequest() const;
+	/**
+	* @brief Gets or sets a value indicating whether the published server uri is based on information in HTTP requests.
+	*/
+	void setEnablePublishedServerUriByRequest(bool newEnablePublishedServerUriByRequest);
+
+	/**
+	 * @brief Gets or sets the PublishedServerUriBySubnet
+Gets or sets PublishedServerUri to advertise for specific subnets.
+	 */
+	QStringList publishedServerUriBySubnet() const;
+	/**
+	* @brief Gets or sets the PublishedServerUriBySubnet
+Gets or sets PublishedServerUri to advertise for specific subnets.
+	*/
+	void setPublishedServerUriBySubnet(QStringList newPublishedServerUriBySubnet);
+
+	/**
+	 * @brief Gets or sets the filter for remote IP connectivity. Used in conjunction with <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.IsRemoteIPFilterBlacklist" />.
+	 */
+	QStringList remoteIPFilter() const;
+	/**
+	* @brief Gets or sets the filter for remote IP connectivity. Used in conjunction with <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.IsRemoteIPFilterBlacklist" />.
+	*/
+	void setRemoteIPFilter(QStringList newRemoteIPFilter);
+
+	/**
+	 * @brief Gets or sets a value indicating whether <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.RemoteIPFilter" /> contains a blacklist or a whitelist. Default is a whitelist.
+	 */
+	bool isRemoteIPFilterBlacklist() const;
+	/**
+	* @brief Gets or sets a value indicating whether <seealso cref="P:MediaBrowser.Common.Net.NetworkConfiguration.RemoteIPFilter" /> contains a blacklist or a whitelist. Default is a whitelist.
+	*/
+	void setIsRemoteIPFilterBlacklist(bool newIsRemoteIPFilterBlacklist);
+
+
+protected:
+	QString m_baseUrl;
+	bool m_enableHttps;
+	bool m_requireHttps;
+	QString m_certificatePath;
+	QString m_certificatePassword;
+	qint32 m_internalHttpPort;
+	qint32 m_internalHttpsPort;
+	qint32 m_publicHttpPort;
+	qint32 m_publicHttpsPort;
+	bool m_autoDiscovery;
+	bool m_enableUPnP;
+	bool m_enableIPv4;
+	bool m_enableIPv6;
+	bool m_enableRemoteAccess;
+	QStringList m_localNetworkSubnets;
+	QStringList m_localNetworkAddresses;
+	QStringList m_knownProxies;
+	bool m_ignoreVirtualInterfaces;
+	QStringList m_virtualInterfaceNames;
+	bool m_enablePublishedServerUriByRequest;
+	QStringList m_publishedServerUriBySubnet;
+	QStringList m_remoteIPFilter;
+	bool m_isRemoteIPFilterBlacklist;
+
+private:
+	// Private constructor which generates an invalid object, for use withing NetworkConfiguration::fromJson();
+	NetworkConfiguration();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using NetworkConfiguration = Jellyfin::DTO::NetworkConfiguration;
+
+template <>
+NetworkConfiguration fromJsonValue(const QJsonValue &source, convertType<NetworkConfiguration>);
+
+template<>
+QJsonValue toJsonValue(const NetworkConfiguration &source, convertType<NetworkConfiguration>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_NETWORKCONFIGURATION_H
diff --git a/core/include/JellyfinQt/dto/newgrouprequestdto.h b/core/include/JellyfinQt/dto/newgrouprequestdto.h
index 402721c..49c7fc6 100644
--- a/core/include/JellyfinQt/dto/newgrouprequestdto.h
+++ b/core/include/JellyfinQt/dto/newgrouprequestdto.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class NewGroupRequestDto {
-public:	NewGroupRequestDto();
+public:
+	NewGroupRequestDto(	
+		QString groupName		
+	);
+
 	NewGroupRequestDto(const NewGroupRequestDto &other);
 	
 	/**
@@ -67,14 +71,14 @@ public:	NewGroupRequestDto();
 	* @brief Gets or sets the group name.
 	*/
 	void setGroupName(QString newGroupName);
-	bool groupNameNull() const;
-	void setGroupNameNull();
 
 
 protected:
 	QString m_groupName;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing NewGroupRequestDto::fromJson();
+	NewGroupRequestDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/notificationdto.h b/core/include/JellyfinQt/dto/notificationdto.h
deleted file mode 100644
index 9969902..0000000
--- a/core/include/JellyfinQt/dto/notificationdto.h
+++ /dev/null
@@ -1,180 +0,0 @@
-/*
- * 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_DTO_NOTIFICATIONDTO_H
-#define JELLYFIN_DTO_NOTIFICATIONDTO_H
-
-#include <QDateTime>
-#include <QJsonObject>
-#include <QJsonValue>
-#include <QString>
-#include <optional>
-
-#include "JellyfinQt/dto/notificationlevel.h"
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-
-class NotificationDto {
-public:
-	NotificationDto(					
-		QDateTime date,			
-		bool isRead,									
-		NotificationLevel level		
-	);
-
-	NotificationDto(const NotificationDto &other);
-	
-	/**
-	 * Replaces the data being hold by this class with that of the other.
-	 */
-	void replaceData(NotificationDto &other);
-	
-	static NotificationDto fromJson(QJsonObject source);
-	void setFromJson(QJsonObject source);
-	QJsonObject toJson() const;
-	
-	// Properties
-	/**
-	 * @brief Gets or sets the notification ID. Defaults to an empty string.
-	 */
-	QString jellyfinId() const;
-	/**
-	* @brief Gets or sets the notification ID. Defaults to an empty string.
-	*/
-	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
-
-	/**
-	 * @brief Gets or sets the notification's user ID. Defaults to an empty string.
-	 */
-	QString userId() const;
-	/**
-	* @brief Gets or sets the notification's user ID. Defaults to an empty string.
-	*/
-	void setUserId(QString newUserId);
-	bool userIdNull() const;
-	void setUserIdNull();
-
-	/**
-	 * @brief Gets or sets the notification date.
-	 */
-	QDateTime date() const;
-	/**
-	* @brief Gets or sets the notification date.
-	*/
-	void setDate(QDateTime newDate);
-
-	/**
-	 * @brief Gets or sets a value indicating whether the notification has been read. Defaults to false.
-	 */
-	bool isRead() const;
-	/**
-	* @brief Gets or sets a value indicating whether the notification has been read. Defaults to false.
-	*/
-	void setIsRead(bool newIsRead);
-
-	/**
-	 * @brief Gets or sets the notification's name. Defaults to an empty string.
-	 */
-	QString name() const;
-	/**
-	* @brief Gets or sets the notification's name. Defaults to an empty string.
-	*/
-	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-
-	/**
-	 * @brief Gets or sets the notification's description. Defaults to an empty string.
-	 */
-	QString description() const;
-	/**
-	* @brief Gets or sets the notification's description. Defaults to an empty string.
-	*/
-	void setDescription(QString newDescription);
-	bool descriptionNull() const;
-	void setDescriptionNull();
-
-	/**
-	 * @brief Gets or sets the notification's URL. Defaults to an empty string.
-	 */
-	QString url() const;
-	/**
-	* @brief Gets or sets the notification's URL. Defaults to an empty string.
-	*/
-	void setUrl(QString newUrl);
-	bool urlNull() const;
-	void setUrlNull();
-
-
-	NotificationLevel level() const;
-
-	void setLevel(NotificationLevel newLevel);
-
-
-protected:
-	QString m_jellyfinId;
-	QString m_userId;
-	QDateTime m_date;
-	bool m_isRead;
-	QString m_name;
-	QString m_description;
-	QString m_url;
-	NotificationLevel m_level;
-
-private:
-	// Private constructor which generates an invalid object, for use withing NotificationDto::fromJson();
-	NotificationDto();
-};
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationDto = Jellyfin::DTO::NotificationDto;
-
-template <>
-NotificationDto fromJsonValue(const QJsonValue &source, convertType<NotificationDto>);
-
-template<>
-QJsonValue toJsonValue(const NotificationDto &source, convertType<NotificationDto>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_NOTIFICATIONDTO_H
diff --git a/core/include/JellyfinQt/dto/notificationssummarydto.h b/core/include/JellyfinQt/dto/notificationssummarydto.h
deleted file mode 100644
index 7b604df..0000000
--- a/core/include/JellyfinQt/dto/notificationssummarydto.h
+++ /dev/null
@@ -1,107 +0,0 @@
-/*
- * 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_DTO_NOTIFICATIONSSUMMARYDTO_H
-#define JELLYFIN_DTO_NOTIFICATIONSSUMMARYDTO_H
-
-#include <QJsonObject>
-#include <QJsonValue>
-#include <optional>
-
-#include "JellyfinQt/dto/notificationlevel.h"
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-
-class NotificationsSummaryDto {
-public:
-	NotificationsSummaryDto(	
-		qint32 unreadCount,			
-		NotificationLevel maxUnreadNotificationLevel		
-	);
-
-	NotificationsSummaryDto(const NotificationsSummaryDto &other);
-	
-	/**
-	 * Replaces the data being hold by this class with that of the other.
-	 */
-	void replaceData(NotificationsSummaryDto &other);
-	
-	static NotificationsSummaryDto fromJson(QJsonObject source);
-	void setFromJson(QJsonObject source);
-	QJsonObject toJson() const;
-	
-	// Properties
-	/**
-	 * @brief Gets or sets the number of unread notifications.
-	 */
-	qint32 unreadCount() const;
-	/**
-	* @brief Gets or sets the number of unread notifications.
-	*/
-	void setUnreadCount(qint32 newUnreadCount);
-
-
-	NotificationLevel maxUnreadNotificationLevel() const;
-
-	void setMaxUnreadNotificationLevel(NotificationLevel newMaxUnreadNotificationLevel);
-
-
-protected:
-	qint32 m_unreadCount;
-	NotificationLevel m_maxUnreadNotificationLevel;
-
-private:
-	// Private constructor which generates an invalid object, for use withing NotificationsSummaryDto::fromJson();
-	NotificationsSummaryDto();
-};
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationsSummaryDto = Jellyfin::DTO::NotificationsSummaryDto;
-
-template <>
-NotificationsSummaryDto fromJsonValue(const QJsonValue &source, convertType<NotificationsSummaryDto>);
-
-template<>
-QJsonValue toJsonValue(const NotificationsSummaryDto &source, convertType<NotificationsSummaryDto>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_NOTIFICATIONSSUMMARYDTO_H
diff --git a/core/include/JellyfinQt/dto/openlivestreamdto.h b/core/include/JellyfinQt/dto/openlivestreamdto.h
index 553c4ed..53fc700 100644
--- a/core/include/JellyfinQt/dto/openlivestreamdto.h
+++ b/core/include/JellyfinQt/dto/openlivestreamdto.h
@@ -52,8 +52,9 @@ namespace DTO {
 
 class OpenLiveStreamDto {
 public:
-	OpenLiveStreamDto(																							
-		QSharedPointer<DeviceProfile> deviceProfile				
+	OpenLiveStreamDto(																									
+		QSharedPointer<DeviceProfile> deviceProfile,			
+		QList<MediaProtocol> directPlayProtocols		
 	);
 
 	OpenLiveStreamDto(const OpenLiveStreamDto &other);
@@ -189,6 +190,17 @@ public:
 	bool enableDirectStreamNull() const;
 	void setEnableDirectStreamNull();
 
+	/**
+	 * @brief Gets or sets a value indicating whether always burn in subtitles when transcoding.
+	 */
+	std::optional<bool> alwaysBurnInSubtitleWhenTranscoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether always burn in subtitles when transcoding.
+	*/
+	void setAlwaysBurnInSubtitleWhenTranscoding(std::optional<bool> newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+
 
 	QSharedPointer<DeviceProfile> deviceProfile() const;
 
@@ -202,8 +214,6 @@ public:
 	* @brief Gets or sets the device play protocols.
 	*/
 	void setDirectPlayProtocols(QList<MediaProtocol> newDirectPlayProtocols);
-	bool directPlayProtocolsNull() const;
-	void setDirectPlayProtocolsNull();
 
 
 protected:
@@ -218,6 +228,7 @@ protected:
 	QString m_itemId;
 	std::optional<bool> m_enableDirectPlay = std::nullopt;
 	std::optional<bool> m_enableDirectStream = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	QSharedPointer<DeviceProfile> m_deviceProfile = QSharedPointer<DeviceProfile>();
 	QList<MediaProtocol> m_directPlayProtocols;
 
diff --git a/core/include/JellyfinQt/dto/outboundkeepalivemessage.h b/core/include/JellyfinQt/dto/outboundkeepalivemessage.h
new file mode 100644
index 0000000..5b7db9e
--- /dev/null
+++ b/core/include/JellyfinQt/dto/outboundkeepalivemessage.h
@@ -0,0 +1,108 @@
+/*
+ * 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_DTO_OUTBOUNDKEEPALIVEMESSAGE_H
+#define JELLYFIN_DTO_OUTBOUNDKEEPALIVEMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class OutboundKeepAliveMessage {
+public:
+	OutboundKeepAliveMessage(	
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	OutboundKeepAliveMessage(const OutboundKeepAliveMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(OutboundKeepAliveMessage &other);
+	
+	static OutboundKeepAliveMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing OutboundKeepAliveMessage::fromJson();
+	OutboundKeepAliveMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using OutboundKeepAliveMessage = Jellyfin::DTO::OutboundKeepAliveMessage;
+
+template <>
+OutboundKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<OutboundKeepAliveMessage>);
+
+template<>
+QJsonValue toJsonValue(const OutboundKeepAliveMessage &source, convertType<OutboundKeepAliveMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_OUTBOUNDKEEPALIVEMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/outboundwebsocketmessage.h b/core/include/JellyfinQt/dto/outboundwebsocketmessage.h
new file mode 100644
index 0000000..9a9dfa2
--- /dev/null
+++ b/core/include/JellyfinQt/dto/outboundwebsocketmessage.h
@@ -0,0 +1,48 @@
+/*
+ * 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_DTO_OUTBOUNDWEBSOCKETMESSAGE_H
+#define JELLYFIN_DTO_OUTBOUNDWEBSOCKETMESSAGE_H
+
+#include <QJsonObject>
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+using OutboundWebSocketMessage = QJsonObject;
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_OUTBOUNDWEBSOCKETMESSAGE_H
+// No implementation needed
diff --git a/core/include/JellyfinQt/dto/packageinfo.h b/core/include/JellyfinQt/dto/packageinfo.h
index c30c6ee..35f6421 100644
--- a/core/include/JellyfinQt/dto/packageinfo.h
+++ b/core/include/JellyfinQt/dto/packageinfo.h
@@ -49,7 +49,17 @@ namespace DTO {
 
 
 class PackageInfo {
-public:	PackageInfo();
+public:
+	PackageInfo(	
+		QString name,			
+		QString description,			
+		QString overview,			
+		QString owner,			
+		QString category,			
+		QString guid,			
+		QList<VersionInfo> versions				
+	);
+
 	PackageInfo(const PackageInfo &other);
 	
 	/**
@@ -70,8 +80,6 @@ public:	PackageInfo();
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets a long description of the plugin containing features or helpful explanations.
@@ -81,8 +89,6 @@ public:	PackageInfo();
 	* @brief Gets or sets a long description of the plugin containing features or helpful explanations.
 	*/
 	void setDescription(QString newDescription);
-	bool descriptionNull() const;
-	void setDescriptionNull();
 
 	/**
 	 * @brief Gets or sets a short overview of what the plugin does.
@@ -92,8 +98,6 @@ public:	PackageInfo();
 	* @brief Gets or sets a short overview of what the plugin does.
 	*/
 	void setOverview(QString newOverview);
-	bool overviewNull() const;
-	void setOverviewNull();
 
 	/**
 	 * @brief Gets or sets the owner.
@@ -103,8 +107,6 @@ public:	PackageInfo();
 	* @brief Gets or sets the owner.
 	*/
 	void setOwner(QString newOwner);
-	bool ownerNull() const;
-	void setOwnerNull();
 
 	/**
 	 * @brief Gets or sets the category.
@@ -114,8 +116,6 @@ public:	PackageInfo();
 	* @brief Gets or sets the category.
 	*/
 	void setCategory(QString newCategory);
-	bool categoryNull() const;
-	void setCategoryNull();
 
 	/**
 	 * @brief Gets or sets the guid of the assembly associated with this plugin.
@@ -127,8 +127,6 @@ This is used to identify the proper item for automatic updates.
 This is used to identify the proper item for automatic updates.
 	*/
 	void setGuid(QString newGuid);
-	bool guidNull() const;
-	void setGuidNull();
 
 	/**
 	 * @brief Gets or sets the versions.
@@ -138,8 +136,6 @@ This is used to identify the proper item for automatic updates.
 	* @brief Gets or sets the versions.
 	*/
 	void setVersions(QList<VersionInfo> newVersions);
-	bool versionsNull() const;
-	void setVersionsNull();
 
 	/**
 	 * @brief Gets or sets the image url for the package.
@@ -163,7 +159,9 @@ protected:
 	QList<VersionInfo> m_versions;
 	QString m_imageUrl;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing PackageInfo::fromJson();
+	PackageInfo();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/parentalrating.h b/core/include/JellyfinQt/dto/parentalrating.h
index f096052..aec4b36 100644
--- a/core/include/JellyfinQt/dto/parentalrating.h
+++ b/core/include/JellyfinQt/dto/parentalrating.h
@@ -46,11 +46,7 @@ namespace DTO {
 
 
 class ParentalRating {
-public:
-	ParentalRating(			
-		qint32 value		
-	);
-
+public:	ParentalRating();
 	ParentalRating(const ParentalRating &other);
 	
 	/**
@@ -77,20 +73,20 @@ public:
 	/**
 	 * @brief Gets or sets the value.
 	 */
-	qint32 value() const;
+	std::optional<qint32> value() const;
 	/**
 	* @brief Gets or sets the value.
 	*/
-	void setValue(qint32 newValue);
+	void setValue(std::optional<qint32> newValue);
+	bool valueNull() const;
+	void setValueNull();
 
 
 protected:
 	QString m_name;
-	qint32 m_value;
+	std::optional<qint32> m_value = std::nullopt;
+
 
-private:
-	// Private constructor which generates an invalid object, for use withing ParentalRating::fromJson();
-	ParentalRating();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/pathsubstitution.h b/core/include/JellyfinQt/dto/pathsubstitution.h
index 4207569..cefd387 100644
--- a/core/include/JellyfinQt/dto/pathsubstitution.h
+++ b/core/include/JellyfinQt/dto/pathsubstitution.h
@@ -46,7 +46,12 @@ namespace DTO {
 
 
 class PathSubstitution {
-public:	PathSubstitution();
+public:
+	PathSubstitution(	
+		QString from,			
+		QString to		
+	);
+
 	PathSubstitution(const PathSubstitution &other);
 	
 	/**
@@ -67,8 +72,6 @@ public:	PathSubstitution();
 	* @brief Gets or sets the value to substitute.
 	*/
 	void setFrom(QString newFrom);
-	bool fromNull() const;
-	void setFromNull();
 
 	/**
 	 * @brief Gets or sets the value to substitution with.
@@ -78,15 +81,15 @@ public:	PathSubstitution();
 	* @brief Gets or sets the value to substitution with.
 	*/
 	void setTo(QString newTo);
-	bool toNull() const;
-	void setToNull();
 
 
 protected:
 	QString m_from;
 	QString m_to;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing PathSubstitution::fromJson();
+	PathSubstitution();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/personkind.h b/core/include/JellyfinQt/dto/personkind.h
new file mode 100644
index 0000000..f923b55
--- /dev/null
+++ b/core/include/JellyfinQt/dto/personkind.h
@@ -0,0 +1,99 @@
+/*
+ * 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_DTO_PERSONKIND_H
+#define JELLYFIN_DTO_PERSONKIND_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class PersonKindClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Unknown,
+		Actor,
+		Director,
+		Composer,
+		Writer,
+		GuestStar,
+		Producer,
+		Conductor,
+		Lyricist,
+		Arranger,
+		Engineer,
+		Mixer,
+		Remixer,
+		Creator,
+		Artist,
+		AlbumArtist,
+		Author,
+		Illustrator,
+		Penciller,
+		Inker,
+		Colorist,
+		Letterer,
+		CoverArtist,
+		Editor,
+		Translator,
+	};
+	Q_ENUM(Value)
+private:
+	explicit PersonKindClass();
+};
+
+using PersonKind = PersonKindClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using PersonKind = Jellyfin::DTO::PersonKind;
+
+template <>
+PersonKind fromJsonValue(const QJsonValue &source, convertType<PersonKind>);
+
+template <>
+QJsonValue toJsonValue(const PersonKind &source, convertType<PersonKind>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PERSONKIND_H
diff --git a/core/include/JellyfinQt/dto/personlookupinfo.h b/core/include/JellyfinQt/dto/personlookupinfo.h
index 926f3d2..dbdcfdf 100644
--- a/core/include/JellyfinQt/dto/personlookupinfo.h
+++ b/core/include/JellyfinQt/dto/personlookupinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class PersonLookupInfo {
 public:
-	PersonLookupInfo(																			
+	PersonLookupInfo(																					
 		bool isAutomated		
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -159,6 +170,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/personlookupinforemotesearchquery.h b/core/include/JellyfinQt/dto/personlookupinforemotesearchquery.h
index 0865fbc..3da2459 100644
--- a/core/include/JellyfinQt/dto/personlookupinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/personlookupinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/pinredeemresult.h b/core/include/JellyfinQt/dto/pinredeemresult.h
index 7fc6471..9873f69 100644
--- a/core/include/JellyfinQt/dto/pinredeemresult.h
+++ b/core/include/JellyfinQt/dto/pinredeemresult.h
@@ -50,7 +50,8 @@ namespace DTO {
 class PinRedeemResult {
 public:
 	PinRedeemResult(	
-		bool success				
+		bool success,			
+		QStringList usersReset		
 	);
 
 	PinRedeemResult(const PinRedeemResult &other);
@@ -82,8 +83,6 @@ public:
 	* @brief Gets or sets the users reset.
 	*/
 	void setUsersReset(QStringList newUsersReset);
-	bool usersResetNull() const;
-	void setUsersResetNull();
 
 
 protected:
diff --git a/core/include/JellyfinQt/dto/playbackinfodto.h b/core/include/JellyfinQt/dto/playbackinfodto.h
index 18ae2b5..5c2a9e2 100644
--- a/core/include/JellyfinQt/dto/playbackinfodto.h
+++ b/core/include/JellyfinQt/dto/playbackinfodto.h
@@ -50,7 +50,7 @@ namespace DTO {
 class PlaybackInfoDto {
 public:
 	PlaybackInfoDto(																	
-		QSharedPointer<DeviceProfile> deviceProfile														
+		QSharedPointer<DeviceProfile> deviceProfile																
 	);
 
 	PlaybackInfoDto(const PlaybackInfoDto &other);
@@ -224,6 +224,17 @@ public:
 	bool autoOpenLiveStreamNull() const;
 	void setAutoOpenLiveStreamNull();
 
+	/**
+	 * @brief Gets or sets a value indicating whether always burn in subtitles when transcoding.
+	 */
+	std::optional<bool> alwaysBurnInSubtitleWhenTranscoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether always burn in subtitles when transcoding.
+	*/
+	void setAlwaysBurnInSubtitleWhenTranscoding(std::optional<bool> newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+
 
 protected:
 	QString m_userId;
@@ -241,6 +252,7 @@ protected:
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_autoOpenLiveStream = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 
 private:
 	// Private constructor which generates an invalid object, for use withing PlaybackInfoDto::fromJson();
diff --git a/core/include/JellyfinQt/dto/playbackinforesponse.h b/core/include/JellyfinQt/dto/playbackinforesponse.h
index 06fc54e..1cd28a8 100644
--- a/core/include/JellyfinQt/dto/playbackinforesponse.h
+++ b/core/include/JellyfinQt/dto/playbackinforesponse.h
@@ -51,7 +51,8 @@ namespace DTO {
 
 class PlaybackInfoResponse {
 public:
-	PlaybackInfoResponse(					
+	PlaybackInfoResponse(	
+		QList<MediaSourceInfo> mediaSources,					
 		PlaybackErrorCode errorCode		
 	);
 
@@ -75,8 +76,6 @@ public:
 	* @brief Gets or sets the media sources.
 	*/
 	void setMediaSources(QList<MediaSourceInfo> newMediaSources);
-	bool mediaSourcesNull() const;
-	void setMediaSourcesNull();
 
 	/**
 	 * @brief Gets or sets the play session identifier.
diff --git a/core/include/JellyfinQt/dto/headermatchtype.h b/core/include/JellyfinQt/dto/playbackorder.h
similarity index 77%
rename from core/include/JellyfinQt/dto/headermatchtype.h
rename to core/include/JellyfinQt/dto/playbackorder.h
index 8b37c1a..da5003b 100644
--- a/core/include/JellyfinQt/dto/headermatchtype.h
+++ b/core/include/JellyfinQt/dto/playbackorder.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_HEADERMATCHTYPE_H
-#define JELLYFIN_DTO_HEADERMATCHTYPE_H
+#ifndef JELLYFIN_DTO_PLAYBACKORDER_H
+#define JELLYFIN_DTO_PLAYBACKORDER_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,35 +43,34 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class HeaderMatchTypeClass {
+class PlaybackOrderClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
-		Equals,
-		Regex,
-		Substring,
+		Default,
+		Shuffle,
 	};
 	Q_ENUM(Value)
 private:
-	explicit HeaderMatchTypeClass();
+	explicit PlaybackOrderClass();
 };
 
-using HeaderMatchType = HeaderMatchTypeClass::Value;
+using PlaybackOrder = PlaybackOrderClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using HeaderMatchType = Jellyfin::DTO::HeaderMatchType;
+using PlaybackOrder = Jellyfin::DTO::PlaybackOrder;
 
 template <>
-HeaderMatchType fromJsonValue(const QJsonValue &source, convertType<HeaderMatchType>);
+PlaybackOrder fromJsonValue(const QJsonValue &source, convertType<PlaybackOrder>);
 
 template <>
-QJsonValue toJsonValue(const HeaderMatchType &source, convertType<HeaderMatchType>);
+QJsonValue toJsonValue(const PlaybackOrder &source, convertType<PlaybackOrder>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_HEADERMATCHTYPE_H
+#endif // JELLYFIN_DTO_PLAYBACKORDER_H
diff --git a/core/include/JellyfinQt/dto/playbackprogressinfo.h b/core/include/JellyfinQt/dto/playbackprogressinfo.h
index 83c267e..fef2dc3 100644
--- a/core/include/JellyfinQt/dto/playbackprogressinfo.h
+++ b/core/include/JellyfinQt/dto/playbackprogressinfo.h
@@ -39,6 +39,7 @@
 #include <optional>
 
 #include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/playbackorder.h"
 #include "JellyfinQt/dto/playmethod.h"
 #include "JellyfinQt/dto/queueitem.h"
 #include "JellyfinQt/dto/repeatmode.h"
@@ -61,7 +62,8 @@ public:
 		bool isPaused,			
 		bool isMuted,													
 		PlayMethod playMethod,							
-		RepeatMode repeatMode						
+		RepeatMode repeatMode,			
+		PlaybackOrder playbackOrder						
 	);
 
 	PlaybackProgressInfo(const PlaybackProgressInfo &other);
@@ -237,6 +239,11 @@ public:
 	void setRepeatMode(RepeatMode newRepeatMode);
 
 
+	PlaybackOrder playbackOrder() const;
+
+	void setPlaybackOrder(PlaybackOrder newPlaybackOrder);
+
+
 	QList<QueueItem> nowPlayingQueue() const;
 
 	void setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue);
@@ -270,6 +277,7 @@ protected:
 	QString m_liveStreamId;
 	QString m_playSessionId;
 	RepeatMode m_repeatMode;
+	PlaybackOrder m_playbackOrder;
 	QList<QueueItem> m_nowPlayingQueue;
 	QString m_playlistItemId;
 
diff --git a/core/include/JellyfinQt/dto/playbackrequesttype.h b/core/include/JellyfinQt/dto/playbackrequesttype.h
new file mode 100644
index 0000000..80b7c46
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playbackrequesttype.h
@@ -0,0 +1,91 @@
+/*
+ * 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_DTO_PLAYBACKREQUESTTYPE_H
+#define JELLYFIN_DTO_PLAYBACKREQUESTTYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class PlaybackRequestTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Play,
+		SetPlaylistItem,
+		RemoveFromPlaylist,
+		MovePlaylistItem,
+		Queue,
+		Unpause,
+		Pause,
+		Stop,
+		Seek,
+		Buffer,
+		Ready,
+		NextItem,
+		PreviousItem,
+		SetRepeatMode,
+		SetShuffleMode,
+		Ping,
+		IgnoreWait,
+	};
+	Q_ENUM(Value)
+private:
+	explicit PlaybackRequestTypeClass();
+};
+
+using PlaybackRequestType = PlaybackRequestTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using PlaybackRequestType = Jellyfin::DTO::PlaybackRequestType;
+
+template <>
+PlaybackRequestType fromJsonValue(const QJsonValue &source, convertType<PlaybackRequestType>);
+
+template <>
+QJsonValue toJsonValue(const PlaybackRequestType &source, convertType<PlaybackRequestType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYBACKREQUESTTYPE_H
diff --git a/core/include/JellyfinQt/dto/playbackstartinfo.h b/core/include/JellyfinQt/dto/playbackstartinfo.h
index 3441dc4..71dcac6 100644
--- a/core/include/JellyfinQt/dto/playbackstartinfo.h
+++ b/core/include/JellyfinQt/dto/playbackstartinfo.h
@@ -39,6 +39,7 @@
 #include <optional>
 
 #include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/playbackorder.h"
 #include "JellyfinQt/dto/playmethod.h"
 #include "JellyfinQt/dto/queueitem.h"
 #include "JellyfinQt/dto/repeatmode.h"
@@ -61,7 +62,8 @@ public:
 		bool isPaused,			
 		bool isMuted,													
 		PlayMethod playMethod,							
-		RepeatMode repeatMode						
+		RepeatMode repeatMode,			
+		PlaybackOrder playbackOrder						
 	);
 
 	PlaybackStartInfo(const PlaybackStartInfo &other);
@@ -237,6 +239,11 @@ public:
 	void setRepeatMode(RepeatMode newRepeatMode);
 
 
+	PlaybackOrder playbackOrder() const;
+
+	void setPlaybackOrder(PlaybackOrder newPlaybackOrder);
+
+
 	QList<QueueItem> nowPlayingQueue() const;
 
 	void setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue);
@@ -270,6 +277,7 @@ protected:
 	QString m_liveStreamId;
 	QString m_playSessionId;
 	RepeatMode m_repeatMode;
+	PlaybackOrder m_playbackOrder;
 	QList<QueueItem> m_nowPlayingQueue;
 	QString m_playlistItemId;
 
diff --git a/core/include/JellyfinQt/dto/playerstateinfo.h b/core/include/JellyfinQt/dto/playerstateinfo.h
index 04acf42..a12fb40 100644
--- a/core/include/JellyfinQt/dto/playerstateinfo.h
+++ b/core/include/JellyfinQt/dto/playerstateinfo.h
@@ -35,6 +35,7 @@
 #include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/playbackorder.h"
 #include "JellyfinQt/dto/playmethod.h"
 #include "JellyfinQt/dto/repeatmode.h"
 #include "JellyfinQt/support/jsonconv.h"
@@ -54,7 +55,8 @@ public:
 		bool isPaused,			
 		bool isMuted,											
 		PlayMethod playMethod,			
-		RepeatMode repeatMode		
+		RepeatMode repeatMode,			
+		PlaybackOrder playbackOrder				
 	);
 
 	PlayerStateInfo(const PlayerStateInfo &other);
@@ -162,6 +164,22 @@ public:
 	void setRepeatMode(RepeatMode newRepeatMode);
 
 
+	PlaybackOrder playbackOrder() const;
+
+	void setPlaybackOrder(PlaybackOrder newPlaybackOrder);
+
+	/**
+	 * @brief Gets or sets the now playing live stream identifier.
+	 */
+	QString liveStreamId() const;
+	/**
+	* @brief Gets or sets the now playing live stream identifier.
+	*/
+	void setLiveStreamId(QString newLiveStreamId);
+	bool liveStreamIdNull() const;
+	void setLiveStreamIdNull();
+
+
 protected:
 	std::optional<qint64> m_positionTicks = std::nullopt;
 	bool m_canSeek;
@@ -173,6 +191,8 @@ protected:
 	QString m_mediaSourceId;
 	PlayMethod m_playMethod;
 	RepeatMode m_repeatMode;
+	PlaybackOrder m_playbackOrder;
+	QString m_liveStreamId;
 
 private:
 	// Private constructor which generates an invalid object, for use withing PlayerStateInfo::fromJson();
diff --git a/core/include/JellyfinQt/dto/playlistcreationresult.h b/core/include/JellyfinQt/dto/playlistcreationresult.h
index 927ee45..8c62c22 100644
--- a/core/include/JellyfinQt/dto/playlistcreationresult.h
+++ b/core/include/JellyfinQt/dto/playlistcreationresult.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class PlaylistCreationResult {
-public:	PlaylistCreationResult();
+public:
+	PlaylistCreationResult(	
+		QString jellyfinId		
+	);
+
 	PlaylistCreationResult(const PlaylistCreationResult &other);
 	
 	/**
@@ -63,14 +67,14 @@ public:	PlaylistCreationResult();
 	QString jellyfinId() const;
 
 	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
 
 
 protected:
 	QString m_jellyfinId;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing PlaylistCreationResult::fromJson();
+	PlaylistCreationResult();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/playlistdto.h b/core/include/JellyfinQt/dto/playlistdto.h
new file mode 100644
index 0000000..2d30dee
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playlistdto.h
@@ -0,0 +1,124 @@
+/*
+ * 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_DTO_PLAYLISTDTO_H
+#define JELLYFIN_DTO_PLAYLISTDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/playlistuserpermissions.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PlaylistDto {
+public:
+	PlaylistDto(	
+		bool openAccess,			
+		QList<PlaylistUserPermissions> shares,			
+		QStringList itemIds		
+	);
+
+	PlaylistDto(const PlaylistDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PlaylistDto &other);
+	
+	static PlaylistDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets a value indicating whether the playlist is publicly readable.
+	 */
+	bool openAccess() const;
+	/**
+	* @brief Gets or sets a value indicating whether the playlist is publicly readable.
+	*/
+	void setOpenAccess(bool newOpenAccess);
+
+	/**
+	 * @brief Gets or sets the share permissions.
+	 */
+	QList<PlaylistUserPermissions> shares() const;
+	/**
+	* @brief Gets or sets the share permissions.
+	*/
+	void setShares(QList<PlaylistUserPermissions> newShares);
+
+	/**
+	 * @brief Gets or sets the item ids.
+	 */
+	QStringList itemIds() const;
+	/**
+	* @brief Gets or sets the item ids.
+	*/
+	void setItemIds(QStringList newItemIds);
+
+
+protected:
+	bool m_openAccess;
+	QList<PlaylistUserPermissions> m_shares;
+	QStringList m_itemIds;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PlaylistDto::fromJson();
+	PlaylistDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlaylistDto = Jellyfin::DTO::PlaylistDto;
+
+template <>
+PlaylistDto fromJsonValue(const QJsonValue &source, convertType<PlaylistDto>);
+
+template<>
+QJsonValue toJsonValue(const PlaylistDto &source, convertType<PlaylistDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYLISTDTO_H
diff --git a/core/include/JellyfinQt/dto/pluginsecurityinfo.h b/core/include/JellyfinQt/dto/playlistuserpermissions.h
similarity index 62%
rename from core/include/JellyfinQt/dto/pluginsecurityinfo.h
rename to core/include/JellyfinQt/dto/playlistuserpermissions.h
index bb16b69..733ef86 100644
--- a/core/include/JellyfinQt/dto/pluginsecurityinfo.h
+++ b/core/include/JellyfinQt/dto/playlistuserpermissions.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_PLUGINSECURITYINFO_H
-#define JELLYFIN_DTO_PLUGINSECURITYINFO_H
+#ifndef JELLYFIN_DTO_PLAYLISTUSERPERMISSIONS_H
+#define JELLYFIN_DTO_PLAYLISTUSERPERMISSIONS_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -45,52 +45,51 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class PluginSecurityInfo {
+class PlaylistUserPermissions {
 public:
-	PluginSecurityInfo(			
-		bool isMbSupporter		
+	PlaylistUserPermissions(	
+		QString userId,			
+		bool canEdit		
 	);
 
-	PluginSecurityInfo(const PluginSecurityInfo &other);
+	PlaylistUserPermissions(const PlaylistUserPermissions &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(PluginSecurityInfo &other);
+	void replaceData(PlaylistUserPermissions &other);
 	
-	static PluginSecurityInfo fromJson(QJsonObject source);
+	static PlaylistUserPermissions fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the supporter key.
+	 * @brief Gets or sets the user id.
 	 */
-	QString supporterKey() const;
+	QString userId() const;
 	/**
-	* @brief Gets or sets the supporter key.
+	* @brief Gets or sets the user id.
 	*/
-	void setSupporterKey(QString newSupporterKey);
-	bool supporterKeyNull() const;
-	void setSupporterKeyNull();
+	void setUserId(QString newUserId);
 
 	/**
-	 * @brief Gets or sets a value indicating whether is mb supporter.
+	 * @brief Gets or sets a value indicating whether the user has edit permissions.
 	 */
-	bool isMbSupporter() const;
+	bool canEdit() const;
 	/**
-	* @brief Gets or sets a value indicating whether is mb supporter.
+	* @brief Gets or sets a value indicating whether the user has edit permissions.
 	*/
-	void setIsMbSupporter(bool newIsMbSupporter);
+	void setCanEdit(bool newCanEdit);
 
 
 protected:
-	QString m_supporterKey;
-	bool m_isMbSupporter;
+	QString m_userId;
+	bool m_canEdit;
 
 private:
-	// Private constructor which generates an invalid object, for use withing PluginSecurityInfo::fromJson();
-	PluginSecurityInfo();
+	// Private constructor which generates an invalid object, for use withing PlaylistUserPermissions::fromJson();
+	PlaylistUserPermissions();
 };
 
 
@@ -98,15 +97,15 @@ private:
 
 namespace Support {
 
-using PluginSecurityInfo = Jellyfin::DTO::PluginSecurityInfo;
+using PlaylistUserPermissions = Jellyfin::DTO::PlaylistUserPermissions;
 
 template <>
-PluginSecurityInfo fromJsonValue(const QJsonValue &source, convertType<PluginSecurityInfo>);
+PlaylistUserPermissions fromJsonValue(const QJsonValue &source, convertType<PlaylistUserPermissions>);
 
 template<>
-QJsonValue toJsonValue(const PluginSecurityInfo &source, convertType<PluginSecurityInfo>);
+QJsonValue toJsonValue(const PlaylistUserPermissions &source, convertType<PlaylistUserPermissions>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_PLUGINSECURITYINFO_H
+#endif // JELLYFIN_DTO_PLAYLISTUSERPERMISSIONS_H
diff --git a/core/include/JellyfinQt/dto/playmessage.h b/core/include/JellyfinQt/dto/playmessage.h
new file mode 100644
index 0000000..640c755
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLAYMESSAGE_H
+#define JELLYFIN_DTO_PLAYMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/playrequest.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PlayMessage {
+public:
+	PlayMessage(	
+		QSharedPointer<PlayRequest> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PlayMessage(const PlayMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PlayMessage &other);
+	
+	static PlayMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<PlayRequest> data() const;
+
+	void setData(QSharedPointer<PlayRequest> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<PlayRequest> m_data = QSharedPointer<PlayRequest>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PlayMessage::fromJson();
+	PlayMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayMessage = Jellyfin::DTO::PlayMessage;
+
+template <>
+PlayMessage fromJsonValue(const QJsonValue &source, convertType<PlayMessage>);
+
+template<>
+QJsonValue toJsonValue(const PlayMessage &source, convertType<PlayMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/playqueueupdate.h b/core/include/JellyfinQt/dto/playqueueupdate.h
new file mode 100644
index 0000000..c19bf2d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playqueueupdate.h
@@ -0,0 +1,171 @@
+/*
+ * 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_DTO_PLAYQUEUEUPDATE_H
+#define JELLYFIN_DTO_PLAYQUEUEUPDATE_H
+
+#include <QDateTime>
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/grouprepeatmode.h"
+#include "JellyfinQt/dto/groupshufflemode.h"
+#include "JellyfinQt/dto/playqueueupdatereason.h"
+#include "JellyfinQt/dto/syncplayqueueitem.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PlayQueueUpdate {
+public:
+	PlayQueueUpdate(	
+		PlayQueueUpdateReason reason,			
+		QDateTime lastUpdate,			
+		QList<SyncPlayQueueItem> playlist,			
+		qint32 playingItemIndex,			
+		qint64 startPositionTicks,			
+		bool isPlaying,			
+		GroupShuffleMode shuffleMode,			
+		GroupRepeatMode repeatMode		
+	);
+
+	PlayQueueUpdate(const PlayQueueUpdate &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PlayQueueUpdate &other);
+	
+	static PlayQueueUpdate fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	PlayQueueUpdateReason reason() const;
+
+	void setReason(PlayQueueUpdateReason newReason);
+
+	/**
+	 * @brief Gets the UTC time of the last change to the playing queue.
+	 */
+	QDateTime lastUpdate() const;
+	/**
+	* @brief Gets the UTC time of the last change to the playing queue.
+	*/
+	void setLastUpdate(QDateTime newLastUpdate);
+
+	/**
+	 * @brief Gets the playlist.
+	 */
+	QList<SyncPlayQueueItem> playlist() const;
+	/**
+	* @brief Gets the playlist.
+	*/
+	void setPlaylist(QList<SyncPlayQueueItem> newPlaylist);
+
+	/**
+	 * @brief Gets the playing item index in the playlist.
+	 */
+	qint32 playingItemIndex() const;
+	/**
+	* @brief Gets the playing item index in the playlist.
+	*/
+	void setPlayingItemIndex(qint32 newPlayingItemIndex);
+
+	/**
+	 * @brief Gets the start position ticks.
+	 */
+	qint64 startPositionTicks() const;
+	/**
+	* @brief Gets the start position ticks.
+	*/
+	void setStartPositionTicks(qint64 newStartPositionTicks);
+
+	/**
+	 * @brief Gets a value indicating whether the current item is playing.
+	 */
+	bool isPlaying() const;
+	/**
+	* @brief Gets a value indicating whether the current item is playing.
+	*/
+	void setIsPlaying(bool newIsPlaying);
+
+
+	GroupShuffleMode shuffleMode() const;
+
+	void setShuffleMode(GroupShuffleMode newShuffleMode);
+
+
+	GroupRepeatMode repeatMode() const;
+
+	void setRepeatMode(GroupRepeatMode newRepeatMode);
+
+
+protected:
+	PlayQueueUpdateReason m_reason;
+	QDateTime m_lastUpdate;
+	QList<SyncPlayQueueItem> m_playlist;
+	qint32 m_playingItemIndex;
+	qint64 m_startPositionTicks;
+	bool m_isPlaying;
+	GroupShuffleMode m_shuffleMode;
+	GroupRepeatMode m_repeatMode;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PlayQueueUpdate::fromJson();
+	PlayQueueUpdate();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdate = Jellyfin::DTO::PlayQueueUpdate;
+
+template <>
+PlayQueueUpdate fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdate>);
+
+template<>
+QJsonValue toJsonValue(const PlayQueueUpdate &source, convertType<PlayQueueUpdate>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYQUEUEUPDATE_H
diff --git a/core/include/JellyfinQt/dto/playqueueupdategroupupdate.h b/core/include/JellyfinQt/dto/playqueueupdategroupupdate.h
new file mode 100644
index 0000000..67fe6ec
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playqueueupdategroupupdate.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLAYQUEUEUPDATEGROUPUPDATE_H
+#define JELLYFIN_DTO_PLAYQUEUEUPDATEGROUPUPDATE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/groupupdatetype.h"
+#include "JellyfinQt/dto/playqueueupdate.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PlayQueueUpdateGroupUpdate {
+public:
+	PlayQueueUpdateGroupUpdate(	
+		QString groupId,			
+		GroupUpdateType type,			
+		QSharedPointer<PlayQueueUpdate> data		
+	);
+
+	PlayQueueUpdateGroupUpdate(const PlayQueueUpdateGroupUpdate &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PlayQueueUpdateGroupUpdate &other);
+	
+	static PlayQueueUpdateGroupUpdate fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets the group identifier.
+	 */
+	QString groupId() const;
+	/**
+	* @brief Gets the group identifier.
+	*/
+	void setGroupId(QString newGroupId);
+
+
+	GroupUpdateType type() const;
+
+	void setType(GroupUpdateType newType);
+
+
+	QSharedPointer<PlayQueueUpdate> data() const;
+
+	void setData(QSharedPointer<PlayQueueUpdate> newData);
+
+
+protected:
+	QString m_groupId;
+	GroupUpdateType m_type;
+	QSharedPointer<PlayQueueUpdate> m_data = QSharedPointer<PlayQueueUpdate>();
+
+private:
+	// Private constructor which generates an invalid object, for use withing PlayQueueUpdateGroupUpdate::fromJson();
+	PlayQueueUpdateGroupUpdate();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdateGroupUpdate = Jellyfin::DTO::PlayQueueUpdateGroupUpdate;
+
+template <>
+PlayQueueUpdateGroupUpdate fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdateGroupUpdate>);
+
+template<>
+QJsonValue toJsonValue(const PlayQueueUpdateGroupUpdate &source, convertType<PlayQueueUpdateGroupUpdate>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYQUEUEUPDATEGROUPUPDATE_H
diff --git a/core/include/JellyfinQt/dto/playqueueupdatereason.h b/core/include/JellyfinQt/dto/playqueueupdatereason.h
new file mode 100644
index 0000000..4005d05
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playqueueupdatereason.h
@@ -0,0 +1,84 @@
+/*
+ * 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_DTO_PLAYQUEUEUPDATEREASON_H
+#define JELLYFIN_DTO_PLAYQUEUEUPDATEREASON_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class PlayQueueUpdateReasonClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		NewPlaylist,
+		SetCurrentItem,
+		RemoveItems,
+		MoveItem,
+		Queue,
+		QueueNext,
+		NextItem,
+		PreviousItem,
+		RepeatMode,
+		ShuffleMode,
+	};
+	Q_ENUM(Value)
+private:
+	explicit PlayQueueUpdateReasonClass();
+};
+
+using PlayQueueUpdateReason = PlayQueueUpdateReasonClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdateReason = Jellyfin::DTO::PlayQueueUpdateReason;
+
+template <>
+PlayQueueUpdateReason fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdateReason>);
+
+template <>
+QJsonValue toJsonValue(const PlayQueueUpdateReason &source, convertType<PlayQueueUpdateReason>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYQUEUEUPDATEREASON_H
diff --git a/core/include/JellyfinQt/dto/playrequestdto.h b/core/include/JellyfinQt/dto/playrequestdto.h
index 9387f04..093479c 100644
--- a/core/include/JellyfinQt/dto/playrequestdto.h
+++ b/core/include/JellyfinQt/dto/playrequestdto.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class PlayRequestDto {
 public:
-	PlayRequestDto(			
+	PlayRequestDto(	
+		QStringList playingQueue,			
 		qint32 playingItemPosition,			
 		qint64 startPositionTicks		
 	);
@@ -74,8 +75,6 @@ public:
 	* @brief Gets or sets the playing queue.
 	*/
 	void setPlayingQueue(QStringList newPlayingQueue);
-	bool playingQueueNull() const;
-	void setPlayingQueueNull();
 
 	/**
 	 * @brief Gets or sets the position of the playing item in the queue.
diff --git a/core/include/JellyfinQt/dto/playstatemessage.h b/core/include/JellyfinQt/dto/playstatemessage.h
new file mode 100644
index 0000000..fe8c0f3
--- /dev/null
+++ b/core/include/JellyfinQt/dto/playstatemessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLAYSTATEMESSAGE_H
+#define JELLYFIN_DTO_PLAYSTATEMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/playstaterequest.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PlaystateMessage {
+public:
+	PlaystateMessage(	
+		QSharedPointer<PlaystateRequest> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PlaystateMessage(const PlaystateMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PlaystateMessage &other);
+	
+	static PlaystateMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<PlaystateRequest> data() const;
+
+	void setData(QSharedPointer<PlaystateRequest> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<PlaystateRequest> m_data = QSharedPointer<PlaystateRequest>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PlaystateMessage::fromJson();
+	PlaystateMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlaystateMessage = Jellyfin::DTO::PlaystateMessage;
+
+template <>
+PlaystateMessage fromJsonValue(const QJsonValue &source, convertType<PlaystateMessage>);
+
+template<>
+QJsonValue toJsonValue(const PlaystateMessage &source, convertType<PlaystateMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLAYSTATEMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/plugininfo.h b/core/include/JellyfinQt/dto/plugininfo.h
index d8aea0c..40fea46 100644
--- a/core/include/JellyfinQt/dto/plugininfo.h
+++ b/core/include/JellyfinQt/dto/plugininfo.h
@@ -32,12 +32,10 @@
 
 #include <QJsonObject>
 #include <QJsonValue>
-#include <QSharedPointer>
 #include <QString>
 #include <optional>
 
 #include "JellyfinQt/dto/pluginstatus.h"
-#include "JellyfinQt/dto/version.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -50,8 +48,10 @@ namespace DTO {
 
 class PluginInfo {
 public:
-	PluginInfo(			
-		QSharedPointer<Version> version,							
+	PluginInfo(	
+		QString name,			
+		QString version,					
+		QString description,			
 		QString jellyfinId,			
 		bool canUninstall,			
 		bool hasImage,			
@@ -78,13 +78,15 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
-
-	QSharedPointer<Version> version() const;
-
-	void setVersion(QSharedPointer<Version> newVersion);
+	/**
+	 * @brief Gets or sets the version.
+	 */
+	QString version() const;
+	/**
+	* @brief Gets or sets the version.
+	*/
+	void setVersion(QString newVersion);
 
 	/**
 	 * @brief Gets or sets the name of the configuration file.
@@ -105,8 +107,6 @@ public:
 	* @brief Gets or sets the description.
 	*/
 	void setDescription(QString newDescription);
-	bool descriptionNull() const;
-	void setDescriptionNull();
 
 	/**
 	 * @brief Gets or sets the unique id.
@@ -143,7 +143,7 @@ public:
 
 protected:
 	QString m_name;
-	QSharedPointer<Version> m_version = QSharedPointer<Version>();
+	QString m_version;
 	QString m_configurationFileName;
 	QString m_description;
 	QString m_jellyfinId;
diff --git a/core/include/JellyfinQt/dto/plugininstallationcancelledmessage.h b/core/include/JellyfinQt/dto/plugininstallationcancelledmessage.h
new file mode 100644
index 0000000..50c47e9
--- /dev/null
+++ b/core/include/JellyfinQt/dto/plugininstallationcancelledmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLUGININSTALLATIONCANCELLEDMESSAGE_H
+#define JELLYFIN_DTO_PLUGININSTALLATIONCANCELLEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/installationinfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PluginInstallationCancelledMessage {
+public:
+	PluginInstallationCancelledMessage(	
+		QSharedPointer<InstallationInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PluginInstallationCancelledMessage(const PluginInstallationCancelledMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PluginInstallationCancelledMessage &other);
+	
+	static PluginInstallationCancelledMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<InstallationInfo> data() const;
+
+	void setData(QSharedPointer<InstallationInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<InstallationInfo> m_data = QSharedPointer<InstallationInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PluginInstallationCancelledMessage::fromJson();
+	PluginInstallationCancelledMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationCancelledMessage = Jellyfin::DTO::PluginInstallationCancelledMessage;
+
+template <>
+PluginInstallationCancelledMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationCancelledMessage>);
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationCancelledMessage &source, convertType<PluginInstallationCancelledMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLUGININSTALLATIONCANCELLEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/plugininstallationcompletedmessage.h b/core/include/JellyfinQt/dto/plugininstallationcompletedmessage.h
new file mode 100644
index 0000000..97c7204
--- /dev/null
+++ b/core/include/JellyfinQt/dto/plugininstallationcompletedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLUGININSTALLATIONCOMPLETEDMESSAGE_H
+#define JELLYFIN_DTO_PLUGININSTALLATIONCOMPLETEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/installationinfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PluginInstallationCompletedMessage {
+public:
+	PluginInstallationCompletedMessage(	
+		QSharedPointer<InstallationInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PluginInstallationCompletedMessage(const PluginInstallationCompletedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PluginInstallationCompletedMessage &other);
+	
+	static PluginInstallationCompletedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<InstallationInfo> data() const;
+
+	void setData(QSharedPointer<InstallationInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<InstallationInfo> m_data = QSharedPointer<InstallationInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PluginInstallationCompletedMessage::fromJson();
+	PluginInstallationCompletedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationCompletedMessage = Jellyfin::DTO::PluginInstallationCompletedMessage;
+
+template <>
+PluginInstallationCompletedMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationCompletedMessage>);
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationCompletedMessage &source, convertType<PluginInstallationCompletedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLUGININSTALLATIONCOMPLETEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/plugininstallationfailedmessage.h b/core/include/JellyfinQt/dto/plugininstallationfailedmessage.h
new file mode 100644
index 0000000..3a6d15d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/plugininstallationfailedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLUGININSTALLATIONFAILEDMESSAGE_H
+#define JELLYFIN_DTO_PLUGININSTALLATIONFAILEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/installationinfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PluginInstallationFailedMessage {
+public:
+	PluginInstallationFailedMessage(	
+		QSharedPointer<InstallationInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PluginInstallationFailedMessage(const PluginInstallationFailedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PluginInstallationFailedMessage &other);
+	
+	static PluginInstallationFailedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<InstallationInfo> data() const;
+
+	void setData(QSharedPointer<InstallationInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<InstallationInfo> m_data = QSharedPointer<InstallationInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PluginInstallationFailedMessage::fromJson();
+	PluginInstallationFailedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationFailedMessage = Jellyfin::DTO::PluginInstallationFailedMessage;
+
+template <>
+PluginInstallationFailedMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationFailedMessage>);
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationFailedMessage &source, convertType<PluginInstallationFailedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLUGININSTALLATIONFAILEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/plugininstallingmessage.h b/core/include/JellyfinQt/dto/plugininstallingmessage.h
new file mode 100644
index 0000000..7fffeea
--- /dev/null
+++ b/core/include/JellyfinQt/dto/plugininstallingmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLUGININSTALLINGMESSAGE_H
+#define JELLYFIN_DTO_PLUGININSTALLINGMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/installationinfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PluginInstallingMessage {
+public:
+	PluginInstallingMessage(	
+		QSharedPointer<InstallationInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PluginInstallingMessage(const PluginInstallingMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PluginInstallingMessage &other);
+	
+	static PluginInstallingMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<InstallationInfo> data() const;
+
+	void setData(QSharedPointer<InstallationInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<InstallationInfo> m_data = QSharedPointer<InstallationInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PluginInstallingMessage::fromJson();
+	PluginInstallingMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallingMessage = Jellyfin::DTO::PluginInstallingMessage;
+
+template <>
+PluginInstallingMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallingMessage>);
+
+template<>
+QJsonValue toJsonValue(const PluginInstallingMessage &source, convertType<PluginInstallingMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLUGININSTALLINGMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/pluginuninstalledmessage.h b/core/include/JellyfinQt/dto/pluginuninstalledmessage.h
new file mode 100644
index 0000000..ba6f7c7
--- /dev/null
+++ b/core/include/JellyfinQt/dto/pluginuninstalledmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_PLUGINUNINSTALLEDMESSAGE_H
+#define JELLYFIN_DTO_PLUGINUNINSTALLEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/plugininfo.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class PluginUninstalledMessage {
+public:
+	PluginUninstalledMessage(	
+		QSharedPointer<PluginInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	PluginUninstalledMessage(const PluginUninstalledMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(PluginUninstalledMessage &other);
+	
+	static PluginUninstalledMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<PluginInfo> data() const;
+
+	void setData(QSharedPointer<PluginInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<PluginInfo> m_data = QSharedPointer<PluginInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing PluginUninstalledMessage::fromJson();
+	PluginUninstalledMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginUninstalledMessage = Jellyfin::DTO::PluginUninstalledMessage;
+
+template <>
+PluginUninstalledMessage fromJsonValue(const QJsonValue &source, convertType<PluginUninstalledMessage>);
+
+template<>
+QJsonValue toJsonValue(const PluginUninstalledMessage &source, convertType<PluginUninstalledMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_PLUGINUNINSTALLEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/notificationlevel.h b/core/include/JellyfinQt/dto/processpriorityclass.h
similarity index 74%
rename from core/include/JellyfinQt/dto/notificationlevel.h
rename to core/include/JellyfinQt/dto/processpriorityclass.h
index 1166ca7..f058fd2 100644
--- a/core/include/JellyfinQt/dto/notificationlevel.h
+++ b/core/include/JellyfinQt/dto/processpriorityclass.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_NOTIFICATIONLEVEL_H
-#define JELLYFIN_DTO_NOTIFICATIONLEVEL_H
+#ifndef JELLYFIN_DTO_PROCESSPRIORITYCLASS_H
+#define JELLYFIN_DTO_PROCESSPRIORITYCLASS_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,35 +43,38 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class NotificationLevelClass {
+class ProcessPriorityClassClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
 		Normal,
-		Warning,
-		Error,
+		Idle,
+		High,
+		RealTime,
+		BelowNormal,
+		AboveNormal,
 	};
 	Q_ENUM(Value)
 private:
-	explicit NotificationLevelClass();
+	explicit ProcessPriorityClassClass();
 };
 
-using NotificationLevel = NotificationLevelClass::Value;
+using ProcessPriorityClass = ProcessPriorityClassClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using NotificationLevel = Jellyfin::DTO::NotificationLevel;
+using ProcessPriorityClass = Jellyfin::DTO::ProcessPriorityClass;
 
 template <>
-NotificationLevel fromJsonValue(const QJsonValue &source, convertType<NotificationLevel>);
+ProcessPriorityClass fromJsonValue(const QJsonValue &source, convertType<ProcessPriorityClass>);
 
 template <>
-QJsonValue toJsonValue(const NotificationLevel &source, convertType<NotificationLevel>);
+QJsonValue toJsonValue(const ProcessPriorityClass &source, convertType<ProcessPriorityClass>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_NOTIFICATIONLEVEL_H
+#endif // JELLYFIN_DTO_PROCESSPRIORITYCLASS_H
diff --git a/core/include/JellyfinQt/dto/profileconditionvalue.h b/core/include/JellyfinQt/dto/profileconditionvalue.h
index fd8212a..4e8a2a1 100644
--- a/core/include/JellyfinQt/dto/profileconditionvalue.h
+++ b/core/include/JellyfinQt/dto/profileconditionvalue.h
@@ -71,6 +71,7 @@ public:
 		IsInterlaced,
 		AudioSampleRate,
 		AudioBitDepth,
+		VideoRangeType,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/queuerequestdto.h b/core/include/JellyfinQt/dto/queuerequestdto.h
index 776b8e8..b3154f1 100644
--- a/core/include/JellyfinQt/dto/queuerequestdto.h
+++ b/core/include/JellyfinQt/dto/queuerequestdto.h
@@ -50,7 +50,8 @@ namespace DTO {
 
 class QueueRequestDto {
 public:
-	QueueRequestDto(			
+	QueueRequestDto(	
+		QStringList itemIds,			
 		GroupQueueMode mode		
 	);
 
@@ -74,8 +75,6 @@ public:
 	* @brief Gets or sets the items to enqueue.
 	*/
 	void setItemIds(QStringList newItemIds);
-	bool itemIdsNull() const;
-	void setItemIdsNull();
 
 
 	GroupQueueMode mode() const;
diff --git a/core/include/JellyfinQt/dto/quickconnectdto.h b/core/include/JellyfinQt/dto/quickconnectdto.h
index 9f10db0..74a4696 100644
--- a/core/include/JellyfinQt/dto/quickconnectdto.h
+++ b/core/include/JellyfinQt/dto/quickconnectdto.h
@@ -48,7 +48,7 @@ namespace DTO {
 class QuickConnectDto {
 public:
 	QuickConnectDto(	
-		QString token		
+		QString secret		
 	);
 
 	QuickConnectDto(const QuickConnectDto &other);
@@ -64,17 +64,17 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the quick connect token.
+	 * @brief Gets or sets the quick connect secret.
 	 */
-	QString token() const;
+	QString secret() const;
 	/**
-	* @brief Gets or sets the quick connect token.
+	* @brief Gets or sets the quick connect secret.
 	*/
-	void setToken(QString newToken);
+	void setSecret(QString newSecret);
 
 
 protected:
-	QString m_token;
+	QString m_secret;
 
 private:
 	// Private constructor which generates an invalid object, for use withing QuickConnectDto::fromJson();
diff --git a/core/include/JellyfinQt/dto/quickconnectresult.h b/core/include/JellyfinQt/dto/quickconnectresult.h
index b16f466..7740b31 100644
--- a/core/include/JellyfinQt/dto/quickconnectresult.h
+++ b/core/include/JellyfinQt/dto/quickconnectresult.h
@@ -49,7 +49,14 @@ namespace DTO {
 class QuickConnectResult {
 public:
 	QuickConnectResult(	
-		bool authenticated												
+		bool authenticated,			
+		QString secret,			
+		QString code,			
+		QString deviceId,			
+		QString deviceName,			
+		QString appName,			
+		QString appVersion,			
+		QDateTime dateAdded		
 	);
 
 	QuickConnectResult(const QuickConnectResult &other);
@@ -65,57 +72,67 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Gets a value indicating whether this request is authorized.
+	 * @brief Gets or sets a value indicating whether this request is authorized.
 	 */
 	bool authenticated() const;
 	/**
-	* @brief Gets a value indicating whether this request is authorized.
+	* @brief Gets or sets a value indicating whether this request is authorized.
 	*/
 	void setAuthenticated(bool newAuthenticated);
 
 	/**
-	 * @brief Gets or sets the secret value used to uniquely identify this request. Can be used to retrieve authentication information.
+	 * @brief Gets the secret value used to uniquely identify this request. Can be used to retrieve authentication information.
 	 */
 	QString secret() const;
 	/**
-	* @brief Gets or sets the secret value used to uniquely identify this request. Can be used to retrieve authentication information.
+	* @brief Gets the secret value used to uniquely identify this request. Can be used to retrieve authentication information.
 	*/
 	void setSecret(QString newSecret);
-	bool secretNull() const;
-	void setSecretNull();
 
 	/**
-	 * @brief Gets or sets the user facing code used so the user can quickly differentiate this request from others.
+	 * @brief Gets the user facing code used so the user can quickly differentiate this request from others.
 	 */
 	QString code() const;
 	/**
-	* @brief Gets or sets the user facing code used so the user can quickly differentiate this request from others.
+	* @brief Gets the user facing code used so the user can quickly differentiate this request from others.
 	*/
 	void setCode(QString newCode);
-	bool codeNull() const;
-	void setCodeNull();
 
 	/**
-	 * @brief Gets or sets the private access token.
+	 * @brief Gets the requesting device id.
 	 */
-	QString authentication() const;
+	QString deviceId() const;
 	/**
-	* @brief Gets or sets the private access token.
+	* @brief Gets the requesting device id.
 	*/
-	void setAuthentication(QString newAuthentication);
-	bool authenticationNull() const;
-	void setAuthenticationNull();
+	void setDeviceId(QString newDeviceId);
 
 	/**
-	 * @brief Gets or sets an error message.
+	 * @brief Gets the requesting device name.
 	 */
-	QString error() const;
+	QString deviceName() const;
 	/**
-	* @brief Gets or sets an error message.
+	* @brief Gets the requesting device name.
 	*/
-	void setError(QString newError);
-	bool errorNull() const;
-	void setErrorNull();
+	void setDeviceName(QString newDeviceName);
+
+	/**
+	 * @brief Gets the requesting app name.
+	 */
+	QString appName() const;
+	/**
+	* @brief Gets the requesting app name.
+	*/
+	void setAppName(QString newAppName);
+
+	/**
+	 * @brief Gets the requesting app version.
+	 */
+	QString appVersion() const;
+	/**
+	* @brief Gets the requesting app version.
+	*/
+	void setAppVersion(QString newAppVersion);
 
 	/**
 	 * @brief Gets or sets the DateTime that this request was created.
@@ -125,16 +142,16 @@ public:
 	* @brief Gets or sets the DateTime that this request was created.
 	*/
 	void setDateAdded(QDateTime newDateAdded);
-	bool dateAddedNull() const;
-	void setDateAddedNull();
 
 
 protected:
 	bool m_authenticated;
 	QString m_secret;
 	QString m_code;
-	QString m_authentication;
-	QString m_error;
+	QString m_deviceId;
+	QString m_deviceName;
+	QString m_appName;
+	QString m_appVersion;
 	QDateTime m_dateAdded;
 
 private:
diff --git a/core/include/JellyfinQt/dto/quickconnectstate.h b/core/include/JellyfinQt/dto/quickconnectstate.h
deleted file mode 100644
index 5ff17f8..0000000
--- a/core/include/JellyfinQt/dto/quickconnectstate.h
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * 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_DTO_QUICKCONNECTSTATE_H
-#define JELLYFIN_DTO_QUICKCONNECTSTATE_H
-
-#include <QJsonValue>
-#include <QObject>
-#include <QString>
-
-#include "JellyfinQt/support/jsonconv.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace DTO {
-
-class QuickConnectStateClass {
-	Q_GADGET
-public:
-	enum Value {
-		EnumNotSet,
-		Unavailable,
-		Available,
-		Active,
-	};
-	Q_ENUM(Value)
-private:
-	explicit QuickConnectStateClass();
-};
-
-using QuickConnectState = QuickConnectStateClass::Value;
-
-} // NS DTO
-
-namespace Support {
-
-using QuickConnectState = Jellyfin::DTO::QuickConnectState;
-
-template <>
-QuickConnectState fromJsonValue(const QJsonValue &source, convertType<QuickConnectState>);
-
-template <>
-QJsonValue toJsonValue(const QuickConnectState &source, convertType<QuickConnectState>);
-
-} // NS DTO
-} // NS Jellyfin
-
-#endif // JELLYFIN_DTO_QUICKCONNECTSTATE_H
diff --git a/core/include/JellyfinQt/dto/refreshprogressmessage.h b/core/include/JellyfinQt/dto/refreshprogressmessage.h
new file mode 100644
index 0000000..c343bf3
--- /dev/null
+++ b/core/include/JellyfinQt/dto/refreshprogressmessage.h
@@ -0,0 +1,120 @@
+/*
+ * 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_DTO_REFRESHPROGRESSMESSAGE_H
+#define JELLYFIN_DTO_REFRESHPROGRESSMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class RefreshProgressMessage {
+public:
+	RefreshProgressMessage(			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	RefreshProgressMessage(const RefreshProgressMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(RefreshProgressMessage &other);
+	
+	static RefreshProgressMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QJsonObject data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QJsonObject newData);
+	bool dataNull() const;
+	void setDataNull();
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QJsonObject m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing RefreshProgressMessage::fromJson();
+	RefreshProgressMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using RefreshProgressMessage = Jellyfin::DTO::RefreshProgressMessage;
+
+template <>
+RefreshProgressMessage fromJsonValue(const QJsonValue &source, convertType<RefreshProgressMessage>);
+
+template<>
+QJsonValue toJsonValue(const RefreshProgressMessage &source, convertType<RefreshProgressMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_REFRESHPROGRESSMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/remoteimageinfo.h b/core/include/JellyfinQt/dto/remoteimageinfo.h
index 9c65b32..d19856e 100644
--- a/core/include/JellyfinQt/dto/remoteimageinfo.h
+++ b/core/include/JellyfinQt/dto/remoteimageinfo.h
@@ -89,11 +89,11 @@ public:
 	void setUrlNull();
 
 	/**
-	 * @brief Gets a url used for previewing a smaller version.
+	 * @brief Gets or sets a url used for previewing a smaller version.
 	 */
 	QString thumbnailUrl() const;
 	/**
-	* @brief Gets a url used for previewing a smaller version.
+	* @brief Gets or sets a url used for previewing a smaller version.
 	*/
 	void setThumbnailUrl(QString newThumbnailUrl);
 	bool thumbnailUrlNull() const;
diff --git a/core/include/JellyfinQt/dto/remotelyricinfodto.h b/core/include/JellyfinQt/dto/remotelyricinfodto.h
new file mode 100644
index 0000000..e7fd5df
--- /dev/null
+++ b/core/include/JellyfinQt/dto/remotelyricinfodto.h
@@ -0,0 +1,120 @@
+/*
+ * 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_DTO_REMOTELYRICINFODTO_H
+#define JELLYFIN_DTO_REMOTELYRICINFODTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/lyricdto.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class RemoteLyricInfoDto {
+public:
+	RemoteLyricInfoDto(	
+		QString jellyfinId,			
+		QString providerName,			
+		QSharedPointer<LyricDto> lyrics		
+	);
+
+	RemoteLyricInfoDto(const RemoteLyricInfoDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(RemoteLyricInfoDto &other);
+	
+	static RemoteLyricInfoDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the id for the lyric.
+	 */
+	QString jellyfinId() const;
+	/**
+	* @brief Gets or sets the id for the lyric.
+	*/
+	void setJellyfinId(QString newJellyfinId);
+
+	/**
+	 * @brief Gets the provider name.
+	 */
+	QString providerName() const;
+	/**
+	* @brief Gets the provider name.
+	*/
+	void setProviderName(QString newProviderName);
+
+
+	QSharedPointer<LyricDto> lyrics() const;
+
+	void setLyrics(QSharedPointer<LyricDto> newLyrics);
+
+
+protected:
+	QString m_jellyfinId;
+	QString m_providerName;
+	QSharedPointer<LyricDto> m_lyrics = QSharedPointer<LyricDto>();
+
+private:
+	// Private constructor which generates an invalid object, for use withing RemoteLyricInfoDto::fromJson();
+	RemoteLyricInfoDto();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using RemoteLyricInfoDto = Jellyfin::DTO::RemoteLyricInfoDto;
+
+template <>
+RemoteLyricInfoDto fromJsonValue(const QJsonValue &source, convertType<RemoteLyricInfoDto>);
+
+template<>
+QJsonValue toJsonValue(const RemoteLyricInfoDto &source, convertType<RemoteLyricInfoDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_REMOTELYRICINFODTO_H
diff --git a/core/include/JellyfinQt/dto/remotesubtitleinfo.h b/core/include/JellyfinQt/dto/remotesubtitleinfo.h
index 87ba9db..993473f 100644
--- a/core/include/JellyfinQt/dto/remotesubtitleinfo.h
+++ b/core/include/JellyfinQt/dto/remotesubtitleinfo.h
@@ -124,6 +124,13 @@ public:	RemoteSubtitleInfo();
 	void setCommunityRatingNull();
 
 
+	std::optional<float> frameRate() const;
+
+	void setFrameRate(std::optional<float> newFrameRate);
+	bool frameRateNull() const;
+	void setFrameRateNull();
+
+
 	std::optional<qint32> downloadCount() const;
 
 	void setDownloadCount(std::optional<qint32> newDownloadCount);
@@ -138,6 +145,34 @@ public:	RemoteSubtitleInfo();
 	void setIsHashMatchNull();
 
 
+	std::optional<bool> aiTranslated() const;
+
+	void setAiTranslated(std::optional<bool> newAiTranslated);
+	bool aiTranslatedNull() const;
+	void setAiTranslatedNull();
+
+
+	std::optional<bool> machineTranslated() const;
+
+	void setMachineTranslated(std::optional<bool> newMachineTranslated);
+	bool machineTranslatedNull() const;
+	void setMachineTranslatedNull();
+
+
+	std::optional<bool> forced() const;
+
+	void setForced(std::optional<bool> newForced);
+	bool forcedNull() const;
+	void setForcedNull();
+
+
+	std::optional<bool> hearingImpaired() const;
+
+	void setHearingImpaired(std::optional<bool> newHearingImpaired);
+	bool hearingImpairedNull() const;
+	void setHearingImpairedNull();
+
+
 protected:
 	QString m_threeLetterISOLanguageName;
 	QString m_jellyfinId;
@@ -148,8 +183,13 @@ protected:
 	QString m_comment;
 	QDateTime m_dateCreated;
 	std::optional<float> m_communityRating = std::nullopt;
+	std::optional<float> m_frameRate = std::nullopt;
 	std::optional<qint32> m_downloadCount = std::nullopt;
 	std::optional<bool> m_isHashMatch = std::nullopt;
+	std::optional<bool> m_aiTranslated = std::nullopt;
+	std::optional<bool> m_machineTranslated = std::nullopt;
+	std::optional<bool> m_forced = std::nullopt;
+	std::optional<bool> m_hearingImpaired = std::nullopt;
 
 
 };
diff --git a/core/include/JellyfinQt/dto/removefromplaylistrequestdto.h b/core/include/JellyfinQt/dto/removefromplaylistrequestdto.h
index 6fc47c8..c01f74d 100644
--- a/core/include/JellyfinQt/dto/removefromplaylistrequestdto.h
+++ b/core/include/JellyfinQt/dto/removefromplaylistrequestdto.h
@@ -48,7 +48,13 @@ namespace DTO {
 
 
 class RemoveFromPlaylistRequestDto {
-public:	RemoveFromPlaylistRequestDto();
+public:
+	RemoveFromPlaylistRequestDto(	
+		QStringList playlistItemIds,			
+		bool clearPlaylist,			
+		bool clearPlayingItem		
+	);
+
 	RemoveFromPlaylistRequestDto(const RemoveFromPlaylistRequestDto &other);
 	
 	/**
@@ -62,21 +68,41 @@ public:	RemoveFromPlaylistRequestDto();
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the playlist identifiers ot the items.
+	 * @brief Gets or sets the playlist identifiers of the items. Ignored when clearing the playlist.
 	 */
 	QStringList playlistItemIds() const;
 	/**
-	* @brief Gets or sets the playlist identifiers ot the items.
+	* @brief Gets or sets the playlist identifiers of the items. Ignored when clearing the playlist.
 	*/
 	void setPlaylistItemIds(QStringList newPlaylistItemIds);
-	bool playlistItemIdsNull() const;
-	void setPlaylistItemIdsNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether the entire playlist should be cleared.
+	 */
+	bool clearPlaylist() const;
+	/**
+	* @brief Gets or sets a value indicating whether the entire playlist should be cleared.
+	*/
+	void setClearPlaylist(bool newClearPlaylist);
+
+	/**
+	 * @brief Gets or sets a value indicating whether the playing item should be removed as well. Used only when clearing the playlist.
+	 */
+	bool clearPlayingItem() const;
+	/**
+	* @brief Gets or sets a value indicating whether the playing item should be removed as well. Used only when clearing the playlist.
+	*/
+	void setClearPlayingItem(bool newClearPlayingItem);
 
 
 protected:
 	QStringList m_playlistItemIds;
+	bool m_clearPlaylist;
+	bool m_clearPlayingItem;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing RemoveFromPlaylistRequestDto::fromJson();
+	RemoveFromPlaylistRequestDto();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/restartrequiredmessage.h b/core/include/JellyfinQt/dto/restartrequiredmessage.h
new file mode 100644
index 0000000..784eb66
--- /dev/null
+++ b/core/include/JellyfinQt/dto/restartrequiredmessage.h
@@ -0,0 +1,108 @@
+/*
+ * 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_DTO_RESTARTREQUIREDMESSAGE_H
+#define JELLYFIN_DTO_RESTARTREQUIREDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class RestartRequiredMessage {
+public:
+	RestartRequiredMessage(	
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	RestartRequiredMessage(const RestartRequiredMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(RestartRequiredMessage &other);
+	
+	static RestartRequiredMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing RestartRequiredMessage::fromJson();
+	RestartRequiredMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using RestartRequiredMessage = Jellyfin::DTO::RestartRequiredMessage;
+
+template <>
+RestartRequiredMessage fromJsonValue(const QJsonValue &source, convertType<RestartRequiredMessage>);
+
+template<>
+QJsonValue toJsonValue(const RestartRequiredMessage &source, convertType<RestartRequiredMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_RESTARTREQUIREDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/scheduledtaskendedmessage.h b/core/include/JellyfinQt/dto/scheduledtaskendedmessage.h
new file mode 100644
index 0000000..7275271
--- /dev/null
+++ b/core/include/JellyfinQt/dto/scheduledtaskendedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_SCHEDULEDTASKENDEDMESSAGE_H
+#define JELLYFIN_DTO_SCHEDULEDTASKENDEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/taskresult.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ScheduledTaskEndedMessage {
+public:
+	ScheduledTaskEndedMessage(	
+		QSharedPointer<TaskResult> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ScheduledTaskEndedMessage(const ScheduledTaskEndedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ScheduledTaskEndedMessage &other);
+	
+	static ScheduledTaskEndedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<TaskResult> data() const;
+
+	void setData(QSharedPointer<TaskResult> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<TaskResult> m_data = QSharedPointer<TaskResult>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ScheduledTaskEndedMessage::fromJson();
+	ScheduledTaskEndedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTaskEndedMessage = Jellyfin::DTO::ScheduledTaskEndedMessage;
+
+template <>
+ScheduledTaskEndedMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTaskEndedMessage>);
+
+template<>
+QJsonValue toJsonValue(const ScheduledTaskEndedMessage &source, convertType<ScheduledTaskEndedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SCHEDULEDTASKENDEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/scheduledtasksinfomessage.h b/core/include/JellyfinQt/dto/scheduledtasksinfomessage.h
new file mode 100644
index 0000000..6627e4e
--- /dev/null
+++ b/core/include/JellyfinQt/dto/scheduledtasksinfomessage.h
@@ -0,0 +1,123 @@
+/*
+ * 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_DTO_SCHEDULEDTASKSINFOMESSAGE_H
+#define JELLYFIN_DTO_SCHEDULEDTASKSINFOMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/taskinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ScheduledTasksInfoMessage {
+public:
+	ScheduledTasksInfoMessage(			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ScheduledTasksInfoMessage(const ScheduledTasksInfoMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ScheduledTasksInfoMessage &other);
+	
+	static ScheduledTasksInfoMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QList<TaskInfo> data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QList<TaskInfo> newData);
+	bool dataNull() const;
+	void setDataNull();
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QList<TaskInfo> m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ScheduledTasksInfoMessage::fromJson();
+	ScheduledTasksInfoMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoMessage = Jellyfin::DTO::ScheduledTasksInfoMessage;
+
+template <>
+ScheduledTasksInfoMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoMessage>);
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoMessage &source, convertType<ScheduledTasksInfoMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SCHEDULEDTASKSINFOMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/scheduledtasksinfostartmessage.h b/core/include/JellyfinQt/dto/scheduledtasksinfostartmessage.h
new file mode 100644
index 0000000..ef69b9f
--- /dev/null
+++ b/core/include/JellyfinQt/dto/scheduledtasksinfostartmessage.h
@@ -0,0 +1,109 @@
+/*
+ * 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_DTO_SCHEDULEDTASKSINFOSTARTMESSAGE_H
+#define JELLYFIN_DTO_SCHEDULEDTASKSINFOSTARTMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ScheduledTasksInfoStartMessage {
+public:
+	ScheduledTasksInfoStartMessage(			
+		SessionMessageType messageType		
+	);
+
+	ScheduledTasksInfoStartMessage(const ScheduledTasksInfoStartMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ScheduledTasksInfoStartMessage &other);
+	
+	static ScheduledTasksInfoStartMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QString data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QString newData);
+	bool dataNull() const;
+	void setDataNull();
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_data;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ScheduledTasksInfoStartMessage::fromJson();
+	ScheduledTasksInfoStartMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoStartMessage = Jellyfin::DTO::ScheduledTasksInfoStartMessage;
+
+template <>
+ScheduledTasksInfoStartMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoStartMessage>);
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoStartMessage &source, convertType<ScheduledTasksInfoStartMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SCHEDULEDTASKSINFOSTARTMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/scheduledtasksinfostopmessage.h b/core/include/JellyfinQt/dto/scheduledtasksinfostopmessage.h
new file mode 100644
index 0000000..87902a0
--- /dev/null
+++ b/core/include/JellyfinQt/dto/scheduledtasksinfostopmessage.h
@@ -0,0 +1,96 @@
+/*
+ * 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_DTO_SCHEDULEDTASKSINFOSTOPMESSAGE_H
+#define JELLYFIN_DTO_SCHEDULEDTASKSINFOSTOPMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ScheduledTasksInfoStopMessage {
+public:
+	ScheduledTasksInfoStopMessage(	
+		SessionMessageType messageType		
+	);
+
+	ScheduledTasksInfoStopMessage(const ScheduledTasksInfoStopMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ScheduledTasksInfoStopMessage &other);
+	
+	static ScheduledTasksInfoStopMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ScheduledTasksInfoStopMessage::fromJson();
+	ScheduledTasksInfoStopMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoStopMessage = Jellyfin::DTO::ScheduledTasksInfoStopMessage;
+
+template <>
+ScheduledTasksInfoStopMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoStopMessage>);
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoStopMessage &source, convertType<ScheduledTasksInfoStopMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SCHEDULEDTASKSINFOSTOPMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/searchhint.h b/core/include/JellyfinQt/dto/searchhint.h
index 98330d4..42c2a0e 100644
--- a/core/include/JellyfinQt/dto/searchhint.h
+++ b/core/include/JellyfinQt/dto/searchhint.h
@@ -38,6 +38,8 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/baseitemkind.h"
+#include "JellyfinQt/dto/mediatype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -52,9 +54,11 @@ class SearchHint {
 public:
 	SearchHint(	
 		QString itemId,			
-		QString jellyfinId,																																									
-		QString albumId,											
-		QString channelId						
+		QString jellyfinId,			
+		QString name,																					
+		BaseItemKind type,							
+		MediaType mediaType,																	
+		QStringList artists												
 	);
 
 	SearchHint(const SearchHint &other);
@@ -78,9 +82,13 @@ public:
 	*/
 	void setItemId(QString newItemId);
 
-
+	/**
+	 * @brief Gets or sets the item id.
+	 */
 	QString jellyfinId() const;
-
+	/**
+	* @brief Gets or sets the item id.
+	*/
 	void setJellyfinId(QString newJellyfinId);
 
 	/**
@@ -91,8 +99,6 @@ public:
 	* @brief Gets or sets the name.
 	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 	/**
 	 * @brief Gets or sets the matched term.
@@ -193,20 +199,18 @@ public:
 	bool backdropImageItemIdNull() const;
 	void setBackdropImageItemIdNull();
 
+
+	BaseItemKind type() const;
+
+	void setType(BaseItemKind newType);
+
 	/**
-	 * @brief Gets or sets the type.
+	 * @brief Gets or sets a value indicating whether this instance is folder.
 	 */
-	QString type() const;
-	/**
-	* @brief Gets or sets the type.
-	*/
-	void setType(QString newType);
-	bool typeNull() const;
-	void setTypeNull();
-
-
 	std::optional<bool> isFolder() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether this instance is folder.
+	*/
 	void setIsFolder(std::optional<bool> newIsFolder);
 	bool isFolderNull() const;
 	void setIsFolderNull();
@@ -222,27 +226,29 @@ public:
 	bool runTimeTicksNull() const;
 	void setRunTimeTicksNull();
 
+
+	MediaType mediaType() const;
+
+	void setMediaType(MediaType newMediaType);
+
 	/**
-	 * @brief Gets or sets the type of the media.
+	 * @brief Gets or sets the start date.
 	 */
-	QString mediaType() const;
-	/**
-	* @brief Gets or sets the type of the media.
-	*/
-	void setMediaType(QString newMediaType);
-	bool mediaTypeNull() const;
-	void setMediaTypeNull();
-
-
 	QDateTime startDate() const;
-
+	/**
+	* @brief Gets or sets the start date.
+	*/
 	void setStartDate(QDateTime newStartDate);
 	bool startDateNull() const;
 	void setStartDateNull();
 
-
+	/**
+	 * @brief Gets or sets the end date.
+	 */
 	QDateTime endDate() const;
-
+	/**
+	* @brief Gets or sets the end date.
+	*/
 	void setEndDate(QDateTime newEndDate);
 	bool endDateNull() const;
 	void setEndDateNull();
@@ -258,9 +264,13 @@ public:
 	bool seriesNull() const;
 	void setSeriesNull();
 
-
+	/**
+	 * @brief Gets or sets the status.
+	 */
 	QString status() const;
-
+	/**
+	* @brief Gets or sets the status.
+	*/
 	void setStatus(QString newStatus);
 	bool statusNull() const;
 	void setStatusNull();
@@ -276,10 +286,16 @@ public:
 	bool albumNull() const;
 	void setAlbumNull();
 
-
+	/**
+	 * @brief Gets or sets the album id.
+	 */
 	QString albumId() const;
-
+	/**
+	* @brief Gets or sets the album id.
+	*/
 	void setAlbumId(QString newAlbumId);
+	bool albumIdNull() const;
+	void setAlbumIdNull();
 
 	/**
 	 * @brief Gets or sets the album artist.
@@ -300,8 +316,6 @@ public:
 	* @brief Gets or sets the artists.
 	*/
 	void setArtists(QStringList newArtists);
-	bool artistsNull() const;
-	void setArtistsNull();
 
 	/**
 	 * @brief Gets or sets the song count.
@@ -333,6 +347,8 @@ public:
 	* @brief Gets or sets the channel identifier.
 	*/
 	void setChannelId(QString newChannelId);
+	bool channelIdNull() const;
+	void setChannelIdNull();
 
 	/**
 	 * @brief Gets or sets the name of the channel.
@@ -370,10 +386,10 @@ protected:
 	QString m_thumbImageItemId;
 	QString m_backdropImageTag;
 	QString m_backdropImageItemId;
-	QString m_type;
+	BaseItemKind m_type;
 	std::optional<bool> m_isFolder = std::nullopt;
 	std::optional<qint64> m_runTimeTicks = std::nullopt;
-	QString m_mediaType;
+	MediaType m_mediaType;
 	QDateTime m_startDate;
 	QDateTime m_endDate;
 	QString m_series;
diff --git a/core/include/JellyfinQt/dto/searchhintresult.h b/core/include/JellyfinQt/dto/searchhintresult.h
index 08aaa81..6b41b45 100644
--- a/core/include/JellyfinQt/dto/searchhintresult.h
+++ b/core/include/JellyfinQt/dto/searchhintresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class SearchHintResult {
 public:
-	SearchHintResult(			
+	SearchHintResult(	
+		QList<SearchHint> searchHints,			
 		qint32 totalRecordCount		
 	);
 
@@ -66,22 +67,20 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the search hints.
+	 * @brief Gets the search hints.
 	 */
 	QList<SearchHint> searchHints() const;
 	/**
-	* @brief Gets or sets the search hints.
+	* @brief Gets the search hints.
 	*/
 	void setSearchHints(QList<SearchHint> newSearchHints);
-	bool searchHintsNull() const;
-	void setSearchHintsNull();
 
 	/**
-	 * @brief Gets or sets the total record count.
+	 * @brief Gets the total record count.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief Gets or sets the total record count.
+	* @brief Gets the total record count.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
diff --git a/core/include/JellyfinQt/dto/seriesinfo.h b/core/include/JellyfinQt/dto/seriesinfo.h
index 3804fd6..e0000e2 100644
--- a/core/include/JellyfinQt/dto/seriesinfo.h
+++ b/core/include/JellyfinQt/dto/seriesinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class SeriesInfo {
 public:
-	SeriesInfo(																			
+	SeriesInfo(																					
 		bool isAutomated		
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -159,6 +170,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/seriesinforemotesearchquery.h b/core/include/JellyfinQt/dto/seriesinforemotesearchquery.h
index 8da45a5..5155236 100644
--- a/core/include/JellyfinQt/dto/seriesinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/seriesinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/seriesstatus.h b/core/include/JellyfinQt/dto/seriesstatus.h
index 3a8ee8e..972a942 100644
--- a/core/include/JellyfinQt/dto/seriesstatus.h
+++ b/core/include/JellyfinQt/dto/seriesstatus.h
@@ -50,6 +50,7 @@ public:
 		EnumNotSet,
 		Continuing,
 		Ended,
+		Unreleased,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/seriestimercancelledmessage.h b/core/include/JellyfinQt/dto/seriestimercancelledmessage.h
new file mode 100644
index 0000000..ed1a29e
--- /dev/null
+++ b/core/include/JellyfinQt/dto/seriestimercancelledmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_SERIESTIMERCANCELLEDMESSAGE_H
+#define JELLYFIN_DTO_SERIESTIMERCANCELLEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/timereventinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SeriesTimerCancelledMessage {
+public:
+	SeriesTimerCancelledMessage(	
+		QSharedPointer<TimerEventInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	SeriesTimerCancelledMessage(const SeriesTimerCancelledMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SeriesTimerCancelledMessage &other);
+	
+	static SeriesTimerCancelledMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<TimerEventInfo> data() const;
+
+	void setData(QSharedPointer<TimerEventInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<TimerEventInfo> m_data = QSharedPointer<TimerEventInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SeriesTimerCancelledMessage::fromJson();
+	SeriesTimerCancelledMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SeriesTimerCancelledMessage = Jellyfin::DTO::SeriesTimerCancelledMessage;
+
+template <>
+SeriesTimerCancelledMessage fromJsonValue(const QJsonValue &source, convertType<SeriesTimerCancelledMessage>);
+
+template<>
+QJsonValue toJsonValue(const SeriesTimerCancelledMessage &source, convertType<SeriesTimerCancelledMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SERIESTIMERCANCELLEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/seriestimercreatedmessage.h b/core/include/JellyfinQt/dto/seriestimercreatedmessage.h
new file mode 100644
index 0000000..973d562
--- /dev/null
+++ b/core/include/JellyfinQt/dto/seriestimercreatedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_SERIESTIMERCREATEDMESSAGE_H
+#define JELLYFIN_DTO_SERIESTIMERCREATEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/timereventinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SeriesTimerCreatedMessage {
+public:
+	SeriesTimerCreatedMessage(	
+		QSharedPointer<TimerEventInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	SeriesTimerCreatedMessage(const SeriesTimerCreatedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SeriesTimerCreatedMessage &other);
+	
+	static SeriesTimerCreatedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<TimerEventInfo> data() const;
+
+	void setData(QSharedPointer<TimerEventInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<TimerEventInfo> m_data = QSharedPointer<TimerEventInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SeriesTimerCreatedMessage::fromJson();
+	SeriesTimerCreatedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SeriesTimerCreatedMessage = Jellyfin::DTO::SeriesTimerCreatedMessage;
+
+template <>
+SeriesTimerCreatedMessage fromJsonValue(const QJsonValue &source, convertType<SeriesTimerCreatedMessage>);
+
+template<>
+QJsonValue toJsonValue(const SeriesTimerCreatedMessage &source, convertType<SeriesTimerCreatedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SERIESTIMERCREATEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/seriestimerinfodto.h b/core/include/JellyfinQt/dto/seriestimerinfodto.h
index f209211..551f3f9 100644
--- a/core/include/JellyfinQt/dto/seriestimerinfodto.h
+++ b/core/include/JellyfinQt/dto/seriestimerinfodto.h
@@ -84,11 +84,11 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Id of the recording.
+	 * @brief Gets or sets the Id of the recording.
 	 */
 	QString jellyfinId() const;
 	/**
-	* @brief Id of the recording.
+	* @brief Gets or sets the Id of the recording.
 	*/
 	void setJellyfinId(QString newJellyfinId);
 	bool jellyfinIdNull() const;
@@ -124,11 +124,11 @@ public:
 	void setExternalIdNull();
 
 	/**
-	 * @brief ChannelId of the recording.
+	 * @brief Gets or sets the channel id of the recording.
 	 */
 	QString channelId() const;
 	/**
-	* @brief ChannelId of the recording.
+	* @brief Gets or sets the channel id of the recording.
 	*/
 	void setChannelId(QString newChannelId);
 
@@ -144,11 +144,11 @@ public:
 	void setExternalChannelIdNull();
 
 	/**
-	 * @brief ChannelName of the recording.
+	 * @brief Gets or sets the channel name of the recording.
 	 */
 	QString channelName() const;
 	/**
-	* @brief ChannelName of the recording.
+	* @brief Gets or sets the channel name of the recording.
 	*/
 	void setChannelName(QString newChannelName);
 	bool channelNameNull() const;
@@ -184,42 +184,42 @@ public:
 	void setExternalProgramIdNull();
 
 	/**
-	 * @brief Name of the recording.
+	 * @brief Gets or sets the name of the recording.
 	 */
 	QString name() const;
 	/**
-	* @brief Name of the recording.
+	* @brief Gets or sets the name of the recording.
 	*/
 	void setName(QString newName);
 	bool nameNull() const;
 	void setNameNull();
 
 	/**
-	 * @brief Description of the recording.
+	 * @brief Gets or sets the description of the recording.
 	 */
 	QString overview() const;
 	/**
-	* @brief Description of the recording.
+	* @brief Gets or sets the description of the recording.
 	*/
 	void setOverview(QString newOverview);
 	bool overviewNull() const;
 	void setOverviewNull();
 
 	/**
-	 * @brief The start date of the recording, in UTC.
+	 * @brief Gets or sets the start date of the recording, in UTC.
 	 */
 	QDateTime startDate() const;
 	/**
-	* @brief The start date of the recording, in UTC.
+	* @brief Gets or sets the start date of the recording, in UTC.
 	*/
 	void setStartDate(QDateTime newStartDate);
 
 	/**
-	 * @brief The end date of the recording, in UTC.
+	 * @brief Gets or sets the end date of the recording, in UTC.
 	 */
 	QDateTime endDate() const;
 	/**
-	* @brief The end date of the recording, in UTC.
+	* @brief Gets or sets the end date of the recording, in UTC.
 	*/
 	void setEndDate(QDateTime newEndDate);
 
@@ -271,11 +271,11 @@ public:
 	void setIsPrePaddingRequired(bool newIsPrePaddingRequired);
 
 	/**
-	 * @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	 * @brief Gets or sets the Id of the Parent that has a backdrop if the item does not have one.
 	 */
 	QString parentBackdropItemId() const;
 	/**
-	* @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	* @brief Gets or sets the Id of the Parent that has a backdrop if the item does not have one.
 	*/
 	void setParentBackdropItemId(QString newParentBackdropItemId);
 	bool parentBackdropItemIdNull() const;
diff --git a/core/include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h b/core/include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h
index 039cd48..d2f4eeb 100644
--- a/core/include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h
+++ b/core/include/JellyfinQt/dto/seriestimerinfodtoqueryresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class SeriesTimerInfoDtoQueryResult {
 public:
-	SeriesTimerInfoDtoQueryResult(			
+	SeriesTimerInfoDtoQueryResult(	
+		QList<SeriesTimerInfoDto> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
@@ -74,24 +75,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<SeriesTimerInfoDto> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/serverconfiguration.h b/core/include/JellyfinQt/dto/serverconfiguration.h
index 33c0979..e9600df 100644
--- a/core/include/JellyfinQt/dto/serverconfiguration.h
+++ b/core/include/JellyfinQt/dto/serverconfiguration.h
@@ -38,12 +38,14 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/castreceiverapplication.h"
+#include "JellyfinQt/dto/imageresolution.h"
 #include "JellyfinQt/dto/imagesavingconvention.h"
 #include "JellyfinQt/dto/metadataoptions.h"
 #include "JellyfinQt/dto/namevaluepair.h"
 #include "JellyfinQt/dto/pathsubstitution.h"
 #include "JellyfinQt/dto/repositoryinfo.h"
-#include "JellyfinQt/dto/version.h"
+#include "JellyfinQt/dto/trickplayoptions.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -58,59 +60,55 @@ class ServerConfiguration {
 public:
 	ServerConfiguration(	
 		qint32 logFileRetentionDays,			
-		bool isStartupWizardCompleted,					
-		QSharedPointer<Version> previousVersion,					
-		bool enableUPnP,			
+		bool isStartupWizardCompleted,									
 		bool enableMetrics,			
-		qint32 publicPort,			
-		bool uPnPCreateHttpPortMap,					
-		bool enableIPV6,			
-		bool enableIPV4,			
-		bool enableSSDPTracing,					
-		qint32 uDPSendCount,			
-		qint32 uDPSendDelay,			
-		bool ignoreVirtualInterfaces,					
-		qint32 gatewayMonitorPeriod,			
-		bool enableMultiSocketBinding,			
-		bool trustAllIP6Interfaces,							
-		bool autoDiscoveryTracing,			
-		bool autoDiscovery,			
-		qint32 publicHttpsPort,			
-		qint32 httpServerPortNumber,			
-		qint32 httpsPortNumber,			
-		bool enableHttps,			
-		bool enableNormalizedItemByNameIds,							
+		bool enableNormalizedItemByNameIds,			
 		bool isPortAuthorized,			
 		bool quickConnectAvailable,			
-		bool enableRemoteAccess,			
 		bool enableCaseSensitiveItemIds,			
-		bool disableLiveTvChannelUserDataName,																	
+		bool disableLiveTvChannelUserDataName,			
+		QString metadataPath,			
+		QString preferredMetadataLanguage,			
+		QString metadataCountryCode,			
+		QStringList sortReplaceCharacters,			
+		QStringList sortRemoveCharacters,			
+		QStringList sortRemoveWords,			
 		qint32 minResumePct,			
 		qint32 maxResumePct,			
 		qint32 minResumeDurationSeconds,			
 		qint32 minAudiobookResume,			
 		qint32 maxAudiobookResume,			
+		qint32 inactiveSessionThreshold,			
 		qint32 libraryMonitorDelay,			
-		bool enableDashboardResponseCaching,			
-		ImageSavingConvention imageSavingConvention,					
-		bool skipDeserializationForBasicTypes,									
-		bool saveMetadataHidden,					
+		qint32 libraryUpdateDuration,			
+		ImageSavingConvention imageSavingConvention,			
+		QList<MetadataOptions> metadataOptions,			
+		bool skipDeserializationForBasicTypes,			
+		QString serverName,			
+		QString uICulture,			
+		bool saveMetadataHidden,			
+		QList<NameValuePair> contentTypes,			
 		qint32 remoteClientBitrateLimit,			
 		bool enableFolderView,			
 		bool enableGroupingIntoCollections,			
-		bool displaySpecialsWithinSeasons,											
+		bool displaySpecialsWithinSeasons,			
+		QStringList codecsUsed,			
+		QList<RepositoryInfo> pluginRepositories,			
 		bool enableExternalContentInSuggestions,			
-		bool requireHttps,			
-		bool enableNewOmdbSupport,					
-		bool isRemoteIPFilterBlacklist,			
-		qint32 imageExtractionTimeoutMs,					
-		bool enableSimpleArtistDetection,					
+		qint32 imageExtractionTimeoutMs,			
+		QList<PathSubstitution> pathSubstitutions,			
 		bool enableSlowResponseWarning,			
-		qint64 slowResponseThresholdMs,									
+		qint64 slowResponseThresholdMs,			
+		QStringList corsHosts,					
 		qint32 libraryScanFanoutConcurrency,			
 		qint32 libraryMetadataRefreshConcurrency,			
 		bool removeOldPlugins,			
-		bool disablePluginImages		
+		bool allowClientLogUpload,			
+		qint32 dummyChapterDuration,			
+		ImageResolution chapterImageResolution,			
+		qint32 parallelImageEncodingLimit,			
+		QList<CastReceiverApplication> castReceiverApplications,			
+		QSharedPointer<TrickplayOptions> trickplayOptions		
 	);
 
 	ServerConfiguration(const ServerConfiguration &other);
@@ -154,10 +152,16 @@ public:
 	bool cachePathNull() const;
 	void setCachePathNull();
 
-
-	QSharedPointer<Version> previousVersion() const;
-
-	void setPreviousVersion(QSharedPointer<Version> newPreviousVersion);
+	/**
+	 * @brief Gets or sets the last known version that was ran using the configuration.
+	 */
+	QString previousVersion() const;
+	/**
+	* @brief Gets or sets the last known version that was ran using the configuration.
+	*/
+	void setPreviousVersion(QString newPreviousVersion);
+	bool previousVersionNull() const;
+	void setPreviousVersionNull();
 
 	/**
 	 * @brief Gets or sets the stringified PreviousVersion to be stored/loaded,
@@ -172,15 +176,6 @@ because System.Version itself isn't xml-serializable.
 	bool previousVersionStrNull() const;
 	void setPreviousVersionStrNull();
 
-	/**
-	 * @brief Gets or sets a value indicating whether to enable automatic port forwarding.
-	 */
-	bool enableUPnP() const;
-	/**
-	* @brief Gets or sets a value indicating whether to enable automatic port forwarding.
-	*/
-	void setEnableUPnP(bool newEnableUPnP);
-
 	/**
 	 * @brief Gets or sets a value indicating whether to enable prometheus metrics exporting.
 	 */
@@ -190,247 +185,11 @@ because System.Version itself isn't xml-serializable.
 	*/
 	void setEnableMetrics(bool newEnableMetrics);
 
-	/**
-	 * @brief Gets or sets the public mapped port.
-	 */
-	qint32 publicPort() const;
-	/**
-	* @brief Gets or sets the public mapped port.
-	*/
-	void setPublicPort(qint32 newPublicPort);
-
-	/**
-	 * @brief Gets or sets a value indicating whether the http port should be mapped as part of UPnP automatic port forwarding.
-	 */
-	bool uPnPCreateHttpPortMap() const;
-	/**
-	* @brief Gets or sets a value indicating whether the http port should be mapped as part of UPnP automatic port forwarding.
-	*/
-	void setUPnPCreateHttpPortMap(bool newUPnPCreateHttpPortMap);
-
-	/**
-	 * @brief Gets or sets client udp port range.
-	 */
-	QString uDPPortRange() const;
-	/**
-	* @brief Gets or sets client udp port range.
-	*/
-	void setUDPPortRange(QString newUDPPortRange);
-	bool uDPPortRangeNull() const;
-	void setUDPPortRangeNull();
-
-	/**
-	 * @brief Gets or sets a value indicating whether IPV6 capability is enabled.
-	 */
-	bool enableIPV6() const;
-	/**
-	* @brief Gets or sets a value indicating whether IPV6 capability is enabled.
-	*/
-	void setEnableIPV6(bool newEnableIPV6);
-
-	/**
-	 * @brief Gets or sets a value indicating whether IPV4 capability is enabled.
-	 */
-	bool enableIPV4() const;
-	/**
-	* @brief Gets or sets a value indicating whether IPV4 capability is enabled.
-	*/
-	void setEnableIPV4(bool newEnableIPV4);
-
-	/**
-	 * @brief Gets or sets a value indicating whether detailed ssdp logs are sent to the console/log.
-"Emby.Dlna": "Debug" must be set in logging.default.json for this property to work.
-	 */
-	bool enableSSDPTracing() const;
-	/**
-	* @brief Gets or sets a value indicating whether detailed ssdp logs are sent to the console/log.
-"Emby.Dlna": "Debug" must be set in logging.default.json for this property to work.
-	*/
-	void setEnableSSDPTracing(bool newEnableSSDPTracing);
-
-	/**
-	 * @brief Gets or sets a value indicating whether an IP address is to be used to filter the detailed ssdp logs that are being sent to the console/log.
-If the setting "Emby.Dlna": "Debug" msut be set in logging.default.json for this property to work.
-	 */
-	QString sSDPTracingFilter() const;
-	/**
-	* @brief Gets or sets a value indicating whether an IP address is to be used to filter the detailed ssdp logs that are being sent to the console/log.
-If the setting "Emby.Dlna": "Debug" msut be set in logging.default.json for this property to work.
-	*/
-	void setSSDPTracingFilter(QString newSSDPTracingFilter);
-	bool sSDPTracingFilterNull() const;
-	void setSSDPTracingFilterNull();
-
-	/**
-	 * @brief Gets or sets the number of times SSDP UDP messages are sent.
-	 */
-	qint32 uDPSendCount() const;
-	/**
-	* @brief Gets or sets the number of times SSDP UDP messages are sent.
-	*/
-	void setUDPSendCount(qint32 newUDPSendCount);
-
-	/**
-	 * @brief Gets or sets the delay between each groups of SSDP messages (in ms).
-	 */
-	qint32 uDPSendDelay() const;
-	/**
-	* @brief Gets or sets the delay between each groups of SSDP messages (in ms).
-	*/
-	void setUDPSendDelay(qint32 newUDPSendDelay);
-
-	/**
-	 * @brief Gets or sets a value indicating whether address names that match MediaBrowser.Model.Configuration.ServerConfiguration.VirtualInterfaceNames should be Ignore for the purposes of binding.
-	 */
-	bool ignoreVirtualInterfaces() const;
-	/**
-	* @brief Gets or sets a value indicating whether address names that match MediaBrowser.Model.Configuration.ServerConfiguration.VirtualInterfaceNames should be Ignore for the purposes of binding.
-	*/
-	void setIgnoreVirtualInterfaces(bool newIgnoreVirtualInterfaces);
-
-	/**
-	 * @brief Gets or sets a value indicating the interfaces that should be ignored. The list can be comma separated. <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.IgnoreVirtualInterfaces" />.
-	 */
-	QString virtualInterfaceNames() const;
-	/**
-	* @brief Gets or sets a value indicating the interfaces that should be ignored. The list can be comma separated. <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.IgnoreVirtualInterfaces" />.
-	*/
-	void setVirtualInterfaceNames(QString newVirtualInterfaceNames);
-	bool virtualInterfaceNamesNull() const;
-	void setVirtualInterfaceNamesNull();
-
-	/**
-	 * @brief Gets or sets the time (in seconds) between the pings of SSDP gateway monitor.
-	 */
-	qint32 gatewayMonitorPeriod() const;
-	/**
-	* @brief Gets or sets the time (in seconds) between the pings of SSDP gateway monitor.
-	*/
-	void setGatewayMonitorPeriod(qint32 newGatewayMonitorPeriod);
-
-	/**
-	 * @brief Gets a value indicating whether multi-socket binding is available.
-	 */
-	bool enableMultiSocketBinding() const;
-	/**
-	* @brief Gets a value indicating whether multi-socket binding is available.
-	*/
-	void setEnableMultiSocketBinding(bool newEnableMultiSocketBinding);
-
-	/**
-	 * @brief Gets or sets a value indicating whether all IPv6 interfaces should be treated as on the internal network.
-Depending on the address range implemented ULA ranges might not be used.
-	 */
-	bool trustAllIP6Interfaces() const;
-	/**
-	* @brief Gets or sets a value indicating whether all IPv6 interfaces should be treated as on the internal network.
-Depending on the address range implemented ULA ranges might not be used.
-	*/
-	void setTrustAllIP6Interfaces(bool newTrustAllIP6Interfaces);
-
-	/**
-	 * @brief Gets or sets the ports that HDHomerun uses.
-	 */
-	QString hDHomerunPortRange() const;
-	/**
-	* @brief Gets or sets the ports that HDHomerun uses.
-	*/
-	void setHDHomerunPortRange(QString newHDHomerunPortRange);
-	bool hDHomerunPortRangeNull() const;
-	void setHDHomerunPortRangeNull();
-
-	/**
-	 * @brief Gets or sets PublishedServerUri to advertise for specific subnets.
-	 */
-	QStringList publishedServerUriBySubnet() const;
-	/**
-	* @brief Gets or sets PublishedServerUri to advertise for specific subnets.
-	*/
-	void setPublishedServerUriBySubnet(QStringList newPublishedServerUriBySubnet);
-	bool publishedServerUriBySubnetNull() const;
-	void setPublishedServerUriBySubnetNull();
-
-	/**
-	 * @brief Gets or sets a value indicating whether Autodiscovery tracing is enabled.
-	 */
-	bool autoDiscoveryTracing() const;
-	/**
-	* @brief Gets or sets a value indicating whether Autodiscovery tracing is enabled.
-	*/
-	void setAutoDiscoveryTracing(bool newAutoDiscoveryTracing);
-
-	/**
-	 * @brief Gets or sets a value indicating whether Autodiscovery is enabled.
-	 */
-	bool autoDiscovery() const;
-	/**
-	* @brief Gets or sets a value indicating whether Autodiscovery is enabled.
-	*/
-	void setAutoDiscovery(bool newAutoDiscovery);
-
-	/**
-	 * @brief Gets or sets the public HTTPS port.
-	 */
-	qint32 publicHttpsPort() const;
-	/**
-	* @brief Gets or sets the public HTTPS port.
-	*/
-	void setPublicHttpsPort(qint32 newPublicHttpsPort);
-
-	/**
-	 * @brief Gets or sets the HTTP server port number.
-	 */
-	qint32 httpServerPortNumber() const;
-	/**
-	* @brief Gets or sets the HTTP server port number.
-	*/
-	void setHttpServerPortNumber(qint32 newHttpServerPortNumber);
-
-	/**
-	 * @brief Gets or sets the HTTPS server port number.
-	 */
-	qint32 httpsPortNumber() const;
-	/**
-	* @brief Gets or sets the HTTPS server port number.
-	*/
-	void setHttpsPortNumber(qint32 newHttpsPortNumber);
-
-	/**
-	 * @brief Gets or sets a value indicating whether to use HTTPS.
-	 */
-	bool enableHttps() const;
-	/**
-	* @brief Gets or sets a value indicating whether to use HTTPS.
-	*/
-	void setEnableHttps(bool newEnableHttps);
-
 
 	bool enableNormalizedItemByNameIds() const;
 
 	void setEnableNormalizedItemByNameIds(bool newEnableNormalizedItemByNameIds);
 
-	/**
-	 * @brief Gets or sets the filesystem path of an X.509 certificate to use for SSL.
-	 */
-	QString certificatePath() const;
-	/**
-	* @brief Gets or sets the filesystem path of an X.509 certificate to use for SSL.
-	*/
-	void setCertificatePath(QString newCertificatePath);
-	bool certificatePathNull() const;
-	void setCertificatePathNull();
-
-	/**
-	 * @brief Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Model.Configuration.ServerConfiguration.CertificatePath.
-	 */
-	QString certificatePassword() const;
-	/**
-	* @brief Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Model.Configuration.ServerConfiguration.CertificatePath.
-	*/
-	void setCertificatePassword(QString newCertificatePassword);
-	bool certificatePasswordNull() const;
-	void setCertificatePasswordNull();
-
 	/**
 	 * @brief Gets or sets a value indicating whether this instance is port authorized.
 	 */
@@ -449,15 +208,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	*/
 	void setQuickConnectAvailable(bool newQuickConnectAvailable);
 
-	/**
-	 * @brief Gets or sets a value indicating whether access outside of the LAN is permitted.
-	 */
-	bool enableRemoteAccess() const;
-	/**
-	* @brief Gets or sets a value indicating whether access outside of the LAN is permitted.
-	*/
-	void setEnableRemoteAccess(bool newEnableRemoteAccess);
-
 	/**
 	 * @brief Gets or sets a value indicating whether [enable case sensitive item ids].
 	 */
@@ -480,15 +230,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets the metadata path.
 	*/
 	void setMetadataPath(QString newMetadataPath);
-	bool metadataPathNull() const;
-	void setMetadataPathNull();
-
-
-	QString metadataNetworkPath() const;
-
-	void setMetadataNetworkPath(QString newMetadataNetworkPath);
-	bool metadataNetworkPathNull() const;
-	void setMetadataNetworkPathNull();
 
 	/**
 	 * @brief Gets or sets the preferred metadata language.
@@ -498,8 +239,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets the preferred metadata language.
 	*/
 	void setPreferredMetadataLanguage(QString newPreferredMetadataLanguage);
-	bool preferredMetadataLanguageNull() const;
-	void setPreferredMetadataLanguageNull();
 
 	/**
 	 * @brief Gets or sets the metadata country code.
@@ -509,8 +248,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets the metadata country code.
 	*/
 	void setMetadataCountryCode(QString newMetadataCountryCode);
-	bool metadataCountryCodeNull() const;
-	void setMetadataCountryCodeNull();
 
 	/**
 	 * @brief Gets or sets characters to be replaced with a ' ' in strings to create a sort name.
@@ -520,8 +257,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets characters to be replaced with a ' ' in strings to create a sort name.
 	*/
 	void setSortReplaceCharacters(QStringList newSortReplaceCharacters);
-	bool sortReplaceCharactersNull() const;
-	void setSortReplaceCharactersNull();
 
 	/**
 	 * @brief Gets or sets characters to be removed from strings to create a sort name.
@@ -531,8 +266,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets characters to be removed from strings to create a sort name.
 	*/
 	void setSortRemoveCharacters(QStringList newSortRemoveCharacters);
-	bool sortRemoveCharactersNull() const;
-	void setSortRemoveCharactersNull();
 
 	/**
 	 * @brief Gets or sets words to be removed from strings to create a sort name.
@@ -542,8 +275,6 @@ Depending on the address range implemented ULA ranges might not be used.
 	* @brief Gets or sets words to be removed from strings to create a sort name.
 	*/
 	void setSortRemoveWords(QStringList newSortRemoveWords);
-	bool sortRemoveWordsNull() const;
-	void setSortRemoveWordsNull();
 
 	/**
 	 * @brief Gets or sets the minimum percentage of an item that must be played in order for playstate to be updated.
@@ -590,6 +321,17 @@ Depending on the address range implemented ULA ranges might not be used.
 	*/
 	void setMaxAudiobookResume(qint32 newMaxAudiobookResume);
 
+	/**
+	 * @brief Gets or sets the threshold in minutes after a inactive session gets closed automatically.
+If set to 0 the check for inactive sessions gets disabled.
+	 */
+	qint32 inactiveSessionThreshold() const;
+	/**
+	* @brief Gets or sets the threshold in minutes after a inactive session gets closed automatically.
+If set to 0 the check for inactive sessions gets disabled.
+	*/
+	void setInactiveSessionThreshold(qint32 newInactiveSessionThreshold);
+
 	/**
 	 * @brief Gets or sets the delay in seconds that we will wait after a file system change to try and discover what has been added/removed
 Some delay is necessary with some items because their creation is not atomic.  It involves the creation of several
@@ -604,15 +346,13 @@ different directories and files.
 	void setLibraryMonitorDelay(qint32 newLibraryMonitorDelay);
 
 	/**
-	 * @brief Gets or sets a value indicating whether [enable dashboard response caching].
-Allows potential contributors without visual studio to modify production dashboard code and test changes.
+	 * @brief Gets or sets the duration in seconds that we will wait after a library updated event before executing the library changed notification.
 	 */
-	bool enableDashboardResponseCaching() const;
+	qint32 libraryUpdateDuration() const;
 	/**
-	* @brief Gets or sets a value indicating whether [enable dashboard response caching].
-Allows potential contributors without visual studio to modify production dashboard code and test changes.
+	* @brief Gets or sets the duration in seconds that we will wait after a library updated event before executing the library changed notification.
 	*/
-	void setEnableDashboardResponseCaching(bool newEnableDashboardResponseCaching);
+	void setLibraryUpdateDuration(qint32 newLibraryUpdateDuration);
 
 
 	ImageSavingConvention imageSavingConvention() const;
@@ -623,8 +363,6 @@ Allows potential contributors without visual studio to modify production dashboa
 	QList<MetadataOptions> metadataOptions() const;
 
 	void setMetadataOptions(QList<MetadataOptions> newMetadataOptions);
-	bool metadataOptionsNull() const;
-	void setMetadataOptionsNull();
 
 
 	bool skipDeserializationForBasicTypes() const;
@@ -635,22 +373,11 @@ Allows potential contributors without visual studio to modify production dashboa
 	QString serverName() const;
 
 	void setServerName(QString newServerName);
-	bool serverNameNull() const;
-	void setServerNameNull();
-
-
-	QString baseUrl() const;
-
-	void setBaseUrl(QString newBaseUrl);
-	bool baseUrlNull() const;
-	void setBaseUrlNull();
 
 
 	QString uICulture() const;
 
 	void setUICulture(QString newUICulture);
-	bool uICultureNull() const;
-	void setUICultureNull();
 
 
 	bool saveMetadataHidden() const;
@@ -661,8 +388,6 @@ Allows potential contributors without visual studio to modify production dashboa
 	QList<NameValuePair> contentTypes() const;
 
 	void setContentTypes(QList<NameValuePair> newContentTypes);
-	bool contentTypesNull() const;
-	void setContentTypesNull();
 
 
 	qint32 remoteClientBitrateLimit() const;
@@ -684,81 +409,21 @@ Allows potential contributors without visual studio to modify production dashboa
 
 	void setDisplaySpecialsWithinSeasons(bool newDisplaySpecialsWithinSeasons);
 
-	/**
-	 * @brief Gets or sets the subnets that are deemed to make up the LAN.
-	 */
-	QStringList localNetworkSubnets() const;
-	/**
-	* @brief Gets or sets the subnets that are deemed to make up the LAN.
-	*/
-	void setLocalNetworkSubnets(QStringList newLocalNetworkSubnets);
-	bool localNetworkSubnetsNull() const;
-	void setLocalNetworkSubnetsNull();
-
-	/**
-	 * @brief Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used.
-	 */
-	QStringList localNetworkAddresses() const;
-	/**
-	* @brief Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used.
-	*/
-	void setLocalNetworkAddresses(QStringList newLocalNetworkAddresses);
-	bool localNetworkAddressesNull() const;
-	void setLocalNetworkAddressesNull();
-
 
 	QStringList codecsUsed() const;
 
 	void setCodecsUsed(QStringList newCodecsUsed);
-	bool codecsUsedNull() const;
-	void setCodecsUsedNull();
 
 
 	QList<RepositoryInfo> pluginRepositories() const;
 
 	void setPluginRepositories(QList<RepositoryInfo> newPluginRepositories);
-	bool pluginRepositoriesNull() const;
-	void setPluginRepositoriesNull();
 
 
 	bool enableExternalContentInSuggestions() const;
 
 	void setEnableExternalContentInSuggestions(bool newEnableExternalContentInSuggestions);
 
-	/**
-	 * @brief Gets or sets a value indicating whether the server should force connections over HTTPS.
-	 */
-	bool requireHttps() const;
-	/**
-	* @brief Gets or sets a value indicating whether the server should force connections over HTTPS.
-	*/
-	void setRequireHttps(bool newRequireHttps);
-
-
-	bool enableNewOmdbSupport() const;
-
-	void setEnableNewOmdbSupport(bool newEnableNewOmdbSupport);
-
-	/**
-	 * @brief Gets or sets the filter for remote IP connectivity. Used in conjuntion with <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.IsRemoteIPFilterBlacklist" />.
-	 */
-	QStringList remoteIPFilter() const;
-	/**
-	* @brief Gets or sets the filter for remote IP connectivity. Used in conjuntion with <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.IsRemoteIPFilterBlacklist" />.
-	*/
-	void setRemoteIPFilter(QStringList newRemoteIPFilter);
-	bool remoteIPFilterNull() const;
-	void setRemoteIPFilterNull();
-
-	/**
-	 * @brief Gets or sets a value indicating whether <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.RemoteIPFilter" /> contains a blacklist or a whitelist. Default is a whitelist.
-	 */
-	bool isRemoteIPFilterBlacklist() const;
-	/**
-	* @brief Gets or sets a value indicating whether <seealso cref="P:MediaBrowser.Model.Configuration.ServerConfiguration.RemoteIPFilter" /> contains a blacklist or a whitelist. Default is a whitelist.
-	*/
-	void setIsRemoteIPFilterBlacklist(bool newIsRemoteIPFilterBlacklist);
-
 
 	qint32 imageExtractionTimeoutMs() const;
 
@@ -768,20 +433,6 @@ Allows potential contributors without visual studio to modify production dashboa
 	QList<PathSubstitution> pathSubstitutions() const;
 
 	void setPathSubstitutions(QList<PathSubstitution> newPathSubstitutions);
-	bool pathSubstitutionsNull() const;
-	void setPathSubstitutionsNull();
-
-
-	bool enableSimpleArtistDetection() const;
-
-	void setEnableSimpleArtistDetection(bool newEnableSimpleArtistDetection);
-
-
-	QStringList uninstalledPlugins() const;
-
-	void setUninstalledPlugins(QStringList newUninstalledPlugins);
-	bool uninstalledPluginsNull() const;
-	void setUninstalledPluginsNull();
 
 	/**
 	 * @brief Gets or sets a value indicating whether slow server responses should be logged as a warning.
@@ -809,19 +460,6 @@ Allows potential contributors without visual studio to modify production dashboa
 	* @brief Gets or sets the cors hosts.
 	*/
 	void setCorsHosts(QStringList newCorsHosts);
-	bool corsHostsNull() const;
-	void setCorsHostsNull();
-
-	/**
-	 * @brief Gets or sets the known proxies.
-	 */
-	QStringList knownProxies() const;
-	/**
-	* @brief Gets or sets the known proxies.
-	*/
-	void setKnownProxies(QStringList newKnownProxies);
-	bool knownProxiesNull() const;
-	void setKnownProxiesNull();
 
 	/**
 	 * @brief Gets or sets the number of days we should retain activity logs.
@@ -862,55 +500,65 @@ Allows potential contributors without visual studio to modify production dashboa
 	void setRemoveOldPlugins(bool newRemoveOldPlugins);
 
 	/**
-	 * @brief Gets or sets a value indicating whether plugin image should be disabled.
+	 * @brief Gets or sets a value indicating whether clients should be allowed to upload logs.
 	 */
-	bool disablePluginImages() const;
+	bool allowClientLogUpload() const;
 	/**
-	* @brief Gets or sets a value indicating whether plugin image should be disabled.
+	* @brief Gets or sets a value indicating whether clients should be allowed to upload logs.
 	*/
-	void setDisablePluginImages(bool newDisablePluginImages);
+	void setAllowClientLogUpload(bool newAllowClientLogUpload);
+
+	/**
+	 * @brief Gets or sets the dummy chapter duration in seconds, use 0 (zero) or less to disable generation alltogether.
+	 */
+	qint32 dummyChapterDuration() const;
+	/**
+	* @brief Gets or sets the dummy chapter duration in seconds, use 0 (zero) or less to disable generation alltogether.
+	*/
+	void setDummyChapterDuration(qint32 newDummyChapterDuration);
+
+
+	ImageResolution chapterImageResolution() const;
+
+	void setChapterImageResolution(ImageResolution newChapterImageResolution);
+
+	/**
+	 * @brief Gets or sets the limit for parallel image encoding.
+	 */
+	qint32 parallelImageEncodingLimit() const;
+	/**
+	* @brief Gets or sets the limit for parallel image encoding.
+	*/
+	void setParallelImageEncodingLimit(qint32 newParallelImageEncodingLimit);
+
+	/**
+	 * @brief Gets or sets the list of cast receiver applications.
+	 */
+	QList<CastReceiverApplication> castReceiverApplications() const;
+	/**
+	* @brief Gets or sets the list of cast receiver applications.
+	*/
+	void setCastReceiverApplications(QList<CastReceiverApplication> newCastReceiverApplications);
+
+
+	QSharedPointer<TrickplayOptions> trickplayOptions() const;
+
+	void setTrickplayOptions(QSharedPointer<TrickplayOptions> newTrickplayOptions);
 
 
 protected:
 	qint32 m_logFileRetentionDays;
 	bool m_isStartupWizardCompleted;
 	QString m_cachePath;
-	QSharedPointer<Version> m_previousVersion = QSharedPointer<Version>();
+	QString m_previousVersion;
 	QString m_previousVersionStr;
-	bool m_enableUPnP;
 	bool m_enableMetrics;
-	qint32 m_publicPort;
-	bool m_uPnPCreateHttpPortMap;
-	QString m_uDPPortRange;
-	bool m_enableIPV6;
-	bool m_enableIPV4;
-	bool m_enableSSDPTracing;
-	QString m_sSDPTracingFilter;
-	qint32 m_uDPSendCount;
-	qint32 m_uDPSendDelay;
-	bool m_ignoreVirtualInterfaces;
-	QString m_virtualInterfaceNames;
-	qint32 m_gatewayMonitorPeriod;
-	bool m_enableMultiSocketBinding;
-	bool m_trustAllIP6Interfaces;
-	QString m_hDHomerunPortRange;
-	QStringList m_publishedServerUriBySubnet;
-	bool m_autoDiscoveryTracing;
-	bool m_autoDiscovery;
-	qint32 m_publicHttpsPort;
-	qint32 m_httpServerPortNumber;
-	qint32 m_httpsPortNumber;
-	bool m_enableHttps;
 	bool m_enableNormalizedItemByNameIds;
-	QString m_certificatePath;
-	QString m_certificatePassword;
 	bool m_isPortAuthorized;
 	bool m_quickConnectAvailable;
-	bool m_enableRemoteAccess;
 	bool m_enableCaseSensitiveItemIds;
 	bool m_disableLiveTvChannelUserDataName;
 	QString m_metadataPath;
-	QString m_metadataNetworkPath;
 	QString m_preferredMetadataLanguage;
 	QString m_metadataCountryCode;
 	QStringList m_sortReplaceCharacters;
@@ -921,13 +569,13 @@ protected:
 	qint32 m_minResumeDurationSeconds;
 	qint32 m_minAudiobookResume;
 	qint32 m_maxAudiobookResume;
+	qint32 m_inactiveSessionThreshold;
 	qint32 m_libraryMonitorDelay;
-	bool m_enableDashboardResponseCaching;
+	qint32 m_libraryUpdateDuration;
 	ImageSavingConvention m_imageSavingConvention;
 	QList<MetadataOptions> m_metadataOptions;
 	bool m_skipDeserializationForBasicTypes;
 	QString m_serverName;
-	QString m_baseUrl;
 	QString m_uICulture;
 	bool m_saveMetadataHidden;
 	QList<NameValuePair> m_contentTypes;
@@ -935,28 +583,24 @@ protected:
 	bool m_enableFolderView;
 	bool m_enableGroupingIntoCollections;
 	bool m_displaySpecialsWithinSeasons;
-	QStringList m_localNetworkSubnets;
-	QStringList m_localNetworkAddresses;
 	QStringList m_codecsUsed;
 	QList<RepositoryInfo> m_pluginRepositories;
 	bool m_enableExternalContentInSuggestions;
-	bool m_requireHttps;
-	bool m_enableNewOmdbSupport;
-	QStringList m_remoteIPFilter;
-	bool m_isRemoteIPFilterBlacklist;
 	qint32 m_imageExtractionTimeoutMs;
 	QList<PathSubstitution> m_pathSubstitutions;
-	bool m_enableSimpleArtistDetection;
-	QStringList m_uninstalledPlugins;
 	bool m_enableSlowResponseWarning;
 	qint64 m_slowResponseThresholdMs;
 	QStringList m_corsHosts;
-	QStringList m_knownProxies;
 	std::optional<qint32> m_activityLogRetentionDays = std::nullopt;
 	qint32 m_libraryScanFanoutConcurrency;
 	qint32 m_libraryMetadataRefreshConcurrency;
 	bool m_removeOldPlugins;
-	bool m_disablePluginImages;
+	bool m_allowClientLogUpload;
+	qint32 m_dummyChapterDuration;
+	ImageResolution m_chapterImageResolution;
+	qint32 m_parallelImageEncodingLimit;
+	QList<CastReceiverApplication> m_castReceiverApplications;
+	QSharedPointer<TrickplayOptions> m_trickplayOptions = QSharedPointer<TrickplayOptions>();
 
 private:
 	// Private constructor which generates an invalid object, for use withing ServerConfiguration::fromJson();
diff --git a/core/include/JellyfinQt/dto/updateusereasypassword.h b/core/include/JellyfinQt/dto/serverdiscoveryinfo.h
similarity index 57%
rename from core/include/JellyfinQt/dto/updateusereasypassword.h
rename to core/include/JellyfinQt/dto/serverdiscoveryinfo.h
index 15ee4ae..a819c1c 100644
--- a/core/include/JellyfinQt/dto/updateusereasypassword.h
+++ b/core/include/JellyfinQt/dto/serverdiscoveryinfo.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_UPDATEUSEREASYPASSWORD_H
-#define JELLYFIN_DTO_UPDATEUSEREASYPASSWORD_H
+#ifndef JELLYFIN_DTO_SERVERDISCOVERYINFO_H
+#define JELLYFIN_DTO_SERVERDISCOVERYINFO_H
 
 #include <QJsonObject>
 #include <QJsonValue>
@@ -45,64 +45,74 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class UpdateUserEasyPassword {
+class ServerDiscoveryInfo {
 public:
-	UpdateUserEasyPassword(					
-		bool resetPassword		
+	ServerDiscoveryInfo(	
+		QString address,			
+		QString jellyfinId,			
+		QString name				
 	);
 
-	UpdateUserEasyPassword(const UpdateUserEasyPassword &other);
+	ServerDiscoveryInfo(const ServerDiscoveryInfo &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(UpdateUserEasyPassword &other);
+	void replaceData(ServerDiscoveryInfo &other);
 	
-	static UpdateUserEasyPassword fromJson(QJsonObject source);
+	static ServerDiscoveryInfo fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the new sha1-hashed password.
+	 * @brief Gets the address.
 	 */
-	QString newPassword() const;
+	QString address() const;
 	/**
-	* @brief Gets or sets the new sha1-hashed password.
+	* @brief Gets the address.
 	*/
-	void setNewPassword(QString newNewPassword);
-	bool newPasswordNull() const;
-	void setNewPasswordNull();
+	void setAddress(QString newAddress);
 
 	/**
-	 * @brief Gets or sets the new password.
+	 * @brief Gets the server identifier.
 	 */
-	QString newPw() const;
+	QString jellyfinId() const;
 	/**
-	* @brief Gets or sets the new password.
+	* @brief Gets the server identifier.
 	*/
-	void setNewPw(QString newNewPw);
-	bool newPwNull() const;
-	void setNewPwNull();
+	void setJellyfinId(QString newJellyfinId);
 
 	/**
-	 * @brief Gets or sets a value indicating whether to reset the password.
+	 * @brief Gets the name.
 	 */
-	bool resetPassword() const;
+	QString name() const;
 	/**
-	* @brief Gets or sets a value indicating whether to reset the password.
+	* @brief Gets the name.
 	*/
-	void setResetPassword(bool newResetPassword);
+	void setName(QString newName);
+
+	/**
+	 * @brief Gets the endpoint address.
+	 */
+	QString endpointAddress() const;
+	/**
+	* @brief Gets the endpoint address.
+	*/
+	void setEndpointAddress(QString newEndpointAddress);
+	bool endpointAddressNull() const;
+	void setEndpointAddressNull();
 
 
 protected:
-	QString m_newPassword;
-	QString m_newPw;
-	bool m_resetPassword;
+	QString m_address;
+	QString m_jellyfinId;
+	QString m_name;
+	QString m_endpointAddress;
 
 private:
-	// Private constructor which generates an invalid object, for use withing UpdateUserEasyPassword::fromJson();
-	UpdateUserEasyPassword();
+	// Private constructor which generates an invalid object, for use withing ServerDiscoveryInfo::fromJson();
+	ServerDiscoveryInfo();
 };
 
 
@@ -110,15 +120,15 @@ private:
 
 namespace Support {
 
-using UpdateUserEasyPassword = Jellyfin::DTO::UpdateUserEasyPassword;
+using ServerDiscoveryInfo = Jellyfin::DTO::ServerDiscoveryInfo;
 
 template <>
-UpdateUserEasyPassword fromJsonValue(const QJsonValue &source, convertType<UpdateUserEasyPassword>);
+ServerDiscoveryInfo fromJsonValue(const QJsonValue &source, convertType<ServerDiscoveryInfo>);
 
 template<>
-QJsonValue toJsonValue(const UpdateUserEasyPassword &source, convertType<UpdateUserEasyPassword>);
+QJsonValue toJsonValue(const ServerDiscoveryInfo &source, convertType<ServerDiscoveryInfo>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_UPDATEUSEREASYPASSWORD_H
+#endif // JELLYFIN_DTO_SERVERDISCOVERYINFO_H
diff --git a/core/include/JellyfinQt/dto/serverrestartingmessage.h b/core/include/JellyfinQt/dto/serverrestartingmessage.h
new file mode 100644
index 0000000..e595994
--- /dev/null
+++ b/core/include/JellyfinQt/dto/serverrestartingmessage.h
@@ -0,0 +1,108 @@
+/*
+ * 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_DTO_SERVERRESTARTINGMESSAGE_H
+#define JELLYFIN_DTO_SERVERRESTARTINGMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ServerRestartingMessage {
+public:
+	ServerRestartingMessage(	
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ServerRestartingMessage(const ServerRestartingMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ServerRestartingMessage &other);
+	
+	static ServerRestartingMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ServerRestartingMessage::fromJson();
+	ServerRestartingMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ServerRestartingMessage = Jellyfin::DTO::ServerRestartingMessage;
+
+template <>
+ServerRestartingMessage fromJsonValue(const QJsonValue &source, convertType<ServerRestartingMessage>);
+
+template<>
+QJsonValue toJsonValue(const ServerRestartingMessage &source, convertType<ServerRestartingMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SERVERRESTARTINGMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/servershuttingdownmessage.h b/core/include/JellyfinQt/dto/servershuttingdownmessage.h
new file mode 100644
index 0000000..5997e4d
--- /dev/null
+++ b/core/include/JellyfinQt/dto/servershuttingdownmessage.h
@@ -0,0 +1,108 @@
+/*
+ * 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_DTO_SERVERSHUTTINGDOWNMESSAGE_H
+#define JELLYFIN_DTO_SERVERSHUTTINGDOWNMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class ServerShuttingDownMessage {
+public:
+	ServerShuttingDownMessage(	
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	ServerShuttingDownMessage(const ServerShuttingDownMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(ServerShuttingDownMessage &other);
+	
+	static ServerShuttingDownMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing ServerShuttingDownMessage::fromJson();
+	ServerShuttingDownMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using ServerShuttingDownMessage = Jellyfin::DTO::ServerShuttingDownMessage;
+
+template <>
+ServerShuttingDownMessage fromJsonValue(const QJsonValue &source, convertType<ServerShuttingDownMessage>);
+
+template<>
+QJsonValue toJsonValue(const ServerShuttingDownMessage &source, convertType<ServerShuttingDownMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SERVERSHUTTINGDOWNMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/sessioninfo.h b/core/include/JellyfinQt/dto/sessioninfodto.h
similarity index 70%
rename from core/include/JellyfinQt/dto/sessioninfo.h
rename to core/include/JellyfinQt/dto/sessioninfodto.h
index dc350ad..a05591f 100644
--- a/core/include/JellyfinQt/dto/sessioninfo.h
+++ b/core/include/JellyfinQt/dto/sessioninfodto.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_SESSIONINFO_H
-#define JELLYFIN_DTO_SESSIONINFO_H
+#ifndef JELLYFIN_DTO_SESSIONINFODTO_H
+#define JELLYFIN_DTO_SESSIONINFODTO_H
 
 #include <QDateTime>
 #include <QJsonObject>
@@ -39,10 +39,10 @@
 #include <QStringList>
 #include <optional>
 
-#include "JellyfinQt/dto/baseitem.h"
 #include "JellyfinQt/dto/baseitemdto.h"
-#include "JellyfinQt/dto/clientcapabilities.h"
+#include "JellyfinQt/dto/clientcapabilitiesdto.h"
 #include "JellyfinQt/dto/generalcommandtype.h"
+#include "JellyfinQt/dto/mediatype.h"
 #include "JellyfinQt/dto/playerstateinfo.h"
 #include "JellyfinQt/dto/queueitem.h"
 #include "JellyfinQt/dto/sessionuserinfo.h"
@@ -57,32 +57,33 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class SessionInfo {
+class SessionInfoDto {
 public:
-	SessionInfo(	
+	SessionInfoDto(	
 		QSharedPointer<PlayerStateInfo> playState,					
-		QSharedPointer<ClientCapabilities> capabilities,									
+		QSharedPointer<ClientCapabilitiesDto> capabilities,					
+		QList<MediaType> playableMediaTypes,					
 		QString userId,							
 		QDateTime lastActivityDate,			
-		QDateTime lastPlaybackCheckIn,							
+		QDateTime lastPlaybackCheckIn,									
 		QSharedPointer<BaseItemDto> nowPlayingItem,			
-		QSharedPointer<BaseItem> fullNowPlayingItem,			
 		QSharedPointer<BaseItemDto> nowViewingItem,							
 		QSharedPointer<TranscodingInfo> transcodingInfo,			
 		bool isActive,			
 		bool supportsMediaControl,			
-		bool supportsRemoteControl,					
-		bool hasCustomDeviceName										
+		bool supportsRemoteControl,							
+		bool hasCustomDeviceName,									
+		QList<GeneralCommandType> supportedCommands		
 	);
 
-	SessionInfo(const SessionInfo &other);
+	SessionInfoDto(const SessionInfoDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(SessionInfo &other);
+	void replaceData(SessionInfoDto &other);
 	
-	static SessionInfo fromJson(QJsonObject source);
+	static SessionInfoDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
@@ -92,17 +93,21 @@ public:
 
 	void setPlayState(QSharedPointer<PlayerStateInfo> newPlayState);
 
-
+	/**
+	 * @brief Gets or sets the additional users.
+	 */
 	QList<SessionUserInfo> additionalUsers() const;
-
+	/**
+	* @brief Gets or sets the additional users.
+	*/
 	void setAdditionalUsers(QList<SessionUserInfo> newAdditionalUsers);
 	bool additionalUsersNull() const;
 	void setAdditionalUsersNull();
 
 
-	QSharedPointer<ClientCapabilities> capabilities() const;
+	QSharedPointer<ClientCapabilitiesDto> capabilities() const;
 
-	void setCapabilities(QSharedPointer<ClientCapabilities> newCapabilities);
+	void setCapabilities(QSharedPointer<ClientCapabilitiesDto> newCapabilities);
 
 	/**
 	 * @brief Gets or sets the remote end point.
@@ -118,13 +123,11 @@ public:
 	/**
 	 * @brief Gets or sets the playable media types.
 	 */
-	QStringList playableMediaTypes() const;
+	QList<MediaType> playableMediaTypes() const;
 	/**
 	* @brief Gets or sets the playable media types.
 	*/
-	void setPlayableMediaTypes(QStringList newPlayableMediaTypes);
-	bool playableMediaTypesNull() const;
-	void setPlayableMediaTypesNull();
+	void setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes);
 
 	/**
 	 * @brief Gets or sets the id.
@@ -186,6 +189,17 @@ public:
 	*/
 	void setLastPlaybackCheckIn(QDateTime newLastPlaybackCheckIn);
 
+	/**
+	 * @brief Gets or sets the last paused date.
+	 */
+	QDateTime lastPausedDate() const;
+	/**
+	* @brief Gets or sets the last paused date.
+	*/
+	void setLastPausedDate(QDateTime newLastPausedDate);
+	bool lastPausedDateNull() const;
+	void setLastPausedDateNull();
+
 	/**
 	 * @brief Gets or sets the name of the device.
 	 */
@@ -214,11 +228,6 @@ public:
 	void setNowPlayingItem(QSharedPointer<BaseItemDto> newNowPlayingItem);
 
 
-	QSharedPointer<BaseItem> fullNowPlayingItem() const;
-
-	void setFullNowPlayingItem(QSharedPointer<BaseItem> newFullNowPlayingItem);
-
-
 	QSharedPointer<BaseItemDto> nowViewingItem() const;
 
 	void setNowViewingItem(QSharedPointer<BaseItemDto> newNowViewingItem);
@@ -251,53 +260,92 @@ public:
 	void setTranscodingInfo(QSharedPointer<TranscodingInfo> newTranscodingInfo);
 
 	/**
-	 * @brief Gets a value indicating whether this instance is active.
+	 * @brief Gets or sets a value indicating whether this session is active.
 	 */
 	bool isActive() const;
 	/**
-	* @brief Gets a value indicating whether this instance is active.
+	* @brief Gets or sets a value indicating whether this session is active.
 	*/
 	void setIsActive(bool newIsActive);
 
-
+	/**
+	 * @brief Gets or sets a value indicating whether the session supports media control.
+	 */
 	bool supportsMediaControl() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether the session supports media control.
+	*/
 	void setSupportsMediaControl(bool newSupportsMediaControl);
 
-
+	/**
+	 * @brief Gets or sets a value indicating whether the session supports remote control.
+	 */
 	bool supportsRemoteControl() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether the session supports remote control.
+	*/
 	void setSupportsRemoteControl(bool newSupportsRemoteControl);
 
-
+	/**
+	 * @brief Gets or sets the now playing queue.
+	 */
 	QList<QueueItem> nowPlayingQueue() const;
-
+	/**
+	* @brief Gets or sets the now playing queue.
+	*/
 	void setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue);
 	bool nowPlayingQueueNull() const;
 	void setNowPlayingQueueNull();
 
+	/**
+	 * @brief Gets or sets the now playing queue full items.
+	 */
+	QList<BaseItemDto> nowPlayingQueueFullItems() const;
+	/**
+	* @brief Gets or sets the now playing queue full items.
+	*/
+	void setNowPlayingQueueFullItems(QList<BaseItemDto> newNowPlayingQueueFullItems);
+	bool nowPlayingQueueFullItemsNull() const;
+	void setNowPlayingQueueFullItemsNull();
 
+	/**
+	 * @brief Gets or sets a value indicating whether the session has a custom device name.
+	 */
 	bool hasCustomDeviceName() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether the session has a custom device name.
+	*/
 	void setHasCustomDeviceName(bool newHasCustomDeviceName);
 
-
+	/**
+	 * @brief Gets or sets the playlist item id.
+	 */
 	QString playlistItemId() const;
-
+	/**
+	* @brief Gets or sets the playlist item id.
+	*/
 	void setPlaylistItemId(QString newPlaylistItemId);
 	bool playlistItemIdNull() const;
 	void setPlaylistItemIdNull();
 
-
+	/**
+	 * @brief Gets or sets the server id.
+	 */
 	QString serverId() const;
-
+	/**
+	* @brief Gets or sets the server id.
+	*/
 	void setServerId(QString newServerId);
 	bool serverIdNull() const;
 	void setServerIdNull();
 
-
+	/**
+	 * @brief Gets or sets the user primary image tag.
+	 */
 	QString userPrimaryImageTag() const;
-
+	/**
+	* @brief Gets or sets the user primary image tag.
+	*/
 	void setUserPrimaryImageTag(QString newUserPrimaryImageTag);
 	bool userPrimaryImageTagNull() const;
 	void setUserPrimaryImageTagNull();
@@ -310,26 +358,24 @@ public:
 	* @brief Gets or sets the supported commands.
 	*/
 	void setSupportedCommands(QList<GeneralCommandType> newSupportedCommands);
-	bool supportedCommandsNull() const;
-	void setSupportedCommandsNull();
 
 
 protected:
 	QSharedPointer<PlayerStateInfo> m_playState = QSharedPointer<PlayerStateInfo>();
 	QList<SessionUserInfo> m_additionalUsers;
-	QSharedPointer<ClientCapabilities> m_capabilities = QSharedPointer<ClientCapabilities>();
+	QSharedPointer<ClientCapabilitiesDto> m_capabilities = QSharedPointer<ClientCapabilitiesDto>();
 	QString m_remoteEndPoint;
-	QStringList m_playableMediaTypes;
+	QList<MediaType> m_playableMediaTypes;
 	QString m_jellyfinId;
 	QString m_userId;
 	QString m_userName;
 	QString m_client;
 	QDateTime m_lastActivityDate;
 	QDateTime m_lastPlaybackCheckIn;
+	QDateTime m_lastPausedDate;
 	QString m_deviceName;
 	QString m_deviceType;
 	QSharedPointer<BaseItemDto> m_nowPlayingItem = QSharedPointer<BaseItemDto>();
-	QSharedPointer<BaseItem> m_fullNowPlayingItem = QSharedPointer<BaseItem>();
 	QSharedPointer<BaseItemDto> m_nowViewingItem = QSharedPointer<BaseItemDto>();
 	QString m_deviceId;
 	QString m_applicationVersion;
@@ -338,6 +384,7 @@ protected:
 	bool m_supportsMediaControl;
 	bool m_supportsRemoteControl;
 	QList<QueueItem> m_nowPlayingQueue;
+	QList<BaseItemDto> m_nowPlayingQueueFullItems;
 	bool m_hasCustomDeviceName;
 	QString m_playlistItemId;
 	QString m_serverId;
@@ -345,8 +392,8 @@ protected:
 	QList<GeneralCommandType> m_supportedCommands;
 
 private:
-	// Private constructor which generates an invalid object, for use withing SessionInfo::fromJson();
-	SessionInfo();
+	// Private constructor which generates an invalid object, for use withing SessionInfoDto::fromJson();
+	SessionInfoDto();
 };
 
 
@@ -354,15 +401,15 @@ private:
 
 namespace Support {
 
-using SessionInfo = Jellyfin::DTO::SessionInfo;
+using SessionInfoDto = Jellyfin::DTO::SessionInfoDto;
 
 template <>
-SessionInfo fromJsonValue(const QJsonValue &source, convertType<SessionInfo>);
+SessionInfoDto fromJsonValue(const QJsonValue &source, convertType<SessionInfoDto>);
 
 template<>
-QJsonValue toJsonValue(const SessionInfo &source, convertType<SessionInfo>);
+QJsonValue toJsonValue(const SessionInfoDto &source, convertType<SessionInfoDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_SESSIONINFO_H
+#endif // JELLYFIN_DTO_SESSIONINFODTO_H
diff --git a/core/include/JellyfinQt/dto/sessionmessagetype.h b/core/include/JellyfinQt/dto/sessionmessagetype.h
new file mode 100644
index 0000000..5376d09
--- /dev/null
+++ b/core/include/JellyfinQt/dto/sessionmessagetype.h
@@ -0,0 +1,108 @@
+/*
+ * 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_DTO_SESSIONMESSAGETYPE_H
+#define JELLYFIN_DTO_SESSIONMESSAGETYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class SessionMessageTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		ForceKeepAlive,
+		GeneralCommand,
+		UserDataChanged,
+		Sessions,
+		Play,
+		SyncPlayCommand,
+		SyncPlayGroupUpdate,
+		Playstate,
+		RestartRequired,
+		ServerShuttingDown,
+		ServerRestarting,
+		LibraryChanged,
+		UserDeleted,
+		UserUpdated,
+		SeriesTimerCreated,
+		TimerCreated,
+		SeriesTimerCancelled,
+		TimerCancelled,
+		RefreshProgress,
+		ScheduledTaskEnded,
+		PackageInstallationCancelled,
+		PackageInstallationFailed,
+		PackageInstallationCompleted,
+		PackageInstalling,
+		PackageUninstalled,
+		ActivityLogEntry,
+		ScheduledTasksInfo,
+		ActivityLogEntryStart,
+		ActivityLogEntryStop,
+		SessionsStart,
+		SessionsStop,
+		ScheduledTasksInfoStart,
+		ScheduledTasksInfoStop,
+		KeepAlive,
+	};
+	Q_ENUM(Value)
+private:
+	explicit SessionMessageTypeClass();
+};
+
+using SessionMessageType = SessionMessageTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using SessionMessageType = Jellyfin::DTO::SessionMessageType;
+
+template <>
+SessionMessageType fromJsonValue(const QJsonValue &source, convertType<SessionMessageType>);
+
+template <>
+QJsonValue toJsonValue(const SessionMessageType &source, convertType<SessionMessageType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SESSIONMESSAGETYPE_H
diff --git a/core/include/JellyfinQt/dto/notificationresultdto.h b/core/include/JellyfinQt/dto/sessionsmessage.h
similarity index 59%
rename from core/include/JellyfinQt/dto/notificationresultdto.h
rename to core/include/JellyfinQt/dto/sessionsmessage.h
index 13b5a1d..6a4ac53 100644
--- a/core/include/JellyfinQt/dto/notificationresultdto.h
+++ b/core/include/JellyfinQt/dto/sessionsmessage.h
@@ -27,16 +27,18 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_NOTIFICATIONRESULTDTO_H
-#define JELLYFIN_DTO_NOTIFICATIONRESULTDTO_H
+#ifndef JELLYFIN_DTO_SESSIONSMESSAGE_H
+#define JELLYFIN_DTO_SESSIONSMESSAGE_H
 
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QList>
+#include <QString>
 #include <QStringList>
 #include <optional>
 
-#include "JellyfinQt/dto/notificationdto.h"
+#include "JellyfinQt/dto/sessioninfodto.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -47,52 +49,59 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class NotificationResultDto {
+class SessionsMessage {
 public:
-	NotificationResultDto(			
-		qint32 totalRecordCount		
+	SessionsMessage(			
+		QString messageId,			
+		SessionMessageType messageType		
 	);
 
-	NotificationResultDto(const NotificationResultDto &other);
+	SessionsMessage(const SessionsMessage &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(NotificationResultDto &other);
+	void replaceData(SessionsMessage &other);
 	
-	static NotificationResultDto fromJson(QJsonObject source);
+	static SessionsMessage fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the current page of notifications.
+	 * @brief Gets or sets the data.
 	 */
-	QList<NotificationDto> notifications() const;
+	QList<SessionInfoDto> data() const;
 	/**
-	* @brief Gets or sets the current page of notifications.
+	* @brief Gets or sets the data.
 	*/
-	void setNotifications(QList<NotificationDto> newNotifications);
-	bool notificationsNull() const;
-	void setNotificationsNull();
+	void setData(QList<SessionInfoDto> newData);
+	bool dataNull() const;
+	void setDataNull();
 
 	/**
-	 * @brief Gets or sets the total number of notifications.
+	 * @brief Gets or sets the message id.
 	 */
-	qint32 totalRecordCount() const;
+	QString messageId() const;
 	/**
-	* @brief Gets or sets the total number of notifications.
+	* @brief Gets or sets the message id.
 	*/
-	void setTotalRecordCount(qint32 newTotalRecordCount);
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
 
 
 protected:
-	QList<NotificationDto> m_notifications;
-	qint32 m_totalRecordCount;
+	QList<SessionInfoDto> m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
 
 private:
-	// Private constructor which generates an invalid object, for use withing NotificationResultDto::fromJson();
-	NotificationResultDto();
+	// Private constructor which generates an invalid object, for use withing SessionsMessage::fromJson();
+	SessionsMessage();
 };
 
 
@@ -100,15 +109,15 @@ private:
 
 namespace Support {
 
-using NotificationResultDto = Jellyfin::DTO::NotificationResultDto;
+using SessionsMessage = Jellyfin::DTO::SessionsMessage;
 
 template <>
-NotificationResultDto fromJsonValue(const QJsonValue &source, convertType<NotificationResultDto>);
+SessionsMessage fromJsonValue(const QJsonValue &source, convertType<SessionsMessage>);
 
 template<>
-QJsonValue toJsonValue(const NotificationResultDto &source, convertType<NotificationResultDto>);
+QJsonValue toJsonValue(const SessionsMessage &source, convertType<SessionsMessage>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_NOTIFICATIONRESULTDTO_H
+#endif // JELLYFIN_DTO_SESSIONSMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/sessionsstartmessage.h b/core/include/JellyfinQt/dto/sessionsstartmessage.h
new file mode 100644
index 0000000..218c6a6
--- /dev/null
+++ b/core/include/JellyfinQt/dto/sessionsstartmessage.h
@@ -0,0 +1,109 @@
+/*
+ * 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_DTO_SESSIONSSTARTMESSAGE_H
+#define JELLYFIN_DTO_SESSIONSSTARTMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SessionsStartMessage {
+public:
+	SessionsStartMessage(			
+		SessionMessageType messageType		
+	);
+
+	SessionsStartMessage(const SessionsStartMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SessionsStartMessage &other);
+	
+	static SessionsStartMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QString data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QString newData);
+	bool dataNull() const;
+	void setDataNull();
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_data;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SessionsStartMessage::fromJson();
+	SessionsStartMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SessionsStartMessage = Jellyfin::DTO::SessionsStartMessage;
+
+template <>
+SessionsStartMessage fromJsonValue(const QJsonValue &source, convertType<SessionsStartMessage>);
+
+template<>
+QJsonValue toJsonValue(const SessionsStartMessage &source, convertType<SessionsStartMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SESSIONSSTARTMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/deviceoptions.h b/core/include/JellyfinQt/dto/sessionsstopmessage.h
similarity index 65%
rename from core/include/JellyfinQt/dto/deviceoptions.h
rename to core/include/JellyfinQt/dto/sessionsstopmessage.h
index 5ac1546..de5595d 100644
--- a/core/include/JellyfinQt/dto/deviceoptions.h
+++ b/core/include/JellyfinQt/dto/sessionsstopmessage.h
@@ -27,14 +27,14 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_DEVICEOPTIONS_H
-#define JELLYFIN_DTO_DEVICEOPTIONS_H
+#ifndef JELLYFIN_DTO_SESSIONSSTOPMESSAGE_H
+#define JELLYFIN_DTO_SESSIONSSTOPMESSAGE_H
 
 #include <QJsonObject>
 #include <QJsonValue>
-#include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/sessionmessagetype.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -45,32 +45,36 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class DeviceOptions {
-public:	DeviceOptions();
-	DeviceOptions(const DeviceOptions &other);
+class SessionsStopMessage {
+public:
+	SessionsStopMessage(	
+		SessionMessageType messageType		
+	);
+
+	SessionsStopMessage(const SessionsStopMessage &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(DeviceOptions &other);
+	void replaceData(SessionsStopMessage &other);
 	
-	static DeviceOptions fromJson(QJsonObject source);
+	static SessionsStopMessage fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 
-	QString customName() const;
+	SessionMessageType messageType() const;
 
-	void setCustomName(QString newCustomName);
-	bool customNameNull() const;
-	void setCustomNameNull();
+	void setMessageType(SessionMessageType newMessageType);
 
 
 protected:
-	QString m_customName;
-
+	SessionMessageType m_messageType;
 
+private:
+	// Private constructor which generates an invalid object, for use withing SessionsStopMessage::fromJson();
+	SessionsStopMessage();
 };
 
 
@@ -78,15 +82,15 @@ protected:
 
 namespace Support {
 
-using DeviceOptions = Jellyfin::DTO::DeviceOptions;
+using SessionsStopMessage = Jellyfin::DTO::SessionsStopMessage;
 
 template <>
-DeviceOptions fromJsonValue(const QJsonValue &source, convertType<DeviceOptions>);
+SessionsStopMessage fromJsonValue(const QJsonValue &source, convertType<SessionsStopMessage>);
 
 template<>
-QJsonValue toJsonValue(const DeviceOptions &source, convertType<DeviceOptions>);
+QJsonValue toJsonValue(const SessionsStopMessage &source, convertType<SessionsStopMessage>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_DEVICEOPTIONS_H
+#endif // JELLYFIN_DTO_SESSIONSSTOPMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/songinfo.h b/core/include/JellyfinQt/dto/songinfo.h
index fc10afa..fe0efae 100644
--- a/core/include/JellyfinQt/dto/songinfo.h
+++ b/core/include/JellyfinQt/dto/songinfo.h
@@ -50,7 +50,7 @@ namespace DTO {
 
 class SongInfo {
 public:
-	SongInfo(																			
+	SongInfo(																					
 		bool isAutomated								
 	);
 
@@ -77,6 +77,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -182,6 +193,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/objectgroupupdate.h b/core/include/JellyfinQt/dto/stringgroupupdate.h
similarity index 76%
rename from core/include/JellyfinQt/dto/objectgroupupdate.h
rename to core/include/JellyfinQt/dto/stringgroupupdate.h
index 5635b80..4d731db 100644
--- a/core/include/JellyfinQt/dto/objectgroupupdate.h
+++ b/core/include/JellyfinQt/dto/stringgroupupdate.h
@@ -27,13 +27,12 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_OBJECTGROUPUPDATE_H
-#define JELLYFIN_DTO_OBJECTGROUPUPDATE_H
+#ifndef JELLYFIN_DTO_STRINGGROUPUPDATE_H
+#define JELLYFIN_DTO_STRINGGROUPUPDATE_H
 
 #include <QJsonObject>
 #include <QJsonValue>
 #include <QString>
-#include <QVariant>
 #include <optional>
 
 #include "JellyfinQt/dto/groupupdatetype.h"
@@ -47,22 +46,22 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class ObjectGroupUpdate {
+class StringGroupUpdate {
 public:
-	ObjectGroupUpdate(	
+	StringGroupUpdate(	
 		QString groupId,			
 		GroupUpdateType type,			
-		QVariant data		
+		QString data		
 	);
 
-	ObjectGroupUpdate(const ObjectGroupUpdate &other);
+	StringGroupUpdate(const StringGroupUpdate &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(ObjectGroupUpdate &other);
+	void replaceData(StringGroupUpdate &other);
 	
-	static ObjectGroupUpdate fromJson(QJsonObject source);
+	static StringGroupUpdate fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
@@ -84,21 +83,21 @@ public:
 	/**
 	 * @brief Gets the update data.
 	 */
-	QVariant data() const;
+	QString data() const;
 	/**
 	* @brief Gets the update data.
 	*/
-	void setData(QVariant newData);
+	void setData(QString newData);
 
 
 protected:
 	QString m_groupId;
 	GroupUpdateType m_type;
-	QVariant m_data;
+	QString m_data;
 
 private:
-	// Private constructor which generates an invalid object, for use withing ObjectGroupUpdate::fromJson();
-	ObjectGroupUpdate();
+	// Private constructor which generates an invalid object, for use withing StringGroupUpdate::fromJson();
+	StringGroupUpdate();
 };
 
 
@@ -106,15 +105,15 @@ private:
 
 namespace Support {
 
-using ObjectGroupUpdate = Jellyfin::DTO::ObjectGroupUpdate;
+using StringGroupUpdate = Jellyfin::DTO::StringGroupUpdate;
 
 template <>
-ObjectGroupUpdate fromJsonValue(const QJsonValue &source, convertType<ObjectGroupUpdate>);
+StringGroupUpdate fromJsonValue(const QJsonValue &source, convertType<StringGroupUpdate>);
 
 template<>
-QJsonValue toJsonValue(const ObjectGroupUpdate &source, convertType<ObjectGroupUpdate>);
+QJsonValue toJsonValue(const StringGroupUpdate &source, convertType<StringGroupUpdate>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_OBJECTGROUPUPDATE_H
+#endif // JELLYFIN_DTO_STRINGGROUPUPDATE_H
diff --git a/core/include/JellyfinQt/dto/subtitledeliverymethod.h b/core/include/JellyfinQt/dto/subtitledeliverymethod.h
index 21118fc..6167ecf 100644
--- a/core/include/JellyfinQt/dto/subtitledeliverymethod.h
+++ b/core/include/JellyfinQt/dto/subtitledeliverymethod.h
@@ -52,6 +52,7 @@ public:
 		Embed,
 		External,
 		Hls,
+		Drop,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/subtitleoptions.h b/core/include/JellyfinQt/dto/subtitleoptions.h
new file mode 100644
index 0000000..188f6b6
--- /dev/null
+++ b/core/include/JellyfinQt/dto/subtitleoptions.h
@@ -0,0 +1,157 @@
+/*
+ * 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_DTO_SUBTITLEOPTIONS_H
+#define JELLYFIN_DTO_SUBTITLEOPTIONS_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SubtitleOptions {
+public:
+	SubtitleOptions(	
+		bool skipIfEmbeddedSubtitlesPresent,			
+		bool skipIfAudioTrackMatches,					
+		bool downloadMovieSubtitles,			
+		bool downloadEpisodeSubtitles,							
+		bool isOpenSubtitleVipAccount,			
+		bool requirePerfectMatch		
+	);
+
+	SubtitleOptions(const SubtitleOptions &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SubtitleOptions &other);
+	
+	static SubtitleOptions fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	bool skipIfEmbeddedSubtitlesPresent() const;
+
+	void setSkipIfEmbeddedSubtitlesPresent(bool newSkipIfEmbeddedSubtitlesPresent);
+
+
+	bool skipIfAudioTrackMatches() const;
+
+	void setSkipIfAudioTrackMatches(bool newSkipIfAudioTrackMatches);
+
+
+	QStringList downloadLanguages() const;
+
+	void setDownloadLanguages(QStringList newDownloadLanguages);
+	bool downloadLanguagesNull() const;
+	void setDownloadLanguagesNull();
+
+
+	bool downloadMovieSubtitles() const;
+
+	void setDownloadMovieSubtitles(bool newDownloadMovieSubtitles);
+
+
+	bool downloadEpisodeSubtitles() const;
+
+	void setDownloadEpisodeSubtitles(bool newDownloadEpisodeSubtitles);
+
+
+	QString openSubtitlesUsername() const;
+
+	void setOpenSubtitlesUsername(QString newOpenSubtitlesUsername);
+	bool openSubtitlesUsernameNull() const;
+	void setOpenSubtitlesUsernameNull();
+
+
+	QString openSubtitlesPasswordHash() const;
+
+	void setOpenSubtitlesPasswordHash(QString newOpenSubtitlesPasswordHash);
+	bool openSubtitlesPasswordHashNull() const;
+	void setOpenSubtitlesPasswordHashNull();
+
+
+	bool isOpenSubtitleVipAccount() const;
+
+	void setIsOpenSubtitleVipAccount(bool newIsOpenSubtitleVipAccount);
+
+
+	bool requirePerfectMatch() const;
+
+	void setRequirePerfectMatch(bool newRequirePerfectMatch);
+
+
+protected:
+	bool m_skipIfEmbeddedSubtitlesPresent;
+	bool m_skipIfAudioTrackMatches;
+	QStringList m_downloadLanguages;
+	bool m_downloadMovieSubtitles;
+	bool m_downloadEpisodeSubtitles;
+	QString m_openSubtitlesUsername;
+	QString m_openSubtitlesPasswordHash;
+	bool m_isOpenSubtitleVipAccount;
+	bool m_requirePerfectMatch;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SubtitleOptions::fromJson();
+	SubtitleOptions();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SubtitleOptions = Jellyfin::DTO::SubtitleOptions;
+
+template <>
+SubtitleOptions fromJsonValue(const QJsonValue &source, convertType<SubtitleOptions>);
+
+template<>
+QJsonValue toJsonValue(const SubtitleOptions &source, convertType<SubtitleOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SUBTITLEOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/subtitleprofile.h b/core/include/JellyfinQt/dto/subtitleprofile.h
index 303dd01..6b29265 100644
--- a/core/include/JellyfinQt/dto/subtitleprofile.h
+++ b/core/include/JellyfinQt/dto/subtitleprofile.h
@@ -64,9 +64,13 @@ public:
 	QJsonObject toJson() const;
 	
 	// Properties
-
+	/**
+	 * @brief Gets or sets the format.
+	 */
 	QString format() const;
-
+	/**
+	* @brief Gets or sets the format.
+	*/
 	void setFormat(QString newFormat);
 	bool formatNull() const;
 	void setFormatNull();
@@ -76,23 +80,35 @@ public:
 
 	void setMethod(SubtitleDeliveryMethod newMethod);
 
-
+	/**
+	 * @brief Gets or sets the DIDL mode.
+	 */
 	QString didlMode() const;
-
+	/**
+	* @brief Gets or sets the DIDL mode.
+	*/
 	void setDidlMode(QString newDidlMode);
 	bool didlModeNull() const;
 	void setDidlModeNull();
 
-
+	/**
+	 * @brief Gets or sets the language.
+	 */
 	QString language() const;
-
+	/**
+	* @brief Gets or sets the language.
+	*/
 	void setLanguage(QString newLanguage);
 	bool languageNull() const;
 	void setLanguageNull();
 
-
+	/**
+	 * @brief Gets or sets the container.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the container.
+	*/
 	void setContainer(QString newContainer);
 	bool containerNull() const;
 	void setContainerNull();
diff --git a/core/include/JellyfinQt/dto/syncplaycommandmessage.h b/core/include/JellyfinQt/dto/syncplaycommandmessage.h
new file mode 100644
index 0000000..77c8ab3
--- /dev/null
+++ b/core/include/JellyfinQt/dto/syncplaycommandmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_SYNCPLAYCOMMANDMESSAGE_H
+#define JELLYFIN_DTO_SYNCPLAYCOMMANDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sendcommand.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SyncPlayCommandMessage {
+public:
+	SyncPlayCommandMessage(	
+		QSharedPointer<SendCommand> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	SyncPlayCommandMessage(const SyncPlayCommandMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SyncPlayCommandMessage &other);
+	
+	static SyncPlayCommandMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<SendCommand> data() const;
+
+	void setData(QSharedPointer<SendCommand> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<SendCommand> m_data = QSharedPointer<SendCommand>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SyncPlayCommandMessage::fromJson();
+	SyncPlayCommandMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayCommandMessage = Jellyfin::DTO::SyncPlayCommandMessage;
+
+template <>
+SyncPlayCommandMessage fromJsonValue(const QJsonValue &source, convertType<SyncPlayCommandMessage>);
+
+template<>
+QJsonValue toJsonValue(const SyncPlayCommandMessage &source, convertType<SyncPlayCommandMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SYNCPLAYCOMMANDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/syncplaygroupupdatecommandmessage.h b/core/include/JellyfinQt/dto/syncplaygroupupdatecommandmessage.h
new file mode 100644
index 0000000..f55e414
--- /dev/null
+++ b/core/include/JellyfinQt/dto/syncplaygroupupdatecommandmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_SYNCPLAYGROUPUPDATECOMMANDMESSAGE_H
+#define JELLYFIN_DTO_SYNCPLAYGROUPUPDATECOMMANDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/groupupdate.h"
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SyncPlayGroupUpdateCommandMessage {
+public:
+	SyncPlayGroupUpdateCommandMessage(	
+		QSharedPointer<GroupUpdate> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	SyncPlayGroupUpdateCommandMessage(const SyncPlayGroupUpdateCommandMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SyncPlayGroupUpdateCommandMessage &other);
+	
+	static SyncPlayGroupUpdateCommandMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<GroupUpdate> data() const;
+
+	void setData(QSharedPointer<GroupUpdate> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<GroupUpdate> m_data = QSharedPointer<GroupUpdate>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SyncPlayGroupUpdateCommandMessage::fromJson();
+	SyncPlayGroupUpdateCommandMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayGroupUpdateCommandMessage = Jellyfin::DTO::SyncPlayGroupUpdateCommandMessage;
+
+template <>
+SyncPlayGroupUpdateCommandMessage fromJsonValue(const QJsonValue &source, convertType<SyncPlayGroupUpdateCommandMessage>);
+
+template<>
+QJsonValue toJsonValue(const SyncPlayGroupUpdateCommandMessage &source, convertType<SyncPlayGroupUpdateCommandMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SYNCPLAYGROUPUPDATECOMMANDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/syncplayqueueitem.h b/core/include/JellyfinQt/dto/syncplayqueueitem.h
new file mode 100644
index 0000000..aa89d5a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/syncplayqueueitem.h
@@ -0,0 +1,111 @@
+/*
+ * 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_DTO_SYNCPLAYQUEUEITEM_H
+#define JELLYFIN_DTO_SYNCPLAYQUEUEITEM_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class SyncPlayQueueItem {
+public:
+	SyncPlayQueueItem(	
+		QString itemId,			
+		QString playlistItemId		
+	);
+
+	SyncPlayQueueItem(const SyncPlayQueueItem &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(SyncPlayQueueItem &other);
+	
+	static SyncPlayQueueItem fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets the item identifier.
+	 */
+	QString itemId() const;
+	/**
+	* @brief Gets the item identifier.
+	*/
+	void setItemId(QString newItemId);
+
+	/**
+	 * @brief Gets the playlist identifier of the item.
+	 */
+	QString playlistItemId() const;
+	/**
+	* @brief Gets the playlist identifier of the item.
+	*/
+	void setPlaylistItemId(QString newPlaylistItemId);
+
+
+protected:
+	QString m_itemId;
+	QString m_playlistItemId;
+
+private:
+	// Private constructor which generates an invalid object, for use withing SyncPlayQueueItem::fromJson();
+	SyncPlayQueueItem();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayQueueItem = Jellyfin::DTO::SyncPlayQueueItem;
+
+template <>
+SyncPlayQueueItem fromJsonValue(const QJsonValue &source, convertType<SyncPlayQueueItem>);
+
+template<>
+QJsonValue toJsonValue(const SyncPlayQueueItem &source, convertType<SyncPlayQueueItem>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_SYNCPLAYQUEUEITEM_H
diff --git a/core/include/JellyfinQt/dto/systeminfo.h b/core/include/JellyfinQt/dto/systeminfo.h
index fb5d31e..b96f380 100644
--- a/core/include/JellyfinQt/dto/systeminfo.h
+++ b/core/include/JellyfinQt/dto/systeminfo.h
@@ -37,8 +37,7 @@
 #include <QStringList>
 #include <optional>
 
-#include "JellyfinQt/dto/architecture.h"
-#include "JellyfinQt/dto/ffmpeglocation.h"
+#include "JellyfinQt/dto/castreceiverapplication.h"
 #include "JellyfinQt/dto/installationinfo.h"
 #include "JellyfinQt/support/jsonconv.h"
 
@@ -57,11 +56,9 @@ public:
 		bool isShuttingDown,			
 		bool supportsLibraryMonitor,			
 		qint32 webSocketPortNumber,					
-		bool canSelfRestart,			
-		bool canLaunchWebBrowser,																	
-		bool hasUpdateAvailable,			
-		FFmpegLocation encoderLocation,			
-		Architecture systemArchitecture		
+		std::optional<bool> canSelfRestart,			
+		std::optional<bool> canLaunchWebBrowser,																			
+		std::optional<bool> hasUpdateAvailable						
 	);
 
 	SystemInfo(const SystemInfo &other);
@@ -165,11 +162,11 @@ public:
 	void setOperatingSystemDisplayNameNull();
 
 	/**
-	 * @brief Get or sets the package name.
+	 * @brief Gets or sets the package name.
 	 */
 	QString packageName() const;
 	/**
-	* @brief Get or sets the package name.
+	* @brief Gets or sets the package name.
 	*/
 	void setPackageName(QString newPackageName);
 	bool packageNameNull() const;
@@ -221,16 +218,16 @@ public:
 	/**
 	 * @brief Gets or sets a value indicating whether this instance can self restart.
 	 */
-	bool canSelfRestart() const;
+	std::optional<bool> canSelfRestart() const;
 	/**
 	* @brief Gets or sets a value indicating whether this instance can self restart.
 	*/
-	void setCanSelfRestart(bool newCanSelfRestart);
+	void setCanSelfRestart(std::optional<bool> newCanSelfRestart);
 
 
-	bool canLaunchWebBrowser() const;
+	std::optional<bool> canLaunchWebBrowser() const;
 
-	void setCanLaunchWebBrowser(bool newCanLaunchWebBrowser);
+	void setCanLaunchWebBrowser(std::optional<bool> newCanLaunchWebBrowser);
 
 	/**
 	 * @brief Gets or sets the program data path.
@@ -309,24 +306,39 @@ public:
 	bool transcodingTempPathNull() const;
 	void setTranscodingTempPathNull();
 
+	/**
+	 * @brief Gets or sets the list of cast receiver applications.
+	 */
+	QList<CastReceiverApplication> castReceiverApplications() const;
+	/**
+	* @brief Gets or sets the list of cast receiver applications.
+	*/
+	void setCastReceiverApplications(QList<CastReceiverApplication> newCastReceiverApplications);
+	bool castReceiverApplicationsNull() const;
+	void setCastReceiverApplicationsNull();
+
 	/**
 	 * @brief Gets or sets a value indicating whether this instance has update available.
 	 */
-	bool hasUpdateAvailable() const;
+	std::optional<bool> hasUpdateAvailable() const;
 	/**
 	* @brief Gets or sets a value indicating whether this instance has update available.
 	*/
-	void setHasUpdateAvailable(bool newHasUpdateAvailable);
+	void setHasUpdateAvailable(std::optional<bool> newHasUpdateAvailable);
 
 
-	FFmpegLocation encoderLocation() const;
+	QString encoderLocation() const;
 
-	void setEncoderLocation(FFmpegLocation newEncoderLocation);
+	void setEncoderLocation(QString newEncoderLocation);
+	bool encoderLocationNull() const;
+	void setEncoderLocationNull();
 
 
-	Architecture systemArchitecture() const;
+	QString systemArchitecture() const;
 
-	void setSystemArchitecture(Architecture newSystemArchitecture);
+	void setSystemArchitecture(QString newSystemArchitecture);
+	bool systemArchitectureNull() const;
+	void setSystemArchitectureNull();
 
 
 protected:
@@ -344,8 +356,8 @@ protected:
 	bool m_supportsLibraryMonitor;
 	qint32 m_webSocketPortNumber;
 	QList<InstallationInfo> m_completedInstallations;
-	bool m_canSelfRestart;
-	bool m_canLaunchWebBrowser;
+	std::optional<bool> m_canSelfRestart = std::nullopt;
+	std::optional<bool> m_canLaunchWebBrowser = std::nullopt;
 	QString m_programDataPath;
 	QString m_webPath;
 	QString m_itemsByNamePath;
@@ -353,9 +365,10 @@ protected:
 	QString m_logPath;
 	QString m_internalMetadataPath;
 	QString m_transcodingTempPath;
-	bool m_hasUpdateAvailable;
-	FFmpegLocation m_encoderLocation;
-	Architecture m_systemArchitecture;
+	QList<CastReceiverApplication> m_castReceiverApplications;
+	std::optional<bool> m_hasUpdateAvailable = std::nullopt;
+	QString m_encoderLocation;
+	QString m_systemArchitecture;
 
 private:
 	// Private constructor which generates an invalid object, for use withing SystemInfo::fromJson();
diff --git a/core/include/JellyfinQt/dto/thememediaresult.h b/core/include/JellyfinQt/dto/thememediaresult.h
index e063c4c..4d66904 100644
--- a/core/include/JellyfinQt/dto/thememediaresult.h
+++ b/core/include/JellyfinQt/dto/thememediaresult.h
@@ -50,7 +50,8 @@ namespace DTO {
 
 class ThemeMediaResult {
 public:
-	ThemeMediaResult(			
+	ThemeMediaResult(	
+		QList<BaseItemDto> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex,			
 		QString ownerId		
@@ -76,24 +77,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<BaseItemDto> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/timercancelledmessage.h b/core/include/JellyfinQt/dto/timercancelledmessage.h
new file mode 100644
index 0000000..781ce32
--- /dev/null
+++ b/core/include/JellyfinQt/dto/timercancelledmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_TIMERCANCELLEDMESSAGE_H
+#define JELLYFIN_DTO_TIMERCANCELLEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/timereventinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class TimerCancelledMessage {
+public:
+	TimerCancelledMessage(	
+		QSharedPointer<TimerEventInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	TimerCancelledMessage(const TimerCancelledMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(TimerCancelledMessage &other);
+	
+	static TimerCancelledMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<TimerEventInfo> data() const;
+
+	void setData(QSharedPointer<TimerEventInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<TimerEventInfo> m_data = QSharedPointer<TimerEventInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing TimerCancelledMessage::fromJson();
+	TimerCancelledMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using TimerCancelledMessage = Jellyfin::DTO::TimerCancelledMessage;
+
+template <>
+TimerCancelledMessage fromJsonValue(const QJsonValue &source, convertType<TimerCancelledMessage>);
+
+template<>
+QJsonValue toJsonValue(const TimerCancelledMessage &source, convertType<TimerCancelledMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TIMERCANCELLEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/timercreatedmessage.h b/core/include/JellyfinQt/dto/timercreatedmessage.h
new file mode 100644
index 0000000..caa47e0
--- /dev/null
+++ b/core/include/JellyfinQt/dto/timercreatedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_TIMERCREATEDMESSAGE_H
+#define JELLYFIN_DTO_TIMERCREATEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/timereventinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class TimerCreatedMessage {
+public:
+	TimerCreatedMessage(	
+		QSharedPointer<TimerEventInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	TimerCreatedMessage(const TimerCreatedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(TimerCreatedMessage &other);
+	
+	static TimerCreatedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<TimerEventInfo> data() const;
+
+	void setData(QSharedPointer<TimerEventInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<TimerEventInfo> m_data = QSharedPointer<TimerEventInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing TimerCreatedMessage::fromJson();
+	TimerCreatedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using TimerCreatedMessage = Jellyfin::DTO::TimerCreatedMessage;
+
+template <>
+TimerCreatedMessage fromJsonValue(const QJsonValue &source, convertType<TimerCreatedMessage>);
+
+template<>
+QJsonValue toJsonValue(const TimerCreatedMessage &source, convertType<TimerCreatedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TIMERCREATEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/timereventinfo.h b/core/include/JellyfinQt/dto/timereventinfo.h
index 9afa5c4..1443d58 100644
--- a/core/include/JellyfinQt/dto/timereventinfo.h
+++ b/core/include/JellyfinQt/dto/timereventinfo.h
@@ -46,7 +46,11 @@ namespace DTO {
 
 
 class TimerEventInfo {
-public:	TimerEventInfo();
+public:
+	TimerEventInfo(	
+		QString jellyfinId				
+	);
+
 	TimerEventInfo(const TimerEventInfo &other);
 	
 	/**
@@ -63,8 +67,6 @@ public:	TimerEventInfo();
 	QString jellyfinId() const;
 
 	void setJellyfinId(QString newJellyfinId);
-	bool jellyfinIdNull() const;
-	void setJellyfinIdNull();
 
 
 	QString programId() const;
@@ -78,7 +80,9 @@ protected:
 	QString m_jellyfinId;
 	QString m_programId;
 
-
+private:
+	// Private constructor which generates an invalid object, for use withing TimerEventInfo::fromJson();
+	TimerEventInfo();
 };
 
 
diff --git a/core/include/JellyfinQt/dto/timerinfodto.h b/core/include/JellyfinQt/dto/timerinfodto.h
index 9384128..d45f14b 100644
--- a/core/include/JellyfinQt/dto/timerinfodto.h
+++ b/core/include/JellyfinQt/dto/timerinfodto.h
@@ -81,11 +81,11 @@ public:
 	
 	// Properties
 	/**
-	 * @brief Id of the recording.
+	 * @brief Gets or sets the Id of the recording.
 	 */
 	QString jellyfinId() const;
 	/**
-	* @brief Id of the recording.
+	* @brief Gets or sets the Id of the recording.
 	*/
 	void setJellyfinId(QString newJellyfinId);
 	bool jellyfinIdNull() const;
@@ -121,11 +121,11 @@ public:
 	void setExternalIdNull();
 
 	/**
-	 * @brief ChannelId of the recording.
+	 * @brief Gets or sets the channel id of the recording.
 	 */
 	QString channelId() const;
 	/**
-	* @brief ChannelId of the recording.
+	* @brief Gets or sets the channel id of the recording.
 	*/
 	void setChannelId(QString newChannelId);
 
@@ -141,11 +141,11 @@ public:
 	void setExternalChannelIdNull();
 
 	/**
-	 * @brief ChannelName of the recording.
+	 * @brief Gets or sets the channel name of the recording.
 	 */
 	QString channelName() const;
 	/**
-	* @brief ChannelName of the recording.
+	* @brief Gets or sets the channel name of the recording.
 	*/
 	void setChannelName(QString newChannelName);
 	bool channelNameNull() const;
@@ -181,42 +181,42 @@ public:
 	void setExternalProgramIdNull();
 
 	/**
-	 * @brief Name of the recording.
+	 * @brief Gets or sets the name of the recording.
 	 */
 	QString name() const;
 	/**
-	* @brief Name of the recording.
+	* @brief Gets or sets the name of the recording.
 	*/
 	void setName(QString newName);
 	bool nameNull() const;
 	void setNameNull();
 
 	/**
-	 * @brief Description of the recording.
+	 * @brief Gets or sets the description of the recording.
 	 */
 	QString overview() const;
 	/**
-	* @brief Description of the recording.
+	* @brief Gets or sets the description of the recording.
 	*/
 	void setOverview(QString newOverview);
 	bool overviewNull() const;
 	void setOverviewNull();
 
 	/**
-	 * @brief The start date of the recording, in UTC.
+	 * @brief Gets or sets the start date of the recording, in UTC.
 	 */
 	QDateTime startDate() const;
 	/**
-	* @brief The start date of the recording, in UTC.
+	* @brief Gets or sets the start date of the recording, in UTC.
 	*/
 	void setStartDate(QDateTime newStartDate);
 
 	/**
-	 * @brief The end date of the recording, in UTC.
+	 * @brief Gets or sets the end date of the recording, in UTC.
 	 */
 	QDateTime endDate() const;
 	/**
-	* @brief The end date of the recording, in UTC.
+	* @brief Gets or sets the end date of the recording, in UTC.
 	*/
 	void setEndDate(QDateTime newEndDate);
 
@@ -268,11 +268,11 @@ public:
 	void setIsPrePaddingRequired(bool newIsPrePaddingRequired);
 
 	/**
-	 * @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	 * @brief Gets or sets the Id of the Parent that has a backdrop if the item does not have one.
 	 */
 	QString parentBackdropItemId() const;
 	/**
-	* @brief If the item does not have any backdrops, this will hold the Id of the Parent that has one.
+	* @brief Gets or sets the Id of the Parent that has a backdrop if the item does not have one.
 	*/
 	void setParentBackdropItemId(QString newParentBackdropItemId);
 	bool parentBackdropItemIdNull() const;
diff --git a/core/include/JellyfinQt/dto/timerinfodtoqueryresult.h b/core/include/JellyfinQt/dto/timerinfodtoqueryresult.h
index 2f17c6e..ca83d46 100644
--- a/core/include/JellyfinQt/dto/timerinfodtoqueryresult.h
+++ b/core/include/JellyfinQt/dto/timerinfodtoqueryresult.h
@@ -49,7 +49,8 @@ namespace DTO {
 
 class TimerInfoDtoQueryResult {
 public:
-	TimerInfoDtoQueryResult(			
+	TimerInfoDtoQueryResult(	
+		QList<TimerInfoDto> items,			
 		qint32 totalRecordCount,			
 		qint32 startIndex		
 	);
@@ -74,24 +75,22 @@ public:
 	* @brief Gets or sets the items.
 	*/
 	void setItems(QList<TimerInfoDto> newItems);
-	bool itemsNull() const;
-	void setItemsNull();
 
 	/**
-	 * @brief The total number of records available.
+	 * @brief Gets or sets the total number of records available.
 	 */
 	qint32 totalRecordCount() const;
 	/**
-	* @brief The total number of records available.
+	* @brief Gets or sets the total number of records available.
 	*/
 	void setTotalRecordCount(qint32 newTotalRecordCount);
 
 	/**
-	 * @brief The index of the first record in Items.
+	 * @brief Gets or sets the index of the first record in Items.
 	 */
 	qint32 startIndex() const;
 	/**
-	* @brief The index of the first record in Items.
+	* @brief Gets or sets the index of the first record in Items.
 	*/
 	void setStartIndex(qint32 newStartIndex);
 
diff --git a/core/include/JellyfinQt/dto/configurationpagetype.h b/core/include/JellyfinQt/dto/tonemappingalgorithm.h
similarity index 74%
rename from core/include/JellyfinQt/dto/configurationpagetype.h
rename to core/include/JellyfinQt/dto/tonemappingalgorithm.h
index 45b5297..51572c6 100644
--- a/core/include/JellyfinQt/dto/configurationpagetype.h
+++ b/core/include/JellyfinQt/dto/tonemappingalgorithm.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_CONFIGURATIONPAGETYPE_H
-#define JELLYFIN_DTO_CONFIGURATIONPAGETYPE_H
+#ifndef JELLYFIN_DTO_TONEMAPPINGALGORITHM_H
+#define JELLYFIN_DTO_TONEMAPPINGALGORITHM_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,34 +43,40 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class ConfigurationPageTypeClass {
+class TonemappingAlgorithmClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
-		PluginConfiguration,
 		None,
+		Clip,
+		Linear,
+		Gamma,
+		Reinhard,
+		Hable,
+		Mobius,
+		Bt2390,
 	};
 	Q_ENUM(Value)
 private:
-	explicit ConfigurationPageTypeClass();
+	explicit TonemappingAlgorithmClass();
 };
 
-using ConfigurationPageType = ConfigurationPageTypeClass::Value;
+using TonemappingAlgorithm = TonemappingAlgorithmClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using ConfigurationPageType = Jellyfin::DTO::ConfigurationPageType;
+using TonemappingAlgorithm = Jellyfin::DTO::TonemappingAlgorithm;
 
 template <>
-ConfigurationPageType fromJsonValue(const QJsonValue &source, convertType<ConfigurationPageType>);
+TonemappingAlgorithm fromJsonValue(const QJsonValue &source, convertType<TonemappingAlgorithm>);
 
 template <>
-QJsonValue toJsonValue(const ConfigurationPageType &source, convertType<ConfigurationPageType>);
+QJsonValue toJsonValue(const TonemappingAlgorithm &source, convertType<TonemappingAlgorithm>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_CONFIGURATIONPAGETYPE_H
+#endif // JELLYFIN_DTO_TONEMAPPINGALGORITHM_H
diff --git a/core/include/JellyfinQt/dto/tonemappingmode.h b/core/include/JellyfinQt/dto/tonemappingmode.h
new file mode 100644
index 0000000..a757817
--- /dev/null
+++ b/core/include/JellyfinQt/dto/tonemappingmode.h
@@ -0,0 +1,79 @@
+/*
+ * 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_DTO_TONEMAPPINGMODE_H
+#define JELLYFIN_DTO_TONEMAPPINGMODE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class TonemappingModeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Automatic,
+		Max,
+		Rgb,
+		Lum,
+		Itp,
+	};
+	Q_ENUM(Value)
+private:
+	explicit TonemappingModeClass();
+};
+
+using TonemappingMode = TonemappingModeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using TonemappingMode = Jellyfin::DTO::TonemappingMode;
+
+template <>
+TonemappingMode fromJsonValue(const QJsonValue &source, convertType<TonemappingMode>);
+
+template <>
+QJsonValue toJsonValue(const TonemappingMode &source, convertType<TonemappingMode>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TONEMAPPINGMODE_H
diff --git a/core/include/JellyfinQt/dto/tonemappingrange.h b/core/include/JellyfinQt/dto/tonemappingrange.h
new file mode 100644
index 0000000..f561665
--- /dev/null
+++ b/core/include/JellyfinQt/dto/tonemappingrange.h
@@ -0,0 +1,77 @@
+/*
+ * 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_DTO_TONEMAPPINGRANGE_H
+#define JELLYFIN_DTO_TONEMAPPINGRANGE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class TonemappingRangeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Automatic,
+		Tv,
+		Pc,
+	};
+	Q_ENUM(Value)
+private:
+	explicit TonemappingRangeClass();
+};
+
+using TonemappingRange = TonemappingRangeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using TonemappingRange = Jellyfin::DTO::TonemappingRange;
+
+template <>
+TonemappingRange fromJsonValue(const QJsonValue &source, convertType<TonemappingRange>);
+
+template <>
+QJsonValue toJsonValue(const TonemappingRange &source, convertType<TonemappingRange>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TONEMAPPINGRANGE_H
diff --git a/core/include/JellyfinQt/dto/trailerinfo.h b/core/include/JellyfinQt/dto/trailerinfo.h
index e58c841..22b6b1c 100644
--- a/core/include/JellyfinQt/dto/trailerinfo.h
+++ b/core/include/JellyfinQt/dto/trailerinfo.h
@@ -48,7 +48,7 @@ namespace DTO {
 
 class TrailerInfo {
 public:
-	TrailerInfo(																			
+	TrailerInfo(																					
 		bool isAutomated		
 	);
 
@@ -75,6 +75,17 @@ public:
 	bool nameNull() const;
 	void setNameNull();
 
+	/**
+	 * @brief Gets or sets the original title.
+	 */
+	QString originalTitle() const;
+	/**
+	* @brief Gets or sets the original title.
+	*/
+	void setOriginalTitle(QString newOriginalTitle);
+	bool originalTitleNull() const;
+	void setOriginalTitleNull();
+
 	/**
 	 * @brief Gets or sets the path.
 	 */
@@ -159,6 +170,7 @@ public:
 
 protected:
 	QString m_name;
+	QString m_originalTitle;
 	QString m_path;
 	QString m_metadataLanguage;
 	QString m_metadataCountryCode;
diff --git a/core/include/JellyfinQt/dto/trailerinforemotesearchquery.h b/core/include/JellyfinQt/dto/trailerinforemotesearchquery.h
index c8d5f00..b42a690 100644
--- a/core/include/JellyfinQt/dto/trailerinforemotesearchquery.h
+++ b/core/include/JellyfinQt/dto/trailerinforemotesearchquery.h
@@ -78,11 +78,11 @@ public:
 	void setItemId(QString newItemId);
 
 	/**
-	 * @brief Will only search within the given provider when set.
+	 * @brief Gets or sets the provider name to search within if set.
 	 */
 	QString searchProviderName() const;
 	/**
-	* @brief Will only search within the given provider when set.
+	* @brief Gets or sets the provider name to search within if set.
 	*/
 	void setSearchProviderName(QString newSearchProviderName);
 	bool searchProviderNameNull() const;
diff --git a/core/include/JellyfinQt/dto/transcodereason.h b/core/include/JellyfinQt/dto/transcodereason.h
index ea5ae58..cae5096 100644
--- a/core/include/JellyfinQt/dto/transcodereason.h
+++ b/core/include/JellyfinQt/dto/transcodereason.h
@@ -51,26 +51,29 @@ public:
 		ContainerNotSupported,
 		VideoCodecNotSupported,
 		AudioCodecNotSupported,
-		ContainerBitrateExceedsLimit,
-		AudioBitrateNotSupported,
-		AudioChannelsNotSupported,
+		SubtitleCodecNotSupported,
+		AudioIsExternal,
+		SecondaryAudioNotSupported,
+		VideoProfileNotSupported,
+		VideoLevelNotSupported,
 		VideoResolutionNotSupported,
-		UnknownVideoStreamInfo,
-		UnknownAudioStreamInfo,
-		AudioProfileNotSupported,
-		AudioSampleRateNotSupported,
+		VideoBitDepthNotSupported,
+		VideoFramerateNotSupported,
+		RefFramesNotSupported,
 		AnamorphicVideoNotSupported,
 		InterlacedVideoNotSupported,
-		SecondaryAudioNotSupported,
-		RefFramesNotSupported,
-		VideoBitDepthNotSupported,
-		VideoBitrateNotSupported,
-		VideoFramerateNotSupported,
-		VideoLevelNotSupported,
-		VideoProfileNotSupported,
+		AudioChannelsNotSupported,
+		AudioProfileNotSupported,
+		AudioSampleRateNotSupported,
 		AudioBitDepthNotSupported,
-		SubtitleCodecNotSupported,
+		ContainerBitrateExceedsLimit,
+		VideoBitrateNotSupported,
+		AudioBitrateNotSupported,
+		UnknownVideoStreamInfo,
+		UnknownAudioStreamInfo,
 		DirectPlayError,
+		VideoRangeTypeNotSupported,
+		VideoCodecTagNotSupported,
 	};
 	Q_ENUM(Value)
 private:
diff --git a/core/include/JellyfinQt/dto/transcodinginfo.h b/core/include/JellyfinQt/dto/transcodinginfo.h
index 6f45e71..da13faa 100644
--- a/core/include/JellyfinQt/dto/transcodinginfo.h
+++ b/core/include/JellyfinQt/dto/transcodinginfo.h
@@ -37,6 +37,7 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/hardwareaccelerationtype.h"
 #include "JellyfinQt/dto/transcodereason.h"
 #include "JellyfinQt/support/jsonconv.h"
 
@@ -52,7 +53,9 @@ class TranscodingInfo {
 public:
 	TranscodingInfo(							
 		bool isVideoDirect,			
-		bool isAudioDirect																
+		bool isAudioDirect,															
+		HardwareAccelerationType hardwareAccelerationType,			
+		QList<TranscodeReason> transcodeReasons		
 	);
 
 	TranscodingInfo(const TranscodingInfo &other);
@@ -67,85 +70,136 @@ public:
 	QJsonObject toJson() const;
 	
 	// Properties
-
+	/**
+	 * @brief Gets or sets the thread count used for encoding.
+	 */
 	QString audioCodec() const;
-
+	/**
+	* @brief Gets or sets the thread count used for encoding.
+	*/
 	void setAudioCodec(QString newAudioCodec);
 	bool audioCodecNull() const;
 	void setAudioCodecNull();
 
-
+	/**
+	 * @brief Gets or sets the thread count used for encoding.
+	 */
 	QString videoCodec() const;
-
+	/**
+	* @brief Gets or sets the thread count used for encoding.
+	*/
 	void setVideoCodec(QString newVideoCodec);
 	bool videoCodecNull() const;
 	void setVideoCodecNull();
 
-
+	/**
+	 * @brief Gets or sets the thread count used for encoding.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the thread count used for encoding.
+	*/
 	void setContainer(QString newContainer);
 	bool containerNull() const;
 	void setContainerNull();
 
-
+	/**
+	 * @brief Gets or sets a value indicating whether the video is passed through.
+	 */
 	bool isVideoDirect() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether the video is passed through.
+	*/
 	void setIsVideoDirect(bool newIsVideoDirect);
 
-
+	/**
+	 * @brief Gets or sets a value indicating whether the audio is passed through.
+	 */
 	bool isAudioDirect() const;
-
+	/**
+	* @brief Gets or sets a value indicating whether the audio is passed through.
+	*/
 	void setIsAudioDirect(bool newIsAudioDirect);
 
-
+	/**
+	 * @brief Gets or sets the bitrate.
+	 */
 	std::optional<qint32> bitrate() const;
-
+	/**
+	* @brief Gets or sets the bitrate.
+	*/
 	void setBitrate(std::optional<qint32> newBitrate);
 	bool bitrateNull() const;
 	void setBitrateNull();
 
-
+	/**
+	 * @brief Gets or sets the framerate.
+	 */
 	std::optional<float> framerate() const;
-
+	/**
+	* @brief Gets or sets the framerate.
+	*/
 	void setFramerate(std::optional<float> newFramerate);
 	bool framerateNull() const;
 	void setFramerateNull();
 
-
+	/**
+	 * @brief Gets or sets the completion percentage.
+	 */
 	std::optional<double> completionPercentage() const;
-
+	/**
+	* @brief Gets or sets the completion percentage.
+	*/
 	void setCompletionPercentage(std::optional<double> newCompletionPercentage);
 	bool completionPercentageNull() const;
 	void setCompletionPercentageNull();
 
-
+	/**
+	 * @brief Gets or sets the video width.
+	 */
 	std::optional<qint32> width() const;
-
+	/**
+	* @brief Gets or sets the video width.
+	*/
 	void setWidth(std::optional<qint32> newWidth);
 	bool widthNull() const;
 	void setWidthNull();
 
-
+	/**
+	 * @brief Gets or sets the video height.
+	 */
 	std::optional<qint32> height() const;
-
+	/**
+	* @brief Gets or sets the video height.
+	*/
 	void setHeight(std::optional<qint32> newHeight);
 	bool heightNull() const;
 	void setHeightNull();
 
-
+	/**
+	 * @brief Gets or sets the audio channels.
+	 */
 	std::optional<qint32> audioChannels() const;
-
+	/**
+	* @brief Gets or sets the audio channels.
+	*/
 	void setAudioChannels(std::optional<qint32> newAudioChannels);
 	bool audioChannelsNull() const;
 	void setAudioChannelsNull();
 
 
-	QList<TranscodeReason> transcodeReasons() const;
+	HardwareAccelerationType hardwareAccelerationType() const;
 
+	void setHardwareAccelerationType(HardwareAccelerationType newHardwareAccelerationType);
+
+	/**
+	 * @brief Gets or sets the transcode reasons.
+	 */
+	QList<TranscodeReason> transcodeReasons() const;
+	/**
+	* @brief Gets or sets the transcode reasons.
+	*/
 	void setTranscodeReasons(QList<TranscodeReason> newTranscodeReasons);
-	bool transcodeReasonsNull() const;
-	void setTranscodeReasonsNull();
 
 
 protected:
@@ -160,6 +214,7 @@ protected:
 	std::optional<qint32> m_width = std::nullopt;
 	std::optional<qint32> m_height = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
+	HardwareAccelerationType m_hardwareAccelerationType;
 	QList<TranscodeReason> m_transcodeReasons;
 
 private:
diff --git a/core/include/JellyfinQt/dto/transcodingprofile.h b/core/include/JellyfinQt/dto/transcodingprofile.h
index 2b1e22a..203d7b3 100644
--- a/core/include/JellyfinQt/dto/transcodingprofile.h
+++ b/core/include/JellyfinQt/dto/transcodingprofile.h
@@ -32,11 +32,15 @@
 
 #include <QJsonObject>
 #include <QJsonValue>
+#include <QList>
 #include <QString>
+#include <QStringList>
 #include <optional>
 
 #include "JellyfinQt/dto/dlnaprofiletype.h"
 #include "JellyfinQt/dto/encodingcontext.h"
+#include "JellyfinQt/dto/mediastreamprotocol.h"
+#include "JellyfinQt/dto/profilecondition.h"
 #include "JellyfinQt/dto/transcodeseekinfo.h"
 #include "JellyfinQt/support/jsonconv.h"
 
@@ -50,17 +54,23 @@ namespace DTO {
 
 class TranscodingProfile {
 public:
-	TranscodingProfile(			
-		DlnaProfileType type,									
-		bool estimateContentLength,			
-		bool enableMpegtsM2TsMode,			
+	TranscodingProfile(	
+		QString container,			
+		DlnaProfileType type,			
+		QString videoCodec,			
+		QString audioCodec,			
+		MediaStreamProtocol protocol,			
+		std::optional<bool> estimateContentLength,			
+		std::optional<bool> enableMpegtsM2TsMode,			
 		TranscodeSeekInfo transcodeSeekInfo,			
-		bool copyTimestamps,			
+		std::optional<bool> copyTimestamps,			
 		EncodingContext context,			
-		bool enableSubtitlesInManifest,					
-		qint32 minSegments,			
-		qint32 segmentLength,			
-		bool breakOnNonKeyFrames		
+		std::optional<bool> enableSubtitlesInManifest,					
+		std::optional<qint32> minSegments,			
+		std::optional<qint32> segmentLength,			
+		std::optional<bool> breakOnNonKeyFrames,			
+		QList<ProfileCondition> conditions,			
+		std::optional<bool> enableAudioVbrEncoding		
 	);
 
 	TranscodingProfile(const TranscodingProfile &other);
@@ -75,90 +85,144 @@ public:
 	QJsonObject toJson() const;
 	
 	// Properties
-
+	/**
+	 * @brief Gets or sets the container.
+	 */
 	QString container() const;
-
+	/**
+	* @brief Gets or sets the container.
+	*/
 	void setContainer(QString newContainer);
-	bool containerNull() const;
-	void setContainerNull();
 
 
 	DlnaProfileType type() const;
 
 	void setType(DlnaProfileType newType);
 
-
+	/**
+	 * @brief Gets or sets the video codec.
+	 */
 	QString videoCodec() const;
-
+	/**
+	* @brief Gets or sets the video codec.
+	*/
 	void setVideoCodec(QString newVideoCodec);
-	bool videoCodecNull() const;
-	void setVideoCodecNull();
-
 
+	/**
+	 * @brief Gets or sets the audio codec.
+	 */
 	QString audioCodec() const;
-
+	/**
+	* @brief Gets or sets the audio codec.
+	*/
 	void setAudioCodec(QString newAudioCodec);
-	bool audioCodecNull() const;
-	void setAudioCodecNull();
 
 
-	QString protocol() const;
+	MediaStreamProtocol protocol() const;
 
-	void setProtocol(QString newProtocol);
-	bool protocolNull() const;
-	void setProtocolNull();
+	void setProtocol(MediaStreamProtocol newProtocol);
 
+	/**
+	 * @brief Gets or sets a value indicating whether the content length should be estimated.
+	 */
+	std::optional<bool> estimateContentLength() const;
+	/**
+	* @brief Gets or sets a value indicating whether the content length should be estimated.
+	*/
+	void setEstimateContentLength(std::optional<bool> newEstimateContentLength);
 
-	bool estimateContentLength() const;
-
-	void setEstimateContentLength(bool newEstimateContentLength);
-
-
-	bool enableMpegtsM2TsMode() const;
-
-	void setEnableMpegtsM2TsMode(bool newEnableMpegtsM2TsMode);
+	/**
+	 * @brief Gets or sets a value indicating whether M2TS mode is enabled.
+	 */
+	std::optional<bool> enableMpegtsM2TsMode() const;
+	/**
+	* @brief Gets or sets a value indicating whether M2TS mode is enabled.
+	*/
+	void setEnableMpegtsM2TsMode(std::optional<bool> newEnableMpegtsM2TsMode);
 
 
 	TranscodeSeekInfo transcodeSeekInfo() const;
 
 	void setTranscodeSeekInfo(TranscodeSeekInfo newTranscodeSeekInfo);
 
-
-	bool copyTimestamps() const;
-
-	void setCopyTimestamps(bool newCopyTimestamps);
+	/**
+	 * @brief Gets or sets a value indicating whether timestamps should be copied.
+	 */
+	std::optional<bool> copyTimestamps() const;
+	/**
+	* @brief Gets or sets a value indicating whether timestamps should be copied.
+	*/
+	void setCopyTimestamps(std::optional<bool> newCopyTimestamps);
 
 
 	EncodingContext context() const;
 
 	void setContext(EncodingContext newContext);
 
+	/**
+	 * @brief Gets or sets a value indicating whether subtitles are allowed in the manifest.
+	 */
+	std::optional<bool> enableSubtitlesInManifest() const;
+	/**
+	* @brief Gets or sets a value indicating whether subtitles are allowed in the manifest.
+	*/
+	void setEnableSubtitlesInManifest(std::optional<bool> newEnableSubtitlesInManifest);
 
-	bool enableSubtitlesInManifest() const;
-
-	void setEnableSubtitlesInManifest(bool newEnableSubtitlesInManifest);
-
-
+	/**
+	 * @brief Gets or sets the maximum audio channels.
+	 */
 	QString maxAudioChannels() const;
-
+	/**
+	* @brief Gets or sets the maximum audio channels.
+	*/
 	void setMaxAudioChannels(QString newMaxAudioChannels);
 	bool maxAudioChannelsNull() const;
 	void setMaxAudioChannelsNull();
 
+	/**
+	 * @brief Gets or sets the minimum amount of segments.
+	 */
+	std::optional<qint32> minSegments() const;
+	/**
+	* @brief Gets or sets the minimum amount of segments.
+	*/
+	void setMinSegments(std::optional<qint32> newMinSegments);
 
-	qint32 minSegments() const;
+	/**
+	 * @brief Gets or sets the segment length.
+	 */
+	std::optional<qint32> segmentLength() const;
+	/**
+	* @brief Gets or sets the segment length.
+	*/
+	void setSegmentLength(std::optional<qint32> newSegmentLength);
 
-	void setMinSegments(qint32 newMinSegments);
+	/**
+	 * @brief Gets or sets a value indicating whether breaking the video stream on non-keyframes is supported.
+	 */
+	std::optional<bool> breakOnNonKeyFrames() const;
+	/**
+	* @brief Gets or sets a value indicating whether breaking the video stream on non-keyframes is supported.
+	*/
+	void setBreakOnNonKeyFrames(std::optional<bool> newBreakOnNonKeyFrames);
 
+	/**
+	 * @brief Gets or sets the profile conditions.
+	 */
+	QList<ProfileCondition> conditions() const;
+	/**
+	* @brief Gets or sets the profile conditions.
+	*/
+	void setConditions(QList<ProfileCondition> newConditions);
 
-	qint32 segmentLength() const;
-
-	void setSegmentLength(qint32 newSegmentLength);
-
-
-	bool breakOnNonKeyFrames() const;
-
-	void setBreakOnNonKeyFrames(bool newBreakOnNonKeyFrames);
+	/**
+	 * @brief Gets or sets a value indicating whether variable bitrate encoding is supported.
+	 */
+	std::optional<bool> enableAudioVbrEncoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether variable bitrate encoding is supported.
+	*/
+	void setEnableAudioVbrEncoding(std::optional<bool> newEnableAudioVbrEncoding);
 
 
 protected:
@@ -166,17 +230,19 @@ protected:
 	DlnaProfileType m_type;
 	QString m_videoCodec;
 	QString m_audioCodec;
-	QString m_protocol;
-	bool m_estimateContentLength;
-	bool m_enableMpegtsM2TsMode;
+	MediaStreamProtocol m_protocol;
+	std::optional<bool> m_estimateContentLength = std::nullopt;
+	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	TranscodeSeekInfo m_transcodeSeekInfo;
-	bool m_copyTimestamps;
+	std::optional<bool> m_copyTimestamps = std::nullopt;
 	EncodingContext m_context;
-	bool m_enableSubtitlesInManifest;
+	std::optional<bool> m_enableSubtitlesInManifest = std::nullopt;
 	QString m_maxAudioChannels;
-	qint32 m_minSegments;
-	qint32 m_segmentLength;
-	bool m_breakOnNonKeyFrames;
+	std::optional<qint32> m_minSegments = std::nullopt;
+	std::optional<qint32> m_segmentLength = std::nullopt;
+	std::optional<bool> m_breakOnNonKeyFrames = std::nullopt;
+	QList<ProfileCondition> m_conditions;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 
 private:
 	// Private constructor which generates an invalid object, for use withing TranscodingProfile::fromJson();
diff --git a/core/include/JellyfinQt/dto/trickplayinfo.h b/core/include/JellyfinQt/dto/trickplayinfo.h
new file mode 100644
index 0000000..b9d8bf3
--- /dev/null
+++ b/core/include/JellyfinQt/dto/trickplayinfo.h
@@ -0,0 +1,165 @@
+/*
+ * 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_DTO_TRICKPLAYINFO_H
+#define JELLYFIN_DTO_TRICKPLAYINFO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class TrickplayInfo {
+public:
+	TrickplayInfo(	
+		qint32 width,			
+		qint32 height,			
+		qint32 tileWidth,			
+		qint32 tileHeight,			
+		qint32 thumbnailCount,			
+		qint32 interval,			
+		qint32 bandwidth		
+	);
+
+	TrickplayInfo(const TrickplayInfo &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(TrickplayInfo &other);
+	
+	static TrickplayInfo fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets width of an individual thumbnail.
+	 */
+	qint32 width() const;
+	/**
+	* @brief Gets or sets width of an individual thumbnail.
+	*/
+	void setWidth(qint32 newWidth);
+
+	/**
+	 * @brief Gets or sets height of an individual thumbnail.
+	 */
+	qint32 height() const;
+	/**
+	* @brief Gets or sets height of an individual thumbnail.
+	*/
+	void setHeight(qint32 newHeight);
+
+	/**
+	 * @brief Gets or sets amount of thumbnails per row.
+	 */
+	qint32 tileWidth() const;
+	/**
+	* @brief Gets or sets amount of thumbnails per row.
+	*/
+	void setTileWidth(qint32 newTileWidth);
+
+	/**
+	 * @brief Gets or sets amount of thumbnails per column.
+	 */
+	qint32 tileHeight() const;
+	/**
+	* @brief Gets or sets amount of thumbnails per column.
+	*/
+	void setTileHeight(qint32 newTileHeight);
+
+	/**
+	 * @brief Gets or sets total amount of non-black thumbnails.
+	 */
+	qint32 thumbnailCount() const;
+	/**
+	* @brief Gets or sets total amount of non-black thumbnails.
+	*/
+	void setThumbnailCount(qint32 newThumbnailCount);
+
+	/**
+	 * @brief Gets or sets interval in milliseconds between each trickplay thumbnail.
+	 */
+	qint32 interval() const;
+	/**
+	* @brief Gets or sets interval in milliseconds between each trickplay thumbnail.
+	*/
+	void setInterval(qint32 newInterval);
+
+	/**
+	 * @brief Gets or sets peak bandwith usage in bits per second.
+	 */
+	qint32 bandwidth() const;
+	/**
+	* @brief Gets or sets peak bandwith usage in bits per second.
+	*/
+	void setBandwidth(qint32 newBandwidth);
+
+
+protected:
+	qint32 m_width;
+	qint32 m_height;
+	qint32 m_tileWidth;
+	qint32 m_tileHeight;
+	qint32 m_thumbnailCount;
+	qint32 m_interval;
+	qint32 m_bandwidth;
+
+private:
+	// Private constructor which generates an invalid object, for use withing TrickplayInfo::fromJson();
+	TrickplayInfo();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayInfo = Jellyfin::DTO::TrickplayInfo;
+
+template <>
+TrickplayInfo fromJsonValue(const QJsonValue &source, convertType<TrickplayInfo>);
+
+template<>
+QJsonValue toJsonValue(const TrickplayInfo &source, convertType<TrickplayInfo>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TRICKPLAYINFO_H
diff --git a/core/include/JellyfinQt/dto/trickplayoptions.h b/core/include/JellyfinQt/dto/trickplayoptions.h
new file mode 100644
index 0000000..ee11ef8
--- /dev/null
+++ b/core/include/JellyfinQt/dto/trickplayoptions.h
@@ -0,0 +1,218 @@
+/*
+ * 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_DTO_TRICKPLAYOPTIONS_H
+#define JELLYFIN_DTO_TRICKPLAYOPTIONS_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/processpriorityclass.h"
+#include "JellyfinQt/dto/trickplayscanbehavior.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class TrickplayOptions {
+public:
+	TrickplayOptions(	
+		bool enableHwAcceleration,			
+		bool enableHwEncoding,			
+		bool enableKeyFrameOnlyExtraction,			
+		TrickplayScanBehavior scanBehavior,			
+		ProcessPriorityClass processPriority,			
+		qint32 interval,			
+		QList<qint32> widthResolutions,			
+		qint32 tileWidth,			
+		qint32 tileHeight,			
+		qint32 qscale,			
+		qint32 jpegQuality,			
+		qint32 processThreads		
+	);
+
+	TrickplayOptions(const TrickplayOptions &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(TrickplayOptions &other);
+	
+	static TrickplayOptions fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets a value indicating whether or not to use HW acceleration.
+	 */
+	bool enableHwAcceleration() const;
+	/**
+	* @brief Gets or sets a value indicating whether or not to use HW acceleration.
+	*/
+	void setEnableHwAcceleration(bool newEnableHwAcceleration);
+
+	/**
+	 * @brief Gets or sets a value indicating whether or not to use HW accelerated MJPEG encoding.
+	 */
+	bool enableHwEncoding() const;
+	/**
+	* @brief Gets or sets a value indicating whether or not to use HW accelerated MJPEG encoding.
+	*/
+	void setEnableHwEncoding(bool newEnableHwEncoding);
+
+	/**
+	 * @brief Gets or sets a value indicating whether to only extract key frames.
+Significantly faster, but is not compatible with all decoders and/or video files.
+	 */
+	bool enableKeyFrameOnlyExtraction() const;
+	/**
+	* @brief Gets or sets a value indicating whether to only extract key frames.
+Significantly faster, but is not compatible with all decoders and/or video files.
+	*/
+	void setEnableKeyFrameOnlyExtraction(bool newEnableKeyFrameOnlyExtraction);
+
+
+	TrickplayScanBehavior scanBehavior() const;
+
+	void setScanBehavior(TrickplayScanBehavior newScanBehavior);
+
+
+	ProcessPriorityClass processPriority() const;
+
+	void setProcessPriority(ProcessPriorityClass newProcessPriority);
+
+	/**
+	 * @brief Gets or sets the interval, in ms, between each new trickplay image.
+	 */
+	qint32 interval() const;
+	/**
+	* @brief Gets or sets the interval, in ms, between each new trickplay image.
+	*/
+	void setInterval(qint32 newInterval);
+
+	/**
+	 * @brief Gets or sets the target width resolutions, in px, to generates preview images for.
+	 */
+	QList<qint32> widthResolutions() const;
+	/**
+	* @brief Gets or sets the target width resolutions, in px, to generates preview images for.
+	*/
+	void setWidthResolutions(QList<qint32> newWidthResolutions);
+
+	/**
+	 * @brief Gets or sets number of tile images to allow in X dimension.
+	 */
+	qint32 tileWidth() const;
+	/**
+	* @brief Gets or sets number of tile images to allow in X dimension.
+	*/
+	void setTileWidth(qint32 newTileWidth);
+
+	/**
+	 * @brief Gets or sets number of tile images to allow in Y dimension.
+	 */
+	qint32 tileHeight() const;
+	/**
+	* @brief Gets or sets number of tile images to allow in Y dimension.
+	*/
+	void setTileHeight(qint32 newTileHeight);
+
+	/**
+	 * @brief Gets or sets the ffmpeg output quality level.
+	 */
+	qint32 qscale() const;
+	/**
+	* @brief Gets or sets the ffmpeg output quality level.
+	*/
+	void setQscale(qint32 newQscale);
+
+	/**
+	 * @brief Gets or sets the jpeg quality to use for image tiles.
+	 */
+	qint32 jpegQuality() const;
+	/**
+	* @brief Gets or sets the jpeg quality to use for image tiles.
+	*/
+	void setJpegQuality(qint32 newJpegQuality);
+
+	/**
+	 * @brief Gets or sets the number of threads to be used by ffmpeg.
+	 */
+	qint32 processThreads() const;
+	/**
+	* @brief Gets or sets the number of threads to be used by ffmpeg.
+	*/
+	void setProcessThreads(qint32 newProcessThreads);
+
+
+protected:
+	bool m_enableHwAcceleration;
+	bool m_enableHwEncoding;
+	bool m_enableKeyFrameOnlyExtraction;
+	TrickplayScanBehavior m_scanBehavior;
+	ProcessPriorityClass m_processPriority;
+	qint32 m_interval;
+	QList<qint32> m_widthResolutions;
+	qint32 m_tileWidth;
+	qint32 m_tileHeight;
+	qint32 m_qscale;
+	qint32 m_jpegQuality;
+	qint32 m_processThreads;
+
+private:
+	// Private constructor which generates an invalid object, for use withing TrickplayOptions::fromJson();
+	TrickplayOptions();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayOptions = Jellyfin::DTO::TrickplayOptions;
+
+template <>
+TrickplayOptions fromJsonValue(const QJsonValue &source, convertType<TrickplayOptions>);
+
+template<>
+QJsonValue toJsonValue(const TrickplayOptions &source, convertType<TrickplayOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TRICKPLAYOPTIONS_H
diff --git a/core/include/JellyfinQt/dto/trickplayscanbehavior.h b/core/include/JellyfinQt/dto/trickplayscanbehavior.h
new file mode 100644
index 0000000..5f2510a
--- /dev/null
+++ b/core/include/JellyfinQt/dto/trickplayscanbehavior.h
@@ -0,0 +1,76 @@
+/*
+ * 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_DTO_TRICKPLAYSCANBEHAVIOR_H
+#define JELLYFIN_DTO_TRICKPLAYSCANBEHAVIOR_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class TrickplayScanBehaviorClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Blocking,
+		NonBlocking,
+	};
+	Q_ENUM(Value)
+private:
+	explicit TrickplayScanBehaviorClass();
+};
+
+using TrickplayScanBehavior = TrickplayScanBehaviorClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayScanBehavior = Jellyfin::DTO::TrickplayScanBehavior;
+
+template <>
+TrickplayScanBehavior fromJsonValue(const QJsonValue &source, convertType<TrickplayScanBehavior>);
+
+template <>
+QJsonValue toJsonValue(const TrickplayScanBehavior &source, convertType<TrickplayScanBehavior>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_TRICKPLAYSCANBEHAVIOR_H
diff --git a/core/include/JellyfinQt/dto/tunerhostinfo.h b/core/include/JellyfinQt/dto/tunerhostinfo.h
index 75bd815..9bd3434 100644
--- a/core/include/JellyfinQt/dto/tunerhostinfo.h
+++ b/core/include/JellyfinQt/dto/tunerhostinfo.h
@@ -50,8 +50,12 @@ public:
 	TunerHostInfo(											
 		bool importFavoritesOnly,			
 		bool allowHWTranscoding,			
+		bool allowFmp4TranscodingContainer,			
+		bool allowStreamSharing,			
+		qint32 fallbackMaxStreamingBitrate,			
 		bool enableStreamLooping,					
-		qint32 tunerCount				
+		qint32 tunerCount,					
+		bool ignoreDts		
 	);
 
 	TunerHostInfo(const TunerHostInfo &other);
@@ -112,6 +116,21 @@ public:
 	void setAllowHWTranscoding(bool newAllowHWTranscoding);
 
 
+	bool allowFmp4TranscodingContainer() const;
+
+	void setAllowFmp4TranscodingContainer(bool newAllowFmp4TranscodingContainer);
+
+
+	bool allowStreamSharing() const;
+
+	void setAllowStreamSharing(bool newAllowStreamSharing);
+
+
+	qint32 fallbackMaxStreamingBitrate() const;
+
+	void setFallbackMaxStreamingBitrate(qint32 newFallbackMaxStreamingBitrate);
+
+
 	bool enableStreamLooping() const;
 
 	void setEnableStreamLooping(bool newEnableStreamLooping);
@@ -136,6 +155,11 @@ public:
 	void setUserAgentNull();
 
 
+	bool ignoreDts() const;
+
+	void setIgnoreDts(bool newIgnoreDts);
+
+
 protected:
 	QString m_jellyfinId;
 	QString m_url;
@@ -144,10 +168,14 @@ protected:
 	QString m_friendlyName;
 	bool m_importFavoritesOnly;
 	bool m_allowHWTranscoding;
+	bool m_allowFmp4TranscodingContainer;
+	bool m_allowStreamSharing;
+	qint32 m_fallbackMaxStreamingBitrate;
 	bool m_enableStreamLooping;
 	QString m_source;
 	qint32 m_tunerCount;
 	QString m_userAgent;
+	bool m_ignoreDts;
 
 private:
 	// Private constructor which generates an invalid object, for use withing TunerHostInfo::fromJson();
diff --git a/core/include/JellyfinQt/dto/notificationtypeinfo.h b/core/include/JellyfinQt/dto/updatemediapathrequestdto.h
similarity index 61%
rename from core/include/JellyfinQt/dto/notificationtypeinfo.h
rename to core/include/JellyfinQt/dto/updatemediapathrequestdto.h
index 4fcf468..0b86af0 100644
--- a/core/include/JellyfinQt/dto/notificationtypeinfo.h
+++ b/core/include/JellyfinQt/dto/updatemediapathrequestdto.h
@@ -27,14 +27,16 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_NOTIFICATIONTYPEINFO_H
-#define JELLYFIN_DTO_NOTIFICATIONTYPEINFO_H
+#ifndef JELLYFIN_DTO_UPDATEMEDIAPATHREQUESTDTO_H
+#define JELLYFIN_DTO_UPDATEMEDIAPATHREQUESTDTO_H
 
 #include <QJsonObject>
 #include <QJsonValue>
+#include <QSharedPointer>
 #include <QString>
 #include <optional>
 
+#include "JellyfinQt/dto/mediapathinfo.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -45,67 +47,47 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class NotificationTypeInfo {
+class UpdateMediaPathRequestDto {
 public:
-	NotificationTypeInfo(					
-		bool enabled,					
-		bool isBasedOnUserEvent		
+	UpdateMediaPathRequestDto(	
+		QString name,			
+		QSharedPointer<MediaPathInfo> pathInfo		
 	);
 
-	NotificationTypeInfo(const NotificationTypeInfo &other);
+	UpdateMediaPathRequestDto(const UpdateMediaPathRequestDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(NotificationTypeInfo &other);
+	void replaceData(UpdateMediaPathRequestDto &other);
 	
-	static NotificationTypeInfo fromJson(QJsonObject source);
+	static UpdateMediaPathRequestDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
-
-	QString type() const;
-
-	void setType(QString newType);
-	bool typeNull() const;
-	void setTypeNull();
-
-
+	/**
+	 * @brief Gets or sets the library name.
+	 */
 	QString name() const;
-
+	/**
+	* @brief Gets or sets the library name.
+	*/
 	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
 
 
-	bool enabled() const;
+	QSharedPointer<MediaPathInfo> pathInfo() const;
 
-	void setEnabled(bool newEnabled);
-
-
-	QString category() const;
-
-	void setCategory(QString newCategory);
-	bool categoryNull() const;
-	void setCategoryNull();
-
-
-	bool isBasedOnUserEvent() const;
-
-	void setIsBasedOnUserEvent(bool newIsBasedOnUserEvent);
+	void setPathInfo(QSharedPointer<MediaPathInfo> newPathInfo);
 
 
 protected:
-	QString m_type;
 	QString m_name;
-	bool m_enabled;
-	QString m_category;
-	bool m_isBasedOnUserEvent;
+	QSharedPointer<MediaPathInfo> m_pathInfo = QSharedPointer<MediaPathInfo>();
 
 private:
-	// Private constructor which generates an invalid object, for use withing NotificationTypeInfo::fromJson();
-	NotificationTypeInfo();
+	// Private constructor which generates an invalid object, for use withing UpdateMediaPathRequestDto::fromJson();
+	UpdateMediaPathRequestDto();
 };
 
 
@@ -113,15 +95,15 @@ private:
 
 namespace Support {
 
-using NotificationTypeInfo = Jellyfin::DTO::NotificationTypeInfo;
+using UpdateMediaPathRequestDto = Jellyfin::DTO::UpdateMediaPathRequestDto;
 
 template <>
-NotificationTypeInfo fromJsonValue(const QJsonValue &source, convertType<NotificationTypeInfo>);
+UpdateMediaPathRequestDto fromJsonValue(const QJsonValue &source, convertType<UpdateMediaPathRequestDto>);
 
 template<>
-QJsonValue toJsonValue(const NotificationTypeInfo &source, convertType<NotificationTypeInfo>);
+QJsonValue toJsonValue(const UpdateMediaPathRequestDto &source, convertType<UpdateMediaPathRequestDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_NOTIFICATIONTYPEINFO_H
+#endif // JELLYFIN_DTO_UPDATEMEDIAPATHREQUESTDTO_H
diff --git a/core/include/JellyfinQt/dto/imagebynameinfo.h b/core/include/JellyfinQt/dto/updateplaylistdto.h
similarity index 55%
rename from core/include/JellyfinQt/dto/imagebynameinfo.h
rename to core/include/JellyfinQt/dto/updateplaylistdto.h
index a353bfa..ba62272 100644
--- a/core/include/JellyfinQt/dto/imagebynameinfo.h
+++ b/core/include/JellyfinQt/dto/updateplaylistdto.h
@@ -27,14 +27,17 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_IMAGEBYNAMEINFO_H
-#define JELLYFIN_DTO_IMAGEBYNAMEINFO_H
+#ifndef JELLYFIN_DTO_UPDATEPLAYLISTDTO_H
+#define JELLYFIN_DTO_UPDATEPLAYLISTDTO_H
 
 #include <QJsonObject>
 #include <QJsonValue>
+#include <QList>
 #include <QString>
+#include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/playlistuserpermissions.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -45,88 +48,72 @@ namespace Jellyfin {
 namespace DTO {
 
 
-class ImageByNameInfo {
-public:
-	ImageByNameInfo(							
-		qint64 fileLength				
-	);
-
-	ImageByNameInfo(const ImageByNameInfo &other);
+class UpdatePlaylistDto {
+public:	UpdatePlaylistDto();
+	UpdatePlaylistDto(const UpdatePlaylistDto &other);
 	
 	/**
 	 * Replaces the data being hold by this class with that of the other.
 	 */
-	void replaceData(ImageByNameInfo &other);
+	void replaceData(UpdatePlaylistDto &other);
 	
-	static ImageByNameInfo fromJson(QJsonObject source);
+	static UpdatePlaylistDto fromJson(QJsonObject source);
 	void setFromJson(QJsonObject source);
 	QJsonObject toJson() const;
 	
 	// Properties
 	/**
-	 * @brief Gets or sets the name.
+	 * @brief Gets or sets the name of the new playlist.
 	 */
 	QString name() const;
 	/**
-	* @brief Gets or sets the name.
+	* @brief Gets or sets the name of the new playlist.
 	*/
 	void setName(QString newName);
 	bool nameNull() const;
 	void setNameNull();
 
 	/**
-	 * @brief Gets or sets the theme.
+	 * @brief Gets or sets item ids of the playlist.
 	 */
-	QString theme() const;
+	QStringList ids() const;
 	/**
-	* @brief Gets or sets the theme.
+	* @brief Gets or sets item ids of the playlist.
 	*/
-	void setTheme(QString newTheme);
-	bool themeNull() const;
-	void setThemeNull();
+	void setIds(QStringList newIds);
+	bool idsNull() const;
+	void setIdsNull();
 
 	/**
-	 * @brief Gets or sets the context.
+	 * @brief Gets or sets the playlist users.
 	 */
-	QString context() const;
+	QList<PlaylistUserPermissions> users() const;
 	/**
-	* @brief Gets or sets the context.
+	* @brief Gets or sets the playlist users.
 	*/
-	void setContext(QString newContext);
-	bool contextNull() const;
-	void setContextNull();
+	void setUsers(QList<PlaylistUserPermissions> newUsers);
+	bool usersNull() const;
+	void setUsersNull();
 
 	/**
-	 * @brief Gets or sets the length of the file.
+	 * @brief Gets or sets a value indicating whether the playlist is public.
 	 */
-	qint64 fileLength() const;
+	std::optional<bool> isPublic() const;
 	/**
-	* @brief Gets or sets the length of the file.
+	* @brief Gets or sets a value indicating whether the playlist is public.
 	*/
-	void setFileLength(qint64 newFileLength);
-
-	/**
-	 * @brief Gets or sets the format.
-	 */
-	QString format() const;
-	/**
-	* @brief Gets or sets the format.
-	*/
-	void setFormat(QString newFormat);
-	bool formatNull() const;
-	void setFormatNull();
+	void setIsPublic(std::optional<bool> newIsPublic);
+	bool isPublicNull() const;
+	void setIsPublicNull();
 
 
 protected:
 	QString m_name;
-	QString m_theme;
-	QString m_context;
-	qint64 m_fileLength;
-	QString m_format;
+	QStringList m_ids;
+	QList<PlaylistUserPermissions> m_users;
+	std::optional<bool> m_isPublic = std::nullopt;
+
 
-private:
-	// Private constructor which generates an invalid object, for use withing ImageByNameInfo::fromJson();
-	ImageByNameInfo();
 };
 
 
@@ -134,15 +121,15 @@ private:
 
 namespace Support {
 
-using ImageByNameInfo = Jellyfin::DTO::ImageByNameInfo;
+using UpdatePlaylistDto = Jellyfin::DTO::UpdatePlaylistDto;
 
 template <>
-ImageByNameInfo fromJsonValue(const QJsonValue &source, convertType<ImageByNameInfo>);
+UpdatePlaylistDto fromJsonValue(const QJsonValue &source, convertType<UpdatePlaylistDto>);
 
 template<>
-QJsonValue toJsonValue(const ImageByNameInfo &source, convertType<ImageByNameInfo>);
+QJsonValue toJsonValue(const UpdatePlaylistDto &source, convertType<UpdatePlaylistDto>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_IMAGEBYNAMEINFO_H
+#endif // JELLYFIN_DTO_UPDATEPLAYLISTDTO_H
diff --git a/core/include/JellyfinQt/dto/updateplaylistuserdto.h b/core/include/JellyfinQt/dto/updateplaylistuserdto.h
new file mode 100644
index 0000000..279e6ae
--- /dev/null
+++ b/core/include/JellyfinQt/dto/updateplaylistuserdto.h
@@ -0,0 +1,95 @@
+/*
+ * 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_DTO_UPDATEPLAYLISTUSERDTO_H
+#define JELLYFIN_DTO_UPDATEPLAYLISTUSERDTO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UpdatePlaylistUserDto {
+public:	UpdatePlaylistUserDto();
+	UpdatePlaylistUserDto(const UpdatePlaylistUserDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UpdatePlaylistUserDto &other);
+	
+	static UpdatePlaylistUserDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets a value indicating whether the user can edit the playlist.
+	 */
+	std::optional<bool> canEdit() const;
+	/**
+	* @brief Gets or sets a value indicating whether the user can edit the playlist.
+	*/
+	void setCanEdit(std::optional<bool> newCanEdit);
+	bool canEditNull() const;
+	void setCanEditNull();
+
+
+protected:
+	std::optional<bool> m_canEdit = std::nullopt;
+
+
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UpdatePlaylistUserDto = Jellyfin::DTO::UpdatePlaylistUserDto;
+
+template <>
+UpdatePlaylistUserDto fromJsonValue(const QJsonValue &source, convertType<UpdatePlaylistUserDto>);
+
+template<>
+QJsonValue toJsonValue(const UpdatePlaylistUserDto &source, convertType<UpdatePlaylistUserDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_UPDATEPLAYLISTUSERDTO_H
diff --git a/core/include/JellyfinQt/dto/updateuseritemdatadto.h b/core/include/JellyfinQt/dto/updateuseritemdatadto.h
new file mode 100644
index 0000000..4efb259
--- /dev/null
+++ b/core/include/JellyfinQt/dto/updateuseritemdatadto.h
@@ -0,0 +1,217 @@
+/*
+ * 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_DTO_UPDATEUSERITEMDATADTO_H
+#define JELLYFIN_DTO_UPDATEUSERITEMDATADTO_H
+
+#include <QDateTime>
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UpdateUserItemDataDto {
+public:	UpdateUserItemDataDto();
+	UpdateUserItemDataDto(const UpdateUserItemDataDto &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UpdateUserItemDataDto &other);
+	
+	static UpdateUserItemDataDto fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the rating.
+	 */
+	std::optional<double> rating() const;
+	/**
+	* @brief Gets or sets the rating.
+	*/
+	void setRating(std::optional<double> newRating);
+	bool ratingNull() const;
+	void setRatingNull();
+
+	/**
+	 * @brief Gets or sets the played percentage.
+	 */
+	std::optional<double> playedPercentage() const;
+	/**
+	* @brief Gets or sets the played percentage.
+	*/
+	void setPlayedPercentage(std::optional<double> newPlayedPercentage);
+	bool playedPercentageNull() const;
+	void setPlayedPercentageNull();
+
+	/**
+	 * @brief Gets or sets the unplayed item count.
+	 */
+	std::optional<qint32> unplayedItemCount() const;
+	/**
+	* @brief Gets or sets the unplayed item count.
+	*/
+	void setUnplayedItemCount(std::optional<qint32> newUnplayedItemCount);
+	bool unplayedItemCountNull() const;
+	void setUnplayedItemCountNull();
+
+	/**
+	 * @brief Gets or sets the playback position ticks.
+	 */
+	std::optional<qint64> playbackPositionTicks() const;
+	/**
+	* @brief Gets or sets the playback position ticks.
+	*/
+	void setPlaybackPositionTicks(std::optional<qint64> newPlaybackPositionTicks);
+	bool playbackPositionTicksNull() const;
+	void setPlaybackPositionTicksNull();
+
+	/**
+	 * @brief Gets or sets the play count.
+	 */
+	std::optional<qint32> playCount() const;
+	/**
+	* @brief Gets or sets the play count.
+	*/
+	void setPlayCount(std::optional<qint32> newPlayCount);
+	bool playCountNull() const;
+	void setPlayCountNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether this instance is favorite.
+	 */
+	std::optional<bool> isFavorite() const;
+	/**
+	* @brief Gets or sets a value indicating whether this instance is favorite.
+	*/
+	void setIsFavorite(std::optional<bool> newIsFavorite);
+	bool isFavoriteNull() const;
+	void setIsFavoriteNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UpdateUserItemDataDto is likes.
+	 */
+	std::optional<bool> likes() const;
+	/**
+	* @brief Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UpdateUserItemDataDto is likes.
+	*/
+	void setLikes(std::optional<bool> newLikes);
+	bool likesNull() const;
+	void setLikesNull();
+
+	/**
+	 * @brief Gets or sets the last played date.
+	 */
+	QDateTime lastPlayedDate() const;
+	/**
+	* @brief Gets or sets the last played date.
+	*/
+	void setLastPlayedDate(QDateTime newLastPlayedDate);
+	bool lastPlayedDateNull() const;
+	void setLastPlayedDateNull();
+
+	/**
+	 * @brief Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is played.
+	 */
+	std::optional<bool> played() const;
+	/**
+	* @brief Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is played.
+	*/
+	void setPlayed(std::optional<bool> newPlayed);
+	bool playedNull() const;
+	void setPlayedNull();
+
+	/**
+	 * @brief Gets or sets the key.
+	 */
+	QString key() const;
+	/**
+	* @brief Gets or sets the key.
+	*/
+	void setKey(QString newKey);
+	bool keyNull() const;
+	void setKeyNull();
+
+	/**
+	 * @brief Gets or sets the item identifier.
+	 */
+	QString itemId() const;
+	/**
+	* @brief Gets or sets the item identifier.
+	*/
+	void setItemId(QString newItemId);
+	bool itemIdNull() const;
+	void setItemIdNull();
+
+
+protected:
+	std::optional<double> m_rating = std::nullopt;
+	std::optional<double> m_playedPercentage = std::nullopt;
+	std::optional<qint32> m_unplayedItemCount = std::nullopt;
+	std::optional<qint64> m_playbackPositionTicks = std::nullopt;
+	std::optional<qint32> m_playCount = std::nullopt;
+	std::optional<bool> m_isFavorite = std::nullopt;
+	std::optional<bool> m_likes = std::nullopt;
+	QDateTime m_lastPlayedDate;
+	std::optional<bool> m_played = std::nullopt;
+	QString m_key;
+	QString m_itemId;
+
+
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UpdateUserItemDataDto = Jellyfin::DTO::UpdateUserItemDataDto;
+
+template <>
+UpdateUserItemDataDto fromJsonValue(const QJsonValue &source, convertType<UpdateUserItemDataDto>);
+
+template<>
+QJsonValue toJsonValue(const UpdateUserItemDataDto &source, convertType<UpdateUserItemDataDto>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_UPDATEUSERITEMDATADTO_H
diff --git a/core/include/JellyfinQt/dto/uploadsubtitledto.h b/core/include/JellyfinQt/dto/uploadsubtitledto.h
index d8a47f4..e462a0c 100644
--- a/core/include/JellyfinQt/dto/uploadsubtitledto.h
+++ b/core/include/JellyfinQt/dto/uploadsubtitledto.h
@@ -51,6 +51,7 @@ public:
 		QString language,			
 		QString format,			
 		bool isForced,			
+		bool isHearingImpaired,			
 		QString data		
 	);
 
@@ -93,6 +94,15 @@ public:
 	*/
 	void setIsForced(bool newIsForced);
 
+	/**
+	 * @brief Gets or sets a value indicating whether the subtitle is for hearing impaired.
+	 */
+	bool isHearingImpaired() const;
+	/**
+	* @brief Gets or sets a value indicating whether the subtitle is for hearing impaired.
+	*/
+	void setIsHearingImpaired(bool newIsHearingImpaired);
+
 	/**
 	 * @brief Gets or sets the subtitle data.
 	 */
@@ -107,6 +117,7 @@ protected:
 	QString m_language;
 	QString m_format;
 	bool m_isForced;
+	bool m_isHearingImpaired;
 	QString m_data;
 
 private:
diff --git a/core/include/JellyfinQt/dto/userconfiguration.h b/core/include/JellyfinQt/dto/userconfiguration.h
index b2c8b85..67226cb 100644
--- a/core/include/JellyfinQt/dto/userconfiguration.h
+++ b/core/include/JellyfinQt/dto/userconfiguration.h
@@ -52,14 +52,18 @@ class UserConfiguration {
 public:
 	UserConfiguration(			
 		bool playDefaultAudioTrack,					
-		bool displayMissingEpisodes,					
+		bool displayMissingEpisodes,			
+		QStringList groupedFolders,			
 		SubtitlePlaybackMode subtitleMode,			
 		bool displayCollectionsView,			
-		bool enableLocalPassword,									
+		bool enableLocalPassword,			
+		QStringList orderedViews,			
+		QStringList latestItemsExcludes,			
+		QStringList myMediaExcludes,			
 		bool hidePlayedInLatest,			
 		bool rememberAudioSelections,			
 		bool rememberSubtitleSelections,			
-		bool enableNextEpisodeAutoPlay		
+		bool enableNextEpisodeAutoPlay				
 	);
 
 	UserConfiguration(const UserConfiguration &other);
@@ -114,8 +118,6 @@ public:
 	QStringList groupedFolders() const;
 
 	void setGroupedFolders(QStringList newGroupedFolders);
-	bool groupedFoldersNull() const;
-	void setGroupedFoldersNull();
 
 
 	SubtitlePlaybackMode subtitleMode() const;
@@ -136,22 +138,16 @@ public:
 	QStringList orderedViews() const;
 
 	void setOrderedViews(QStringList newOrderedViews);
-	bool orderedViewsNull() const;
-	void setOrderedViewsNull();
 
 
 	QStringList latestItemsExcludes() const;
 
 	void setLatestItemsExcludes(QStringList newLatestItemsExcludes);
-	bool latestItemsExcludesNull() const;
-	void setLatestItemsExcludesNull();
 
 
 	QStringList myMediaExcludes() const;
 
 	void setMyMediaExcludes(QStringList newMyMediaExcludes);
-	bool myMediaExcludesNull() const;
-	void setMyMediaExcludesNull();
 
 
 	bool hidePlayedInLatest() const;
@@ -173,6 +169,17 @@ public:
 
 	void setEnableNextEpisodeAutoPlay(bool newEnableNextEpisodeAutoPlay);
 
+	/**
+	 * @brief Gets or sets the id of the selected cast receiver.
+	 */
+	QString castReceiverId() const;
+	/**
+	* @brief Gets or sets the id of the selected cast receiver.
+	*/
+	void setCastReceiverId(QString newCastReceiverId);
+	bool castReceiverIdNull() const;
+	void setCastReceiverIdNull();
+
 
 protected:
 	QString m_audioLanguagePreference;
@@ -190,6 +197,7 @@ protected:
 	bool m_rememberAudioSelections;
 	bool m_rememberSubtitleSelections;
 	bool m_enableNextEpisodeAutoPlay;
+	QString m_castReceiverId;
 
 private:
 	// Private constructor which generates an invalid object, for use withing UserConfiguration::fromJson();
diff --git a/core/include/JellyfinQt/dto/userdatachangedmessage.h b/core/include/JellyfinQt/dto/userdatachangedmessage.h
new file mode 100644
index 0000000..81ae415
--- /dev/null
+++ b/core/include/JellyfinQt/dto/userdatachangedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_USERDATACHANGEDMESSAGE_H
+#define JELLYFIN_DTO_USERDATACHANGEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/userdatachangeinfo.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UserDataChangedMessage {
+public:
+	UserDataChangedMessage(	
+		QSharedPointer<UserDataChangeInfo> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	UserDataChangedMessage(const UserDataChangedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UserDataChangedMessage &other);
+	
+	static UserDataChangedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<UserDataChangeInfo> data() const;
+
+	void setData(QSharedPointer<UserDataChangeInfo> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<UserDataChangeInfo> m_data = QSharedPointer<UserDataChangeInfo>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing UserDataChangedMessage::fromJson();
+	UserDataChangedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDataChangedMessage = Jellyfin::DTO::UserDataChangedMessage;
+
+template <>
+UserDataChangedMessage fromJsonValue(const QJsonValue &source, convertType<UserDataChangedMessage>);
+
+template<>
+QJsonValue toJsonValue(const UserDataChangedMessage &source, convertType<UserDataChangedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_USERDATACHANGEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/userdatachangeinfo.h b/core/include/JellyfinQt/dto/userdatachangeinfo.h
new file mode 100644
index 0000000..ee45425
--- /dev/null
+++ b/core/include/JellyfinQt/dto/userdatachangeinfo.h
@@ -0,0 +1,114 @@
+/*
+ * 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_DTO_USERDATACHANGEINFO_H
+#define JELLYFIN_DTO_USERDATACHANGEINFO_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QList>
+#include <QString>
+#include <QStringList>
+#include <optional>
+
+#include "JellyfinQt/dto/useritemdatadto.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UserDataChangeInfo {
+public:
+	UserDataChangeInfo(	
+		QString userId,			
+		QList<UserItemDataDto> userDataList		
+	);
+
+	UserDataChangeInfo(const UserDataChangeInfo &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UserDataChangeInfo &other);
+	
+	static UserDataChangeInfo fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the user id.
+	 */
+	QString userId() const;
+	/**
+	* @brief Gets or sets the user id.
+	*/
+	void setUserId(QString newUserId);
+
+	/**
+	 * @brief Gets or sets the user data list.
+	 */
+	QList<UserItemDataDto> userDataList() const;
+	/**
+	* @brief Gets or sets the user data list.
+	*/
+	void setUserDataList(QList<UserItemDataDto> newUserDataList);
+
+
+protected:
+	QString m_userId;
+	QList<UserItemDataDto> m_userDataList;
+
+private:
+	// Private constructor which generates an invalid object, for use withing UserDataChangeInfo::fromJson();
+	UserDataChangeInfo();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDataChangeInfo = Jellyfin::DTO::UserDataChangeInfo;
+
+template <>
+UserDataChangeInfo fromJsonValue(const QJsonValue &source, convertType<UserDataChangeInfo>);
+
+template<>
+QJsonValue toJsonValue(const UserDataChangeInfo &source, convertType<UserDataChangeInfo>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_USERDATACHANGEINFO_H
diff --git a/core/include/JellyfinQt/dto/userdeletedmessage.h b/core/include/JellyfinQt/dto/userdeletedmessage.h
new file mode 100644
index 0000000..33da1cf
--- /dev/null
+++ b/core/include/JellyfinQt/dto/userdeletedmessage.h
@@ -0,0 +1,119 @@
+/*
+ * 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_DTO_USERDELETEDMESSAGE_H
+#define JELLYFIN_DTO_USERDELETEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UserDeletedMessage {
+public:
+	UserDeletedMessage(	
+		QString data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	UserDeletedMessage(const UserDeletedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UserDeletedMessage &other);
+	
+	static UserDeletedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+	/**
+	 * @brief Gets or sets the data.
+	 */
+	QString data() const;
+	/**
+	* @brief Gets or sets the data.
+	*/
+	void setData(QString newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QString m_data;
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing UserDeletedMessage::fromJson();
+	UserDeletedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDeletedMessage = Jellyfin::DTO::UserDeletedMessage;
+
+template <>
+UserDeletedMessage fromJsonValue(const QJsonValue &source, convertType<UserDeletedMessage>);
+
+template<>
+QJsonValue toJsonValue(const UserDeletedMessage &source, convertType<UserDeletedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_USERDELETEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/useritemdatadto.h b/core/include/JellyfinQt/dto/useritemdatadto.h
index 3f3a933..f7b0eef 100644
--- a/core/include/JellyfinQt/dto/useritemdatadto.h
+++ b/core/include/JellyfinQt/dto/useritemdatadto.h
@@ -52,7 +52,9 @@ public:
 		qint64 playbackPositionTicks,			
 		qint32 playCount,			
 		bool isFavorite,							
-		bool played						
+		bool played,			
+		QString key,			
+		QString itemId		
 	);
 
 	UserItemDataDto(const UserItemDataDto &other);
@@ -166,8 +168,6 @@ public:
 	* @brief Gets or sets the key.
 	*/
 	void setKey(QString newKey);
-	bool keyNull() const;
-	void setKeyNull();
 
 	/**
 	 * @brief Gets or sets the item identifier.
@@ -177,8 +177,6 @@ public:
 	* @brief Gets or sets the item identifier.
 	*/
 	void setItemId(QString newItemId);
-	bool itemIdNull() const;
-	void setItemIdNull();
 
 
 protected:
diff --git a/core/include/JellyfinQt/dto/userpolicy.h b/core/include/JellyfinQt/dto/userpolicy.h
index e7218ca..f3c59be 100644
--- a/core/include/JellyfinQt/dto/userpolicy.h
+++ b/core/include/JellyfinQt/dto/userpolicy.h
@@ -55,7 +55,10 @@ public:
 	UserPolicy(	
 		bool isAdministrator,			
 		bool isHidden,			
-		bool isDisabled,							
+		std::optional<bool> enableCollectionManagement,			
+		std::optional<bool> enableSubtitleManagement,			
+		std::optional<bool> enableLyricManagement,			
+		bool isDisabled,									
 		bool enableUserPreferenceAccess,							
 		bool enableRemoteControlOfOtherUsers,			
 		bool enableSharedDeviceControl,			
@@ -78,7 +81,9 @@ public:
 		qint32 loginAttemptsBeforeLockout,			
 		qint32 maxActiveSessions,			
 		bool enablePublicSharing,							
-		qint32 remoteClientBitrateLimit,							
+		qint32 remoteClientBitrateLimit,			
+		QString authenticationProviderId,			
+		QString passwordResetProviderId,			
 		SyncPlayUserAccessType syncPlayAccess		
 	);
 
@@ -112,6 +117,33 @@ public:
 	*/
 	void setIsHidden(bool newIsHidden);
 
+	/**
+	 * @brief Gets or sets a value indicating whether this instance can manage collections.
+	 */
+	std::optional<bool> enableCollectionManagement() const;
+	/**
+	* @brief Gets or sets a value indicating whether this instance can manage collections.
+	*/
+	void setEnableCollectionManagement(std::optional<bool> newEnableCollectionManagement);
+
+	/**
+	 * @brief Gets or sets a value indicating whether this instance can manage subtitles.
+	 */
+	std::optional<bool> enableSubtitleManagement() const;
+	/**
+	* @brief Gets or sets a value indicating whether this instance can manage subtitles.
+	*/
+	void setEnableSubtitleManagement(std::optional<bool> newEnableSubtitleManagement);
+
+	/**
+	 * @brief Gets or sets a value indicating whether this user can manage lyrics.
+	 */
+	std::optional<bool> enableLyricManagement() const;
+	/**
+	* @brief Gets or sets a value indicating whether this user can manage lyrics.
+	*/
+	void setEnableLyricManagement(std::optional<bool> newEnableLyricManagement);
+
 	/**
 	 * @brief Gets or sets a value indicating whether this instance is disabled.
 	 */
@@ -140,6 +172,13 @@ public:
 	void setBlockedTagsNull();
 
 
+	QStringList allowedTags() const;
+
+	void setAllowedTags(QStringList newAllowedTags);
+	bool allowedTagsNull() const;
+	void setAllowedTagsNull();
+
+
 	bool enableUserPreferenceAccess() const;
 
 	void setEnableUserPreferenceAccess(bool newEnableUserPreferenceAccess);
@@ -318,15 +357,11 @@ public:
 	QString authenticationProviderId() const;
 
 	void setAuthenticationProviderId(QString newAuthenticationProviderId);
-	bool authenticationProviderIdNull() const;
-	void setAuthenticationProviderIdNull();
 
 
 	QString passwordResetProviderId() const;
 
 	void setPasswordResetProviderId(QString newPasswordResetProviderId);
-	bool passwordResetProviderIdNull() const;
-	void setPasswordResetProviderIdNull();
 
 
 	SyncPlayUserAccessType syncPlayAccess() const;
@@ -337,9 +372,13 @@ public:
 protected:
 	bool m_isAdministrator;
 	bool m_isHidden;
+	std::optional<bool> m_enableCollectionManagement = std::nullopt;
+	std::optional<bool> m_enableSubtitleManagement = std::nullopt;
+	std::optional<bool> m_enableLyricManagement = std::nullopt;
 	bool m_isDisabled;
 	std::optional<qint32> m_maxParentalRating = std::nullopt;
 	QStringList m_blockedTags;
+	QStringList m_allowedTags;
 	bool m_enableUserPreferenceAccess;
 	QList<AccessSchedule> m_accessSchedules;
 	QList<UnratedItem> m_blockUnratedItems;
diff --git a/core/include/JellyfinQt/dto/userupdatedmessage.h b/core/include/JellyfinQt/dto/userupdatedmessage.h
new file mode 100644
index 0000000..8bc47e9
--- /dev/null
+++ b/core/include/JellyfinQt/dto/userupdatedmessage.h
@@ -0,0 +1,117 @@
+/*
+ * 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_DTO_USERUPDATEDMESSAGE_H
+#define JELLYFIN_DTO_USERUPDATEDMESSAGE_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QSharedPointer>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/dto/sessionmessagetype.h"
+#include "JellyfinQt/dto/userdto.h"
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class UserUpdatedMessage {
+public:
+	UserUpdatedMessage(	
+		QSharedPointer<UserDto> data,			
+		QString messageId,			
+		SessionMessageType messageType		
+	);
+
+	UserUpdatedMessage(const UserUpdatedMessage &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(UserUpdatedMessage &other);
+	
+	static UserUpdatedMessage fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QSharedPointer<UserDto> data() const;
+
+	void setData(QSharedPointer<UserDto> newData);
+
+	/**
+	 * @brief Gets or sets the message id.
+	 */
+	QString messageId() const;
+	/**
+	* @brief Gets or sets the message id.
+	*/
+	void setMessageId(QString newMessageId);
+
+
+	SessionMessageType messageType() const;
+
+	void setMessageType(SessionMessageType newMessageType);
+
+
+protected:
+	QSharedPointer<UserDto> m_data = QSharedPointer<UserDto>();
+	QString m_messageId;
+	SessionMessageType m_messageType;
+
+private:
+	// Private constructor which generates an invalid object, for use withing UserUpdatedMessage::fromJson();
+	UserUpdatedMessage();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserUpdatedMessage = Jellyfin::DTO::UserUpdatedMessage;
+
+template <>
+UserUpdatedMessage fromJsonValue(const QJsonValue &source, convertType<UserUpdatedMessage>);
+
+template<>
+QJsonValue toJsonValue(const UserUpdatedMessage &source, convertType<UserUpdatedMessage>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_USERUPDATEDMESSAGE_H
diff --git a/core/include/JellyfinQt/dto/versioninfo.h b/core/include/JellyfinQt/dto/versioninfo.h
index 392f62c..2d2fe02 100644
--- a/core/include/JellyfinQt/dto/versioninfo.h
+++ b/core/include/JellyfinQt/dto/versioninfo.h
@@ -32,11 +32,9 @@
 
 #include <QJsonObject>
 #include <QJsonValue>
-#include <QSharedPointer>
 #include <QString>
 #include <optional>
 
-#include "JellyfinQt/dto/version.h"
 #include "JellyfinQt/support/jsonconv.h"
 
 namespace Jellyfin {
@@ -49,8 +47,11 @@ namespace DTO {
 
 class VersionInfo {
 public:
-	VersionInfo(			
-		QSharedPointer<Version> versionNumber																
+	VersionInfo(	
+		QString version,			
+		QString versionNumber,													
+		QString repositoryName,			
+		QString repositoryUrl		
 	);
 
 	VersionInfo(const VersionInfo &other);
@@ -73,13 +74,15 @@ public:
 	* @brief Gets or sets the version.
 	*/
 	void setVersion(QString newVersion);
-	bool versionNull() const;
-	void setVersionNull();
 
-
-	QSharedPointer<Version> versionNumber() const;
-
-	void setVersionNumber(QSharedPointer<Version> newVersionNumber);
+	/**
+	 * @brief Gets the version as a System.Version.
+	 */
+	QString versionNumber() const;
+	/**
+	* @brief Gets the version as a System.Version.
+	*/
+	void setVersionNumber(QString newVersionNumber);
 
 	/**
 	 * @brief Gets or sets the changelog for this version.
@@ -144,8 +147,6 @@ public:
 	* @brief Gets or sets the repository name.
 	*/
 	void setRepositoryName(QString newRepositoryName);
-	bool repositoryNameNull() const;
-	void setRepositoryNameNull();
 
 	/**
 	 * @brief Gets or sets the repository url.
@@ -155,13 +156,11 @@ public:
 	* @brief Gets or sets the repository url.
 	*/
 	void setRepositoryUrl(QString newRepositoryUrl);
-	bool repositoryUrlNull() const;
-	void setRepositoryUrlNull();
 
 
 protected:
 	QString m_version;
-	QSharedPointer<Version> m_versionNumber = QSharedPointer<Version>();
+	QString m_versionNumber;
 	QString m_changelog;
 	QString m_targetAbi;
 	QString m_sourceUrl;
diff --git a/core/include/JellyfinQt/dto/ffmpeglocation.h b/core/include/JellyfinQt/dto/videorange.h
similarity index 77%
rename from core/include/JellyfinQt/dto/ffmpeglocation.h
rename to core/include/JellyfinQt/dto/videorange.h
index 1aac3f0..a320332 100644
--- a/core/include/JellyfinQt/dto/ffmpeglocation.h
+++ b/core/include/JellyfinQt/dto/videorange.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_DTO_FFMPEGLOCATION_H
-#define JELLYFIN_DTO_FFMPEGLOCATION_H
+#ifndef JELLYFIN_DTO_VIDEORANGE_H
+#define JELLYFIN_DTO_VIDEORANGE_H
 
 #include <QJsonValue>
 #include <QObject>
@@ -43,36 +43,35 @@ class ApiClient;
 namespace Jellyfin {
 namespace DTO {
 
-class FFmpegLocationClass {
+class VideoRangeClass {
 	Q_GADGET
 public:
 	enum Value {
 		EnumNotSet,
-		NotFound,
-		SetByArgument,
-		Custom,
-		System,
+		Unknown,
+		SDR,
+		HDR,
 	};
 	Q_ENUM(Value)
 private:
-	explicit FFmpegLocationClass();
+	explicit VideoRangeClass();
 };
 
-using FFmpegLocation = FFmpegLocationClass::Value;
+using VideoRange = VideoRangeClass::Value;
 
 } // NS DTO
 
 namespace Support {
 
-using FFmpegLocation = Jellyfin::DTO::FFmpegLocation;
+using VideoRange = Jellyfin::DTO::VideoRange;
 
 template <>
-FFmpegLocation fromJsonValue(const QJsonValue &source, convertType<FFmpegLocation>);
+VideoRange fromJsonValue(const QJsonValue &source, convertType<VideoRange>);
 
 template <>
-QJsonValue toJsonValue(const FFmpegLocation &source, convertType<FFmpegLocation>);
+QJsonValue toJsonValue(const VideoRange &source, convertType<VideoRange>);
 
 } // NS DTO
 } // NS Jellyfin
 
-#endif // JELLYFIN_DTO_FFMPEGLOCATION_H
+#endif // JELLYFIN_DTO_VIDEORANGE_H
diff --git a/core/include/JellyfinQt/dto/videorangetype.h b/core/include/JellyfinQt/dto/videorangetype.h
new file mode 100644
index 0000000..1c6dba2
--- /dev/null
+++ b/core/include/JellyfinQt/dto/videorangetype.h
@@ -0,0 +1,83 @@
+/*
+ * 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_DTO_VIDEORANGETYPE_H
+#define JELLYFIN_DTO_VIDEORANGETYPE_H
+
+#include <QJsonValue>
+#include <QObject>
+#include <QString>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+class VideoRangeTypeClass {
+	Q_GADGET
+public:
+	enum Value {
+		EnumNotSet,
+		Unknown,
+		SDR,
+		HDR10,
+		HLG,
+		DOVI,
+		DOVIWithHDR10,
+		DOVIWithHLG,
+		DOVIWithSDR,
+		HDR10Plus,
+	};
+	Q_ENUM(Value)
+private:
+	explicit VideoRangeTypeClass();
+};
+
+using VideoRangeType = VideoRangeTypeClass::Value;
+
+} // NS DTO
+
+namespace Support {
+
+using VideoRangeType = Jellyfin::DTO::VideoRangeType;
+
+template <>
+VideoRangeType fromJsonValue(const QJsonValue &source, convertType<VideoRangeType>);
+
+template <>
+QJsonValue toJsonValue(const VideoRangeType &source, convertType<VideoRangeType>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_VIDEORANGETYPE_H
diff --git a/core/include/JellyfinQt/dto/virtualfolderinfo.h b/core/include/JellyfinQt/dto/virtualfolderinfo.h
index f45fa6f..a306491 100644
--- a/core/include/JellyfinQt/dto/virtualfolderinfo.h
+++ b/core/include/JellyfinQt/dto/virtualfolderinfo.h
@@ -38,6 +38,7 @@
 #include <QStringList>
 #include <optional>
 
+#include "JellyfinQt/dto/collectiontypeoptions.h"
 #include "JellyfinQt/dto/libraryoptions.h"
 #include "JellyfinQt/support/jsonconv.h"
 
@@ -51,7 +52,8 @@ namespace DTO {
 
 class VirtualFolderInfo {
 public:
-	VirtualFolderInfo(							
+	VirtualFolderInfo(					
+		CollectionTypeOptions collectionType,			
 		QSharedPointer<LibraryOptions> libraryOptions										
 	);
 
@@ -89,16 +91,10 @@ public:
 	bool locationsNull() const;
 	void setLocationsNull();
 
-	/**
-	 * @brief Gets or sets the type of the collection.
-	 */
-	QString collectionType() const;
-	/**
-	* @brief Gets or sets the type of the collection.
-	*/
-	void setCollectionType(QString newCollectionType);
-	bool collectionTypeNull() const;
-	void setCollectionTypeNull();
+
+	CollectionTypeOptions collectionType() const;
+
+	void setCollectionType(CollectionTypeOptions newCollectionType);
 
 
 	QSharedPointer<LibraryOptions> libraryOptions() const;
@@ -145,7 +141,7 @@ public:
 protected:
 	QString m_name;
 	QStringList m_locations;
-	QString m_collectionType;
+	CollectionTypeOptions m_collectionType;
 	QSharedPointer<LibraryOptions> m_libraryOptions = QSharedPointer<LibraryOptions>();
 	QString m_itemId;
 	QString m_primaryImageItemId;
diff --git a/core/include/JellyfinQt/dto/websocketmessage.h b/core/include/JellyfinQt/dto/websocketmessage.h
new file mode 100644
index 0000000..9535b22
--- /dev/null
+++ b/core/include/JellyfinQt/dto/websocketmessage.h
@@ -0,0 +1,48 @@
+/*
+ * 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_DTO_WEBSOCKETMESSAGE_H
+#define JELLYFIN_DTO_WEBSOCKETMESSAGE_H
+
+#include <QJsonObject>
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+using WebSocketMessage = QJsonObject;
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_WEBSOCKETMESSAGE_H
+// No implementation needed
diff --git a/core/include/JellyfinQt/dto/xbmcmetadataoptions.h b/core/include/JellyfinQt/dto/xbmcmetadataoptions.h
new file mode 100644
index 0000000..600c210
--- /dev/null
+++ b/core/include/JellyfinQt/dto/xbmcmetadataoptions.h
@@ -0,0 +1,125 @@
+/*
+ * 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_DTO_XBMCMETADATAOPTIONS_H
+#define JELLYFIN_DTO_XBMCMETADATAOPTIONS_H
+
+#include <QJsonObject>
+#include <QJsonValue>
+#include <QString>
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace DTO {
+
+
+class XbmcMetadataOptions {
+public:
+	XbmcMetadataOptions(			
+		QString releaseDateFormat,			
+		bool saveImagePathsInNfo,			
+		bool enablePathSubstitution,			
+		bool enableExtraThumbsDuplication		
+	);
+
+	XbmcMetadataOptions(const XbmcMetadataOptions &other);
+	
+	/**
+	 * Replaces the data being hold by this class with that of the other.
+	 */
+	void replaceData(XbmcMetadataOptions &other);
+	
+	static XbmcMetadataOptions fromJson(QJsonObject source);
+	void setFromJson(QJsonObject source);
+	QJsonObject toJson() const;
+	
+	// Properties
+
+	QString userId() const;
+
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+
+
+	QString releaseDateFormat() const;
+
+	void setReleaseDateFormat(QString newReleaseDateFormat);
+
+
+	bool saveImagePathsInNfo() const;
+
+	void setSaveImagePathsInNfo(bool newSaveImagePathsInNfo);
+
+
+	bool enablePathSubstitution() const;
+
+	void setEnablePathSubstitution(bool newEnablePathSubstitution);
+
+
+	bool enableExtraThumbsDuplication() const;
+
+	void setEnableExtraThumbsDuplication(bool newEnableExtraThumbsDuplication);
+
+
+protected:
+	QString m_userId;
+	QString m_releaseDateFormat;
+	bool m_saveImagePathsInNfo;
+	bool m_enablePathSubstitution;
+	bool m_enableExtraThumbsDuplication;
+
+private:
+	// Private constructor which generates an invalid object, for use withing XbmcMetadataOptions::fromJson();
+	XbmcMetadataOptions();
+};
+
+
+} // NS DTO
+
+namespace Support {
+
+using XbmcMetadataOptions = Jellyfin::DTO::XbmcMetadataOptions;
+
+template <>
+XbmcMetadataOptions fromJsonValue(const QJsonValue &source, convertType<XbmcMetadataOptions>);
+
+template<>
+QJsonValue toJsonValue(const XbmcMetadataOptions &source, convertType<XbmcMetadataOptions>);
+
+} // NS DTO
+} // NS Jellyfin
+
+#endif // JELLYFIN_DTO_XBMCMETADATAOPTIONS_H
diff --git a/core/include/JellyfinQt/loader/http/clientlog.h b/core/include/JellyfinQt/loader/http/clientlog.h
new file mode 100644
index 0000000..69b858f
--- /dev/null
+++ b/core/include/JellyfinQt/loader/http/clientlog.h
@@ -0,0 +1,69 @@
+/*
+ * 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_CLIENTLOG_H
+#define JELLYFIN_LOADER_HTTP_CLIENTLOG_H
+
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+#include "JellyfinQt/support/loader.h"
+#include "JellyfinQt/loader/requesttypes.h"
+#include "JellyfinQt/dto/clientlogdocumentresponsedto.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+/**
+ * @brief Upload a document.
+ */
+
+class LogFileLoader : public Jellyfin::Support::HttpLoader<ClientLogDocumentResponseDto, LogFileParams> {
+public:
+	explicit LogFileLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const LogFileParams& parameters) const override;
+	QUrlQuery query(const LogFileParams& parameters) const override;
+	QByteArray body(const LogFileParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
+
+#endif // JELLYFIN_LOADER_HTTP_CLIENTLOG_H
diff --git a/core/include/JellyfinQt/loader/http/configuration.h b/core/include/JellyfinQt/loader/http/configuration.h
index f2636e7..39bfff6 100644
--- a/core/include/JellyfinQt/loader/http/configuration.h
+++ b/core/include/JellyfinQt/loader/http/configuration.h
@@ -118,20 +118,6 @@ protected:
 	QByteArray body(const GetDefaultMetadataOptionsParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Updates the path to the media encoder.
- */
-
-class UpdateMediaEncoderPathLoader : public Jellyfin::Support::HttpLoader<void, UpdateMediaEncoderPathParams> {
-public:
-	explicit UpdateMediaEncoderPathLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateMediaEncoderPathParams& parameters) const override;
-	QUrlQuery query(const UpdateMediaEncoderPathParams& parameters) const override;
-	QByteArray body(const UpdateMediaEncoderPathParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/devices.h b/core/include/JellyfinQt/loader/http/devices.h
index 54c6bdc..a0e22c9 100644
--- a/core/include/JellyfinQt/loader/http/devices.h
+++ b/core/include/JellyfinQt/loader/http/devices.h
@@ -35,9 +35,9 @@
 #include "JellyfinQt/support/jsonconv.h"
 #include "JellyfinQt/support/loader.h"
 #include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/deviceinfoqueryresult.h"
-#include "JellyfinQt/dto/deviceinfo.h"
-#include "JellyfinQt/dto/deviceoptions.h"
+#include "JellyfinQt/dto/deviceinfodtoqueryresult.h"
+#include "JellyfinQt/dto/deviceinfodto.h"
+#include "JellyfinQt/dto/deviceoptionsdto.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -53,7 +53,7 @@ using namespace Jellyfin::DTO;
  * @brief Get Devices.
  */
 
-class GetDevicesLoader : public Jellyfin::Support::HttpLoader<DeviceInfoQueryResult, GetDevicesParams> {
+class GetDevicesLoader : public Jellyfin::Support::HttpLoader<DeviceInfoDtoQueryResult, GetDevicesParams> {
 public:
 	explicit GetDevicesLoader(ApiClient *apiClient = nullptr);
 
@@ -81,7 +81,7 @@ protected:
  * @brief Get info for a device.
  */
 
-class GetDeviceInfoLoader : public Jellyfin::Support::HttpLoader<DeviceInfo, GetDeviceInfoParams> {
+class GetDeviceInfoLoader : public Jellyfin::Support::HttpLoader<DeviceInfoDto, GetDeviceInfoParams> {
 public:
 	explicit GetDeviceInfoLoader(ApiClient *apiClient = nullptr);
 
@@ -95,7 +95,7 @@ protected:
  * @brief Get options for a device.
  */
 
-class GetDeviceOptionsLoader : public Jellyfin::Support::HttpLoader<DeviceOptions, GetDeviceOptionsParams> {
+class GetDeviceOptionsLoader : public Jellyfin::Support::HttpLoader<DeviceOptionsDto, GetDeviceOptionsParams> {
 public:
 	explicit GetDeviceOptionsLoader(ApiClient *apiClient = nullptr);
 
diff --git a/core/include/JellyfinQt/loader/http/dlna.h b/core/include/JellyfinQt/loader/http/dlna.h
deleted file mode 100644
index 67f1b80..0000000
--- a/core/include/JellyfinQt/loader/http/dlna.h
+++ /dev/null
@@ -1,141 +0,0 @@
-/*
- * 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_DLNA_H
-#define JELLYFIN_LOADER_HTTP_DLNA_H
-
-#include <optional>
-
-#include "JellyfinQt/support/jsonconv.h"
-#include "JellyfinQt/support/loader.h"
-#include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/deviceprofileinfo.h"
-#include "JellyfinQt/dto/deviceprofile.h"
-#include "JellyfinQt/dto/deviceprofile.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-/**
- * @brief Get profile infos.
- */
-
-class GetProfileInfosLoader : public Jellyfin::Support::HttpLoader<QList<DeviceProfileInfo>, GetProfileInfosParams> {
-public:
-	explicit GetProfileInfosLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetProfileInfosParams& parameters) const override;
-	QUrlQuery query(const GetProfileInfosParams& parameters) const override;
-	QByteArray body(const GetProfileInfosParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Creates a profile.
- */
-
-class CreateProfileLoader : public Jellyfin::Support::HttpLoader<void, CreateProfileParams> {
-public:
-	explicit CreateProfileLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const CreateProfileParams& parameters) const override;
-	QUrlQuery query(const CreateProfileParams& parameters) const override;
-	QByteArray body(const CreateProfileParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Gets a single profile.
- */
-
-class GetProfileLoader : public Jellyfin::Support::HttpLoader<DeviceProfile, GetProfileParams> {
-public:
-	explicit GetProfileLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetProfileParams& parameters) const override;
-	QUrlQuery query(const GetProfileParams& parameters) const override;
-	QByteArray body(const GetProfileParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Deletes a profile.
- */
-
-class DeleteProfileLoader : public Jellyfin::Support::HttpLoader<void, DeleteProfileParams> {
-public:
-	explicit DeleteProfileLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const DeleteProfileParams& parameters) const override;
-	QUrlQuery query(const DeleteProfileParams& parameters) const override;
-	QByteArray body(const DeleteProfileParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Updates a profile.
- */
-
-class UpdateProfileLoader : public Jellyfin::Support::HttpLoader<void, UpdateProfileParams> {
-public:
-	explicit UpdateProfileLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateProfileParams& parameters) const override;
-	QUrlQuery query(const UpdateProfileParams& parameters) const override;
-	QByteArray body(const UpdateProfileParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Gets the default profile.
- */
-
-class GetDefaultProfileLoader : public Jellyfin::Support::HttpLoader<DeviceProfile, GetDefaultProfileParams> {
-public:
-	explicit GetDefaultProfileLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetDefaultProfileParams& parameters) const override;
-	QUrlQuery query(const GetDefaultProfileParams& parameters) const override;
-	QByteArray body(const GetDefaultProfileParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
-
-#endif // JELLYFIN_LOADER_HTTP_DLNA_H
diff --git a/core/include/JellyfinQt/loader/http/image.h b/core/include/JellyfinQt/loader/http/image.h
index 0bb28f6..3ee6640 100644
--- a/core/include/JellyfinQt/loader/http/image.h
+++ b/core/include/JellyfinQt/loader/http/image.h
@@ -47,6 +47,35 @@ 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.
  */
@@ -159,34 +188,6 @@ protected:
 	QByteArray body(const DeleteUserImageParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Sets the user image.
- */
-
-class PostUserImageByIndexLoader : public Jellyfin::Support::HttpLoader<void, PostUserImageByIndexParams> {
-public:
-	explicit PostUserImageByIndexLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const PostUserImageByIndexParams& parameters) const override;
-	QUrlQuery query(const PostUserImageByIndexParams& parameters) const override;
-	QByteArray body(const PostUserImageByIndexParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Delete the user's image.
- */
-
-class DeleteUserImageByIndexLoader : public Jellyfin::Support::HttpLoader<void, DeleteUserImageByIndexParams> {
-public:
-	explicit DeleteUserImageByIndexLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const DeleteUserImageByIndexParams& parameters) const override;
-	QUrlQuery query(const DeleteUserImageByIndexParams& parameters) const override;
-	QByteArray body(const DeleteUserImageByIndexParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/imagebyname.h b/core/include/JellyfinQt/loader/http/imagebyname.h
deleted file mode 100644
index 76721ab..0000000
--- a/core/include/JellyfinQt/loader/http/imagebyname.h
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * 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_IMAGEBYNAME_H
-#define JELLYFIN_LOADER_HTTP_IMAGEBYNAME_H
-
-#include <optional>
-
-#include "JellyfinQt/support/jsonconv.h"
-#include "JellyfinQt/support/loader.h"
-#include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/imagebynameinfo.h"
-#include "JellyfinQt/dto/imagebynameinfo.h"
-#include "JellyfinQt/dto/imagebynameinfo.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-/**
- * @brief Get all general images.
- */
-
-class GetGeneralImagesLoader : public Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetGeneralImagesParams> {
-public:
-	explicit GetGeneralImagesLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetGeneralImagesParams& parameters) const override;
-	QUrlQuery query(const GetGeneralImagesParams& parameters) const override;
-	QByteArray body(const GetGeneralImagesParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Get all media info images.
- */
-
-class GetMediaInfoImagesLoader : public Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetMediaInfoImagesParams> {
-public:
-	explicit GetMediaInfoImagesLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetMediaInfoImagesParams& parameters) const override;
-	QUrlQuery query(const GetMediaInfoImagesParams& parameters) const override;
-	QByteArray body(const GetMediaInfoImagesParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Get all general images.
- */
-
-class GetRatingImagesLoader : public Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetRatingImagesParams> {
-public:
-	explicit GetRatingImagesLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetRatingImagesParams& parameters) const override;
-	QUrlQuery query(const GetRatingImagesParams& parameters) const override;
-	QByteArray body(const GetRatingImagesParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
-
-#endif // JELLYFIN_LOADER_HTTP_IMAGEBYNAME_H
diff --git a/core/include/JellyfinQt/loader/http/instantmix.h b/core/include/JellyfinQt/loader/http/instantmix.h
index 91d853d..e9df851 100644
--- a/core/include/JellyfinQt/loader/http/instantmix.h
+++ b/core/include/JellyfinQt/loader/http/instantmix.h
@@ -42,6 +42,7 @@
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
+#include "JellyfinQt/dto/baseitemdtoqueryresult.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -54,7 +55,7 @@ namespace HTTP {
 using namespace Jellyfin::DTO;
 
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given album.
  */
 
 class GetInstantMixFromAlbumLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromAlbumParams> {
@@ -68,7 +69,7 @@ protected:
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given artist.
  */
 
 class GetInstantMixFromArtistsLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromArtistsParams> {
@@ -82,7 +83,21 @@ protected:
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given artist.
+ */
+
+class GetInstantMixFromArtists2Loader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromArtists2Params> {
+public:
+	explicit GetInstantMixFromArtists2Loader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetInstantMixFromArtists2Params& parameters) const override;
+	QUrlQuery query(const GetInstantMixFromArtists2Params& parameters) const override;
+	QByteArray body(const GetInstantMixFromArtists2Params& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Creates an instant playlist based on a given item.
  */
 
 class GetInstantMixFromItemLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromItemParams> {
@@ -96,35 +111,35 @@ protected:
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given genre.
  */
 
-class GetInstantMixFromMusicGenresLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenresParams> {
+class GetInstantMixFromMusicGenreByNameLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreByNameParams> {
 public:
-	explicit GetInstantMixFromMusicGenresLoader(ApiClient *apiClient = nullptr);
+	explicit GetInstantMixFromMusicGenreByNameLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const GetInstantMixFromMusicGenresParams& parameters) const override;
-	QUrlQuery query(const GetInstantMixFromMusicGenresParams& parameters) const override;
-	QByteArray body(const GetInstantMixFromMusicGenresParams& parameters) const override;
+	QString path(const GetInstantMixFromMusicGenreByNameParams& parameters) const override;
+	QUrlQuery query(const GetInstantMixFromMusicGenreByNameParams& parameters) const override;
+	QByteArray body(const GetInstantMixFromMusicGenreByNameParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given genre.
  */
 
-class GetInstantMixFromMusicGenreLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreParams> {
+class GetInstantMixFromMusicGenreByIdLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreByIdParams> {
 public:
-	explicit GetInstantMixFromMusicGenreLoader(ApiClient *apiClient = nullptr);
+	explicit GetInstantMixFromMusicGenreByIdLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const GetInstantMixFromMusicGenreParams& parameters) const override;
-	QUrlQuery query(const GetInstantMixFromMusicGenreParams& parameters) const override;
-	QByteArray body(const GetInstantMixFromMusicGenreParams& parameters) const override;
+	QString path(const GetInstantMixFromMusicGenreByIdParams& parameters) const override;
+	QUrlQuery query(const GetInstantMixFromMusicGenreByIdParams& parameters) const override;
+	QByteArray body(const GetInstantMixFromMusicGenreByIdParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Creates an instant playlist based on a given song.
+ * @brief Creates an instant playlist based on a given playlist.
  */
 
 class GetInstantMixFromPlaylistLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromPlaylistParams> {
diff --git a/core/include/JellyfinQt/loader/http/itemrefresh.h b/core/include/JellyfinQt/loader/http/itemrefresh.h
index 61ec6be..5e97550 100644
--- a/core/include/JellyfinQt/loader/http/itemrefresh.h
+++ b/core/include/JellyfinQt/loader/http/itemrefresh.h
@@ -50,14 +50,14 @@ using namespace Jellyfin::DTO;
  * @brief Refreshes metadata for an item.
  */
 
-class PostLoader : public Jellyfin::Support::HttpLoader<void, PostParams> {
+class RefreshItemLoader : public Jellyfin::Support::HttpLoader<void, RefreshItemParams> {
 public:
-	explicit PostLoader(ApiClient *apiClient = nullptr);
+	explicit RefreshItemLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const PostParams& parameters) const override;
-	QUrlQuery query(const PostParams& parameters) const override;
-	QByteArray body(const PostParams& parameters) const override;
+	QString path(const RefreshItemParams& parameters) const override;
+	QUrlQuery query(const RefreshItemParams& parameters) const override;
+	QByteArray body(const RefreshItemParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 
diff --git a/core/include/JellyfinQt/loader/http/items.h b/core/include/JellyfinQt/loader/http/items.h
index bb91830..92e6d88 100644
--- a/core/include/JellyfinQt/loader/http/items.h
+++ b/core/include/JellyfinQt/loader/http/items.h
@@ -36,7 +36,8 @@
 #include "JellyfinQt/support/loader.h"
 #include "JellyfinQt/loader/requesttypes.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
-#include "JellyfinQt/dto/baseitemdtoqueryresult.h"
+#include "JellyfinQt/dto/useritemdatadto.h"
+#include "JellyfinQt/dto/useritemdatadto.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
 
 namespace Jellyfin {
@@ -64,17 +65,31 @@ protected:
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
- * @brief Gets items based on a query.
+ * @brief Get Item User Data.
  */
 
-class GetItemsByUserIdLoader : public Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetItemsByUserIdParams> {
+class GetItemUserDataLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, GetItemUserDataParams> {
 public:
-	explicit GetItemsByUserIdLoader(ApiClient *apiClient = nullptr);
+	explicit GetItemUserDataLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const GetItemsByUserIdParams& parameters) const override;
-	QUrlQuery query(const GetItemsByUserIdParams& parameters) const override;
-	QByteArray body(const GetItemsByUserIdParams& parameters) const override;
+	QString path(const GetItemUserDataParams& parameters) const override;
+	QUrlQuery query(const GetItemUserDataParams& parameters) const override;
+	QByteArray body(const GetItemUserDataParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Update Item User Data.
+ */
+
+class UpdateItemUserDataLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateItemUserDataParams> {
+public:
+	explicit UpdateItemUserDataLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdateItemUserDataParams& parameters) const override;
+	QUrlQuery query(const UpdateItemUserDataParams& parameters) const override;
+	QByteArray body(const UpdateItemUserDataParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
diff --git a/core/include/JellyfinQt/loader/http/lyrics.h b/core/include/JellyfinQt/loader/http/lyrics.h
new file mode 100644
index 0000000..587846e
--- /dev/null
+++ b/core/include/JellyfinQt/loader/http/lyrics.h
@@ -0,0 +1,143 @@
+/*
+ * 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_LYRICS_H
+#define JELLYFIN_LOADER_HTTP_LYRICS_H
+
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+#include "JellyfinQt/support/loader.h"
+#include "JellyfinQt/loader/requesttypes.h"
+#include "JellyfinQt/dto/lyricdto.h"
+#include "JellyfinQt/dto/lyricdto.h"
+#include "JellyfinQt/dto/remotelyricinfodto.h"
+#include "JellyfinQt/dto/lyricdto.h"
+#include "JellyfinQt/dto/lyricdto.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+/**
+ * @brief Gets an item's lyrics.
+ */
+
+class GetLyricsLoader : public Jellyfin::Support::HttpLoader<LyricDto, GetLyricsParams> {
+public:
+	explicit GetLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetLyricsParams& parameters) const override;
+	QUrlQuery query(const GetLyricsParams& parameters) const override;
+	QByteArray body(const GetLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Upload an external lyric file.
+ */
+
+class UploadLyricsLoader : public Jellyfin::Support::HttpLoader<LyricDto, UploadLyricsParams> {
+public:
+	explicit UploadLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UploadLyricsParams& parameters) const override;
+	QUrlQuery query(const UploadLyricsParams& parameters) const override;
+	QByteArray body(const UploadLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Deletes an external lyric file.
+ */
+
+class DeleteLyricsLoader : public Jellyfin::Support::HttpLoader<void, DeleteLyricsParams> {
+public:
+	explicit DeleteLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const DeleteLyricsParams& parameters) const override;
+	QUrlQuery query(const DeleteLyricsParams& parameters) const override;
+	QByteArray body(const DeleteLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Search remote lyrics.
+ */
+
+class SearchRemoteLyricsLoader : public Jellyfin::Support::HttpLoader<QList<RemoteLyricInfoDto>, SearchRemoteLyricsParams> {
+public:
+	explicit SearchRemoteLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const SearchRemoteLyricsParams& parameters) const override;
+	QUrlQuery query(const SearchRemoteLyricsParams& parameters) const override;
+	QByteArray body(const SearchRemoteLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Downloads a remote lyric.
+ */
+
+class DownloadRemoteLyricsLoader : public Jellyfin::Support::HttpLoader<LyricDto, DownloadRemoteLyricsParams> {
+public:
+	explicit DownloadRemoteLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const DownloadRemoteLyricsParams& parameters) const override;
+	QUrlQuery query(const DownloadRemoteLyricsParams& parameters) const override;
+	QByteArray body(const DownloadRemoteLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Gets the remote lyrics.
+ */
+
+class GetRemoteLyricsLoader : public Jellyfin::Support::HttpLoader<LyricDto, GetRemoteLyricsParams> {
+public:
+	explicit GetRemoteLyricsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetRemoteLyricsParams& parameters) const override;
+	QUrlQuery query(const GetRemoteLyricsParams& parameters) const override;
+	QByteArray body(const GetRemoteLyricsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
+
+#endif // JELLYFIN_LOADER_HTTP_LYRICS_H
diff --git a/core/include/JellyfinQt/loader/http/mediasegments.h b/core/include/JellyfinQt/loader/http/mediasegments.h
new file mode 100644
index 0000000..24349e9
--- /dev/null
+++ b/core/include/JellyfinQt/loader/http/mediasegments.h
@@ -0,0 +1,69 @@
+/*
+ * 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_MEDIASEGMENTS_H
+#define JELLYFIN_LOADER_HTTP_MEDIASEGMENTS_H
+
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+#include "JellyfinQt/support/loader.h"
+#include "JellyfinQt/loader/requesttypes.h"
+#include "JellyfinQt/dto/mediasegmentdtoqueryresult.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+/**
+ * @brief Gets all media segments based on an itemId.
+ */
+
+class GetItemSegmentsLoader : public Jellyfin::Support::HttpLoader<MediaSegmentDtoQueryResult, GetItemSegmentsParams> {
+public:
+	explicit GetItemSegmentsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetItemSegmentsParams& parameters) const override;
+	QUrlQuery query(const GetItemSegmentsParams& parameters) const override;
+	QByteArray body(const GetItemSegmentsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
+
+#endif // JELLYFIN_LOADER_HTTP_MEDIASEGMENTS_H
diff --git a/core/include/JellyfinQt/loader/http/notifications.h b/core/include/JellyfinQt/loader/http/notifications.h
deleted file mode 100644
index 6ce32df..0000000
--- a/core/include/JellyfinQt/loader/http/notifications.h
+++ /dev/null
@@ -1,156 +0,0 @@
-/*
- * 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_NOTIFICATIONS_H
-#define JELLYFIN_LOADER_HTTP_NOTIFICATIONS_H
-
-#include <optional>
-
-#include "JellyfinQt/support/jsonconv.h"
-#include "JellyfinQt/support/loader.h"
-#include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/notificationresultdto.h"
-#include "JellyfinQt/dto/notificationssummarydto.h"
-#include "JellyfinQt/dto/nameidpair.h"
-#include "JellyfinQt/dto/notificationtypeinfo.h"
-
-namespace Jellyfin {
-// Forward declaration
-class ApiClient;
-}
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-/**
- * @brief Gets a user's notifications.
- */
-
-class GetNotificationsLoader : public Jellyfin::Support::HttpLoader<NotificationResultDto, GetNotificationsParams> {
-public:
-	explicit GetNotificationsLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetNotificationsParams& parameters) const override;
-	QUrlQuery query(const GetNotificationsParams& parameters) const override;
-	QByteArray body(const GetNotificationsParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Sets notifications as read.
- */
-
-class SetReadLoader : public Jellyfin::Support::HttpLoader<void, SetReadParams> {
-public:
-	explicit SetReadLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const SetReadParams& parameters) const override;
-	QUrlQuery query(const SetReadParams& parameters) const override;
-	QByteArray body(const SetReadParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Gets a user's notification summary.
- */
-
-class GetNotificationsSummaryLoader : public Jellyfin::Support::HttpLoader<NotificationsSummaryDto, GetNotificationsSummaryParams> {
-public:
-	explicit GetNotificationsSummaryLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetNotificationsSummaryParams& parameters) const override;
-	QUrlQuery query(const GetNotificationsSummaryParams& parameters) const override;
-	QByteArray body(const GetNotificationsSummaryParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Sets notifications as unread.
- */
-
-class SetUnreadLoader : public Jellyfin::Support::HttpLoader<void, SetUnreadParams> {
-public:
-	explicit SetUnreadLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const SetUnreadParams& parameters) const override;
-	QUrlQuery query(const SetUnreadParams& parameters) const override;
-	QByteArray body(const SetUnreadParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Sends a notification to all admins.
- */
-
-class CreateAdminNotificationLoader : public Jellyfin::Support::HttpLoader<void, CreateAdminNotificationParams> {
-public:
-	explicit CreateAdminNotificationLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const CreateAdminNotificationParams& parameters) const override;
-	QUrlQuery query(const CreateAdminNotificationParams& parameters) const override;
-	QByteArray body(const CreateAdminNotificationParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Gets notification services.
- */
-
-class GetNotificationServicesLoader : public Jellyfin::Support::HttpLoader<QList<NameIdPair>, GetNotificationServicesParams> {
-public:
-	explicit GetNotificationServicesLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetNotificationServicesParams& parameters) const override;
-	QUrlQuery query(const GetNotificationServicesParams& parameters) const override;
-	QByteArray body(const GetNotificationServicesParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Gets notification types.
- */
-
-class GetNotificationTypesLoader : public Jellyfin::Support::HttpLoader<QList<NotificationTypeInfo>, GetNotificationTypesParams> {
-public:
-	explicit GetNotificationTypesLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetNotificationTypesParams& parameters) const override;
-	QUrlQuery query(const GetNotificationTypesParams& parameters) const override;
-	QByteArray body(const GetNotificationTypesParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
-
-#endif // JELLYFIN_LOADER_HTTP_NOTIFICATIONS_H
diff --git a/core/include/JellyfinQt/loader/http/playlists.h b/core/include/JellyfinQt/loader/http/playlists.h
index 8df3078..69b1360 100644
--- a/core/include/JellyfinQt/loader/http/playlists.h
+++ b/core/include/JellyfinQt/loader/http/playlists.h
@@ -36,7 +36,10 @@
 #include "JellyfinQt/support/loader.h"
 #include "JellyfinQt/loader/requesttypes.h"
 #include "JellyfinQt/dto/playlistcreationresult.h"
+#include "JellyfinQt/dto/playlistdto.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
+#include "JellyfinQt/dto/playlistuserpermissions.h"
+#include "JellyfinQt/dto/playlistuserpermissions.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -62,32 +65,60 @@ protected:
 	QByteArray body(const CreatePlaylistParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Updates a playlist.
+ */
+
+class UpdatePlaylistLoader : public Jellyfin::Support::HttpLoader<void, UpdatePlaylistParams> {
+public:
+	explicit UpdatePlaylistLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdatePlaylistParams& parameters) const override;
+	QUrlQuery query(const UpdatePlaylistParams& parameters) const override;
+	QByteArray body(const UpdatePlaylistParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Get a playlist.
+ */
+
+class GetPlaylistLoader : public Jellyfin::Support::HttpLoader<PlaylistDto, GetPlaylistParams> {
+public:
+	explicit GetPlaylistLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetPlaylistParams& parameters) const override;
+	QUrlQuery query(const GetPlaylistParams& parameters) const override;
+	QByteArray body(const GetPlaylistParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 /**
  * @brief Adds items to a playlist.
  */
 
-class AddToPlaylistLoader : public Jellyfin::Support::HttpLoader<void, AddToPlaylistParams> {
+class AddItemToPlaylistLoader : public Jellyfin::Support::HttpLoader<void, AddItemToPlaylistParams> {
 public:
-	explicit AddToPlaylistLoader(ApiClient *apiClient = nullptr);
+	explicit AddItemToPlaylistLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const AddToPlaylistParams& parameters) const override;
-	QUrlQuery query(const AddToPlaylistParams& parameters) const override;
-	QByteArray body(const AddToPlaylistParams& parameters) const override;
+	QString path(const AddItemToPlaylistParams& parameters) const override;
+	QUrlQuery query(const AddItemToPlaylistParams& parameters) const override;
+	QByteArray body(const AddItemToPlaylistParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
  * @brief Removes items from a playlist.
  */
 
-class RemoveFromPlaylistLoader : public Jellyfin::Support::HttpLoader<void, RemoveFromPlaylistParams> {
+class RemoveItemFromPlaylistLoader : public Jellyfin::Support::HttpLoader<void, RemoveItemFromPlaylistParams> {
 public:
-	explicit RemoveFromPlaylistLoader(ApiClient *apiClient = nullptr);
+	explicit RemoveItemFromPlaylistLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const RemoveFromPlaylistParams& parameters) const override;
-	QUrlQuery query(const RemoveFromPlaylistParams& parameters) const override;
-	QByteArray body(const RemoveFromPlaylistParams& parameters) const override;
+	QString path(const RemoveItemFromPlaylistParams& parameters) const override;
+	QUrlQuery query(const RemoveItemFromPlaylistParams& parameters) const override;
+	QByteArray body(const RemoveItemFromPlaylistParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
@@ -118,6 +149,62 @@ protected:
 	QByteArray body(const MoveItemParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Get a playlist's users.
+ */
+
+class GetPlaylistUsersLoader : public Jellyfin::Support::HttpLoader<QList<PlaylistUserPermissions>, GetPlaylistUsersParams> {
+public:
+	explicit GetPlaylistUsersLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetPlaylistUsersParams& parameters) const override;
+	QUrlQuery query(const GetPlaylistUsersParams& parameters) const override;
+	QByteArray body(const GetPlaylistUsersParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Get a playlist user.
+ */
+
+class GetPlaylistUserLoader : public Jellyfin::Support::HttpLoader<PlaylistUserPermissions, GetPlaylistUserParams> {
+public:
+	explicit GetPlaylistUserLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetPlaylistUserParams& parameters) const override;
+	QUrlQuery query(const GetPlaylistUserParams& parameters) const override;
+	QByteArray body(const GetPlaylistUserParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Modify a user of a playlist's users.
+ */
+
+class UpdatePlaylistUserLoader : public Jellyfin::Support::HttpLoader<void, UpdatePlaylistUserParams> {
+public:
+	explicit UpdatePlaylistUserLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdatePlaylistUserParams& parameters) const override;
+	QUrlQuery query(const UpdatePlaylistUserParams& parameters) const override;
+	QByteArray body(const UpdatePlaylistUserParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Remove a user from a playlist's users.
+ */
+
+class RemoveUserFromPlaylistLoader : public Jellyfin::Support::HttpLoader<void, RemoveUserFromPlaylistParams> {
+public:
+	explicit RemoveUserFromPlaylistLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const RemoveUserFromPlaylistParams& parameters) const override;
+	QUrlQuery query(const RemoveUserFromPlaylistParams& parameters) const override;
+	QByteArray body(const RemoveUserFromPlaylistParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/playstate.h b/core/include/JellyfinQt/loader/http/playstate.h
index 1c981fa..b0f3d22 100644
--- a/core/include/JellyfinQt/loader/http/playstate.h
+++ b/core/include/JellyfinQt/loader/http/playstate.h
@@ -48,6 +48,48 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
+/**
+ * @brief Reports that a session has begun playing an item.
+ */
+
+class OnPlaybackStartLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackStartParams> {
+public:
+	explicit OnPlaybackStartLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const OnPlaybackStartParams& parameters) const override;
+	QUrlQuery query(const OnPlaybackStartParams& parameters) const override;
+	QByteArray body(const OnPlaybackStartParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Reports that a session has stopped playing an item.
+ */
+
+class OnPlaybackStoppedLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackStoppedParams> {
+public:
+	explicit OnPlaybackStoppedLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const OnPlaybackStoppedParams& parameters) const override;
+	QUrlQuery query(const OnPlaybackStoppedParams& parameters) const override;
+	QByteArray body(const OnPlaybackStoppedParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Reports a session's playback progress.
+ */
+
+class OnPlaybackProgressLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackProgressParams> {
+public:
+	explicit OnPlaybackProgressLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const OnPlaybackProgressParams& parameters) const override;
+	QUrlQuery query(const OnPlaybackProgressParams& parameters) const override;
+	QByteArray body(const OnPlaybackProgressParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 /**
  * @brief Reports playback has started within a session.
  */
@@ -132,48 +174,6 @@ protected:
 	QByteArray body(const MarkUnplayedItemParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Reports that a user has begun playing an item.
- */
-
-class OnPlaybackStartLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackStartParams> {
-public:
-	explicit OnPlaybackStartLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const OnPlaybackStartParams& parameters) const override;
-	QUrlQuery query(const OnPlaybackStartParams& parameters) const override;
-	QByteArray body(const OnPlaybackStartParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Reports that a user has stopped playing an item.
- */
-
-class OnPlaybackStoppedLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackStoppedParams> {
-public:
-	explicit OnPlaybackStoppedLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const OnPlaybackStoppedParams& parameters) const override;
-	QUrlQuery query(const OnPlaybackStoppedParams& parameters) const override;
-	QByteArray body(const OnPlaybackStoppedParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Reports a user's playback progress.
- */
-
-class OnPlaybackProgressLoader : public Jellyfin::Support::HttpLoader<void, OnPlaybackProgressParams> {
-public:
-	explicit OnPlaybackProgressLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const OnPlaybackProgressParams& parameters) const override;
-	QUrlQuery query(const OnPlaybackProgressParams& parameters) const override;
-	QByteArray body(const OnPlaybackProgressParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/plugins.h b/core/include/JellyfinQt/loader/http/plugins.h
index 9931970..4ef3176 100644
--- a/core/include/JellyfinQt/loader/http/plugins.h
+++ b/core/include/JellyfinQt/loader/http/plugins.h
@@ -160,20 +160,6 @@ protected:
 	QByteArray body(const GetPluginManifestParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Updates plugin security info.
- */
-
-class UpdatePluginSecurityInfoLoader : public Jellyfin::Support::HttpLoader<void, UpdatePluginSecurityInfoParams> {
-public:
-	explicit UpdatePluginSecurityInfoLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdatePluginSecurityInfoParams& parameters) const override;
-	QUrlQuery query(const UpdatePluginSecurityInfoParams& parameters) const override;
-	QByteArray body(const UpdatePluginSecurityInfoParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/quickconnect.h b/core/include/JellyfinQt/loader/http/quickconnect.h
index 1478958..207b439 100644
--- a/core/include/JellyfinQt/loader/http/quickconnect.h
+++ b/core/include/JellyfinQt/loader/http/quickconnect.h
@@ -37,7 +37,6 @@
 #include "JellyfinQt/loader/requesttypes.h"
 #include "JellyfinQt/dto/quickconnectresult.h"
 #include "JellyfinQt/dto/quickconnectresult.h"
-#include "JellyfinQt/dto/quickconnectstate.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -49,102 +48,60 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-/**
- * @brief Temporarily activates quick connect for five minutes.
- */
-
-class ActivateLoader : public Jellyfin::Support::HttpLoader<void, ActivateParams> {
-public:
-	explicit ActivateLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const ActivateParams& parameters) const override;
-	QUrlQuery query(const ActivateParams& parameters) const override;
-	QByteArray body(const ActivateParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 /**
  * @brief Authorizes a pending quick connect request.
  */
 
-class AuthorizeLoader : public Jellyfin::Support::HttpLoader<bool, AuthorizeParams> {
+class AuthorizeQuickConnectLoader : public Jellyfin::Support::HttpLoader<bool, AuthorizeQuickConnectParams> {
 public:
-	explicit AuthorizeLoader(ApiClient *apiClient = nullptr);
+	explicit AuthorizeQuickConnectLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const AuthorizeParams& parameters) const override;
-	QUrlQuery query(const AuthorizeParams& parameters) const override;
-	QByteArray body(const AuthorizeParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Enables or disables quick connect.
- */
-
-class AvailableLoader : public Jellyfin::Support::HttpLoader<void, AvailableParams> {
-public:
-	explicit AvailableLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const AvailableParams& parameters) const override;
-	QUrlQuery query(const AvailableParams& parameters) const override;
-	QByteArray body(const AvailableParams& parameters) const override;
+	QString path(const AuthorizeQuickConnectParams& parameters) const override;
+	QUrlQuery query(const AuthorizeQuickConnectParams& parameters) const override;
+	QByteArray body(const AuthorizeQuickConnectParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
  * @brief Attempts to retrieve authentication information.
  */
 
-class ConnectLoader : public Jellyfin::Support::HttpLoader<QuickConnectResult, ConnectParams> {
+class GetQuickConnectStateLoader : public Jellyfin::Support::HttpLoader<QuickConnectResult, GetQuickConnectStateParams> {
 public:
-	explicit ConnectLoader(ApiClient *apiClient = nullptr);
+	explicit GetQuickConnectStateLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const ConnectParams& parameters) const override;
-	QUrlQuery query(const ConnectParams& parameters) const override;
-	QByteArray body(const ConnectParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Deauthorize all quick connect devices for the current user.
- */
-
-class DeauthorizeLoader : public Jellyfin::Support::HttpLoader<qint32, DeauthorizeParams> {
-public:
-	explicit DeauthorizeLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const DeauthorizeParams& parameters) const override;
-	QUrlQuery query(const DeauthorizeParams& parameters) const override;
-	QByteArray body(const DeauthorizeParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Initiate a new quick connect request.
- */
-
-class InitiateLoader : public Jellyfin::Support::HttpLoader<QuickConnectResult, InitiateParams> {
-public:
-	explicit InitiateLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const InitiateParams& parameters) const override;
-	QUrlQuery query(const InitiateParams& parameters) const override;
-	QByteArray body(const InitiateParams& parameters) const override;
+	QString path(const GetQuickConnectStateParams& parameters) const override;
+	QUrlQuery query(const GetQuickConnectStateParams& parameters) const override;
+	QByteArray body(const GetQuickConnectStateParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 /**
  * @brief Gets the current quick connect state.
  */
 
-class GetStatusLoader : public Jellyfin::Support::HttpLoader<QuickConnectState, GetStatusParams> {
+class GetQuickConnectEnabledLoader : public Jellyfin::Support::HttpLoader<bool, GetQuickConnectEnabledParams> {
 public:
-	explicit GetStatusLoader(ApiClient *apiClient = nullptr);
+	explicit GetQuickConnectEnabledLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const GetStatusParams& parameters) const override;
-	QUrlQuery query(const GetStatusParams& parameters) const override;
-	QByteArray body(const GetStatusParams& parameters) const override;
+	QString path(const GetQuickConnectEnabledParams& parameters) const override;
+	QUrlQuery query(const GetQuickConnectEnabledParams& parameters) const override;
+	QByteArray body(const GetQuickConnectEnabledParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Initiate a new quick connect request.
+ */
+
+class InitiateQuickConnectLoader : public Jellyfin::Support::HttpLoader<QuickConnectResult, InitiateQuickConnectParams> {
+public:
+	explicit InitiateQuickConnectLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const InitiateQuickConnectParams& parameters) const override;
+	QUrlQuery query(const InitiateQuickConnectParams& parameters) const override;
+	QByteArray body(const InitiateQuickConnectParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 
diff --git a/core/include/JellyfinQt/loader/http/search.h b/core/include/JellyfinQt/loader/http/search.h
index 9f3bd96..440374e 100644
--- a/core/include/JellyfinQt/loader/http/search.h
+++ b/core/include/JellyfinQt/loader/http/search.h
@@ -51,14 +51,14 @@ using namespace Jellyfin::DTO;
  * @brief Gets the search hint result.
  */
 
-class GetLoader : public Jellyfin::Support::HttpLoader<SearchHintResult, GetParams> {
+class GetSearchHintsLoader : public Jellyfin::Support::HttpLoader<SearchHintResult, GetSearchHintsParams> {
 public:
-	explicit GetLoader(ApiClient *apiClient = nullptr);
+	explicit GetSearchHintsLoader(ApiClient *apiClient = nullptr);
 
 protected:
-	QString path(const GetParams& parameters) const override;
-	QUrlQuery query(const GetParams& parameters) const override;
-	QByteArray body(const GetParams& parameters) const override;
+	QString path(const GetSearchHintsParams& parameters) const override;
+	QUrlQuery query(const GetSearchHintsParams& parameters) const override;
+	QByteArray body(const GetSearchHintsParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
 
diff --git a/core/include/JellyfinQt/loader/http/session.h b/core/include/JellyfinQt/loader/http/session.h
index ffd5a6b..5eeb71d 100644
--- a/core/include/JellyfinQt/loader/http/session.h
+++ b/core/include/JellyfinQt/loader/http/session.h
@@ -37,7 +37,7 @@
 #include "JellyfinQt/loader/requesttypes.h"
 #include "JellyfinQt/dto/nameidpair.h"
 #include "JellyfinQt/dto/nameidpair.h"
-#include "JellyfinQt/dto/sessioninfo.h"
+#include "JellyfinQt/dto/sessioninfodto.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -81,7 +81,7 @@ protected:
  * @brief Gets a list of sessions.
  */
 
-class GetSessionsLoader : public Jellyfin::Support::HttpLoader<QList<SessionInfo>, GetSessionsParams> {
+class GetSessionsLoader : public Jellyfin::Support::HttpLoader<QList<SessionInfoDto>, GetSessionsParams> {
 public:
 	explicit GetSessionsLoader(ApiClient *apiClient = nullptr);
 
diff --git a/core/include/JellyfinQt/loader/http/tmdb.h b/core/include/JellyfinQt/loader/http/tmdb.h
new file mode 100644
index 0000000..9fda96d
--- /dev/null
+++ b/core/include/JellyfinQt/loader/http/tmdb.h
@@ -0,0 +1,69 @@
+/*
+ * 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_TMDB_H
+#define JELLYFIN_LOADER_HTTP_TMDB_H
+
+#include <optional>
+
+#include "JellyfinQt/support/jsonconv.h"
+#include "JellyfinQt/support/loader.h"
+#include "JellyfinQt/loader/requesttypes.h"
+#include "JellyfinQt/dto/configimagetypes.h"
+
+namespace Jellyfin {
+// Forward declaration
+class ApiClient;
+}
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+/**
+ * @brief Gets the TMDb image configuration options.
+ */
+
+class TmdbClientConfigurationLoader : public Jellyfin::Support::HttpLoader<ConfigImageTypes, TmdbClientConfigurationParams> {
+public:
+	explicit TmdbClientConfigurationLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const TmdbClientConfigurationParams& parameters) const override;
+	QUrlQuery query(const TmdbClientConfigurationParams& parameters) const override;
+	QByteArray body(const TmdbClientConfigurationParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
+
+#endif // JELLYFIN_LOADER_HTTP_TMDB_H
diff --git a/core/include/JellyfinQt/loader/http/videohls.h b/core/include/JellyfinQt/loader/http/trickplay.h
similarity index 93%
rename from core/include/JellyfinQt/loader/http/videohls.h
rename to core/include/JellyfinQt/loader/http/trickplay.h
index 05bcabb..caebf5c 100644
--- a/core/include/JellyfinQt/loader/http/videohls.h
+++ b/core/include/JellyfinQt/loader/http/trickplay.h
@@ -27,8 +27,8 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#ifndef JELLYFIN_LOADER_HTTP_VIDEOHLS_H
-#define JELLYFIN_LOADER_HTTP_VIDEOHLS_H
+#ifndef JELLYFIN_LOADER_HTTP_TRICKPLAY_H
+#define JELLYFIN_LOADER_HTTP_TRICKPLAY_H
 
 #include <optional>
 
@@ -51,4 +51,4 @@ using namespace Jellyfin::DTO;
 } // NS Loader
 } // NS Jellyfin
 
-#endif // JELLYFIN_LOADER_HTTP_VIDEOHLS_H
+#endif // JELLYFIN_LOADER_HTTP_TRICKPLAY_H
diff --git a/core/include/JellyfinQt/loader/http/user.h b/core/include/JellyfinQt/loader/http/user.h
index bd3f319..ad43262 100644
--- a/core/include/JellyfinQt/loader/http/user.h
+++ b/core/include/JellyfinQt/loader/http/user.h
@@ -39,7 +39,6 @@
 #include "JellyfinQt/dto/userdto.h"
 #include "JellyfinQt/dto/authenticationresult.h"
 #include "JellyfinQt/dto/authenticationresult.h"
-#include "JellyfinQt/dto/authenticationresult.h"
 #include "JellyfinQt/dto/forgotpasswordresult.h"
 #include "JellyfinQt/dto/pinredeemresult.h"
 #include "JellyfinQt/dto/userdto.h"
@@ -70,6 +69,20 @@ protected:
 	QByteArray body(const GetUsersParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Updates a user.
+ */
+
+class UpdateUserLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserParams> {
+public:
+	explicit UpdateUserLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdateUserParams& parameters) const override;
+	QUrlQuery query(const UpdateUserParams& parameters) const override;
+	QByteArray body(const UpdateUserParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 /**
  * @brief Gets a user by Id.
  */
@@ -98,76 +111,6 @@ protected:
 	QByteArray body(const DeleteUserParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Updates a user.
- */
-
-class UpdateUserLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserParams> {
-public:
-	explicit UpdateUserLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateUserParams& parameters) const override;
-	QUrlQuery query(const UpdateUserParams& parameters) const override;
-	QByteArray body(const UpdateUserParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Authenticates a user.
- */
-
-class AuthenticateUserLoader : public Jellyfin::Support::HttpLoader<AuthenticationResult, AuthenticateUserParams> {
-public:
-	explicit AuthenticateUserLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const AuthenticateUserParams& parameters) const override;
-	QUrlQuery query(const AuthenticateUserParams& parameters) const override;
-	QByteArray body(const AuthenticateUserParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Updates a user configuration.
- */
-
-class UpdateUserConfigurationLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserConfigurationParams> {
-public:
-	explicit UpdateUserConfigurationLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateUserConfigurationParams& parameters) const override;
-	QUrlQuery query(const UpdateUserConfigurationParams& parameters) const override;
-	QByteArray body(const UpdateUserConfigurationParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Updates a user's easy password.
- */
-
-class UpdateUserEasyPasswordLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserEasyPasswordParams> {
-public:
-	explicit UpdateUserEasyPasswordLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateUserEasyPasswordParams& parameters) const override;
-	QUrlQuery query(const UpdateUserEasyPasswordParams& parameters) const override;
-	QByteArray body(const UpdateUserEasyPasswordParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Updates a user's password.
- */
-
-class UpdateUserPasswordLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserPasswordParams> {
-public:
-	explicit UpdateUserPasswordLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateUserPasswordParams& parameters) const override;
-	QUrlQuery query(const UpdateUserPasswordParams& parameters) const override;
-	QByteArray body(const UpdateUserPasswordParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 /**
  * @brief Updates a user policy.
  */
@@ -210,6 +153,20 @@ protected:
 	QByteArray body(const AuthenticateWithQuickConnectParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Updates a user configuration.
+ */
+
+class UpdateUserConfigurationLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserConfigurationParams> {
+public:
+	explicit UpdateUserConfigurationLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdateUserConfigurationParams& parameters) const override;
+	QUrlQuery query(const UpdateUserConfigurationParams& parameters) const override;
+	QByteArray body(const UpdateUserConfigurationParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 /**
  * @brief Initiates the forgot password process for a local user.
  */
@@ -266,6 +223,20 @@ protected:
 	QByteArray body(const CreateUserByNameParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Updates a user's password.
+ */
+
+class UpdateUserPasswordLoader : public Jellyfin::Support::HttpLoader<void, UpdateUserPasswordParams> {
+public:
+	explicit UpdateUserPasswordLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdateUserPasswordParams& parameters) const override;
+	QUrlQuery query(const UpdateUserPasswordParams& parameters) const override;
+	QByteArray body(const UpdateUserPasswordParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 /**
  * @brief Gets a list of publicly visible users for display on a login screen.
  */
diff --git a/core/include/JellyfinQt/loader/http/userlibrary.h b/core/include/JellyfinQt/loader/http/userlibrary.h
index efba9a1..2ebd392 100644
--- a/core/include/JellyfinQt/loader/http/userlibrary.h
+++ b/core/include/JellyfinQt/loader/http/userlibrary.h
@@ -35,16 +35,16 @@
 #include "JellyfinQt/support/jsonconv.h"
 #include "JellyfinQt/support/loader.h"
 #include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/useritemdatadto.h"
-#include "JellyfinQt/dto/useritemdatadto.h"
 #include "JellyfinQt/dto/baseitemdto.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
 #include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/useritemdatadto.h"
+#include "JellyfinQt/dto/useritemdatadto.h"
 #include "JellyfinQt/dto/useritemdatadto.h"
 #include "JellyfinQt/dto/useritemdatadto.h"
-#include "JellyfinQt/dto/baseitemdto.h"
-#include "JellyfinQt/dto/baseitemdto.h"
-#include "JellyfinQt/dto/baseitemdto.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -56,34 +56,6 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-/**
- * @brief Marks an item as a favorite.
- */
-
-class MarkFavoriteItemLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, MarkFavoriteItemParams> {
-public:
-	explicit MarkFavoriteItemLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const MarkFavoriteItemParams& parameters) const override;
-	QUrlQuery query(const MarkFavoriteItemParams& parameters) const override;
-	QByteArray body(const MarkFavoriteItemParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Unmarks item as a favorite.
- */
-
-class UnmarkFavoriteItemLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, UnmarkFavoriteItemParams> {
-public:
-	explicit UnmarkFavoriteItemLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UnmarkFavoriteItemParams& parameters) const override;
-	QUrlQuery query(const UnmarkFavoriteItemParams& parameters) const override;
-	QByteArray body(const UnmarkFavoriteItemParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 /**
  * @brief Gets an item from a user's library.
  */
@@ -126,34 +98,6 @@ protected:
 	QByteArray body(const GetLocalTrailersParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
-/**
- * @brief Deletes a user's saved personal rating for an item.
- */
-
-class DeleteUserItemRatingLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, DeleteUserItemRatingParams> {
-public:
-	explicit DeleteUserItemRatingLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const DeleteUserItemRatingParams& parameters) const override;
-	QUrlQuery query(const DeleteUserItemRatingParams& parameters) const override;
-	QByteArray body(const DeleteUserItemRatingParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
-/**
- * @brief Updates a user's rating for an item.
- */
-
-class UpdateUserItemRatingLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateUserItemRatingParams> {
-public:
-	explicit UpdateUserItemRatingLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const UpdateUserItemRatingParams& parameters) const override;
-	QUrlQuery query(const UpdateUserItemRatingParams& parameters) const override;
-	QByteArray body(const UpdateUserItemRatingParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 /**
  * @brief Gets special features for an item.
  */
@@ -196,6 +140,62 @@ protected:
 	QByteArray body(const GetRootFolderParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Marks an item as a favorite.
+ */
+
+class MarkFavoriteItemLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, MarkFavoriteItemParams> {
+public:
+	explicit MarkFavoriteItemLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const MarkFavoriteItemParams& parameters) const override;
+	QUrlQuery query(const MarkFavoriteItemParams& parameters) const override;
+	QByteArray body(const MarkFavoriteItemParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Unmarks item as a favorite.
+ */
+
+class UnmarkFavoriteItemLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, UnmarkFavoriteItemParams> {
+public:
+	explicit UnmarkFavoriteItemLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UnmarkFavoriteItemParams& parameters) const override;
+	QUrlQuery query(const UnmarkFavoriteItemParams& parameters) const override;
+	QByteArray body(const UnmarkFavoriteItemParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Deletes a user's saved personal rating for an item.
+ */
+
+class DeleteUserItemRatingLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, DeleteUserItemRatingParams> {
+public:
+	explicit DeleteUserItemRatingLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const DeleteUserItemRatingParams& parameters) const override;
+	QUrlQuery query(const DeleteUserItemRatingParams& parameters) const override;
+	QByteArray body(const DeleteUserItemRatingParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
+/**
+ * @brief Updates a user's rating for an item.
+ */
+
+class UpdateUserItemRatingLoader : public Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateUserItemRatingParams> {
+public:
+	explicit UpdateUserItemRatingLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const UpdateUserItemRatingParams& parameters) const override;
+	QUrlQuery query(const UpdateUserItemRatingParams& parameters) const override;
+	QByteArray body(const UpdateUserItemRatingParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/http/userviews.h b/core/include/JellyfinQt/loader/http/userviews.h
index 473653e..e483ede 100644
--- a/core/include/JellyfinQt/loader/http/userviews.h
+++ b/core/include/JellyfinQt/loader/http/userviews.h
@@ -35,8 +35,8 @@
 #include "JellyfinQt/support/jsonconv.h"
 #include "JellyfinQt/support/loader.h"
 #include "JellyfinQt/loader/requesttypes.h"
-#include "JellyfinQt/dto/specialviewoptiondto.h"
 #include "JellyfinQt/dto/baseitemdtoqueryresult.h"
+#include "JellyfinQt/dto/specialviewoptiondto.h"
 
 namespace Jellyfin {
 // Forward declaration
@@ -48,20 +48,6 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-/**
- * @brief Get user view grouping options.
- */
-
-class GetGroupingOptionsLoader : public Jellyfin::Support::HttpLoader<QList<SpecialViewOptionDto>, GetGroupingOptionsParams> {
-public:
-	explicit GetGroupingOptionsLoader(ApiClient *apiClient = nullptr);
-
-protected:
-	QString path(const GetGroupingOptionsParams& parameters) const override;
-	QUrlQuery query(const GetGroupingOptionsParams& parameters) const override;
-	QByteArray body(const GetGroupingOptionsParams& parameters) const override;
-	QNetworkAccessManager::Operation operation() const override;
-};
 /**
  * @brief Get user views.
  */
@@ -76,6 +62,20 @@ protected:
 	QByteArray body(const GetUserViewsParams& parameters) const override;
 	QNetworkAccessManager::Operation operation() const override;
 };
+/**
+ * @brief Get user view grouping options.
+ */
+
+class GetGroupingOptionsLoader : public Jellyfin::Support::HttpLoader<QList<SpecialViewOptionDto>, GetGroupingOptionsParams> {
+public:
+	explicit GetGroupingOptionsLoader(ApiClient *apiClient = nullptr);
+
+protected:
+	QString path(const GetGroupingOptionsParams& parameters) const override;
+	QUrlQuery query(const GetGroupingOptionsParams& parameters) const override;
+	QByteArray body(const GetGroupingOptionsParams& parameters) const override;
+	QNetworkAccessManager::Operation operation() const override;
+};
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/include/JellyfinQt/loader/requesttypes.h b/core/include/JellyfinQt/loader/requesttypes.h
index f68f249..bd3277f 100644
--- a/core/include/JellyfinQt/loader/requesttypes.h
+++ b/core/include/JellyfinQt/loader/requesttypes.h
@@ -30,8 +30,10 @@
 #ifndef JELLYFIN_LOADER_REQUESTTYPES_H
 #define JELLYFIN_LOADER_REQUESTTYPES_H
 
+#include <QByteArray>
 #include <QDateTime>
 #include <QString>
+#include <QVariant>
 #include <QList>
 #include <QStringList>
 #include <optional>
@@ -41,19 +43,21 @@
 #include "JellyfinQt/dto/artistinforemotesearchquery.h"
 #include "JellyfinQt/dto/authenticateuserbyname.h"
 #include "JellyfinQt/dto/baseitemdto.h"
+#include "JellyfinQt/dto/baseitemkind.h"
 #include "JellyfinQt/dto/bookinforemotesearchquery.h"
 #include "JellyfinQt/dto/boxsetinforemotesearchquery.h"
 #include "JellyfinQt/dto/bufferrequestdto.h"
 #include "JellyfinQt/dto/channeltype.h"
 #include "JellyfinQt/dto/clientcapabilitiesdto.h"
-#include "JellyfinQt/dto/configurationpagetype.h"
+#include "JellyfinQt/dto/collectiontype.h"
+#include "JellyfinQt/dto/collectiontypeoptions.h"
 #include "JellyfinQt/dto/createplaylistdto.h"
 #include "JellyfinQt/dto/createuserbyname.h"
-#include "JellyfinQt/dto/deviceoptions.h"
-#include "JellyfinQt/dto/deviceprofile.h"
+#include "JellyfinQt/dto/deviceoptionsdto.h"
 #include "JellyfinQt/dto/displaypreferencesdto.h"
 #include "JellyfinQt/dto/encodingcontext.h"
 #include "JellyfinQt/dto/forgotpassworddto.h"
+#include "JellyfinQt/dto/forgotpasswordpindto.h"
 #include "JellyfinQt/dto/generalcommand.h"
 #include "JellyfinQt/dto/generalcommandtype.h"
 #include "JellyfinQt/dto/getprogramsdto.h"
@@ -62,20 +66,22 @@
 #include "JellyfinQt/dto/imagetype.h"
 #include "JellyfinQt/dto/itemfields.h"
 #include "JellyfinQt/dto/itemfilter.h"
+#include "JellyfinQt/dto/itemsortby.h"
 #include "JellyfinQt/dto/joingrouprequestdto.h"
 #include "JellyfinQt/dto/listingsproviderinfo.h"
 #include "JellyfinQt/dto/locationtype.h"
-#include "JellyfinQt/dto/mediaencoderpathdto.h"
 #include "JellyfinQt/dto/mediapathdto.h"
-#include "JellyfinQt/dto/mediapathinfo.h"
+#include "JellyfinQt/dto/mediasegmenttype.h"
+#include "JellyfinQt/dto/mediastreamprotocol.h"
+#include "JellyfinQt/dto/mediatype.h"
 #include "JellyfinQt/dto/mediaupdateinfodto.h"
+#include "JellyfinQt/dto/messagecommand.h"
 #include "JellyfinQt/dto/metadatarefreshmode.h"
 #include "JellyfinQt/dto/moveplaylistitemrequestdto.h"
 #include "JellyfinQt/dto/movieinforemotesearchquery.h"
 #include "JellyfinQt/dto/musicvideoinforemotesearchquery.h"
 #include "JellyfinQt/dto/newgrouprequestdto.h"
 #include "JellyfinQt/dto/nextitemrequestdto.h"
-#include "JellyfinQt/dto/notificationlevel.h"
 #include "JellyfinQt/dto/openlivestreamdto.h"
 #include "JellyfinQt/dto/personlookupinforemotesearchquery.h"
 #include "JellyfinQt/dto/pingrequestdto.h"
@@ -87,11 +93,9 @@
 #include "JellyfinQt/dto/playbackstartinfo.h"
 #include "JellyfinQt/dto/playbackstopinfo.h"
 #include "JellyfinQt/dto/playstatecommand.h"
-#include "JellyfinQt/dto/pluginsecurityinfo.h"
 #include "JellyfinQt/dto/previousitemrequestdto.h"
 #include "JellyfinQt/dto/queuerequestdto.h"
 #include "JellyfinQt/dto/quickconnectdto.h"
-#include "JellyfinQt/dto/quickconnectstate.h"
 #include "JellyfinQt/dto/readyrequestdto.h"
 #include "JellyfinQt/dto/recordingstatus.h"
 #include "JellyfinQt/dto/remotesearchresult.h"
@@ -117,14 +121,16 @@
 #include "JellyfinQt/dto/trailerinforemotesearchquery.h"
 #include "JellyfinQt/dto/tunerhostinfo.h"
 #include "JellyfinQt/dto/updatelibraryoptionsdto.h"
-#include "JellyfinQt/dto/updateusereasypassword.h"
+#include "JellyfinQt/dto/updatemediapathrequestdto.h"
+#include "JellyfinQt/dto/updateplaylistdto.h"
+#include "JellyfinQt/dto/updateplaylistuserdto.h"
+#include "JellyfinQt/dto/updateuseritemdatadto.h"
 #include "JellyfinQt/dto/updateuserpassword.h"
 #include "JellyfinQt/dto/uploadsubtitledto.h"
 #include "JellyfinQt/dto/userconfiguration.h"
 #include "JellyfinQt/dto/userdto.h"
 #include "JellyfinQt/dto/userpolicy.h"
 #include "JellyfinQt/dto/validatepathdto.h"
-#include "JellyfinQt/dto/version.h"
 #include "JellyfinQt/dto/videotype.h"
 
 namespace Jellyfin {
@@ -135,15 +141,43 @@ namespace Jellyfin {
 namespace Loader {
 
 using namespace Jellyfin::DTO;
-class ActivateParams {
+class AddItemToPlaylistParams {
 public:
 
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+	/**
+	 * @brief Item id, comma delimited.	
+	 */
+	const QStringList &ids() const;
+	void setIds(QStringList newIds);
+	bool idsNull() const;
+	void setIdsNull();
+	
+	
+	/**
+	 * @brief The userId.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
+	QString m_playlistId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QStringList m_ids;
+	QString m_userId;
 
 
 };
@@ -259,47 +293,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class AddToPlaylistParams {
-public:
-
-	/**
-	 * @brief The playlist id.	
-	 */
-	const QString &playlistId() const;
-	void setPlaylistId(QString newPlaylistId);
-
-	
-	/**
-	 * @brief Item id, comma delimited.	
-	 */
-	const QStringList &ids() const;
-	void setIds(QStringList newIds);
-	bool idsNull() const;
-	void setIdsNull();
-	
-	
-	/**
-	 * @brief The userId.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-	bool userIdNull() const;
-	void setUserIdNull();
-	
-	
-private:
-	// Required path parameters
-	QString m_playlistId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	QStringList m_ids;
-	QString m_userId;
-
-
 };
 
 class AddTunerHostParams {
@@ -359,8 +352,8 @@ public:
 	/**
 	 * @brief The type of the collection.	
 	 */
-	const QString &collectionType() const;
-	void setCollectionType(QString newCollectionType);
+	const CollectionTypeOptions &collectionType() const;
+	void setCollectionType(CollectionTypeOptions newCollectionType);
 	bool collectionTypeNull() const;
 	void setCollectionTypeNull();
 	
@@ -405,7 +398,7 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	QString m_collectionType;
+	CollectionTypeOptions m_collectionType;
 	QString m_name;
 	QStringList m_paths;
 	std::optional<bool> m_refreshLibrary = std::nullopt;
@@ -455,45 +448,6 @@ private:
 
 };
 
-class AuthenticateUserParams {
-public:
-
-	/**
-	 * @brief The user id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief The password as plain text.	
-	 */
-	const QString &pw() const;
-	void setPw(QString newPw);
-
-	
-	/**
-	 * @brief The password sha1-hash.	
-	 */
-	const QString &password() const;
-	void setPassword(QString newPassword);
-	bool passwordNull() const;
-	void setPasswordNull();
-	
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-	QString m_pw;
-
-	// Optional query parameters
-	QString m_password;
-
-
-};
-
 class AuthenticateUserByNameParams {
 public:
 
@@ -538,7 +492,7 @@ private:
 
 };
 
-class AuthorizeParams {
+class AuthorizeQuickConnectParams {
 public:
 
 	/**
@@ -548,6 +502,15 @@ public:
 	void setCode(QString newCode);
 
 	
+	/**
+	 * @brief The user the authorize. Access to the requested user is required.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
 	
@@ -555,29 +518,7 @@ private:
 	QString m_code;
 
 	// Optional query parameters
-
-
-};
-
-class AvailableParams {
-public:
-
-	/**
-	 * @brief New MediaBrowser.Model.QuickConnect.QuickConnectState.	
-	 */
-	const QuickConnectState &status() const;
-	void setStatus(QuickConnectState newStatus);
-	bool statusNull() const;
-	void setStatusNull();
-	
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-	QuickConnectState m_status;
+	QString m_userId;
 
 
 };
@@ -677,80 +618,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class ConnectParams {
-public:
-
-	/**
-	 * @brief Secret previously returned from the Initiate endpoint.	
-	 */
-	const QString &secret() const;
-	void setSecret(QString newSecret);
-
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-	QString m_secret;
-
-	// Optional query parameters
-
-
-};
-
-class CreateAdminNotificationParams {
-public:
-
-	/**
-	 * @brief The description of the notification.	
-	 */
-	const QString &description() const;
-	void setDescription(QString newDescription);
-	bool descriptionNull() const;
-	void setDescriptionNull();
-	
-	
-	/**
-	 * @brief The level of the notification.	
-	 */
-	const NotificationLevel &level() const;
-	void setLevel(NotificationLevel newLevel);
-	bool levelNull() const;
-	void setLevelNull();
-	
-	
-	/**
-	 * @brief The name of the notification.	
-	 */
-	const QString &name() const;
-	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-	
-	
-	/**
-	 * @brief The URL of the notification.	
-	 */
-	const QString &url() const;
-	void setUrl(QString newUrl);
-	bool urlNull() const;
-	void setUrlNull();
-	
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-	QString m_description;
-	NotificationLevel m_level;
-	QString m_name;
-	QString m_url;
-
-
 };
 
 class CreateCollectionParams {
@@ -842,8 +709,8 @@ public:
 	/**
 	 * @brief The media type.	
 	 */
-	const QString &mediaType() const;
-	void setMediaType(QString newMediaType);
+	const MediaType &mediaType() const;
+	void setMediaType(MediaType newMediaType);
 	bool mediaTypeNull() const;
 	void setMediaTypeNull();
 	
@@ -880,7 +747,7 @@ private:
 
 	// Optional query parameters
 	QStringList m_ids;
-	QString m_mediaType;
+	MediaType m_mediaType;
 	QString m_name;
 	QString m_userId;
 
@@ -889,28 +756,6 @@ private:
 
 };
 
-class CreateProfileParams {
-public:
-
-	/**
-	 * @brief Device profile.	
-	 */
-	const QSharedPointer<DeviceProfile> &body() const;
-	void setBody(QSharedPointer<DeviceProfile> newBody);
-
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-	// Body parameters
-	QSharedPointer<DeviceProfile> m_body;
-
-};
-
 class CreateSeriesTimerParams {
 public:
 
@@ -977,19 +822,6 @@ private:
 
 };
 
-class DeauthorizeParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
 class DeleteAlternateSourcesParams {
 public:
 
@@ -1009,6 +841,19 @@ private:
 	// Optional query parameters
 
 
+};
+
+class DeleteCustomSplashscreenParams {
+public:
+
+private:
+	// Required path parameters
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class DeleteDeviceParams {
@@ -1175,19 +1020,19 @@ private:
 
 };
 
-class DeleteProfileParams {
+class DeleteLyricsParams {
 public:
 
 	/**
-	 * @brief Profile id.	
+	 * @brief The item id.	
 	 */
-	const QString &profileId() const;
-	void setProfileId(QString newProfileId);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 private:
 	// Required path parameters
-	QString m_profileId;
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -1293,75 +1138,22 @@ private:
 class DeleteUserImageParams {
 public:
 
-	/**
-	 * @brief (Unused) Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
 	/**
 	 * @brief User Id.	
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief (Unused) Image index.	
-	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
-	bool indexNull() const;
-	void setIndexNull();
+	bool userIdNull() const;
+	void setUserIdNull();
 	
 	
 private:
 	// Required path parameters
-	ImageType m_imageType;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<qint32> m_index = std::nullopt;
-
-
-};
-
-class DeleteUserImageByIndexParams {
-public:
-
-	/**
-	 * @brief (Unused) Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
-	/**
-	 * @brief (Unused) Image index.	
-	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
-
-	
-	/**
-	 * @brief User Id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-private:
-	// Required path parameters
-	ImageType m_imageType;
-	qint32 m_index;
 	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
 
 
 };
@@ -1381,16 +1173,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -1408,14 +1202,14 @@ public:
 	/**
 	 * @brief Plugin version.	
 	 */
-	const QSharedPointer<Version> &version() const;
-	void setVersion(QSharedPointer<Version> newVersion);
+	const QString &version() const;
+	void setVersion(QString newVersion);
 
 	
 private:
 	// Required path parameters
 	QString m_pluginId;
-	QSharedPointer<Version> m_version;
+	QString m_version;
 	
 	// Required query parameters
 
@@ -1497,8 +1291,8 @@ public:
 	/**
 	 * @brief The type of item to browse to.	
 	 */
-	const QString &itemType() const;
-	void setItemType(QString newItemType);
+	const BaseItemKind &itemType() const;
+	void setItemType(BaseItemKind newItemType);
 
 	
 private:
@@ -1508,7 +1302,7 @@ private:
 	// Required query parameters
 	QString m_itemId;
 	QString m_itemName;
-	QString m_itemType;
+	BaseItemKind m_itemType;
 
 	// Optional query parameters
 
@@ -1552,6 +1346,35 @@ private:
 	QString m_imageUrl;
 
 
+};
+
+class DownloadRemoteLyricsParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief The lyric id.	
+	 */
+	const QString &lyricId() const;
+	void setLyricId(QString newLyricId);
+
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	QString m_lyricId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class DownloadRemoteSubtitlesParams {
@@ -1596,14 +1419,14 @@ public:
 	/**
 	 * @brief Plugin version.	
 	 */
-	const QSharedPointer<Version> &version() const;
-	void setVersion(QSharedPointer<Version> newVersion);
+	const QString &version() const;
+	void setVersion(QString newVersion);
 
 	
 private:
 	// Required path parameters
 	QString m_pluginId;
-	QSharedPointer<Version> m_version;
+	QString m_version;
 	
 	// Required query parameters
 
@@ -1638,10 +1461,10 @@ class ForgotPasswordPinParams {
 public:
 
 	/**
-	 * @brief The pin.	
+	 * @brief The forgot password pin request containing the entered pin.	
 	 */
-	const QString &body() const;
-	void setBody(QString newBody);
+	const QSharedPointer<ForgotPasswordPinDto> &body() const;
+	void setBody(QSharedPointer<ForgotPasswordPinDto> newBody);
 
 	
 private:
@@ -1652,198 +1475,7 @@ private:
 	// Optional query parameters
 
 	// Body parameters
-	QString m_body;
-
-};
-
-class GetParams {
-public:
-
-	/**
-	 * @brief The search term to filter on.	
-	 */
-	const QString &searchTerm() const;
-	void setSearchTerm(QString newSearchTerm);
-
-	
-	/**
-	 * @brief If specified, results with these item types are filtered out. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
-	bool excludeItemTypesNull() const;
-	void setExcludeItemTypesNull();
-	
-	
-	/**
-	 * @brief Optional filter whether to include artists.	
-	 */
-	const bool &includeArtists() const;
-	void setIncludeArtists(bool newIncludeArtists);
-	bool includeArtistsNull() const;
-	void setIncludeArtistsNull();
-	
-	
-	/**
-	 * @brief Optional filter whether to include genres.	
-	 */
-	const bool &includeGenres() const;
-	void setIncludeGenres(bool newIncludeGenres);
-	bool includeGenresNull() const;
-	void setIncludeGenresNull();
-	
-	
-	/**
-	 * @brief If specified, only results with the specified item types are returned. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
-	bool includeItemTypesNull() const;
-	void setIncludeItemTypesNull();
-	
-	
-	/**
-	 * @brief Optional filter whether to include media.	
-	 */
-	const bool &includeMedia() const;
-	void setIncludeMedia(bool newIncludeMedia);
-	bool includeMediaNull() const;
-	void setIncludeMediaNull();
-	
-	
-	/**
-	 * @brief Optional filter whether to include people.	
-	 */
-	const bool &includePeople() const;
-	void setIncludePeople(bool newIncludePeople);
-	bool includePeopleNull() const;
-	void setIncludePeopleNull();
-	
-	
-	/**
-	 * @brief Optional filter whether to include studios.	
-	 */
-	const bool &includeStudios() const;
-	void setIncludeStudios(bool newIncludeStudios);
-	bool includeStudiosNull() const;
-	void setIncludeStudiosNull();
-	
-	
-	/**
-	 * @brief Optional filter for kids.	
-	 */
-	const bool &isKids() const;
-	void setIsKids(bool newIsKids);
-	bool isKidsNull() const;
-	void setIsKidsNull();
-	
-	
-	/**
-	 * @brief Optional filter for movies.	
-	 */
-	const bool &isMovie() const;
-	void setIsMovie(bool newIsMovie);
-	bool isMovieNull() const;
-	void setIsMovieNull();
-	
-	
-	/**
-	 * @brief Optional filter for news.	
-	 */
-	const bool &isNews() const;
-	void setIsNews(bool newIsNews);
-	bool isNewsNull() const;
-	void setIsNewsNull();
-	
-	
-	/**
-	 * @brief Optional filter for series.	
-	 */
-	const bool &isSeries() const;
-	void setIsSeries(bool newIsSeries);
-	bool isSeriesNull() const;
-	void setIsSeriesNull();
-	
-	
-	/**
-	 * @brief Optional filter for sports.	
-	 */
-	const bool &isSports() const;
-	void setIsSports(bool newIsSports);
-	bool isSportsNull() const;
-	void setIsSportsNull();
-	
-	
-	/**
-	 * @brief Optional. The maximum number of records to return.	
-	 */
-	const qint32 &limit() const;
-	void setLimit(qint32 newLimit);
-	bool limitNull() const;
-	void setLimitNull();
-	
-	
-	/**
-	 * @brief If specified, only results with the specified media types are returned. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
-	bool mediaTypesNull() const;
-	void setMediaTypesNull();
-	
-	
-	/**
-	 * @brief If specified, only children of the parent are returned.	
-	 */
-	const QString &parentId() const;
-	void setParentId(QString newParentId);
-	bool parentIdNull() const;
-	void setParentIdNull();
-	
-	
-	/**
-	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
-	 */
-	const qint32 &startIndex() const;
-	void setStartIndex(qint32 newStartIndex);
-	bool startIndexNull() const;
-	void setStartIndexNull();
-	
-	
-	/**
-	 * @brief Optional. Supply a user id to search within a user's library or omit to search all.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-	bool userIdNull() const;
-	void setUserIdNull();
-	
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-	QString m_searchTerm;
-
-	// Optional query parameters
-	QStringList m_excludeItemTypes;
-	std::optional<bool> m_includeArtists = std::nullopt;
-	std::optional<bool> m_includeGenres = std::nullopt;
-	QStringList m_includeItemTypes;
-	std::optional<bool> m_includeMedia = std::nullopt;
-	std::optional<bool> m_includePeople = std::nullopt;
-	std::optional<bool> m_includeStudios = std::nullopt;
-	std::optional<bool> m_isKids = std::nullopt;
-	std::optional<bool> m_isMovie = std::nullopt;
-	std::optional<bool> m_isNews = std::nullopt;
-	std::optional<bool> m_isSeries = std::nullopt;
-	std::optional<bool> m_isSports = std::nullopt;
-	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaTypes;
-	QString m_parentId;
-	std::optional<qint32> m_startIndex = std::nullopt;
-	QString m_userId;
-
+	QSharedPointer<ForgotPasswordPinDto> m_body;
 
 };
 
@@ -1920,8 +1552,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -1974,8 +1606,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -2001,8 +1633,8 @@ public:
 	/**
 	 * @brief Optional filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -2097,6 +1729,24 @@ public:
 	void setSearchTermNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Sort Order - Ascending,Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
 	 */
@@ -2161,16 +1811,16 @@ private:
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	QList<ItemFilter> m_filters;
 	QStringList m_genreIds;
 	QStringList m_genres;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	std::optional<double> m_minCommunityRating = std::nullopt;
 	QString m_nameLessThan;
 	QString m_nameStartsWith;
@@ -2181,6 +1831,8 @@ private:
 	QStringList m_personIds;
 	QStringList m_personTypes;
 	QString m_searchTerm;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QStringList m_studioIds;
 	QStringList m_studios;
@@ -2290,15 +1942,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -2318,12 +1961,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -2425,10 +2077,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -2485,8 +2137,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -2539,8 +2191,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -2566,8 +2218,8 @@ public:
 	/**
 	 * @brief Optional filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -2662,6 +2314,24 @@ public:
 	void setSearchTermNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Sort Order - Ascending,Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
 	 */
@@ -2726,16 +2396,16 @@ private:
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	QList<ItemFilter> m_filters;
 	QStringList m_genreIds;
 	QStringList m_genres;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	std::optional<double> m_minCommunityRating = std::nullopt;
 	QString m_nameLessThan;
 	QString m_nameStartsWith;
@@ -2746,6 +2416,8 @@ private:
 	QStringList m_personIds;
 	QStringList m_personTypes;
 	QString m_searchTerm;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QStringList m_studioIds;
 	QStringList m_studios;
@@ -2840,7 +2512,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -2938,6 +2610,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -3209,7 +2890,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -3257,6 +2938,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -3348,7 +3030,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -3437,6 +3119,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -3609,7 +3300,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -3708,7 +3399,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -3756,6 +3447,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -4013,8 +3705,8 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
@@ -4022,8 +3714,8 @@ public:
 	/**
 	 * @brief Optional. Sort Order - Ascending,Descending.	
 	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 	
@@ -4057,8 +3749,8 @@ private:
 	QList<ItemFilter> m_filters;
 	QString m_folderId;
 	std::optional<qint32> m_limit = std::nullopt;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
@@ -4186,15 +3878,6 @@ public:
 	void setEnableInMainMenuNull();
 	
 	
-	/**
-	 * @brief The Jellyfin.Api.Models.ConfigurationPageInfo.	
-	 */
-	const ConfigurationPageType &pageType() const;
-	void setPageType(ConfigurationPageType newPageType);
-	bool pageTypeNull() const;
-	void setPageTypeNull();
-	
-	
 private:
 	// Required path parameters
 	
@@ -4202,133 +3885,6 @@ private:
 
 	// Optional query parameters
 	std::optional<bool> m_enableInMainMenu = std::nullopt;
-	ConfigurationPageType m_pageType;
-
-
-};
-
-class GetConnectionManagerParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetConnectionManager_2Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetConnectionManager_3Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetContentDirectoryParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetContentDirectory_2Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetContentDirectory_3Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
 
 
 };
@@ -4453,19 +4009,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class GetDefaultProfileParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetDefaultTimerParams {
@@ -4489,48 +4032,6 @@ private:
 	QString m_programId;
 
 
-};
-
-class GetDescriptionXmlParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetDescriptionXml_2Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetDeviceInfoParams {
@@ -4578,15 +4079,6 @@ private:
 class GetDevicesParams {
 public:
 
-	/**
-	 * @brief Gets or sets a value indicating whether [supports synchronize].	
-	 */
-	const bool &supportsSync() const;
-	void setSupportsSync(bool newSupportsSync);
-	bool supportsSyncNull() const;
-	void setSupportsSyncNull();
-	
-	
 	/**
 	 * @brief Gets or sets the user identifier.	
 	 */
@@ -4602,7 +4094,6 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_supportsSync = std::nullopt;
 	QString m_userId;
 
 
@@ -4671,7 +4162,9 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
@@ -4679,9 +4172,9 @@ private:
 	
 	// Required query parameters
 	QString m_client;
-	QString m_userId;
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -4836,8 +4329,8 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const ItemSortBy &sortBy() const;
+	void setSortBy(ItemSortBy newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
@@ -4886,7 +4379,7 @@ private:
 	std::optional<qint32> m_limit = std::nullopt;
 	std::optional<qint32> m_season = std::nullopt;
 	QString m_seasonId;
-	QString m_sortBy;
+	ItemSortBy m_sortBy;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_startItemId;
 	QString m_userId;
@@ -4994,48 +4487,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class GetGeneralImageParams {
-public:
-
-	/**
-	 * @brief The name of the image.	
-	 */
-	const QString &name() const;
-	void setName(QString newName);
-
-	
-	/**
-	 * @brief Image Type (primary, backdrop, logo, etc).	
-	 */
-	const QString &type() const;
-	void setType(QString newType);
-
-	
-private:
-	// Required path parameters
-	QString m_name;
-	QString m_type;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetGeneralImagesParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetGenreParams {
@@ -5086,15 +4537,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -5114,12 +4556,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -5229,10 +4680,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -5272,15 +4723,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -5300,12 +4742,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -5407,10 +4858,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -5458,8 +4909,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -5485,8 +4936,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered in based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -5554,6 +5005,24 @@ public:
 	void setSearchTermNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Sort Order - Ascending,Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
 	 */
@@ -5581,10 +5050,10 @@ private:
 	QList<ImageType> m_enableImageTypes;
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QString m_nameLessThan;
@@ -5592,6 +5061,8 @@ private:
 	QString m_nameStartsWithOrGreater;
 	QString m_parentId;
 	QString m_searchTerm;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
@@ -5606,15 +5077,17 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -5663,6 +5136,20 @@ public:
 	void setSegmentId(qint32 newSegmentId);
 
 	
+	/**
+	 * @brief The length of the requested segment in ticks.	
+	 */
+	const qint64 &actualSegmentLengthTicks() const;
+	void setActualSegmentLengthTicks(qint64 newActualSegmentLengthTicks);
+
+	
+	/**
+	 * @brief The position of the requested segment in ticks.	
+	 */
+	const qint64 &runtimeTicks() const;
+	void setRuntimeTicks(qint64 newRuntimeTicks);
+
+	
 	/**
 	 * @brief Whether or not to allow copying of the audio stream url.	
 	 */
@@ -5700,7 +5187,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -5789,6 +5276,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -6069,7 +5565,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -6103,6 +5599,8 @@ private:
 	qint32 m_segmentId;
 	
 	// Required query parameters
+	qint64 m_actualSegmentLengthTicks;
+	qint64 m_runtimeTicks;
 
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
@@ -6119,6 +5617,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -6275,6 +5774,20 @@ public:
 	void setSegmentId(qint32 newSegmentId);
 
 	
+	/**
+	 * @brief The length of the requested segment in ticks.	
+	 */
+	const qint64 &actualSegmentLengthTicks() const;
+	void setActualSegmentLengthTicks(qint64 newActualSegmentLengthTicks);
+
+	
+	/**
+	 * @brief The position of the requested segment in ticks.	
+	 */
+	const qint64 &runtimeTicks() const;
+	void setRuntimeTicks(qint64 newRuntimeTicks);
+
+	
 	/**
 	 * @brief Whether or not to allow copying of the audio stream url.	
 	 */
@@ -6293,6 +5806,15 @@ public:
 	void setAllowVideoStreamCopyNull();
 	
 	
+	/**
+	 * @brief Whether to always burn in subtitles when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.	
 	 */
@@ -6312,7 +5834,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -6401,6 +5923,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -6482,6 +6013,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -6500,6 +6040,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -6573,7 +6122,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The desired segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -6672,7 +6221,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -6706,10 +6255,13 @@ private:
 	qint32 m_segmentId;
 	
 	// Required query parameters
+	qint64 m_actualSegmentLengthTicks;
+	qint64 m_runtimeTicks;
 
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioBitRate = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
 	QString m_audioCodec;
@@ -6722,6 +6274,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -6731,8 +6284,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -6802,56 +6357,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class GetIconParams {
-public:
-
-	/**
-	 * @brief The icon filename.	
-	 */
-	const QString &fileName() const;
-	void setFileName(QString newFileName);
-
-	
-private:
-	// Required path parameters
-	QString m_fileName;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetIconIdParams {
-public:
-
-	/**
-	 * @brief The icon filename.	
-	 */
-	const QString &fileName() const;
-	void setFileName(QString newFileName);
-
-	
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_fileName;
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetInstantMixFromAlbumParams {
@@ -6860,8 +6365,8 @@ public:
 	/**
 	 * @brief The item id.	
 	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 	/**
@@ -6929,7 +6434,7 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_jellyfinId;
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -6951,8 +6456,8 @@ public:
 	/**
 	 * @brief The item id.	
 	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 	/**
@@ -7020,7 +6525,7 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_jellyfinId;
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -7036,7 +6541,7 @@ private:
 
 };
 
-class GetInstantMixFromItemParams {
+class GetInstantMixFromArtists2Params {
 public:
 
 	/**
@@ -7111,7 +6616,98 @@ public:
 	
 private:
 	// Required path parameters
+	
+	// Required query parameters
 	QString m_jellyfinId;
+
+	// Optional query parameters
+	QList<ImageType> m_enableImageTypes;
+	std::optional<bool> m_enableImages = std::nullopt;
+	std::optional<bool> m_enableUserData = std::nullopt;
+	QList<ItemFields> m_fields;
+	std::optional<qint32> m_imageTypeLimit = std::nullopt;
+	std::optional<qint32> m_limit = std::nullopt;
+	QString m_userId;
+
+
+};
+
+class GetInstantMixFromItemParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief Optional. The image types to include in the output.	
+	 */
+	const QList<ImageType> &enableImageTypes() const;
+	void setEnableImageTypes(QList<ImageType> newEnableImageTypes);
+	bool enableImageTypesNull() const;
+	void setEnableImageTypesNull();
+	
+	
+	/**
+	 * @brief Optional. Include image information in output.	
+	 */
+	const bool &enableImages() const;
+	void setEnableImages(bool newEnableImages);
+	bool enableImagesNull() const;
+	void setEnableImagesNull();
+	
+	
+	/**
+	 * @brief Optional. Include user data.	
+	 */
+	const bool &enableUserData() const;
+	void setEnableUserData(bool newEnableUserData);
+	bool enableUserDataNull() const;
+	void setEnableUserDataNull();
+	
+	
+	/**
+	 * @brief Optional. Specify additional fields of information to return in the output.	
+	 */
+	const QList<ItemFields> &fields() const;
+	void setFields(QList<ItemFields> newFields);
+	bool fieldsNull() const;
+	void setFieldsNull();
+	
+	
+	/**
+	 * @brief Optional. The max number of images to return, per image type.	
+	 */
+	const qint32 &imageTypeLimit() const;
+	void setImageTypeLimit(qint32 newImageTypeLimit);
+	bool imageTypeLimitNull() const;
+	void setImageTypeLimitNull();
+	
+	
+	/**
+	 * @brief Optional. The maximum number of records to return.	
+	 */
+	const qint32 &limit() const;
+	void setLimit(qint32 newLimit);
+	bool limitNull() const;
+	void setLimitNull();
+	
+	
+	/**
+	 * @brief Optional. Filter by user id, and attach user data.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
+private:
+	// Required path parameters
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -7127,7 +6723,98 @@ private:
 
 };
 
-class GetInstantMixFromMusicGenreParams {
+class GetInstantMixFromMusicGenreByIdParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &jellyfinId() const;
+	void setJellyfinId(QString newJellyfinId);
+
+	
+	/**
+	 * @brief Optional. The image types to include in the output.	
+	 */
+	const QList<ImageType> &enableImageTypes() const;
+	void setEnableImageTypes(QList<ImageType> newEnableImageTypes);
+	bool enableImageTypesNull() const;
+	void setEnableImageTypesNull();
+	
+	
+	/**
+	 * @brief Optional. Include image information in output.	
+	 */
+	const bool &enableImages() const;
+	void setEnableImages(bool newEnableImages);
+	bool enableImagesNull() const;
+	void setEnableImagesNull();
+	
+	
+	/**
+	 * @brief Optional. Include user data.	
+	 */
+	const bool &enableUserData() const;
+	void setEnableUserData(bool newEnableUserData);
+	bool enableUserDataNull() const;
+	void setEnableUserDataNull();
+	
+	
+	/**
+	 * @brief Optional. Specify additional fields of information to return in the output.	
+	 */
+	const QList<ItemFields> &fields() const;
+	void setFields(QList<ItemFields> newFields);
+	bool fieldsNull() const;
+	void setFieldsNull();
+	
+	
+	/**
+	 * @brief Optional. The max number of images to return, per image type.	
+	 */
+	const qint32 &imageTypeLimit() const;
+	void setImageTypeLimit(qint32 newImageTypeLimit);
+	bool imageTypeLimitNull() const;
+	void setImageTypeLimitNull();
+	
+	
+	/**
+	 * @brief Optional. The maximum number of records to return.	
+	 */
+	const qint32 &limit() const;
+	void setLimit(qint32 newLimit);
+	bool limitNull() const;
+	void setLimitNull();
+	
+	
+	/**
+	 * @brief Optional. Filter by user id, and attach user data.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
+private:
+	// Required path parameters
+	
+	// Required query parameters
+	QString m_jellyfinId;
+
+	// Optional query parameters
+	QList<ImageType> m_enableImageTypes;
+	std::optional<bool> m_enableImages = std::nullopt;
+	std::optional<bool> m_enableUserData = std::nullopt;
+	QList<ItemFields> m_fields;
+	std::optional<qint32> m_imageTypeLimit = std::nullopt;
+	std::optional<qint32> m_limit = std::nullopt;
+	QString m_userId;
+
+
+};
+
+class GetInstantMixFromMusicGenreByNameParams {
 public:
 
 	/**
@@ -7216,97 +6903,6 @@ private:
 	QString m_userId;
 
 
-};
-
-class GetInstantMixFromMusicGenresParams {
-public:
-
-	/**
-	 * @brief The item id.	
-	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
-
-	
-	/**
-	 * @brief Optional. The image types to include in the output.	
-	 */
-	const QList<ImageType> &enableImageTypes() const;
-	void setEnableImageTypes(QList<ImageType> newEnableImageTypes);
-	bool enableImageTypesNull() const;
-	void setEnableImageTypesNull();
-	
-	
-	/**
-	 * @brief Optional. Include image information in output.	
-	 */
-	const bool &enableImages() const;
-	void setEnableImages(bool newEnableImages);
-	bool enableImagesNull() const;
-	void setEnableImagesNull();
-	
-	
-	/**
-	 * @brief Optional. Include user data.	
-	 */
-	const bool &enableUserData() const;
-	void setEnableUserData(bool newEnableUserData);
-	bool enableUserDataNull() const;
-	void setEnableUserDataNull();
-	
-	
-	/**
-	 * @brief Optional. Specify additional fields of information to return in the output.	
-	 */
-	const QList<ItemFields> &fields() const;
-	void setFields(QList<ItemFields> newFields);
-	bool fieldsNull() const;
-	void setFieldsNull();
-	
-	
-	/**
-	 * @brief Optional. The max number of images to return, per image type.	
-	 */
-	const qint32 &imageTypeLimit() const;
-	void setImageTypeLimit(qint32 newImageTypeLimit);
-	bool imageTypeLimitNull() const;
-	void setImageTypeLimitNull();
-	
-	
-	/**
-	 * @brief Optional. The maximum number of records to return.	
-	 */
-	const qint32 &limit() const;
-	void setLimit(qint32 newLimit);
-	bool limitNull() const;
-	void setLimitNull();
-	
-	
-	/**
-	 * @brief Optional. Filter by user id, and attach user data.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-	bool userIdNull() const;
-	void setUserIdNull();
-	
-	
-private:
-	// Required path parameters
-	QString m_jellyfinId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	QList<ImageType> m_enableImageTypes;
-	std::optional<bool> m_enableImages = std::nullopt;
-	std::optional<bool> m_enableUserData = std::nullopt;
-	QList<ItemFields> m_fields;
-	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	std::optional<qint32> m_limit = std::nullopt;
-	QString m_userId;
-
-
 };
 
 class GetInstantMixFromPlaylistParams {
@@ -7315,8 +6911,8 @@ public:
 	/**
 	 * @brief The item id.	
 	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 	/**
@@ -7384,7 +6980,7 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_jellyfinId;
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -7406,8 +7002,8 @@ public:
 	/**
 	 * @brief The item id.	
 	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 	/**
@@ -7475,7 +7071,7 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_jellyfinId;
+	QString m_itemId;
 	
 	// Required query parameters
 
@@ -7506,16 +7102,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -7535,16 +7133,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -7599,15 +7199,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -7627,12 +7218,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -7742,10 +7342,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -7827,15 +7427,6 @@ public:
 	void setUnplayedCount(qint32 newUnplayedCount);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -7855,12 +7446,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -7914,10 +7514,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	std::optional<qint32> m_height = std::nullopt;
 	std::optional<qint32> m_quality = std::nullopt;
@@ -7950,15 +7550,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -7978,12 +7569,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -8085,10 +7685,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -8122,6 +7722,68 @@ private:
 	// Optional query parameters
 
 
+};
+
+class GetItemSegmentsParams {
+public:
+
+	/**
+	 * @brief The ItemId.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief Optional filter of requested segment types.	
+	 */
+	const QList<MediaSegmentType> &includeSegmentTypes() const;
+	void setIncludeSegmentTypes(QList<MediaSegmentType> newIncludeSegmentTypes);
+	bool includeSegmentTypesNull() const;
+	void setIncludeSegmentTypesNull();
+	
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QList<MediaSegmentType> m_includeSegmentTypes;
+
+
+};
+
+class GetItemUserDataParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QString m_userId;
+
+
 };
 
 class GetItemsParams {
@@ -8256,8 +7918,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -8308,7 +7970,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have an imdb id or not.	
+	 * @brief Optional filter by items that have an IMDb id or not.	
 	 */
 	const bool &hasImdbId() const;
 	void setHasImdbId(bool newHasImdbId);
@@ -8380,7 +8042,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have a tmdb id or not.	
+	 * @brief Optional filter by items that have a TMDb id or not.	
 	 */
 	const bool &hasTmdbId() const;
 	void setHasTmdbId(bool newHasTmdbId);
@@ -8398,7 +8060,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have a tvdb id or not.	
+	 * @brief Optional filter by items that have a TVDb id or not.	
 	 */
 	const bool &hasTvdbId() const;
 	void setHasTvdbId(bool newHasTvdbId);
@@ -8436,12 +8098,21 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
 	
+	/**
+	 * @brief Optional filter by index number.	
+	 */
+	const qint32 &indexNumber() const;
+	void setIndexNumber(qint32 newIndexNumber);
+	bool indexNumberNull() const;
+	void setIndexNumberNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are 3D, or not.	
 	 */
@@ -8478,6 +8149,15 @@ public:
 	void setIsHdNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv kids.	
+	 */
+	const bool &isKids() const;
+	void setIsKids(bool newIsKids);
+	bool isKidsNull() const;
+	void setIsKidsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are locked.	
 	 */
@@ -8496,6 +8176,24 @@ public:
 	void setIsMissingNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv movies.	
+	 */
+	const bool &isMovie() const;
+	void setIsMovie(bool newIsMovie);
+	bool isMovieNull() const;
+	void setIsMovieNull();
+	
+	
+	/**
+	 * @brief Optional filter for live tv news.	
+	 */
+	const bool &isNews() const;
+	void setIsNews(bool newIsNews);
+	bool isNewsNull() const;
+	void setIsNewsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are placeholders.	
 	 */
@@ -8514,6 +8212,24 @@ public:
 	void setIsPlayedNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv series.	
+	 */
+	const bool &isSeries() const;
+	void setIsSeries(bool newIsSeries);
+	bool isSeriesNull() const;
+	void setIsSeriesNull();
+	
+	
+	/**
+	 * @brief Optional filter for live tv sports.	
+	 */
+	const bool &isSports() const;
+	void setIsSports(bool newIsSports);
+	bool isSportsNull() const;
+	void setIsSportsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are unaired episodes or not.	
 	 */
@@ -8580,8 +8296,8 @@ public:
 	/**
 	 * @brief Optional filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -8769,17 +8485,17 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
 	
 	/**
-	 * @brief Sort Order - Ascending,Descending.	
+	 * @brief Sort Order - Ascending, Descending.	
 	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 	
@@ -8821,7 +8537,7 @@ public:
 	
 	
 	/**
-	 * @brief The user id supplied as query parameter.	
+	 * @brief The user id supplied as query parameter; this is required when not using an API key.	
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
@@ -8867,7 +8583,7 @@ private:
 	std::optional<bool> m_enableUserData = std::nullopt;
 	QStringList m_excludeArtistIds;
 	QStringList m_excludeItemIds;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<LocationType> m_excludeLocationTypes;
 	QList<ItemFields> m_fields;
 	QList<ItemFilter> m_filters;
@@ -8887,15 +8603,21 @@ private:
 	QStringList m_ids;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
 	QList<ImageType> m_imageTypes;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
+	std::optional<qint32> m_indexNumber = std::nullopt;
 	std::optional<bool> m_is3D = std::nullopt;
 	std::optional<bool> m_is4K = std::nullopt;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<bool> m_isHd = std::nullopt;
+	std::optional<bool> m_isKids = std::nullopt;
 	std::optional<bool> m_isLocked = std::nullopt;
 	std::optional<bool> m_isMissing = std::nullopt;
+	std::optional<bool> m_isMovie = std::nullopt;
+	std::optional<bool> m_isNews = std::nullopt;
 	std::optional<bool> m_isPlaceHolder = std::nullopt;
 	std::optional<bool> m_isPlayed = std::nullopt;
+	std::optional<bool> m_isSeries = std::nullopt;
+	std::optional<bool> m_isSports = std::nullopt;
 	std::optional<bool> m_isUnaired = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QList<LocationType> m_locationTypes;
@@ -8903,7 +8625,7 @@ private:
 	QString m_maxOfficialRating;
 	QDateTime m_maxPremiereDate;
 	std::optional<qint32> m_maxWidth = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	std::optional<double> m_minCommunityRating = std::nullopt;
 	std::optional<double> m_minCriticRating = std::nullopt;
 	QDateTime m_minDateLastSaved;
@@ -8924,8 +8646,8 @@ private:
 	std::optional<bool> m_recursive = std::nullopt;
 	QString m_searchTerm;
 	QList<SeriesStatus> m_seriesStatus;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QStringList m_studioIds;
 	QStringList m_studios;
@@ -8935,817 +8657,6 @@ private:
 	QList<qint32> m_years;
 
 
-};
-
-class GetItemsByUserIdParams {
-public:
-
-	/**
-	 * @brief The user id supplied as query parameter.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Optional. Return items that are siblings of a supplied item.	
-	 */
-	const QString &adjacentTo() const;
-	void setAdjacentTo(QString newAdjacentTo);
-	bool adjacentToNull() const;
-	void setAdjacentToNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered to include only those containing the specified album artist id.	
-	 */
-	const QStringList &albumArtistIds() const;
-	void setAlbumArtistIds(QStringList newAlbumArtistIds);
-	bool albumArtistIdsNull() const;
-	void setAlbumArtistIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on album id. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &albumIds() const;
-	void setAlbumIds(QStringList newAlbumIds);
-	bool albumIdsNull() const;
-	void setAlbumIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on album. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &albums() const;
-	void setAlbums(QStringList newAlbums);
-	bool albumsNull() const;
-	void setAlbumsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered to include only those containing the specified artist id.	
-	 */
-	const QStringList &artistIds() const;
-	void setArtistIds(QStringList newArtistIds);
-	bool artistIdsNull() const;
-	void setArtistIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on artists. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &artists() const;
-	void setArtists(QStringList newArtists);
-	bool artistsNull() const;
-	void setArtistsNull();
-	
-	
-	/**
-	 * @brief Whether or not to hide items behind their boxsets.	
-	 */
-	const bool &collapseBoxSetItems() const;
-	void setCollapseBoxSetItems(bool newCollapseBoxSetItems);
-	bool collapseBoxSetItemsNull() const;
-	void setCollapseBoxSetItemsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered to include only those containing the specified contributing artist id.	
-	 */
-	const QStringList &contributingArtistIds() const;
-	void setContributingArtistIds(QStringList newContributingArtistIds);
-	bool contributingArtistIdsNull() const;
-	void setContributingArtistIdsNull();
-	
-	
-	/**
-	 * @brief Optional. The image types to include in the output.	
-	 */
-	const QList<ImageType> &enableImageTypes() const;
-	void setEnableImageTypes(QList<ImageType> newEnableImageTypes);
-	bool enableImageTypesNull() const;
-	void setEnableImageTypesNull();
-	
-	
-	/**
-	 * @brief Optional, include image information in output.	
-	 */
-	const bool &enableImages() const;
-	void setEnableImages(bool newEnableImages);
-	bool enableImagesNull() const;
-	void setEnableImagesNull();
-	
-	
-	/**
-	 * @brief Optional. Enable the total record count.	
-	 */
-	const bool &enableTotalRecordCount() const;
-	void setEnableTotalRecordCount(bool newEnableTotalRecordCount);
-	bool enableTotalRecordCountNull() const;
-	void setEnableTotalRecordCountNull();
-	
-	
-	/**
-	 * @brief Optional, include user data.	
-	 */
-	const bool &enableUserData() const;
-	void setEnableUserData(bool newEnableUserData);
-	bool enableUserDataNull() const;
-	void setEnableUserDataNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on artist id. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &excludeArtistIds() const;
-	void setExcludeArtistIds(QStringList newExcludeArtistIds);
-	bool excludeArtistIdsNull() const;
-	void setExcludeArtistIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered by exxcluding item ids. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &excludeItemIds() const;
-	void setExcludeItemIds(QStringList newExcludeItemIds);
-	bool excludeItemIdsNull() const;
-	void setExcludeItemIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
-	bool excludeItemTypesNull() const;
-	void setExcludeItemTypesNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on the LocationType. This allows multiple, comma delimeted.	
-	 */
-	const QList<LocationType> &excludeLocationTypes() const;
-	void setExcludeLocationTypes(QList<LocationType> newExcludeLocationTypes);
-	bool excludeLocationTypesNull() const;
-	void setExcludeLocationTypesNull();
-	
-	
-	/**
-	 * @brief Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimeted. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.	
-	 */
-	const QList<ItemFields> &fields() const;
-	void setFields(QList<ItemFields> newFields);
-	bool fieldsNull() const;
-	void setFieldsNull();
-	
-	
-	/**
-	 * @brief Optional. Specify additional filters to apply. This allows multiple, comma delimeted. Options: IsFolder, IsNotFolder, IsUnplayed, IsPlayed, IsFavorite, IsResumable, Likes, Dislikes.	
-	 */
-	const QList<ItemFilter> &filters() const;
-	void setFilters(QList<ItemFilter> newFilters);
-	bool filtersNull() const;
-	void setFiltersNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &genreIds() const;
-	void setGenreIds(QStringList newGenreIds);
-	bool genreIdsNull() const;
-	void setGenreIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &genres() const;
-	void setGenres(QStringList newGenres);
-	bool genresNull() const;
-	void setGenresNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have an imdb id or not.	
-	 */
-	const bool &hasImdbId() const;
-	void setHasImdbId(bool newHasImdbId);
-	bool hasImdbIdNull() const;
-	void setHasImdbIdNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have official ratings.	
-	 */
-	const bool &hasOfficialRating() const;
-	void setHasOfficialRating(bool newHasOfficialRating);
-	bool hasOfficialRatingNull() const;
-	void setHasOfficialRatingNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have an overview or not.	
-	 */
-	const bool &hasOverview() const;
-	void setHasOverview(bool newHasOverview);
-	bool hasOverviewNull() const;
-	void setHasOverviewNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have or do not have a parental rating.	
-	 */
-	const bool &hasParentalRating() const;
-	void setHasParentalRating(bool newHasParentalRating);
-	bool hasParentalRatingNull() const;
-	void setHasParentalRatingNull();
-	
-	
-	/**
-	 * @brief Optional filter by items with special features.	
-	 */
-	const bool &hasSpecialFeature() const;
-	void setHasSpecialFeature(bool newHasSpecialFeature);
-	bool hasSpecialFeatureNull() const;
-	void setHasSpecialFeatureNull();
-	
-	
-	/**
-	 * @brief Optional filter by items with subtitles.	
-	 */
-	const bool &hasSubtitles() const;
-	void setHasSubtitles(bool newHasSubtitles);
-	bool hasSubtitlesNull() const;
-	void setHasSubtitlesNull();
-	
-	
-	/**
-	 * @brief Optional filter by items with theme songs.	
-	 */
-	const bool &hasThemeSong() const;
-	void setHasThemeSong(bool newHasThemeSong);
-	bool hasThemeSongNull() const;
-	void setHasThemeSongNull();
-	
-	
-	/**
-	 * @brief Optional filter by items with theme videos.	
-	 */
-	const bool &hasThemeVideo() const;
-	void setHasThemeVideo(bool newHasThemeVideo);
-	bool hasThemeVideoNull() const;
-	void setHasThemeVideoNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have a tmdb id or not.	
-	 */
-	const bool &hasTmdbId() const;
-	void setHasTmdbId(bool newHasTmdbId);
-	bool hasTmdbIdNull() const;
-	void setHasTmdbIdNull();
-	
-	
-	/**
-	 * @brief Optional filter by items with trailers.	
-	 */
-	const bool &hasTrailer() const;
-	void setHasTrailer(bool newHasTrailer);
-	bool hasTrailerNull() const;
-	void setHasTrailerNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that have a tvdb id or not.	
-	 */
-	const bool &hasTvdbId() const;
-	void setHasTvdbId(bool newHasTvdbId);
-	bool hasTvdbIdNull() const;
-	void setHasTvdbIdNull();
-	
-	
-	/**
-	 * @brief Optional. If specific items are needed, specify a list of item id's to retrieve. This allows multiple, comma delimited.	
-	 */
-	const QStringList &ids() const;
-	void setIds(QStringList newIds);
-	bool idsNull() const;
-	void setIdsNull();
-	
-	
-	/**
-	 * @brief Optional, the max number of images to return, per image type.	
-	 */
-	const qint32 &imageTypeLimit() const;
-	void setImageTypeLimit(qint32 newImageTypeLimit);
-	bool imageTypeLimitNull() const;
-	void setImageTypeLimitNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on those containing image types. This allows multiple, comma delimited.	
-	 */
-	const QList<ImageType> &imageTypes() const;
-	void setImageTypes(QList<ImageType> newImageTypes);
-	bool imageTypesNull() const;
-	void setImageTypesNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimeted.	
-	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
-	bool includeItemTypesNull() const;
-	void setIncludeItemTypesNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are 3D, or not.	
-	 */
-	const bool &is3D() const;
-	void setIs3D(bool newIs3D);
-	bool is3DNull() const;
-	void setIs3DNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are 4K or not.	
-	 */
-	const bool &is4K() const;
-	void setIs4K(bool newIs4K);
-	bool is4KNull() const;
-	void setIs4KNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are marked as favorite, or not.	
-	 */
-	const bool &isFavorite() const;
-	void setIsFavorite(bool newIsFavorite);
-	bool isFavoriteNull() const;
-	void setIsFavoriteNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are HD or not.	
-	 */
-	const bool &isHd() const;
-	void setIsHd(bool newIsHd);
-	bool isHdNull() const;
-	void setIsHdNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are locked.	
-	 */
-	const bool &isLocked() const;
-	void setIsLocked(bool newIsLocked);
-	bool isLockedNull() const;
-	void setIsLockedNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are missing episodes or not.	
-	 */
-	const bool &isMissing() const;
-	void setIsMissing(bool newIsMissing);
-	bool isMissingNull() const;
-	void setIsMissingNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are placeholders.	
-	 */
-	const bool &isPlaceHolder() const;
-	void setIsPlaceHolder(bool newIsPlaceHolder);
-	bool isPlaceHolderNull() const;
-	void setIsPlaceHolderNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are played, or not.	
-	 */
-	const bool &isPlayed() const;
-	void setIsPlayed(bool newIsPlayed);
-	bool isPlayedNull() const;
-	void setIsPlayedNull();
-	
-	
-	/**
-	 * @brief Optional filter by items that are unaired episodes or not.	
-	 */
-	const bool &isUnaired() const;
-	void setIsUnaired(bool newIsUnaired);
-	bool isUnairedNull() const;
-	void setIsUnairedNull();
-	
-	
-	/**
-	 * @brief Optional. The maximum number of records to return.	
-	 */
-	const qint32 &limit() const;
-	void setLimit(qint32 newLimit);
-	bool limitNull() const;
-	void setLimitNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on LocationType. This allows multiple, comma delimeted.	
-	 */
-	const QList<LocationType> &locationTypes() const;
-	void setLocationTypes(QList<LocationType> newLocationTypes);
-	bool locationTypesNull() const;
-	void setLocationTypesNull();
-	
-	
-	/**
-	 * @brief Optional. Filter by the maximum height of the item.	
-	 */
-	const qint32 &maxHeight() const;
-	void setMaxHeight(qint32 newMaxHeight);
-	bool maxHeightNull() const;
-	void setMaxHeightNull();
-	
-	
-	/**
-	 * @brief Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).	
-	 */
-	const QString &maxOfficialRating() const;
-	void setMaxOfficialRating(QString newMaxOfficialRating);
-	bool maxOfficialRatingNull() const;
-	void setMaxOfficialRatingNull();
-	
-	
-	/**
-	 * @brief Optional. The maximum premiere date. Format = ISO.	
-	 */
-	const QDateTime &maxPremiereDate() const;
-	void setMaxPremiereDate(QDateTime newMaxPremiereDate);
-	bool maxPremiereDateNull() const;
-	void setMaxPremiereDateNull();
-	
-	
-	/**
-	 * @brief Optional. Filter by the maximum width of the item.	
-	 */
-	const qint32 &maxWidth() const;
-	void setMaxWidth(qint32 newMaxWidth);
-	bool maxWidthNull() const;
-	void setMaxWidthNull();
-	
-	
-	/**
-	 * @brief Optional filter by MediaType. Allows multiple, comma delimited.	
-	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
-	bool mediaTypesNull() const;
-	void setMediaTypesNull();
-	
-	
-	/**
-	 * @brief Optional filter by minimum community rating.	
-	 */
-	const double &minCommunityRating() const;
-	void setMinCommunityRating(double newMinCommunityRating);
-	bool minCommunityRatingNull() const;
-	void setMinCommunityRatingNull();
-	
-	
-	/**
-	 * @brief Optional filter by minimum critic rating.	
-	 */
-	const double &minCriticRating() const;
-	void setMinCriticRating(double newMinCriticRating);
-	bool minCriticRatingNull() const;
-	void setMinCriticRatingNull();
-	
-	
-	/**
-	 * @brief Optional. The minimum last saved date. Format = ISO.	
-	 */
-	const QDateTime &minDateLastSaved() const;
-	void setMinDateLastSaved(QDateTime newMinDateLastSaved);
-	bool minDateLastSavedNull() const;
-	void setMinDateLastSavedNull();
-	
-	
-	/**
-	 * @brief Optional. The minimum last saved date for the current user. Format = ISO.	
-	 */
-	const QDateTime &minDateLastSavedForUser() const;
-	void setMinDateLastSavedForUser(QDateTime newMinDateLastSavedForUser);
-	bool minDateLastSavedForUserNull() const;
-	void setMinDateLastSavedForUserNull();
-	
-	
-	/**
-	 * @brief Optional. Filter by the minimum height of the item.	
-	 */
-	const qint32 &minHeight() const;
-	void setMinHeight(qint32 newMinHeight);
-	bool minHeightNull() const;
-	void setMinHeightNull();
-	
-	
-	/**
-	 * @brief Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).	
-	 */
-	const QString &minOfficialRating() const;
-	void setMinOfficialRating(QString newMinOfficialRating);
-	bool minOfficialRatingNull() const;
-	void setMinOfficialRatingNull();
-	
-	
-	/**
-	 * @brief Optional. The minimum premiere date. Format = ISO.	
-	 */
-	const QDateTime &minPremiereDate() const;
-	void setMinPremiereDate(QDateTime newMinPremiereDate);
-	bool minPremiereDateNull() const;
-	void setMinPremiereDateNull();
-	
-	
-	/**
-	 * @brief Optional. Filter by the minimum width of the item.	
-	 */
-	const qint32 &minWidth() const;
-	void setMinWidth(qint32 newMinWidth);
-	bool minWidthNull() const;
-	void setMinWidthNull();
-	
-	
-	/**
-	 * @brief Optional filter by items whose name is equally or lesser than a given input string.	
-	 */
-	const QString &nameLessThan() const;
-	void setNameLessThan(QString newNameLessThan);
-	bool nameLessThanNull() const;
-	void setNameLessThanNull();
-	
-	
-	/**
-	 * @brief Optional filter by items whose name is sorted equally than a given input string.	
-	 */
-	const QString &nameStartsWith() const;
-	void setNameStartsWith(QString newNameStartsWith);
-	bool nameStartsWithNull() const;
-	void setNameStartsWithNull();
-	
-	
-	/**
-	 * @brief Optional filter by items whose name is sorted equally or greater than a given input string.	
-	 */
-	const QString &nameStartsWithOrGreater() const;
-	void setNameStartsWithOrGreater(QString newNameStartsWithOrGreater);
-	bool nameStartsWithOrGreaterNull() const;
-	void setNameStartsWithOrGreaterNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &officialRatings() const;
-	void setOfficialRatings(QStringList newOfficialRatings);
-	bool officialRatingsNull() const;
-	void setOfficialRatingsNull();
-	
-	
-	/**
-	 * @brief Specify this to localize the search to a specific item or folder. Omit to use the root.	
-	 */
-	const QString &parentId() const;
-	void setParentId(QString newParentId);
-	bool parentIdNull() const;
-	void setParentIdNull();
-	
-	
-	/**
-	 * @brief Optional filter by parent index number.	
-	 */
-	const qint32 &parentIndexNumber() const;
-	void setParentIndexNumber(qint32 newParentIndexNumber);
-	bool parentIndexNumberNull() const;
-	void setParentIndexNumberNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered to include only those containing the specified person.	
-	 */
-	const QString &person() const;
-	void setPerson(QString newPerson);
-	bool personNull() const;
-	void setPersonNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered to include only those containing the specified person id.	
-	 */
-	const QStringList &personIds() const;
-	void setPersonIds(QStringList newPersonIds);
-	bool personIdsNull() const;
-	void setPersonIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.	
-	 */
-	const QStringList &personTypes() const;
-	void setPersonTypes(QStringList newPersonTypes);
-	bool personTypesNull() const;
-	void setPersonTypesNull();
-	
-	
-	/**
-	 * @brief When searching within folders, this determines whether or not the search will be recursive. true/false.	
-	 */
-	const bool &recursive() const;
-	void setRecursive(bool newRecursive);
-	bool recursiveNull() const;
-	void setRecursiveNull();
-	
-	
-	/**
-	 * @brief Optional. Filter based on a search term.	
-	 */
-	const QString &searchTerm() const;
-	void setSearchTerm(QString newSearchTerm);
-	bool searchTermNull() const;
-	void setSearchTermNull();
-	
-	
-	/**
-	 * @brief Optional filter by Series Status. Allows multiple, comma delimeted.	
-	 */
-	const QList<SeriesStatus> &seriesStatus() const;
-	void setSeriesStatus(QList<SeriesStatus> newSeriesStatus);
-	bool seriesStatusNull() const;
-	void setSeriesStatusNull();
-	
-	
-	/**
-	 * @brief Optional. Specify one or more sort orders, comma delimeted. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
-	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
-	bool sortByNull() const;
-	void setSortByNull();
-	
-	
-	/**
-	 * @brief Sort Order - Ascending,Descending.	
-	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
-	bool sortOrderNull() const;
-	void setSortOrderNull();
-	
-	
-	/**
-	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
-	 */
-	const qint32 &startIndex() const;
-	void setStartIndex(qint32 newStartIndex);
-	bool startIndexNull() const;
-	void setStartIndexNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &studioIds() const;
-	void setStudioIds(QStringList newStudioIds);
-	bool studioIdsNull() const;
-	void setStudioIdsNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &studios() const;
-	void setStudios(QStringList newStudios);
-	bool studiosNull() const;
-	void setStudiosNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimeted.	
-	 */
-	const QStringList &tags() const;
-	void setTags(QStringList newTags);
-	bool tagsNull() const;
-	void setTagsNull();
-	
-	
-	/**
-	 * @brief Optional filter by VideoType (videofile, dvd, bluray, iso). Allows multiple, comma delimeted.	
-	 */
-	const QList<VideoType> &videoTypes() const;
-	void setVideoTypes(QList<VideoType> newVideoTypes);
-	bool videoTypesNull() const;
-	void setVideoTypesNull();
-	
-	
-	/**
-	 * @brief Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimeted.	
-	 */
-	const QList<qint32> &years() const;
-	void setYears(QList<qint32> newYears);
-	bool yearsNull() const;
-	void setYearsNull();
-	
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	QString m_adjacentTo;
-	QStringList m_albumArtistIds;
-	QStringList m_albumIds;
-	QStringList m_albums;
-	QStringList m_artistIds;
-	QStringList m_artists;
-	std::optional<bool> m_collapseBoxSetItems = std::nullopt;
-	QStringList m_contributingArtistIds;
-	QList<ImageType> m_enableImageTypes;
-	std::optional<bool> m_enableImages = std::nullopt;
-	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
-	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeArtistIds;
-	QStringList m_excludeItemIds;
-	QStringList m_excludeItemTypes;
-	QList<LocationType> m_excludeLocationTypes;
-	QList<ItemFields> m_fields;
-	QList<ItemFilter> m_filters;
-	QStringList m_genreIds;
-	QStringList m_genres;
-	std::optional<bool> m_hasImdbId = std::nullopt;
-	std::optional<bool> m_hasOfficialRating = std::nullopt;
-	std::optional<bool> m_hasOverview = std::nullopt;
-	std::optional<bool> m_hasParentalRating = std::nullopt;
-	std::optional<bool> m_hasSpecialFeature = std::nullopt;
-	std::optional<bool> m_hasSubtitles = std::nullopt;
-	std::optional<bool> m_hasThemeSong = std::nullopt;
-	std::optional<bool> m_hasThemeVideo = std::nullopt;
-	std::optional<bool> m_hasTmdbId = std::nullopt;
-	std::optional<bool> m_hasTrailer = std::nullopt;
-	std::optional<bool> m_hasTvdbId = std::nullopt;
-	QStringList m_ids;
-	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QList<ImageType> m_imageTypes;
-	QStringList m_includeItemTypes;
-	std::optional<bool> m_is3D = std::nullopt;
-	std::optional<bool> m_is4K = std::nullopt;
-	std::optional<bool> m_isFavorite = std::nullopt;
-	std::optional<bool> m_isHd = std::nullopt;
-	std::optional<bool> m_isLocked = std::nullopt;
-	std::optional<bool> m_isMissing = std::nullopt;
-	std::optional<bool> m_isPlaceHolder = std::nullopt;
-	std::optional<bool> m_isPlayed = std::nullopt;
-	std::optional<bool> m_isUnaired = std::nullopt;
-	std::optional<qint32> m_limit = std::nullopt;
-	QList<LocationType> m_locationTypes;
-	std::optional<qint32> m_maxHeight = std::nullopt;
-	QString m_maxOfficialRating;
-	QDateTime m_maxPremiereDate;
-	std::optional<qint32> m_maxWidth = std::nullopt;
-	QStringList m_mediaTypes;
-	std::optional<double> m_minCommunityRating = std::nullopt;
-	std::optional<double> m_minCriticRating = std::nullopt;
-	QDateTime m_minDateLastSaved;
-	QDateTime m_minDateLastSavedForUser;
-	std::optional<qint32> m_minHeight = std::nullopt;
-	QString m_minOfficialRating;
-	QDateTime m_minPremiereDate;
-	std::optional<qint32> m_minWidth = std::nullopt;
-	QString m_nameLessThan;
-	QString m_nameStartsWith;
-	QString m_nameStartsWithOrGreater;
-	QStringList m_officialRatings;
-	QString m_parentId;
-	std::optional<qint32> m_parentIndexNumber = std::nullopt;
-	QString m_person;
-	QStringList m_personIds;
-	QStringList m_personTypes;
-	std::optional<bool> m_recursive = std::nullopt;
-	QString m_searchTerm;
-	QList<SeriesStatus> m_seriesStatus;
-	QString m_sortBy;
-	QString m_sortOrder;
-	std::optional<qint32> m_startIndex = std::nullopt;
-	QStringList m_studioIds;
-	QStringList m_studios;
-	QStringList m_tags;
-	QList<VideoType> m_videoTypes;
-	QList<qint32> m_years;
-
-
 };
 
 class GetKeysParams {
@@ -9837,13 +8748,6 @@ private:
 class GetLatestMediaParams {
 public:
 
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Optional. The image types to include in the output.	
 	 */
@@ -9901,8 +8805,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -9934,9 +8838,17 @@ public:
 	void setParentIdNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
@@ -9947,10 +8859,11 @@ private:
 	QList<ItemFields> m_fields;
 	std::optional<bool> m_groupItems = std::nullopt;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isPlayed = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QString m_parentId;
+	QString m_userId;
 
 
 };
@@ -9970,8 +8883,8 @@ public:
 	/**
 	 * @brief Library content type.	
 	 */
-	const QString &libraryContentType() const;
-	void setLibraryContentType(QString newLibraryContentType);
+	const CollectionType &libraryContentType() const;
+	void setLibraryContentType(CollectionType newLibraryContentType);
 	bool libraryContentTypeNull() const;
 	void setLibraryContentTypeNull();
 	
@@ -9983,7 +8896,7 @@ private:
 
 	// Optional query parameters
 	std::optional<bool> m_isNewLibrary = std::nullopt;
-	QString m_libraryContentType;
+	CollectionType m_libraryContentType;
 
 
 };
@@ -10069,6 +8982,15 @@ public:
 	void setAllowVideoStreamCopyNull();
 	
 	
+	/**
+	 * @brief Whether to always burn in subtitles when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.	
 	 */
@@ -10088,7 +9010,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -10186,6 +9108,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -10385,7 +9316,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -10484,7 +9415,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -10519,6 +9450,7 @@ private:
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioBitRate = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
 	QString m_audioCodec;
@@ -10532,6 +9464,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<bool> m_enableSubtitlesInManifest = std::nullopt;
@@ -10772,8 +9705,8 @@ public:
 	/**
 	 * @brief Optional. Key to sort by.	
 	 */
-	const QStringList &sortBy() const;
-	void setSortBy(QStringList newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
@@ -10836,7 +9769,7 @@ private:
 	std::optional<bool> m_isSeries = std::nullopt;
 	std::optional<bool> m_isSports = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_sortBy;
+	QList<ItemSortBy> m_sortBy;
 	SortOrder m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	ChannelType m_type;
@@ -11071,8 +10004,8 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Name, StartDate.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
@@ -11080,8 +10013,8 @@ public:
 	/**
 	 * @brief Sort Order - Ascending,Descending.	
 	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 	
@@ -11133,8 +10066,8 @@ private:
 	QDateTime m_minEndDate;
 	QDateTime m_minStartDate;
 	QString m_seriesTimerId;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
@@ -11156,16 +10089,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -11255,6 +10190,27 @@ private:
 	// Optional query parameters
 
 
+};
+
+class GetLyricsParams {
+public:
+
+	/**
+	 * @brief Item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class GetMasterHlsAudioPlaylistParams {
@@ -11311,7 +10267,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -11409,6 +10365,15 @@ public:
 	void setEnableAdaptiveBitrateStreamingNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -11680,7 +10645,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -11729,6 +10694,7 @@ private:
 	QString m_deviceId;
 	QString m_deviceProfileId;
 	std::optional<bool> m_enableAdaptiveBitrateStreaming = std::nullopt;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -11801,6 +10767,15 @@ public:
 	void setAllowVideoStreamCopyNull();
 	
 	
+	/**
+	 * @brief Whether to always burn in subtitles when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.	
 	 */
@@ -11820,7 +10795,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -11918,6 +10893,15 @@ public:
 	void setEnableAdaptiveBitrateStreamingNull();
 	
 	
+	/**
+	 * @brief Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -11936,6 +10920,15 @@ public:
 	void setEnableMpegtsM2TsModeNull();
 	
 	
+	/**
+	 * @brief Enable trickplay image playlists being added to master playlist.	
+	 */
+	const bool &enableTrickplay() const;
+	void setEnableTrickplay(bool newEnableTrickplay);
+	bool enableTrickplayNull() const;
+	void setEnableTrickplayNull();
+	
+	
 	/**
 	 * @brief Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.	
 	 */
@@ -11999,6 +10992,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -12017,6 +11019,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The minimum number of segments.	
 	 */
@@ -12180,7 +11191,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -12216,6 +11227,7 @@ private:
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioBitRate = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
 	QString m_audioCodec;
@@ -12229,8 +11241,10 @@ private:
 	QString m_deviceId;
 	QString m_deviceProfileId;
 	std::optional<bool> m_enableAdaptiveBitrateStreaming = std::nullopt;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
+	std::optional<bool> m_enableTrickplay = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
 	std::optional<qint32> m_height = std::nullopt;
 	QString m_level;
@@ -12238,8 +11252,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
 	QString m_playSessionId;
@@ -12286,111 +11302,6 @@ private:
 	std::optional<bool> m_isHidden = std::nullopt;
 
 
-};
-
-class GetMediaInfoImageParams {
-public:
-
-	/**
-	 * @brief The name of the image.	
-	 */
-	const QString &name() const;
-	void setName(QString newName);
-
-	
-	/**
-	 * @brief The theme to get the image from.	
-	 */
-	const QString &theme() const;
-	void setTheme(QString newTheme);
-
-	
-private:
-	// Required path parameters
-	QString m_name;
-	QString m_theme;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetMediaInfoImagesParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetMediaReceiverRegistrarParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetMediaReceiverRegistrar_2Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetMediaReceiverRegistrar_3Params {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetMetadataEditorInfoParams {
@@ -12591,15 +11502,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -12619,12 +11521,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -12734,10 +11645,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -12777,15 +11688,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -12805,12 +11707,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -12912,10 +11823,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -12963,8 +11874,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -12990,8 +11901,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered in based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -13059,6 +11970,24 @@ public:
 	void setSearchTermNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Sort Order - Ascending,Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
 	 */
@@ -13086,10 +12015,10 @@ private:
 	QList<ImageType> m_enableImageTypes;
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QString m_nameLessThan;
@@ -13097,6 +12026,8 @@ private:
 	QString m_nameStartsWithOrGreater;
 	QString m_parentId;
 	QString m_searchTerm;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
@@ -13183,10 +12114,28 @@ public:
 	/**
 	 * @brief Optional. Include image information in output.	
 	 */
-	const bool &enableImges() const;
-	void setEnableImges(bool newEnableImges);
-	bool enableImgesNull() const;
-	void setEnableImgesNull();
+	const bool &enableImages() const;
+	void setEnableImages(bool newEnableImages);
+	bool enableImagesNull() const;
+	void setEnableImagesNull();
+	
+	
+	/**
+	 * @brief Whether to include resumable episodes in next up results.	
+	 */
+	const bool &enableResumable() const;
+	void setEnableResumable(bool newEnableResumable);
+	bool enableResumableNull() const;
+	void setEnableResumableNull();
+	
+	
+	/**
+	 * @brief Whether to include watched episodes in next up results.	
+	 */
+	const bool &enableRewatching() const;
+	void setEnableRewatching(bool newEnableRewatching);
+	bool enableRewatchingNull() const;
+	void setEnableRewatchingNull();
 	
 	
 	/**
@@ -13234,6 +12183,15 @@ public:
 	void setLimitNull();
 	
 	
+	/**
+	 * @brief Optional. Starting date of shows to show in Next Up section.	
+	 */
+	const QDateTime &nextUpDateCutoff() const;
+	void setNextUpDateCutoff(QDateTime newNextUpDateCutoff);
+	bool nextUpDateCutoffNull() const;
+	void setNextUpDateCutoffNull();
+	
+	
 	/**
 	 * @brief Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.	
 	 */
@@ -13278,86 +12236,21 @@ private:
 	// Optional query parameters
 	std::optional<bool> m_disableFirstEpisode = std::nullopt;
 	QList<ImageType> m_enableImageTypes;
-	std::optional<bool> m_enableImges = std::nullopt;
+	std::optional<bool> m_enableImages = std::nullopt;
+	std::optional<bool> m_enableResumable = std::nullopt;
+	std::optional<bool> m_enableRewatching = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
+	QDateTime m_nextUpDateCutoff;
 	QString m_parentId;
 	QString m_seriesId;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
 
-};
-
-class GetNotificationServicesParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetNotificationTypesParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetNotificationsParams {
-public:
-
-	/**
-	 * @brief 	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetNotificationsSummaryParams {
-public:
-
-	/**
-	 * @brief 	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetPackageInfoParams {
@@ -13499,15 +12392,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -13527,12 +12411,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -13642,10 +12535,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -13685,15 +12578,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -13713,12 +12597,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -13820,10 +12713,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -14044,15 +12937,38 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
 	
 	// Required query parameters
+
+	// Optional query parameters
 	QString m_userId;
 
+
+};
+
+class GetPlaylistParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	
+	// Required query parameters
+
 	// Optional query parameters
 
 
@@ -14068,13 +12984,6 @@ public:
 	void setPlaylistId(QString newPlaylistId);
 
 	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Optional. The image types to include in the output.	
 	 */
@@ -14138,12 +13047,20 @@ public:
 	void setStartIndexNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
 	QString m_playlistId;
 	
 	// Required query parameters
-	QString m_userId;
 
 	// Optional query parameters
 	QList<ImageType> m_enableImageTypes;
@@ -14153,6 +13070,57 @@ private:
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	std::optional<qint32> m_startIndex = std::nullopt;
+	QString m_userId;
+
+
+};
+
+class GetPlaylistUserParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	QString m_userId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
+};
+
+class GetPlaylistUsersParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	
+	// Required query parameters
+
+	// Optional query parameters
 
 
 };
@@ -14191,14 +13159,14 @@ public:
 	/**
 	 * @brief Plugin version.	
 	 */
-	const QSharedPointer<Version> &version() const;
-	void setVersion(QSharedPointer<Version> newVersion);
+	const QString &version() const;
+	void setVersion(QString newVersion);
 
 	
 private:
 	// Required path parameters
 	QString m_pluginId;
-	QSharedPointer<Version> m_version;
+	QString m_version;
 	
 	// Required query parameters
 
@@ -14411,40 +13379,6 @@ private:
 
 };
 
-class GetProfileParams {
-public:
-
-	/**
-	 * @brief Profile Id.	
-	 */
-	const QString &profileId() const;
-	void setProfileId(QString newProfileId);
-
-	
-private:
-	// Required path parameters
-	QString m_profileId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class GetProfileInfosParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
 class GetProgramParams {
 public:
 
@@ -14530,8 +13464,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -14623,7 +13557,7 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isAiring = std::nullopt;
 	std::optional<bool> m_isKids = std::nullopt;
 	std::optional<bool> m_isMovie = std::nullopt;
@@ -14643,8 +13577,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -14652,8 +13586,8 @@ public:
 	/**
 	 * @brief Optional. Filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -14682,35 +13616,19 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	QStringList m_includeItemTypes;
-	QStringList m_mediaTypes;
+	QList<BaseItemKind> m_includeItemTypes;
+	QList<MediaType> m_mediaTypes;
 	QString m_parentId;
 	QString m_userId;
 
 
 };
 
-class GetRatingImageParams {
+class GetQuickConnectEnabledParams {
 public:
 
-	/**
-	 * @brief The name of the image.	
-	 */
-	const QString &name() const;
-	void setName(QString newName);
-
-	
-	/**
-	 * @brief The theme to get the image from.	
-	 */
-	const QString &theme() const;
-	void setTheme(QString newTheme);
-
-	
 private:
 	// Required path parameters
-	QString m_name;
-	QString m_theme;
 	
 	// Required query parameters
 
@@ -14719,13 +13637,21 @@ private:
 
 };
 
-class GetRatingImagesParams {
+class GetQuickConnectStateParams {
 public:
 
+	/**
+	 * @brief Secret previously returned from the Initiate endpoint.	
+	 */
+	const QString &secret() const;
+	void setSecret(QString newSecret);
+
+	
 private:
 	// Required path parameters
 	
 	// Required query parameters
+	QString m_secret;
 
 	// Optional query parameters
 
@@ -15357,27 +14283,6 @@ private:
 	QString m_userId;
 
 
-};
-
-class GetRemoteImageParams {
-public:
-
-	/**
-	 * @brief The image url.	
-	 */
-	const QString &imageUrl() const;
-	void setImageUrl(QString newImageUrl);
-
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-	QString m_imageUrl;
-
-	// Optional query parameters
-
-
 };
 
 class GetRemoteImageProvidersParams {
@@ -15472,29 +14377,21 @@ private:
 
 };
 
-class GetRemoteSearchImageParams {
+class GetRemoteLyricsParams {
 public:
 
 	/**
-	 * @brief The image url.	
+	 * @brief The remote provider item id.	
 	 */
-	const QString &imageUrl() const;
-	void setImageUrl(QString newImageUrl);
-
-	
-	/**
-	 * @brief The provider name.	
-	 */
-	const QString &providerName() const;
-	void setProviderName(QString newProviderName);
+	const QString &lyricId() const;
+	void setLyricId(QString newLyricId);
 
 	
 private:
 	// Required path parameters
+	QString m_lyricId;
 	
 	// Required query parameters
-	QString m_imageUrl;
-	QString m_providerName;
 
 	// Optional query parameters
 
@@ -15507,13 +14404,13 @@ public:
 	/**
 	 * @brief The item id.	
 	 */
-	const QString &jellyfinId() const;
-	void setJellyfinId(QString newJellyfinId);
+	const QString &subtitleId() const;
+	void setSubtitleId(QString newSubtitleId);
 
 	
 private:
 	// Required path parameters
-	QString m_jellyfinId;
+	QString m_subtitleId;
 	
 	// Required query parameters
 
@@ -15538,13 +14435,6 @@ private:
 class GetResumeItemsParams {
 public:
 
-	/**
-	 * @brief The user id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Optional. The image types to include in the output.	
 	 */
@@ -15581,11 +14471,20 @@ public:
 	void setEnableUserDataNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to exclude the currently active sessions.	
+	 */
+	const bool &excludeActiveSessions() const;
+	void setExcludeActiveSessions(bool newExcludeActiveSessions);
+	bool excludeActiveSessionsNull() const;
+	void setExcludeActiveSessionsNull();
+	
+	
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -15611,8 +14510,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -15629,8 +14528,8 @@ public:
 	/**
 	 * @brief Optional. Filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -15662,9 +14561,17 @@ public:
 	void setStartIndexNull();
 	
 	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
@@ -15673,15 +14580,17 @@ private:
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeItemTypes;
+	std::optional<bool> m_excludeActiveSessions = std::nullopt;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	QString m_parentId;
 	QString m_searchTerm;
 	std::optional<qint32> m_startIndex = std::nullopt;
+	QString m_userId;
 
 
 };
@@ -15694,15 +14603,17 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -15718,6 +14629,197 @@ private:
 	// Optional query parameters
 
 
+};
+
+class GetSearchHintsParams {
+public:
+
+	/**
+	 * @brief The search term to filter on.	
+	 */
+	const QString &searchTerm() const;
+	void setSearchTerm(QString newSearchTerm);
+
+	
+	/**
+	 * @brief If specified, results with these item types are filtered out. This allows multiple, comma delimited.	
+	 */
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
+	bool excludeItemTypesNull() const;
+	void setExcludeItemTypesNull();
+	
+	
+	/**
+	 * @brief Optional filter whether to include artists.	
+	 */
+	const bool &includeArtists() const;
+	void setIncludeArtists(bool newIncludeArtists);
+	bool includeArtistsNull() const;
+	void setIncludeArtistsNull();
+	
+	
+	/**
+	 * @brief Optional filter whether to include genres.	
+	 */
+	const bool &includeGenres() const;
+	void setIncludeGenres(bool newIncludeGenres);
+	bool includeGenresNull() const;
+	void setIncludeGenresNull();
+	
+	
+	/**
+	 * @brief If specified, only results with the specified item types are returned. This allows multiple, comma delimited.	
+	 */
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
+	bool includeItemTypesNull() const;
+	void setIncludeItemTypesNull();
+	
+	
+	/**
+	 * @brief Optional filter whether to include media.	
+	 */
+	const bool &includeMedia() const;
+	void setIncludeMedia(bool newIncludeMedia);
+	bool includeMediaNull() const;
+	void setIncludeMediaNull();
+	
+	
+	/**
+	 * @brief Optional filter whether to include people.	
+	 */
+	const bool &includePeople() const;
+	void setIncludePeople(bool newIncludePeople);
+	bool includePeopleNull() const;
+	void setIncludePeopleNull();
+	
+	
+	/**
+	 * @brief Optional filter whether to include studios.	
+	 */
+	const bool &includeStudios() const;
+	void setIncludeStudios(bool newIncludeStudios);
+	bool includeStudiosNull() const;
+	void setIncludeStudiosNull();
+	
+	
+	/**
+	 * @brief Optional filter for kids.	
+	 */
+	const bool &isKids() const;
+	void setIsKids(bool newIsKids);
+	bool isKidsNull() const;
+	void setIsKidsNull();
+	
+	
+	/**
+	 * @brief Optional filter for movies.	
+	 */
+	const bool &isMovie() const;
+	void setIsMovie(bool newIsMovie);
+	bool isMovieNull() const;
+	void setIsMovieNull();
+	
+	
+	/**
+	 * @brief Optional filter for news.	
+	 */
+	const bool &isNews() const;
+	void setIsNews(bool newIsNews);
+	bool isNewsNull() const;
+	void setIsNewsNull();
+	
+	
+	/**
+	 * @brief Optional filter for series.	
+	 */
+	const bool &isSeries() const;
+	void setIsSeries(bool newIsSeries);
+	bool isSeriesNull() const;
+	void setIsSeriesNull();
+	
+	
+	/**
+	 * @brief Optional filter for sports.	
+	 */
+	const bool &isSports() const;
+	void setIsSports(bool newIsSports);
+	bool isSportsNull() const;
+	void setIsSportsNull();
+	
+	
+	/**
+	 * @brief Optional. The maximum number of records to return.	
+	 */
+	const qint32 &limit() const;
+	void setLimit(qint32 newLimit);
+	bool limitNull() const;
+	void setLimitNull();
+	
+	
+	/**
+	 * @brief If specified, only results with the specified media types are returned. This allows multiple, comma delimited.	
+	 */
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
+	bool mediaTypesNull() const;
+	void setMediaTypesNull();
+	
+	
+	/**
+	 * @brief If specified, only children of the parent are returned.	
+	 */
+	const QString &parentId() const;
+	void setParentId(QString newParentId);
+	bool parentIdNull() const;
+	void setParentIdNull();
+	
+	
+	/**
+	 * @brief Optional. The record index to start at. All items with a lower index will be dropped from the results.	
+	 */
+	const qint32 &startIndex() const;
+	void setStartIndex(qint32 newStartIndex);
+	bool startIndexNull() const;
+	void setStartIndexNull();
+	
+	
+	/**
+	 * @brief Optional. Supply a user id to search within a user's library or omit to search all.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
+private:
+	// Required path parameters
+	
+	// Required query parameters
+	QString m_searchTerm;
+
+	// Optional query parameters
+	QList<BaseItemKind> m_excludeItemTypes;
+	std::optional<bool> m_includeArtists = std::nullopt;
+	std::optional<bool> m_includeGenres = std::nullopt;
+	QList<BaseItemKind> m_includeItemTypes;
+	std::optional<bool> m_includeMedia = std::nullopt;
+	std::optional<bool> m_includePeople = std::nullopt;
+	std::optional<bool> m_includeStudios = std::nullopt;
+	std::optional<bool> m_isKids = std::nullopt;
+	std::optional<bool> m_isMovie = std::nullopt;
+	std::optional<bool> m_isNews = std::nullopt;
+	std::optional<bool> m_isSeries = std::nullopt;
+	std::optional<bool> m_isSports = std::nullopt;
+	std::optional<qint32> m_limit = std::nullopt;
+	QList<MediaType> m_mediaTypes;
+	QString m_parentId;
+	std::optional<qint32> m_startIndex = std::nullopt;
+	QString m_userId;
+
+
 };
 
 class GetSeasonsParams {
@@ -16344,16 +15446,151 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
+
+
+};
+
+class GetSplashscreenParams {
+public:
+
+	/**
+	 * @brief Apply a background color for transparent images.	
+	 */
+	const QString &backgroundColor() const;
+	void setBackgroundColor(QString newBackgroundColor);
+	bool backgroundColorNull() const;
+	void setBackgroundColorNull();
+	
+	
+	/**
+	 * @brief Blur image.	
+	 */
+	const qint32 &blur() const;
+	void setBlur(qint32 newBlur);
+	bool blurNull() const;
+	void setBlurNull();
+	
+	
+	/**
+	 * @brief Height of box to fill.	
+	 */
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
+	
+	
+	/**
+	 * @brief Apply a foreground layer on top of the image.	
+	 */
+	const QString &foregroundLayer() const;
+	void setForegroundLayer(QString newForegroundLayer);
+	bool foregroundLayerNull() const;
+	void setForegroundLayerNull();
+	
+	
+	/**
+	 * @brief Determines the output format of the image - original,gif,jpg,png.	
+	 */
+	const ImageFormat &format() const;
+	void setFormat(ImageFormat newFormat);
+	bool formatNull() const;
+	void setFormatNull();
+	
+	
+	/**
+	 * @brief The fixed image height to return.	
+	 */
+	const qint32 &height() const;
+	void setHeight(qint32 newHeight);
+	bool heightNull() const;
+	void setHeightNull();
+	
+	
+	/**
+	 * @brief The maximum image height to return.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
+	/**
+	 * @brief The maximum image width to return.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
+	/**
+	 * @brief Quality setting, from 0-100.	
+	 */
+	const qint32 &quality() const;
+	void setQuality(qint32 newQuality);
+	bool qualityNull() const;
+	void setQualityNull();
+	
+	
+	/**
+	 * @brief Supply the cache tag from the item object to receive strong caching headers.	
+	 */
+	const QString &tag() const;
+	void setTag(QString newTag);
+	bool tagNull() const;
+	void setTagNull();
+	
+	
+	/**
+	 * @brief The fixed image width to return.	
+	 */
+	const qint32 &width() const;
+	void setWidth(qint32 newWidth);
+	bool widthNull() const;
+	void setWidthNull();
+	
+	
+private:
+	// Required path parameters
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QString m_backgroundColor;
+	std::optional<qint32> m_blur = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
+	QString m_foregroundLayer;
+	ImageFormat m_format;
+	std::optional<qint32> m_height = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
+	std::optional<qint32> m_quality = std::nullopt;
+	QString m_tag;
+	std::optional<qint32> m_width = std::nullopt;
 
 
 };
@@ -16369,19 +15606,6 @@ private:
 	// Optional query parameters
 
 
-};
-
-class GetStatusParams {
-public:
-
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
 };
 
 class GetStudioParams {
@@ -16432,15 +15656,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -16460,12 +15675,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -16575,10 +15799,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -16618,15 +15842,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -16646,12 +15861,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -16753,10 +15977,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -16813,8 +16037,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -16840,8 +16064,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -16937,10 +16161,10 @@ private:
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QString m_nameLessThan;
@@ -16958,31 +16182,31 @@ class GetSubtitleParams {
 public:
 
 	/**
-	 * @brief The format of the returned subtitle.	
+	 * @brief The (route) format of the returned subtitle.	
 	 */
-	const QString &format() const;
-	void setFormat(QString newFormat);
+	const QString &routeFormat() const;
+	void setRouteFormat(QString newRouteFormat);
 
 	
 	/**
-	 * @brief The subtitle stream index.	
+	 * @brief The (route) subtitle stream index.	
 	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
+	const qint32 &routeIndex() const;
+	void setRouteIndex(qint32 newRouteIndex);
 
 	
 	/**
-	 * @brief The item id.	
+	 * @brief The (route) item id.	
 	 */
-	const QString &itemId() const;
-	void setItemId(QString newItemId);
+	const QString &routeItemId() const;
+	void setRouteItemId(QString newRouteItemId);
 
 	
 	/**
-	 * @brief The media source id.	
+	 * @brief The (route) media source id.	
 	 */
-	const QString &mediaSourceId() const;
-	void setMediaSourceId(QString newMediaSourceId);
+	const QString &routeMediaSourceId() const;
+	void setRouteMediaSourceId(QString newRouteMediaSourceId);
 
 	
 	/**
@@ -17013,7 +16237,43 @@ public:
 	
 	
 	/**
-	 * @brief Optional. The start position of the subtitle in ticks.	
+	 * @brief The format of the returned subtitle.	
+	 */
+	const QString &format() const;
+	void setFormat(QString newFormat);
+	bool formatNull() const;
+	void setFormatNull();
+	
+	
+	/**
+	 * @brief The subtitle stream index.	
+	 */
+	const qint32 &index() const;
+	void setIndex(qint32 newIndex);
+	bool indexNull() const;
+	void setIndexNull();
+	
+	
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+	bool itemIdNull() const;
+	void setItemIdNull();
+	
+	
+	/**
+	 * @brief The media source id.	
+	 */
+	const QString &mediaSourceId() const;
+	void setMediaSourceId(QString newMediaSourceId);
+	bool mediaSourceIdNull() const;
+	void setMediaSourceIdNull();
+	
+	
+	/**
+	 * @brief The start position of the subtitle in ticks.	
 	 */
 	const qint64 &startPositionTicks() const;
 	void setStartPositionTicks(qint64 newStartPositionTicks);
@@ -17023,10 +16283,10 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_format;
-	qint32 m_index;
-	QString m_itemId;
-	QString m_mediaSourceId;
+	QString m_routeFormat;
+	qint32 m_routeIndex;
+	QString m_routeItemId;
+	QString m_routeMediaSourceId;
 	
 	// Required query parameters
 
@@ -17034,6 +16294,10 @@ private:
 	std::optional<bool> m_addVttTimeMap = std::nullopt;
 	std::optional<bool> m_copyTimestamps = std::nullopt;
 	std::optional<qint64> m_endPositionTicks = std::nullopt;
+	QString m_format;
+	std::optional<qint32> m_index = std::nullopt;
+	QString m_itemId;
+	QString m_mediaSourceId;
 	std::optional<qint64> m_startPositionTicks = std::nullopt;
 
 
@@ -17088,38 +16352,38 @@ class GetSubtitleWithTicksParams {
 public:
 
 	/**
-	 * @brief The format of the returned subtitle.	
+	 * @brief The (route) format of the returned subtitle.	
 	 */
-	const QString &format() const;
-	void setFormat(QString newFormat);
+	const QString &routeFormat() const;
+	void setRouteFormat(QString newRouteFormat);
 
 	
 	/**
-	 * @brief The subtitle stream index.	
+	 * @brief The (route) subtitle stream index.	
 	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
+	const qint32 &routeIndex() const;
+	void setRouteIndex(qint32 newRouteIndex);
 
 	
 	/**
-	 * @brief The item id.	
+	 * @brief The (route) item id.	
 	 */
-	const QString &itemId() const;
-	void setItemId(QString newItemId);
+	const QString &routeItemId() const;
+	void setRouteItemId(QString newRouteItemId);
 
 	
 	/**
-	 * @brief The media source id.	
+	 * @brief The (route) media source id.	
 	 */
-	const QString &mediaSourceId() const;
-	void setMediaSourceId(QString newMediaSourceId);
+	const QString &routeMediaSourceId() const;
+	void setRouteMediaSourceId(QString newRouteMediaSourceId);
 
 	
 	/**
-	 * @brief Optional. The start position of the subtitle in ticks.	
+	 * @brief The (route) start position of the subtitle in ticks.	
 	 */
-	const qint64 &startPositionTicks() const;
-	void setStartPositionTicks(qint64 newStartPositionTicks);
+	const qint64 &routeStartPositionTicks() const;
+	void setRouteStartPositionTicks(qint64 newRouteStartPositionTicks);
 
 	
 	/**
@@ -17149,13 +16413,58 @@ public:
 	void setEndPositionTicksNull();
 	
 	
+	/**
+	 * @brief The format of the returned subtitle.	
+	 */
+	const QString &format() const;
+	void setFormat(QString newFormat);
+	bool formatNull() const;
+	void setFormatNull();
+	
+	
+	/**
+	 * @brief The subtitle stream index.	
+	 */
+	const qint32 &index() const;
+	void setIndex(qint32 newIndex);
+	bool indexNull() const;
+	void setIndexNull();
+	
+	
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+	bool itemIdNull() const;
+	void setItemIdNull();
+	
+	
+	/**
+	 * @brief The media source id.	
+	 */
+	const QString &mediaSourceId() const;
+	void setMediaSourceId(QString newMediaSourceId);
+	bool mediaSourceIdNull() const;
+	void setMediaSourceIdNull();
+	
+	
+	/**
+	 * @brief The start position of the subtitle in ticks.	
+	 */
+	const qint64 &startPositionTicks() const;
+	void setStartPositionTicks(qint64 newStartPositionTicks);
+	bool startPositionTicksNull() const;
+	void setStartPositionTicksNull();
+	
+	
 private:
 	// Required path parameters
-	QString m_format;
-	qint32 m_index;
-	QString m_itemId;
-	QString m_mediaSourceId;
-	qint64 m_startPositionTicks;
+	QString m_routeFormat;
+	qint32 m_routeIndex;
+	QString m_routeItemId;
+	QString m_routeMediaSourceId;
+	qint64 m_routeStartPositionTicks;
 	
 	// Required query parameters
 
@@ -17163,6 +16472,11 @@ private:
 	std::optional<bool> m_addVttTimeMap = std::nullopt;
 	std::optional<bool> m_copyTimestamps = std::nullopt;
 	std::optional<qint64> m_endPositionTicks = std::nullopt;
+	QString m_format;
+	std::optional<qint32> m_index = std::nullopt;
+	QString m_itemId;
+	QString m_mediaSourceId;
+	std::optional<qint64> m_startPositionTicks = std::nullopt;
 
 
 };
@@ -17170,13 +16484,6 @@ private:
 class GetSuggestionsParams {
 public:
 
-	/**
-	 * @brief The user id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Whether to enable the total record count.	
 	 */
@@ -17198,8 +16505,8 @@ public:
 	/**
 	 * @brief The media types.	
 	 */
-	const QStringList &mediaType() const;
-	void setMediaType(QStringList newMediaType);
+	const QList<MediaType> &mediaType() const;
+	void setMediaType(QList<MediaType> newMediaType);
 	bool mediaTypeNull() const;
 	void setMediaTypeNull();
 	
@@ -17216,24 +16523,33 @@ public:
 	/**
 	 * @brief The type.	
 	 */
-	const QStringList &type() const;
-	void setType(QStringList newType);
+	const QList<BaseItemKind> &type() const;
+	void setType(QList<BaseItemKind> newType);
 	bool typeNull() const;
 	void setTypeNull();
 	
 	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
 	std::optional<bool> m_enableTotalRecordCount = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaType;
+	QList<MediaType> m_mediaType;
 	std::optional<qint32> m_startIndex = std::nullopt;
-	QStringList m_type;
+	QList<BaseItemKind> m_type;
+	QString m_userId;
 
 
 };
@@ -17324,6 +16640,24 @@ public:
 	void setInheritFromParentNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Optional. Sort Order - Ascending, Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. Filter by user id, and attach user data.	
 	 */
@@ -17341,6 +16675,8 @@ private:
 
 	// Optional query parameters
 	std::optional<bool> m_inheritFromParent = std::nullopt;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	QString m_userId;
 
 
@@ -17365,6 +16701,24 @@ public:
 	void setInheritFromParentNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Optional. Sort Order - Ascending, Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. Filter by user id, and attach user data.	
 	 */
@@ -17382,6 +16736,8 @@ private:
 
 	// Optional query parameters
 	std::optional<bool> m_inheritFromParent = std::nullopt;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	QString m_userId;
 
 
@@ -17406,6 +16762,24 @@ public:
 	void setInheritFromParentNull();
 	
 	
+	/**
+	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
+	 */
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
+	bool sortByNull() const;
+	void setSortByNull();
+	
+	
+	/**
+	 * @brief Optional. Sort Order - Ascending, Descending.	
+	 */
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
+	bool sortOrderNull() const;
+	void setSortOrderNull();
+	
+	
 	/**
 	 * @brief Optional. Filter by user id, and attach user data.	
 	 */
@@ -17423,6 +16797,8 @@ private:
 
 	// Optional query parameters
 	std::optional<bool> m_inheritFromParent = std::nullopt;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	QString m_userId;
 
 
@@ -17656,8 +17032,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -17708,7 +17084,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have an imdb id or not.	
+	 * @brief Optional filter by items that have an IMDb id or not.	
 	 */
 	const bool &hasImdbId() const;
 	void setHasImdbId(bool newHasImdbId);
@@ -17780,7 +17156,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have a tmdb id or not.	
+	 * @brief Optional filter by items that have a TMDb id or not.	
 	 */
 	const bool &hasTmdbId() const;
 	void setHasTmdbId(bool newHasTmdbId);
@@ -17798,7 +17174,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional filter by items that have a tvdb id or not.	
+	 * @brief Optional filter by items that have a TVDb id or not.	
 	 */
 	const bool &hasTvdbId() const;
 	void setHasTvdbId(bool newHasTvdbId);
@@ -17869,6 +17245,15 @@ public:
 	void setIsHdNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv kids.	
+	 */
+	const bool &isKids() const;
+	void setIsKids(bool newIsKids);
+	bool isKidsNull() const;
+	void setIsKidsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are locked.	
 	 */
@@ -17887,6 +17272,24 @@ public:
 	void setIsMissingNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv movies.	
+	 */
+	const bool &isMovie() const;
+	void setIsMovie(bool newIsMovie);
+	bool isMovieNull() const;
+	void setIsMovieNull();
+	
+	
+	/**
+	 * @brief Optional filter for live tv news.	
+	 */
+	const bool &isNews() const;
+	void setIsNews(bool newIsNews);
+	bool isNewsNull() const;
+	void setIsNewsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are placeholders.	
 	 */
@@ -17905,6 +17308,24 @@ public:
 	void setIsPlayedNull();
 	
 	
+	/**
+	 * @brief Optional filter for live tv series.	
+	 */
+	const bool &isSeries() const;
+	void setIsSeries(bool newIsSeries);
+	bool isSeriesNull() const;
+	void setIsSeriesNull();
+	
+	
+	/**
+	 * @brief Optional filter for live tv sports.	
+	 */
+	const bool &isSports() const;
+	void setIsSports(bool newIsSports);
+	bool isSportsNull() const;
+	void setIsSportsNull();
+	
+	
 	/**
 	 * @brief Optional filter by items that are unaired episodes or not.	
 	 */
@@ -17971,8 +17392,8 @@ public:
 	/**
 	 * @brief Optional filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -18160,17 +17581,17 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
 	
 	/**
-	 * @brief Sort Order - Ascending,Descending.	
+	 * @brief Sort Order - Ascending, Descending.	
 	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 	
@@ -18212,7 +17633,7 @@ public:
 	
 	
 	/**
-	 * @brief The user id.	
+	 * @brief The user id supplied as query parameter; this is required when not using an API key.	
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
@@ -18258,7 +17679,7 @@ private:
 	std::optional<bool> m_enableUserData = std::nullopt;
 	QStringList m_excludeArtistIds;
 	QStringList m_excludeItemIds;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<LocationType> m_excludeLocationTypes;
 	QList<ItemFields> m_fields;
 	QList<ItemFilter> m_filters;
@@ -18282,10 +17703,15 @@ private:
 	std::optional<bool> m_is4K = std::nullopt;
 	std::optional<bool> m_isFavorite = std::nullopt;
 	std::optional<bool> m_isHd = std::nullopt;
+	std::optional<bool> m_isKids = std::nullopt;
 	std::optional<bool> m_isLocked = std::nullopt;
 	std::optional<bool> m_isMissing = std::nullopt;
+	std::optional<bool> m_isMovie = std::nullopt;
+	std::optional<bool> m_isNews = std::nullopt;
 	std::optional<bool> m_isPlaceHolder = std::nullopt;
 	std::optional<bool> m_isPlayed = std::nullopt;
+	std::optional<bool> m_isSeries = std::nullopt;
+	std::optional<bool> m_isSports = std::nullopt;
 	std::optional<bool> m_isUnaired = std::nullopt;
 	std::optional<qint32> m_limit = std::nullopt;
 	QList<LocationType> m_locationTypes;
@@ -18293,7 +17719,7 @@ private:
 	QString m_maxOfficialRating;
 	QDateTime m_maxPremiereDate;
 	std::optional<qint32> m_maxWidth = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	std::optional<double> m_minCommunityRating = std::nullopt;
 	std::optional<double> m_minCriticRating = std::nullopt;
 	QDateTime m_minDateLastSaved;
@@ -18314,8 +17740,8 @@ private:
 	std::optional<bool> m_recursive = std::nullopt;
 	QString m_searchTerm;
 	QList<SeriesStatus> m_seriesStatus;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QStringList m_studioIds;
 	QStringList m_studios;
@@ -18325,6 +17751,92 @@ private:
 	QList<qint32> m_years;
 
 
+};
+
+class GetTrickplayHlsPlaylistParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief The width of a single tile.	
+	 */
+	const qint32 &width() const;
+	void setWidth(qint32 newWidth);
+
+	
+	/**
+	 * @brief The media version id, if using an alternate version.	
+	 */
+	const QString &mediaSourceId() const;
+	void setMediaSourceId(QString newMediaSourceId);
+	bool mediaSourceIdNull() const;
+	void setMediaSourceIdNull();
+	
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	qint32 m_width;
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QString m_mediaSourceId;
+
+
+};
+
+class GetTrickplayTileImageParams {
+public:
+
+	/**
+	 * @brief The index of the desired tile.	
+	 */
+	const qint32 &index() const;
+	void setIndex(qint32 newIndex);
+
+	
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief The width of a single tile.	
+	 */
+	const qint32 &width() const;
+	void setWidth(qint32 newWidth);
+
+	
+	/**
+	 * @brief The media version id, if using an alternate version.	
+	 */
+	const QString &mediaSourceId() const;
+	void setMediaSourceId(QString newMediaSourceId);
+	bool mediaSourceIdNull() const;
+	void setMediaSourceIdNull();
+	
+	
+private:
+	// Required path parameters
+	qint32 m_index;
+	QString m_itemId;
+	qint32 m_width;
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QString m_mediaSourceId;
+
+
 };
 
 class GetTunerHostTypesParams {
@@ -18395,6 +17907,15 @@ public:
 	void setDeviceIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether to enable redirection. Defaults to true.	
 	 */
@@ -18488,8 +18009,8 @@ public:
 	/**
 	 * @brief Optional. The transcoding protocol.	
 	 */
-	const QString &transcodingProtocol() const;
-	void setTranscodingProtocol(QString newTranscodingProtocol);
+	const MediaStreamProtocol &transcodingProtocol() const;
+	void setTranscodingProtocol(MediaStreamProtocol newTranscodingProtocol);
 	bool transcodingProtocolNull() const;
 	void setTranscodingProtocolNull();
 	
@@ -18515,6 +18036,7 @@ private:
 	std::optional<bool> m_breakOnNonKeyFrames = std::nullopt;
 	QStringList m_container;
 	QString m_deviceId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableRedirection = std::nullopt;
 	std::optional<bool> m_enableRemoteMedia = std::nullopt;
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
@@ -18525,7 +18047,7 @@ private:
 	std::optional<qint64> m_startTimeTicks = std::nullopt;
 	std::optional<qint32> m_transcodingAudioChannels = std::nullopt;
 	QString m_transcodingContainer;
-	QString m_transcodingProtocol;
+	MediaStreamProtocol m_transcodingProtocol;
 	QString m_userId;
 
 
@@ -18546,10 +18068,10 @@ public:
 	/**
 	 * @brief Optional. Include image information in output.	
 	 */
-	const bool &enableImges() const;
-	void setEnableImges(bool newEnableImges);
-	bool enableImgesNull() const;
-	void setEnableImgesNull();
+	const bool &enableImages() const;
+	void setEnableImages(bool newEnableImages);
+	bool enableImagesNull() const;
+	void setEnableImagesNull();
 	
 	
 	/**
@@ -18622,7 +18144,7 @@ private:
 
 	// Optional query parameters
 	QList<ImageType> m_enableImageTypes;
-	std::optional<bool> m_enableImges = std::nullopt;
+	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
@@ -18658,29 +18180,6 @@ private:
 class GetUserImageParams {
 public:
 
-	/**
-	 * @brief Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -18700,12 +18199,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -18798,6 +18306,15 @@ public:
 	void setUnplayedCountNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 	/**
 	 * @brief The fixed image width to return.	
 	 */
@@ -18809,16 +18326,14 @@ public:
 	
 private:
 	// Required path parameters
-	ImageType m_imageType;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -18829,183 +18344,7 @@ private:
 	std::optional<qint32> m_quality = std::nullopt;
 	QString m_tag;
 	std::optional<qint32> m_unplayedCount = std::nullopt;
-	std::optional<qint32> m_width = std::nullopt;
-
-
-};
-
-class GetUserImageByIndexParams {
-public:
-
-	/**
-	 * @brief Image index.	
-	 */
-	const qint32 &imageIndex() const;
-	void setImageIndex(qint32 newImageIndex);
-
-	
-	/**
-	 * @brief Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
-	/**
-	 * @brief Optional. Apply a background color for transparent images.	
-	 */
-	const QString &backgroundColor() const;
-	void setBackgroundColor(QString newBackgroundColor);
-	bool backgroundColorNull() const;
-	void setBackgroundColorNull();
-	
-	
-	/**
-	 * @brief Optional. Blur image.	
-	 */
-	const qint32 &blur() const;
-	void setBlur(qint32 newBlur);
-	bool blurNull() const;
-	void setBlurNull();
-	
-	
-	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
-	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
-	
-	
-	/**
-	 * @brief Optional. Apply a foreground layer on top of the image.	
-	 */
-	const QString &foregroundLayer() const;
-	void setForegroundLayer(QString newForegroundLayer);
-	bool foregroundLayerNull() const;
-	void setForegroundLayerNull();
-	
-	
-	/**
-	 * @brief Determines the output format of the image - original,gif,jpg,png.	
-	 */
-	const ImageFormat &format() const;
-	void setFormat(ImageFormat newFormat);
-	bool formatNull() const;
-	void setFormatNull();
-	
-	
-	/**
-	 * @brief The fixed image height to return.	
-	 */
-	const qint32 &height() const;
-	void setHeight(qint32 newHeight);
-	bool heightNull() const;
-	void setHeightNull();
-	
-	
-	/**
-	 * @brief The maximum image height to return.	
-	 */
-	const qint32 &maxHeight() const;
-	void setMaxHeight(qint32 newMaxHeight);
-	bool maxHeightNull() const;
-	void setMaxHeightNull();
-	
-	
-	/**
-	 * @brief The maximum image width to return.	
-	 */
-	const qint32 &maxWidth() const;
-	void setMaxWidth(qint32 newMaxWidth);
-	bool maxWidthNull() const;
-	void setMaxWidthNull();
-	
-	
-	/**
-	 * @brief Optional. Percent to render for the percent played overlay.	
-	 */
-	const double &percentPlayed() const;
-	void setPercentPlayed(double newPercentPlayed);
-	bool percentPlayedNull() const;
-	void setPercentPlayedNull();
-	
-	
-	/**
-	 * @brief Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.	
-	 */
-	const qint32 &quality() const;
-	void setQuality(qint32 newQuality);
-	bool qualityNull() const;
-	void setQualityNull();
-	
-	
-	/**
-	 * @brief Optional. Supply the cache tag from the item object to receive strong caching headers.	
-	 */
-	const QString &tag() const;
-	void setTag(QString newTag);
-	bool tagNull() const;
-	void setTagNull();
-	
-	
-	/**
-	 * @brief Optional. Unplayed count overlay to render.	
-	 */
-	const qint32 &unplayedCount() const;
-	void setUnplayedCount(qint32 newUnplayedCount);
-	bool unplayedCountNull() const;
-	void setUnplayedCountNull();
-	
-	
-	/**
-	 * @brief The fixed image width to return.	
-	 */
-	const qint32 &width() const;
-	void setWidth(qint32 newWidth);
-	bool widthNull() const;
-	void setWidthNull();
-	
-	
-private:
-	// Required path parameters
-	qint32 m_imageIndex;
-	ImageType m_imageType;
 	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
-	QString m_backgroundColor;
-	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
-	QString m_foregroundLayer;
-	ImageFormat m_format;
-	std::optional<qint32> m_height = std::nullopt;
-	std::optional<qint32> m_maxHeight = std::nullopt;
-	std::optional<qint32> m_maxWidth = std::nullopt;
-	std::optional<double> m_percentPlayed = std::nullopt;
-	std::optional<qint32> m_quality = std::nullopt;
-	QString m_tag;
-	std::optional<qint32> m_unplayedCount = std::nullopt;
 	std::optional<qint32> m_width = std::nullopt;
 
 
@@ -19014,13 +18353,6 @@ private:
 class GetUserViewsParams {
 public:
 
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Whether or not to include external views such as channels or live tv.	
 	 */
@@ -19042,22 +18374,31 @@ public:
 	/**
 	 * @brief Preset views.	
 	 */
-	const QStringList &presetViews() const;
-	void setPresetViews(QStringList newPresetViews);
+	const QList<CollectionType> &presetViews() const;
+	void setPresetViews(QList<CollectionType> newPresetViews);
 	bool presetViewsNull() const;
 	void setPresetViewsNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
 	std::optional<bool> m_includeExternalContent = std::nullopt;
 	std::optional<bool> m_includeHidden = std::nullopt;
-	QStringList m_presetViews;
+	QList<CollectionType> m_presetViews;
+	QString m_userId;
 
 
 };
@@ -19155,7 +18496,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -19244,6 +18585,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -19524,7 +18874,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -19571,6 +18921,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -19637,6 +18988,15 @@ public:
 	void setAllowVideoStreamCopyNull();
 	
 	
+	/**
+	 * @brief Whether to always burn in subtitles when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.	
 	 */
@@ -19656,7 +19016,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -19745,6 +19105,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -19826,6 +19195,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -19844,6 +19222,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -20016,7 +19403,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -20051,6 +19438,7 @@ private:
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioBitRate = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
 	QString m_audioCodec;
@@ -20063,6 +19451,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -20072,8 +19461,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -20147,7 +19538,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -20245,6 +19636,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -20326,6 +19726,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -20344,6 +19753,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -20516,7 +19934,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -20564,6 +19982,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -20573,8 +19992,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -20618,13 +20039,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief 	
-	 */
-	const QString &stream() const;
-	void setStream(QString newStream);
-
-	
 	/**
 	 * @brief Whether or not to allow copying of the audio stream url.	
 	 */
@@ -20662,7 +20076,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -20751,6 +20165,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -20832,6 +20255,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -20850,6 +20282,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -20905,7 +20346,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Whether to require a non anamporphic stream.	
+	 * @brief Optional. Whether to require a non anamorphic stream.	
 	 */
 	const bool &requireNonAnamorphic() const;
 	void setRequireNonAnamorphic(bool newRequireNonAnamorphic);
@@ -20923,7 +20364,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -21022,7 +20463,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -21052,7 +20493,6 @@ private:
 	// Required path parameters
 	QString m_container;
 	QString m_itemId;
-	QString m_stream;
 	
 	// Required query parameters
 
@@ -21071,6 +20511,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -21080,8 +20521,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -21198,8 +20641,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be excluded based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &excludeItemTypes() const;
-	void setExcludeItemTypes(QStringList newExcludeItemTypes);
+	const QList<BaseItemKind> &excludeItemTypes() const;
+	void setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes);
 	bool excludeItemTypesNull() const;
 	void setExcludeItemTypesNull();
 	
@@ -21225,8 +20668,8 @@ public:
 	/**
 	 * @brief Optional. If specified, results will be included based on item type. This allows multiple, comma delimited.	
 	 */
-	const QStringList &includeItemTypes() const;
-	void setIncludeItemTypes(QStringList newIncludeItemTypes);
+	const QList<BaseItemKind> &includeItemTypes() const;
+	void setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes);
 	bool includeItemTypesNull() const;
 	void setIncludeItemTypesNull();
 	
@@ -21243,8 +20686,8 @@ public:
 	/**
 	 * @brief Optional. Filter by MediaType. Allows multiple, comma delimited.	
 	 */
-	const QStringList &mediaTypes() const;
-	void setMediaTypes(QStringList newMediaTypes);
+	const QList<MediaType> &mediaTypes() const;
+	void setMediaTypes(QList<MediaType> newMediaTypes);
 	bool mediaTypesNull() const;
 	void setMediaTypesNull();
 	
@@ -21270,8 +20713,8 @@ public:
 	/**
 	 * @brief Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.	
 	 */
-	const QString &sortBy() const;
-	void setSortBy(QString newSortBy);
+	const QList<ItemSortBy> &sortBy() const;
+	void setSortBy(QList<ItemSortBy> newSortBy);
 	bool sortByNull() const;
 	void setSortByNull();
 	
@@ -21279,8 +20722,8 @@ public:
 	/**
 	 * @brief Sort Order - Ascending,Descending.	
 	 */
-	const QString &sortOrder() const;
-	void setSortOrder(QString newSortOrder);
+	const QList<SortOrder> &sortOrder() const;
+	void setSortOrder(QList<SortOrder> newSortOrder);
 	bool sortOrderNull() const;
 	void setSortOrderNull();
 	
@@ -21312,16 +20755,16 @@ private:
 	QList<ImageType> m_enableImageTypes;
 	std::optional<bool> m_enableImages = std::nullopt;
 	std::optional<bool> m_enableUserData = std::nullopt;
-	QStringList m_excludeItemTypes;
+	QList<BaseItemKind> m_excludeItemTypes;
 	QList<ItemFields> m_fields;
 	std::optional<qint32> m_imageTypeLimit = std::nullopt;
-	QStringList m_includeItemTypes;
+	QList<BaseItemKind> m_includeItemTypes;
 	std::optional<qint32> m_limit = std::nullopt;
-	QStringList m_mediaTypes;
+	QList<MediaType> m_mediaTypes;
 	QString m_parentId;
 	std::optional<bool> m_recursive = std::nullopt;
-	QString m_sortBy;
-	QString m_sortOrder;
+	QList<ItemSortBy> m_sortBy;
+	QList<SortOrder> m_sortOrder;
 	std::optional<qint32> m_startIndex = std::nullopt;
 	QString m_userId;
 
@@ -21352,15 +20795,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -21380,12 +20814,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -21487,10 +20930,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -21552,7 +20995,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -21650,6 +21093,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -21921,7 +21373,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -21969,6 +21421,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -22060,7 +21513,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -22149,6 +21602,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -22321,7 +21783,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -22420,7 +21882,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -22468,6 +21930,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -22522,15 +21985,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -22550,12 +22004,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -22665,10 +22128,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -22708,15 +22171,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -22736,12 +22190,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -22843,10 +22306,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -22878,15 +22341,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -22906,12 +22360,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -23021,10 +22484,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -23106,15 +22569,6 @@ public:
 	void setUnplayedCount(qint32 newUnplayedCount);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -23134,12 +22588,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -23193,10 +22656,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	std::optional<qint32> m_height = std::nullopt;
 	std::optional<qint32> m_quality = std::nullopt;
@@ -23229,15 +22692,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -23257,12 +22711,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -23364,10 +22827,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -23436,7 +22899,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -23534,6 +22997,15 @@ public:
 	void setEnableAdaptiveBitrateStreamingNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -23805,7 +23277,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -23854,6 +23326,7 @@ private:
 	QString m_deviceId;
 	QString m_deviceProfileId;
 	std::optional<bool> m_enableAdaptiveBitrateStreaming = std::nullopt;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -23926,6 +23399,15 @@ public:
 	void setAllowVideoStreamCopyNull();
 	
 	
+	/**
+	 * @brief Whether to always burn in subtitles when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.	
 	 */
@@ -23945,7 +23427,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -24043,6 +23525,15 @@ public:
 	void setEnableAdaptiveBitrateStreamingNull();
 	
 	
+	/**
+	 * @brief Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -24061,6 +23552,15 @@ public:
 	void setEnableMpegtsM2TsModeNull();
 	
 	
+	/**
+	 * @brief Enable trickplay image playlists being added to master playlist.	
+	 */
+	const bool &enableTrickplay() const;
+	void setEnableTrickplay(bool newEnableTrickplay);
+	bool enableTrickplayNull() const;
+	void setEnableTrickplayNull();
+	
+	
 	/**
 	 * @brief Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.	
 	 */
@@ -24124,6 +23624,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -24142,6 +23651,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The minimum number of segments.	
 	 */
@@ -24305,7 +23823,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -24341,6 +23859,7 @@ private:
 	// Optional query parameters
 	std::optional<bool> m_allowAudioStreamCopy = std::nullopt;
 	std::optional<bool> m_allowVideoStreamCopy = std::nullopt;
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioBitRate = std::nullopt;
 	std::optional<qint32> m_audioChannels = std::nullopt;
 	QString m_audioCodec;
@@ -24354,8 +23873,10 @@ private:
 	QString m_deviceId;
 	QString m_deviceProfileId;
 	std::optional<bool> m_enableAdaptiveBitrateStreaming = std::nullopt;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
+	std::optional<bool> m_enableTrickplay = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
 	std::optional<qint32> m_height = std::nullopt;
 	QString m_level;
@@ -24363,8 +23884,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
 	QString m_playSessionId;
@@ -24407,15 +23930,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -24435,12 +23949,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -24550,10 +24073,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -24593,15 +24116,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -24621,12 +24135,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -24728,10 +24251,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -24763,15 +24286,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -24791,12 +24305,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -24906,10 +24429,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -24949,15 +24472,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -24977,12 +24491,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -25084,10 +24607,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -25119,15 +24642,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -25147,12 +24661,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -25262,10 +24785,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -25305,15 +24828,6 @@ public:
 	void setName(QString newName);
 
 	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -25333,12 +24847,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -25440,10 +24963,10 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -25513,6 +25036,15 @@ public:
 	void setDeviceIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether to enable redirection. Defaults to true.	
 	 */
@@ -25606,8 +25138,8 @@ public:
 	/**
 	 * @brief Optional. The transcoding protocol.	
 	 */
-	const QString &transcodingProtocol() const;
-	void setTranscodingProtocol(QString newTranscodingProtocol);
+	const MediaStreamProtocol &transcodingProtocol() const;
+	void setTranscodingProtocol(MediaStreamProtocol newTranscodingProtocol);
 	bool transcodingProtocolNull() const;
 	void setTranscodingProtocolNull();
 	
@@ -25633,6 +25165,7 @@ private:
 	std::optional<bool> m_breakOnNonKeyFrames = std::nullopt;
 	QStringList m_container;
 	QString m_deviceId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableRedirection = std::nullopt;
 	std::optional<bool> m_enableRemoteMedia = std::nullopt;
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
@@ -25643,7 +25176,7 @@ private:
 	std::optional<qint64> m_startTimeTicks = std::nullopt;
 	std::optional<qint32> m_transcodingAudioChannels = std::nullopt;
 	QString m_transcodingContainer;
-	QString m_transcodingProtocol;
+	MediaStreamProtocol m_transcodingProtocol;
 	QString m_userId;
 
 
@@ -25652,29 +25185,6 @@ private:
 class HeadUserImageParams {
 public:
 
-	/**
-	 * @brief Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
 	/**
 	 * @brief Optional. Apply a background color for transparent images.	
 	 */
@@ -25694,12 +25204,21 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
+	 * @brief Height of box to fill.	
 	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
+	const qint32 &fillHeight() const;
+	void setFillHeight(qint32 newFillHeight);
+	bool fillHeightNull() const;
+	void setFillHeightNull();
+	
+	
+	/**
+	 * @brief Width of box to fill.	
+	 */
+	const qint32 &fillWidth() const;
+	void setFillWidth(qint32 newFillWidth);
+	bool fillWidthNull() const;
+	void setFillWidthNull();
 	
 	
 	/**
@@ -25792,6 +25311,15 @@ public:
 	void setUnplayedCountNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 	/**
 	 * @brief The fixed image width to return.	
 	 */
@@ -25803,16 +25331,14 @@ public:
 	
 private:
 	// Required path parameters
-	ImageType m_imageType;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
 	QString m_backgroundColor;
 	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
+	std::optional<qint32> m_fillHeight = std::nullopt;
+	std::optional<qint32> m_fillWidth = std::nullopt;
 	QString m_foregroundLayer;
 	ImageFormat m_format;
 	std::optional<qint32> m_height = std::nullopt;
@@ -25823,183 +25349,7 @@ private:
 	std::optional<qint32> m_quality = std::nullopt;
 	QString m_tag;
 	std::optional<qint32> m_unplayedCount = std::nullopt;
-	std::optional<qint32> m_width = std::nullopt;
-
-
-};
-
-class HeadUserImageByIndexParams {
-public:
-
-	/**
-	 * @brief Image index.	
-	 */
-	const qint32 &imageIndex() const;
-	void setImageIndex(qint32 newImageIndex);
-
-	
-	/**
-	 * @brief Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Optional. Add a played indicator.	
-	 */
-	const bool &addPlayedIndicator() const;
-	void setAddPlayedIndicator(bool newAddPlayedIndicator);
-	bool addPlayedIndicatorNull() const;
-	void setAddPlayedIndicatorNull();
-	
-	
-	/**
-	 * @brief Optional. Apply a background color for transparent images.	
-	 */
-	const QString &backgroundColor() const;
-	void setBackgroundColor(QString newBackgroundColor);
-	bool backgroundColorNull() const;
-	void setBackgroundColorNull();
-	
-	
-	/**
-	 * @brief Optional. Blur image.	
-	 */
-	const qint32 &blur() const;
-	void setBlur(qint32 newBlur);
-	bool blurNull() const;
-	void setBlurNull();
-	
-	
-	/**
-	 * @brief Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.	
-	 */
-	const bool &cropWhitespace() const;
-	void setCropWhitespace(bool newCropWhitespace);
-	bool cropWhitespaceNull() const;
-	void setCropWhitespaceNull();
-	
-	
-	/**
-	 * @brief Optional. Apply a foreground layer on top of the image.	
-	 */
-	const QString &foregroundLayer() const;
-	void setForegroundLayer(QString newForegroundLayer);
-	bool foregroundLayerNull() const;
-	void setForegroundLayerNull();
-	
-	
-	/**
-	 * @brief Determines the output format of the image - original,gif,jpg,png.	
-	 */
-	const ImageFormat &format() const;
-	void setFormat(ImageFormat newFormat);
-	bool formatNull() const;
-	void setFormatNull();
-	
-	
-	/**
-	 * @brief The fixed image height to return.	
-	 */
-	const qint32 &height() const;
-	void setHeight(qint32 newHeight);
-	bool heightNull() const;
-	void setHeightNull();
-	
-	
-	/**
-	 * @brief The maximum image height to return.	
-	 */
-	const qint32 &maxHeight() const;
-	void setMaxHeight(qint32 newMaxHeight);
-	bool maxHeightNull() const;
-	void setMaxHeightNull();
-	
-	
-	/**
-	 * @brief The maximum image width to return.	
-	 */
-	const qint32 &maxWidth() const;
-	void setMaxWidth(qint32 newMaxWidth);
-	bool maxWidthNull() const;
-	void setMaxWidthNull();
-	
-	
-	/**
-	 * @brief Optional. Percent to render for the percent played overlay.	
-	 */
-	const double &percentPlayed() const;
-	void setPercentPlayed(double newPercentPlayed);
-	bool percentPlayedNull() const;
-	void setPercentPlayedNull();
-	
-	
-	/**
-	 * @brief Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.	
-	 */
-	const qint32 &quality() const;
-	void setQuality(qint32 newQuality);
-	bool qualityNull() const;
-	void setQualityNull();
-	
-	
-	/**
-	 * @brief Optional. Supply the cache tag from the item object to receive strong caching headers.	
-	 */
-	const QString &tag() const;
-	void setTag(QString newTag);
-	bool tagNull() const;
-	void setTagNull();
-	
-	
-	/**
-	 * @brief Optional. Unplayed count overlay to render.	
-	 */
-	const qint32 &unplayedCount() const;
-	void setUnplayedCount(qint32 newUnplayedCount);
-	bool unplayedCountNull() const;
-	void setUnplayedCountNull();
-	
-	
-	/**
-	 * @brief The fixed image width to return.	
-	 */
-	const qint32 &width() const;
-	void setWidth(qint32 newWidth);
-	bool widthNull() const;
-	void setWidthNull();
-	
-	
-private:
-	// Required path parameters
-	qint32 m_imageIndex;
-	ImageType m_imageType;
 	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	std::optional<bool> m_addPlayedIndicator = std::nullopt;
-	QString m_backgroundColor;
-	std::optional<qint32> m_blur = std::nullopt;
-	std::optional<bool> m_cropWhitespace = std::nullopt;
-	QString m_foregroundLayer;
-	ImageFormat m_format;
-	std::optional<qint32> m_height = std::nullopt;
-	std::optional<qint32> m_maxHeight = std::nullopt;
-	std::optional<qint32> m_maxWidth = std::nullopt;
-	std::optional<double> m_percentPlayed = std::nullopt;
-	std::optional<qint32> m_quality = std::nullopt;
-	QString m_tag;
-	std::optional<qint32> m_unplayedCount = std::nullopt;
 	std::optional<qint32> m_width = std::nullopt;
 
 
@@ -26052,7 +25402,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -26150,6 +25500,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -26231,6 +25590,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -26249,6 +25617,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -26421,7 +25798,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -26469,6 +25846,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -26478,8 +25856,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -26523,13 +25903,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief 	
-	 */
-	const QString &stream() const;
-	void setStream(QString newStream);
-
-	
 	/**
 	 * @brief Whether or not to allow copying of the audio stream url.	
 	 */
@@ -26567,7 +25940,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.	
+	 * @brief Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &audioCodec() const;
 	void setAudioCodec(QString newAudioCodec);
@@ -26656,6 +26029,15 @@ public:
 	void setDeviceProfileIdNull();
 	
 	
+	/**
+	 * @brief Optional. Whether to enable Audio Encoding.	
+	 */
+	const bool &enableAudioVbrEncoding() const;
+	void setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding);
+	bool enableAudioVbrEncodingNull() const;
+	void setEnableAudioVbrEncodingNull();
+	
+	
 	/**
 	 * @brief Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.	
 	 */
@@ -26737,6 +26119,15 @@ public:
 	void setMaxFramerateNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum vertical resolution of the encoded video.	
+	 */
+	const qint32 &maxHeight() const;
+	void setMaxHeight(qint32 newMaxHeight);
+	bool maxHeightNull() const;
+	void setMaxHeightNull();
+	
+	
 	/**
 	 * @brief Optional.	
 	 */
@@ -26755,6 +26146,15 @@ public:
 	void setMaxVideoBitDepthNull();
 	
 	
+	/**
+	 * @brief Optional. The maximum horizontal resolution of the encoded video.	
+	 */
+	const qint32 &maxWidth() const;
+	void setMaxWidth(qint32 newMaxWidth);
+	bool maxWidthNull() const;
+	void setMaxWidthNull();
+	
+	
 	/**
 	 * @brief The media version id, if playing an alternate version.	
 	 */
@@ -26810,7 +26210,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Whether to require a non anamporphic stream.	
+	 * @brief Optional. Whether to require a non anamorphic stream.	
 	 */
 	const bool &requireNonAnamorphic() const;
 	void setRequireNonAnamorphic(bool newRequireNonAnamorphic);
@@ -26828,7 +26228,7 @@ public:
 	
 	
 	/**
-	 * @brief The segment lenght.	
+	 * @brief The segment length.	
 	 */
 	const qint32 &segmentLength() const;
 	void setSegmentLength(qint32 newSegmentLength);
@@ -26927,7 +26327,7 @@ public:
 	
 	
 	/**
-	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.	
+	 * @brief Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.	
 	 */
 	const QString &videoCodec() const;
 	void setVideoCodec(QString newVideoCodec);
@@ -26957,7 +26357,6 @@ private:
 	// Required path parameters
 	QString m_container;
 	QString m_itemId;
-	QString m_stream;
 	
 	// Required query parameters
 
@@ -26976,6 +26375,7 @@ private:
 	std::optional<bool> m_deInterlace = std::nullopt;
 	QString m_deviceId;
 	QString m_deviceProfileId;
+	std::optional<bool> m_enableAudioVbrEncoding = std::nullopt;
 	std::optional<bool> m_enableAutoStreamCopy = std::nullopt;
 	std::optional<bool> m_enableMpegtsM2TsMode = std::nullopt;
 	std::optional<float> m_framerate = std::nullopt;
@@ -26985,8 +26385,10 @@ private:
 	std::optional<qint32> m_maxAudioBitDepth = std::nullopt;
 	std::optional<qint32> m_maxAudioChannels = std::nullopt;
 	std::optional<float> m_maxFramerate = std::nullopt;
+	std::optional<qint32> m_maxHeight = std::nullopt;
 	std::optional<qint32> m_maxRefFrames = std::nullopt;
 	std::optional<qint32> m_maxVideoBitDepth = std::nullopt;
+	std::optional<qint32> m_maxWidth = std::nullopt;
 	QString m_mediaSourceId;
 	std::optional<qint32> m_minSegments = std::nullopt;
 	QString m_params;
@@ -27013,7 +26415,7 @@ private:
 
 };
 
-class InitiateParams {
+class InitiateQuickConnectParams {
 public:
 
 private:
@@ -27077,6 +26479,28 @@ private:
 
 };
 
+class LogFileParams {
+public:
+
+	/**
+	 * @brief 	
+	 */
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
+	
+private:
+	// Required path parameters
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+	// Body parameters
+	QByteArray m_body;
+
+};
+
 class MarkFavoriteItemParams {
 public:
 
@@ -27092,16 +26516,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -27116,13 +26542,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief Optional. The date the item was played.	
 	 */
@@ -27132,15 +26551,24 @@ public:
 	void setDatePlayedNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
 	QDateTime m_datePlayed;
+	QString m_userId;
 
 
 };
@@ -27160,16 +26588,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -27242,13 +26672,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief The audio stream index.	
 	 */
@@ -27351,7 +26774,6 @@ public:
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
@@ -27381,13 +26803,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief The audio stream index.	
 	 */
@@ -27454,7 +26869,6 @@ public:
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
@@ -27480,13 +26894,6 @@ public:
 	void setItemId(QString newItemId);
 
 	
-	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
 	/**
 	 * @brief The live stream id.	
 	 */
@@ -27535,7 +26942,6 @@ public:
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
@@ -27552,6 +26958,15 @@ private:
 class OpenLiveStreamParams {
 public:
 
+	/**
+	 * @brief Always burn-in subtitle when transcoding.	
+	 */
+	const bool &alwaysBurnInSubtitleWhenTranscoding() const;
+	void setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding);
+	bool alwaysBurnInSubtitleWhenTranscodingNull() const;
+	void setAlwaysBurnInSubtitleWhenTranscodingNull();
+	
+	
 	/**
 	 * @brief The audio stream index.	
 	 */
@@ -27664,6 +27079,7 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
+	std::optional<bool> m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
 	std::optional<qint32> m_audioStreamIndex = std::nullopt;
 	std::optional<bool> m_enableDirectPlay = std::nullopt;
 	std::optional<bool> m_enableDirectStream = std::nullopt;
@@ -27689,17 +27105,15 @@ public:
 	 */
 	const QString &playSessionId() const;
 	void setPlaySessionId(QString newPlaySessionId);
-	bool playSessionIdNull() const;
-	void setPlaySessionIdNull();
-	
+
 	
 private:
 	// Required path parameters
 	
 	// Required query parameters
+	QString m_playSessionId;
 
 	// Optional query parameters
-	QString m_playSessionId;
 
 
 };
@@ -27789,67 +27203,6 @@ private:
 	std::optional<qint32> m_subtitleStreamIndex = std::nullopt;
 
 
-};
-
-class PostParams {
-public:
-
-	/**
-	 * @brief Item id.	
-	 */
-	const QString &itemId() const;
-	void setItemId(QString newItemId);
-
-	
-	/**
-	 * @brief (Optional) Specifies the image refresh mode.	
-	 */
-	const MetadataRefreshMode &imageRefreshMode() const;
-	void setImageRefreshMode(MetadataRefreshMode newImageRefreshMode);
-	bool imageRefreshModeNull() const;
-	void setImageRefreshModeNull();
-	
-	
-	/**
-	 * @brief (Optional) Specifies the metadata refresh mode.	
-	 */
-	const MetadataRefreshMode &metadataRefreshMode() const;
-	void setMetadataRefreshMode(MetadataRefreshMode newMetadataRefreshMode);
-	bool metadataRefreshModeNull() const;
-	void setMetadataRefreshModeNull();
-	
-	
-	/**
-	 * @brief (Optional) Determines if images should be replaced. Only applicable if mode is FullRefresh.	
-	 */
-	const bool &replaceAllImages() const;
-	void setReplaceAllImages(bool newReplaceAllImages);
-	bool replaceAllImagesNull() const;
-	void setReplaceAllImagesNull();
-	
-	
-	/**
-	 * @brief (Optional) Determines if metadata should be replaced. Only applicable if mode is FullRefresh.	
-	 */
-	const bool &replaceAllMetadata() const;
-	void setReplaceAllMetadata(bool newReplaceAllMetadata);
-	bool replaceAllMetadataNull() const;
-	void setReplaceAllMetadataNull();
-	
-	
-private:
-	// Required path parameters
-	QString m_itemId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	MetadataRefreshMode m_imageRefreshMode;
-	MetadataRefreshMode m_metadataRefreshMode;
-	std::optional<bool> m_replaceAllImages = std::nullopt;
-	std::optional<bool> m_replaceAllMetadata = std::nullopt;
-
-
 };
 
 class PostAddedMoviesParams {
@@ -27923,8 +27276,8 @@ public:
 	/**
 	 * @brief A list of playable media types, comma delimited. Audio, Video, Book, Photo.	
 	 */
-	const QStringList &playableMediaTypes() const;
-	void setPlayableMediaTypes(QStringList newPlayableMediaTypes);
+	const QList<MediaType> &playableMediaTypes() const;
+	void setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes);
 	bool playableMediaTypesNull() const;
 	void setPlayableMediaTypesNull();
 	
@@ -27956,15 +27309,6 @@ public:
 	void setSupportsPersistentIdentifierNull();
 	
 	
-	/**
-	 * @brief Determines whether sync is supported.	
-	 */
-	const bool &supportsSync() const;
-	void setSupportsSync(bool newSupportsSync);
-	bool supportsSyncNull() const;
-	void setSupportsSyncNull();
-	
-	
 private:
 	// Required path parameters
 	
@@ -27972,11 +27316,10 @@ private:
 
 	// Optional query parameters
 	QString m_jellyfinId;
-	QStringList m_playableMediaTypes;
+	QList<MediaType> m_playableMediaTypes;
 	QList<GeneralCommandType> m_supportedCommands;
 	std::optional<bool> m_supportsMediaControl = std::nullopt;
 	std::optional<bool> m_supportsPersistentIdentifier = std::nullopt;
-	std::optional<bool> m_supportsSync = std::nullopt;
 
 
 };
@@ -28030,10 +27373,10 @@ class PostUpdatedMediaParams {
 public:
 
 	/**
-	 * @brief A list of updated media paths.	
+	 * @brief The update paths.	
 	 */
-	const QList<MediaUpdateInfoDto> &body() const;
-	void setBody(QList<MediaUpdateInfoDto> newBody);
+	const QSharedPointer<MediaUpdateInfoDto> &body() const;
+	void setBody(QSharedPointer<MediaUpdateInfoDto> newBody);
 
 	
 private:
@@ -28044,7 +27387,7 @@ private:
 	// Optional query parameters
 
 	// Body parameters
-	QList<MediaUpdateInfoDto> m_body;
+	QSharedPointer<MediaUpdateInfoDto> m_body;
 
 };
 
@@ -28107,138 +27450,102 @@ private:
 class PostUserImageParams {
 public:
 
-	/**
-	 * @brief (Unused) Image type.	
-	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
-
-	
 	/**
 	 * @brief User Id.	
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 	/**
-	 * @brief (Unused) Image index.	
+	 * @brief 	
 	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
-	bool indexNull() const;
-	void setIndexNull();
-	
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
 	
 private:
 	// Required path parameters
-	ImageType m_imageType;
+	
+	// Required query parameters
+
+	// Optional query parameters
 	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-	std::optional<qint32> m_index = std::nullopt;
 
+	// Body parameters
+	QByteArray m_body;
 
 };
 
-class PostUserImageByIndexParams {
+class RefreshItemParams {
 public:
 
 	/**
-	 * @brief (Unused) Image type.	
+	 * @brief Item id.	
 	 */
-	const ImageType &imageType() const;
-	void setImageType(ImageType newImageType);
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
 
 	
 	/**
-	 * @brief (Unused) Image index.	
+	 * @brief (Optional) Specifies the image refresh mode.	
 	 */
-	const qint32 &index() const;
-	void setIndex(qint32 newIndex);
-
+	const MetadataRefreshMode &imageRefreshMode() const;
+	void setImageRefreshMode(MetadataRefreshMode newImageRefreshMode);
+	bool imageRefreshModeNull() const;
+	void setImageRefreshModeNull();
+	
 	
 	/**
-	 * @brief User Id.	
+	 * @brief (Optional) Specifies the metadata refresh mode.	
 	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
+	const MetadataRefreshMode &metadataRefreshMode() const;
+	void setMetadataRefreshMode(MetadataRefreshMode newMetadataRefreshMode);
+	bool metadataRefreshModeNull() const;
+	void setMetadataRefreshModeNull();
+	
+	
+	/**
+	 * @brief (Optional) Determines if trickplay images should be replaced. Only applicable if mode is FullRefresh.	
+	 */
+	const bool &regenerateTrickplay() const;
+	void setRegenerateTrickplay(bool newRegenerateTrickplay);
+	bool regenerateTrickplayNull() const;
+	void setRegenerateTrickplayNull();
+	
+	
+	/**
+	 * @brief (Optional) Determines if images should be replaced. Only applicable if mode is FullRefresh.	
+	 */
+	const bool &replaceAllImages() const;
+	void setReplaceAllImages(bool newReplaceAllImages);
+	bool replaceAllImagesNull() const;
+	void setReplaceAllImagesNull();
+	
+	
+	/**
+	 * @brief (Optional) Determines if metadata should be replaced. Only applicable if mode is FullRefresh.	
+	 */
+	const bool &replaceAllMetadata() const;
+	void setReplaceAllMetadata(bool newReplaceAllMetadata);
+	bool replaceAllMetadataNull() const;
+	void setReplaceAllMetadataNull();
+	
 	
 private:
 	// Required path parameters
-	ImageType m_imageType;
-	qint32 m_index;
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class ProcessConnectionManagerControlRequestParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class ProcessContentDirectoryControlRequestParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
-class ProcessMediaReceiverRegistrarControlRequestParams {
-public:
-
-	/**
-	 * @brief Server UUID.	
-	 */
-	const QString &serverId() const;
-	void setServerId(QString newServerId);
-
-	
-private:
-	// Required path parameters
-	QString m_serverId;
+	QString m_itemId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	MetadataRefreshMode m_imageRefreshMode;
+	MetadataRefreshMode m_metadataRefreshMode;
+	std::optional<bool> m_regenerateTrickplay = std::nullopt;
+	std::optional<bool> m_replaceAllImages = std::nullopt;
+	std::optional<bool> m_replaceAllMetadata = std::nullopt;
 
 
 };
@@ -28285,7 +27592,7 @@ private:
 
 };
 
-class RemoveFromPlaylistParams {
+class RemoveItemFromPlaylistParams {
 public:
 
 	/**
@@ -28357,6 +27664,35 @@ private:
 	std::optional<bool> m_refreshLibrary = std::nullopt;
 
 
+};
+
+class RemoveUserFromPlaylistParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	QString m_userId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class RemoveUserFromSessionParams {
@@ -28627,6 +27963,27 @@ private:
 	// Optional query parameters
 
 
+};
+
+class SearchRemoteLyricsParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class SearchRemoteSubtitlesParams {
@@ -28738,41 +28095,22 @@ public:
 
 	
 	/**
-	 * @brief The message test.	
+	 * @brief The MediaBrowser.Model.Session.MessageCommand object containing Header, Message Text, and TimeoutMs.	
 	 */
-	const QString &text() const;
-	void setText(QString newText);
+	const QSharedPointer<MessageCommand> &body() const;
+	void setBody(QSharedPointer<MessageCommand> newBody);
 
 	
-	/**
-	 * @brief The message header.	
-	 */
-	const QString &header() const;
-	void setHeader(QString newHeader);
-	bool headerNull() const;
-	void setHeaderNull();
-	
-	
-	/**
-	 * @brief The message timeout. If omitted the user will have to confirm viewing the message.	
-	 */
-	const qint64 &timeoutMs() const;
-	void setTimeoutMs(qint64 newTimeoutMs);
-	bool timeoutMsNull() const;
-	void setTimeoutMsNull();
-	
-	
 private:
 	// Required path parameters
 	QString m_sessionId;
 	
 	// Required query parameters
-	QString m_text;
 
 	// Optional query parameters
-	QString m_header;
-	std::optional<qint64> m_timeoutMs = std::nullopt;
 
+	// Body parameters
+	QSharedPointer<MessageCommand> m_body;
 
 };
 
@@ -28893,6 +28231,13 @@ public:
 	void setItemId(QString newItemId);
 
 	
+	/**
+	 * @brief 	
+	 */
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
+	
 private:
 	// Required path parameters
 	ImageType m_imageType;
@@ -28902,6 +28247,8 @@ private:
 
 	// Optional query parameters
 
+	// Body parameters
+	QByteArray m_body;
 
 };
 
@@ -28929,6 +28276,13 @@ public:
 	void setItemId(QString newItemId);
 
 	
+	/**
+	 * @brief 	
+	 */
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
+	
 private:
 	// Required path parameters
 	qint32 m_imageIndex;
@@ -28939,27 +28293,8 @@ private:
 
 	// Optional query parameters
 
-
-};
-
-class SetReadParams {
-public:
-
-	/**
-	 * @brief 	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
+	// Body parameters
+	QByteArray m_body;
 
 };
 
@@ -29007,27 +28342,6 @@ private:
 
 };
 
-class SetUnreadParams {
-public:
-
-	/**
-	 * @brief 	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-
-};
-
 class ShutdownApplicationParams {
 public:
 
@@ -29070,28 +28384,24 @@ public:
 	 */
 	const QString &deviceId() const;
 	void setDeviceId(QString newDeviceId);
-	bool deviceIdNull() const;
-	void setDeviceIdNull();
-	
+
 	
 	/**
 	 * @brief The play session id.	
 	 */
 	const QString &playSessionId() const;
 	void setPlaySessionId(QString newPlaySessionId);
-	bool playSessionIdNull() const;
-	void setPlaySessionIdNull();
-	
+
 	
 private:
 	// Required path parameters
 	
 	// Required query parameters
-
-	// Optional query parameters
 	QString m_deviceId;
 	QString m_playSessionId;
 
+	// Optional query parameters
+
 
 };
 
@@ -29531,6 +28841,19 @@ private:
 	// Optional query parameters
 
 
+};
+
+class TmdbClientConfigurationParams {
+public:
+
+private:
+	// Required path parameters
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+
 };
 
 class UninstallPluginParams {
@@ -29567,14 +28890,14 @@ public:
 	/**
 	 * @brief Plugin version.	
 	 */
-	const QSharedPointer<Version> &version() const;
-	void setVersion(QSharedPointer<Version> newVersion);
+	const QString &version() const;
+	void setVersion(QString newVersion);
 
 	
 private:
 	// Required path parameters
 	QString m_pluginId;
-	QSharedPointer<Version> m_version;
+	QString m_version;
 	
 	// Required query parameters
 
@@ -29598,16 +28921,18 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 
 };
@@ -29647,8 +28972,8 @@ public:
 	/**
 	 * @brief Device Options.	
 	 */
-	const QSharedPointer<DeviceOptions> &body() const;
-	void setBody(QSharedPointer<DeviceOptions> newBody);
+	const QSharedPointer<DeviceOptionsDto> &body() const;
+	void setBody(QSharedPointer<DeviceOptionsDto> newBody);
 
 	
 private:
@@ -29660,7 +28985,7 @@ private:
 	// Optional query parameters
 
 	// Body parameters
-	QSharedPointer<DeviceOptions> m_body;
+	QSharedPointer<DeviceOptionsDto> m_body;
 
 };
 
@@ -29686,7 +29011,9 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 	/**
 	 * @brief New Display Preferences object.	
@@ -29701,9 +29028,9 @@ private:
 	
 	// Required query parameters
 	QString m_client;
-	QString m_userId;
 
 	// Optional query parameters
+	QString m_userId;
 
 	// Body parameters
 	QSharedPointer<DisplayPreferencesDto> m_body;
@@ -29822,9 +29149,7 @@ public:
 	 */
 	const qint32 &newIndex() const;
 	void setNewIndex(qint32 newNewIndex);
-	bool newIndexNull() const;
-	void setNewIndexNull();
-	
+
 	
 private:
 	// Required path parameters
@@ -29833,13 +29158,53 @@ private:
 	QString m_itemId;
 	
 	// Required query parameters
+	qint32 m_newIndex;
 
 	// Optional query parameters
-	std::optional<qint32> m_newIndex = std::nullopt;
 
 
 };
 
+class UpdateItemUserDataParams {
+public:
+
+	/**
+	 * @brief The item id.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
+	/**
+	 * @brief New user data object.	
+	 */
+	const QSharedPointer<UpdateUserItemDataDto> &body() const;
+	void setBody(QSharedPointer<UpdateUserItemDataDto> newBody);
+
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+	QString m_userId;
+
+	// Body parameters
+	QSharedPointer<UpdateUserItemDataDto> m_body;
+
+};
+
 class UpdateLibraryOptionsParams {
 public:
 
@@ -29862,45 +29227,14 @@ private:
 
 };
 
-class UpdateMediaEncoderPathParams {
-public:
-
-	/**
-	 * @brief Media encoder path form body.	
-	 */
-	const QSharedPointer<MediaEncoderPathDto> &body() const;
-	void setBody(QSharedPointer<MediaEncoderPathDto> newBody);
-
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-	// Body parameters
-	QSharedPointer<MediaEncoderPathDto> m_body;
-
-};
-
 class UpdateMediaPathParams {
 public:
 
 	/**
-	 * @brief The name of the library.	
+	 * @brief The name of the library and path infos.	
 	 */
-	const QString &name() const;
-	void setName(QString newName);
-	bool nameNull() const;
-	void setNameNull();
-	
-	
-	/**
-	 * @brief The path info.	
-	 */
-	const QSharedPointer<MediaPathInfo> &body() const;
-	void setBody(QSharedPointer<MediaPathInfo> newBody);
+	const QSharedPointer<UpdateMediaPathRequestDto> &body() const;
+	void setBody(QSharedPointer<UpdateMediaPathRequestDto> newBody);
 
 	
 private:
@@ -29909,10 +29243,9 @@ private:
 	// Required query parameters
 
 	// Optional query parameters
-	QString m_name;
 
 	// Body parameters
-	QSharedPointer<MediaPathInfo> m_body;
+	QSharedPointer<UpdateMediaPathRequestDto> m_body;
 
 };
 
@@ -29926,6 +29259,13 @@ public:
 	void setKey(QString newKey);
 
 	
+	/**
+	 * @brief Configuration.	
+	 */
+	const QVariant &body() const;
+	void setBody(QVariant newBody);
+
+	
 private:
 	// Required path parameters
 	QString m_key;
@@ -29934,6 +29274,76 @@ private:
 
 	// Optional query parameters
 
+	// Body parameters
+	QVariant m_body;
+
+};
+
+class UpdatePlaylistParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+	/**
+	 * @brief The Jellyfin.Api.Models.PlaylistDtos.UpdatePlaylistDto id.	
+	 */
+	const QSharedPointer<UpdatePlaylistDto> &body() const;
+	void setBody(QSharedPointer<UpdatePlaylistDto> newBody);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+	// Body parameters
+	QSharedPointer<UpdatePlaylistDto> m_body;
+
+};
+
+class UpdatePlaylistUserParams {
+public:
+
+	/**
+	 * @brief The playlist id.	
+	 */
+	const QString &playlistId() const;
+	void setPlaylistId(QString newPlaylistId);
+
+	
+	/**
+	 * @brief The user id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+
+	
+	/**
+	 * @brief The Jellyfin.Api.Models.PlaylistDtos.UpdatePlaylistUserDto.	
+	 */
+	const QSharedPointer<UpdatePlaylistUserDto> &body() const;
+	void setBody(QSharedPointer<UpdatePlaylistUserDto> newBody);
+
+	
+private:
+	// Required path parameters
+	QString m_playlistId;
+	QString m_userId;
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+	// Body parameters
+	QSharedPointer<UpdatePlaylistUserDto> m_body;
 
 };
 
@@ -29958,58 +29368,6 @@ private:
 
 };
 
-class UpdatePluginSecurityInfoParams {
-public:
-
-	/**
-	 * @brief Plugin security info.	
-	 */
-	const QSharedPointer<PluginSecurityInfo> &body() const;
-	void setBody(QSharedPointer<PluginSecurityInfo> newBody);
-
-	
-private:
-	// Required path parameters
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-	// Body parameters
-	QSharedPointer<PluginSecurityInfo> m_body;
-
-};
-
-class UpdateProfileParams {
-public:
-
-	/**
-	 * @brief Profile id.	
-	 */
-	const QString &profileId() const;
-	void setProfileId(QString newProfileId);
-
-	
-	/**
-	 * @brief Device profile.	
-	 */
-	const QSharedPointer<DeviceProfile> &body() const;
-	void setBody(QSharedPointer<DeviceProfile> newBody);
-
-	
-private:
-	// Required path parameters
-	QString m_profileId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-	// Body parameters
-	QSharedPointer<DeviceProfile> m_body;
-
-};
-
 class UpdateSeriesTimerParams {
 public:
 
@@ -30130,7 +29488,9 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 	/**
 	 * @brief The updated user model.	
@@ -30141,11 +29501,11 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 	// Body parameters
 	QSharedPointer<UserDto> m_body;
@@ -30160,7 +29520,9 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 	/**
 	 * @brief The new user configuration.	
@@ -30171,47 +29533,17 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 	// Body parameters
 	QSharedPointer<UserConfiguration> m_body;
 
 };
 
-class UpdateUserEasyPasswordParams {
-public:
-
-	/**
-	 * @brief The user id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief The M:Jellyfin.Api.Controllers.UserController.UpdateUserEasyPassword(System.Guid,Jellyfin.Api.Models.UserDtos.UpdateUserEasyPassword) request.	
-	 */
-	const QSharedPointer<UpdateUserEasyPassword> &body() const;
-	void setBody(QSharedPointer<UpdateUserEasyPassword> newBody);
-
-	
-private:
-	// Required path parameters
-	QString m_userId;
-	
-	// Required query parameters
-
-	// Optional query parameters
-
-	// Body parameters
-	QSharedPointer<UpdateUserEasyPassword> m_body;
-
-};
-
 class UpdateUserItemRatingParams {
 public:
 
@@ -30223,14 +29555,7 @@ public:
 
 	
 	/**
-	 * @brief User id.	
-	 */
-	const QString &userId() const;
-	void setUserId(QString newUserId);
-
-	
-	/**
-	 * @brief Whether this M:Jellyfin.Api.Controllers.UserLibraryController.UpdateUserItemRating(System.Guid,System.Guid,System.Nullable{System.Boolean}) is likes.	
+	 * @brief Whether this M:Jellyfin.Api.Controllers.UserLibraryController.UpdateUserItemRating(System.Nullable{System.Guid},System.Guid,System.Nullable{System.Boolean}) is likes.	
 	 */
 	const bool &likes() const;
 	void setLikes(bool newLikes);
@@ -30238,15 +29563,24 @@ public:
 	void setLikesNull();
 	
 	
+	/**
+	 * @brief User id.	
+	 */
+	const QString &userId() const;
+	void setUserId(QString newUserId);
+	bool userIdNull() const;
+	void setUserIdNull();
+	
+	
 private:
 	// Required path parameters
 	QString m_itemId;
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
 	std::optional<bool> m_likes = std::nullopt;
+	QString m_userId;
 
 
 };
@@ -30259,10 +29593,12 @@ public:
 	 */
 	const QString &userId() const;
 	void setUserId(QString newUserId);
-
+	bool userIdNull() const;
+	void setUserIdNull();
+	
 	
 	/**
-	 * @brief The M:Jellyfin.Api.Controllers.UserController.UpdateUserPassword(System.Guid,Jellyfin.Api.Models.UserDtos.UpdateUserPassword) request.	
+	 * @brief The M:Jellyfin.Api.Controllers.UserController.UpdateUserPassword(System.Nullable{System.Guid},Jellyfin.Api.Models.UserDtos.UpdateUserPassword) request.	
 	 */
 	const QSharedPointer<UpdateUserPassword> &body() const;
 	void setBody(QSharedPointer<UpdateUserPassword> newBody);
@@ -30270,11 +29606,11 @@ public:
 	
 private:
 	// Required path parameters
-	QString m_userId;
 	
 	// Required query parameters
 
 	// Optional query parameters
+	QString m_userId;
 
 	// Body parameters
 	QSharedPointer<UpdateUserPassword> m_body;
@@ -30311,6 +29647,66 @@ private:
 
 };
 
+class UploadCustomSplashscreenParams {
+public:
+
+	/**
+	 * @brief 	
+	 */
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
+	
+private:
+	// Required path parameters
+	
+	// Required query parameters
+
+	// Optional query parameters
+
+	// Body parameters
+	QByteArray m_body;
+
+};
+
+class UploadLyricsParams {
+public:
+
+	/**
+	 * @brief The item the lyric belongs to.	
+	 */
+	const QString &itemId() const;
+	void setItemId(QString newItemId);
+
+	
+	/**
+	 * @brief Name of the file being uploaded.	
+	 */
+	const QString &fileName() const;
+	void setFileName(QString newFileName);
+
+	
+	/**
+	 * @brief 	
+	 */
+	const QByteArray &body() const;
+	void setBody(QByteArray newBody);
+
+	
+private:
+	// Required path parameters
+	QString m_itemId;
+	
+	// Required query parameters
+	QString m_fileName;
+
+	// Optional query parameters
+
+	// Body parameters
+	QByteArray m_body;
+
+};
+
 class UploadSubtitleParams {
 public:
 
diff --git a/core/openapi.json b/core/openapi.json
index 09a057c..4fd8346 100644
--- a/core/openapi.json
+++ b/core/openapi.json
@@ -2,8 +2,8 @@
   "openapi": "3.0.1",
   "info": {
     "title": "Jellyfin API",
-    "version": "v1",
-    "x-jellyfin-version": "10.7.0.0"
+    "version": "10.10.6",
+    "x-jellyfin-version": "10.10.6"
   },
   "servers": [
     {
@@ -25,9 +25,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -36,9 +34,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -47,9 +43,7 @@
             "description": "Optional. The minimum date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -57,9 +51,7 @@
             "in": "query",
             "description": "Optional. Filter log entries if it has user id, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter log entries if it has user id, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -156,8 +148,7 @@
             "description": "Name of the app using the authentication key.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Name of the app using the authentication key."
+              "type": "string"
             }
           }
         ],
@@ -195,8 +186,7 @@
             "description": "The access token to delete.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The access token to delete."
+              "type": "string"
             }
           }
         ],
@@ -234,9 +224,7 @@
             "description": "Optional filter by minimum community rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum community rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -245,9 +233,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -256,9 +242,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -266,9 +250,7 @@
             "in": "query",
             "description": "Optional. Search term.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -277,9 +259,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -290,9 +270,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -302,10 +280,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -315,10 +291,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -329,9 +303,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply.",
-              "nullable": true
+              }
             }
           },
           {
@@ -339,9 +311,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -351,10 +321,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -365,9 +333,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -379,9 +345,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -392,9 +356,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -405,9 +367,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -419,9 +379,7 @@
               "items": {
                 "type": "integer",
                 "format": "int32"
-              },
-              "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -429,9 +387,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -440,9 +396,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -453,9 +407,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -463,9 +415,7 @@
             "in": "query",
             "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
             "schema": {
-              "type": "string",
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -477,9 +427,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -490,9 +438,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -503,9 +449,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -517,9 +461,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -528,9 +470,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -538,9 +478,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -548,9 +486,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -558,9 +494,29 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
+            }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Sort Order - Ascending,Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -569,9 +525,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -580,7 +534,6 @@
             "description": "Total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Total record count.",
               "default": true
             }
           }
@@ -636,8 +589,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -646,9 +598,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -703,9 +653,7 @@
             "description": "Optional filter by minimum community rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum community rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -714,9 +662,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -725,9 +671,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -735,9 +679,7 @@
             "in": "query",
             "description": "Optional. Search term.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -746,9 +688,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -759,9 +699,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -771,10 +709,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -784,10 +720,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -798,9 +732,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply.",
-              "nullable": true
+              }
             }
           },
           {
@@ -808,9 +740,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -820,10 +750,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -834,9 +762,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -848,9 +774,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -861,9 +785,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -874,9 +796,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -888,9 +808,7 @@
               "items": {
                 "type": "integer",
                 "format": "int32"
-              },
-              "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -898,9 +816,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -909,9 +825,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -922,9 +836,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -932,9 +844,7 @@
             "in": "query",
             "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
             "schema": {
-              "type": "string",
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -946,9 +856,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -959,9 +867,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -972,9 +878,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -986,9 +890,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -997,9 +899,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -1007,9 +907,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1017,9 +915,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1027,9 +923,29 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
+            }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Sort Order - Ascending,Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -1038,9 +954,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -1049,7 +963,6 @@
             "description": "Total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Total record count.",
               "default": true
             }
           }
@@ -1106,7 +1019,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -1115,9 +1027,8 @@
             "in": "query",
             "description": "The audio container.",
             "schema": {
-              "type": "string",
-              "description": "The audio container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1125,9 +1036,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1135,9 +1044,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1145,19 +1052,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1165,9 +1069,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1175,9 +1077,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1186,9 +1087,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1197,9 +1096,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1207,9 +1104,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1217,19 +1112,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1237,9 +1129,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1247,9 +1137,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1257,9 +1145,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1267,9 +1153,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1278,9 +1162,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1289,9 +1171,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1300,9 +1180,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1311,9 +1189,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1322,9 +1198,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1332,9 +1206,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1342,9 +1214,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1353,9 +1223,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -1364,9 +1232,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -1374,9 +1240,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1385,9 +1249,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -1396,9 +1258,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1407,9 +1267,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1418,9 +1276,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1429,9 +1285,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1439,7 +1293,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -1448,9 +1313,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1459,9 +1322,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1469,9 +1330,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1479,9 +1338,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1489,9 +1346,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1500,9 +1355,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1511,9 +1364,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1521,9 +1372,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1531,19 +1380,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1551,9 +1397,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1561,9 +1406,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1572,9 +1415,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1583,9 +1424,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1593,7 +1432,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -1603,10 +1450,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -1638,7 +1493,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -1647,9 +1501,8 @@
             "in": "query",
             "description": "The audio container.",
             "schema": {
-              "type": "string",
-              "description": "The audio container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1657,9 +1510,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1667,9 +1518,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1677,19 +1526,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1697,9 +1543,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1707,9 +1551,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1718,9 +1561,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1729,9 +1570,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1739,9 +1578,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1749,19 +1586,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -1769,9 +1603,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1779,9 +1611,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1789,9 +1619,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1799,9 +1627,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1810,9 +1636,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1821,9 +1645,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1832,9 +1654,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1843,9 +1663,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1854,9 +1672,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1864,9 +1680,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1874,9 +1688,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -1885,9 +1697,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -1896,9 +1706,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -1906,9 +1714,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -1917,9 +1723,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -1928,9 +1732,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1939,9 +1741,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1950,9 +1750,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1961,9 +1759,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1971,7 +1767,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -1980,9 +1787,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -1991,9 +1796,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2001,9 +1804,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2011,9 +1812,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2021,9 +1820,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2032,9 +1829,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2043,9 +1838,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2053,9 +1846,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2063,19 +1854,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2083,9 +1871,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2093,9 +1880,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2104,9 +1889,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2115,9 +1898,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2125,7 +1906,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -2135,10 +1924,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -2172,7 +1969,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -2182,8 +1978,7 @@
             "description": "The audio container.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The audio container."
+              "type": "string"
             }
           },
           {
@@ -2191,9 +1986,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2201,9 +1994,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2211,19 +2002,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2231,9 +2019,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2241,20 +2027,17 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
             "name": "segmentLength",
             "in": "query",
-            "description": "The segment lenght.",
+            "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2263,9 +2046,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2273,9 +2054,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2283,19 +2062,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2303,9 +2079,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2313,9 +2087,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2323,9 +2095,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2333,9 +2103,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2344,9 +2112,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2355,9 +2121,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2366,9 +2130,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2377,9 +2139,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2388,9 +2148,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2398,9 +2156,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2408,9 +2164,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2419,9 +2173,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -2430,9 +2182,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -2440,9 +2190,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2451,9 +2199,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -2462,9 +2208,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2473,9 +2217,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2484,9 +2226,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2495,9 +2235,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2505,7 +2243,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -2514,9 +2263,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2525,9 +2272,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2535,9 +2280,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2545,9 +2288,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2555,9 +2296,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamporphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamporphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2566,9 +2305,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2577,9 +2314,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2587,9 +2322,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2597,19 +2330,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2617,9 +2347,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2627,9 +2356,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2638,9 +2365,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2649,9 +2374,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2659,7 +2382,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -2669,10 +2400,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -2704,7 +2443,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -2714,8 +2452,7 @@
             "description": "The audio container.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The audio container."
+              "type": "string"
             }
           },
           {
@@ -2723,9 +2460,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2733,9 +2468,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2743,19 +2476,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2763,9 +2493,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2773,20 +2501,17 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
             "name": "segmentLength",
             "in": "query",
-            "description": "The segment lenght.",
+            "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2795,9 +2520,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2805,9 +2528,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2815,19 +2536,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -2835,9 +2553,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2845,9 +2561,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2855,9 +2569,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2865,9 +2577,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2876,9 +2586,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2887,9 +2595,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2898,9 +2604,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2909,9 +2613,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2920,9 +2622,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -2930,9 +2630,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2940,9 +2638,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -2951,9 +2647,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -2962,9 +2656,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -2972,9 +2664,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -2983,9 +2673,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -2994,9 +2682,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3005,9 +2691,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3016,9 +2700,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3027,9 +2709,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3037,7 +2717,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -3046,9 +2737,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3057,9 +2746,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3067,9 +2754,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -3077,9 +2762,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -3087,9 +2770,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamporphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamporphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -3098,9 +2779,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3109,9 +2788,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3119,9 +2796,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -3129,19 +2804,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -3149,9 +2821,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -3159,9 +2830,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -3170,9 +2839,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3181,9 +2848,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3191,7 +2856,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -3201,10 +2874,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -3346,9 +3027,7 @@
             "description": "User Id to filter by. Use System.Guid.Empty to not filter by user.",
             "schema": {
               "type": "string",
-              "description": "User Id to filter by. Use System.Guid.Empty to not filter by user.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -3357,9 +3036,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3368,9 +3045,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3378,9 +3053,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that support getting latest items.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that support getting latest items.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -3388,9 +3061,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that support media deletion.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that support media deletion.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -3398,9 +3069,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that are favorite.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that are favorite.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -3456,7 +3125,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Channel id.",
               "format": "uuid"
             }
           }
@@ -3513,7 +3181,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Channel Id.",
               "format": "uuid"
             }
           },
@@ -3523,9 +3190,7 @@
             "description": "Optional. Folder Id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Folder Id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -3534,9 +3199,7 @@
             "description": "Optional. User Id.",
             "schema": {
               "type": "string",
-              "description": "Optional. User Id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -3545,9 +3208,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3556,9 +3217,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3566,9 +3225,10 @@
             "in": "query",
             "description": "Optional. Sort Order - Ascending,Descending.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Sort Order - Ascending,Descending.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -3579,9 +3239,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply.",
-              "nullable": true
+              }
             }
           },
           {
@@ -3589,9 +3247,10 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -3602,9 +3261,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -3712,9 +3369,7 @@
             "description": "Optional. User Id.",
             "schema": {
               "type": "string",
-              "description": "Optional. User Id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -3723,9 +3378,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3734,9 +3387,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -3747,9 +3398,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply.",
-              "nullable": true
+              }
             }
           },
           {
@@ -3760,9 +3409,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -3774,9 +3421,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. Specify one or more channel id's, comma delimited.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -3817,6 +3462,97 @@
         ]
       }
     },
+    "/ClientLog/Document": {
+      "post": {
+        "tags": [
+          "ClientLog"
+        ],
+        "summary": "Upload a document.",
+        "operationId": "LogFile",
+        "requestBody": {
+          "content": {
+            "text/plain": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "Document saved.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ClientLogDocumentResponseDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ClientLogDocumentResponseDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ClientLogDocumentResponseDto"
+                }
+              }
+            }
+          },
+          "403": {
+            "description": "Event logging disabled.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "413": {
+            "description": "Upload size too large.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Collections": {
       "post": {
         "tags": [
@@ -3830,9 +3566,7 @@
             "in": "query",
             "description": "The name of the collection.",
             "schema": {
-              "type": "string",
-              "description": "The name of the collection.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -3843,9 +3577,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Item Ids to add to the collection.",
-              "nullable": true
+              }
             }
           },
           {
@@ -3854,9 +3586,7 @@
             "description": "Optional. Create the collection within a specific folder.",
             "schema": {
               "type": "string",
-              "description": "Optional. Create the collection within a specific folder.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -3865,7 +3595,6 @@
             "description": "Whether or not to lock the new collection.",
             "schema": {
               "type": "boolean",
-              "description": "Whether or not to lock the new collection.",
               "default": false
             }
           }
@@ -3901,6 +3630,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "CollectionManagement",
               "DefaultAuthorization"
             ]
           }
@@ -3922,7 +3652,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The collection id.",
               "format": "uuid"
             }
           },
@@ -3936,8 +3665,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Item ids, comma delimited."
+              }
             }
           }
         ],
@@ -3955,6 +3683,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "CollectionManagement",
               "DefaultAuthorization"
             ]
           }
@@ -3974,7 +3703,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The collection id.",
               "format": "uuid"
             }
           },
@@ -3988,8 +3716,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Item ids, comma delimited."
+              }
             }
           }
         ],
@@ -4007,6 +3734,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "CollectionManagement",
               "DefaultAuthorization"
             ]
           }
@@ -4067,17 +3795,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ServerConfiguration"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ServerConfiguration"
+                  }
+                ],
+                "description": "Represents the server configuration."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ServerConfiguration"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ServerConfiguration"
+                  }
+                ],
+                "description": "Represents the server configuration."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ServerConfiguration"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ServerConfiguration"
+                  }
+                ],
+                "description": "Represents the server configuration."
               }
             }
           },
@@ -4118,8 +3861,7 @@
             "description": "Configuration key.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Configuration key."
+              "type": "string"
             }
           }
         ],
@@ -4163,11 +3905,25 @@
             "description": "Configuration key.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Configuration key."
+              "type": "string"
             }
           }
         ],
+        "requestBody": {
+          "description": "Configuration.",
+          "content": {
+            "application/json": {
+              "schema": { }
+            },
+            "text/json": {
+              "schema": { }
+            },
+            "application/*+json": {
+              "schema": { }
+            }
+          },
+          "required": true
+        },
         "responses": {
           "204": {
             "description": "Named configuration updated."
@@ -4234,55 +3990,6 @@
         ]
       }
     },
-    "/System/MediaEncoder/Path": {
-      "post": {
-        "tags": [
-          "Configuration"
-        ],
-        "summary": "Updates the path to the media encoder.",
-        "operationId": "UpdateMediaEncoderPath",
-        "requestBody": {
-          "description": "Media encoder path form body.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/MediaEncoderPathDto"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/MediaEncoderPathDto"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/MediaEncoderPathDto"
-              }
-            }
-          },
-          "required": true
-        },
-        "responses": {
-          "204": {
-            "description": "Media encoder path updated."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "FirstTimeSetupOrElevated",
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
     "/web/ConfigurationPage": {
       "get": {
         "tags": [
@@ -4296,9 +4003,7 @@
             "in": "query",
             "description": "The name of the page.",
             "schema": {
-              "type": "string",
-              "description": "The name of the page.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -4356,17 +4061,7 @@
             "in": "query",
             "description": "Whether to enable in the main menu.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable in the main menu.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "pageType",
-            "in": "query",
-            "description": "The Jellyfin.Api.Models.ConfigurationPageInfo.",
-            "schema": {
-              "$ref": "#/components/schemas/ConfigurationPageType"
+              "type": "boolean"
             }
           }
         ],
@@ -4419,8 +4114,21 @@
                 }
               }
             }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
           }
-        }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "RequiresElevation"
+            ]
+          }
+        ]
       }
     },
     "/Devices": {
@@ -4431,25 +4139,13 @@
         "summary": "Get Devices.",
         "operationId": "GetDevices",
         "parameters": [
-          {
-            "name": "supportsSync",
-            "in": "query",
-            "description": "Gets or sets a value indicating whether [supports synchronize].",
-            "schema": {
-              "type": "boolean",
-              "description": "Gets or sets a value indicating whether [supports synchronize].",
-              "nullable": true
-            }
-          },
           {
             "name": "userId",
             "in": "query",
             "description": "Gets or sets the user identifier.",
             "schema": {
               "type": "string",
-              "description": "Gets or sets the user identifier.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -4459,17 +4155,17 @@
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfoQueryResult"
+                  "$ref": "#/components/schemas/DeviceInfoDtoQueryResult"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfoQueryResult"
+                  "$ref": "#/components/schemas/DeviceInfoDtoQueryResult"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfoQueryResult"
+                  "$ref": "#/components/schemas/DeviceInfoDtoQueryResult"
                 }
               }
             }
@@ -4502,8 +4198,7 @@
             "description": "Device Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Device Id."
+              "type": "string"
             }
           }
         ],
@@ -4561,8 +4256,7 @@
             "description": "Device Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Device Id."
+              "type": "string"
             }
           }
         ],
@@ -4572,17 +4266,17 @@
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfo"
+                  "$ref": "#/components/schemas/DeviceInfoDto"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfo"
+                  "$ref": "#/components/schemas/DeviceInfoDto"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceInfo"
+                  "$ref": "#/components/schemas/DeviceInfoDto"
                 }
               }
             }
@@ -4637,8 +4331,7 @@
             "description": "Device Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Device Id."
+              "type": "string"
             }
           }
         ],
@@ -4648,17 +4341,17 @@
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceOptions"
+                  "$ref": "#/components/schemas/DeviceOptionsDto"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceOptions"
+                  "$ref": "#/components/schemas/DeviceOptionsDto"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/DeviceOptions"
+                  "$ref": "#/components/schemas/DeviceOptionsDto"
                 }
               }
             }
@@ -4711,8 +4404,7 @@
             "description": "Device Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Device Id."
+              "type": "string"
             }
           }
         ],
@@ -4721,17 +4413,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/DeviceOptions"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DeviceOptionsDto"
+                  }
+                ],
+                "description": "A dto representing custom options for a device."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/DeviceOptions"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DeviceOptionsDto"
+                  }
+                ],
+                "description": "A dto representing custom options for a device."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/DeviceOptions"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DeviceOptionsDto"
+                  }
+                ],
+                "description": "A dto representing custom options for a device."
               }
             }
           },
@@ -4741,26 +4448,6 @@
           "204": {
             "description": "Device options updated."
           },
-          "404": {
-            "description": "Device not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
           "401": {
             "description": "Unauthorized"
           },
@@ -4791,18 +4478,15 @@
             "description": "Display preferences id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Display preferences id."
+              "type": "string"
             }
           },
           {
             "name": "userId",
             "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -4812,8 +4496,7 @@
             "description": "Client.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Client."
+              "type": "string"
             }
           }
         ],
@@ -4866,18 +4549,15 @@
             "description": "Display preferences id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Display preferences id."
+              "type": "string"
             }
           },
           {
             "name": "userId",
             "in": "query",
             "description": "User Id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User Id.",
               "format": "uuid"
             }
           },
@@ -4887,8 +4567,7 @@
             "description": "Client.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Client."
+              "type": "string"
             }
           }
         ],
@@ -4897,17 +4576,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/DisplayPreferencesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DisplayPreferencesDto"
+                  }
+                ],
+                "description": "Defines the display preferences for any item that supports them (usually Folders)."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/DisplayPreferencesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DisplayPreferencesDto"
+                  }
+                ],
+                "description": "Defines the display preferences for any item that supports them (usually Folders)."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/DisplayPreferencesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/DisplayPreferencesDto"
+                  }
+                ],
+                "description": "Defines the display preferences for any item that supports them (usually Folders)."
               }
             }
           },
@@ -4933,1002 +4627,6 @@
         ]
       }
     },
-    "/Dlna/ProfileInfos": {
-      "get": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Get profile infos.",
-        "operationId": "GetProfileInfos",
-        "responses": {
-          "200": {
-            "description": "Device profile infos returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/DeviceProfileInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/DeviceProfileInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/DeviceProfileInfo"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      }
-    },
-    "/Dlna/Profiles": {
-      "post": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Creates a profile.",
-        "operationId": "CreateProfile",
-        "requestBody": {
-          "description": "Device profile.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            }
-          }
-        },
-        "responses": {
-          "204": {
-            "description": "Device profile created."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      }
-    },
-    "/Dlna/Profiles/{profileId}": {
-      "get": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Gets a single profile.",
-        "operationId": "GetProfile",
-        "parameters": [
-          {
-            "name": "profileId",
-            "in": "path",
-            "description": "Profile Id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Profile Id."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Device profile returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Device profile not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      },
-      "delete": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Deletes a profile.",
-        "operationId": "DeleteProfile",
-        "parameters": [
-          {
-            "name": "profileId",
-            "in": "path",
-            "description": "Profile id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Profile id."
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Device profile deleted."
-          },
-          "404": {
-            "description": "Device profile not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      },
-      "post": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Updates a profile.",
-        "operationId": "UpdateProfile",
-        "parameters": [
-          {
-            "name": "profileId",
-            "in": "path",
-            "description": "Profile id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Profile id."
-            }
-          }
-        ],
-        "requestBody": {
-          "description": "Device profile.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/DeviceProfile"
-              }
-            }
-          }
-        },
-        "responses": {
-          "204": {
-            "description": "Device profile updated."
-          },
-          "404": {
-            "description": "Device profile not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      }
-    },
-    "/Dlna/Profiles/Default": {
-      "get": {
-        "tags": [
-          "Dlna"
-        ],
-        "summary": "Gets the default profile.",
-        "operationId": "GetDefaultProfile",
-        "responses": {
-          "200": {
-            "description": "Default device profile returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/DeviceProfile"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      }
-    },
-    "/Dlna/{serverId}/ConnectionManager": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetConnectionManager",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ConnectionManager/ConnectionManager": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetConnectionManager_2",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ConnectionManager/ConnectionManager.xml": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetConnectionManager_3",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ConnectionManager/Control": {
-      "post": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Process a connection manager control request.",
-        "operationId": "ProcessConnectionManagerControlRequest",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Request processed.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ContentDirectory": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna content directory xml.",
-        "operationId": "GetContentDirectory",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna content directory returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ContentDirectory/ContentDirectory": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna content directory xml.",
-        "operationId": "GetContentDirectory_2",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna content directory returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ContentDirectory/ContentDirectory.xml": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna content directory xml.",
-        "operationId": "GetContentDirectory_3",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna content directory returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/ContentDirectory/Control": {
-      "post": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Process a content directory control request.",
-        "operationId": "ProcessContentDirectoryControlRequest",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Request processed.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/description": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Get Description Xml.",
-        "operationId": "GetDescriptionXml",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Description xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/description.xml": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Get Description Xml.",
-        "operationId": "GetDescriptionXml_2",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Description xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/icons/{fileName}": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets a server icon.",
-        "operationId": "GetIconId",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          },
-          {
-            "name": "fileName",
-            "in": "path",
-            "description": "The icon filename.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The icon filename."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Request processed.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Not Found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/MediaReceiverRegistrar": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetMediaReceiverRegistrar",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/MediaReceiverRegistrar/Control": {
-      "post": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Process a media receiver registrar control request.",
-        "operationId": "ProcessMediaReceiverRegistrarControlRequest",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Request processed.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/MediaReceiverRegistrar/MediaReceiverRegistrar": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetMediaReceiverRegistrar_2",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/{serverId}/MediaReceiverRegistrar/MediaReceiverRegistrar.xml": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets Dlna media receiver registrar xml.",
-        "operationId": "GetMediaReceiverRegistrar_3",
-        "parameters": [
-          {
-            "name": "serverId",
-            "in": "path",
-            "description": "Server UUID.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Server UUID."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Dlna media receiver registrar xml returned.",
-            "content": {
-              "text/xml": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
-    "/Dlna/icons/{fileName}": {
-      "get": {
-        "tags": [
-          "DlnaServer"
-        ],
-        "summary": "Gets a server icon.",
-        "operationId": "GetIcon",
-        "parameters": [
-          {
-            "name": "fileName",
-            "in": "path",
-            "description": "The icon filename.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The icon filename."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Request processed.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Not Found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "503": {
-            "description": "DLNA is disabled."
-          }
-        }
-      }
-    },
     "/Audio/{itemId}/hls1/{playlistId}/{segmentId}.{container}": {
       "get": {
         "tags": [
@@ -5944,7 +4642,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -5954,8 +4651,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           },
           {
@@ -5965,7 +4661,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The segment id.",
               "format": "int32"
             }
           },
@@ -5975,8 +4670,27 @@
             "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv."
+              "type": "string"
+            }
+          },
+          {
+            "name": "runtimeTicks",
+            "in": "query",
+            "description": "The position of the requested segment in ticks.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "actualSegmentLengthTicks",
+            "in": "query",
+            "description": "The length of the requested segment in ticks.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
             }
           },
           {
@@ -5984,9 +4698,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -5994,9 +4706,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6004,19 +4714,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6024,9 +4731,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6034,9 +4739,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6045,9 +4749,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6056,9 +4758,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6066,9 +4766,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6076,19 +4774,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6096,9 +4791,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6106,9 +4799,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6116,9 +4807,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6126,9 +4815,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6137,9 +4824,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6148,9 +4833,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6159,9 +4842,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6170,9 +4851,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6181,9 +4860,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6192,9 +4869,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6202,9 +4877,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6212,9 +4885,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6223,9 +4894,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -6234,9 +4903,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -6244,9 +4911,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6255,9 +4920,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -6266,9 +4929,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6277,9 +4938,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6288,9 +4947,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6299,9 +4956,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6309,7 +4964,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -6318,9 +4984,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6329,9 +4993,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6339,9 +5001,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6349,9 +5009,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6359,9 +5017,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6370,9 +5026,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6381,9 +5035,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6391,9 +5043,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6401,19 +5051,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6421,9 +5068,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6431,9 +5077,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6442,9 +5086,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6453,9 +5095,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6463,7 +5103,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -6473,10 +5121,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -6523,7 +5179,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -6532,9 +5187,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6542,9 +5195,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6552,19 +5203,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6572,9 +5220,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6582,9 +5228,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6593,9 +5238,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6604,9 +5247,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6614,9 +5255,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6624,19 +5263,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6644,9 +5280,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6654,9 +5288,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6664,9 +5296,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6674,9 +5304,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6685,9 +5313,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6696,9 +5322,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6707,9 +5331,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6718,9 +5340,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6729,9 +5349,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6740,9 +5358,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6750,9 +5366,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6760,9 +5374,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6771,9 +5383,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -6782,9 +5392,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -6792,9 +5400,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6803,9 +5409,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -6814,9 +5418,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6825,9 +5427,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6836,9 +5436,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6847,9 +5445,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6857,7 +5453,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -6866,9 +5473,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6877,9 +5482,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6887,9 +5490,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6897,9 +5498,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6907,9 +5506,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -6918,9 +5515,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6929,9 +5524,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -6939,9 +5532,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6949,19 +5540,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6969,9 +5557,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -6979,9 +5566,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -6990,9 +5575,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7001,9 +5584,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7011,7 +5592,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -7021,10 +5610,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -7071,7 +5668,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -7080,9 +5676,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7090,9 +5684,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7100,19 +5692,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7120,9 +5709,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7130,9 +5717,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7141,9 +5727,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7152,9 +5736,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7163,8 +5745,7 @@
             "description": "The media version id, if playing an alternate version.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version."
+              "type": "string"
             }
           },
           {
@@ -7172,19 +5753,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7192,9 +5770,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7202,9 +5778,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7212,9 +5786,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7222,9 +5794,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7233,9 +5803,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7244,9 +5812,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7255,9 +5821,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7266,9 +5830,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7277,9 +5839,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7288,9 +5848,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7298,9 +5856,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7308,9 +5864,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7319,9 +5873,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -7330,9 +5882,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -7340,9 +5890,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7351,9 +5899,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -7362,9 +5908,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7373,9 +5917,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7384,9 +5926,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7395,9 +5935,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7405,7 +5943,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -7414,9 +5963,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7425,9 +5972,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7435,9 +5980,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7445,9 +5988,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7455,9 +5996,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7466,9 +6005,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7477,9 +6014,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7487,9 +6022,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7497,19 +6030,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7517,9 +6047,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7527,9 +6056,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7538,9 +6065,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7549,9 +6074,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7559,7 +6082,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -7569,10 +6100,9 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
             }
           },
           {
@@ -7581,7 +6111,15 @@
             "description": "Enable adaptive bitrate streaming.",
             "schema": {
               "type": "boolean",
-              "description": "Enable adaptive bitrate streaming.",
+              "default": true
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
               "default": true
             }
           }
@@ -7627,7 +6165,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -7636,9 +6173,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7646,9 +6181,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7656,19 +6189,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7676,9 +6206,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7686,9 +6214,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7697,9 +6224,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7708,9 +6233,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7719,8 +6242,7 @@
             "description": "The media version id, if playing an alternate version.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version."
+              "type": "string"
             }
           },
           {
@@ -7728,19 +6250,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -7748,9 +6267,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7758,9 +6275,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7768,9 +6283,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7778,9 +6291,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7789,9 +6300,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7800,9 +6309,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7811,9 +6318,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7822,9 +6327,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7833,9 +6336,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7844,9 +6345,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7854,9 +6353,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7864,9 +6361,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -7875,9 +6370,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -7886,9 +6379,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -7896,9 +6387,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -7907,9 +6396,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -7918,9 +6405,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7929,9 +6414,7 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7940,9 +6423,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7951,9 +6432,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7961,7 +6440,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -7970,9 +6460,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7981,9 +6469,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -7991,9 +6477,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8001,9 +6485,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8011,9 +6493,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8022,9 +6502,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8033,9 +6511,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8043,9 +6519,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8053,19 +6527,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8073,9 +6544,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8083,9 +6553,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8094,9 +6562,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8105,9 +6571,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8115,7 +6579,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -8125,10 +6597,9 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
             }
           },
           {
@@ -8137,7 +6608,15 @@
             "description": "Enable adaptive bitrate streaming.",
             "schema": {
               "type": "boolean",
-              "description": "Enable adaptive bitrate streaming.",
+              "default": true
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
               "default": true
             }
           }
@@ -8185,7 +6664,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -8195,8 +6673,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           },
           {
@@ -8206,7 +6683,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The segment id.",
               "format": "int32"
             }
           },
@@ -8216,8 +6692,27 @@
             "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv."
+              "type": "string"
+            }
+          },
+          {
+            "name": "runtimeTicks",
+            "in": "query",
+            "description": "The position of the requested segment in ticks.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "actualSegmentLengthTicks",
+            "in": "query",
+            "description": "The length of the requested segment in ticks.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
             }
           },
           {
@@ -8225,9 +6720,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8235,9 +6728,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8245,19 +6736,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8265,9 +6753,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8275,20 +6761,17 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
             "name": "segmentLength",
             "in": "query",
-            "description": "The segment lenght.",
+            "description": "The desired segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8297,9 +6780,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8307,9 +6788,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8317,19 +6796,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8337,9 +6813,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8347,9 +6821,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8357,9 +6829,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8367,9 +6837,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8378,9 +6846,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8389,9 +6855,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8400,9 +6864,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8411,9 +6873,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8422,9 +6882,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8432,9 +6890,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8442,9 +6898,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8453,9 +6907,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -8464,9 +6916,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -8474,9 +6924,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8485,9 +6933,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -8496,9 +6942,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8507,9 +6951,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -8518,9 +6978,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8529,9 +6987,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8539,7 +6995,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -8548,9 +7015,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8559,9 +7024,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8569,9 +7032,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8579,9 +7040,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8589,9 +7048,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8600,9 +7057,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8611,9 +7066,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8621,9 +7074,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8631,19 +7082,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8651,9 +7099,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8661,9 +7108,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8672,9 +7117,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8683,9 +7126,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8693,7 +7134,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -8703,10 +7152,27 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Whether to always burn in subtitles when transcoding.",
+            "schema": {
+              "type": "boolean",
+              "default": false
             }
           }
         ],
@@ -8738,6 +7204,530 @@
         ]
       }
     },
+    "/Videos/{itemId}/live.m3u8": {
+      "get": {
+        "tags": [
+          "DynamicHls"
+        ],
+        "summary": "Gets a hls live stream.",
+        "operationId": "GetLiveHlsStream",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "container",
+            "in": "query",
+            "description": "The audio container.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "static",
+            "in": "query",
+            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "params",
+            "in": "query",
+            "description": "The streaming parameters.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "tag",
+            "in": "query",
+            "description": "The tag.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceProfileId",
+            "in": "query",
+            "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentContainer",
+            "in": "query",
+            "description": "The segment container.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentLength",
+            "in": "query",
+            "description": "The segment length.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "minSegments",
+            "in": "query",
+            "description": "The minimum number of segments.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media version id, if playing an alternate version.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceId",
+            "in": "query",
+            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioCodec",
+            "in": "query",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableAutoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowVideoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the video stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowAudioStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the audio stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "breakOnNonKeyFrames",
+            "in": "query",
+            "description": "Optional. Whether to break on non key frames.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "audioSampleRate",
+            "in": "query",
+            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum audio bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioBitRate",
+            "in": "query",
+            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioChannels",
+            "in": "query",
+            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioChannels",
+            "in": "query",
+            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "profile",
+            "in": "query",
+            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "level",
+            "in": "query",
+            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "framerate",
+            "in": "query",
+            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "maxFramerate",
+            "in": "query",
+            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "copyTimestamps",
+            "in": "query",
+            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "startTimeTicks",
+            "in": "query",
+            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "width",
+            "in": "query",
+            "description": "Optional. The fixed horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "height",
+            "in": "query",
+            "description": "Optional. The fixed vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoBitRate",
+            "in": "query",
+            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleMethod",
+            "in": "query",
+            "description": "Optional. Specify the subtitle delivery method.",
+            "schema": {
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
+            }
+          },
+          {
+            "name": "maxRefFrames",
+            "in": "query",
+            "description": "Optional.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxVideoBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum video bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "requireAvc",
+            "in": "query",
+            "description": "Optional. Whether to require avc.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "deInterlace",
+            "in": "query",
+            "description": "Optional. Whether to deinterlace the video.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "requireNonAnamorphic",
+            "in": "query",
+            "description": "Optional. Whether to require a non anamorphic stream.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "transcodingMaxAudioChannels",
+            "in": "query",
+            "description": "Optional. The maximum number of audio channels to transcode.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "cpuCoreLimit",
+            "in": "query",
+            "description": "Optional. The limit of how many cpu cores to use.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableMpegtsM2TsMode",
+            "in": "query",
+            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "videoCodec",
+            "in": "query",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "subtitleCodec",
+            "in": "query",
+            "description": "Optional. Specify a subtitle codec to encode to.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "transcodeReasons",
+            "in": "query",
+            "description": "Optional. The transcoding reason.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "context",
+            "in": "query",
+            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
+            "schema": {
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
+            }
+          },
+          {
+            "name": "streamOptions",
+            "in": "query",
+            "description": "Optional. The streaming options.",
+            "schema": {
+              "type": "object",
+              "additionalProperties": {
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The max width.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The max height.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "enableSubtitlesInManifest",
+            "in": "query",
+            "description": "Optional. Whether to enable subtitles in the manifest.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Whether to always burn in subtitles when transcoding.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Hls live stream retrieved.",
+            "content": {
+              "application/x-mpegURL": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Videos/{itemId}/main.m3u8": {
       "get": {
         "tags": [
@@ -8753,7 +7743,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -8762,9 +7751,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8772,9 +7759,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8782,19 +7767,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8802,9 +7784,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8812,9 +7792,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8823,9 +7802,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8834,9 +7811,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8844,9 +7819,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8854,19 +7827,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -8874,9 +7844,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8884,9 +7852,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8894,9 +7860,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8904,9 +7868,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -8915,9 +7877,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8926,9 +7886,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8937,9 +7895,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8948,9 +7904,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8959,9 +7913,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -8969,9 +7921,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8979,9 +7929,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -8990,9 +7938,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -9001,9 +7947,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -9011,9 +7955,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9022,9 +7964,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -9033,9 +7973,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9044,9 +7982,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -9055,9 +8009,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9066,9 +8018,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9076,7 +8026,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -9085,9 +8046,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9096,9 +8055,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9106,9 +8063,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9116,9 +8071,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9126,9 +8079,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9137,9 +8088,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9148,9 +8097,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9158,9 +8105,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9168,19 +8113,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9188,9 +8130,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9198,9 +8139,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9209,9 +8148,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9220,9 +8157,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9230,7 +8165,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -9240,10 +8183,27 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Whether to always burn in subtitles when transcoding.",
+            "schema": {
+              "type": "boolean",
+              "default": false
             }
           }
         ],
@@ -9290,7 +8250,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -9299,9 +8258,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9309,9 +8266,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9319,19 +8274,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9339,9 +8291,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9349,9 +8299,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9360,9 +8309,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9371,9 +8318,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9382,8 +8327,7 @@
             "description": "The media version id, if playing an alternate version.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version."
+              "type": "string"
             }
           },
           {
@@ -9391,19 +8335,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9411,9 +8352,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9421,9 +8360,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9431,9 +8368,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9441,9 +8376,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9452,9 +8385,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9463,9 +8394,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9474,9 +8403,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9485,9 +8412,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9496,9 +8421,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9506,9 +8429,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9516,9 +8437,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9527,9 +8446,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -9538,9 +8455,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -9548,9 +8463,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9559,9 +8472,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -9570,9 +8481,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9581,9 +8490,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -9592,9 +8517,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9603,9 +8526,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9613,7 +8534,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -9622,9 +8554,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9633,9 +8563,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9643,9 +8571,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9653,9 +8579,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9663,9 +8587,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9674,9 +8596,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9685,9 +8605,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9695,9 +8613,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9705,19 +8621,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9725,9 +8638,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9735,9 +8647,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9746,9 +8656,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9757,9 +8665,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9767,7 +8673,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -9777,10 +8691,9 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
             }
           },
           {
@@ -9789,9 +8702,35 @@
             "description": "Enable adaptive bitrate streaming.",
             "schema": {
               "type": "boolean",
-              "description": "Enable adaptive bitrate streaming.",
               "default": true
             }
+          },
+          {
+            "name": "enableTrickplay",
+            "in": "query",
+            "description": "Enable trickplay image playlists being added to master playlist.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Whether to always burn in subtitles when transcoding.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
           }
         ],
         "responses": {
@@ -9835,7 +8774,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -9844,9 +8782,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9854,9 +8790,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9864,19 +8798,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9884,9 +8815,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -9894,9 +8823,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9905,9 +8833,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9916,9 +8842,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -9927,8 +8851,7 @@
             "description": "The media version id, if playing an alternate version.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version."
+              "type": "string"
             }
           },
           {
@@ -9936,19 +8859,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -9956,9 +8876,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9966,9 +8884,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9976,9 +8892,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9986,9 +8900,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -9997,9 +8909,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10008,9 +8918,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10019,9 +8927,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10030,9 +8936,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10041,9 +8945,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10051,9 +8953,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -10061,9 +8961,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -10072,9 +8970,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -10083,9 +8979,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -10093,9 +8987,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10104,9 +8996,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -10115,9 +9005,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10126,9 +9014,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -10137,9 +9041,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10148,9 +9050,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10158,7 +9058,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -10167,9 +9078,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10178,9 +9087,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10188,9 +9095,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10198,9 +9103,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10208,9 +9111,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10219,9 +9120,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10230,9 +9129,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10240,9 +9137,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -10250,19 +9145,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -10270,9 +9162,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -10280,9 +9171,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -10291,9 +9180,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10302,9 +9189,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10312,7 +9197,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -10322,10 +9215,9 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
             }
           },
           {
@@ -10334,9 +9226,35 @@
             "description": "Enable adaptive bitrate streaming.",
             "schema": {
               "type": "boolean",
-              "description": "Enable adaptive bitrate streaming.",
               "default": true
             }
+          },
+          {
+            "name": "enableTrickplay",
+            "in": "query",
+            "description": "Enable trickplay image playlists being added to master playlist.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Whether to always burn in subtitles when transcoding.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
           }
         ],
         "responses": {
@@ -10405,7 +9323,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10425,8 +9344,7 @@
             "description": "The path.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The path."
+              "type": "string"
             }
           },
           {
@@ -10435,7 +9353,6 @@
             "description": "An optional filter to include or exclude files from the results. true/false.",
             "schema": {
               "type": "boolean",
-              "description": "An optional filter to include or exclude files from the results. true/false.",
               "default": false
             }
           },
@@ -10445,7 +9362,6 @@
             "description": "An optional filter to include or exclude folders from the results. true/false.",
             "schema": {
               "type": "boolean",
-              "description": "An optional filter to include or exclude folders from the results. true/false.",
               "default": false
             }
           }
@@ -10490,7 +9406,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10543,7 +9460,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10597,7 +9515,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10617,8 +9536,7 @@
             "description": "The path.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The path."
+              "type": "string"
             }
           }
         ],
@@ -10653,7 +9571,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10671,17 +9590,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ValidatePathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ValidatePathDto"
+                  }
+                ],
+                "description": "Validate path object."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ValidatePathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ValidatePathDto"
+                  }
+                ],
+                "description": "Validate path object."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ValidatePathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ValidatePathDto"
+                  }
+                ],
+                "description": "Validate path object."
               }
             }
           },
@@ -10721,7 +9655,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -10741,9 +9676,7 @@
             "description": "Optional. User id.",
             "schema": {
               "type": "string",
-              "description": "Optional. User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -10752,9 +9685,7 @@
             "description": "Optional. Parent id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Parent id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -10764,10 +9695,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -10777,10 +9706,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. Filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           }
         ],
@@ -10835,9 +9762,7 @@
             "description": "Optional. User id.",
             "schema": {
               "type": "string",
-              "description": "Optional. User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -10846,9 +9771,7 @@
             "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -10858,10 +9781,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -10869,9 +9790,7 @@
             "in": "query",
             "description": "Optional. Is item airing.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item airing.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10879,9 +9798,7 @@
             "in": "query",
             "description": "Optional. Is item movie.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item movie.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10889,9 +9806,7 @@
             "in": "query",
             "description": "Optional. Is item sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10899,9 +9814,7 @@
             "in": "query",
             "description": "Optional. Is item kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10909,9 +9822,7 @@
             "in": "query",
             "description": "Optional. Is item news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10919,9 +9830,7 @@
             "in": "query",
             "description": "Optional. Is item series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Is item series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -10929,9 +9838,7 @@
             "in": "query",
             "description": "Optional. Search recursive.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Search recursive.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -10986,9 +9893,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -10997,9 +9902,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11007,9 +9910,7 @@
             "in": "query",
             "description": "The search term.",
             "schema": {
-              "type": "string",
-              "description": "The search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11018,9 +9919,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -11031,9 +9930,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -11043,10 +9940,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -11056,10 +9951,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered in based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -11067,9 +9960,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -11078,9 +9969,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11091,9 +9980,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -11102,9 +9989,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -11112,9 +9997,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11122,9 +10005,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11132,9 +10013,29 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
+            }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Sort Order - Ascending,Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -11143,9 +10044,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -11154,7 +10053,6 @@
             "description": "Optional. Include total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Include total record count.",
               "default": true
             }
           }
@@ -11210,8 +10108,7 @@
             "description": "The genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The genre name."
+              "type": "string"
             }
           },
           {
@@ -11220,9 +10117,7 @@
             "description": "The user id.",
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -11277,8 +10172,7 @@
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           },
           {
@@ -11287,8 +10181,7 @@
             "description": "The segment id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The segment id."
+              "type": "string"
             }
           }
         ],
@@ -11321,8 +10214,7 @@
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           },
           {
@@ -11331,8 +10223,7 @@
             "description": "The segment id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The segment id."
+              "type": "string"
             }
           }
         ],
@@ -11365,8 +10256,7 @@
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           },
           {
@@ -11375,8 +10265,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           },
           {
@@ -11385,8 +10274,7 @@
             "description": "The segment id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The segment id."
+              "type": "string"
             }
           },
           {
@@ -11395,8 +10283,7 @@
             "description": "The segment container.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The segment container."
+              "type": "string"
             }
           }
         ],
@@ -11449,8 +10336,7 @@
             "description": "The video id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The video id."
+              "type": "string"
             }
           },
           {
@@ -11459,8 +10345,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           }
         ],
@@ -11504,20 +10389,18 @@
             "name": "deviceId",
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
+            "required": true,
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "playSessionId",
             "in": "query",
             "description": "The play session id.",
+            "required": true,
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -11555,8 +10438,7 @@
             "description": "Artist name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Artist name."
+              "type": "string"
             }
           },
           {
@@ -11565,7 +10447,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -11573,9 +10475,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11583,7 +10483,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -11592,9 +10504,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11603,9 +10513,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11614,9 +10522,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -11625,9 +10531,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11636,9 +10540,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11647,9 +10549,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11658,29 +10558,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -11689,9 +10585,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11699,9 +10593,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11709,9 +10601,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11721,7 +10611,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           }
@@ -11773,8 +10662,7 @@
             "description": "Artist name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Artist name."
+              "type": "string"
             }
           },
           {
@@ -11783,7 +10671,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -11791,9 +10699,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11801,7 +10707,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -11810,9 +10728,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11821,9 +10737,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11832,9 +10746,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -11843,9 +10755,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11854,9 +10764,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11865,9 +10773,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11876,29 +10782,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -11907,9 +10809,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -11917,9 +10817,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11927,9 +10825,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -11939,7 +10835,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           }
@@ -11979,6 +10874,246 @@
         }
       }
     },
+    "/Branding/Splashscreen": {
+      "get": {
+        "tags": [
+          "Image"
+        ],
+        "summary": "Generates or gets the splashscreen.",
+        "operationId": "GetSplashscreen",
+        "parameters": [
+          {
+            "name": "tag",
+            "in": "query",
+            "description": "Supply the cache tag from the item object to receive strong caching headers.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "format",
+            "in": "query",
+            "description": "Determines the output format of the image - original,gif,jpg,png.",
+            "schema": {
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "The maximum image width to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "The maximum image height to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "width",
+            "in": "query",
+            "description": "The fixed image width to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "height",
+            "in": "query",
+            "description": "The fixed image height to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "blur",
+            "in": "query",
+            "description": "Blur image.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "backgroundColor",
+            "in": "query",
+            "description": "Apply a background color for transparent images.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "foregroundLayer",
+            "in": "query",
+            "description": "Apply a foreground layer on top of the image.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "quality",
+            "in": "query",
+            "description": "Quality setting, from 0-100.",
+            "schema": {
+              "maximum": 100,
+              "minimum": 0,
+              "type": "integer",
+              "format": "int32",
+              "default": 90
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Splashscreen returned successfully.",
+            "content": {
+              "image/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          }
+        }
+      },
+      "post": {
+        "tags": [
+          "Image"
+        ],
+        "summary": "Uploads a custom splashscreen.\r\nThe body is expected to the image contents base64 encoded.",
+        "operationId": "UploadCustomSplashscreen",
+        "requestBody": {
+          "content": {
+            "image/*": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
+        "responses": {
+          "204": {
+            "description": "Successfully uploaded new splashscreen."
+          },
+          "400": {
+            "description": "Error reading MimeType from uploaded image.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "403": {
+            "description": "User does not have permission to upload splashscreen..",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "RequiresElevation"
+            ]
+          }
+        ]
+      },
+      "delete": {
+        "tags": [
+          "Image"
+        ],
+        "summary": "Delete a custom splashscreen.",
+        "operationId": "DeleteCustomSplashscreen",
+        "responses": {
+          "204": {
+            "description": "Successfully deleted the custom splashscreen."
+          },
+          "403": {
+            "description": "User does not have permission to delete splashscreen.."
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "RequiresElevation"
+            ]
+          }
+        ]
+      }
+    },
     "/Genres/{name}/Images/{imageType}": {
       "get": {
         "tags": [
@@ -11993,8 +11128,7 @@
             "description": "Genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Genre name."
+              "type": "string"
             }
           },
           {
@@ -12003,7 +11137,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -12011,9 +11165,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12021,7 +11173,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -12030,9 +11194,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12041,9 +11203,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12052,9 +11212,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -12063,9 +11221,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12074,9 +11230,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12085,9 +11239,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12096,29 +11248,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -12127,9 +11275,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12137,9 +11283,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12147,9 +11291,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12158,9 +11300,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -12211,8 +11351,7 @@
             "description": "Genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Genre name."
+              "type": "string"
             }
           },
           {
@@ -12221,7 +11360,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -12229,9 +11388,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12239,7 +11396,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -12248,9 +11417,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12259,9 +11426,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12270,9 +11435,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -12281,9 +11444,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12292,9 +11453,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12303,9 +11462,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12314,29 +11471,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -12345,9 +11498,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12355,9 +11506,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12365,9 +11514,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12376,9 +11523,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -12431,8 +11576,7 @@
             "description": "Genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Genre name."
+              "type": "string"
             }
           },
           {
@@ -12441,7 +11585,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -12451,7 +11615,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -12460,9 +11623,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12470,7 +11631,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -12479,9 +11652,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12490,9 +11661,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12501,9 +11670,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -12512,9 +11679,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12523,9 +11688,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12534,9 +11697,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12545,29 +11706,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -12576,9 +11733,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12586,9 +11741,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12596,9 +11749,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -12649,8 +11800,7 @@
             "description": "Genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Genre name."
+              "type": "string"
             }
           },
           {
@@ -12659,7 +11809,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -12669,7 +11839,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -12678,9 +11847,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12688,7 +11855,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -12697,9 +11876,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12708,9 +11885,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12719,9 +11894,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -12730,9 +11903,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12741,9 +11912,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12752,9 +11921,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12763,29 +11930,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -12794,9 +11957,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -12804,9 +11965,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -12814,9 +11973,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -12870,7 +12027,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -12956,7 +12112,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -12966,7 +12121,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -12975,9 +12150,7 @@
             "description": "The image index.",
             "schema": {
               "type": "integer",
-              "description": "The image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -13034,7 +12207,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13044,14 +12216,64 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           }
         ],
+        "requestBody": {
+          "content": {
+            "image/*": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
         "responses": {
           "204": {
             "description": "Image saved."
           },
+          "400": {
+            "description": "Bad Request",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "404": {
             "description": "Item not found.",
             "content": {
@@ -13101,7 +12323,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13111,7 +12332,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13120,9 +12361,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13131,9 +12370,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13142,9 +12379,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13153,9 +12388,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13164,9 +12397,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -13174,19 +12423,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13194,17 +12431,19 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Drawing.ImageFormat of the returned image.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -13213,9 +12452,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -13224,9 +12461,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13235,9 +12470,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13245,9 +12478,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13255,9 +12486,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13266,9 +12495,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -13320,7 +12547,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13330,7 +12556,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13339,9 +12585,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13350,9 +12594,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13361,9 +12603,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13372,9 +12612,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13383,9 +12621,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -13393,19 +12647,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13413,17 +12655,19 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Drawing.ImageFormat of the returned image.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -13432,9 +12676,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -13443,9 +12685,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13454,9 +12694,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13464,9 +12702,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13474,9 +12710,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13485,9 +12719,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -13541,7 +12773,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13551,7 +12782,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13561,7 +12812,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The image index.",
               "format": "int32"
             }
           }
@@ -13619,7 +12869,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13629,7 +12878,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13639,15 +12908,44 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "(Unused) Image index.",
               "format": "int32"
             }
           }
         ],
+        "requestBody": {
+          "content": {
+            "image/*": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
         "responses": {
           "204": {
             "description": "Image saved."
           },
+          "400": {
+            "description": "Bad Request",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "404": {
             "description": "Item not found.",
             "content": {
@@ -13697,7 +12995,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13707,7 +13004,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13717,7 +13034,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -13727,9 +13043,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13738,9 +13052,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13749,9 +13061,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13760,9 +13070,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13771,9 +13079,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -13781,19 +13105,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13801,17 +13113,19 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Drawing.ImageFormat of the returned image.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -13820,9 +13134,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -13831,9 +13143,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13842,9 +13152,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13852,9 +13160,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -13862,9 +13168,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -13916,7 +13220,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -13926,7 +13229,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -13936,7 +13259,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -13946,9 +13268,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13957,9 +13277,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13968,9 +13286,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13979,9 +13295,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -13990,9 +13304,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -14000,19 +13330,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14020,17 +13338,19 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Drawing.ImageFormat of the returned image.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -14039,9 +13359,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -14050,9 +13368,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14061,9 +13377,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14071,9 +13385,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14081,9 +13393,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -14137,7 +13447,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -14147,7 +13456,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -14157,7 +13486,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
               "format": "int32"
             }
           },
@@ -14168,7 +13496,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
               "format": "int32"
             }
           },
@@ -14178,9 +13505,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14189,9 +13514,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14200,9 +13523,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -14211,18 +13550,7 @@
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers."
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14231,17 +13559,20 @@
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ],
+              "description": "Enum ImageOutputFormat."
             }
           },
           {
@@ -14251,7 +13582,6 @@
             "required": true,
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
               "format": "double"
             }
           },
@@ -14262,7 +13592,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
               "format": "int32"
             }
           },
@@ -14272,9 +13601,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14282,9 +13609,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14292,9 +13617,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14304,7 +13627,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           }
@@ -14357,7 +13679,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -14367,7 +13688,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -14377,7 +13718,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
               "format": "int32"
             }
           },
@@ -14388,7 +13728,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
               "format": "int32"
             }
           },
@@ -14398,9 +13737,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14409,9 +13746,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14420,9 +13755,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillWidth",
+            "in": "query",
+            "description": "Width of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fillHeight",
+            "in": "query",
+            "description": "Height of box to fill.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -14431,18 +13782,7 @@
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers."
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14451,17 +13791,20 @@
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ],
+              "description": "Enum ImageOutputFormat."
             }
           },
           {
@@ -14471,7 +13814,6 @@
             "required": true,
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
               "format": "double"
             }
           },
@@ -14482,7 +13824,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
               "format": "int32"
             }
           },
@@ -14492,9 +13833,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14502,9 +13841,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14512,9 +13849,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14524,7 +13859,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           }
@@ -14579,7 +13913,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -14589,7 +13922,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -14599,7 +13952,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Old image index.",
               "format": "int32"
             }
           },
@@ -14607,9 +13959,9 @@
             "name": "newIndex",
             "in": "query",
             "description": "New image index.",
+            "required": true,
             "schema": {
               "type": "integer",
-              "description": "New image index.",
               "format": "int32"
             }
           }
@@ -14668,8 +14020,7 @@
             "description": "Music genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Music genre name."
+              "type": "string"
             }
           },
           {
@@ -14678,7 +14029,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -14686,9 +14057,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14696,7 +14065,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -14705,9 +14086,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14716,9 +14095,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14727,9 +14104,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -14738,9 +14113,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14749,9 +14122,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14760,9 +14131,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14771,29 +14140,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -14802,9 +14167,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14812,9 +14175,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14822,9 +14183,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14833,9 +14192,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -14886,8 +14243,7 @@
             "description": "Music genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Music genre name."
+              "type": "string"
             }
           },
           {
@@ -14896,7 +14252,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -14904,9 +14280,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -14914,7 +14288,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -14923,9 +14309,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14934,9 +14318,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14945,9 +14327,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -14956,9 +14336,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14967,9 +14345,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14978,9 +14354,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -14989,29 +14363,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -15020,9 +14390,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15030,9 +14398,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15040,9 +14406,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15051,9 +14415,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -15106,8 +14468,7 @@
             "description": "Music genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Music genre name."
+              "type": "string"
             }
           },
           {
@@ -15116,7 +14477,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -15126,7 +14507,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -15135,9 +14515,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15145,7 +14523,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -15154,9 +14544,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15165,9 +14553,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15176,9 +14562,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -15187,9 +14571,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15198,9 +14580,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15209,9 +14589,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15220,29 +14598,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -15251,9 +14625,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15261,9 +14633,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15271,9 +14641,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -15324,8 +14692,7 @@
             "description": "Music genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Music genre name."
+              "type": "string"
             }
           },
           {
@@ -15334,7 +14701,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -15344,7 +14731,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -15353,9 +14739,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15363,7 +14747,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -15372,9 +14768,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15383,9 +14777,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15394,9 +14786,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -15405,9 +14795,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15416,9 +14804,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15427,9 +14813,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15438,29 +14822,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -15469,9 +14849,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15479,9 +14857,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15489,9 +14865,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -15544,8 +14918,7 @@
             "description": "Person name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Person name."
+              "type": "string"
             }
           },
           {
@@ -15554,7 +14927,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -15562,9 +14955,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15572,7 +14963,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -15581,9 +14984,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15592,9 +14993,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15603,9 +15002,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -15614,9 +15011,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15625,9 +15020,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15636,9 +15029,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15647,29 +15038,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -15678,9 +15065,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15688,9 +15073,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15698,9 +15081,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15709,9 +15090,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -15762,8 +15141,7 @@
             "description": "Person name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Person name."
+              "type": "string"
             }
           },
           {
@@ -15772,7 +15150,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -15780,9 +15178,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15790,7 +15186,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -15799,9 +15207,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15810,9 +15216,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15821,9 +15225,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -15832,9 +15234,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15843,9 +15243,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15854,9 +15252,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15865,29 +15261,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -15896,9 +15288,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -15906,9 +15296,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15916,9 +15304,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -15927,9 +15313,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -15982,8 +15366,7 @@
             "description": "Person name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Person name."
+              "type": "string"
             }
           },
           {
@@ -15992,7 +15375,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -16002,7 +15405,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -16011,9 +15413,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16021,7 +15421,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -16030,9 +15442,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16041,9 +15451,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16052,9 +15460,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -16063,9 +15469,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16074,9 +15478,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16085,9 +15487,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16096,29 +15496,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -16127,9 +15523,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16137,9 +15531,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16147,9 +15539,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -16200,8 +15590,7 @@
             "description": "Person name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Person name."
+              "type": "string"
             }
           },
           {
@@ -16210,7 +15599,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -16220,7 +15629,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -16229,9 +15637,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16239,7 +15645,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -16248,9 +15666,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16259,9 +15675,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16270,9 +15684,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -16281,9 +15693,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16292,9 +15702,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16303,9 +15711,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16314,29 +15720,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -16345,9 +15747,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16355,9 +15755,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16365,9 +15763,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -16420,8 +15816,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -16430,7 +15825,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -16438,9 +15853,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16448,7 +15861,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -16457,9 +15882,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16468,9 +15891,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16479,9 +15900,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -16490,9 +15909,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16501,9 +15918,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16512,9 +15927,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16523,29 +15936,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -16554,9 +15963,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16564,9 +15971,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16574,9 +15979,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16585,9 +15988,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -16638,8 +16039,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -16648,7 +16048,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -16656,9 +16076,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16666,7 +16084,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -16675,9 +16105,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16686,9 +16114,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16697,9 +16123,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -16708,9 +16132,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16719,9 +16141,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16730,9 +16150,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16741,29 +16159,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -16772,9 +16186,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16782,9 +16194,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16792,9 +16202,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16803,9 +16211,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -16858,8 +16264,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -16868,7 +16273,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -16878,7 +16303,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -16887,9 +16311,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -16897,7 +16319,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -16906,9 +16340,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16917,9 +16349,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16928,9 +16358,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -16939,9 +16367,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16950,9 +16376,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16961,9 +16385,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -16972,29 +16394,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -17003,9 +16421,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17013,9 +16429,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17023,9 +16437,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -17076,8 +16488,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -17086,7 +16497,27 @@
             "description": "Image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -17096,7 +16527,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Image index.",
               "format": "int32"
             }
           },
@@ -17105,9 +16535,7 @@
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17115,7 +16543,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -17124,9 +16564,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17135,9 +16573,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17146,9 +16582,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -17157,9 +16591,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17168,9 +16600,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17179,9 +16609,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17190,29 +16618,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -17221,9 +16645,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17231,9 +16653,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17241,9 +16661,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -17282,7 +16700,7 @@
         }
       }
     },
-    "/Users/{userId}/Images/{imageType}": {
+    "/UserImage": {
       "post": {
         "tags": [
           "Image"
@@ -17292,40 +16710,48 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User Id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User Id.",
               "format": "uuid"
             }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "(Unused) Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "index",
-            "in": "query",
-            "description": "(Unused) Image index.",
-            "schema": {
-              "type": "integer",
-              "description": "(Unused) Image index.",
-              "format": "int32",
-              "nullable": true
-            }
           }
         ],
+        "requestBody": {
+          "content": {
+            "image/*": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
         "responses": {
           "204": {
             "description": "Image updated."
           },
+          "400": {
+            "description": "Bad Request",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "403": {
             "description": "User does not have permission to delete the image.",
             "content": {
@@ -17346,6 +16772,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           }
@@ -17367,34 +16813,12 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User Id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User Id.",
               "format": "uuid"
             }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "(Unused) Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "index",
-            "in": "query",
-            "description": "(Unused) Image index.",
-            "schema": {
-              "type": "integer",
-              "description": "(Unused) Image index.",
-              "format": "int32",
-              "nullable": true
-            }
           }
         ],
         "responses": {
@@ -17442,32 +16866,19 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
           {
             "name": "tag",
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17475,7 +16886,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -17484,9 +16907,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17495,9 +16916,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17506,9 +16925,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -17517,9 +16934,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17528,9 +16943,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17539,9 +16952,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17550,29 +16961,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -17581,9 +16988,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17591,9 +16996,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17601,9 +17004,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17612,9 +17013,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -17630,6 +17029,26 @@
               }
             }
           },
+          "400": {
+            "description": "User id not provided.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "404": {
             "description": "Item not found.",
             "content": {
@@ -17661,32 +17080,19 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
           {
             "name": "tag",
             "in": "query",
             "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17694,7 +17100,19 @@
             "in": "query",
             "description": "Determines the output format of the image - original,gif,jpg,png.",
             "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
+              "enum": [
+                "Bmp",
+                "Gif",
+                "Jpg",
+                "Png",
+                "Webp",
+                "Svg"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageFormat"
+                }
+              ]
             }
           },
           {
@@ -17703,9 +17121,7 @@
             "description": "The maximum image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17714,9 +17130,7 @@
             "description": "The maximum image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17725,9 +17139,7 @@
             "description": "Optional. Percent to render for the percent played overlay.",
             "schema": {
               "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -17736,9 +17148,7 @@
             "description": "Optional. Unplayed count overlay to render.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17747,9 +17157,7 @@
             "description": "The fixed image width to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17758,9 +17166,7 @@
             "description": "The fixed image height to return.",
             "schema": {
               "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17769,29 +17175,25 @@
             "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
-            "name": "cropWhitespace",
+            "name": "fillWidth",
             "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
+            "description": "Width of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
-            "name": "addPlayedIndicator",
+            "name": "fillHeight",
             "in": "query",
-            "description": "Optional. Add a played indicator.",
+            "description": "Height of box to fill.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -17800,9 +17202,7 @@
             "description": "Optional. Blur image.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -17810,9 +17210,7 @@
             "in": "query",
             "description": "Optional. Apply a background color for transparent images.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17820,9 +17218,7 @@
             "in": "query",
             "description": "Optional. Apply a foreground layer on top of the image.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -17831,9 +17227,7 @@
             "description": "Image index.",
             "schema": {
               "type": "integer",
-              "description": "Image index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -17849,6 +17243,26 @@
               }
             }
           },
+          "400": {
+            "description": "User id not provided.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "404": {
             "description": "Item not found.",
             "content": {
@@ -17872,980 +17286,21 @@
         }
       }
     },
-    "/Users/{userId}/Images/{imageType}/{imageIndex}": {
-      "get": {
-        "tags": [
-          "Image"
-        ],
-        "summary": "Get user profile image.",
-        "operationId": "GetUserImageByIndex",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "imageIndex",
-            "in": "path",
-            "description": "Image index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "Image index.",
-              "format": "int32"
-            }
-          },
-          {
-            "name": "tag",
-            "in": "query",
-            "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "format",
-            "in": "query",
-            "description": "Determines the output format of the image - original,gif,jpg,png.",
-            "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "maxWidth",
-            "in": "query",
-            "description": "The maximum image width to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxHeight",
-            "in": "query",
-            "description": "The maximum image height to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "percentPlayed",
-            "in": "query",
-            "description": "Optional. Percent to render for the percent played overlay.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
-            }
-          },
-          {
-            "name": "unplayedCount",
-            "in": "query",
-            "description": "Optional. Unplayed count overlay to render.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "width",
-            "in": "query",
-            "description": "The fixed image width to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "height",
-            "in": "query",
-            "description": "The fixed image height to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "quality",
-            "in": "query",
-            "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "blur",
-            "in": "query",
-            "description": "Optional. Blur image.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "backgroundColor",
-            "in": "query",
-            "description": "Optional. Apply a background color for transparent images.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "foregroundLayer",
-            "in": "query",
-            "description": "Optional. Apply a foreground layer on top of the image.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Image stream returned.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Item not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      },
-      "head": {
-        "tags": [
-          "Image"
-        ],
-        "summary": "Get user profile image.",
-        "operationId": "HeadUserImageByIndex",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "imageIndex",
-            "in": "path",
-            "description": "Image index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "Image index.",
-              "format": "int32"
-            }
-          },
-          {
-            "name": "tag",
-            "in": "query",
-            "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Supply the cache tag from the item object to receive strong caching headers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "format",
-            "in": "query",
-            "description": "Determines the output format of the image - original,gif,jpg,png.",
-            "schema": {
-              "$ref": "#/components/schemas/ImageFormat"
-            }
-          },
-          {
-            "name": "maxWidth",
-            "in": "query",
-            "description": "The maximum image width to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The maximum image width to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxHeight",
-            "in": "query",
-            "description": "The maximum image height to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The maximum image height to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "percentPlayed",
-            "in": "query",
-            "description": "Optional. Percent to render for the percent played overlay.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. Percent to render for the percent played overlay.",
-              "format": "double",
-              "nullable": true
-            }
-          },
-          {
-            "name": "unplayedCount",
-            "in": "query",
-            "description": "Optional. Unplayed count overlay to render.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Unplayed count overlay to render.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "width",
-            "in": "query",
-            "description": "The fixed image width to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The fixed image width to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "height",
-            "in": "query",
-            "description": "The fixed image height to return.",
-            "schema": {
-              "type": "integer",
-              "description": "The fixed image height to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "quality",
-            "in": "query",
-            "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Quality setting, from 0-100. Defaults to 90 and should suffice in most cases.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cropWhitespace",
-            "in": "query",
-            "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Specify if whitespace should be cropped out of the image. True/False. If unspecified, whitespace will be cropped from logos and clear art.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "addPlayedIndicator",
-            "in": "query",
-            "description": "Optional. Add a played indicator.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Add a played indicator.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "blur",
-            "in": "query",
-            "description": "Optional. Blur image.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Blur image.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "backgroundColor",
-            "in": "query",
-            "description": "Optional. Apply a background color for transparent images.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Apply a background color for transparent images.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "foregroundLayer",
-            "in": "query",
-            "description": "Optional. Apply a foreground layer on top of the image.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Apply a foreground layer on top of the image.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Image stream returned.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Item not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Users/{userId}/Images/{imageType}/{index}": {
-      "post": {
-        "tags": [
-          "Image"
-        ],
-        "summary": "Sets the user image.",
-        "operationId": "PostUserImageByIndex",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User Id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User Id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "(Unused) Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "index",
-            "in": "path",
-            "description": "(Unused) Image index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "(Unused) Image index.",
-              "format": "int32"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Image updated."
-          },
-          "403": {
-            "description": "User does not have permission to delete the image.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      },
-      "delete": {
-        "tags": [
-          "Image"
-        ],
-        "summary": "Delete the user's image.",
-        "operationId": "DeleteUserImageByIndex",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User Id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User Id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "imageType",
-            "in": "path",
-            "description": "(Unused) Image type.",
-            "required": true,
-            "schema": {
-              "$ref": "#/components/schemas/ImageType"
-            }
-          },
-          {
-            "name": "index",
-            "in": "path",
-            "description": "(Unused) Image index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "(Unused) Image index.",
-              "format": "int32"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Image deleted."
-          },
-          "403": {
-            "description": "User does not have permission to delete the image.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Images/General": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get all general images.",
-        "operationId": "GetGeneralImages",
-        "responses": {
-          "200": {
-            "description": "Retrieved list of images.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Images/General/{name}/{type}": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get General Image.",
-        "operationId": "GetGeneralImage",
-        "parameters": [
-          {
-            "name": "name",
-            "in": "path",
-            "description": "The name of the image.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The name of the image."
-            }
-          },
-          {
-            "name": "type",
-            "in": "path",
-            "description": "Image Type (primary, backdrop, logo, etc).",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Image Type (primary, backdrop, logo, etc)."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Image stream retrieved.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Image not found.",
-            "content": {
-              "application/octet-stream": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Images/MediaInfo": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get all media info images.",
-        "operationId": "GetMediaInfoImages",
-        "responses": {
-          "200": {
-            "description": "Image list retrieved.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Images/MediaInfo/{theme}/{name}": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get media info image.",
-        "operationId": "GetMediaInfoImage",
-        "parameters": [
-          {
-            "name": "theme",
-            "in": "path",
-            "description": "The theme to get the image from.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The theme to get the image from."
-            }
-          },
-          {
-            "name": "name",
-            "in": "path",
-            "description": "The name of the image.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The name of the image."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Image stream retrieved.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Image not found.",
-            "content": {
-              "application/octet-stream": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Images/Ratings": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get all general images.",
-        "operationId": "GetRatingImages",
-        "responses": {
-          "200": {
-            "description": "Retrieved list of images.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/ImageByNameInfo"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Images/Ratings/{theme}/{name}": {
-      "get": {
-        "tags": [
-          "ImageByName"
-        ],
-        "summary": "Get rating image.",
-        "operationId": "GetRatingImage",
-        "parameters": [
-          {
-            "name": "theme",
-            "in": "path",
-            "description": "The theme to get the image from.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The theme to get the image from."
-            }
-          },
-          {
-            "name": "name",
-            "in": "path",
-            "description": "The name of the image.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The name of the image."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Image stream retrieved.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Image not found.",
-            "content": {
-              "application/octet-stream": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Albums/{id}/InstantMix": {
+    "/Albums/{itemId}/InstantMix": {
       "get": {
         "tags": [
           "InstantMix"
         ],
-        "summary": "Creates an instant playlist based on a given song.",
+        "summary": "Creates an instant playlist based on a given album.",
         "operationId": "GetInstantMixFromAlbum",
         "parameters": [
           {
-            "name": "id",
+            "name": "itemId",
             "in": "path",
             "description": "The item id.",
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -18855,9 +17310,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -18866,9 +17319,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -18879,9 +17330,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -18889,9 +17338,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -18899,9 +17346,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -18910,9 +17355,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -18923,9 +17366,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -18950,6 +17391,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -18966,22 +17427,21 @@
         ]
       }
     },
-    "/Artists/{id}/InstantMix": {
+    "/Artists/{itemId}/InstantMix": {
       "get": {
         "tags": [
           "InstantMix"
         ],
-        "summary": "Creates an instant playlist based on a given song.",
+        "summary": "Creates an instant playlist based on a given artist.",
         "operationId": "GetInstantMixFromArtists",
         "parameters": [
           {
-            "name": "id",
+            "name": "itemId",
             "in": "path",
             "description": "The item id.",
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -18991,9 +17451,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -19002,9 +17460,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19015,9 +17471,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -19025,9 +17479,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19035,9 +17487,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19046,9 +17496,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19059,9 +17507,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -19086,6 +17532,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -19102,22 +17568,163 @@
         ]
       }
     },
-    "/Items/{id}/InstantMix": {
+    "/Artists/InstantMix": {
       "get": {
         "tags": [
           "InstantMix"
         ],
-        "summary": "Creates an instant playlist based on a given song.",
+        "summary": "Creates an instant playlist based on a given artist.",
+        "operationId": "GetInstantMixFromArtists2",
+        "parameters": [
+          {
+            "name": "id",
+            "in": "query",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "Optional. Filter by user id, and attach user data.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Optional. The maximum number of records to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fields",
+            "in": "query",
+            "description": "Optional. Specify additional fields of information to return in the output.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemFields"
+              }
+            }
+          },
+          {
+            "name": "enableImages",
+            "in": "query",
+            "description": "Optional. Include image information in output.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "enableUserData",
+            "in": "query",
+            "description": "Optional. Include user data.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "imageTypeLimit",
+            "in": "query",
+            "description": "Optional. The max number of images to return, per image type.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "enableImageTypes",
+            "in": "query",
+            "description": "Optional. The image types to include in the output.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ImageType"
+              }
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Instant playlist returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "deprecated": true,
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Items/{itemId}/InstantMix": {
+      "get": {
+        "tags": [
+          "InstantMix"
+        ],
+        "summary": "Creates an instant playlist based on a given item.",
         "operationId": "GetInstantMixFromItem",
         "parameters": [
           {
-            "name": "id",
+            "name": "itemId",
             "in": "path",
             "description": "The item id.",
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -19127,9 +17734,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -19138,9 +17743,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19151,9 +17754,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -19161,9 +17762,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19171,9 +17770,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19182,9 +17779,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19195,9 +17790,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -19222,138 +17815,22 @@
               }
             }
           },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/MusicGenres/{id}/InstantMix": {
-      "get": {
-        "tags": [
-          "InstantMix"
-        ],
-        "summary": "Creates an instant playlist based on a given song.",
-        "operationId": "GetInstantMixFromMusicGenres",
-        "parameters": [
-          {
-            "name": "id",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "userId",
-            "in": "query",
-            "description": "Optional. Filter by user id, and attach user data.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
-            }
-          },
-          {
-            "name": "limit",
-            "in": "query",
-            "description": "Optional. The maximum number of records to return.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "fields",
-            "in": "query",
-            "description": "Optional. Specify additional fields of information to return in the output.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableImages",
-            "in": "query",
-            "description": "Optional. Include image information in output.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableUserData",
-            "in": "query",
-            "description": "Optional. Include user data.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "imageTypeLimit",
-            "in": "query",
-            "description": "Optional. The max number of images to return, per image type.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableImageTypes",
-            "in": "query",
-            "description": "Optional. The image types to include in the output.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Instant playlist returned.",
+          "404": {
+            "description": "Item not found.",
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/ProblemDetails"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/ProblemDetails"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/ProblemDetails"
                 }
               }
             }
@@ -19379,8 +17856,8 @@
         "tags": [
           "InstantMix"
         ],
-        "summary": "Creates an instant playlist based on a given song.",
-        "operationId": "GetInstantMixFromMusicGenre",
+        "summary": "Creates an instant playlist based on a given genre.",
+        "operationId": "GetInstantMixFromMusicGenreByName",
         "parameters": [
           {
             "name": "name",
@@ -19388,8 +17865,7 @@
             "description": "The genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The genre name."
+              "type": "string"
             }
           },
           {
@@ -19398,9 +17874,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -19409,9 +17883,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19422,9 +17894,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -19432,9 +17902,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19442,9 +17910,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19453,9 +17919,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19466,9 +17930,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -19509,22 +17971,21 @@
         ]
       }
     },
-    "/Playlists/{id}/InstantMix": {
+    "/MusicGenres/InstantMix": {
       "get": {
         "tags": [
           "InstantMix"
         ],
-        "summary": "Creates an instant playlist based on a given song.",
-        "operationId": "GetInstantMixFromPlaylist",
+        "summary": "Creates an instant playlist based on a given genre.",
+        "operationId": "GetInstantMixFromMusicGenreById",
         "parameters": [
           {
             "name": "id",
-            "in": "path",
+            "in": "query",
             "description": "The item id.",
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -19534,9 +17995,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -19545,9 +18004,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19558,9 +18015,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -19568,9 +18023,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19578,9 +18031,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19589,9 +18040,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19602,9 +18051,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -19629,6 +18076,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -19645,7 +18112,148 @@
         ]
       }
     },
-    "/Songs/{id}/InstantMix": {
+    "/Playlists/{itemId}/InstantMix": {
+      "get": {
+        "tags": [
+          "InstantMix"
+        ],
+        "summary": "Creates an instant playlist based on a given playlist.",
+        "operationId": "GetInstantMixFromPlaylist",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "Optional. Filter by user id, and attach user data.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "limit",
+            "in": "query",
+            "description": "Optional. The maximum number of records to return.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "fields",
+            "in": "query",
+            "description": "Optional. Specify additional fields of information to return in the output.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemFields"
+              }
+            }
+          },
+          {
+            "name": "enableImages",
+            "in": "query",
+            "description": "Optional. Include image information in output.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "enableUserData",
+            "in": "query",
+            "description": "Optional. Include user data.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "imageTypeLimit",
+            "in": "query",
+            "description": "Optional. The max number of images to return, per image type.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "enableImageTypes",
+            "in": "query",
+            "description": "Optional. The image types to include in the output.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ImageType"
+              }
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Instant playlist returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Songs/{itemId}/InstantMix": {
       "get": {
         "tags": [
           "InstantMix"
@@ -19654,13 +18262,12 @@
         "operationId": "GetInstantMixFromSong",
         "parameters": [
           {
-            "name": "id",
+            "name": "itemId",
             "in": "path",
             "description": "The item id.",
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -19670,9 +18277,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -19681,9 +18286,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19694,9 +18297,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -19704,9 +18305,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19714,9 +18313,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -19725,9 +18322,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -19738,9 +18333,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -19765,6 +18358,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -19796,7 +18409,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -19883,7 +18495,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -19893,7 +18504,6 @@
             "description": "Optional. Whether or not to replace all images. Default: True.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Whether or not to replace all images. Default: True.",
               "default": true
             }
           }
@@ -19903,17 +18513,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoteSearchResult"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoteSearchResult"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoteSearchResult"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoteSearchResult"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoteSearchResult"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoteSearchResult"
+                  }
+                ]
               }
             }
           },
@@ -19923,6 +18545,26 @@
           "204": {
             "description": "Item metadata refreshed."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -19952,17 +18594,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BookInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20026,17 +18680,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BoxSetInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20088,63 +18754,6 @@
         ]
       }
     },
-    "/Items/RemoteSearch/Image": {
-      "get": {
-        "tags": [
-          "ItemLookup"
-        ],
-        "summary": "Gets a remote image.",
-        "operationId": "GetRemoteSearchImage",
-        "parameters": [
-          {
-            "name": "imageUrl",
-            "in": "query",
-            "description": "The image url.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The image url."
-            }
-          },
-          {
-            "name": "providerName",
-            "in": "query",
-            "description": "The provider name.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The provider name."
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Remote image retrieved.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
     "/Items/RemoteSearch/Movie": {
       "post": {
         "tags": [
@@ -20157,17 +18766,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovieInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20231,17 +18852,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AlbumInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20305,17 +18938,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ArtistInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20379,17 +19024,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MusicVideoInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20453,17 +19110,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PersonLookupInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20528,17 +19197,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20602,17 +19283,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TrailerInfoRemoteSearchQuery"
+                  }
+                ]
               }
             }
           },
@@ -20670,7 +19363,7 @@
           "ItemRefresh"
         ],
         "summary": "Refreshes metadata for an item.",
-        "operationId": "Post",
+        "operationId": "RefreshItem",
         "parameters": [
           {
             "name": "itemId",
@@ -20679,7 +19372,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -20688,7 +19380,18 @@
             "in": "query",
             "description": "(Optional) Specifies the metadata refresh mode.",
             "schema": {
-              "$ref": "#/components/schemas/MetadataRefreshMode"
+              "enum": [
+                "None",
+                "ValidationOnly",
+                "Default",
+                "FullRefresh"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/MetadataRefreshMode"
+                }
+              ],
+              "default": "None"
             }
           },
           {
@@ -20696,7 +19399,18 @@
             "in": "query",
             "description": "(Optional) Specifies the image refresh mode.",
             "schema": {
-              "$ref": "#/components/schemas/MetadataRefreshMode"
+              "enum": [
+                "None",
+                "ValidationOnly",
+                "Default",
+                "FullRefresh"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/MetadataRefreshMode"
+                }
+              ],
+              "default": "None"
             }
           },
           {
@@ -20705,7 +19419,6 @@
             "description": "(Optional) Determines if metadata should be replaced. Only applicable if mode is FullRefresh.",
             "schema": {
               "type": "boolean",
-              "description": "(Optional) Determines if metadata should be replaced. Only applicable if mode is FullRefresh.",
               "default": false
             }
           },
@@ -20715,7 +19428,15 @@
             "description": "(Optional) Determines if images should be replaced. Only applicable if mode is FullRefresh.",
             "schema": {
               "type": "boolean",
-              "description": "(Optional) Determines if images should be replaced. Only applicable if mode is FullRefresh.",
+              "default": false
+            }
+          },
+          {
+            "name": "regenerateTrickplay",
+            "in": "query",
+            "description": "(Optional) Determines if trickplay images should be replaced. Only applicable if mode is FullRefresh.",
+            "schema": {
+              "type": "boolean",
               "default": false
             }
           }
@@ -20754,7 +19475,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -20771,12 +19492,10 @@
           {
             "name": "userId",
             "in": "query",
-            "description": "The user id supplied as query parameter.",
+            "description": "The user id supplied as query parameter; this is required when not using an API key.",
             "schema": {
               "type": "string",
-              "description": "The user id supplied as query parameter.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -20784,9 +19503,7 @@
             "in": "query",
             "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -20794,9 +19511,7 @@
             "in": "query",
             "description": "Optional filter by items with theme songs.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme songs.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20804,9 +19519,7 @@
             "in": "query",
             "description": "Optional filter by items with theme videos.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme videos.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20814,9 +19527,7 @@
             "in": "query",
             "description": "Optional filter by items with subtitles.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with subtitles.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20824,9 +19535,7 @@
             "in": "query",
             "description": "Optional filter by items with special features.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with special features.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20834,9 +19543,7 @@
             "in": "query",
             "description": "Optional filter by items with trailers.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with trailers.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20845,8 +19552,16 @@
             "description": "Optional. Return items that are siblings of a supplied item.",
             "schema": {
               "type": "string",
-              "description": "Optional. Return items that are siblings of a supplied item.",
-              "nullable": true
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "indexNumber",
+            "in": "query",
+            "description": "Optional filter by index number.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -20855,9 +19570,7 @@
             "description": "Optional filter by parent index number.",
             "schema": {
               "type": "integer",
-              "description": "Optional filter by parent index number.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -20865,9 +19578,7 @@
             "in": "query",
             "description": "Optional filter by items that have or do not have a parental rating.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have or do not have a parental rating.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20875,9 +19586,7 @@
             "in": "query",
             "description": "Optional filter by items that are HD or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are HD or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20885,9 +19594,7 @@
             "in": "query",
             "description": "Optional filter by items that are 4K or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 4K or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20898,9 +19605,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on LocationType. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -20911,9 +19616,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on the LocationType. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -20921,9 +19624,7 @@
             "in": "query",
             "description": "Optional filter by items that are missing episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are missing episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20931,9 +19632,7 @@
             "in": "query",
             "description": "Optional filter by items that are unaired episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are unaired episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -20942,9 +19641,7 @@
             "description": "Optional filter by minimum community rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum community rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -20953,9 +19650,7 @@
             "description": "Optional filter by minimum critic rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum critic rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -20964,9 +19659,7 @@
             "description": "Optional. The minimum premiere date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -20975,9 +19668,7 @@
             "description": "Optional. The minimum last saved date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum last saved date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -20986,9 +19677,7 @@
             "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -20997,9 +19686,7 @@
             "description": "Optional. The maximum premiere date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The maximum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -21007,39 +19694,71 @@
             "in": "query",
             "description": "Optional filter by items that have an overview or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an overview or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasImdbId",
             "in": "query",
-            "description": "Optional filter by items that have an imdb id or not.",
+            "description": "Optional filter by items that have an IMDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an imdb id or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasTmdbId",
             "in": "query",
-            "description": "Optional filter by items that have a tmdb id or not.",
+            "description": "Optional filter by items that have a TMDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tmdb id or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasTvdbId",
             "in": "query",
-            "description": "Optional filter by items that have a tvdb id or not.",
+            "description": "Optional filter by items that have a TVDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tvdb id or not.",
-              "nullable": true
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isMovie",
+            "in": "query",
+            "description": "Optional filter for live tv movies.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isSeries",
+            "in": "query",
+            "description": "Optional filter for live tv series.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isNews",
+            "in": "query",
+            "description": "Optional filter for live tv news.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isKids",
+            "in": "query",
+            "description": "Optional filter for live tv kids.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isSports",
+            "in": "query",
+            "description": "Optional filter for live tv sports.",
+            "schema": {
+              "type": "boolean"
             }
           },
           {
@@ -21051,9 +19770,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered by excluding item ids. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21062,9 +19779,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21073,9 +19788,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21083,9 +19796,7 @@
             "in": "query",
             "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21093,19 +19804,18 @@
             "in": "query",
             "description": "Optional. Filter based on a search term.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter based on a search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "sortOrder",
             "in": "query",
-            "description": "Sort Order - Ascending,Descending.",
+            "description": "Sort Order - Ascending, Descending.",
             "schema": {
-              "type": "string",
-              "description": "Sort Order - Ascending,Descending.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -21114,9 +19824,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -21127,9 +19835,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21139,10 +19845,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -21152,10 +19856,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -21166,9 +19868,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply. This allows multiple, comma delimited. Options: IsFolder, IsNotFolder, IsUnplayed, IsPlayed, IsFavorite, IsResumable, Likes, Dislikes.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21176,9 +19876,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21188,10 +19886,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -21202,9 +19898,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. If specified, results will be filtered based on those containing image types. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21212,9 +19906,10 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -21222,9 +19917,7 @@
             "in": "query",
             "description": "Optional filter by items that are played, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are played, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21235,9 +19928,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21248,9 +19939,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21261,9 +19950,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21275,9 +19962,7 @@
               "items": {
                 "type": "integer",
                 "format": "int32"
-              },
-              "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21285,9 +19970,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21296,9 +19979,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21309,9 +19990,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21319,9 +19998,7 @@
             "in": "query",
             "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
             "schema": {
-              "type": "string",
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -21333,9 +20010,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21346,9 +20021,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21359,9 +20032,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21372,9 +20043,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on artists. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21386,9 +20055,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on artist id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21400,9 +20067,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21414,9 +20079,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified album artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21428,9 +20091,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified contributing artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21441,9 +20102,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on album. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21455,9 +20114,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on album id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21469,9 +20126,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specific items are needed, specify a list of item id's to retrieve. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21482,9 +20137,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/VideoType"
-              },
-              "description": "Optional filter by VideoType (videofile, dvd, bluray, iso). Allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21492,9 +20145,7 @@
             "in": "query",
             "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -21502,9 +20153,7 @@
             "in": "query",
             "description": "Optional filter by items that are locked.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are locked.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21512,9 +20161,7 @@
             "in": "query",
             "description": "Optional filter by items that are placeholders.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are placeholders.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21522,9 +20169,7 @@
             "in": "query",
             "description": "Optional filter by items that have official ratings.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have official ratings.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21532,9 +20177,7 @@
             "in": "query",
             "description": "Whether or not to hide items behind their boxsets.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to hide items behind their boxsets.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21543,9 +20186,7 @@
             "description": "Optional. Filter by the minimum width of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the minimum width of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21554,9 +20195,7 @@
             "description": "Optional. Filter by the minimum height of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the minimum height of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21565,9 +20204,7 @@
             "description": "Optional. Filter by the maximum width of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the maximum width of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21576,9 +20213,7 @@
             "description": "Optional. Filter by the maximum height of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the maximum height of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -21586,9 +20221,7 @@
             "in": "query",
             "description": "Optional filter by items that are 3D, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 3D, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -21599,9 +20232,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/SeriesStatus"
-              },
-              "description": "Optional filter by Series Status. Allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21609,9 +20240,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -21619,9 +20248,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -21629,9 +20256,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -21643,9 +20268,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21657,9 +20280,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -21668,7 +20289,6 @@
             "description": "Optional. Enable the total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Enable the total record count.",
               "default": true
             }
           },
@@ -21678,9 +20298,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           }
         ],
@@ -21736,9 +20354,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The item ids.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -21766,6 +20382,26 @@
               }
             }
           },
+          "404": {
+            "description": "Not Found",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "403": {
             "description": "Forbidden"
           }
@@ -21779,947 +20415,190 @@
         ]
       }
     },
-    "/Users/{userId}/Items": {
+    "/UserItems/{itemId}/UserData": {
       "get": {
         "tags": [
           "Items"
         ],
-        "summary": "Gets items based on a query.",
-        "operationId": "GetItemsByUserId",
+        "summary": "Get Item User Data.",
+        "operationId": "GetItemUserData",
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
-            "description": "The user id supplied as query parameter.",
-            "required": true,
+            "in": "query",
+            "description": "The user id.",
             "schema": {
               "type": "string",
-              "description": "The user id supplied as query parameter.",
               "format": "uuid"
             }
           },
           {
-            "name": "maxOfficialRating",
-            "in": "query",
-            "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
             "schema": {
               "type": "string",
-              "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasThemeSong",
-            "in": "query",
-            "description": "Optional filter by items with theme songs.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme songs.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasThemeVideo",
-            "in": "query",
-            "description": "Optional filter by items with theme videos.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme videos.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasSubtitles",
-            "in": "query",
-            "description": "Optional filter by items with subtitles.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with subtitles.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasSpecialFeature",
-            "in": "query",
-            "description": "Optional filter by items with special features.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with special features.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasTrailer",
-            "in": "query",
-            "description": "Optional filter by items with trailers.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with trailers.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "adjacentTo",
-            "in": "query",
-            "description": "Optional. Return items that are siblings of a supplied item.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Return items that are siblings of a supplied item.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "parentIndexNumber",
-            "in": "query",
-            "description": "Optional filter by parent index number.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional filter by parent index number.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasParentalRating",
-            "in": "query",
-            "description": "Optional filter by items that have or do not have a parental rating.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have or do not have a parental rating.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isHd",
-            "in": "query",
-            "description": "Optional filter by items that are HD or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are HD or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "is4K",
-            "in": "query",
-            "description": "Optional filter by items that are 4K or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 4K or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "locationTypes",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on LocationType. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on LocationType. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "excludeLocationTypes",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on the LocationType. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on the LocationType. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isMissing",
-            "in": "query",
-            "description": "Optional filter by items that are missing episodes or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are missing episodes or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isUnaired",
-            "in": "query",
-            "description": "Optional filter by items that are unaired episodes or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are unaired episodes or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minCommunityRating",
-            "in": "query",
-            "description": "Optional filter by minimum community rating.",
-            "schema": {
-              "type": "number",
-              "description": "Optional filter by minimum community rating.",
-              "format": "double",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minCriticRating",
-            "in": "query",
-            "description": "Optional filter by minimum critic rating.",
-            "schema": {
-              "type": "number",
-              "description": "Optional filter by minimum critic rating.",
-              "format": "double",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minPremiereDate",
-            "in": "query",
-            "description": "Optional. The minimum premiere date. Format = ISO.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The minimum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minDateLastSaved",
-            "in": "query",
-            "description": "Optional. The minimum last saved date. Format = ISO.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The minimum last saved date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minDateLastSavedForUser",
-            "in": "query",
-            "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxPremiereDate",
-            "in": "query",
-            "description": "Optional. The maximum premiere date. Format = ISO.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The maximum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasOverview",
-            "in": "query",
-            "description": "Optional filter by items that have an overview or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an overview or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasImdbId",
-            "in": "query",
-            "description": "Optional filter by items that have an imdb id or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an imdb id or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasTmdbId",
-            "in": "query",
-            "description": "Optional filter by items that have a tmdb id or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tmdb id or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasTvdbId",
-            "in": "query",
-            "description": "Optional filter by items that have a tvdb id or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tvdb id or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "excludeItemIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered by exxcluding item ids. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered by exxcluding item ids. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "startIndex",
-            "in": "query",
-            "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "limit",
-            "in": "query",
-            "description": "Optional. The maximum number of records to return.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "recursive",
-            "in": "query",
-            "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
-            "schema": {
-              "type": "boolean",
-              "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "searchTerm",
-            "in": "query",
-            "description": "Optional. Filter based on a search term.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Filter based on a search term.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "sortOrder",
-            "in": "query",
-            "description": "Sort Order - Ascending,Descending.",
-            "schema": {
-              "type": "string",
-              "description": "Sort Order - Ascending,Descending.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "parentId",
-            "in": "query",
-            "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-            "schema": {
-              "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
-            }
-          },
-          {
-            "name": "fields",
-            "in": "query",
-            "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimeted. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimeted. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "excludeItemTypes",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "includeItemTypes",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "filters",
-            "in": "query",
-            "description": "Optional. Specify additional filters to apply. This allows multiple, comma delimeted. Options: IsFolder, IsNotFolder, IsUnplayed, IsPlayed, IsFavorite, IsResumable, Likes, Dislikes.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply. This allows multiple, comma delimeted. Options: IsFolder, IsNotFolder, IsUnplayed, IsPlayed, IsFavorite, IsResumable, Likes, Dislikes.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isFavorite",
-            "in": "query",
-            "description": "Optional filter by items that are marked as favorite, or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "mediaTypes",
-            "in": "query",
-            "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "imageTypes",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on those containing image types. This allows multiple, comma delimited.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. If specified, results will be filtered based on those containing image types. This allows multiple, comma delimited.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "sortBy",
-            "in": "query",
-            "description": "Optional. Specify one or more sort orders, comma delimeted. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimeted. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isPlayed",
-            "in": "query",
-            "description": "Optional filter by items that are played, or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are played, or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "genres",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "officialRatings",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "tags",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "years",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "integer",
-                "format": "int32"
-              },
-              "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableUserData",
-            "in": "query",
-            "description": "Optional, include user data.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "imageTypeLimit",
-            "in": "query",
-            "description": "Optional, the max number of images to return, per image type.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableImageTypes",
-            "in": "query",
-            "description": "Optional. The image types to include in the output.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "person",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "personIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered to include only those containing the specified person id.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "personTypes",
-            "in": "query",
-            "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "studios",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "artists",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on artists. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on artists. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "excludeArtistIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on artist id. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on artist id. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "artistIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered to include only those containing the specified artist id.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified artist id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "albumArtistIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered to include only those containing the specified album artist id.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified album artist id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "contributingArtistIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered to include only those containing the specified contributing artist id.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified contributing artist id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "albums",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on album. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on album. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "albumIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on album id. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on album id. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "ids",
-            "in": "query",
-            "description": "Optional. If specific items are needed, specify a list of item id's to retrieve. This allows multiple, comma delimited.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specific items are needed, specify a list of item id's to retrieve. This allows multiple, comma delimited.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoTypes",
-            "in": "query",
-            "description": "Optional filter by VideoType (videofile, dvd, bluray, iso). Allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/VideoType"
-              },
-              "description": "Optional filter by VideoType (videofile, dvd, bluray, iso). Allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minOfficialRating",
-            "in": "query",
-            "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
-            "schema": {
-              "type": "string",
-              "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isLocked",
-            "in": "query",
-            "description": "Optional filter by items that are locked.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are locked.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "isPlaceHolder",
-            "in": "query",
-            "description": "Optional filter by items that are placeholders.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are placeholders.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "hasOfficialRating",
-            "in": "query",
-            "description": "Optional filter by items that have official ratings.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have official ratings.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "collapseBoxSetItems",
-            "in": "query",
-            "description": "Whether or not to hide items behind their boxsets.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to hide items behind their boxsets.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minWidth",
-            "in": "query",
-            "description": "Optional. Filter by the minimum width of the item.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Filter by the minimum width of the item.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minHeight",
-            "in": "query",
-            "description": "Optional. Filter by the minimum height of the item.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Filter by the minimum height of the item.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxWidth",
-            "in": "query",
-            "description": "Optional. Filter by the maximum width of the item.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Filter by the maximum width of the item.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxHeight",
-            "in": "query",
-            "description": "Optional. Filter by the maximum height of the item.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Filter by the maximum height of the item.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "is3D",
-            "in": "query",
-            "description": "Optional filter by items that are 3D, or not.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 3D, or not.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "seriesStatus",
-            "in": "query",
-            "description": "Optional filter by Series Status. Allows multiple, comma delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "$ref": "#/components/schemas/SeriesStatus"
-              },
-              "description": "Optional filter by Series Status. Allows multiple, comma delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "nameStartsWithOrGreater",
-            "in": "query",
-            "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-            "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "nameStartsWith",
-            "in": "query",
-            "description": "Optional filter by items whose name is sorted equally than a given input string.",
-            "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "nameLessThan",
-            "in": "query",
-            "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-            "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "studioIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "genreIds",
-            "in": "query",
-            "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimeted.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string",
-                "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimeted.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableTotalRecordCount",
-            "in": "query",
-            "description": "Optional. Enable the total record count.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Enable the total record count.",
-              "default": true
-            }
-          },
-          {
-            "name": "enableImages",
-            "in": "query",
-            "description": "Optional, include image information in output.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
         "responses": {
           "200": {
-            "description": "Success",
+            "description": "return item user data.",
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/UserItemDataDto"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/UserItemDataDto"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item is not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "post": {
+        "tags": [
+          "Items"
+        ],
+        "summary": "Update Item User Data.",
+        "operationId": "UpdateItemUserData",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "The user id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "New user data object.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserItemDataDto"
+                  }
+                ],
+                "description": "This is used by the api to get information about a item user data."
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserItemDataDto"
+                  }
+                ],
+                "description": "This is used by the api to get information about a item user data."
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserItemDataDto"
+                  }
+                ],
+                "description": "This is used by the api to get information about a item user data."
+              }
+            }
+          },
+          "required": true
+        },
+        "responses": {
+          "200": {
+            "description": "return updated user item data.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item is not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
                 }
               }
             }
@@ -22740,7 +20619,7 @@
         ]
       }
     },
-    "/Users/{userId}/Items/Resume": {
+    "/UserItems/Resume": {
       "get": {
         "tags": [
           "Items"
@@ -22750,12 +20629,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "The user id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           },
@@ -22765,9 +20642,7 @@
             "description": "The start index.",
             "schema": {
               "type": "integer",
-              "description": "The start index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -22776,9 +20651,7 @@
             "description": "The item limit.",
             "schema": {
               "type": "integer",
-              "description": "The item limit.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -22786,9 +20659,7 @@
             "in": "query",
             "description": "The search term.",
             "schema": {
-              "type": "string",
-              "description": "The search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -22797,9 +20668,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -22810,9 +20679,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.",
-              "nullable": true
+              }
             }
           },
           {
@@ -22822,10 +20689,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. Filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -22833,9 +20698,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -22844,9 +20707,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -22857,9 +20718,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -22869,10 +20728,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -22882,10 +20739,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on the item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -22894,7 +20749,6 @@
             "description": "Optional. Enable the total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Enable the total record count.",
               "default": true
             }
           },
@@ -22904,9 +20758,16 @@
             "description": "Optional. Include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
+            }
+          },
+          {
+            "name": "excludeActiveSessions",
+            "in": "query",
+            "description": "Optional. Whether to exclude the currently active sessions.",
+            "schema": {
+              "type": "boolean",
+              "default": false
             }
           }
         ],
@@ -22962,7 +20823,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -22972,17 +20832,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/BaseItemDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BaseItemDto"
+                  }
+                ],
+                "description": "This is strictly used as a data transfer object from the api layer.\r\nThis holds information about a BaseItem in a format that is convenient for the client."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/BaseItemDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BaseItemDto"
+                  }
+                ],
+                "description": "This is strictly used as a data transfer object from the api layer.\r\nThis holds information about a BaseItem in a format that is convenient for the client."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/BaseItemDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BaseItemDto"
+                  }
+                ],
+                "description": "This is strictly used as a data transfer object from the api layer.\r\nThis holds information about a BaseItem in a format that is convenient for the client."
               }
             }
           },
@@ -23041,7 +20916,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -23070,6 +20944,89 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "get": {
+        "tags": [
+          "UserLibrary"
+        ],
+        "summary": "Gets an item from a user's library.",
+        "operationId": "GetItem",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Item returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDto"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
           "403": {
             "description": "Forbidden"
           }
@@ -23098,7 +21055,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23107,9 +21063,7 @@
             "in": "query",
             "description": "The content type of the item.",
             "schema": {
-              "type": "string",
-              "description": "The content type of the item.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -23168,7 +21122,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -23245,7 +21198,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23258,9 +21210,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -23269,9 +21219,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -23280,9 +21228,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -23293,9 +21239,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -23351,7 +21295,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23364,9 +21307,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -23375,9 +21316,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -23386,9 +21325,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -23399,9 +21336,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -23457,7 +21392,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23467,9 +21401,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -23609,7 +21541,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -23662,7 +21593,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "Download"
+              "Download",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -23683,7 +21615,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -23757,7 +21688,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23770,9 +21700,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -23781,9 +21709,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -23792,9 +21718,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -23805,9 +21729,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -23863,7 +21785,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23873,9 +21794,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -23884,9 +21803,30 @@
             "description": "Optional. Determines whether or not parent items should be searched for theme media.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Determines whether or not parent items should be searched for theme media.",
               "default": false
             }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Optional. Sort Order - Ascending, Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
+            }
           }
         ],
         "responses": {
@@ -23944,7 +21884,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -23954,9 +21893,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -23965,9 +21902,30 @@
             "description": "Optional. Determines whether or not parent items should be searched for theme media.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Determines whether or not parent items should be searched for theme media.",
               "default": false
             }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Optional. Sort Order - Ascending, Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
+            }
           }
         ],
         "responses": {
@@ -24042,7 +22000,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -24052,9 +22009,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -24063,9 +22018,30 @@
             "description": "Optional. Determines whether or not parent items should be searched for theme media.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Determines whether or not parent items should be searched for theme media.",
               "default": false
             }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Optional. Sort Order - Ascending, Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
+            }
           }
         ],
         "responses": {
@@ -24139,9 +22115,7 @@
             "description": "Optional. Get counts from a specific user's library.",
             "schema": {
               "type": "string",
-              "description": "Optional. Get counts from a specific user's library.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -24149,9 +22123,7 @@
             "in": "query",
             "description": "Optional. Get counts of favorite items.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Get counts of favorite items.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -24205,9 +22177,26 @@
             "in": "query",
             "description": "Library content type.",
             "schema": {
-              "type": "string",
-              "description": "Library content type.",
-              "nullable": true
+              "enum": [
+                "unknown",
+                "movies",
+                "tvshows",
+                "music",
+                "musicvideos",
+                "trailers",
+                "homevideos",
+                "boxsets",
+                "books",
+                "photos",
+                "livetv",
+                "playlists",
+                "folders"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/CollectionType"
+                }
+              ]
             }
           },
           {
@@ -24216,7 +22205,7 @@
             "description": "Whether this is a new library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether this is a new library."
+              "default": false
             }
           }
         ],
@@ -24251,7 +22240,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrDefault"
+              "FirstTimeSetupOrDefault",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -24265,33 +22255,36 @@
         "summary": "Reports that new movies have been added by an external source.",
         "operationId": "PostUpdatedMedia",
         "requestBody": {
-          "description": "A list of updated media paths.",
+          "description": "The update paths.",
           "content": {
             "application/json": {
               "schema": {
-                "type": "array",
-                "items": {
-                  "$ref": "#/components/schemas/MediaUpdateInfoDto"
-                },
-                "description": "A list of updated media paths."
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaUpdateInfoDto"
+                  }
+                ],
+                "description": "Media Update Info Dto."
               }
             },
             "text/json": {
               "schema": {
-                "type": "array",
-                "items": {
-                  "$ref": "#/components/schemas/MediaUpdateInfoDto"
-                },
-                "description": "A list of updated media paths."
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaUpdateInfoDto"
+                  }
+                ],
+                "description": "Media Update Info Dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "type": "array",
-                "items": {
-                  "$ref": "#/components/schemas/MediaUpdateInfoDto"
-                },
-                "description": "A list of updated media paths."
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaUpdateInfoDto"
+                  }
+                ],
+                "description": "Media Update Info Dto."
               }
             }
           },
@@ -24330,9 +22323,7 @@
             "in": "query",
             "description": "Optional. Filter by folders that are marked hidden, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by folders that are marked hidden, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -24367,7 +22358,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -24386,9 +22377,7 @@
             "in": "query",
             "description": "The tmdbId.",
             "schema": {
-              "type": "string",
-              "description": "The tmdbId.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -24396,9 +22385,7 @@
             "in": "query",
             "description": "The imdbId.",
             "schema": {
-              "type": "string",
-              "description": "The imdbId.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -24435,9 +22422,7 @@
             "in": "query",
             "description": "The tmdbId.",
             "schema": {
-              "type": "string",
-              "description": "The tmdbId.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -24445,9 +22430,7 @@
             "in": "query",
             "description": "The imdbId.",
             "schema": {
-              "type": "string",
-              "description": "The imdbId.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -24525,7 +22508,7 @@
       }
     },
     "/Library/Refresh": {
-      "get": {
+      "post": {
         "tags": [
           "Library"
         ],
@@ -24564,9 +22547,7 @@
             "in": "query",
             "description": "The tvdbId.",
             "schema": {
-              "type": "string",
-              "description": "The tvdbId.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -24603,9 +22584,7 @@
             "in": "query",
             "description": "The tvdbId.",
             "schema": {
-              "type": "string",
-              "description": "The tvdbId.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -24644,7 +22623,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -24657,9 +22635,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -24668,9 +22644,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -24679,9 +22653,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -24692,9 +22664,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -24750,7 +22720,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -24763,9 +22732,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -24774,9 +22741,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -24785,9 +22750,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -24798,9 +22761,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -24856,7 +22817,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -24869,9 +22829,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Exclude artist ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -24880,9 +22838,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -24891,9 +22847,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -24904,9 +22858,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -24994,7 +22946,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25011,9 +22964,7 @@
             "in": "query",
             "description": "The name of the virtual folder.",
             "schema": {
-              "type": "string",
-              "description": "The name of the virtual folder.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25021,9 +22972,21 @@
             "in": "query",
             "description": "The type of the collection.",
             "schema": {
-              "type": "string",
-              "description": "The type of the collection.",
-              "nullable": true
+              "enum": [
+                "movies",
+                "tvshows",
+                "music",
+                "musicvideos",
+                "homevideos",
+                "boxsets",
+                "books",
+                "mixed"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/CollectionTypeOptions"
+                }
+              ]
             }
           },
           {
@@ -25034,9 +22997,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "The paths of the virtual folder.",
-              "nullable": true
+              }
             }
           },
           {
@@ -25045,7 +23006,6 @@
             "description": "Whether to refresh the library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to refresh the library.",
               "default": false
             }
           }
@@ -25055,17 +23015,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/AddVirtualFolderDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AddVirtualFolderDto"
+                  }
+                ],
+                "description": "Add virtual folder dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/AddVirtualFolderDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AddVirtualFolderDto"
+                  }
+                ],
+                "description": "Add virtual folder dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/AddVirtualFolderDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AddVirtualFolderDto"
+                  }
+                ],
+                "description": "Add virtual folder dto."
               }
             }
           }
@@ -25084,7 +23059,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25101,9 +23077,7 @@
             "in": "query",
             "description": "The name of the folder.",
             "schema": {
-              "type": "string",
-              "description": "The name of the folder.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25112,7 +23086,6 @@
             "description": "Whether to refresh the library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to refresh the library.",
               "default": false
             }
           }
@@ -25131,7 +23104,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25149,17 +23123,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateLibraryOptionsDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             }
           }
@@ -25168,6 +23157,26 @@
           "204": {
             "description": "Library updated."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -25178,7 +23187,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25197,9 +23207,7 @@
             "in": "query",
             "description": "The name of the virtual folder.",
             "schema": {
-              "type": "string",
-              "description": "The name of the virtual folder.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25207,9 +23215,7 @@
             "in": "query",
             "description": "The new name.",
             "schema": {
-              "type": "string",
-              "description": "The new name.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25218,7 +23224,6 @@
             "description": "Whether to refresh the library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to refresh the library.",
               "default": false
             }
           }
@@ -25277,7 +23282,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25297,7 +23303,6 @@
             "description": "Whether to refresh the library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to refresh the library.",
               "default": false
             }
           }
@@ -25307,17 +23312,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaPathDto"
+                  }
+                ],
+                "description": "Media Path dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaPathDto"
+                  }
+                ],
+                "description": "Media Path dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MediaPathDto"
+                  }
+                ],
+                "description": "Media Path dto."
               }
             }
           },
@@ -25337,7 +23357,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25354,9 +23375,7 @@
             "in": "query",
             "description": "The name of the library.",
             "schema": {
-              "type": "string",
-              "description": "The name of the library.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25364,9 +23383,7 @@
             "in": "query",
             "description": "The path to remove.",
             "schema": {
-              "type": "string",
-              "description": "The path to remove.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -25375,7 +23392,6 @@
             "description": "Whether to refresh the library.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to refresh the library.",
               "default": false
             }
           }
@@ -25394,7 +23410,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25407,37 +23424,41 @@
         ],
         "summary": "Updates a media path.",
         "operationId": "UpdateMediaPath",
-        "parameters": [
-          {
-            "name": "name",
-            "in": "query",
-            "description": "The name of the library.",
-            "schema": {
-              "type": "string",
-              "description": "The name of the library.",
-              "nullable": true
-            }
-          }
-        ],
         "requestBody": {
-          "description": "The path info.",
+          "description": "The name of the library and path infos.",
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateMediaPathRequestDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateMediaPathRequestDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/MediaPathInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateMediaPathRequestDto"
+                  }
+                ],
+                "description": "Update library options dto."
               }
             }
-          }
+          },
+          "required": true
         },
         "responses": {
           "204": {
@@ -25453,7 +23474,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -25472,9 +23494,7 @@
             "in": "query",
             "description": "Provider id.",
             "schema": {
-              "type": "string",
-              "description": "Provider id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -25509,6 +23529,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -25527,17 +23548,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetChannelMappingDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetChannelMappingDto"
+                  }
+                ],
+                "description": "Set channel mapping dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetChannelMappingDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetChannelMappingDto"
+                  }
+                ],
+                "description": "Set channel mapping dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SetChannelMappingDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetChannelMappingDto"
+                  }
+                ],
+                "description": "Set channel mapping dto."
               }
             }
           },
@@ -25574,6 +23610,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -25593,7 +23630,15 @@
             "in": "query",
             "description": "Optional. Filter by channel type.",
             "schema": {
-              "$ref": "#/components/schemas/ChannelType"
+              "enum": [
+                "TV",
+                "Radio"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ChannelType"
+                }
+              ]
             }
           },
           {
@@ -25602,9 +23647,7 @@
             "description": "Optional. Filter by user and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -25613,9 +23656,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -25623,9 +23664,7 @@
             "in": "query",
             "description": "Optional. Filter for movies.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for movies.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25633,9 +23672,7 @@
             "in": "query",
             "description": "Optional. Filter for series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25643,9 +23680,7 @@
             "in": "query",
             "description": "Optional. Filter for news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25653,9 +23688,7 @@
             "in": "query",
             "description": "Optional. Filter for kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25663,9 +23696,7 @@
             "in": "query",
             "description": "Optional. Filter for sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25674,9 +23705,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -25684,9 +23713,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that are favorites, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that are favorites, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25694,9 +23721,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that are liked, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that are liked, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25704,9 +23729,7 @@
             "in": "query",
             "description": "Optional. Filter by channels that are disliked, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by channels that are disliked, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25714,9 +23737,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25725,9 +23746,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -25738,9 +23757,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "\"Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -25751,9 +23768,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -25761,9 +23776,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -25773,10 +23786,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. Key to sort by.",
-              "nullable": true
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -25784,7 +23795,15 @@
             "in": "query",
             "description": "Optional. Sort order.",
             "schema": {
-              "$ref": "#/components/schemas/SortOrder"
+              "enum": [
+                "Ascending",
+                "Descending"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SortOrder"
+                }
+              ]
             }
           },
           {
@@ -25793,7 +23812,6 @@
             "description": "Optional. Incorporate favorite and like status into channel sorting.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Incorporate favorite and like status into channel sorting.",
               "default": false
             }
           },
@@ -25803,7 +23821,6 @@
             "description": "Optional. Adds current program info to each channel.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Adds current program info to each channel.",
               "default": true
             }
           }
@@ -25839,6 +23856,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -25860,7 +23878,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Channel id.",
               "format": "uuid"
             }
           },
@@ -25870,9 +23887,7 @@
             "description": "Optional. Attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -25897,6 +23912,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -25907,6 +23942,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -25951,6 +23987,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -25995,6 +24032,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26014,9 +24052,7 @@
             "in": "query",
             "description": "Password.",
             "schema": {
-              "type": "string",
-              "description": "Password.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -26025,7 +24061,6 @@
             "description": "Validate listings.",
             "schema": {
               "type": "boolean",
-              "description": "Validate listings.",
               "default": false
             }
           },
@@ -26035,7 +24070,6 @@
             "description": "Validate login.",
             "schema": {
               "type": "boolean",
-              "description": "Validate login.",
               "default": false
             }
           }
@@ -26045,17 +24079,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ListingsProviderInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ListingsProviderInfo"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ListingsProviderInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ListingsProviderInfo"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ListingsProviderInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ListingsProviderInfo"
+                  }
+                ]
               }
             }
           }
@@ -26091,6 +24137,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -26108,9 +24155,7 @@
             "in": "query",
             "description": "Listing provider id.",
             "schema": {
-              "type": "string",
-              "description": "Listing provider id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -26128,6 +24173,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -26172,6 +24218,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26191,9 +24238,7 @@
             "in": "query",
             "description": "Provider id.",
             "schema": {
-              "type": "string",
-              "description": "Provider id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -26201,9 +24246,7 @@
             "in": "query",
             "description": "Provider type.",
             "schema": {
-              "type": "string",
-              "description": "Provider type.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -26211,9 +24254,7 @@
             "in": "query",
             "description": "Location.",
             "schema": {
-              "type": "string",
-              "description": "Location.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -26221,9 +24262,7 @@
             "in": "query",
             "description": "Country.",
             "schema": {
-              "type": "string",
-              "description": "Country.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -26267,6 +24306,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26302,6 +24342,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26322,8 +24363,7 @@
             "description": "Recording id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Recording id."
+              "type": "string"
             }
           }
         ],
@@ -26376,8 +24416,7 @@
             "description": "Stream id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Stream id."
+              "type": "string"
             }
           },
           {
@@ -26386,8 +24425,7 @@
             "description": "Container type.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Container type."
+              "type": "string"
             }
           }
         ],
@@ -26443,9 +24481,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The channels to return guide information for.",
-              "nullable": true
+              }
             }
           },
           {
@@ -26454,9 +24490,7 @@
             "description": "Optional. Filter by user id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -26465,9 +24499,7 @@
             "description": "Optional. The minimum premiere start date.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum premiere start date.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -26475,9 +24507,7 @@
             "in": "query",
             "description": "Optional. Filter by programs that have completed airing, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by programs that have completed airing, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26485,9 +24515,7 @@
             "in": "query",
             "description": "Optional. Filter by programs that are currently airing, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by programs that are currently airing, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26496,9 +24524,7 @@
             "description": "Optional. The maximum premiere start date.",
             "schema": {
               "type": "string",
-              "description": "Optional. The maximum premiere start date.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -26507,9 +24533,7 @@
             "description": "Optional. The minimum premiere end date.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum premiere end date.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -26518,9 +24542,7 @@
             "description": "Optional. The maximum premiere end date.",
             "schema": {
               "type": "string",
-              "description": "Optional. The maximum premiere end date.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -26528,9 +24550,7 @@
             "in": "query",
             "description": "Optional. Filter for movies.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for movies.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26538,9 +24558,7 @@
             "in": "query",
             "description": "Optional. Filter for series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26548,9 +24566,7 @@
             "in": "query",
             "description": "Optional. Filter for news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26558,9 +24574,7 @@
             "in": "query",
             "description": "Optional. Filter for kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26568,9 +24582,7 @@
             "in": "query",
             "description": "Optional. Filter for sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26579,9 +24591,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -26590,9 +24600,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -26600,9 +24608,10 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Name, StartDate.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Name, StartDate.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -26610,9 +24619,10 @@
             "in": "query",
             "description": "Sort Order - Ascending,Descending.",
             "schema": {
-              "type": "string",
-              "description": "Sort Order - Ascending,Descending.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -26623,9 +24633,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "The genres to return guide information for.",
-              "nullable": true
+              }
             }
           },
           {
@@ -26637,9 +24645,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The genre ids to return guide information for.",
-              "nullable": true
+              }
             }
           },
           {
@@ -26647,9 +24653,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26658,9 +24662,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -26671,9 +24673,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -26681,9 +24681,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26691,9 +24689,7 @@
             "in": "query",
             "description": "Optional. Filter by series timer id.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by series timer id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -26702,9 +24698,7 @@
             "description": "Optional. Filter by library series id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by library series id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -26715,9 +24709,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -26726,7 +24718,6 @@
             "description": "Retrieve total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Retrieve total record count.",
               "default": true
             }
           }
@@ -26762,6 +24753,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26778,17 +24770,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/GetProgramsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GetProgramsDto"
+                  }
+                ],
+                "description": "Get programs dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/GetProgramsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GetProgramsDto"
+                  }
+                ],
+                "description": "Get programs dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/GetProgramsDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GetProgramsDto"
+                  }
+                ],
+                "description": "Get programs dto."
               }
             }
           }
@@ -26824,6 +24831,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26844,8 +24852,7 @@
             "description": "Program id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Program id."
+              "type": "string"
             }
           },
           {
@@ -26854,9 +24861,7 @@
             "description": "Optional. Attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -26891,6 +24896,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -26911,9 +24917,7 @@
             "description": "Optional. filter by user id.",
             "schema": {
               "type": "string",
-              "description": "Optional. filter by user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -26922,9 +24926,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -26932,9 +24934,7 @@
             "in": "query",
             "description": "Optional. Filter by programs that are currently airing, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by programs that are currently airing, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26942,9 +24942,7 @@
             "in": "query",
             "description": "Optional. Filter by programs that have completed airing, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by programs that have completed airing, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26952,9 +24950,7 @@
             "in": "query",
             "description": "Optional. Filter for series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26962,9 +24958,7 @@
             "in": "query",
             "description": "Optional. Filter for movies.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for movies.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26972,9 +24966,7 @@
             "in": "query",
             "description": "Optional. Filter for news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26982,9 +24974,7 @@
             "in": "query",
             "description": "Optional. Filter for kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -26992,9 +24982,7 @@
             "in": "query",
             "description": "Optional. Filter for sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27002,9 +24990,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27013,9 +24999,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27026,9 +25010,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27040,9 +25022,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The genres to return guide information for.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27053,9 +25033,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27063,9 +25041,7 @@
             "in": "query",
             "description": "Optional. include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27074,7 +25050,6 @@
             "description": "Retrieve total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Retrieve total record count.",
               "default": true
             }
           }
@@ -27110,6 +25085,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27129,9 +25105,7 @@
             "in": "query",
             "description": "Optional. Filter by channel id.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by channel id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27140,9 +25114,7 @@
             "description": "Optional. Filter by user and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -27151,9 +25123,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27162,9 +25132,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27172,7 +25140,20 @@
             "in": "query",
             "description": "Optional. Filter by recording status.",
             "schema": {
-              "$ref": "#/components/schemas/RecordingStatus"
+              "enum": [
+                "New",
+                "InProgress",
+                "Completed",
+                "Cancelled",
+                "ConflictedOk",
+                "ConflictedNotOk",
+                "Error"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/RecordingStatus"
+                }
+              ]
             }
           },
           {
@@ -27180,9 +25161,7 @@
             "in": "query",
             "description": "Optional. Filter by recordings that are in progress, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by recordings that are in progress, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27190,9 +25169,7 @@
             "in": "query",
             "description": "Optional. Filter by recordings belonging to a series timer.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by recordings belonging to a series timer.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27200,9 +25177,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27211,9 +25186,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27224,9 +25197,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27237,9 +25208,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27247,9 +25216,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27257,9 +25224,7 @@
             "in": "query",
             "description": "Optional. Filter for movies.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for movies.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27267,9 +25232,7 @@
             "in": "query",
             "description": "Optional. Filter for series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27277,9 +25240,7 @@
             "in": "query",
             "description": "Optional. Filter for kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27287,9 +25248,7 @@
             "in": "query",
             "description": "Optional. Filter for sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27297,9 +25256,7 @@
             "in": "query",
             "description": "Optional. Filter for news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27307,9 +25264,7 @@
             "in": "query",
             "description": "Optional. Filter for is library item.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter for is library item.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27318,7 +25273,6 @@
             "description": "Optional. Return total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Return total record count.",
               "default": true
             }
           }
@@ -27354,6 +25308,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27375,7 +25330,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Recording id.",
               "format": "uuid"
             }
           },
@@ -27385,9 +25339,7 @@
             "description": "Optional. Attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -27412,6 +25364,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -27422,6 +25394,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27441,7 +25414,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Recording id.",
               "format": "uuid"
             }
           }
@@ -27480,6 +25452,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -27500,9 +25473,7 @@
             "description": "Optional. Filter by user and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -27537,6 +25508,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27557,9 +25529,7 @@
             "description": "Optional. Filter by user and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -27595,6 +25565,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27616,7 +25587,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Group id.",
               "format": "uuid"
             }
           }
@@ -27653,6 +25623,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27672,9 +25643,7 @@
             "in": "query",
             "description": "Optional. Filter by channel id.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by channel id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27683,9 +25652,7 @@
             "description": "Optional. Filter by user and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -27693,9 +25660,7 @@
             "in": "query",
             "description": "Optional. Filter by recording group.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by recording group.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27704,9 +25669,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27715,9 +25678,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27725,7 +25686,20 @@
             "in": "query",
             "description": "Optional. Filter by recording status.",
             "schema": {
-              "$ref": "#/components/schemas/RecordingStatus"
+              "enum": [
+                "New",
+                "InProgress",
+                "Completed",
+                "Cancelled",
+                "ConflictedOk",
+                "ConflictedNotOk",
+                "Error"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/RecordingStatus"
+                }
+              ]
             }
           },
           {
@@ -27733,9 +25707,7 @@
             "in": "query",
             "description": "Optional. Filter by recordings that are in progress, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by recordings that are in progress, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27743,9 +25715,7 @@
             "in": "query",
             "description": "Optional. Filter by recordings belonging to a series timer.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by recordings belonging to a series timer.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27753,9 +25723,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27764,9 +25732,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -27777,9 +25743,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27790,9 +25754,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -27800,9 +25762,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -27811,7 +25771,6 @@
             "description": "Optional. Return total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Return total record count.",
               "default": true
             }
           }
@@ -27848,6 +25807,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27867,9 +25827,7 @@
             "in": "query",
             "description": "Optional. Sort by SortName or Priority.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Sort by SortName or Priority.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -27877,7 +25835,15 @@
             "in": "query",
             "description": "Optional. Sort in Ascending or Descending order.",
             "schema": {
-              "$ref": "#/components/schemas/SortOrder"
+              "enum": [
+                "Ascending",
+                "Descending"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SortOrder"
+                }
+              ]
             }
           }
         ],
@@ -27912,6 +25878,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -27928,17 +25895,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             }
           }
@@ -27957,6 +25939,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -27977,8 +25960,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28033,6 +26015,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -28051,8 +26034,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28070,6 +26052,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28088,8 +26071,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28098,17 +26080,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeriesTimerInfoDto"
+                  }
+                ],
+                "description": "Class SeriesTimerInfoDto."
               }
             }
           }
@@ -28127,6 +26124,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28146,9 +26144,7 @@
             "in": "query",
             "description": "Optional. Filter by channel id.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by channel id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -28156,9 +26152,7 @@
             "in": "query",
             "description": "Optional. Filter by timers belonging to a series timer.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter by timers belonging to a series timer.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -28166,9 +26160,7 @@
             "in": "query",
             "description": "Optional. Filter by timers that are active.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by timers that are active.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -28176,9 +26168,7 @@
             "in": "query",
             "description": "Optional. Filter by timers that are scheduled.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by timers that are scheduled.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -28213,6 +26203,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -28229,17 +26220,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             }
           }
@@ -28258,6 +26261,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28278,8 +26282,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28314,6 +26317,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -28332,8 +26336,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28351,6 +26354,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28369,8 +26373,7 @@
             "description": "Timer id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Timer id."
+              "type": "string"
             }
           }
         ],
@@ -28379,17 +26382,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/TimerInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TimerInfoDto"
+                  }
+                ]
               }
             }
           }
@@ -28408,6 +26423,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28427,9 +26443,7 @@
             "in": "query",
             "description": "Optional. To attach default values based on a program.",
             "schema": {
-              "type": "string",
-              "description": "Optional. To attach default values based on a program.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -28464,6 +26478,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -28482,17 +26497,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/TunerHostInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TunerHostInfo"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/TunerHostInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TunerHostInfo"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/TunerHostInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/TunerHostInfo"
+                  }
+                ]
               }
             }
           }
@@ -28528,6 +26555,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28545,9 +26573,7 @@
             "in": "query",
             "description": "Tuner host id.",
             "schema": {
-              "type": "string",
-              "description": "Tuner host id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -28565,6 +26591,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28618,6 +26645,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvAccess",
               "DefaultAuthorization"
             ]
           }
@@ -28638,8 +26666,7 @@
             "description": "Tuner id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Tuner id."
+              "type": "string"
             }
           }
         ],
@@ -28657,6 +26684,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28677,7 +26705,6 @@
             "description": "Only discover new tuners.",
             "schema": {
               "type": "boolean",
-              "description": "Only discover new tuners.",
               "default": false
             }
           }
@@ -28722,6 +26749,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28742,7 +26770,6 @@
             "description": "Only discover new tuners.",
             "schema": {
               "type": "boolean",
-              "description": "Only discover new tuners.",
               "default": false
             }
           }
@@ -28787,6 +26814,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "LiveTvManagement",
               "DefaultAuthorization"
             ]
           }
@@ -28840,7 +26868,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrDefault"
+              "FirstTimeSetupOrDefault",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -28893,7 +26922,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrDefault"
+              "FirstTimeSetupOrDefault",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -28946,7 +26976,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrDefault"
+              "FirstTimeSetupOrDefault",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -28999,7 +27030,504 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrDefault"
+              "FirstTimeSetupOrDefault",
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Audio/{itemId}/Lyrics": {
+      "get": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Gets an item's lyrics.",
+        "operationId": "GetLyrics",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Lyrics returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Something went wrong. No Lyrics will be returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "post": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Upload an external lyric file.",
+        "operationId": "UploadLyrics",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item the lyric belongs to.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "fileName",
+            "in": "query",
+            "description": "Name of the file being uploaded.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "requestBody": {
+          "content": {
+            "text/plain": {
+              "schema": {
+                "type": "string",
+                "format": "binary"
+              }
+            }
+          }
+        },
+        "responses": {
+          "200": {
+            "description": "Lyrics uploaded.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              }
+            }
+          },
+          "400": {
+            "description": "Error processing upload.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "LyricManagement",
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "delete": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Deletes an external lyric file.",
+        "operationId": "DeleteLyrics",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "Lyric deleted."
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "LyricManagement",
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Audio/{itemId}/RemoteSearch/Lyrics": {
+      "get": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Search remote lyrics.",
+        "operationId": "SearchRemoteLyrics",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Lyrics retrieved.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/RemoteLyricInfoDto"
+                  }
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/RemoteLyricInfoDto"
+                  }
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/RemoteLyricInfoDto"
+                  }
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "LyricManagement",
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Audio/{itemId}/RemoteSearch/Lyrics/{lyricId}": {
+      "post": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Downloads a remote lyric.",
+        "operationId": "DownloadRemoteLyrics",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "lyricId",
+            "in": "path",
+            "description": "The lyric id.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Lyric downloaded.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "LyricManagement",
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Providers/Lyrics/{lyricId}": {
+      "get": {
+        "tags": [
+          "Lyrics"
+        ],
+        "summary": "Gets the remote lyrics.",
+        "operationId": "GetRemoteLyrics",
+        "parameters": [
+          {
+            "name": "lyricId",
+            "in": "path",
+            "description": "The remote provider item id.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "File returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/LyricDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Lyric not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "LyricManagement",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -29020,7 +27548,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -29028,10 +27555,8 @@
             "name": "userId",
             "in": "query",
             "description": "The user id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
@@ -29057,6 +27582,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -29087,7 +27632,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -29098,9 +27642,7 @@
             "deprecated": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29110,9 +27652,7 @@
             "deprecated": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29122,9 +27662,7 @@
             "deprecated": true,
             "schema": {
               "type": "integer",
-              "description": "The start time in ticks.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -29134,9 +27672,7 @@
             "deprecated": true,
             "schema": {
               "type": "integer",
-              "description": "The audio stream index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29146,9 +27682,7 @@
             "deprecated": true,
             "schema": {
               "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29158,9 +27692,7 @@
             "deprecated": true,
             "schema": {
               "type": "integer",
-              "description": "The maximum number of audio channels.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29169,9 +27701,7 @@
             "description": "The media source id.",
             "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "The media source id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29180,9 +27710,7 @@
             "description": "The livestream id.",
             "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "The livestream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29191,9 +27719,7 @@
             "description": "Whether to auto open the livestream.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to auto open the livestream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29202,9 +27728,7 @@
             "description": "Whether to enable direct play. Default: true.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable direct play. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29213,9 +27737,7 @@
             "description": "Whether to enable direct stream. Default: true.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable direct stream. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29224,9 +27746,7 @@
             "description": "Whether to enable transcoding. Default: true.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable transcoding. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29235,9 +27755,7 @@
             "description": "Whether to allow to copy the video stream. Default: true.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to allow to copy the video stream. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29246,9 +27764,7 @@
             "description": "Whether to allow to copy the audio stream. Default: true.",
             "deprecated": true,
             "schema": {
-              "type": "boolean",
-              "description": "Whether to allow to copy the audio stream. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -29257,17 +27773,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackInfoDto"
+                  }
+                ],
+                "description": "Plabyback info dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackInfoDto"
+                  }
+                ],
+                "description": "Plabyback info dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackInfoDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackInfoDto"
+                  }
+                ],
+                "description": "Plabyback info dto."
               }
             }
           }
@@ -29293,6 +27824,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -29323,8 +27874,7 @@
             "description": "The livestream id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The livestream id."
+              "type": "string"
             }
           }
         ],
@@ -29361,9 +27911,7 @@
             "in": "query",
             "description": "The open token.",
             "schema": {
-              "type": "string",
-              "description": "The open token.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29372,9 +27920,7 @@
             "description": "The user id.",
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29382,9 +27928,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29393,9 +27937,7 @@
             "description": "The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29404,9 +27946,7 @@
             "description": "The start time in ticks.",
             "schema": {
               "type": "integer",
-              "description": "The start time in ticks.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -29415,9 +27955,7 @@
             "description": "The audio stream index.",
             "schema": {
               "type": "integer",
-              "description": "The audio stream index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29426,9 +27964,7 @@
             "description": "The subtitle stream index.",
             "schema": {
               "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29437,9 +27973,7 @@
             "description": "The maximum number of audio channels.",
             "schema": {
               "type": "integer",
-              "description": "The maximum number of audio channels.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29448,9 +27982,7 @@
             "description": "The item id.",
             "schema": {
               "type": "string",
-              "description": "The item id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29458,9 +27990,7 @@
             "in": "query",
             "description": "Whether to enable direct play. Default: true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable direct play. Default: true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29468,9 +27998,15 @@
             "in": "query",
             "description": "Whether to enable direct stream. Default: true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether to enable direct stream. Default: true.",
-              "nullable": true
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "alwaysBurnInSubtitleWhenTranscoding",
+            "in": "query",
+            "description": "Always burn-in subtitle when transcoding.",
+            "schema": {
+              "type": "boolean"
             }
           }
         ],
@@ -29479,17 +28015,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/OpenLiveStreamDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/OpenLiveStreamDto"
+                  }
+                ],
+                "description": "Open live stream dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/OpenLiveStreamDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/OpenLiveStreamDto"
+                  }
+                ],
+                "description": "Open live stream dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/OpenLiveStreamDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/OpenLiveStreamDto"
+                  }
+                ],
+                "description": "Open live stream dto."
               }
             }
           }
@@ -29544,8 +28095,9 @@
             "in": "query",
             "description": "The bitrate. Defaults to 102400.",
             "schema": {
+              "maximum": 100000000,
+              "minimum": 1,
               "type": "integer",
-              "description": "The bitrate. Defaults to 102400.",
               "format": "int32",
               "default": 102400
             }
@@ -29563,14 +28115,76 @@
               }
             }
           },
-          "400": {
-            "description": "Size has to be a numer between 0 and 10,000,000.",
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/MediaSegments/{itemId}": {
+      "get": {
+        "tags": [
+          "MediaSegments"
+        ],
+        "summary": "Gets all media segments based on an itemId.",
+        "operationId": "GetItemSegments",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The ItemId.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "includeSegmentTypes",
+            "in": "query",
+            "description": "Optional filter of requested segment types.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/MediaSegmentType"
+              }
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Success",
             "content": {
-              "application/octet-stream": {
+              "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
+                  "$ref": "#/components/schemas/MediaSegmentDtoQueryResult"
                 }
               },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/MediaSegmentDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/MediaSegmentDtoQueryResult"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Not Found",
+            "content": {
               "application/json": {
                 "schema": {
                   "$ref": "#/components/schemas/ProblemDetails"
@@ -29618,9 +28232,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29629,9 +28241,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29642,9 +28252,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. The fields to return.",
-              "nullable": true
+              }
             }
           },
           {
@@ -29653,7 +28261,6 @@
             "description": "The max number of categories to return.",
             "schema": {
               "type": "integer",
-              "description": "The max number of categories to return.",
               "format": "int32",
               "default": 5
             }
@@ -29664,7 +28271,6 @@
             "description": "The max number of items to return per category.",
             "schema": {
               "type": "integer",
-              "description": "The max number of items to return per category.",
               "format": "int32",
               "default": 8
             }
@@ -29730,9 +28336,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29741,9 +28345,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29751,9 +28353,7 @@
             "in": "query",
             "description": "The search term.",
             "schema": {
-              "type": "string",
-              "description": "The search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29762,9 +28362,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29775,9 +28373,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -29787,10 +28383,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -29800,10 +28394,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered in based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -29811,9 +28403,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -29822,9 +28412,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -29835,9 +28423,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -29846,9 +28432,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -29856,9 +28440,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29866,9 +28448,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -29876,9 +28456,29 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
+            }
+          },
+          {
+            "name": "sortBy",
+            "in": "query",
+            "description": "Optional. Specify one or more sort orders, comma delimited.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
+            }
+          },
+          {
+            "name": "sortOrder",
+            "in": "query",
+            "description": "Sort Order - Ascending,Descending.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -29887,9 +28487,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -29898,7 +28496,6 @@
             "description": "Optional. Include total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Include total record count.",
               "default": true
             }
           }
@@ -29955,8 +28552,7 @@
             "description": "The genre name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The genre name."
+              "type": "string"
             }
           },
           {
@@ -29965,9 +28561,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -30008,363 +28602,6 @@
         ]
       }
     },
-    "/Notifications/{userId}": {
-      "get": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Gets a user's notifications.",
-        "operationId": "GetNotifications",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Notifications returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationResultDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationResultDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationResultDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/{userId}/Read": {
-      "post": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Sets notifications as read.",
-        "operationId": "SetRead",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Notifications set as read."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/{userId}/Summary": {
-      "get": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Gets a user's notification summary.",
-        "operationId": "GetNotificationsSummary",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Summary of user's notifications returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationsSummaryDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationsSummaryDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/NotificationsSummaryDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/{userId}/Unread": {
-      "post": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Sets notifications as unread.",
-        "operationId": "SetUnread",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Notifications set as unread."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/Admin": {
-      "post": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Sends a notification to all admins.",
-        "operationId": "CreateAdminNotification",
-        "parameters": [
-          {
-            "name": "url",
-            "in": "query",
-            "description": "The URL of the notification.",
-            "schema": {
-              "type": "string",
-              "description": "The URL of the notification.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "level",
-            "in": "query",
-            "description": "The level of the notification.",
-            "schema": {
-              "$ref": "#/components/schemas/NotificationLevel"
-            }
-          },
-          {
-            "name": "name",
-            "in": "query",
-            "description": "The name of the notification.",
-            "schema": {
-              "type": "string",
-              "description": "The name of the notification.",
-              "default": "",
-              "nullable": true
-            }
-          },
-          {
-            "name": "description",
-            "in": "query",
-            "description": "The description of the notification.",
-            "schema": {
-              "type": "string",
-              "description": "The description of the notification.",
-              "default": "",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Notification sent."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/Services": {
-      "get": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Gets notification services.",
-        "operationId": "GetNotificationServices",
-        "responses": {
-          "200": {
-            "description": "All notification services returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NameIdPair"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NameIdPair"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NameIdPair"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Notifications/Types": {
-      "get": {
-        "tags": [
-          "Notifications"
-        ],
-        "summary": "Gets notification types.",
-        "operationId": "GetNotificationTypes",
-        "responses": {
-          "200": {
-            "description": "All notification types returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NotificationTypeInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NotificationTypeInfo"
-                  }
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "array",
-                  "items": {
-                    "$ref": "#/components/schemas/NotificationTypeInfo"
-                  }
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
     "/Packages": {
       "get": {
         "tags": [
@@ -30412,7 +28649,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30432,8 +28669,7 @@
             "description": "The name of the package.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The name of the package."
+              "type": "string"
             }
           },
           {
@@ -30442,9 +28678,7 @@
             "description": "The GUID of the associated assembly.",
             "schema": {
               "type": "string",
-              "description": "The GUID of the associated assembly.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -30479,7 +28713,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30499,8 +28733,7 @@
             "description": "Package name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Package name."
+              "type": "string"
             }
           },
           {
@@ -30509,9 +28742,7 @@
             "description": "GUID of the associated assembly.",
             "schema": {
               "type": "string",
-              "description": "GUID of the associated assembly.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -30519,9 +28750,7 @@
             "in": "query",
             "description": "Optional version. Defaults to latest version.",
             "schema": {
-              "type": "string",
-              "description": "Optional version. Defaults to latest version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -30529,9 +28758,7 @@
             "in": "query",
             "description": "Optional. Specify the repository to install from.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify the repository to install from.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -30569,8 +28796,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30591,7 +28817,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Installation Id.",
               "format": "uuid"
             }
           }
@@ -30610,8 +28835,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30664,7 +28888,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30683,9 +28907,7 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/RepositoryInfo"
-                },
-                "description": "The list of package repositories.",
-                "nullable": true
+                }
               }
             },
             "text/json": {
@@ -30693,9 +28915,7 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/RepositoryInfo"
-                },
-                "description": "The list of package repositories.",
-                "nullable": true
+                }
               }
             },
             "application/*+json": {
@@ -30703,12 +28923,11 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/RepositoryInfo"
-                },
-                "description": "The list of package repositories.",
-                "nullable": true
+                }
               }
             }
-          }
+          },
+          "required": true
         },
         "responses": {
           "204": {
@@ -30724,7 +28943,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -30744,9 +28963,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -30754,9 +28971,7 @@
             "in": "query",
             "description": "The search term.",
             "schema": {
-              "type": "string",
-              "description": "The search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -30767,9 +28982,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -30780,9 +28993,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply.",
-              "nullable": true
+              }
             }
           },
           {
@@ -30790,9 +29001,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not. userId is required.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not. userId is required.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -30800,9 +29009,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -30811,9 +29018,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -30824,9 +29029,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -30837,9 +29040,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified results will be filtered to exclude those containing the specified PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -30850,9 +29051,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified results will be filtered to include only those containing the specified PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -30861,9 +29060,7 @@
             "description": "Optional. If specified, person results will be filtered on items related to said persons.",
             "schema": {
               "type": "string",
-              "description": "Optional. If specified, person results will be filtered on items related to said persons.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -30872,9 +29069,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -30883,9 +29078,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           }
         ],
@@ -30940,8 +29133,7 @@
             "description": "Person name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Person name."
+              "type": "string"
             }
           },
           {
@@ -30950,9 +29142,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -31028,9 +29218,7 @@
             "description": "The playlist name.",
             "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist name.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -31043,9 +29231,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The item ids.",
-              "nullable": true
+              }
             }
           },
           {
@@ -31055,9 +29241,7 @@
             "deprecated": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -31066,9 +29250,18 @@
             "description": "The media type.",
             "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "The media type.",
-              "nullable": true
+              "enum": [
+                "Unknown",
+                "Video",
+                "Audio",
+                "Photo",
+                "Book"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/MediaType"
+                }
+              ]
             }
           }
         ],
@@ -31077,24 +29270,39 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/CreatePlaylistDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreatePlaylistDto"
+                  }
+                ],
+                "description": "Create new playlist dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/CreatePlaylistDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreatePlaylistDto"
+                  }
+                ],
+                "description": "Create new playlist dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/CreatePlaylistDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreatePlaylistDto"
+                  }
+                ],
+                "description": "Create new playlist dto."
               }
             }
           }
         },
         "responses": {
           "200": {
-            "description": "Success",
+            "description": "Playlist created.",
             "content": {
               "application/json": {
                 "schema": {
@@ -31129,13 +29337,199 @@
         ]
       }
     },
+    "/Playlists/{playlistId}": {
+      "post": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Updates a playlist.",
+        "operationId": "UpdatePlaylist",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The Jellyfin.Api.Models.PlaylistDtos.UpdatePlaylistDto id.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistDto"
+                  }
+                ],
+                "description": "Update existing playlist dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistDto"
+                  }
+                ],
+                "description": "Update existing playlist dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistDto"
+                  }
+                ],
+                "description": "Update existing playlist dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            }
+          },
+          "required": true
+        },
+        "responses": {
+          "204": {
+            "description": "Playlist updated."
+          },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "get": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Get a playlist.",
+        "operationId": "GetPlaylist",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "The playlist.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistDto"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Playlists/{playlistId}/Items": {
       "post": {
         "tags": [
           "Playlists"
         ],
         "summary": "Adds items to a playlist.",
-        "operationId": "AddToPlaylist",
+        "operationId": "AddItemToPlaylist",
         "parameters": [
           {
             "name": "playlistId",
@@ -31144,7 +29538,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The playlist id.",
               "format": "uuid"
             }
           },
@@ -31157,9 +29550,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Item id, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -31168,9 +29559,7 @@
             "description": "The userId.",
             "schema": {
               "type": "string",
-              "description": "The userId.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -31178,11 +29567,48 @@
           "204": {
             "description": "Items added to playlist."
           },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -31198,7 +29624,7 @@
           "Playlists"
         ],
         "summary": "Removes items from a playlist.",
-        "operationId": "RemoveFromPlaylist",
+        "operationId": "RemoveItemFromPlaylist",
         "parameters": [
           {
             "name": "playlistId",
@@ -31206,8 +29632,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           },
           {
@@ -31218,9 +29643,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "The item ids, comma delimited.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -31228,11 +29651,48 @@
           "204": {
             "description": "Items removed."
           },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -31257,7 +29717,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The playlist id.",
               "format": "uuid"
             }
           },
@@ -31265,10 +29724,8 @@
             "name": "userId",
             "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -31278,9 +29735,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -31289,9 +29744,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -31302,9 +29755,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -31312,9 +29763,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -31322,9 +29771,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -31333,9 +29780,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -31346,9 +29791,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           }
         ],
@@ -31373,14 +29816,48 @@
               }
             }
           },
+          "403": {
+            "description": "Forbidden",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "404": {
-            "description": "Playlist not found."
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
           },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -31406,8 +29883,7 @@
             "description": "The playlist id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The playlist id."
+              "type": "string"
             }
           },
           {
@@ -31416,8 +29892,7 @@
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           },
           {
@@ -31427,7 +29902,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The new index.",
               "format": "int32"
             }
           }
@@ -31436,6 +29910,788 @@
           "204": {
             "description": "Item moved to new index."
           },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Playlists/{playlistId}/Users": {
+      "get": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Get a playlist's users.",
+        "operationId": "GetPlaylistUsers",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Found shares.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/PlaylistUserPermissions"
+                  }
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/PlaylistUserPermissions"
+                  }
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "type": "array",
+                  "items": {
+                    "$ref": "#/components/schemas/PlaylistUserPermissions"
+                  }
+                }
+              }
+            }
+          },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Playlists/{playlistId}/Users/{userId}": {
+      "get": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Get a playlist user.",
+        "operationId": "GetPlaylistUser",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "path",
+            "description": "The user id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "User permission found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistUserPermissions"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistUserPermissions"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/PlaylistUserPermissions"
+                }
+              }
+            }
+          },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "post": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Modify a user of a playlist's users.",
+        "operationId": "UpdatePlaylistUser",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "path",
+            "description": "The user id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The Jellyfin.Api.Models.PlaylistDtos.UpdatePlaylistUserDto.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistUserDto"
+                  }
+                ],
+                "description": "Update existing playlist user dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistUserDto"
+                  }
+                ],
+                "description": "Update existing playlist user dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdatePlaylistUserDto"
+                  }
+                ],
+                "description": "Update existing playlist user dto. Fields set to `null` will not be updated and keep their current values."
+              }
+            }
+          },
+          "required": true
+        },
+        "responses": {
+          "204": {
+            "description": "User's permissions modified."
+          },
+          "403": {
+            "description": "Access forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Playlist not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "delete": {
+        "tags": [
+          "Playlists"
+        ],
+        "summary": "Remove a user from a playlist's users.",
+        "operationId": "RemoveUserFromPlaylist",
+        "parameters": [
+          {
+            "name": "playlistId",
+            "in": "path",
+            "description": "The playlist id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "path",
+            "description": "The user id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "User permissions removed from playlist."
+          },
+          "403": {
+            "description": "Forbidden",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "No playlist or user permissions found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized access."
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/PlayingItems/{itemId}": {
+      "post": {
+        "tags": [
+          "Playstate"
+        ],
+        "summary": "Reports that a session has begun playing an item.",
+        "operationId": "OnPlaybackStart",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The id of the MediaSource.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioStreamIndex",
+            "in": "query",
+            "description": "The audio stream index.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleStreamIndex",
+            "in": "query",
+            "description": "The subtitle stream index.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "playMethod",
+            "in": "query",
+            "description": "The play method.",
+            "schema": {
+              "enum": [
+                "Transcode",
+                "DirectStream",
+                "DirectPlay"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/PlayMethod"
+                }
+              ]
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "canSeek",
+            "in": "query",
+            "description": "Indicates if the client can seek.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "Play start recorded."
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "delete": {
+        "tags": [
+          "Playstate"
+        ],
+        "summary": "Reports that a session has stopped playing an item.",
+        "operationId": "OnPlaybackStopped",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The id of the MediaSource.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "nextMediaType",
+            "in": "query",
+            "description": "The next media type that will play.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "positionTicks",
+            "in": "query",
+            "description": "Optional. The position, in ticks, where playback stopped. 1 tick = 10000 ms.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "Playback stop recorded."
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/PlayingItems/{itemId}/Progress": {
+      "post": {
+        "tags": [
+          "Playstate"
+        ],
+        "summary": "Reports a session's playback progress.",
+        "operationId": "OnPlaybackProgress",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The id of the MediaSource.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "positionTicks",
+            "in": "query",
+            "description": "Optional. The current position, in ticks. 1 tick = 10000 ms.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "audioStreamIndex",
+            "in": "query",
+            "description": "The audio stream index.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleStreamIndex",
+            "in": "query",
+            "description": "The subtitle stream index.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "volumeLevel",
+            "in": "query",
+            "description": "Scale of 0-100.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "playMethod",
+            "in": "query",
+            "description": "The play method.",
+            "schema": {
+              "enum": [
+                "Transcode",
+                "DirectStream",
+                "DirectPlay"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/PlayMethod"
+                }
+              ]
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "repeatMode",
+            "in": "query",
+            "description": "The repeat mode.",
+            "schema": {
+              "enum": [
+                "RepeatNone",
+                "RepeatAll",
+                "RepeatOne"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/RepeatMode"
+                }
+              ]
+            }
+          },
+          {
+            "name": "isPaused",
+            "in": "query",
+            "description": "Indicates if the player is paused.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          },
+          {
+            "name": "isMuted",
+            "in": "query",
+            "description": "Indicates if the player is muted.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          }
+        ],
+        "responses": {
+          "204": {
+            "description": "Play progress recorded."
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -31464,17 +30720,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStartInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStartInfo"
+                  }
+                ],
+                "description": "Class PlaybackStartInfo."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStartInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStartInfo"
+                  }
+                ],
+                "description": "Class PlaybackStartInfo."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStartInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStartInfo"
+                  }
+                ],
+                "description": "Class PlaybackStartInfo."
               }
             }
           }
@@ -31511,10 +30782,9 @@
             "name": "playSessionId",
             "in": "query",
             "description": "Playback session id.",
+            "required": true,
             "schema": {
-              "type": "string",
-              "description": "Playback session id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -31550,17 +30820,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackProgressInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackProgressInfo"
+                  }
+                ],
+                "description": "Class PlaybackProgressInfo."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackProgressInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackProgressInfo"
+                  }
+                ],
+                "description": "Class PlaybackProgressInfo."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackProgressInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackProgressInfo"
+                  }
+                ],
+                "description": "Class PlaybackProgressInfo."
               }
             }
           }
@@ -31597,17 +30882,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStopInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStopInfo"
+                  }
+                ],
+                "description": "Class PlaybackStopInfo."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStopInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStopInfo"
+                  }
+                ],
+                "description": "Class PlaybackStopInfo."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PlaybackStopInfo"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlaybackStopInfo"
+                  }
+                ],
+                "description": "Class PlaybackStopInfo."
               }
             }
           }
@@ -31632,7 +30932,7 @@
         ]
       }
     },
-    "/Users/{userId}/PlayedItems/{itemId}": {
+    "/UserPlayedItems/{itemId}": {
       "post": {
         "tags": [
           "Playstate"
@@ -31642,12 +30942,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -31658,7 +30956,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           },
@@ -31668,9 +30965,7 @@
             "description": "Optional. The date the item was played.",
             "schema": {
               "type": "string",
-              "description": "Optional. The date the item was played.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           }
         ],
@@ -31695,6 +30990,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -31719,12 +31034,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -31735,7 +31048,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -31761,388 +31073,26 @@
               }
             }
           },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/PlayingItems/{itemId}": {
-      "post": {
-        "tags": [
-          "Playstate"
-        ],
-        "summary": "Reports that a user has begun playing an item.",
-        "operationId": "OnPlaybackStart",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
             }
           },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The id of the MediaSource.",
-            "schema": {
-              "type": "string",
-              "description": "The id of the MediaSource.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioStreamIndex",
-            "in": "query",
-            "description": "The audio stream index.",
-            "schema": {
-              "type": "integer",
-              "description": "The audio stream index.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleStreamIndex",
-            "in": "query",
-            "description": "The subtitle stream index.",
-            "schema": {
-              "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playMethod",
-            "in": "query",
-            "description": "The play method.",
-            "schema": {
-              "$ref": "#/components/schemas/PlayMethod"
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "canSeek",
-            "in": "query",
-            "description": "Indicates if the client can seek.",
-            "schema": {
-              "type": "boolean",
-              "description": "Indicates if the client can seek.",
-              "default": false
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Play start recorded."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      },
-      "delete": {
-        "tags": [
-          "Playstate"
-        ],
-        "summary": "Reports that a user has stopped playing an item.",
-        "operationId": "OnPlaybackStopped",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The id of the MediaSource.",
-            "schema": {
-              "type": "string",
-              "description": "The id of the MediaSource.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "nextMediaType",
-            "in": "query",
-            "description": "The next media type that will play.",
-            "schema": {
-              "type": "string",
-              "description": "The next media type that will play.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "positionTicks",
-            "in": "query",
-            "description": "Optional. The position, in ticks, where playback stopped. 1 tick = 10000 ms.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The position, in ticks, where playback stopped. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Playback stop recorded."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/PlayingItems/{itemId}/Progress": {
-      "post": {
-        "tags": [
-          "Playstate"
-        ],
-        "summary": "Reports a user's playback progress.",
-        "operationId": "OnPlaybackProgress",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The id of the MediaSource.",
-            "schema": {
-              "type": "string",
-              "description": "The id of the MediaSource.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "positionTicks",
-            "in": "query",
-            "description": "Optional. The current position, in ticks. 1 tick = 10000 ms.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The current position, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioStreamIndex",
-            "in": "query",
-            "description": "The audio stream index.",
-            "schema": {
-              "type": "integer",
-              "description": "The audio stream index.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleStreamIndex",
-            "in": "query",
-            "description": "The subtitle stream index.",
-            "schema": {
-              "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "volumeLevel",
-            "in": "query",
-            "description": "Scale of 0-100.",
-            "schema": {
-              "type": "integer",
-              "description": "Scale of 0-100.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playMethod",
-            "in": "query",
-            "description": "The play method.",
-            "schema": {
-              "$ref": "#/components/schemas/PlayMethod"
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "repeatMode",
-            "in": "query",
-            "description": "The repeat mode.",
-            "schema": {
-              "$ref": "#/components/schemas/RepeatMode"
-            }
-          },
-          {
-            "name": "isPaused",
-            "in": "query",
-            "description": "Indicates if the player is paused.",
-            "schema": {
-              "type": "boolean",
-              "description": "Indicates if the player is paused.",
-              "default": false
-            }
-          },
-          {
-            "name": "isMuted",
-            "in": "query",
-            "description": "Indicates if the player is muted.",
-            "schema": {
-              "type": "boolean",
-              "description": "Indicates if the player is muted.",
-              "default": false
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Play progress recorded."
-          },
           "401": {
             "description": "Unauthorized"
           },
@@ -32206,7 +31156,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32227,7 +31177,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           }
@@ -32267,8 +31216,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32289,7 +31237,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           },
@@ -32299,7 +31246,7 @@
             "description": "Plugin version.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/Version"
+              "type": "string"
             }
           }
         ],
@@ -32337,8 +31284,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32359,7 +31305,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           },
@@ -32369,7 +31314,7 @@
             "description": "Plugin version.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/Version"
+              "type": "string"
             }
           }
         ],
@@ -32407,8 +31352,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32429,7 +31373,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           },
@@ -32439,7 +31382,7 @@
             "description": "Plugin version.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/Version"
+              "type": "string"
             }
           }
         ],
@@ -32477,8 +31420,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32499,7 +31441,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           },
@@ -32509,7 +31450,7 @@
             "description": "Plugin version.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/Version"
+              "type": "string"
             }
           }
         ],
@@ -32555,7 +31496,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32576,7 +31517,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           }
@@ -32632,7 +31572,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32652,7 +31592,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           }
@@ -32691,7 +31630,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32712,7 +31651,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Plugin id.",
               "format": "uuid"
             }
           }
@@ -32751,101 +31689,7 @@
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Plugins/SecurityInfo": {
-      "post": {
-        "tags": [
-          "Plugins"
-        ],
-        "summary": "Updates plugin security info.",
-        "operationId": "UpdatePluginSecurityInfo",
-        "requestBody": {
-          "description": "Plugin security info.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/PluginSecurityInfo"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/PluginSecurityInfo"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/PluginSecurityInfo"
-              }
-            }
-          },
-          "required": true
-        },
-        "responses": {
-          "204": {
-            "description": "Plugin security info updated."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "deprecated": true,
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation",
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/QuickConnect/Activate": {
-      "post": {
-        "tags": [
-          "QuickConnect"
-        ],
-        "summary": "Temporarily activates quick connect for five minutes.",
-        "operationId": "Activate",
-        "responses": {
-          "204": {
-            "description": "Quick connect has been temporarily activated."
-          },
-          "403": {
-            "description": "Quick connect is unavailable on this server.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -32857,16 +31701,24 @@
           "QuickConnect"
         ],
         "summary": "Authorizes a pending quick connect request.",
-        "operationId": "Authorize",
+        "operationId": "AuthorizeQuickConnect",
         "parameters": [
           {
             "name": "code",
             "in": "query",
             "description": "Quick connect code to authorize.",
             "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "The user the authorize. Access to the requested user is required.",
             "schema": {
               "type": "string",
-              "description": "Quick connect code to authorize."
+              "format": "uuid"
             }
           }
         ],
@@ -32924,50 +31776,13 @@
         ]
       }
     },
-    "/QuickConnect/Available": {
-      "post": {
-        "tags": [
-          "QuickConnect"
-        ],
-        "summary": "Enables or disables quick connect.",
-        "operationId": "Available",
-        "parameters": [
-          {
-            "name": "status",
-            "in": "query",
-            "description": "New MediaBrowser.Model.QuickConnect.QuickConnectState.",
-            "schema": {
-              "$ref": "#/components/schemas/QuickConnectState"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "Quick connect state set successfully."
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
-      }
-    },
     "/QuickConnect/Connect": {
       "get": {
         "tags": [
           "QuickConnect"
         ],
         "summary": "Attempts to retrieve authentication information.",
-        "operationId": "Connect",
+        "operationId": "GetQuickConnectState",
         "parameters": [
           {
             "name": "secret",
@@ -32975,8 +31790,7 @@
             "description": "Secret previously returned from the Initiate endpoint.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Secret previously returned from the Initiate endpoint."
+              "type": "string"
             }
           }
         ],
@@ -33024,60 +31838,44 @@
         }
       }
     },
-    "/QuickConnect/Deauthorize": {
-      "post": {
-        "tags": [
-          "QuickConnect"
-        ],
-        "summary": "Deauthorize all quick connect devices for the current user.",
-        "operationId": "Deauthorize",
-        "responses": {
-          "200": {
-            "description": "All quick connect devices were deleted.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "type": "integer",
-                  "format": "int32"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "type": "integer",
-                  "format": "int32"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "type": "integer",
-                  "format": "int32"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/QuickConnect/Initiate": {
+    "/QuickConnect/Enabled": {
       "get": {
+        "tags": [
+          "QuickConnect"
+        ],
+        "summary": "Gets the current quick connect state.",
+        "operationId": "GetQuickConnectEnabled",
+        "responses": {
+          "200": {
+            "description": "Quick connect state returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "type": "boolean"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "type": "boolean"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "type": "boolean"
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/QuickConnect/Initiate": {
+      "post": {
         "tags": [
           "QuickConnect"
         ],
         "summary": "Initiate a new quick connect request.",
-        "operationId": "Initiate",
+        "operationId": "InitiateQuickConnect",
         "responses": {
           "200": {
             "description": "Quick connect request successfully created.",
@@ -33105,97 +31903,6 @@
         }
       }
     },
-    "/QuickConnect/Status": {
-      "get": {
-        "tags": [
-          "QuickConnect"
-        ],
-        "summary": "Gets the current quick connect state.",
-        "operationId": "GetStatus",
-        "responses": {
-          "200": {
-            "description": "Quick connect state returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/QuickConnectState"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/QuickConnectState"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/QuickConnectState"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Images/Remote": {
-      "get": {
-        "tags": [
-          "RemoteImage"
-        ],
-        "summary": "Gets a remote image.",
-        "operationId": "GetRemoteImage",
-        "parameters": [
-          {
-            "name": "imageUrl",
-            "in": "query",
-            "description": "The image url.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The image url.",
-              "format": "uri"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Remote image returned.",
-            "content": {
-              "image/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "Remote image not found.",
-            "content": {
-              "application/octet-stream": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
     "/Items/{itemId}/RemoteImages": {
       "get": {
         "tags": [
@@ -33211,7 +31918,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item Id.",
               "format": "uuid"
             }
           },
@@ -33220,7 +31926,26 @@
             "in": "query",
             "description": "The image type.",
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ]
             }
           },
           {
@@ -33229,9 +31954,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -33240,9 +31963,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -33250,9 +31971,7 @@
             "in": "query",
             "description": "Optional. The image provider to use.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The image provider to use.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -33261,7 +31980,6 @@
             "description": "Optional. Include all languages.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Include all languages.",
               "default": false
             }
           }
@@ -33338,7 +32056,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item Id.",
               "format": "uuid"
             }
           },
@@ -33348,7 +32065,27 @@
             "description": "The image type.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/ImageType"
+              "enum": [
+                "Primary",
+                "Art",
+                "Backdrop",
+                "Banner",
+                "Logo",
+                "Thumb",
+                "Disc",
+                "Box",
+                "Screenshot",
+                "Menu",
+                "Chapter",
+                "BoxRear",
+                "Profile"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ImageType"
+                }
+              ],
+              "description": "Enum ImageType."
             }
           },
           {
@@ -33356,9 +32093,7 @@
             "in": "query",
             "description": "The image url.",
             "schema": {
-              "type": "string",
-              "description": "The image url.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -33417,7 +32152,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item Id.",
               "format": "uuid"
             }
           }
@@ -33501,9 +32235,7 @@
             "in": "query",
             "description": "Optional filter tasks that are hidden, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter tasks that are hidden, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -33511,9 +32243,7 @@
             "in": "query",
             "description": "Optional filter tasks that are enabled, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter tasks that are enabled, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -33577,8 +32307,7 @@
             "description": "Task Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Task Id."
+              "type": "string"
             }
           }
         ],
@@ -33653,8 +32382,7 @@
             "description": "Task Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Task Id."
+              "type": "string"
             }
           }
         ],
@@ -33666,8 +32394,7 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/TaskTriggerInfo"
-                },
-                "description": "Triggers."
+                }
               }
             },
             "text/json": {
@@ -33675,8 +32402,7 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/TaskTriggerInfo"
-                },
-                "description": "Triggers."
+                }
               }
             },
             "application/*+json": {
@@ -33684,8 +32410,7 @@
                 "type": "array",
                 "items": {
                   "$ref": "#/components/schemas/TaskTriggerInfo"
-                },
-                "description": "Triggers."
+                }
               }
             }
           },
@@ -33745,8 +32470,7 @@
             "description": "Task Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Task Id."
+              "type": "string"
             }
           }
         ],
@@ -33802,8 +32526,7 @@
             "description": "Task Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Task Id."
+              "type": "string"
             }
           }
         ],
@@ -33853,7 +32576,7 @@
           "Search"
         ],
         "summary": "Gets the search hint result.",
-        "operationId": "Get",
+        "operationId": "GetSearchHints",
         "parameters": [
           {
             "name": "startIndex",
@@ -33861,9 +32584,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -33872,9 +32593,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -33883,9 +32602,7 @@
             "description": "Optional. Supply a user id to search within a user's library or omit to search all.",
             "schema": {
               "type": "string",
-              "description": "Optional. Supply a user id to search within a user's library or omit to search all.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -33894,47 +32611,40 @@
             "description": "The search term to filter on.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The search term to filter on."
+              "type": "string"
             }
           },
           {
             "name": "includeItemTypes",
             "in": "query",
-            "description": "If specified, only results with the specified item types are returned. This allows multiple, comma delimeted.",
+            "description": "If specified, only results with the specified item types are returned. This allows multiple, comma delimited.",
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "If specified, only results with the specified item types are returned. This allows multiple, comma delimeted.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
             "name": "excludeItemTypes",
             "in": "query",
-            "description": "If specified, results with these item types are filtered out. This allows multiple, comma delimeted.",
+            "description": "If specified, results with these item types are filtered out. This allows multiple, comma delimited.",
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "If specified, results with these item types are filtered out. This allows multiple, comma delimeted.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
             "name": "mediaTypes",
             "in": "query",
-            "description": "If specified, only results with the specified media types are returned. This allows multiple, comma delimeted.",
+            "description": "If specified, only results with the specified media types are returned. This allows multiple, comma delimited.",
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "If specified, only results with the specified media types are returned. This allows multiple, comma delimeted.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -33943,9 +32653,7 @@
             "description": "If specified, only children of the parent are returned.",
             "schema": {
               "type": "string",
-              "description": "If specified, only children of the parent are returned.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -33953,9 +32661,7 @@
             "in": "query",
             "description": "Optional filter for movies.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter for movies.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -33963,9 +32669,7 @@
             "in": "query",
             "description": "Optional filter for series.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter for series.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -33973,9 +32677,7 @@
             "in": "query",
             "description": "Optional filter for news.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter for news.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -33983,9 +32685,7 @@
             "in": "query",
             "description": "Optional filter for kids.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter for kids.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -33993,9 +32693,7 @@
             "in": "query",
             "description": "Optional filter for sports.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter for sports.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -34004,7 +32702,6 @@
             "description": "Optional filter whether to include people.",
             "schema": {
               "type": "boolean",
-              "description": "Optional filter whether to include people.",
               "default": true
             }
           },
@@ -34014,7 +32711,6 @@
             "description": "Optional filter whether to include media.",
             "schema": {
               "type": "boolean",
-              "description": "Optional filter whether to include media.",
               "default": true
             }
           },
@@ -34024,7 +32720,6 @@
             "description": "Optional filter whether to include genres.",
             "schema": {
               "type": "boolean",
-              "description": "Optional filter whether to include genres.",
               "default": true
             }
           },
@@ -34034,7 +32729,6 @@
             "description": "Optional filter whether to include studios.",
             "schema": {
               "type": "boolean",
-              "description": "Optional filter whether to include studios.",
               "default": true
             }
           },
@@ -34044,7 +32738,6 @@
             "description": "Optional filter whether to include artists.",
             "schema": {
               "type": "boolean",
-              "description": "Optional filter whether to include artists.",
               "default": true
             }
           }
@@ -34206,9 +32899,7 @@
             "description": "Filter by sessions that a given user is allowed to remote control.",
             "schema": {
               "type": "string",
-              "description": "Filter by sessions that a given user is allowed to remote control.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -34216,9 +32907,7 @@
             "in": "query",
             "description": "Filter by device Id.",
             "schema": {
-              "type": "string",
-              "description": "Filter by device Id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -34227,9 +32916,7 @@
             "description": "Optional. Filter by sessions that were active in the last n seconds.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by sessions that were active in the last n seconds.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           }
         ],
@@ -34241,7 +32928,7 @@
                 "schema": {
                   "type": "array",
                   "items": {
-                    "$ref": "#/components/schemas/SessionInfo"
+                    "$ref": "#/components/schemas/SessionInfoDto"
                   }
                 }
               },
@@ -34249,7 +32936,7 @@
                 "schema": {
                   "type": "array",
                   "items": {
-                    "$ref": "#/components/schemas/SessionInfo"
+                    "$ref": "#/components/schemas/SessionInfoDto"
                   }
                 }
               },
@@ -34257,7 +32944,7 @@
                 "schema": {
                   "type": "array",
                   "items": {
-                    "$ref": "#/components/schemas/SessionInfo"
+                    "$ref": "#/components/schemas/SessionInfoDto"
                   }
                 }
               }
@@ -34293,8 +32980,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           }
         ],
@@ -34303,17 +32989,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/GeneralCommand"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GeneralCommand"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/GeneralCommand"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GeneralCommand"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/GeneralCommand"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/GeneralCommand"
+                  }
+                ]
               }
             }
           },
@@ -34353,8 +33051,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34363,7 +33060,57 @@
             "description": "The command to send.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/GeneralCommandType"
+              "enum": [
+                "MoveUp",
+                "MoveDown",
+                "MoveLeft",
+                "MoveRight",
+                "PageUp",
+                "PageDown",
+                "PreviousLetter",
+                "NextLetter",
+                "ToggleOsd",
+                "ToggleContextMenu",
+                "Select",
+                "Back",
+                "TakeScreenshot",
+                "SendKey",
+                "SendString",
+                "GoHome",
+                "GoToSettings",
+                "VolumeUp",
+                "VolumeDown",
+                "Mute",
+                "Unmute",
+                "ToggleMute",
+                "SetVolume",
+                "SetAudioStreamIndex",
+                "SetSubtitleStreamIndex",
+                "ToggleFullscreen",
+                "DisplayContent",
+                "GoToSearch",
+                "DisplayMessage",
+                "SetRepeatMode",
+                "ChannelUp",
+                "ChannelDown",
+                "Guide",
+                "ToggleStats",
+                "PlayMediaSource",
+                "PlayTrailers",
+                "SetShuffleQueue",
+                "PlayState",
+                "PlayNext",
+                "ToggleOsdMenu",
+                "Play",
+                "SetMaxStreamingBitrate",
+                "SetPlaybackOrder"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/GeneralCommandType"
+                }
+              ],
+              "description": "This exists simply to identify a set of known commands."
             }
           }
         ],
@@ -34401,42 +33148,43 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
-            }
-          },
-          {
-            "name": "text",
-            "in": "query",
-            "description": "The message test.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The message test."
-            }
-          },
-          {
-            "name": "header",
-            "in": "query",
-            "description": "The message header.",
-            "schema": {
-              "type": "string",
-              "description": "The message header.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "timeoutMs",
-            "in": "query",
-            "description": "The message timeout. If omitted the user will have to confirm viewing the message.",
-            "schema": {
-              "type": "integer",
-              "description": "The message timeout. If omitted the user will have to confirm viewing the message.",
-              "format": "int64",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
+        "requestBody": {
+          "description": "The MediaBrowser.Model.Session.MessageCommand object containing Header, Message Text, and TimeoutMs.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MessageCommand"
+                  }
+                ]
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MessageCommand"
+                  }
+                ]
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MessageCommand"
+                  }
+                ]
+              }
+            }
+          },
+          "required": true
+        },
         "responses": {
           "204": {
             "description": "Message sent."
@@ -34471,8 +33219,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34481,7 +33228,19 @@
             "description": "The type of play command to issue (PlayNow, PlayNext, PlayLast). Clients who have not yet implemented play next and play last may play now.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/PlayCommand"
+              "enum": [
+                "PlayNow",
+                "PlayNext",
+                "PlayLast",
+                "PlayInstantMix",
+                "PlayShuffle"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/PlayCommand"
+                }
+              ],
+              "description": "Enum PlayCommand."
             }
           },
           {
@@ -34494,8 +33253,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "The ids of the items to play, comma delimited."
+              }
             }
           },
           {
@@ -34504,9 +33262,7 @@
             "description": "The starting position of the first item.",
             "schema": {
               "type": "integer",
-              "description": "The starting position of the first item.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -34579,8 +33335,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34589,7 +33344,23 @@
             "description": "The MediaBrowser.Model.Session.PlaystateCommand.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/PlaystateCommand"
+              "enum": [
+                "Stop",
+                "Pause",
+                "Unpause",
+                "NextTrack",
+                "PreviousTrack",
+                "Seek",
+                "Rewind",
+                "FastForward",
+                "PlayPause"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/PlaystateCommand"
+                }
+              ],
+              "description": "Enum PlaystateCommand."
             }
           },
           {
@@ -34598,9 +33369,7 @@
             "description": "The optional position ticks.",
             "schema": {
               "type": "integer",
-              "description": "The optional position ticks.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -34608,9 +33377,7 @@
             "in": "query",
             "description": "The optional controlling user id.",
             "schema": {
-              "type": "string",
-              "description": "The optional controlling user id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -34648,8 +33415,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34658,7 +33424,57 @@
             "description": "The command to send.",
             "required": true,
             "schema": {
-              "$ref": "#/components/schemas/GeneralCommandType"
+              "enum": [
+                "MoveUp",
+                "MoveDown",
+                "MoveLeft",
+                "MoveRight",
+                "PageUp",
+                "PageDown",
+                "PreviousLetter",
+                "NextLetter",
+                "ToggleOsd",
+                "ToggleContextMenu",
+                "Select",
+                "Back",
+                "TakeScreenshot",
+                "SendKey",
+                "SendString",
+                "GoHome",
+                "GoToSettings",
+                "VolumeUp",
+                "VolumeDown",
+                "Mute",
+                "Unmute",
+                "ToggleMute",
+                "SetVolume",
+                "SetAudioStreamIndex",
+                "SetSubtitleStreamIndex",
+                "ToggleFullscreen",
+                "DisplayContent",
+                "GoToSearch",
+                "DisplayMessage",
+                "SetRepeatMode",
+                "ChannelUp",
+                "ChannelDown",
+                "Guide",
+                "ToggleStats",
+                "PlayMediaSource",
+                "PlayTrailers",
+                "SetShuffleQueue",
+                "PlayState",
+                "PlayNext",
+                "ToggleOsdMenu",
+                "Play",
+                "SetMaxStreamingBitrate",
+                "SetPlaybackOrder"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/GeneralCommandType"
+                }
+              ],
+              "description": "This exists simply to identify a set of known commands."
             }
           }
         ],
@@ -34696,8 +33512,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34707,7 +33522,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
@@ -34744,8 +33558,7 @@
             "description": "The session id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session id."
+              "type": "string"
             }
           },
           {
@@ -34755,7 +33568,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
@@ -34794,8 +33606,7 @@
             "description": "The session Id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The session Id."
+              "type": "string"
             }
           },
           {
@@ -34804,8 +33615,51 @@
             "description": "The type of item to browse to.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The type of item to browse to."
+              "enum": [
+                "AggregateFolder",
+                "Audio",
+                "AudioBook",
+                "BasePluginFolder",
+                "Book",
+                "BoxSet",
+                "Channel",
+                "ChannelFolderItem",
+                "CollectionFolder",
+                "Episode",
+                "Folder",
+                "Genre",
+                "ManualPlaylistsFolder",
+                "Movie",
+                "LiveTvChannel",
+                "LiveTvProgram",
+                "MusicAlbum",
+                "MusicArtist",
+                "MusicGenre",
+                "MusicVideo",
+                "Person",
+                "Photo",
+                "PhotoAlbum",
+                "Playlist",
+                "PlaylistsFolder",
+                "Program",
+                "Recording",
+                "Season",
+                "Series",
+                "Studio",
+                "Trailer",
+                "TvChannel",
+                "TvProgram",
+                "UserRootFolder",
+                "UserView",
+                "Video",
+                "Year"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/BaseItemKind"
+                }
+              ],
+              "description": "The base item kind."
             }
           },
           {
@@ -34814,8 +33668,7 @@
             "description": "The Id of the item.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The Id of the item."
+              "type": "string"
             }
           },
           {
@@ -34824,8 +33677,7 @@
             "description": "The name of the item.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The name of the item."
+              "type": "string"
             }
           }
         ],
@@ -34862,9 +33714,7 @@
             "in": "query",
             "description": "The session id.",
             "schema": {
-              "type": "string",
-              "description": "The session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -34874,10 +33724,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "A list of playable media types, comma delimited. Audio, Video, Book, Photo.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -34888,9 +33736,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/GeneralCommandType"
-              },
-              "description": "A list of supported remote control commands, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -34899,17 +33745,6 @@
             "description": "Determines whether media can be played remotely..",
             "schema": {
               "type": "boolean",
-              "description": "Determines whether media can be played remotely..",
-              "default": false
-            }
-          },
-          {
-            "name": "supportsSync",
-            "in": "query",
-            "description": "Determines whether sync is supported.",
-            "schema": {
-              "type": "boolean",
-              "description": "Determines whether sync is supported.",
               "default": false
             }
           },
@@ -34919,7 +33754,6 @@
             "description": "Determines whether the device supports a unique identifier.",
             "schema": {
               "type": "boolean",
-              "description": "Determines whether the device supports a unique identifier.",
               "default": true
             }
           }
@@ -34957,9 +33791,7 @@
             "in": "query",
             "description": "The session id.",
             "schema": {
-              "type": "string",
-              "description": "The session id.",
-              "nullable": true
+              "type": "string"
             }
           }
         ],
@@ -34968,17 +33800,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                  }
+                ],
+                "description": "Client capabilities dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                  }
+                ],
+                "description": "Client capabilities dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ClientCapabilitiesDto"
+                  }
+                ],
+                "description": "Client capabilities dto."
               }
             }
           },
@@ -35044,9 +33891,7 @@
             "in": "query",
             "description": "The session id.",
             "schema": {
-              "type": "string",
-              "description": "The session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -35055,8 +33900,7 @@
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           }
         ],
@@ -35101,7 +33945,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35145,7 +33990,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35161,17 +34007,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupConfigurationDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupConfigurationDto"
+                  }
+                ],
+                "description": "The startup configuration DTO."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupConfigurationDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupConfigurationDto"
+                  }
+                ],
+                "description": "The startup configuration DTO."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupConfigurationDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupConfigurationDto"
+                  }
+                ],
+                "description": "The startup configuration DTO."
               }
             }
           },
@@ -35191,7 +34052,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35235,7 +34097,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35253,17 +34116,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                  }
+                ],
+                "description": "Startup remote access dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                  }
+                ],
+                "description": "Startup remote access dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupRemoteAccessDto"
+                  }
+                ],
+                "description": "Startup remote access dto."
               }
             }
           },
@@ -35283,7 +34161,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35327,7 +34206,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35343,17 +34223,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupUserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupUserDto"
+                  }
+                ],
+                "description": "The startup user DTO."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupUserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupUserDto"
+                  }
+                ],
+                "description": "The startup user DTO."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/StartupUserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/StartupUserDto"
+                  }
+                ],
+                "description": "The startup user DTO."
               }
             }
           }
@@ -35372,7 +34267,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrElevated"
+              "FirstTimeSetupOrElevated",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -35392,9 +34288,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -35403,9 +34297,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -35413,9 +34305,7 @@
             "in": "query",
             "description": "Optional. Search term.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -35424,9 +34314,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -35437,9 +34325,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -35449,10 +34335,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered out based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -35462,10 +34346,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -35473,9 +34355,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -35483,9 +34363,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -35494,9 +34372,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -35507,9 +34383,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -35518,9 +34392,7 @@
             "description": "User id.",
             "schema": {
               "type": "string",
-              "description": "User id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -35528,9 +34400,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -35538,9 +34408,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -35548,9 +34416,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -35559,9 +34425,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -35570,7 +34434,6 @@
             "description": "Total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Total record count.",
               "default": true
             }
           }
@@ -35626,8 +34489,7 @@
             "description": "Studio name.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Studio name."
+              "type": "string"
             }
           },
           {
@@ -35636,9 +34498,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -35746,8 +34606,7 @@
             "description": "The name of the fallback font file to get.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The name of the fallback font file to get."
+              "type": "string"
             }
           }
         ],
@@ -35794,7 +34653,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -35804,8 +34662,7 @@
             "description": "The language of the subtitles.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The language of the subtitles."
+              "type": "string"
             }
           },
           {
@@ -35813,9 +34670,7 @@
             "in": "query",
             "description": "Optional. Only show subtitles which are a perfect match.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Only show subtitles which are a perfect match.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -35849,6 +34704,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -35859,6 +34734,7 @@
         "security": [
           {
             "CustomAuthentication": [
+              "SubtitleManagement",
               "DefaultAuthorization"
             ]
           }
@@ -35880,7 +34756,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -35890,8 +34765,7 @@
             "description": "The subtitle id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The subtitle id."
+              "type": "string"
             }
           }
         ],
@@ -35899,6 +34773,26 @@
           "204": {
             "description": "Subtitle downloaded."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -35909,13 +34803,14 @@
         "security": [
           {
             "CustomAuthentication": [
+              "SubtitleManagement",
               "DefaultAuthorization"
             ]
           }
         ]
       }
     },
-    "/Providers/Subtitles/Subtitles/{id}": {
+    "/Providers/Subtitles/Subtitles/{subtitleId}": {
       "get": {
         "tags": [
           "Subtitle"
@@ -35924,13 +34819,12 @@
         "operationId": "GetRemoteSubtitles",
         "parameters": [
           {
-            "name": "id",
+            "name": "subtitleId",
             "in": "path",
             "description": "The item id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The item id."
+              "type": "string"
             }
           }
         ],
@@ -35956,228 +34850,13 @@
         "security": [
           {
             "CustomAuthentication": [
+              "SubtitleManagement",
               "DefaultAuthorization"
             ]
           }
         ]
       }
     },
-    "/Videos/{itemId}/{mediaSourceId}/Subtitles/{index}/{startPositionTicks}/Stream.{format}": {
-      "get": {
-        "tags": [
-          "Subtitle"
-        ],
-        "summary": "Gets subtitles in a specified format.",
-        "operationId": "GetSubtitleWithTicks",
-        "parameters": [
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "path",
-            "description": "The media source id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The media source id."
-            }
-          },
-          {
-            "name": "index",
-            "in": "path",
-            "description": "The subtitle stream index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32"
-            }
-          },
-          {
-            "name": "startPositionTicks",
-            "in": "path",
-            "description": "Optional. The start position of the subtitle in ticks.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The start position of the subtitle in ticks.",
-              "format": "int64"
-            }
-          },
-          {
-            "name": "format",
-            "in": "path",
-            "description": "The format of the returned subtitle.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The format of the returned subtitle."
-            }
-          },
-          {
-            "name": "endPositionTicks",
-            "in": "query",
-            "description": "Optional. The end position of the subtitle in ticks.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The end position of the subtitle in ticks.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "copyTimestamps",
-            "in": "query",
-            "description": "Optional. Whether to copy the timestamps.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to copy the timestamps.",
-              "default": false
-            }
-          },
-          {
-            "name": "addVttTimeMap",
-            "in": "query",
-            "description": "Optional. Whether to add a VTT time map.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to add a VTT time map.",
-              "default": false
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "File returned.",
-            "content": {
-              "text/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
-    "/Videos/{itemId}/{mediaSourceId}/Subtitles/{index}/Stream.{format}": {
-      "get": {
-        "tags": [
-          "Subtitle"
-        ],
-        "summary": "Gets subtitles in a specified format.",
-        "operationId": "GetSubtitle",
-        "parameters": [
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "path",
-            "description": "The media source id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The media source id."
-            }
-          },
-          {
-            "name": "index",
-            "in": "path",
-            "description": "The subtitle stream index.",
-            "required": true,
-            "schema": {
-              "type": "integer",
-              "description": "The subtitle stream index.",
-              "format": "int32"
-            }
-          },
-          {
-            "name": "format",
-            "in": "path",
-            "description": "The format of the returned subtitle.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The format of the returned subtitle."
-            }
-          },
-          {
-            "name": "endPositionTicks",
-            "in": "query",
-            "description": "Optional. The end position of the subtitle in ticks.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The end position of the subtitle in ticks.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "copyTimestamps",
-            "in": "query",
-            "description": "Optional. Whether to copy the timestamps.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to copy the timestamps.",
-              "default": false
-            }
-          },
-          {
-            "name": "addVttTimeMap",
-            "in": "query",
-            "description": "Optional. Whether to add a VTT time map.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to add a VTT time map.",
-              "default": false
-            }
-          },
-          {
-            "name": "startPositionTicks",
-            "in": "query",
-            "description": "Optional. The start position of the subtitle in ticks.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The start position of the subtitle in ticks.",
-              "format": "int64",
-              "default": 0
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "File returned.",
-            "content": {
-              "text/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
     "/Videos/{itemId}/{mediaSourceId}/Subtitles/{index}/subtitles.m3u8": {
       "get": {
         "tags": [
@@ -36193,7 +34872,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -36204,7 +34882,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The subtitle stream index.",
               "format": "int32"
             }
           },
@@ -36214,8 +34891,7 @@
             "description": "The media source id.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The media source id."
+              "type": "string"
             }
           },
           {
@@ -36225,7 +34901,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The subtitle segment length.",
               "format": "int32"
             }
           }
@@ -36242,6 +34917,26 @@
               }
             }
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -36273,7 +34968,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item the subtitle belongs to.",
               "format": "uuid"
             }
           }
@@ -36283,17 +34977,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/UploadSubtitleDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UploadSubtitleDto"
+                  }
+                ],
+                "description": "Upload subtitles dto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/UploadSubtitleDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UploadSubtitleDto"
+                  }
+                ],
+                "description": "Upload subtitles dto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/UploadSubtitleDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UploadSubtitleDto"
+                  }
+                ],
+                "description": "Upload subtitles dto."
               }
             }
           },
@@ -36303,6 +35012,26 @@
           "204": {
             "description": "Subtitle uploaded."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -36313,7 +35042,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "RequiresElevation"
+              "SubtitleManagement",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36334,7 +35064,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -36345,7 +35074,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The index of the subtitle file.",
               "format": "int32"
             }
           }
@@ -36390,7 +35118,291 @@
         ]
       }
     },
-    "/Users/{userId}/Suggestions": {
+    "/Videos/{routeItemId}/{routeMediaSourceId}/Subtitles/{routeIndex}/{routeStartPositionTicks}/Stream.{routeFormat}": {
+      "get": {
+        "tags": [
+          "Subtitle"
+        ],
+        "summary": "Gets subtitles in a specified format.",
+        "operationId": "GetSubtitleWithTicks",
+        "parameters": [
+          {
+            "name": "routeItemId",
+            "in": "path",
+            "description": "The (route) item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "routeMediaSourceId",
+            "in": "path",
+            "description": "The (route) media source id.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "routeIndex",
+            "in": "path",
+            "description": "The (route) subtitle stream index.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "routeStartPositionTicks",
+            "in": "path",
+            "description": "The (route) start position of the subtitle in ticks.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "routeFormat",
+            "in": "path",
+            "description": "The (route) format of the returned subtitle.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "query",
+            "description": "The item id.",
+            "deprecated": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media source id.",
+            "deprecated": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "index",
+            "in": "query",
+            "description": "The subtitle stream index.",
+            "deprecated": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "startPositionTicks",
+            "in": "query",
+            "description": "The start position of the subtitle in ticks.",
+            "deprecated": true,
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "format",
+            "in": "query",
+            "description": "The format of the returned subtitle.",
+            "deprecated": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "endPositionTicks",
+            "in": "query",
+            "description": "Optional. The end position of the subtitle in ticks.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "copyTimestamps",
+            "in": "query",
+            "description": "Optional. Whether to copy the timestamps.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          },
+          {
+            "name": "addVttTimeMap",
+            "in": "query",
+            "description": "Optional. Whether to add a VTT time map.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "File returned.",
+            "content": {
+              "text/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/Videos/{routeItemId}/{routeMediaSourceId}/Subtitles/{routeIndex}/Stream.{routeFormat}": {
+      "get": {
+        "tags": [
+          "Subtitle"
+        ],
+        "summary": "Gets subtitles in a specified format.",
+        "operationId": "GetSubtitle",
+        "parameters": [
+          {
+            "name": "routeItemId",
+            "in": "path",
+            "description": "The (route) item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "routeMediaSourceId",
+            "in": "path",
+            "description": "The (route) media source id.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "routeIndex",
+            "in": "path",
+            "description": "The (route) subtitle stream index.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "routeFormat",
+            "in": "path",
+            "description": "The (route) format of the returned subtitle.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "query",
+            "description": "The item id.",
+            "deprecated": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media source id.",
+            "deprecated": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "index",
+            "in": "query",
+            "description": "The subtitle stream index.",
+            "deprecated": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "format",
+            "in": "query",
+            "description": "The format of the returned subtitle.",
+            "deprecated": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "endPositionTicks",
+            "in": "query",
+            "description": "Optional. The end position of the subtitle in ticks.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "copyTimestamps",
+            "in": "query",
+            "description": "Optional. Whether to copy the timestamps.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          },
+          {
+            "name": "addVttTimeMap",
+            "in": "query",
+            "description": "Optional. Whether to add a VTT time map.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          },
+          {
+            "name": "startPositionTicks",
+            "in": "query",
+            "description": "The start position of the subtitle in ticks.",
+            "schema": {
+              "type": "integer",
+              "format": "int64",
+              "default": 0
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "File returned.",
+            "content": {
+              "text/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/Items/Suggestions": {
       "get": {
         "tags": [
           "Suggestions"
@@ -36400,12 +35412,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "The user id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           },
@@ -36416,10 +35426,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "The media types.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -36429,10 +35437,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "The type.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -36441,9 +35447,7 @@
             "description": "Optional. The start index.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The start index.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -36452,9 +35456,7 @@
             "description": "Optional. The limit.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -36463,7 +35465,6 @@
             "description": "Whether to enable the total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to enable the total record count.",
               "default": false
             }
           }
@@ -36517,17 +35518,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/BufferRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BufferRequestDto"
+                  }
+                ],
+                "description": "Class BufferRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/BufferRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BufferRequestDto"
+                  }
+                ],
+                "description": "Class BufferRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/BufferRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/BufferRequestDto"
+                  }
+                ],
+                "description": "Class BufferRequestDto."
               }
             }
           },
@@ -36548,7 +35564,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36566,17 +35583,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/JoinGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/JoinGroupRequestDto"
+                  }
+                ],
+                "description": "Class JoinGroupRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/JoinGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/JoinGroupRequestDto"
+                  }
+                ],
+                "description": "Class JoinGroupRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/JoinGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/JoinGroupRequestDto"
+                  }
+                ],
+                "description": "Class JoinGroupRequestDto."
               }
             }
           },
@@ -36597,7 +35629,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayJoinGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36625,7 +35658,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36679,7 +35713,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayJoinGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36697,17 +35732,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class MovePlaylistItemRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class MovePlaylistItemRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/MovePlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class MovePlaylistItemRequestDto."
               }
             }
           },
@@ -36728,7 +35778,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36746,17 +35797,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/NewGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NewGroupRequestDto"
+                  }
+                ],
+                "description": "Class NewGroupRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/NewGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NewGroupRequestDto"
+                  }
+                ],
+                "description": "Class NewGroupRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/NewGroupRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NewGroupRequestDto"
+                  }
+                ],
+                "description": "Class NewGroupRequestDto."
               }
             }
           },
@@ -36777,7 +35843,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayCreateGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36795,17 +35862,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/NextItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NextItemRequestDto"
+                  }
+                ],
+                "description": "Class NextItemRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/NextItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NextItemRequestDto"
+                  }
+                ],
+                "description": "Class NextItemRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/NextItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/NextItemRequestDto"
+                  }
+                ],
+                "description": "Class NextItemRequestDto."
               }
             }
           },
@@ -36826,7 +35908,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36854,7 +35937,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36872,17 +35956,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PingRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PingRequestDto"
+                  }
+                ],
+                "description": "Class PingRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PingRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PingRequestDto"
+                  }
+                ],
+                "description": "Class PingRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PingRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PingRequestDto"
+                  }
+                ],
+                "description": "Class PingRequestDto."
               }
             }
           },
@@ -36902,7 +36001,8 @@
         "security": [
           {
             "CustomAuthentication": [
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36920,17 +36020,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PreviousItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PreviousItemRequestDto"
+                  }
+                ],
+                "description": "Class PreviousItemRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PreviousItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PreviousItemRequestDto"
+                  }
+                ],
+                "description": "Class PreviousItemRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PreviousItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PreviousItemRequestDto"
+                  }
+                ],
+                "description": "Class PreviousItemRequestDto."
               }
             }
           },
@@ -36951,7 +36066,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -36969,17 +36085,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/QueueRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QueueRequestDto"
+                  }
+                ],
+                "description": "Class QueueRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/QueueRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QueueRequestDto"
+                  }
+                ],
+                "description": "Class QueueRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/QueueRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QueueRequestDto"
+                  }
+                ],
+                "description": "Class QueueRequestDto."
               }
             }
           },
@@ -37000,7 +36131,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37018,17 +36150,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ReadyRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ReadyRequestDto"
+                  }
+                ],
+                "description": "Class ReadyRequest."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ReadyRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ReadyRequestDto"
+                  }
+                ],
+                "description": "Class ReadyRequest."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ReadyRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ReadyRequestDto"
+                  }
+                ],
+                "description": "Class ReadyRequest."
               }
             }
           },
@@ -37049,7 +36196,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37067,17 +36215,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                  }
+                ],
+                "description": "Class RemoveFromPlaylistRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                  }
+                ],
+                "description": "Class RemoveFromPlaylistRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/RemoveFromPlaylistRequestDto"
+                  }
+                ],
+                "description": "Class RemoveFromPlaylistRequestDto."
               }
             }
           },
@@ -37098,7 +36261,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37116,17 +36280,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeekRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeekRequestDto"
+                  }
+                ],
+                "description": "Class SeekRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SeekRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeekRequestDto"
+                  }
+                ],
+                "description": "Class SeekRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SeekRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SeekRequestDto"
+                  }
+                ],
+                "description": "Class SeekRequestDto."
               }
             }
           },
@@ -37147,7 +36326,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37165,17 +36345,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                  }
+                ],
+                "description": "Class IgnoreWaitRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                  }
+                ],
+                "description": "Class IgnoreWaitRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/IgnoreWaitRequestDto"
+                  }
+                ],
+                "description": "Class IgnoreWaitRequestDto."
               }
             }
           },
@@ -37196,7 +36391,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37214,17 +36410,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlayRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlayRequestDto"
+                  }
+                ],
+                "description": "Class PlayRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/PlayRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlayRequestDto"
+                  }
+                ],
+                "description": "Class PlayRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/PlayRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/PlayRequestDto"
+                  }
+                ],
+                "description": "Class PlayRequestDto."
               }
             }
           },
@@ -37245,7 +36456,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37263,17 +36475,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class SetPlaylistItemRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class SetPlaylistItemRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetPlaylistItemRequestDto"
+                  }
+                ],
+                "description": "Class SetPlaylistItemRequestDto."
               }
             }
           },
@@ -37294,7 +36521,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37312,17 +36540,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                  }
+                ],
+                "description": "Class SetRepeatModeRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                  }
+                ],
+                "description": "Class SetRepeatModeRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetRepeatModeRequestDto"
+                  }
+                ],
+                "description": "Class SetRepeatModeRequestDto."
               }
             }
           },
@@ -37343,7 +36586,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37361,17 +36605,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                  }
+                ],
+                "description": "Class SetShuffleModeRequestDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                  }
+                ],
+                "description": "Class SetShuffleModeRequestDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/SetShuffleModeRequestDto"
+                  }
+                ],
+                "description": "Class SetShuffleModeRequestDto."
               }
             }
           },
@@ -37392,7 +36651,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37420,7 +36680,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37448,7 +36709,8 @@
           {
             "CustomAuthentication": [
               "SyncPlayIsInGroup",
-              "SyncPlayHasAccess"
+              "SyncPlayHasAccess",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37482,11 +36744,28 @@
               }
             }
           },
+          "403": {
+            "description": "User does not have permission to get endpoint information.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -37526,17 +36805,35 @@
               }
             }
           },
+          "403": {
+            "description": "User does not have permission to retrieve information.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
           {
             "CustomAuthentication": [
-              "FirstTimeSetupOrIgnoreParentalControl"
+              "FirstTimeSetupOrIgnoreParentalControl",
+              "DefaultAuthorization"
             ]
           }
         ]
@@ -37610,11 +36907,28 @@
               }
             }
           },
+          "403": {
+            "description": "User does not have permission to get server logs.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -37640,8 +36954,7 @@
             "description": "The name of the log file to get.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "The name of the log file to get."
+              "type": "string"
             }
           }
         ],
@@ -37657,11 +36970,48 @@
               }
             }
           },
+          "403": {
+            "description": "User does not have permission to get log files.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Could not find a log file with the name.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -37744,11 +37094,28 @@
           "204": {
             "description": "Server restarted."
           },
+          "403": {
+            "description": "User does not have permission to restart server.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -37771,11 +37138,28 @@
           "204": {
             "description": "Server shut down."
           },
+          "403": {
+            "description": "User does not have permission to shutdown server.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
           }
         },
         "security": [
@@ -37831,6 +37215,7 @@
             "description": "Forbidden"
           }
         },
+        "deprecated": true,
         "security": [
           {
             "CustomAuthentication": [
@@ -37871,6 +37256,40 @@
         }
       }
     },
+    "/Tmdb/ClientConfiguration": {
+      "get": {
+        "tags": [
+          "Tmdb"
+        ],
+        "summary": "Gets the TMDb image configuration options.",
+        "operationId": "TmdbClientConfiguration",
+        "responses": {
+          "200": {
+            "description": "Success",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ConfigImageTypes"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Trailers": {
       "get": {
         "tags": [
@@ -37882,12 +37301,10 @@
           {
             "name": "userId",
             "in": "query",
-            "description": "The user id.",
+            "description": "The user id supplied as query parameter; this is required when not using an API key.",
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -37895,9 +37312,7 @@
             "in": "query",
             "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by maximum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -37905,9 +37320,7 @@
             "in": "query",
             "description": "Optional filter by items with theme songs.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme songs.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37915,9 +37328,7 @@
             "in": "query",
             "description": "Optional filter by items with theme videos.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with theme videos.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37925,9 +37336,7 @@
             "in": "query",
             "description": "Optional filter by items with subtitles.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with subtitles.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37935,9 +37344,7 @@
             "in": "query",
             "description": "Optional filter by items with special features.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with special features.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37945,9 +37352,7 @@
             "in": "query",
             "description": "Optional filter by items with trailers.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items with trailers.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37956,8 +37361,7 @@
             "description": "Optional. Return items that are siblings of a supplied item.",
             "schema": {
               "type": "string",
-              "description": "Optional. Return items that are siblings of a supplied item.",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -37966,9 +37370,7 @@
             "description": "Optional filter by parent index number.",
             "schema": {
               "type": "integer",
-              "description": "Optional filter by parent index number.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -37976,9 +37378,7 @@
             "in": "query",
             "description": "Optional filter by items that have or do not have a parental rating.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have or do not have a parental rating.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37986,9 +37386,7 @@
             "in": "query",
             "description": "Optional filter by items that are HD or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are HD or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -37996,9 +37394,7 @@
             "in": "query",
             "description": "Optional filter by items that are 4K or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 4K or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38009,9 +37405,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on LocationType. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38022,9 +37416,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/LocationType"
-              },
-              "description": "Optional. If specified, results will be filtered based on the LocationType. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38032,9 +37424,7 @@
             "in": "query",
             "description": "Optional filter by items that are missing episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are missing episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38042,9 +37432,7 @@
             "in": "query",
             "description": "Optional filter by items that are unaired episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are unaired episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38053,9 +37441,7 @@
             "description": "Optional filter by minimum community rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum community rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -38064,9 +37450,7 @@
             "description": "Optional filter by minimum critic rating.",
             "schema": {
               "type": "number",
-              "description": "Optional filter by minimum critic rating.",
-              "format": "double",
-              "nullable": true
+              "format": "double"
             }
           },
           {
@@ -38075,9 +37459,7 @@
             "description": "Optional. The minimum premiere date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -38086,9 +37468,7 @@
             "description": "Optional. The minimum last saved date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum last saved date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -38097,9 +37477,7 @@
             "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The minimum last saved date for the current user. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -38108,9 +37486,7 @@
             "description": "Optional. The maximum premiere date. Format = ISO.",
             "schema": {
               "type": "string",
-              "description": "Optional. The maximum premiere date. Format = ISO.",
-              "format": "date-time",
-              "nullable": true
+              "format": "date-time"
             }
           },
           {
@@ -38118,39 +37494,71 @@
             "in": "query",
             "description": "Optional filter by items that have an overview or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an overview or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasImdbId",
             "in": "query",
-            "description": "Optional filter by items that have an imdb id or not.",
+            "description": "Optional filter by items that have an IMDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have an imdb id or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasTmdbId",
             "in": "query",
-            "description": "Optional filter by items that have a tmdb id or not.",
+            "description": "Optional filter by items that have a TMDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tmdb id or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "hasTvdbId",
             "in": "query",
-            "description": "Optional filter by items that have a tvdb id or not.",
+            "description": "Optional filter by items that have a TVDb id or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have a tvdb id or not.",
-              "nullable": true
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isMovie",
+            "in": "query",
+            "description": "Optional filter for live tv movies.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isSeries",
+            "in": "query",
+            "description": "Optional filter for live tv series.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isNews",
+            "in": "query",
+            "description": "Optional filter for live tv news.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isKids",
+            "in": "query",
+            "description": "Optional filter for live tv kids.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "isSports",
+            "in": "query",
+            "description": "Optional filter for live tv sports.",
+            "schema": {
+              "type": "boolean"
             }
           },
           {
@@ -38162,9 +37570,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered by excluding item ids. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38173,9 +37579,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38184,9 +37588,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38194,9 +37596,7 @@
             "in": "query",
             "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "When searching within folders, this determines whether or not the search will be recursive. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38204,19 +37604,18 @@
             "in": "query",
             "description": "Optional. Filter based on a search term.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Filter based on a search term.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "sortOrder",
             "in": "query",
-            "description": "Sort Order - Ascending,Descending.",
+            "description": "Sort Order - Ascending, Descending.",
             "schema": {
-              "type": "string",
-              "description": "Sort Order - Ascending,Descending.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -38225,9 +37624,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -38238,9 +37635,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38250,10 +37645,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -38264,9 +37657,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFilter"
-              },
-              "description": "Optional. Specify additional filters to apply. This allows multiple, comma delimited. Options: IsFolder, IsNotFolder, IsUnplayed, IsPlayed, IsFavorite, IsResumable, Likes, Dislikes.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38274,9 +37665,7 @@
             "in": "query",
             "description": "Optional filter by items that are marked as favorite, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are marked as favorite, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38286,10 +37675,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -38300,9 +37687,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. If specified, results will be filtered based on those containing image types. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38310,9 +37695,10 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -38320,9 +37706,7 @@
             "in": "query",
             "description": "Optional filter by items that are played, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are played, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38333,9 +37717,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38346,9 +37728,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on OfficialRating. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38359,9 +37739,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on tag. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38373,9 +37751,7 @@
               "items": {
                 "type": "integer",
                 "format": "int32"
-              },
-              "description": "Optional. If specified, results will be filtered based on production year. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38383,9 +37759,7 @@
             "in": "query",
             "description": "Optional, include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38394,9 +37768,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38407,9 +37779,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38417,9 +37787,7 @@
             "in": "query",
             "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
             "schema": {
-              "type": "string",
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -38431,9 +37799,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified person id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38444,9 +37810,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, along with Person, results will be filtered to include only those containing the specified person and PersonType. Allows multiple, comma-delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38457,9 +37821,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38470,9 +37832,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on artists. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38484,9 +37844,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on artist id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38498,9 +37856,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38512,9 +37868,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified album artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38526,9 +37880,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered to include only those containing the specified contributing artist id.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38539,9 +37891,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on album. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38553,9 +37903,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on album id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38567,9 +37915,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specific items are needed, specify a list of item id's to retrieve. This allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38580,9 +37926,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/VideoType"
-              },
-              "description": "Optional filter by VideoType (videofile, dvd, bluray, iso). Allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38590,9 +37934,7 @@
             "in": "query",
             "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by minimum official rating (PG, PG-13, TV-MA, etc).",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -38600,9 +37942,7 @@
             "in": "query",
             "description": "Optional filter by items that are locked.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are locked.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38610,9 +37950,7 @@
             "in": "query",
             "description": "Optional filter by items that are placeholders.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are placeholders.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38620,9 +37958,7 @@
             "in": "query",
             "description": "Optional filter by items that have official ratings.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that have official ratings.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38630,9 +37966,7 @@
             "in": "query",
             "description": "Whether or not to hide items behind their boxsets.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to hide items behind their boxsets.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38641,9 +37975,7 @@
             "description": "Optional. Filter by the minimum width of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the minimum width of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38652,9 +37984,7 @@
             "description": "Optional. Filter by the minimum height of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the minimum height of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38663,9 +37993,7 @@
             "description": "Optional. Filter by the maximum width of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the maximum width of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38674,9 +38002,7 @@
             "description": "Optional. Filter by the maximum height of the item.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Filter by the maximum height of the item.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38684,9 +38010,7 @@
             "in": "query",
             "description": "Optional filter by items that are 3D, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by items that are 3D, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38697,9 +38021,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/SeriesStatus"
-              },
-              "description": "Optional filter by Series Status. Allows multiple, comma delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38707,9 +38029,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally or greater than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -38717,9 +38037,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is sorted equally than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is sorted equally than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -38727,9 +38045,7 @@
             "in": "query",
             "description": "Optional filter by items whose name is equally or lesser than a given input string.",
             "schema": {
-              "type": "string",
-              "description": "Optional filter by items whose name is equally or lesser than a given input string.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -38741,9 +38057,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on studio id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38755,9 +38069,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Optional. If specified, results will be filtered based on genre id. This allows multiple, pipe delimited.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38766,7 +38078,6 @@
             "description": "Optional. Enable the total record count.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Enable the total record count.",
               "default": true
             }
           },
@@ -38776,9 +38087,7 @@
             "description": "Optional, include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           }
         ],
@@ -38819,6 +38128,188 @@
         ]
       }
     },
+    "/Videos/{itemId}/Trickplay/{width}/{index}.jpg": {
+      "get": {
+        "tags": [
+          "Trickplay"
+        ],
+        "summary": "Gets a trickplay tile image.",
+        "operationId": "GetTrickplayTileImage",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "width",
+            "in": "path",
+            "description": "The width of a single tile.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "index",
+            "in": "path",
+            "description": "The index of the desired tile.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media version id, if using an alternate version.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Tile image not found at specified index.",
+            "content": {
+              "image/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Not Found",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/Videos/{itemId}/Trickplay/{width}/tiles.m3u8": {
+      "get": {
+        "tags": [
+          "Trickplay"
+        ],
+        "summary": "Gets an image tiles playlist for trickplay.",
+        "operationId": "GetTrickplayHlsPlaylist",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "width",
+            "in": "path",
+            "description": "The width of a single tile.",
+            "required": true,
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media version id, if using an alternate version.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Tiles playlist returned.",
+            "content": {
+              "application/x-mpegURL": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "Not Found",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Shows/{seriesId}/Episodes": {
       "get": {
         "tags": [
@@ -38834,7 +38325,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The series id.",
               "format": "uuid"
             }
           },
@@ -38844,9 +38334,7 @@
             "description": "The user id.",
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -38857,9 +38345,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38868,9 +38354,7 @@
             "description": "Optional filter by season number.",
             "schema": {
               "type": "integer",
-              "description": "Optional filter by season number.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38879,9 +38363,7 @@
             "description": "Optional. Filter by season id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by season id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -38889,9 +38371,7 @@
             "in": "query",
             "description": "Optional. Filter by items that are missing episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by items that are missing episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38900,8 +38380,7 @@
             "description": "Optional. Return items that are siblings of a supplied item.",
             "schema": {
               "type": "string",
-              "description": "Optional. Return items that are siblings of a supplied item.",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -38910,9 +38389,7 @@
             "description": "Optional. Skip through the list until a given item is found.",
             "schema": {
               "type": "string",
-              "description": "Optional. Skip through the list until a given item is found.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -38921,9 +38398,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38932,9 +38407,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38942,9 +38415,7 @@
             "in": "query",
             "description": "Optional, include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional, include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38953,9 +38424,7 @@
             "description": "Optional, the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional, the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -38966,9 +38435,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -38976,9 +38443,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -38986,9 +38451,45 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
+              "enum": [
+                "Default",
+                "AiredEpisodeOrder",
+                "Album",
+                "AlbumArtist",
+                "Artist",
+                "DateCreated",
+                "OfficialRating",
+                "DatePlayed",
+                "PremiereDate",
+                "StartDate",
+                "SortName",
+                "Name",
+                "Random",
+                "Runtime",
+                "CommunityRating",
+                "ProductionYear",
+                "PlayCount",
+                "CriticRating",
+                "IsFolder",
+                "IsUnplayed",
+                "IsPlayed",
+                "SeriesSortName",
+                "VideoBitRate",
+                "AirTime",
+                "Studio",
+                "IsFavoriteOrLiked",
+                "DateLastContentAdded",
+                "SeriesDatePlayed",
+                "ParentIndexNumber",
+                "IndexNumber",
+                "SimilarityScore",
+                "SearchScore"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/ItemSortBy"
+                }
+              ]
             }
           }
         ],
@@ -39064,7 +38565,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The series id.",
               "format": "uuid"
             }
           },
@@ -39074,9 +38574,7 @@
             "description": "The user id.",
             "schema": {
               "type": "string",
-              "description": "The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39087,9 +38585,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines, TrailerUrls.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39097,9 +38593,7 @@
             "in": "query",
             "description": "Optional. Filter by special season.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by special season.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -39107,9 +38601,7 @@
             "in": "query",
             "description": "Optional. Filter by items that are missing episodes or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Filter by items that are missing episodes or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -39118,8 +38610,7 @@
             "description": "Optional. Return items that are siblings of a supplied item.",
             "schema": {
               "type": "string",
-              "description": "Optional. Return items that are siblings of a supplied item.",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39127,9 +38618,7 @@
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -39138,9 +38627,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39151,9 +38638,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39161,9 +38646,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -39238,9 +38721,7 @@
             "description": "The user id of the user to get the next up episodes for.",
             "schema": {
               "type": "string",
-              "description": "The user id of the user to get the next up episodes for.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39249,9 +38730,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39260,9 +38739,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39273,9 +38750,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39284,8 +38759,7 @@
             "description": "Optional. Filter by series id.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by series id.",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39294,19 +38768,15 @@
             "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
-            "name": "enableImges",
+            "name": "enableImages",
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -39315,9 +38785,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39328,9 +38796,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39338,9 +38804,16 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "nextUpDateCutoff",
+            "in": "query",
+            "description": "Optional. Starting date of shows to show in Next Up section.",
+            "schema": {
+              "type": "string",
+              "format": "date-time"
             }
           },
           {
@@ -39349,7 +38822,6 @@
             "description": "Whether to enable the total records count. Defaults to true.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to enable the total records count. Defaults to true.",
               "default": true
             }
           },
@@ -39359,7 +38831,24 @@
             "description": "Whether to disable sending the first episode in a series as next up.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to disable sending the first episode in a series as next up.",
+              "default": false
+            }
+          },
+          {
+            "name": "enableResumable",
+            "in": "query",
+            "description": "Whether to include resumable episodes in next up results.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          },
+          {
+            "name": "enableRewatching",
+            "in": "query",
+            "description": "Whether to include watched episodes in next up results.",
+            "schema": {
+              "type": "boolean",
               "default": false
             }
           }
@@ -39415,9 +38904,7 @@
             "description": "The user id of the user to get the upcoming episodes for.",
             "schema": {
               "type": "string",
-              "description": "The user id of the user to get the upcoming episodes for.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39426,9 +38913,7 @@
             "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The record index to start at. All items with a lower index will be dropped from the results.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39437,9 +38922,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39450,9 +38933,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39461,19 +38942,15 @@
             "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Optional. Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
-            "name": "enableImges",
+            "name": "enableImages",
             "in": "query",
             "description": "Optional. Include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -39482,9 +38959,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39495,9 +38970,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39505,9 +38978,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -39563,7 +39034,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -39575,9 +39045,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. The audio container.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39585,9 +39053,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -39595,9 +39061,7 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -39606,9 +39070,7 @@
             "description": "Optional. The user id.",
             "schema": {
               "type": "string",
-              "description": "Optional. The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39616,9 +39078,8 @@
             "in": "query",
             "description": "Optional. The audio codec to transcode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The audio codec to transcode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -39627,9 +39088,7 @@
             "description": "Optional. The maximum number of audio channels.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39638,9 +39097,7 @@
             "description": "Optional. The number of how many audio channels to transcode to.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The number of how many audio channels to transcode to.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39649,9 +39106,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39660,9 +39115,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39671,9 +39124,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -39681,9 +39132,8 @@
             "in": "query",
             "description": "Optional. The container to transcode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The container to transcode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -39691,9 +39141,15 @@
             "in": "query",
             "description": "Optional. The transcoding protocol.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding protocol.",
-              "nullable": true
+              "enum": [
+                "http",
+                "hls"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/MediaStreamProtocol"
+                }
+              ]
             }
           },
           {
@@ -39702,9 +39158,7 @@
             "description": "Optional. The maximum audio sample rate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio sample rate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39713,19 +39167,24 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
             "name": "enableRemoteMedia",
             "in": "query",
             "description": "Optional. Whether to enable remote media.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Whether to enable remote media.",
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -39734,7 +39193,7 @@
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Whether to break on non key frames."
+              "default": false
             }
           },
           {
@@ -39743,7 +39202,6 @@
             "description": "Whether to enable redirection. Defaults to true.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to enable redirection. Defaults to true.",
               "default": true
             }
           }
@@ -39763,6 +39221,26 @@
           "302": {
             "description": "Redirected to remote audio stream."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -39792,7 +39270,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -39804,9 +39281,7 @@
               "type": "array",
               "items": {
                 "type": "string"
-              },
-              "description": "Optional. The audio container.",
-              "nullable": true
+              }
             }
           },
           {
@@ -39814,9 +39289,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -39824,9 +39297,7 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -39835,9 +39306,7 @@
             "description": "Optional. The user id.",
             "schema": {
               "type": "string",
-              "description": "Optional. The user id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -39845,9 +39314,8 @@
             "in": "query",
             "description": "Optional. The audio codec to transcode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The audio codec to transcode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -39856,9 +39324,7 @@
             "description": "Optional. The maximum number of audio channels.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39867,9 +39333,7 @@
             "description": "Optional. The number of how many audio channels to transcode to.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The number of how many audio channels to transcode to.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39878,9 +39342,7 @@
             "description": "Optional. The maximum streaming bitrate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum streaming bitrate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39889,9 +39351,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39900,9 +39360,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -39910,9 +39368,8 @@
             "in": "query",
             "description": "Optional. The container to transcode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The container to transcode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -39920,9 +39377,15 @@
             "in": "query",
             "description": "Optional. The transcoding protocol.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding protocol.",
-              "nullable": true
+              "enum": [
+                "http",
+                "hls"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/MediaStreamProtocol"
+                }
+              ]
             }
           },
           {
@@ -39931,9 +39394,7 @@
             "description": "Optional. The maximum audio sample rate.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio sample rate.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -39942,19 +39403,24 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
             "name": "enableRemoteMedia",
             "in": "query",
             "description": "Optional. Whether to enable remote media.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Whether to enable remote media.",
-              "nullable": true
+              "default": true
             }
           },
           {
@@ -39963,7 +39429,7 @@
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Whether to break on non key frames."
+              "default": false
             }
           },
           {
@@ -39972,7 +39438,6 @@
             "description": "Whether to enable redirection. Defaults to true.",
             "schema": {
               "type": "boolean",
-              "description": "Whether to enable redirection. Defaults to true.",
               "default": true
             }
           }
@@ -39992,6 +39457,26 @@
           "302": {
             "description": "Redirected to remote audio stream."
           },
+          "404": {
+            "description": "Item not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
           "401": {
             "description": "Unauthorized"
           },
@@ -40021,9 +39506,7 @@
             "in": "query",
             "description": "Optional filter by IsHidden=true or false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by IsHidden=true or false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -40031,9 +39514,7 @@
             "in": "query",
             "description": "Optional filter by IsDisabled=true or false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional filter by IsDisabled=true or false.",
-              "nullable": true
+              "type": "boolean"
             }
           }
         ],
@@ -40081,141 +39562,6 @@
             ]
           }
         ]
-      }
-    },
-    "/Users/{userId}": {
-      "get": {
-        "tags": [
-          "User"
-        ],
-        "summary": "Gets a user by Id.",
-        "operationId": "GetUserById",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "The user id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The user id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "User returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserDto"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "User not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "IgnoreParentalControl"
-            ]
-          }
-        ]
-      },
-      "delete": {
-        "tags": [
-          "User"
-        ],
-        "summary": "Deletes a user.",
-        "operationId": "DeleteUser",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "The user id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The user id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "204": {
-            "description": "User deleted."
-          },
-          "404": {
-            "description": "User not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "RequiresElevation"
-            ]
-          }
-        ]
       },
       "post": {
         "tags": [
@@ -40226,12 +39572,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "The user id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
@@ -40241,17 +39585,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/UserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserDto"
+                  }
+                ],
+                "description": "Class UserDto."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/UserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserDto"
+                  }
+                ],
+                "description": "Class UserDto."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/UserDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserDto"
+                  }
+                ],
+                "description": "Class UserDto."
               }
             }
           },
@@ -40314,13 +39673,13 @@
         ]
       }
     },
-    "/Users/{userId}/Authenticate": {
-      "post": {
+    "/Users/{userId}": {
+      "get": {
         "tags": [
           "User"
         ],
-        "summary": "Authenticates a user.",
-        "operationId": "AuthenticateUser",
+        "summary": "Gets a user by Id.",
+        "operationId": "GetUserById",
         "parameters": [
           {
             "name": "userId",
@@ -40329,68 +39688,27 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
-          },
-          {
-            "name": "pw",
-            "in": "query",
-            "description": "The password as plain text.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The password as plain text."
-            }
-          },
-          {
-            "name": "password",
-            "in": "query",
-            "description": "The password sha1-hash.",
-            "schema": {
-              "type": "string",
-              "description": "The password sha1-hash.",
-              "nullable": true
-            }
           }
         ],
         "responses": {
           "200": {
-            "description": "User authenticated.",
+            "description": "User returned.",
             "content": {
               "application/json": {
                 "schema": {
-                  "$ref": "#/components/schemas/AuthenticationResult"
+                  "$ref": "#/components/schemas/UserDto"
                 }
               },
               "application/json; profile=\"CamelCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/AuthenticationResult"
+                  "$ref": "#/components/schemas/UserDto"
                 }
               },
               "application/json; profile=\"PascalCase\"": {
                 "schema": {
-                  "$ref": "#/components/schemas/AuthenticationResult"
-                }
-              }
-            }
-          },
-          "403": {
-            "description": "Sha1-hashed password only is not allowed.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
+                  "$ref": "#/components/schemas/UserDto"
                 }
               }
             }
@@ -40414,95 +39732,29 @@
                 }
               }
             }
-          }
-        }
-      }
-    },
-    "/Users/{userId}/Configuration": {
-      "post": {
-        "tags": [
-          "User"
-        ],
-        "summary": "Updates a user configuration.",
-        "operationId": "UpdateUserConfiguration",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "The user id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The user id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "requestBody": {
-          "description": "The new user configuration.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UserConfiguration"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UserConfiguration"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/UserConfiguration"
-              }
-            }
-          },
-          "required": true
-        },
-        "responses": {
-          "204": {
-            "description": "User configuration updated."
-          },
-          "403": {
-            "description": "User configuration update forbidden.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
           },
           "401": {
             "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
           }
         },
         "security": [
           {
             "CustomAuthentication": [
+              "IgnoreParentalControl",
               "DefaultAuthorization"
             ]
           }
         ]
-      }
-    },
-    "/Users/{userId}/EasyPassword": {
-      "post": {
+      },
+      "delete": {
         "tags": [
           "User"
         ],
-        "summary": "Updates a user's easy password.",
-        "operationId": "UpdateUserEasyPassword",
+        "summary": "Deletes a user.",
+        "operationId": "DeleteUser",
         "parameters": [
           {
             "name": "userId",
@@ -40511,55 +39763,13 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
         ],
-        "requestBody": {
-          "description": "The M:Jellyfin.Api.Controllers.UserController.UpdateUserEasyPassword(System.Guid,Jellyfin.Api.Models.UserDtos.UpdateUserEasyPassword) request.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserEasyPassword"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserEasyPassword"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserEasyPassword"
-              }
-            }
-          },
-          "required": true
-        },
         "responses": {
           "204": {
-            "description": "Password successfully reset."
-          },
-          "403": {
-            "description": "User is not allowed to update the password.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
+            "description": "User deleted."
           },
           "404": {
             "description": "User not found.",
@@ -40583,110 +39793,15 @@
           },
           "401": {
             "description": "Unauthorized"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/Password": {
-      "post": {
-        "tags": [
-          "User"
-        ],
-        "summary": "Updates a user's password.",
-        "operationId": "UpdateUserPassword",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "The user id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The user id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "requestBody": {
-          "description": "The M:Jellyfin.Api.Controllers.UserController.UpdateUserPassword(System.Guid,Jellyfin.Api.Models.UserDtos.UpdateUserPassword) request.",
-          "content": {
-            "application/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserPassword"
-              }
-            },
-            "text/json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserPassword"
-              }
-            },
-            "application/*+json": {
-              "schema": {
-                "$ref": "#/components/schemas/UpdateUserPassword"
-              }
-            }
-          },
-          "required": true
-        },
-        "responses": {
-          "204": {
-            "description": "Password successfully reset."
           },
           "403": {
-            "description": "User is not allowed to update the password.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "404": {
-            "description": "User not found.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/ProblemDetails"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
+            "description": "Forbidden"
           }
         },
         "security": [
           {
             "CustomAuthentication": [
-              "DefaultAuthorization"
+              "RequiresElevation"
             ]
           }
         ]
@@ -40707,7 +39822,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The user id.",
               "format": "uuid"
             }
           }
@@ -40717,17 +39831,29 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/UserPolicy"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserPolicy"
+                  }
+                ]
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/UserPolicy"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserPolicy"
+                  }
+                ]
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/UserPolicy"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserPolicy"
+                  }
+                ]
               }
             }
           },
@@ -40802,17 +39928,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/AuthenticateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AuthenticateUserByName"
+                  }
+                ],
+                "description": "The authenticate user by name request body."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/AuthenticateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AuthenticateUserByName"
+                  }
+                ],
+                "description": "The authenticate user by name request body."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/AuthenticateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/AuthenticateUserByName"
+                  }
+                ],
+                "description": "The authenticate user by name request body."
               }
             }
           },
@@ -40854,17 +39995,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/QuickConnectDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QuickConnectDto"
+                  }
+                ],
+                "description": "The quick connect request body."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/QuickConnectDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QuickConnectDto"
+                  }
+                ],
+                "description": "The quick connect request body."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/QuickConnectDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/QuickConnectDto"
+                  }
+                ],
+                "description": "The quick connect request body."
               }
             }
           },
@@ -40897,6 +40053,97 @@
         }
       }
     },
+    "/Users/Configuration": {
+      "post": {
+        "tags": [
+          "User"
+        ],
+        "summary": "Updates a user configuration.",
+        "operationId": "UpdateUserConfiguration",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "The user id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The new user configuration.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserConfiguration"
+                  }
+                ],
+                "description": "Class UserConfiguration."
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserConfiguration"
+                  }
+                ],
+                "description": "Class UserConfiguration."
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UserConfiguration"
+                  }
+                ],
+                "description": "Class UserConfiguration."
+              }
+            }
+          },
+          "required": true
+        },
+        "responses": {
+          "204": {
+            "description": "User configuration updated."
+          },
+          "403": {
+            "description": "User configuration update forbidden.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Users/ForgotPassword": {
       "post": {
         "tags": [
@@ -40909,17 +40156,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/ForgotPasswordDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordDto"
+                  }
+                ],
+                "description": "Forgot Password request body DTO."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/ForgotPasswordDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordDto"
+                  }
+                ],
+                "description": "Forgot Password request body DTO."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/ForgotPasswordDto"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordDto"
+                  }
+                ],
+                "description": "Forgot Password request body DTO."
               }
             }
           },
@@ -40957,30 +40219,40 @@
         "summary": "Redeems a forgot password pin.",
         "operationId": "ForgotPasswordPin",
         "requestBody": {
-          "description": "The pin.",
+          "description": "The forgot password pin request containing the entered pin.",
           "content": {
             "application/json": {
               "schema": {
-                "type": "string",
-                "description": "The pin.",
-                "nullable": true
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordPinDto"
+                  }
+                ],
+                "description": "Forgot Password Pin enter request body DTO."
               }
             },
             "text/json": {
               "schema": {
-                "type": "string",
-                "description": "The pin.",
-                "nullable": true
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordPinDto"
+                  }
+                ],
+                "description": "Forgot Password Pin enter request body DTO."
               }
             },
             "application/*+json": {
               "schema": {
-                "type": "string",
-                "description": "The pin.",
-                "nullable": true
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/ForgotPasswordPinDto"
+                  }
+                ],
+                "description": "Forgot Password Pin enter request body DTO."
               }
             }
-          }
+          },
+          "required": true
         },
         "responses": {
           "200": {
@@ -41082,17 +40354,32 @@
           "content": {
             "application/json": {
               "schema": {
-                "$ref": "#/components/schemas/CreateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreateUserByName"
+                  }
+                ],
+                "description": "The create user by name request body."
               }
             },
             "text/json": {
               "schema": {
-                "$ref": "#/components/schemas/CreateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreateUserByName"
+                  }
+                ],
+                "description": "The create user by name request body."
               }
             },
             "application/*+json": {
               "schema": {
-                "$ref": "#/components/schemas/CreateUserByName"
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/CreateUserByName"
+                  }
+                ],
+                "description": "The create user by name request body."
               }
             }
           },
@@ -41135,6 +40422,117 @@
         ]
       }
     },
+    "/Users/Password": {
+      "post": {
+        "tags": [
+          "User"
+        ],
+        "summary": "Updates a user's password.",
+        "operationId": "UpdateUserPassword",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "The user id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "requestBody": {
+          "description": "The M:Jellyfin.Api.Controllers.UserController.UpdateUserPassword(System.Nullable{System.Guid},Jellyfin.Api.Models.UserDtos.UpdateUserPassword) request.",
+          "content": {
+            "application/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserPassword"
+                  }
+                ],
+                "description": "The update user password request body."
+              }
+            },
+            "text/json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserPassword"
+                  }
+                ],
+                "description": "The update user password request body."
+              }
+            },
+            "application/*+json": {
+              "schema": {
+                "allOf": [
+                  {
+                    "$ref": "#/components/schemas/UpdateUserPassword"
+                  }
+                ],
+                "description": "The update user password request body."
+              }
+            }
+          },
+          "required": true
+        },
+        "responses": {
+          "204": {
+            "description": "Password successfully reset."
+          },
+          "403": {
+            "description": "User is not allowed to update the password.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "404": {
+            "description": "User not found.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/ProblemDetails"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
     "/Users/Public": {
       "get": {
         "tags": [
@@ -41175,209 +40573,7 @@
         }
       }
     },
-    "/Users/{userId}/FavoriteItems/{itemId}": {
-      "post": {
-        "tags": [
-          "UserLibrary"
-        ],
-        "summary": "Marks an item as a favorite.",
-        "operationId": "MarkFavoriteItem",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Item marked as favorite.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      },
-      "delete": {
-        "tags": [
-          "UserLibrary"
-        ],
-        "summary": "Unmarks item as a favorite.",
-        "operationId": "UnmarkFavoriteItem",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Item unmarked as favorite.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/Items/{itemId}": {
-      "get": {
-        "tags": [
-          "UserLibrary"
-        ],
-        "summary": "Gets an item from a user's library.",
-        "operationId": "GetItem",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Item returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/Items/{itemId}/Intros": {
+    "/Items/{itemId}/Intros": {
       "get": {
         "tags": [
           "UserLibrary"
@@ -41387,12 +40583,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -41403,7 +40597,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -41445,7 +40638,7 @@
         ]
       }
     },
-    "/Users/{userId}/Items/{itemId}/LocalTrailers": {
+    "/Items/{itemId}/LocalTrailers": {
       "get": {
         "tags": [
           "UserLibrary"
@@ -41455,12 +40648,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -41471,7 +40662,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -41522,151 +40712,7 @@
         ]
       }
     },
-    "/Users/{userId}/Items/{itemId}/Rating": {
-      "delete": {
-        "tags": [
-          "UserLibrary"
-        ],
-        "summary": "Deletes a user's saved personal rating for an item.",
-        "operationId": "DeleteUserItemRating",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Personal rating removed.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      },
-      "post": {
-        "tags": [
-          "UserLibrary"
-        ],
-        "summary": "Updates a user's rating for an item.",
-        "operationId": "UpdateUserItemRating",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "Item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "Item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "likes",
-            "in": "query",
-            "description": "Whether this M:Jellyfin.Api.Controllers.UserLibraryController.UpdateUserItemRating(System.Guid,System.Guid,System.Nullable{System.Boolean}) is likes.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether this M:Jellyfin.Api.Controllers.UserLibraryController.UpdateUserItemRating(System.Guid,System.Guid,System.Nullable{System.Boolean}) is likes.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Item rating updated.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/UserItemDataDto"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Users/{userId}/Items/{itemId}/SpecialFeatures": {
+    "/Items/{itemId}/SpecialFeatures": {
       "get": {
         "tags": [
           "UserLibrary"
@@ -41676,12 +40722,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -41692,7 +40736,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Item id.",
               "format": "uuid"
             }
           }
@@ -41743,7 +40786,7 @@
         ]
       }
     },
-    "/Users/{userId}/Items/Latest": {
+    "/Items/Latest": {
       "get": {
         "tags": [
           "UserLibrary"
@@ -41753,12 +40796,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           },
@@ -41768,9 +40809,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -41781,9 +40820,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -41793,10 +40830,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be filtered based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -41804,9 +40839,7 @@
             "in": "query",
             "description": "Filter by items that are played, or not.",
             "schema": {
-              "type": "boolean",
-              "description": "Filter by items that are played, or not.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -41814,9 +40847,7 @@
             "in": "query",
             "description": "Optional. include image information in output.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. include image information in output.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -41825,9 +40856,7 @@
             "description": "Optional. the max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. the max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -41838,9 +40867,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -41848,9 +40875,7 @@
             "in": "query",
             "description": "Optional. include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -41859,7 +40884,6 @@
             "description": "Return item limit.",
             "schema": {
               "type": "integer",
-              "description": "Return item limit.",
               "format": "int32",
               "default": 20
             }
@@ -41870,7 +40894,6 @@
             "description": "Whether or not to group items into a parent container.",
             "schema": {
               "type": "boolean",
-              "description": "Whether or not to group items into a parent container.",
               "default": true
             }
           }
@@ -41921,7 +40944,7 @@
         ]
       }
     },
-    "/Users/{userId}/Items/Root": {
+    "/Items/Root": {
       "get": {
         "tags": [
           "UserLibrary"
@@ -41931,12 +40954,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           }
@@ -41978,7 +40999,354 @@
         ]
       }
     },
-    "/Users/{userId}/GroupingOptions": {
+    "/UserFavoriteItems/{itemId}": {
+      "post": {
+        "tags": [
+          "UserLibrary"
+        ],
+        "summary": "Marks an item as a favorite.",
+        "operationId": "MarkFavoriteItem",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Item marked as favorite.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "delete": {
+        "tags": [
+          "UserLibrary"
+        ],
+        "summary": "Unmarks item as a favorite.",
+        "operationId": "UnmarkFavoriteItem",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Item unmarked as favorite.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/UserItems/{itemId}/Rating": {
+      "delete": {
+        "tags": [
+          "UserLibrary"
+        ],
+        "summary": "Deletes a user's saved personal rating for an item.",
+        "operationId": "DeleteUserItemRating",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Personal rating removed.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      },
+      "post": {
+        "tags": [
+          "UserLibrary"
+        ],
+        "summary": "Updates a user's rating for an item.",
+        "operationId": "UpdateUserItemRating",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "Item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "likes",
+            "in": "query",
+            "description": "Whether this M:Jellyfin.Api.Controllers.UserLibraryController.UpdateUserItemRating(System.Nullable{System.Guid},System.Guid,System.Nullable{System.Boolean}) is likes.",
+            "schema": {
+              "type": "boolean"
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Item rating updated.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/UserItemDataDto"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/UserViews": {
+      "get": {
+        "tags": [
+          "UserViews"
+        ],
+        "summary": "Get user views.",
+        "operationId": "GetUserViews",
+        "parameters": [
+          {
+            "name": "userId",
+            "in": "query",
+            "description": "User id.",
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "includeExternalContent",
+            "in": "query",
+            "description": "Whether or not to include external views such as channels or live tv.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "presetViews",
+            "in": "query",
+            "description": "Preset views.",
+            "schema": {
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/CollectionType"
+              }
+            }
+          },
+          {
+            "name": "includeHidden",
+            "in": "query",
+            "description": "Whether or not to include hidden content.",
+            "schema": {
+              "type": "boolean",
+              "default": false
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "User views returned.",
+            "content": {
+              "application/json": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"CamelCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              },
+              "application/json; profile=\"PascalCase\"": {
+                "schema": {
+                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
+                }
+              }
+            }
+          },
+          "401": {
+            "description": "Unauthorized"
+          },
+          "403": {
+            "description": "Forbidden"
+          }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
+          }
+        ]
+      }
+    },
+    "/UserViews/GroupingOptions": {
       "get": {
         "tags": [
           "UserViews"
@@ -41988,12 +41356,10 @@
         "parameters": [
           {
             "name": "userId",
-            "in": "path",
+            "in": "query",
             "description": "User id.",
-            "required": true,
             "schema": {
               "type": "string",
-              "description": "User id.",
               "format": "uuid"
             }
           }
@@ -42047,85 +41413,21 @@
                 }
               }
             }
-          }
-        }
-      }
-    },
-    "/Users/{userId}/Views": {
-      "get": {
-        "tags": [
-          "UserViews"
-        ],
-        "summary": "Get user views.",
-        "operationId": "GetUserViews",
-        "parameters": [
-          {
-            "name": "userId",
-            "in": "path",
-            "description": "User id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "User id.",
-              "format": "uuid"
-            }
           },
-          {
-            "name": "includeExternalContent",
-            "in": "query",
-            "description": "Whether or not to include external views such as channels or live tv.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to include external views such as channels or live tv.",
-              "nullable": true
-            }
+          "401": {
+            "description": "Unauthorized"
           },
-          {
-            "name": "presetViews",
-            "in": "query",
-            "description": "Preset views.",
-            "schema": {
-              "type": "array",
-              "items": {
-                "type": "string"
-              },
-              "description": "Preset views.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "includeHidden",
-            "in": "query",
-            "description": "Whether or not to include hidden content.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to include hidden content.",
-              "default": false
-            }
+          "403": {
+            "description": "Forbidden"
           }
-        ],
-        "responses": {
-          "200": {
-            "description": "User views returned.",
-            "content": {
-              "application/json": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
-                }
-              },
-              "application/json; profile=\"CamelCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
-                }
-              },
-              "application/json; profile=\"PascalCase\"": {
-                "schema": {
-                  "$ref": "#/components/schemas/BaseItemDtoQueryResult"
-                }
-              }
-            }
+        },
+        "security": [
+          {
+            "CustomAuthentication": [
+              "DefaultAuthorization"
+            ]
           }
-        }
+        ]
       }
     },
     "/Videos/{videoId}/{mediaSourceId}/Attachments/{index}": {
@@ -42143,7 +41445,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "Video ID.",
               "format": "uuid"
             }
           },
@@ -42153,8 +41454,7 @@
             "description": "Media Source ID.",
             "required": true,
             "schema": {
-              "type": "string",
-              "description": "Media Source ID."
+              "type": "string"
             }
           },
           {
@@ -42164,7 +41464,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "Attachment Index.",
               "format": "int32"
             }
           }
@@ -42204,1667 +41503,6 @@
         }
       }
     },
-    "/Videos/{itemId}/live.m3u8": {
-      "get": {
-        "tags": [
-          "VideoHls"
-        ],
-        "summary": "Gets a hls live stream.",
-        "operationId": "GetLiveHlsStream",
-        "parameters": [
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "container",
-            "in": "query",
-            "description": "The audio container.",
-            "schema": {
-              "type": "string",
-              "description": "The audio container.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "static",
-            "in": "query",
-            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "params",
-            "in": "query",
-            "description": "The streaming parameters.",
-            "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "tag",
-            "in": "query",
-            "description": "The tag.",
-            "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceProfileId",
-            "in": "query",
-            "description": "Optional. The dlna device profile id to utilize.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentContainer",
-            "in": "query",
-            "description": "The segment container.",
-            "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentLength",
-            "in": "query",
-            "description": "The segment lenght.",
-            "schema": {
-              "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minSegments",
-            "in": "query",
-            "description": "The minimum number of segments.",
-            "schema": {
-              "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The media version id, if playing an alternate version.",
-            "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceId",
-            "in": "query",
-            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-            "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioCodec",
-            "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableAutoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowVideoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the video stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowAudioStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the audio stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "breakOnNonKeyFrames",
-            "in": "query",
-            "description": "Optional. Whether to break on non key frames.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioSampleRate",
-            "in": "query",
-            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum audio bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioBitRate",
-            "in": "query",
-            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioChannels",
-            "in": "query",
-            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioChannels",
-            "in": "query",
-            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "profile",
-            "in": "query",
-            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "level",
-            "in": "query",
-            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "framerate",
-            "in": "query",
-            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxFramerate",
-            "in": "query",
-            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "copyTimestamps",
-            "in": "query",
-            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "startTimeTicks",
-            "in": "query",
-            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "width",
-            "in": "query",
-            "description": "Optional. The fixed horizontal resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "height",
-            "in": "query",
-            "description": "Optional. The fixed vertical resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoBitRate",
-            "in": "query",
-            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleMethod",
-            "in": "query",
-            "description": "Optional. Specify the subtitle delivery method.",
-            "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
-            }
-          },
-          {
-            "name": "maxRefFrames",
-            "in": "query",
-            "description": "Optional.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxVideoBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum video bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireAvc",
-            "in": "query",
-            "description": "Optional. Whether to require avc.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deInterlace",
-            "in": "query",
-            "description": "Optional. Whether to deinterlace the video.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireNonAnamorphic",
-            "in": "query",
-            "description": "Optional. Whether to require a non anamorphic stream.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodingMaxAudioChannels",
-            "in": "query",
-            "description": "Optional. The maximum number of audio channels to transcode.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cpuCoreLimit",
-            "in": "query",
-            "description": "Optional. The limit of how many cpu cores to use.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableMpegtsM2TsMode",
-            "in": "query",
-            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoCodec",
-            "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleCodec",
-            "in": "query",
-            "description": "Optional. Specify a subtitle codec to encode to.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodeReasons",
-            "in": "query",
-            "description": "Optional. The transcoding reason.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "context",
-            "in": "query",
-            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
-            "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
-            }
-          },
-          {
-            "name": "streamOptions",
-            "in": "query",
-            "description": "Optional. The streaming options.",
-            "schema": {
-              "type": "object",
-              "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxWidth",
-            "in": "query",
-            "description": "Optional. The max width.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The max width.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxHeight",
-            "in": "query",
-            "description": "Optional. The max height.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The max height.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableSubtitlesInManifest",
-            "in": "query",
-            "description": "Optional. Whether to enable subtitles in the manifest.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable subtitles in the manifest.",
-              "nullable": true
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Hls live stream retrieved.",
-            "content": {
-              "application/x-mpegURL": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          },
-          "401": {
-            "description": "Unauthorized"
-          },
-          "403": {
-            "description": "Forbidden"
-          }
-        },
-        "security": [
-          {
-            "CustomAuthentication": [
-              "DefaultAuthorization"
-            ]
-          }
-        ]
-      }
-    },
-    "/Videos/{itemId}/{stream}.{container}": {
-      "get": {
-        "tags": [
-          "Videos"
-        ],
-        "summary": "Gets a video stream.",
-        "operationId": "GetVideoStreamByContainer",
-        "parameters": [
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "container",
-            "in": "path",
-            "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv."
-            }
-          },
-          {
-            "name": "static",
-            "in": "query",
-            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "params",
-            "in": "query",
-            "description": "The streaming parameters.",
-            "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "tag",
-            "in": "query",
-            "description": "The tag.",
-            "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceProfileId",
-            "in": "query",
-            "description": "Optional. The dlna device profile id to utilize.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentContainer",
-            "in": "query",
-            "description": "The segment container.",
-            "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentLength",
-            "in": "query",
-            "description": "The segment lenght.",
-            "schema": {
-              "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minSegments",
-            "in": "query",
-            "description": "The minimum number of segments.",
-            "schema": {
-              "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The media version id, if playing an alternate version.",
-            "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceId",
-            "in": "query",
-            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-            "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioCodec",
-            "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableAutoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowVideoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the video stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowAudioStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the audio stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "breakOnNonKeyFrames",
-            "in": "query",
-            "description": "Optional. Whether to break on non key frames.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioSampleRate",
-            "in": "query",
-            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum audio bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioBitRate",
-            "in": "query",
-            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioChannels",
-            "in": "query",
-            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioChannels",
-            "in": "query",
-            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "profile",
-            "in": "query",
-            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "level",
-            "in": "query",
-            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "framerate",
-            "in": "query",
-            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxFramerate",
-            "in": "query",
-            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "copyTimestamps",
-            "in": "query",
-            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "startTimeTicks",
-            "in": "query",
-            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "width",
-            "in": "query",
-            "description": "Optional. The fixed horizontal resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "height",
-            "in": "query",
-            "description": "Optional. The fixed vertical resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoBitRate",
-            "in": "query",
-            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleMethod",
-            "in": "query",
-            "description": "Optional. Specify the subtitle delivery method.",
-            "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
-            }
-          },
-          {
-            "name": "maxRefFrames",
-            "in": "query",
-            "description": "Optional.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxVideoBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum video bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireAvc",
-            "in": "query",
-            "description": "Optional. Whether to require avc.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deInterlace",
-            "in": "query",
-            "description": "Optional. Whether to deinterlace the video.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireNonAnamorphic",
-            "in": "query",
-            "description": "Optional. Whether to require a non anamporphic stream.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamporphic stream.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodingMaxAudioChannels",
-            "in": "query",
-            "description": "Optional. The maximum number of audio channels to transcode.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cpuCoreLimit",
-            "in": "query",
-            "description": "Optional. The limit of how many cpu cores to use.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableMpegtsM2TsMode",
-            "in": "query",
-            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoCodec",
-            "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleCodec",
-            "in": "query",
-            "description": "Optional. Specify a subtitle codec to encode to.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodeReasons",
-            "in": "query",
-            "description": "Optional. The transcoding reason.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "context",
-            "in": "query",
-            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
-            "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
-            }
-          },
-          {
-            "name": "streamOptions",
-            "in": "query",
-            "description": "Optional. The streaming options.",
-            "schema": {
-              "type": "object",
-              "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "stream",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Video stream returned.",
-            "content": {
-              "video/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          }
-        }
-      },
-      "head": {
-        "tags": [
-          "Videos"
-        ],
-        "summary": "Gets a video stream.",
-        "operationId": "HeadVideoStreamByContainer",
-        "parameters": [
-          {
-            "name": "itemId",
-            "in": "path",
-            "description": "The item id.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The item id.",
-              "format": "uuid"
-            }
-          },
-          {
-            "name": "container",
-            "in": "path",
-            "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
-            "required": true,
-            "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv."
-            }
-          },
-          {
-            "name": "static",
-            "in": "query",
-            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "params",
-            "in": "query",
-            "description": "The streaming parameters.",
-            "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "tag",
-            "in": "query",
-            "description": "The tag.",
-            "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceProfileId",
-            "in": "query",
-            "description": "Optional. The dlna device profile id to utilize.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "playSessionId",
-            "in": "query",
-            "description": "The play session id.",
-            "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentContainer",
-            "in": "query",
-            "description": "The segment container.",
-            "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "segmentLength",
-            "in": "query",
-            "description": "The segment lenght.",
-            "schema": {
-              "type": "integer",
-              "description": "The segment lenght.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "minSegments",
-            "in": "query",
-            "description": "The minimum number of segments.",
-            "schema": {
-              "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "mediaSourceId",
-            "in": "query",
-            "description": "The media version id, if playing an alternate version.",
-            "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deviceId",
-            "in": "query",
-            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-            "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioCodec",
-            "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableAutoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowVideoStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the video stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "allowAudioStreamCopy",
-            "in": "query",
-            "description": "Whether or not to allow copying of the audio stream url.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "breakOnNonKeyFrames",
-            "in": "query",
-            "description": "Optional. Whether to break on non key frames.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioSampleRate",
-            "in": "query",
-            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum audio bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioBitRate",
-            "in": "query",
-            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioChannels",
-            "in": "query",
-            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxAudioChannels",
-            "in": "query",
-            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "profile",
-            "in": "query",
-            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "level",
-            "in": "query",
-            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "framerate",
-            "in": "query",
-            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxFramerate",
-            "in": "query",
-            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-            "schema": {
-              "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
-            }
-          },
-          {
-            "name": "copyTimestamps",
-            "in": "query",
-            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-            "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "startTimeTicks",
-            "in": "query",
-            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
-            }
-          },
-          {
-            "name": "width",
-            "in": "query",
-            "description": "Optional. The fixed horizontal resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "height",
-            "in": "query",
-            "description": "Optional. The fixed vertical resolution of the encoded video.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoBitRate",
-            "in": "query",
-            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleMethod",
-            "in": "query",
-            "description": "Optional. Specify the subtitle delivery method.",
-            "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
-            }
-          },
-          {
-            "name": "maxRefFrames",
-            "in": "query",
-            "description": "Optional.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "maxVideoBitDepth",
-            "in": "query",
-            "description": "Optional. The maximum video bit depth.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireAvc",
-            "in": "query",
-            "description": "Optional. Whether to require avc.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "deInterlace",
-            "in": "query",
-            "description": "Optional. Whether to deinterlace the video.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "requireNonAnamorphic",
-            "in": "query",
-            "description": "Optional. Whether to require a non anamporphic stream.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamporphic stream.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodingMaxAudioChannels",
-            "in": "query",
-            "description": "Optional. The maximum number of audio channels to transcode.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "cpuCoreLimit",
-            "in": "query",
-            "description": "Optional. The limit of how many cpu cores to use.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "liveStreamId",
-            "in": "query",
-            "description": "The live stream id.",
-            "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "enableMpegtsM2TsMode",
-            "in": "query",
-            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-            "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoCodec",
-            "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "subtitleCodec",
-            "in": "query",
-            "description": "Optional. Specify a subtitle codec to encode to.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "transcodeReasons",
-            "in": "query",
-            "description": "Optional. The transcoding reason.",
-            "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "audioStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "videoStreamIndex",
-            "in": "query",
-            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-            "schema": {
-              "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
-            }
-          },
-          {
-            "name": "context",
-            "in": "query",
-            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
-            "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
-            }
-          },
-          {
-            "name": "streamOptions",
-            "in": "query",
-            "description": "Optional. The streaming options.",
-            "schema": {
-              "type": "object",
-              "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
-            }
-          },
-          {
-            "name": "stream",
-            "in": "path",
-            "required": true,
-            "schema": {
-              "type": "string"
-            }
-          }
-        ],
-        "responses": {
-          "200": {
-            "description": "Video stream returned.",
-            "content": {
-              "video/*": {
-                "schema": {
-                  "type": "string",
-                  "format": "binary"
-                }
-              }
-            }
-          }
-        }
-      }
-    },
     "/Videos/{itemId}/AdditionalParts": {
       "get": {
         "tags": [
@@ -43880,7 +41518,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -43890,9 +41527,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -43948,7 +41583,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           }
@@ -44008,7 +41642,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -44017,9 +41650,8 @@
             "in": "query",
             "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
             "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44027,9 +41659,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44037,9 +41667,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44047,19 +41675,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44067,9 +41692,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44077,9 +41700,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44088,9 +41710,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44099,9 +41719,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44109,9 +41727,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44119,19 +41735,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44139,9 +41752,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44149,9 +41760,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44159,9 +41768,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44169,9 +41776,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44180,9 +41785,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44191,9 +41794,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44202,9 +41803,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44213,9 +41812,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44224,9 +41821,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44234,9 +41829,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44244,9 +41837,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44255,9 +41846,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -44266,9 +41855,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -44276,9 +41863,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44287,9 +41872,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -44298,9 +41881,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44309,9 +41890,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -44320,9 +41917,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44331,9 +41926,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44341,7 +41934,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -44350,9 +41954,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44361,9 +41963,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44371,9 +41971,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44381,9 +41979,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44391,9 +41987,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44402,9 +41996,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44413,9 +42005,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44423,9 +42013,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44433,19 +42021,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44453,9 +42038,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44463,9 +42047,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44474,9 +42056,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44485,9 +42065,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44495,7 +42073,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -44505,10 +42091,18 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -44540,7 +42134,6 @@
             "required": true,
             "schema": {
               "type": "string",
-              "description": "The item id.",
               "format": "uuid"
             }
           },
@@ -44549,9 +42142,8 @@
             "in": "query",
             "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
             "schema": {
-              "type": "string",
-              "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44559,9 +42151,7 @@
             "in": "query",
             "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44569,9 +42159,7 @@
             "in": "query",
             "description": "The streaming parameters.",
             "schema": {
-              "type": "string",
-              "description": "The streaming parameters.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44579,19 +42167,16 @@
             "in": "query",
             "description": "The tag.",
             "schema": {
-              "type": "string",
-              "description": "The tag.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "deviceProfileId",
             "in": "query",
             "description": "Optional. The dlna device profile id to utilize.",
+            "deprecated": true,
             "schema": {
-              "type": "string",
-              "description": "Optional. The dlna device profile id to utilize.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44599,9 +42184,7 @@
             "in": "query",
             "description": "The play session id.",
             "schema": {
-              "type": "string",
-              "description": "The play session id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44609,9 +42192,8 @@
             "in": "query",
             "description": "The segment container.",
             "schema": {
-              "type": "string",
-              "description": "The segment container.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44620,9 +42202,7 @@
             "description": "The segment length.",
             "schema": {
               "type": "integer",
-              "description": "The segment length.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44631,9 +42211,7 @@
             "description": "The minimum number of segments.",
             "schema": {
               "type": "integer",
-              "description": "The minimum number of segments.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44641,9 +42219,7 @@
             "in": "query",
             "description": "The media version id, if playing an alternate version.",
             "schema": {
-              "type": "string",
-              "description": "The media version id, if playing an alternate version.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44651,19 +42227,16 @@
             "in": "query",
             "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
             "schema": {
-              "type": "string",
-              "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
             "name": "audioCodec",
             "in": "query",
-            "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension. Options: aac, mp3, vorbis, wma.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44671,9 +42244,7 @@
             "in": "query",
             "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44681,9 +42252,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the video stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the video stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44691,9 +42260,7 @@
             "in": "query",
             "description": "Whether or not to allow copying of the audio stream url.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to allow copying of the audio stream url.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44701,9 +42268,7 @@
             "in": "query",
             "description": "Optional. Whether to break on non key frames.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to break on non key frames.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44712,9 +42277,7 @@
             "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44723,9 +42286,7 @@
             "description": "Optional. The maximum audio bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum audio bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44734,9 +42295,7 @@
             "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44745,9 +42304,7 @@
             "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44756,9 +42313,7 @@
             "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44766,9 +42321,7 @@
             "in": "query",
             "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44776,9 +42329,7 @@
             "in": "query",
             "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44787,9 +42338,7 @@
             "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -44798,9 +42347,7 @@
             "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
             "schema": {
               "type": "number",
-              "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
-              "format": "float",
-              "nullable": true
+              "format": "float"
             }
           },
           {
@@ -44808,9 +42355,7 @@
             "in": "query",
             "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
             "schema": {
-              "type": "boolean",
-              "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44819,9 +42364,7 @@
             "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
-              "format": "int64",
-              "nullable": true
+              "format": "int64"
             }
           },
           {
@@ -44830,9 +42373,7 @@
             "description": "Optional. The fixed horizontal resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed horizontal resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44841,9 +42382,25 @@
             "description": "Optional. The fixed vertical resolution of the encoded video.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The fixed vertical resolution of the encoded video.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
             }
           },
           {
@@ -44852,9 +42409,7 @@
             "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
             "schema": {
               "type": "integer",
-              "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44863,9 +42418,7 @@
             "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44873,7 +42426,18 @@
             "in": "query",
             "description": "Optional. Specify the subtitle delivery method.",
             "schema": {
-              "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
             }
           },
           {
@@ -44882,9 +42446,7 @@
             "description": "Optional.",
             "schema": {
               "type": "integer",
-              "description": "Optional.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44893,9 +42455,7 @@
             "description": "Optional. The maximum video bit depth.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum video bit depth.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44903,9 +42463,7 @@
             "in": "query",
             "description": "Optional. Whether to require avc.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require avc.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44913,9 +42471,7 @@
             "in": "query",
             "description": "Optional. Whether to deinterlace the video.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to deinterlace the video.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44923,9 +42479,7 @@
             "in": "query",
             "description": "Optional. Whether to require a non anamorphic stream.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to require a non anamorphic stream.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -44934,9 +42488,7 @@
             "description": "Optional. The maximum number of audio channels to transcode.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of audio channels to transcode.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44945,9 +42497,7 @@
             "description": "Optional. The limit of how many cpu cores to use.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The limit of how many cpu cores to use.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -44955,9 +42505,7 @@
             "in": "query",
             "description": "The live stream id.",
             "schema": {
-              "type": "string",
-              "description": "The live stream id.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -44965,19 +42513,16 @@
             "in": "query",
             "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
             "name": "videoCodec",
             "in": "query",
-            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension. Options: h265, h264, mpeg4, theora, vpx, wmv.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44985,9 +42530,8 @@
             "in": "query",
             "description": "Optional. Specify a subtitle codec to encode to.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify a subtitle codec to encode to.",
-              "nullable": true
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
             }
           },
           {
@@ -44995,9 +42539,7 @@
             "in": "query",
             "description": "Optional. The transcoding reason.",
             "schema": {
-              "type": "string",
-              "description": "Optional. The transcoding reason.",
-              "nullable": true
+              "type": "string"
             }
           },
           {
@@ -45006,9 +42548,7 @@
             "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -45017,9 +42557,7 @@
             "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -45027,7 +42565,15 @@
             "in": "query",
             "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
             "schema": {
-              "$ref": "#/components/schemas/EncodingContext"
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
             }
           },
           {
@@ -45037,10 +42583,1002 @@
             "schema": {
               "type": "object",
               "additionalProperties": {
-                "type": "string"
-              },
-              "description": "Optional. The streaming options.",
-              "nullable": true
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Video stream returned.",
+            "content": {
+              "video/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          }
+        }
+      }
+    },
+    "/Videos/{itemId}/stream.{container}": {
+      "get": {
+        "tags": [
+          "Videos"
+        ],
+        "summary": "Gets a video stream.",
+        "operationId": "GetVideoStreamByContainer",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "container",
+            "in": "path",
+            "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "static",
+            "in": "query",
+            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "params",
+            "in": "query",
+            "description": "The streaming parameters.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "tag",
+            "in": "query",
+            "description": "The tag.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceProfileId",
+            "in": "query",
+            "description": "Optional. The dlna device profile id to utilize.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentContainer",
+            "in": "query",
+            "description": "The segment container.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentLength",
+            "in": "query",
+            "description": "The segment length.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "minSegments",
+            "in": "query",
+            "description": "The minimum number of segments.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media version id, if playing an alternate version.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceId",
+            "in": "query",
+            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioCodec",
+            "in": "query",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableAutoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowVideoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the video stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowAudioStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the audio stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "breakOnNonKeyFrames",
+            "in": "query",
+            "description": "Optional. Whether to break on non key frames.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "audioSampleRate",
+            "in": "query",
+            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum audio bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioBitRate",
+            "in": "query",
+            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioChannels",
+            "in": "query",
+            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioChannels",
+            "in": "query",
+            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "profile",
+            "in": "query",
+            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "level",
+            "in": "query",
+            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "framerate",
+            "in": "query",
+            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "maxFramerate",
+            "in": "query",
+            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "copyTimestamps",
+            "in": "query",
+            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "startTimeTicks",
+            "in": "query",
+            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "width",
+            "in": "query",
+            "description": "Optional. The fixed horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "height",
+            "in": "query",
+            "description": "Optional. The fixed vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoBitRate",
+            "in": "query",
+            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleMethod",
+            "in": "query",
+            "description": "Optional. Specify the subtitle delivery method.",
+            "schema": {
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
+            }
+          },
+          {
+            "name": "maxRefFrames",
+            "in": "query",
+            "description": "Optional.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxVideoBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum video bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "requireAvc",
+            "in": "query",
+            "description": "Optional. Whether to require avc.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "deInterlace",
+            "in": "query",
+            "description": "Optional. Whether to deinterlace the video.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "requireNonAnamorphic",
+            "in": "query",
+            "description": "Optional. Whether to require a non anamorphic stream.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "transcodingMaxAudioChannels",
+            "in": "query",
+            "description": "Optional. The maximum number of audio channels to transcode.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "cpuCoreLimit",
+            "in": "query",
+            "description": "Optional. The limit of how many cpu cores to use.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableMpegtsM2TsMode",
+            "in": "query",
+            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "videoCodec",
+            "in": "query",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "subtitleCodec",
+            "in": "query",
+            "description": "Optional. Specify a subtitle codec to encode to.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "transcodeReasons",
+            "in": "query",
+            "description": "Optional. The transcoding reason.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "context",
+            "in": "query",
+            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
+            "schema": {
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
+            }
+          },
+          {
+            "name": "streamOptions",
+            "in": "query",
+            "description": "Optional. The streaming options.",
+            "schema": {
+              "type": "object",
+              "additionalProperties": {
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
+            }
+          }
+        ],
+        "responses": {
+          "200": {
+            "description": "Video stream returned.",
+            "content": {
+              "video/*": {
+                "schema": {
+                  "type": "string",
+                  "format": "binary"
+                }
+              }
+            }
+          }
+        }
+      },
+      "head": {
+        "tags": [
+          "Videos"
+        ],
+        "summary": "Gets a video stream.",
+        "operationId": "HeadVideoStreamByContainer",
+        "parameters": [
+          {
+            "name": "itemId",
+            "in": "path",
+            "description": "The item id.",
+            "required": true,
+            "schema": {
+              "type": "string",
+              "format": "uuid"
+            }
+          },
+          {
+            "name": "container",
+            "in": "path",
+            "description": "The video container. Possible values are: ts, webm, asf, wmv, ogv, mp4, m4v, mkv, mpeg, mpg, avi, 3gp, wmv, wtv, m2ts, mov, iso, flv.",
+            "required": true,
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "static",
+            "in": "query",
+            "description": "Optional. If true, the original file will be streamed statically without any encoding. Use either no url extension or the original file extension. true/false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "params",
+            "in": "query",
+            "description": "The streaming parameters.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "tag",
+            "in": "query",
+            "description": "The tag.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceProfileId",
+            "in": "query",
+            "description": "Optional. The dlna device profile id to utilize.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "playSessionId",
+            "in": "query",
+            "description": "The play session id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentContainer",
+            "in": "query",
+            "description": "The segment container.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "segmentLength",
+            "in": "query",
+            "description": "The segment length.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "minSegments",
+            "in": "query",
+            "description": "The minimum number of segments.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "mediaSourceId",
+            "in": "query",
+            "description": "The media version id, if playing an alternate version.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "deviceId",
+            "in": "query",
+            "description": "The device id of the client requesting. Used to stop encoding processes when needed.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioCodec",
+            "in": "query",
+            "description": "Optional. Specify an audio codec to encode to, e.g. mp3. If omitted the server will auto-select using the url's extension.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableAutoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow automatic stream copy if requested values match the original source. Defaults to true.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowVideoStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the video stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "allowAudioStreamCopy",
+            "in": "query",
+            "description": "Whether or not to allow copying of the audio stream url.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "breakOnNonKeyFrames",
+            "in": "query",
+            "description": "Optional. Whether to break on non key frames.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "audioSampleRate",
+            "in": "query",
+            "description": "Optional. Specify a specific audio sample rate, e.g. 44100.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum audio bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioBitRate",
+            "in": "query",
+            "description": "Optional. Specify an audio bitrate to encode to, e.g. 128000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "audioChannels",
+            "in": "query",
+            "description": "Optional. Specify a specific number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxAudioChannels",
+            "in": "query",
+            "description": "Optional. Specify a maximum number of audio channels to encode to, e.g. 2.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "profile",
+            "in": "query",
+            "description": "Optional. Specify a specific an encoder profile (varies by encoder), e.g. main, baseline, high.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "level",
+            "in": "query",
+            "description": "Optional. Specify a level for the encoder profile (varies by encoder), e.g. 3, 3.1.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "framerate",
+            "in": "query",
+            "description": "Optional. A specific video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "maxFramerate",
+            "in": "query",
+            "description": "Optional. A specific maximum video framerate to encode to, e.g. 23.976. Generally this should be omitted unless the device has specific requirements.",
+            "schema": {
+              "type": "number",
+              "format": "float"
+            }
+          },
+          {
+            "name": "copyTimestamps",
+            "in": "query",
+            "description": "Whether or not to copy timestamps when transcoding with an offset. Defaults to false.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "startTimeTicks",
+            "in": "query",
+            "description": "Optional. Specify a starting offset, in ticks. 1 tick = 10000 ms.",
+            "schema": {
+              "type": "integer",
+              "format": "int64"
+            }
+          },
+          {
+            "name": "width",
+            "in": "query",
+            "description": "Optional. The fixed horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "height",
+            "in": "query",
+            "description": "Optional. The fixed vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxWidth",
+            "in": "query",
+            "description": "Optional. The maximum horizontal resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxHeight",
+            "in": "query",
+            "description": "Optional. The maximum vertical resolution of the encoded video.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoBitRate",
+            "in": "query",
+            "description": "Optional. Specify a video bitrate to encode to, e.g. 500000. If omitted this will be left to encoder defaults.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the subtitle stream to use. If omitted no subtitles will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "subtitleMethod",
+            "in": "query",
+            "description": "Optional. Specify the subtitle delivery method.",
+            "schema": {
+              "enum": [
+                "Encode",
+                "Embed",
+                "External",
+                "Hls",
+                "Drop"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+                }
+              ]
+            }
+          },
+          {
+            "name": "maxRefFrames",
+            "in": "query",
+            "description": "Optional.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "maxVideoBitDepth",
+            "in": "query",
+            "description": "Optional. The maximum video bit depth.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "requireAvc",
+            "in": "query",
+            "description": "Optional. Whether to require avc.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "deInterlace",
+            "in": "query",
+            "description": "Optional. Whether to deinterlace the video.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "requireNonAnamorphic",
+            "in": "query",
+            "description": "Optional. Whether to require a non anamorphic stream.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "transcodingMaxAudioChannels",
+            "in": "query",
+            "description": "Optional. The maximum number of audio channels to transcode.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "cpuCoreLimit",
+            "in": "query",
+            "description": "Optional. The limit of how many cpu cores to use.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "liveStreamId",
+            "in": "query",
+            "description": "The live stream id.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "enableMpegtsM2TsMode",
+            "in": "query",
+            "description": "Optional. Whether to enable the MpegtsM2Ts mode.",
+            "schema": {
+              "type": "boolean"
+            }
+          },
+          {
+            "name": "videoCodec",
+            "in": "query",
+            "description": "Optional. Specify a video codec to encode to, e.g. h264. If omitted the server will auto-select using the url's extension.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "subtitleCodec",
+            "in": "query",
+            "description": "Optional. Specify a subtitle codec to encode to.",
+            "schema": {
+              "pattern": "^[a-zA-Z0-9\\-\\._,|]{0,40}$",
+              "type": "string"
+            }
+          },
+          {
+            "name": "transcodeReasons",
+            "in": "query",
+            "description": "Optional. The transcoding reason.",
+            "schema": {
+              "type": "string"
+            }
+          },
+          {
+            "name": "audioStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the audio stream to use. If omitted the first audio stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "videoStreamIndex",
+            "in": "query",
+            "description": "Optional. The index of the video stream to use. If omitted the first video stream will be used.",
+            "schema": {
+              "type": "integer",
+              "format": "int32"
+            }
+          },
+          {
+            "name": "context",
+            "in": "query",
+            "description": "Optional. The MediaBrowser.Model.Dlna.EncodingContext.",
+            "schema": {
+              "enum": [
+                "Streaming",
+                "Static"
+              ],
+              "allOf": [
+                {
+                  "$ref": "#/components/schemas/EncodingContext"
+                }
+              ]
+            }
+          },
+          {
+            "name": "streamOptions",
+            "in": "query",
+            "description": "Optional. The streaming options.",
+            "schema": {
+              "type": "object",
+              "additionalProperties": {
+                "type": "string",
+                "nullable": true
+              }
+            }
+          },
+          {
+            "name": "enableAudioVbrEncoding",
+            "in": "query",
+            "description": "Optional. Whether to enable Audio Encoding.",
+            "schema": {
+              "type": "boolean",
+              "default": true
             }
           }
         ],
@@ -45077,8 +43615,7 @@
               "items": {
                 "type": "string",
                 "format": "uuid"
-              },
-              "description": "Item id list. This allows multiple, comma delimited."
+              }
             }
           }
         ],
@@ -45136,9 +43673,7 @@
             "description": "Skips over a given number of items within the results. Use for paging.",
             "schema": {
               "type": "integer",
-              "description": "Skips over a given number of items within the results. Use for paging.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -45147,9 +43682,7 @@
             "description": "Optional. The maximum number of records to return.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The maximum number of records to return.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -45157,9 +43690,10 @@
             "in": "query",
             "description": "Sort Order - Ascending,Descending.",
             "schema": {
-              "type": "string",
-              "description": "Sort Order - Ascending,Descending.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/SortOrder"
+              }
             }
           },
           {
@@ -45168,9 +43702,7 @@
             "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
             "schema": {
               "type": "string",
-              "description": "Specify this to localize the search to a specific item or folder. Omit to use the root.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -45181,9 +43713,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ItemFields"
-              },
-              "description": "Optional. Specify additional fields of information to return in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -45193,10 +43723,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be excluded based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -45206,10 +43734,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. If specified, results will be included based on item type. This allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
             }
           },
           {
@@ -45219,10 +43745,8 @@
             "schema": {
               "type": "array",
               "items": {
-                "type": "string"
-              },
-              "description": "Optional. Filter by MediaType. Allows multiple, comma delimited.",
-              "nullable": true
+                "$ref": "#/components/schemas/MediaType"
+              }
             }
           },
           {
@@ -45230,9 +43754,10 @@
             "in": "query",
             "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
             "schema": {
-              "type": "string",
-              "description": "Optional. Specify one or more sort orders, comma delimited. Options: Album, AlbumArtist, Artist, Budget, CommunityRating, CriticRating, DateCreated, DatePlayed, PlayCount, PremiereDate, ProductionYear, SortName, Random, Revenue, Runtime.",
-              "nullable": true
+              "type": "array",
+              "items": {
+                "$ref": "#/components/schemas/ItemSortBy"
+              }
             }
           },
           {
@@ -45240,9 +43765,7 @@
             "in": "query",
             "description": "Optional. Include user data.",
             "schema": {
-              "type": "boolean",
-              "description": "Optional. Include user data.",
-              "nullable": true
+              "type": "boolean"
             }
           },
           {
@@ -45251,9 +43774,7 @@
             "description": "Optional. The max number of images to return, per image type.",
             "schema": {
               "type": "integer",
-              "description": "Optional. The max number of images to return, per image type.",
-              "format": "int32",
-              "nullable": true
+              "format": "int32"
             }
           },
           {
@@ -45264,9 +43785,7 @@
               "type": "array",
               "items": {
                 "$ref": "#/components/schemas/ImageType"
-              },
-              "description": "Optional. The image types to include in the output.",
-              "nullable": true
+              }
             }
           },
           {
@@ -45275,9 +43794,7 @@
             "description": "User Id.",
             "schema": {
               "type": "string",
-              "description": "User Id.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           },
           {
@@ -45286,7 +43803,6 @@
             "description": "Search recursively.",
             "schema": {
               "type": "boolean",
-              "description": "Search recursively.",
               "default": true
             }
           },
@@ -45296,9 +43812,7 @@
             "description": "Optional. Include image information in output.",
             "schema": {
               "type": "boolean",
-              "description": "Optional. Include image information in output.",
-              "default": true,
-              "nullable": true
+              "default": true
             }
           }
         ],
@@ -45354,7 +43868,6 @@
             "required": true,
             "schema": {
               "type": "integer",
-              "description": "The year.",
               "format": "int32"
             }
           },
@@ -45364,9 +43877,7 @@
             "description": "Optional. Filter by user id, and attach user data.",
             "schema": {
               "type": "string",
-              "description": "Optional. Filter by user id, and attach user data.",
-              "format": "uuid",
-              "nullable": true
+              "format": "uuid"
             }
           }
         ],
@@ -45430,17 +43941,53 @@
   },
   "components": {
     "schemas": {
-      "LogLevel": {
-        "enum": [
-          "Trace",
-          "Debug",
-          "Information",
-          "Warning",
-          "Error",
-          "Critical",
-          "None"
-        ],
-        "type": "string"
+      "AccessSchedule": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "integer",
+            "description": "Gets the id of this instance.",
+            "format": "int32",
+            "readOnly": true
+          },
+          "UserId": {
+            "type": "string",
+            "description": "Gets the id of the associated user.",
+            "format": "uuid"
+          },
+          "DayOfWeek": {
+            "enum": [
+              "Sunday",
+              "Monday",
+              "Tuesday",
+              "Wednesday",
+              "Thursday",
+              "Friday",
+              "Saturday",
+              "Everyday",
+              "Weekday",
+              "Weekend"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DynamicDayOfWeek"
+              }
+            ],
+            "description": "Gets or sets the day of week."
+          },
+          "StartHour": {
+            "type": "number",
+            "description": "Gets or sets the start hour.",
+            "format": "double"
+          },
+          "EndHour": {
+            "type": "number",
+            "description": "Gets or sets the end hour.",
+            "format": "double"
+          }
+        },
+        "additionalProperties": false,
+        "description": "An entity representing a user's access schedule."
       },
       "ActivityLogEntry": {
         "type": "object",
@@ -45452,8 +43999,7 @@
           },
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "Overview": {
             "type": "string",
@@ -45467,8 +44013,7 @@
           },
           "Type": {
             "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
+            "description": "Gets or sets the type."
           },
           "ItemId": {
             "type": "string",
@@ -45492,10 +44037,91 @@
             "deprecated": true
           },
           "Severity": {
-            "$ref": "#/components/schemas/LogLevel"
+            "enum": [
+              "Trace",
+              "Debug",
+              "Information",
+              "Warning",
+              "Error",
+              "Critical",
+              "None"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LogLevel"
+              }
+            ],
+            "description": "Gets or sets the log severity."
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "An activity log entry."
+      },
+      "ActivityLogEntryMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ActivityLogEntry"
+            },
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ActivityLogEntry",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Activity log created message."
       },
       "ActivityLogEntryQueryResult": {
         "type": "object",
@@ -45505,22 +44131,417 @@
             "items": {
               "$ref": "#/components/schemas/ActivityLogEntry"
             },
-            "description": "Gets or sets the items.",
-            "nullable": true
+            "description": "Gets or sets the items."
           },
           "TotalRecordCount": {
             "type": "integer",
-            "description": "The total number of records available.",
+            "description": "Gets or sets the total number of records available.",
             "format": "int32"
           },
           "StartIndex": {
             "type": "integer",
-            "description": "The index of the first record in Items.",
+            "description": "Gets or sets the index of the first record in Items.",
             "format": "int32"
           }
         },
+        "additionalProperties": false,
+        "description": "Query result container."
+      },
+      "ActivityLogEntryStartMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "string",
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ActivityLogEntryStart",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Activity log entry start message.\r\nData is the timing data encoded as \"$initialDelay,$interval\" in ms."
+      },
+      "ActivityLogEntryStopMessage": {
+        "type": "object",
+        "properties": {
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ActivityLogEntryStop",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Activity log entry stop message."
+      },
+      "AddVirtualFolderDto": {
+        "type": "object",
+        "properties": {
+          "LibraryOptions": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LibraryOptions"
+              }
+            ],
+            "description": "Gets or sets library options.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Add virtual folder dto."
+      },
+      "AlbumInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          },
+          "AlbumArtists": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the album artist."
+          },
+          "ArtistProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the artist provider ids."
+          },
+          "SongInfos": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SongInfo"
+            }
+          }
+        },
         "additionalProperties": false
       },
+      "AlbumInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/AlbumInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "AllThemeMediaResult": {
+        "type": "object",
+        "properties": {
+          "ThemeVideosResult": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ThemeMediaResult"
+              }
+            ],
+            "description": "Class ThemeMediaResult.",
+            "nullable": true
+          },
+          "ThemeSongsResult": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ThemeMediaResult"
+              }
+            ],
+            "description": "Class ThemeMediaResult.",
+            "nullable": true
+          },
+          "SoundtrackSongsResult": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ThemeMediaResult"
+              }
+            ],
+            "description": "Class ThemeMediaResult.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "ArtistInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          },
+          "SongInfos": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SongInfo"
+            }
+          }
+        },
+        "additionalProperties": false
+      },
+      "ArtistInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ArtistInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "AudioSpatialFormat": {
+        "enum": [
+          "None",
+          "DolbyAtmos",
+          "DTSX"
+        ],
+        "type": "string",
+        "description": "An enum representing formats of spatial audio."
+      },
+      "AuthenticateUserByName": {
+        "type": "object",
+        "properties": {
+          "Username": {
+            "type": "string",
+            "description": "Gets or sets the username.",
+            "nullable": true
+          },
+          "Pw": {
+            "type": "string",
+            "description": "Gets or sets the plain text password.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "The authenticate user by name request body."
+      },
       "AuthenticationInfo": {
         "type": "object",
         "properties": {
@@ -45593,984 +44614,56 @@
             "items": {
               "$ref": "#/components/schemas/AuthenticationInfo"
             },
-            "description": "Gets or sets the items.",
-            "nullable": true
+            "description": "Gets or sets the items."
           },
           "TotalRecordCount": {
             "type": "integer",
-            "description": "The total number of records available.",
+            "description": "Gets or sets the total number of records available.",
             "format": "int32"
           },
           "StartIndex": {
             "type": "integer",
-            "description": "The index of the first record in Items.",
+            "description": "Gets or sets the index of the first record in Items.",
             "format": "int32"
           }
         },
-        "additionalProperties": false
-      },
-      "ItemFields": {
-        "enum": [
-          "AirTime",
-          "CanDelete",
-          "CanDownload",
-          "ChannelInfo",
-          "Chapters",
-          "ChildCount",
-          "CumulativeRunTimeTicks",
-          "CustomRating",
-          "DateCreated",
-          "DateLastMediaAdded",
-          "DisplayPreferencesId",
-          "Etag",
-          "ExternalUrls",
-          "Genres",
-          "HomePageUrl",
-          "ItemCounts",
-          "MediaSourceCount",
-          "MediaSources",
-          "OriginalTitle",
-          "Overview",
-          "ParentId",
-          "Path",
-          "People",
-          "PlayAccess",
-          "ProductionLocations",
-          "ProviderIds",
-          "PrimaryImageAspectRatio",
-          "RecursiveItemCount",
-          "Settings",
-          "ScreenshotImageTags",
-          "SeriesPrimaryImage",
-          "SeriesStudio",
-          "SortName",
-          "SpecialEpisodeNumbers",
-          "Studios",
-          "BasicSyncInfo",
-          "SyncInfo",
-          "Taglines",
-          "Tags",
-          "RemoteTrailers",
-          "MediaStreams",
-          "SeasonUserData",
-          "ServiceName",
-          "ThemeSongIds",
-          "ThemeVideoIds",
-          "ExternalEtag",
-          "PresentationUniqueKey",
-          "InheritedParentalRatingValue",
-          "ExternalSeriesId",
-          "SeriesPresentationUniqueKey",
-          "DateLastRefreshed",
-          "DateLastSaved",
-          "RefreshState",
-          "ChannelImage",
-          "EnableMediaSourceDisplay",
-          "Width",
-          "Height",
-          "ExtraIds",
-          "LocalTrailerCount",
-          "IsHD",
-          "SpecialFeatureCount"
-        ],
-        "type": "string",
-        "description": "Used to control the data that gets attached to DtoBaseItems."
-      },
-      "ItemFilter": {
-        "enum": [
-          "IsFolder",
-          "IsNotFolder",
-          "IsUnplayed",
-          "IsPlayed",
-          "IsFavorite",
-          "IsResumable",
-          "Likes",
-          "Dislikes",
-          "IsFavoriteOrLikes"
-        ],
-        "type": "string",
-        "description": "Enum ItemFilter."
-      },
-      "ImageType": {
-        "enum": [
-          "Primary",
-          "Art",
-          "Backdrop",
-          "Banner",
-          "Logo",
-          "Thumb",
-          "Disc",
-          "Box",
-          "Screenshot",
-          "Menu",
-          "Chapter",
-          "BoxRear",
-          "Profile"
-        ],
-        "type": "string",
-        "description": "Enum ImageType."
-      },
-      "Video3DFormat": {
-        "enum": [
-          "HalfSideBySide",
-          "FullSideBySide",
-          "FullTopAndBottom",
-          "HalfTopAndBottom",
-          "MVC"
-        ],
-        "type": "string"
-      },
-      "ExternalUrl": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Url": {
-            "type": "string",
-            "description": "Gets or sets the type of the item.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "MediaProtocol": {
-        "enum": [
-          "File",
-          "Http",
-          "Rtmp",
-          "Rtsp",
-          "Udp",
-          "Rtp",
-          "Ftp"
-        ],
-        "type": "string"
-      },
-      "MediaSourceType": {
-        "enum": [
-          "Default",
-          "Grouping",
-          "Placeholder"
-        ],
-        "type": "string"
-      },
-      "VideoType": {
-        "enum": [
-          "VideoFile",
-          "Iso",
-          "Dvd",
-          "BluRay"
-        ],
-        "type": "string",
-        "description": "Enum VideoType."
-      },
-      "IsoType": {
-        "enum": [
-          "Dvd",
-          "BluRay"
-        ],
-        "type": "string",
-        "description": "Enum IsoType."
-      },
-      "MediaStreamType": {
-        "enum": [
-          "Audio",
-          "Video",
-          "Subtitle",
-          "EmbeddedImage"
-        ],
-        "type": "string",
-        "description": "Enum MediaStreamType."
-      },
-      "SubtitleDeliveryMethod": {
-        "enum": [
-          "Encode",
-          "Embed",
-          "External",
-          "Hls"
-        ],
-        "type": "string"
-      },
-      "MediaStream": {
-        "type": "object",
-        "properties": {
-          "Codec": {
-            "type": "string",
-            "description": "Gets or sets the codec.",
-            "nullable": true
-          },
-          "CodecTag": {
-            "type": "string",
-            "description": "Gets or sets the codec tag.",
-            "nullable": true
-          },
-          "Language": {
-            "type": "string",
-            "description": "Gets or sets the language.",
-            "nullable": true
-          },
-          "ColorRange": {
-            "type": "string",
-            "description": "Gets or sets the color range.",
-            "nullable": true
-          },
-          "ColorSpace": {
-            "type": "string",
-            "description": "Gets or sets the color space.",
-            "nullable": true
-          },
-          "ColorTransfer": {
-            "type": "string",
-            "description": "Gets or sets the color transfer.",
-            "nullable": true
-          },
-          "ColorPrimaries": {
-            "type": "string",
-            "description": "Gets or sets the color primaries.",
-            "nullable": true
-          },
-          "Comment": {
-            "type": "string",
-            "description": "Gets or sets the comment.",
-            "nullable": true
-          },
-          "TimeBase": {
-            "type": "string",
-            "description": "Gets or sets the time base.",
-            "nullable": true
-          },
-          "CodecTimeBase": {
-            "type": "string",
-            "description": "Gets or sets the codec time base.",
-            "nullable": true
-          },
-          "Title": {
-            "type": "string",
-            "description": "Gets or sets the title.",
-            "nullable": true
-          },
-          "VideoRange": {
-            "type": "string",
-            "description": "Gets or sets the video range.",
-            "nullable": true,
-            "readOnly": true
-          },
-          "localizedUndefined": {
-            "type": "string",
-            "nullable": true
-          },
-          "localizedDefault": {
-            "type": "string",
-            "nullable": true
-          },
-          "localizedForced": {
-            "type": "string",
-            "nullable": true
-          },
-          "DisplayTitle": {
-            "type": "string",
-            "nullable": true,
-            "readOnly": true
-          },
-          "NalLengthSize": {
-            "type": "string",
-            "nullable": true
-          },
-          "IsInterlaced": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is interlaced."
-          },
-          "IsAVC": {
-            "type": "boolean",
-            "nullable": true
-          },
-          "ChannelLayout": {
-            "type": "string",
-            "description": "Gets or sets the channel layout.",
-            "nullable": true
-          },
-          "BitRate": {
-            "type": "integer",
-            "description": "Gets or sets the bit rate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "BitDepth": {
-            "type": "integer",
-            "description": "Gets or sets the bit depth.",
-            "format": "int32",
-            "nullable": true
-          },
-          "RefFrames": {
-            "type": "integer",
-            "description": "Gets or sets the reference frames.",
-            "format": "int32",
-            "nullable": true
-          },
-          "PacketLength": {
-            "type": "integer",
-            "description": "Gets or sets the length of the packet.",
-            "format": "int32",
-            "nullable": true
-          },
-          "Channels": {
-            "type": "integer",
-            "description": "Gets or sets the channels.",
-            "format": "int32",
-            "nullable": true
-          },
-          "SampleRate": {
-            "type": "integer",
-            "description": "Gets or sets the sample rate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IsDefault": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is default."
-          },
-          "IsForced": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is forced."
-          },
-          "Height": {
-            "type": "integer",
-            "description": "Gets or sets the height.",
-            "format": "int32",
-            "nullable": true
-          },
-          "Width": {
-            "type": "integer",
-            "description": "Gets or sets the width.",
-            "format": "int32",
-            "nullable": true
-          },
-          "AverageFrameRate": {
-            "type": "number",
-            "description": "Gets or sets the average frame rate.",
-            "format": "float",
-            "nullable": true
-          },
-          "RealFrameRate": {
-            "type": "number",
-            "description": "Gets or sets the real frame rate.",
-            "format": "float",
-            "nullable": true
-          },
-          "Profile": {
-            "type": "string",
-            "description": "Gets or sets the profile.",
-            "nullable": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/MediaStreamType"
-          },
-          "AspectRatio": {
-            "type": "string",
-            "description": "Gets or sets the aspect ratio.",
-            "nullable": true
-          },
-          "Index": {
-            "type": "integer",
-            "description": "Gets or sets the index.",
-            "format": "int32"
-          },
-          "Score": {
-            "type": "integer",
-            "description": "Gets or sets the score.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IsExternal": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is external."
-          },
-          "DeliveryMethod": {
-            "$ref": "#/components/schemas/SubtitleDeliveryMethod"
-          },
-          "DeliveryUrl": {
-            "type": "string",
-            "description": "Gets or sets the delivery URL.",
-            "nullable": true
-          },
-          "IsExternalUrl": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is external URL.",
-            "nullable": true
-          },
-          "IsTextSubtitleStream": {
-            "type": "boolean",
-            "readOnly": true
-          },
-          "SupportsExternalStream": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [supports external stream]."
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the filename.",
-            "nullable": true
-          },
-          "PixelFormat": {
-            "type": "string",
-            "description": "Gets or sets the pixel format.",
-            "nullable": true
-          },
-          "Level": {
-            "type": "number",
-            "description": "Gets or sets the level.",
-            "format": "double",
-            "nullable": true
-          },
-          "IsAnamorphic": {
-            "type": "boolean",
-            "description": "Gets a value indicating whether this instance is anamorphic.",
-            "nullable": true
-          }
-        },
         "additionalProperties": false,
-        "description": "Class MediaStream."
+        "description": "Query result container."
       },
-      "MediaAttachment": {
+      "AuthenticationResult": {
         "type": "object",
         "properties": {
-          "Codec": {
-            "type": "string",
-            "description": "Gets or sets the codec.",
-            "nullable": true
-          },
-          "CodecTag": {
-            "type": "string",
-            "description": "Gets or sets the codec tag.",
-            "nullable": true
-          },
-          "Comment": {
-            "type": "string",
-            "description": "Gets or sets the comment.",
-            "nullable": true
-          },
-          "Index": {
-            "type": "integer",
-            "description": "Gets or sets the index.",
-            "format": "int32"
-          },
-          "FileName": {
-            "type": "string",
-            "description": "Gets or sets the filename.",
-            "nullable": true
-          },
-          "MimeType": {
-            "type": "string",
-            "description": "Gets or sets the MIME type.",
-            "nullable": true
-          },
-          "DeliveryUrl": {
-            "type": "string",
-            "description": "Gets or sets the delivery URL.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class MediaAttachment."
-      },
-      "TransportStreamTimestamp": {
-        "enum": [
-          "None",
-          "Zero",
-          "Valid"
-        ],
-        "type": "string"
-      },
-      "MediaSourceInfo": {
-        "type": "object",
-        "properties": {
-          "Protocol": {
-            "$ref": "#/components/schemas/MediaProtocol"
-          },
-          "Id": {
-            "type": "string",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "nullable": true
-          },
-          "EncoderPath": {
-            "type": "string",
-            "nullable": true
-          },
-          "EncoderProtocol": {
-            "$ref": "#/components/schemas/MediaProtocol"
-          },
-          "Type": {
-            "$ref": "#/components/schemas/MediaSourceType"
-          },
-          "Container": {
-            "type": "string",
-            "nullable": true
-          },
-          "Size": {
-            "type": "integer",
-            "format": "int64",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "IsRemote": {
-            "type": "boolean",
-            "description": "Differentiate internet url vs local network."
-          },
-          "ETag": {
-            "type": "string",
-            "nullable": true
-          },
-          "RunTimeTicks": {
-            "type": "integer",
-            "format": "int64",
-            "nullable": true
-          },
-          "ReadAtNativeFramerate": {
-            "type": "boolean"
-          },
-          "IgnoreDts": {
-            "type": "boolean"
-          },
-          "IgnoreIndex": {
-            "type": "boolean"
-          },
-          "GenPtsInput": {
-            "type": "boolean"
-          },
-          "SupportsTranscoding": {
-            "type": "boolean"
-          },
-          "SupportsDirectStream": {
-            "type": "boolean"
-          },
-          "SupportsDirectPlay": {
-            "type": "boolean"
-          },
-          "IsInfiniteStream": {
-            "type": "boolean"
-          },
-          "RequiresOpening": {
-            "type": "boolean"
-          },
-          "OpenToken": {
-            "type": "string",
-            "nullable": true
-          },
-          "RequiresClosing": {
-            "type": "boolean"
-          },
-          "LiveStreamId": {
-            "type": "string",
-            "nullable": true
-          },
-          "BufferMs": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "RequiresLooping": {
-            "type": "boolean"
-          },
-          "SupportsProbing": {
-            "type": "boolean"
-          },
-          "VideoType": {
-            "$ref": "#/components/schemas/VideoType"
-          },
-          "IsoType": {
-            "$ref": "#/components/schemas/IsoType"
-          },
-          "Video3DFormat": {
-            "$ref": "#/components/schemas/Video3DFormat"
-          },
-          "MediaStreams": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/MediaStream"
-            },
-            "nullable": true
-          },
-          "MediaAttachments": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/MediaAttachment"
-            },
-            "nullable": true
-          },
-          "Formats": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "Bitrate": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "Timestamp": {
-            "$ref": "#/components/schemas/TransportStreamTimestamp"
-          },
-          "RequiredHttpHeaders": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "TranscodingUrl": {
-            "type": "string",
-            "nullable": true
-          },
-          "TranscodingSubProtocol": {
-            "type": "string",
-            "nullable": true
-          },
-          "TranscodingContainer": {
-            "type": "string",
-            "nullable": true
-          },
-          "AnalyzeDurationMs": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "DefaultAudioStreamIndex": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "DefaultSubtitleStreamIndex": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "PlayAccess": {
-        "enum": [
-          "Full",
-          "None"
-        ],
-        "type": "string"
-      },
-      "MediaUrl": {
-        "type": "object",
-        "properties": {
-          "Url": {
-            "type": "string",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "BaseItemPerson": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the identifier.",
-            "nullable": true
-          },
-          "Role": {
-            "type": "string",
-            "description": "Gets or sets the role.",
-            "nullable": true
-          },
-          "Type": {
-            "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
-          },
-          "PrimaryImageTag": {
-            "type": "string",
-            "description": "Gets or sets the primary image tag.",
-            "nullable": true
-          },
-          "ImageBlurHashes": {
-            "type": "object",
-            "properties": {
-              "Primary": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Art": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Backdrop": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Banner": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Logo": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Thumb": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Disc": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Box": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Screenshot": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Menu": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Chapter": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "BoxRear": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
-              },
-              "Profile": {
-                "type": "object",
-                "additionalProperties": {
-                  "type": "string"
-                }
+          "User": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserDto"
               }
-            },
-            "description": "Gets or sets the primary image blurhash.",
+            ],
+            "description": "Gets or sets the user.",
+            "nullable": true
+          },
+          "SessionInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionInfoDto"
+              }
+            ],
+            "description": "Gets or sets the session info.",
+            "nullable": true
+          },
+          "AccessToken": {
+            "type": "string",
+            "description": "Gets or sets the access token.",
+            "nullable": true
+          },
+          "ServerId": {
+            "type": "string",
+            "description": "Gets or sets the server id.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "This is used by the api to get information about a Person within a BaseItem."
-      },
-      "NameGuidPair": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false
-      },
-      "UserItemDataDto": {
-        "type": "object",
-        "properties": {
-          "Rating": {
-            "type": "number",
-            "description": "Gets or sets the rating.",
-            "format": "double",
-            "nullable": true
-          },
-          "PlayedPercentage": {
-            "type": "number",
-            "description": "Gets or sets the played percentage.",
-            "format": "double",
-            "nullable": true
-          },
-          "UnplayedItemCount": {
-            "type": "integer",
-            "description": "Gets or sets the unplayed item count.",
-            "format": "int32",
-            "nullable": true
-          },
-          "PlaybackPositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the playback position ticks.",
-            "format": "int64"
-          },
-          "PlayCount": {
-            "type": "integer",
-            "description": "Gets or sets the play count.",
-            "format": "int32"
-          },
-          "IsFavorite": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is favorite."
-          },
-          "Likes": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is likes.",
-            "nullable": true
-          },
-          "LastPlayedDate": {
-            "type": "string",
-            "description": "Gets or sets the last played date.",
-            "format": "date-time",
-            "nullable": true
-          },
-          "Played": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is played."
-          },
-          "Key": {
-            "type": "string",
-            "description": "Gets or sets the key.",
-            "nullable": true
-          },
-          "ItemId": {
-            "type": "string",
-            "description": "Gets or sets the item identifier.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class UserItemDataDto."
-      },
-      "DayOfWeek": {
-        "enum": [
-          "Sunday",
-          "Monday",
-          "Tuesday",
-          "Wednesday",
-          "Thursday",
-          "Friday",
-          "Saturday"
-        ],
-        "type": "string"
-      },
-      "ChapterInfo": {
-        "type": "object",
-        "properties": {
-          "StartPositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the start position ticks.",
-            "format": "int64"
-          },
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "ImagePath": {
-            "type": "string",
-            "description": "Gets or sets the image path.",
-            "nullable": true
-          },
-          "ImageDateModified": {
-            "type": "string",
-            "format": "date-time"
-          },
-          "ImageTag": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class ChapterInfo."
-      },
-      "LocationType": {
-        "enum": [
-          "FileSystem",
-          "Remote",
-          "Virtual",
-          "Offline"
-        ],
-        "type": "string",
-        "description": "Enum LocationType."
-      },
-      "MetadataField": {
-        "enum": [
-          "Cast",
-          "Genres",
-          "ProductionLocations",
-          "Studios",
-          "Tags",
-          "Name",
-          "Overview",
-          "Runtime",
-          "OfficialRating"
-        ],
-        "type": "string",
-        "description": "Enum MetadataFields."
-      },
-      "ImageOrientation": {
-        "enum": [
-          "TopLeft",
-          "TopRight",
-          "BottomRight",
-          "BottomLeft",
-          "LeftTop",
-          "RightTop",
-          "RightBottom",
-          "LeftBottom"
-        ],
-        "type": "string"
-      },
-      "ChannelType": {
-        "enum": [
-          "TV",
-          "Radio"
-        ],
-        "type": "string",
-        "description": "Enum ChannelType."
-      },
-      "ProgramAudio": {
-        "enum": [
-          "Mono",
-          "Stereo",
-          "Dolby",
-          "DolbyDigital",
-          "Thx",
-          "Atmos"
-        ],
-        "type": "string"
+        "description": "A class representing an authentication result."
       },
       "BaseItemDto": {
         "type": "object",
@@ -46621,7 +44714,25 @@
             "nullable": true
           },
           "ExtraType": {
-            "type": "string",
+            "enum": [
+              "Unknown",
+              "Clip",
+              "Trailer",
+              "BehindTheScenes",
+              "DeletedScene",
+              "Interview",
+              "Scene",
+              "Sample",
+              "ThemeSong",
+              "ThemeVideo",
+              "Featurette",
+              "Short"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ExtraType"
+              }
+            ],
             "nullable": true
           },
           "AirsBeforeSeasonNumber": {
@@ -46647,6 +44758,10 @@
             "type": "boolean",
             "nullable": true
           },
+          "HasLyrics": {
+            "type": "boolean",
+            "nullable": true
+          },
           "HasSubtitles": {
             "type": "boolean",
             "nullable": true
@@ -46659,11 +44774,6 @@
             "type": "string",
             "nullable": true
           },
-          "SupportsSync": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [supports synchronize].",
-            "nullable": true
-          },
           "Container": {
             "type": "string",
             "nullable": true
@@ -46678,7 +44788,20 @@
             "nullable": true
           },
           "Video3DFormat": {
-            "$ref": "#/components/schemas/Video3DFormat"
+            "enum": [
+              "HalfSideBySide",
+              "FullSideBySide",
+              "FullTopAndBottom",
+              "HalfTopAndBottom",
+              "MVC"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/Video3DFormat"
+              }
+            ],
+            "description": "Gets or sets the video3 D format.",
+            "nullable": true
           },
           "PremiereDate": {
             "type": "string",
@@ -46784,7 +44907,17 @@
             "nullable": true
           },
           "PlayAccess": {
-            "$ref": "#/components/schemas/PlayAccess"
+            "enum": [
+              "Full",
+              "None"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayAccess"
+              }
+            ],
+            "description": "Gets or sets the play access.",
+            "nullable": true
           },
           "AspectRatio": {
             "type": "string",
@@ -46840,7 +44973,8 @@
           "ProviderIds": {
             "type": "object",
             "additionalProperties": {
-              "type": "string"
+              "type": "string",
+              "nullable": true
             },
             "description": "Gets or sets the provider ids.",
             "nullable": true
@@ -46862,9 +44996,51 @@
             "nullable": true
           },
           "Type": {
-            "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
+            "enum": [
+              "AggregateFolder",
+              "Audio",
+              "AudioBook",
+              "BasePluginFolder",
+              "Book",
+              "BoxSet",
+              "Channel",
+              "ChannelFolderItem",
+              "CollectionFolder",
+              "Episode",
+              "Folder",
+              "Genre",
+              "ManualPlaylistsFolder",
+              "Movie",
+              "LiveTvChannel",
+              "LiveTvProgram",
+              "MusicAlbum",
+              "MusicArtist",
+              "MusicGenre",
+              "MusicVideo",
+              "Person",
+              "Photo",
+              "PhotoAlbum",
+              "Playlist",
+              "PlaylistsFolder",
+              "Program",
+              "Recording",
+              "Season",
+              "Series",
+              "Studio",
+              "Trailer",
+              "TvChannel",
+              "TvProgram",
+              "UserRootFolder",
+              "UserView",
+              "Video",
+              "Year"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
+            ],
+            "description": "The base item kind."
           },
           "People": {
             "type": "array",
@@ -46891,12 +45067,14 @@
           },
           "ParentLogoItemId": {
             "type": "string",
-            "description": "If the item does not have a logo, this will hold the Id of the Parent that has one.",
+            "description": "Gets or sets whether the item has a logo, this will hold the Id of the Parent that has one.",
+            "format": "uuid",
             "nullable": true
           },
           "ParentBackdropItemId": {
             "type": "string",
-            "description": "If the item does not have any backdrops, this will hold the Id of the Parent that has one.",
+            "description": "Gets or sets whether the item has any backdrops, this will hold the Id of the Parent that has one.",
+            "format": "uuid",
             "nullable": true
           },
           "ParentBackdropImageTags": {
@@ -46914,7 +45092,13 @@
             "nullable": true
           },
           "UserData": {
-            "$ref": "#/components/schemas/UserItemDataDto"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserItemDataDto"
+              }
+            ],
+            "description": "Gets or sets the user data for this item based on the user it's being requested for.",
+            "nullable": true
           },
           "RecursiveItemCount": {
             "type": "integer",
@@ -47010,7 +45194,26 @@
             "nullable": true
           },
           "CollectionType": {
-            "type": "string",
+            "enum": [
+              "unknown",
+              "movies",
+              "tvshows",
+              "music",
+              "musicvideos",
+              "trailers",
+              "homevideos",
+              "boxsets",
+              "books",
+              "photos",
+              "livetv",
+              "playlists",
+              "folders"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/CollectionType"
+              }
+            ],
             "description": "Gets or sets the type of the collection.",
             "nullable": true
           },
@@ -47062,7 +45265,19 @@
             "nullable": true
           },
           "VideoType": {
-            "$ref": "#/components/schemas/VideoType"
+            "enum": [
+              "VideoFile",
+              "Iso",
+              "Dvd",
+              "BluRay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/VideoType"
+              }
+            ],
+            "description": "Gets or sets the type of the video.",
+            "nullable": true
           },
           "PartCount": {
             "type": "integer",
@@ -47106,7 +45321,8 @@
           },
           "ParentArtItemId": {
             "type": "string",
-            "description": "If the item does not have a art, this will hold the Id of the Parent that has one.",
+            "description": "Gets or sets whether the item has fan art, this will hold the Id of the Parent that has one.",
+            "format": "uuid",
             "nullable": true
           },
           "ParentArtImageTag": {
@@ -47212,6 +45428,7 @@
           "ParentThumbItemId": {
             "type": "string",
             "description": "Gets or sets the parent thumb item id.",
+            "format": "uuid",
             "nullable": true
           },
           "ParentThumbImageTag": {
@@ -47237,16 +45454,59 @@
             "description": "Gets or sets the chapters.",
             "nullable": true
           },
+          "Trickplay": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "object",
+              "additionalProperties": {
+                "$ref": "#/components/schemas/TrickplayInfo"
+              }
+            },
+            "description": "Gets or sets the trickplay manifest.",
+            "nullable": true
+          },
           "LocationType": {
-            "$ref": "#/components/schemas/LocationType"
+            "enum": [
+              "FileSystem",
+              "Remote",
+              "Virtual",
+              "Offline"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LocationType"
+              }
+            ],
+            "description": "Gets or sets the type of the location.",
+            "nullable": true
           },
           "IsoType": {
-            "$ref": "#/components/schemas/IsoType"
+            "enum": [
+              "Dvd",
+              "BluRay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/IsoType"
+              }
+            ],
+            "description": "Gets or sets the type of the iso.",
+            "nullable": true
           },
           "MediaType": {
-            "type": "string",
-            "description": "Gets or sets the type of the media.",
-            "nullable": true
+            "enum": [
+              "Unknown",
+              "Video",
+              "Audio",
+              "Photo",
+              "Book"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaType"
+              }
+            ],
+            "description": "Media types."
           },
           "EndDate": {
             "type": "string",
@@ -47352,7 +45612,22 @@
             "nullable": true
           },
           "ImageOrientation": {
-            "$ref": "#/components/schemas/ImageOrientation"
+            "enum": [
+              "TopLeft",
+              "TopRight",
+              "BottomRight",
+              "BottomLeft",
+              "LeftTop",
+              "RightTop",
+              "RightBottom",
+              "LeftBottom"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageOrientation"
+              }
+            ],
+            "nullable": true
           },
           "Aperture": {
             "type": "number",
@@ -47401,7 +45676,7 @@
           },
           "StartDate": {
             "type": "string",
-            "description": "The start date of the recording, in UTC.",
+            "description": "Gets or sets the start date of the recording, in UTC.",
             "format": "date-time",
             "nullable": true
           },
@@ -47422,10 +45697,34 @@
             "nullable": true
           },
           "ChannelType": {
-            "$ref": "#/components/schemas/ChannelType"
+            "enum": [
+              "TV",
+              "Radio"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ChannelType"
+              }
+            ],
+            "description": "Gets or sets the type of the channel.",
+            "nullable": true
           },
           "Audio": {
-            "$ref": "#/components/schemas/ProgramAudio"
+            "enum": [
+              "Mono",
+              "Stereo",
+              "Dolby",
+              "DolbyDigital",
+              "Thx",
+              "Atmos"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ProgramAudio"
+              }
+            ],
+            "description": "Gets or sets the audio.",
+            "nullable": true
           },
           "IsMovie": {
             "type": "boolean",
@@ -47467,8 +45766,20 @@
             "description": "Gets or sets the timer identifier.",
             "nullable": true
           },
+          "NormalizationGain": {
+            "type": "number",
+            "description": "Gets or sets the gain required for audio normalization.",
+            "format": "float",
+            "nullable": true
+          },
           "CurrentProgram": {
-            "$ref": "#/components/schemas/BaseItemDto"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the current program.",
+            "nullable": true
           }
         },
         "additionalProperties": false,
@@ -47482,28 +45793,402 @@
             "items": {
               "$ref": "#/components/schemas/BaseItemDto"
             },
-            "description": "Gets or sets the items.",
-            "nullable": true
+            "description": "Gets or sets the items."
           },
           "TotalRecordCount": {
             "type": "integer",
-            "description": "The total number of records available.",
+            "description": "Gets or sets the total number of records available.",
             "format": "int32"
           },
           "StartIndex": {
             "type": "integer",
-            "description": "The index of the first record in Items.",
+            "description": "Gets or sets the index of the first record in Items.",
             "format": "int32"
           }
         },
+        "additionalProperties": false,
+        "description": "Query result container."
+      },
+      "BaseItemKind": {
+        "enum": [
+          "AggregateFolder",
+          "Audio",
+          "AudioBook",
+          "BasePluginFolder",
+          "Book",
+          "BoxSet",
+          "Channel",
+          "ChannelFolderItem",
+          "CollectionFolder",
+          "Episode",
+          "Folder",
+          "Genre",
+          "ManualPlaylistsFolder",
+          "Movie",
+          "LiveTvChannel",
+          "LiveTvProgram",
+          "MusicAlbum",
+          "MusicArtist",
+          "MusicGenre",
+          "MusicVideo",
+          "Person",
+          "Photo",
+          "PhotoAlbum",
+          "Playlist",
+          "PlaylistsFolder",
+          "Program",
+          "Recording",
+          "Season",
+          "Series",
+          "Studio",
+          "Trailer",
+          "TvChannel",
+          "TvProgram",
+          "UserRootFolder",
+          "UserView",
+          "Video",
+          "Year"
+        ],
+        "type": "string",
+        "description": "The base item kind."
+      },
+      "BaseItemPerson": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the identifier.",
+            "format": "uuid"
+          },
+          "Role": {
+            "type": "string",
+            "description": "Gets or sets the role.",
+            "nullable": true
+          },
+          "Type": {
+            "enum": [
+              "Unknown",
+              "Actor",
+              "Director",
+              "Composer",
+              "Writer",
+              "GuestStar",
+              "Producer",
+              "Conductor",
+              "Lyricist",
+              "Arranger",
+              "Engineer",
+              "Mixer",
+              "Remixer",
+              "Creator",
+              "Artist",
+              "AlbumArtist",
+              "Author",
+              "Illustrator",
+              "Penciller",
+              "Inker",
+              "Colorist",
+              "Letterer",
+              "CoverArtist",
+              "Editor",
+              "Translator"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PersonKind"
+              }
+            ],
+            "description": "The person kind."
+          },
+          "PrimaryImageTag": {
+            "type": "string",
+            "description": "Gets or sets the primary image tag.",
+            "nullable": true
+          },
+          "ImageBlurHashes": {
+            "type": "object",
+            "properties": {
+              "Primary": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Art": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Backdrop": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Banner": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Logo": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Thumb": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Disc": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Box": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Screenshot": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Menu": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Chapter": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "BoxRear": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              },
+              "Profile": {
+                "type": "object",
+                "additionalProperties": {
+                  "type": "string"
+                }
+              }
+            },
+            "description": "Gets or sets the primary image blurhash.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "This is used by the api to get information about a Person within a BaseItem."
+      },
+      "BasePluginConfiguration": {
+        "type": "object",
+        "additionalProperties": false,
+        "description": "Class BasePluginConfiguration."
+      },
+      "BookInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          },
+          "SeriesName": {
+            "type": "string",
+            "nullable": true
+          }
+        },
         "additionalProperties": false
       },
-      "EncodingContext": {
-        "enum": [
-          "Streaming",
-          "Static"
-        ],
-        "type": "string"
+      "BookInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BookInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "BoxSetInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "BoxSetInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BoxSetInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
       },
       "BrandingOptions": {
         "type": "object",
@@ -47517,55 +46202,67 @@
             "type": "string",
             "description": "Gets or sets the custom CSS.",
             "nullable": true
+          },
+          "SplashscreenEnabled": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable the splashscreen."
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "The branding options."
       },
-      "ChannelMediaType": {
-        "enum": [
-          "Audio",
-          "Video",
-          "Photo"
-        ],
-        "type": "string"
+      "BufferRequestDto": {
+        "type": "object",
+        "properties": {
+          "When": {
+            "type": "string",
+            "description": "Gets or sets when the request has been made by the client.",
+            "format": "date-time"
+          },
+          "PositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the position ticks.",
+            "format": "int64"
+          },
+          "IsPlaying": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the client playback is unpaused."
+          },
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playlist item identifier of the playing item.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class BufferRequestDto."
       },
-      "ChannelMediaContentType": {
-        "enum": [
-          "Clip",
-          "Podcast",
-          "Trailer",
-          "Movie",
-          "Episode",
-          "Song",
-          "MovieExtra",
-          "TvExtra"
-        ],
-        "type": "string"
-      },
-      "ChannelItemSortField": {
-        "enum": [
-          "Name",
-          "CommunityRating",
-          "PremiereDate",
-          "DateCreated",
-          "Runtime",
-          "PlayCount",
-          "CommunityPlayCount"
-        ],
-        "type": "string"
+      "CastReceiverApplication": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the cast receiver application id."
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the cast receiver application name."
+          }
+        },
+        "additionalProperties": false,
+        "description": "The cast receiver application model."
       },
       "ChannelFeatures": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "Id": {
             "type": "string",
             "description": "Gets or sets the identifier.",
-            "nullable": true
+            "format": "uuid"
           },
           "CanSearch": {
             "type": "boolean",
@@ -47576,20 +46273,18 @@
             "items": {
               "$ref": "#/components/schemas/ChannelMediaType"
             },
-            "description": "Gets or sets the media types.",
-            "nullable": true
+            "description": "Gets or sets the media types."
           },
           "ContentTypes": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/ChannelMediaContentType"
             },
-            "description": "Gets or sets the content types.",
-            "nullable": true
+            "description": "Gets or sets the content types."
           },
           "MaxPageSize": {
             "type": "integer",
-            "description": "Represents the maximum number of records the channel allows retrieving at a time.",
+            "description": "Gets or sets the maximum number of records the channel allows retrieving at a time.",
             "format": "int32",
             "nullable": true
           },
@@ -47604,12 +46299,11 @@
             "items": {
               "$ref": "#/components/schemas/ChannelItemSortField"
             },
-            "description": "Gets or sets the default sort orders.",
-            "nullable": true
+            "description": "Gets or sets the default sort orders."
           },
           "SupportsSortOrderToggle": {
             "type": "boolean",
-            "description": "Indicates if a sort ascending/descending toggle is supported or not."
+            "description": "Gets or sets a value indicating whether a sort ascending/descending toggle is supported."
           },
           "SupportsLatestMedia": {
             "type": "boolean",
@@ -47626,6 +46320,226 @@
         },
         "additionalProperties": false
       },
+      "ChannelItemSortField": {
+        "enum": [
+          "Name",
+          "CommunityRating",
+          "PremiereDate",
+          "DateCreated",
+          "Runtime",
+          "PlayCount",
+          "CommunityPlayCount"
+        ],
+        "type": "string"
+      },
+      "ChannelMappingOptionsDto": {
+        "type": "object",
+        "properties": {
+          "TunerChannels": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TunerChannelMapping"
+            },
+            "description": "Gets or sets list of tuner channels."
+          },
+          "ProviderChannels": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/NameIdPair"
+            },
+            "description": "Gets or sets list of provider channels."
+          },
+          "Mappings": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/NameValuePair"
+            },
+            "description": "Gets or sets list of mappings."
+          },
+          "ProviderName": {
+            "type": "string",
+            "description": "Gets or sets provider name.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Channel mapping options dto."
+      },
+      "ChannelMediaContentType": {
+        "enum": [
+          "Clip",
+          "Podcast",
+          "Trailer",
+          "Movie",
+          "Episode",
+          "Song",
+          "MovieExtra",
+          "TvExtra"
+        ],
+        "type": "string"
+      },
+      "ChannelMediaType": {
+        "enum": [
+          "Audio",
+          "Video",
+          "Photo"
+        ],
+        "type": "string"
+      },
+      "ChannelType": {
+        "enum": [
+          "TV",
+          "Radio"
+        ],
+        "type": "string",
+        "description": "Enum ChannelType."
+      },
+      "ChapterInfo": {
+        "type": "object",
+        "properties": {
+          "StartPositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the start position ticks.",
+            "format": "int64"
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "ImagePath": {
+            "type": "string",
+            "description": "Gets or sets the image path.",
+            "nullable": true
+          },
+          "ImageDateModified": {
+            "type": "string",
+            "format": "date-time"
+          },
+          "ImageTag": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class ChapterInfo."
+      },
+      "ClientCapabilitiesDto": {
+        "type": "object",
+        "properties": {
+          "PlayableMediaTypes": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaType"
+            },
+            "description": "Gets or sets the list of playable media types."
+          },
+          "SupportedCommands": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/GeneralCommandType"
+            },
+            "description": "Gets or sets the list of supported commands."
+          },
+          "SupportsMediaControl": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether session supports media control."
+          },
+          "SupportsPersistentIdentifier": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether session supports a persistent identifier."
+          },
+          "DeviceProfile": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DeviceProfile"
+              }
+            ],
+            "description": "Gets or sets the device profile.",
+            "nullable": true
+          },
+          "AppStoreUrl": {
+            "type": "string",
+            "description": "Gets or sets the app store url.",
+            "nullable": true
+          },
+          "IconUrl": {
+            "type": "string",
+            "description": "Gets or sets the icon url.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Client capabilities dto."
+      },
+      "ClientLogDocumentResponseDto": {
+        "type": "object",
+        "properties": {
+          "FileName": {
+            "type": "string",
+            "description": "Gets the resulting filename."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Client log document response dto."
+      },
+      "CodecProfile": {
+        "type": "object",
+        "properties": {
+          "Type": {
+            "enum": [
+              "Video",
+              "VideoAudio",
+              "Audio"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/CodecType"
+              }
+            ],
+            "description": "Gets or sets the MediaBrowser.Model.Dlna.CodecType which this container must meet."
+          },
+          "Conditions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ProfileCondition"
+            },
+            "description": "Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this profile must meet."
+          },
+          "ApplyConditions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ProfileCondition"
+            },
+            "description": "Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition to apply if this profile is met."
+          },
+          "Codec": {
+            "type": "string",
+            "description": "Gets or sets the codec(s) that this profile applies to.",
+            "nullable": true
+          },
+          "Container": {
+            "type": "string",
+            "description": "Gets or sets the container(s) which this profile will be applied to.",
+            "nullable": true
+          },
+          "SubContainer": {
+            "type": "string",
+            "description": "Gets or sets the sub-container(s) which this profile will be applied to.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Model.Dlna.CodecProfile."
+      },
+      "CodecType": {
+        "enum": [
+          "Video",
+          "VideoAudio",
+          "Audio"
+        ],
+        "type": "string"
+      },
       "CollectionCreationResult": {
         "type": "object",
         "properties": {
@@ -47636,635 +46550,94 @@
         },
         "additionalProperties": false
       },
-      "Version": {
-        "type": "object",
-        "properties": {
-          "Major": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          },
-          "Minor": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          },
-          "Build": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          },
-          "Revision": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          },
-          "MajorRevision": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          },
-          "MinorRevision": {
-            "type": "integer",
-            "format": "int32",
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ImageSavingConvention": {
+      "CollectionType": {
         "enum": [
-          "Legacy",
-          "Compatible"
+          "unknown",
+          "movies",
+          "tvshows",
+          "music",
+          "musicvideos",
+          "trailers",
+          "homevideos",
+          "boxsets",
+          "books",
+          "photos",
+          "livetv",
+          "playlists",
+          "folders"
         ],
-        "type": "string"
+        "type": "string",
+        "description": "Collection type."
       },
-      "MetadataOptions": {
+      "CollectionTypeOptions": {
+        "enum": [
+          "movies",
+          "tvshows",
+          "music",
+          "musicvideos",
+          "homevideos",
+          "boxsets",
+          "books",
+          "mixed"
+        ],
+        "type": "string",
+        "description": "The collection type options."
+      },
+      "ConfigImageTypes": {
         "type": "object",
         "properties": {
-          "ItemType": {
-            "type": "string",
-            "nullable": true
-          },
-          "DisabledMetadataSavers": {
+          "BackdropSizes": {
             "type": "array",
             "items": {
               "type": "string"
             },
             "nullable": true
           },
-          "LocalMetadataReaderOrder": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "DisabledMetadataFetchers": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "MetadataFetcherOrder": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "DisabledImageFetchers": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "ImageFetcherOrder": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class MetadataOptions."
-      },
-      "NameValuePair": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Value": {
-            "type": "string",
-            "description": "Gets or sets the value.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "RepositoryInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Url": {
-            "type": "string",
-            "description": "Gets or sets the URL.",
-            "nullable": true
-          },
-          "Enabled": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the repository is enabled."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class RepositoryInfo."
-      },
-      "PathSubstitution": {
-        "type": "object",
-        "properties": {
-          "From": {
-            "type": "string",
-            "description": "Gets or sets the value to substitute.",
-            "nullable": true
-          },
-          "To": {
-            "type": "string",
-            "description": "Gets or sets the value to substitution with.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the MediaBrowser.Model.Configuration.PathSubstitution."
-      },
-      "ServerConfiguration": {
-        "type": "object",
-        "properties": {
-          "LogFileRetentionDays": {
-            "type": "integer",
-            "description": "Gets or sets the number of days we should retain log files.",
-            "format": "int32"
-          },
-          "IsStartupWizardCompleted": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is first run."
-          },
-          "CachePath": {
-            "type": "string",
-            "description": "Gets or sets the cache path.",
-            "nullable": true
-          },
-          "PreviousVersion": {
-            "$ref": "#/components/schemas/Version"
-          },
-          "PreviousVersionStr": {
-            "type": "string",
-            "description": "Gets or sets the stringified PreviousVersion to be stored/loaded,\r\nbecause System.Version itself isn't xml-serializable.",
-            "nullable": true
-          },
-          "EnableUPnP": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable automatic port forwarding."
-          },
-          "EnableMetrics": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable prometheus metrics exporting."
-          },
-          "PublicPort": {
-            "type": "integer",
-            "description": "Gets or sets the public mapped port.",
-            "format": "int32"
-          },
-          "UPnPCreateHttpPortMap": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the http port should be mapped as part of UPnP automatic port forwarding."
-          },
-          "UDPPortRange": {
-            "type": "string",
-            "description": "Gets or sets client udp port range.",
-            "nullable": true
-          },
-          "EnableIPV6": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether IPV6 capability is enabled."
-          },
-          "EnableIPV4": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether IPV4 capability is enabled."
-          },
-          "EnableSSDPTracing": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether detailed ssdp logs are sent to the console/log.\r\n\"Emby.Dlna\": \"Debug\" must be set in logging.default.json for this property to work."
-          },
-          "SSDPTracingFilter": {
-            "type": "string",
-            "description": "Gets or sets a value indicating whether an IP address is to be used to filter the detailed ssdp logs that are being sent to the console/log.\r\nIf the setting \"Emby.Dlna\": \"Debug\" msut be set in logging.default.json for this property to work.",
-            "nullable": true
-          },
-          "UDPSendCount": {
-            "type": "integer",
-            "description": "Gets or sets the number of times SSDP UDP messages are sent.",
-            "format": "int32"
-          },
-          "UDPSendDelay": {
-            "type": "integer",
-            "description": "Gets or sets the delay between each groups of SSDP messages (in ms).",
-            "format": "int32"
-          },
-          "IgnoreVirtualInterfaces": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether address names that match MediaBrowser.Model.Configuration.ServerConfiguration.VirtualInterfaceNames should be Ignore for the purposes of binding."
-          },
-          "VirtualInterfaceNames": {
-            "type": "string",
-            "description": "Gets or sets a value indicating the interfaces that should be ignored. The list can be comma separated. <seealso cref=\"P:MediaBrowser.Model.Configuration.ServerConfiguration.IgnoreVirtualInterfaces\" />.",
-            "nullable": true
-          },
-          "GatewayMonitorPeriod": {
-            "type": "integer",
-            "description": "Gets or sets the time (in seconds) between the pings of SSDP gateway monitor.",
-            "format": "int32"
-          },
-          "EnableMultiSocketBinding": {
-            "type": "boolean",
-            "description": "Gets a value indicating whether multi-socket binding is available.",
-            "readOnly": true
-          },
-          "TrustAllIP6Interfaces": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether all IPv6 interfaces should be treated as on the internal network.\r\nDepending on the address range implemented ULA ranges might not be used."
-          },
-          "HDHomerunPortRange": {
-            "type": "string",
-            "description": "Gets or sets the ports that HDHomerun uses.",
-            "nullable": true
-          },
-          "PublishedServerUriBySubnet": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets PublishedServerUri to advertise for specific subnets.",
-            "nullable": true
-          },
-          "AutoDiscoveryTracing": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether Autodiscovery tracing is enabled."
-          },
-          "AutoDiscovery": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether Autodiscovery is enabled."
-          },
-          "PublicHttpsPort": {
-            "type": "integer",
-            "description": "Gets or sets the public HTTPS port.",
-            "format": "int32"
-          },
-          "HttpServerPortNumber": {
-            "type": "integer",
-            "description": "Gets or sets the HTTP server port number.",
-            "format": "int32"
-          },
-          "HttpsPortNumber": {
-            "type": "integer",
-            "description": "Gets or sets the HTTPS server port number.",
-            "format": "int32"
-          },
-          "EnableHttps": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to use HTTPS."
-          },
-          "EnableNormalizedItemByNameIds": {
-            "type": "boolean"
-          },
-          "CertificatePath": {
-            "type": "string",
-            "description": "Gets or sets the filesystem path of an X.509 certificate to use for SSL.",
-            "nullable": true
-          },
-          "CertificatePassword": {
-            "type": "string",
-            "description": "Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Model.Configuration.ServerConfiguration.CertificatePath.",
-            "nullable": true
-          },
-          "IsPortAuthorized": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is port authorized."
-          },
-          "QuickConnectAvailable": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether quick connect is available for use on this server."
-          },
-          "EnableRemoteAccess": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether access outside of the LAN is permitted."
-          },
-          "EnableCaseSensitiveItemIds": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [enable case sensitive item ids]."
-          },
-          "DisableLiveTvChannelUserDataName": {
-            "type": "boolean"
-          },
-          "MetadataPath": {
-            "type": "string",
-            "description": "Gets or sets the metadata path.",
-            "nullable": true
-          },
-          "MetadataNetworkPath": {
-            "type": "string",
-            "nullable": true
-          },
-          "PreferredMetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the preferred metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "SortReplaceCharacters": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets characters to be replaced with a ' ' in strings to create a sort name.",
-            "nullable": true
-          },
-          "SortRemoveCharacters": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets characters to be removed from strings to create a sort name.",
-            "nullable": true
-          },
-          "SortRemoveWords": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets words to be removed from strings to create a sort name.",
-            "nullable": true
-          },
-          "MinResumePct": {
-            "type": "integer",
-            "description": "Gets or sets the minimum percentage of an item that must be played in order for playstate to be updated.",
-            "format": "int32"
-          },
-          "MaxResumePct": {
-            "type": "integer",
-            "description": "Gets or sets the maximum percentage of an item that can be played while still saving playstate. If this percentage is crossed playstate will be reset to the beginning and the item will be marked watched.",
-            "format": "int32"
-          },
-          "MinResumeDurationSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the minimum duration that an item must have in order to be eligible for playstate updates..",
-            "format": "int32"
-          },
-          "MinAudiobookResume": {
-            "type": "integer",
-            "description": "Gets or sets the minimum minutes of a book that must be played in order for playstate to be updated.",
-            "format": "int32"
-          },
-          "MaxAudiobookResume": {
-            "type": "integer",
-            "description": "Gets or sets the remaining minutes of a book that can be played while still saving playstate. If this percentage is crossed playstate will be reset to the beginning and the item will be marked watched.",
-            "format": "int32"
-          },
-          "LibraryMonitorDelay": {
-            "type": "integer",
-            "description": "Gets or sets the delay in seconds that we will wait after a file system change to try and discover what has been added/removed\r\nSome delay is necessary with some items because their creation is not atomic.  It involves the creation of several\r\ndifferent directories and files.",
-            "format": "int32"
-          },
-          "EnableDashboardResponseCaching": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [enable dashboard response caching].\r\nAllows potential contributors without visual studio to modify production dashboard code and test changes."
-          },
-          "ImageSavingConvention": {
-            "$ref": "#/components/schemas/ImageSavingConvention"
-          },
-          "MetadataOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/MetadataOptions"
-            },
-            "nullable": true
-          },
-          "SkipDeserializationForBasicTypes": {
-            "type": "boolean"
-          },
-          "ServerName": {
-            "type": "string",
-            "nullable": true
-          },
           "BaseUrl": {
             "type": "string",
             "nullable": true
           },
-          "UICulture": {
+          "LogoSizes": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "PosterSizes": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "ProfileSizes": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "SecureBaseUrl": {
             "type": "string",
             "nullable": true
           },
-          "SaveMetadataHidden": {
-            "type": "boolean"
-          },
-          "ContentTypes": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NameValuePair"
-            },
-            "nullable": true
-          },
-          "RemoteClientBitrateLimit": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "EnableFolderView": {
-            "type": "boolean"
-          },
-          "EnableGroupingIntoCollections": {
-            "type": "boolean"
-          },
-          "DisplaySpecialsWithinSeasons": {
-            "type": "boolean"
-          },
-          "LocalNetworkSubnets": {
+          "StillSizes": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "description": "Gets or sets the subnets that are deemed to make up the LAN.",
-            "nullable": true
-          },
-          "LocalNetworkAddresses": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used.",
-            "nullable": true
-          },
-          "CodecsUsed": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "PluginRepositories": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/RepositoryInfo"
-            },
-            "nullable": true
-          },
-          "EnableExternalContentInSuggestions": {
-            "type": "boolean"
-          },
-          "RequireHttps": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the server should force connections over HTTPS."
-          },
-          "EnableNewOmdbSupport": {
-            "type": "boolean"
-          },
-          "RemoteIPFilter": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the filter for remote IP connectivity. Used in conjuntion with <seealso cref=\"P:MediaBrowser.Model.Configuration.ServerConfiguration.IsRemoteIPFilterBlacklist\" />.",
-            "nullable": true
-          },
-          "IsRemoteIPFilterBlacklist": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether <seealso cref=\"P:MediaBrowser.Model.Configuration.ServerConfiguration.RemoteIPFilter\" /> contains a blacklist or a whitelist. Default is a whitelist."
-          },
-          "ImageExtractionTimeoutMs": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "PathSubstitutions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/PathSubstitution"
-            },
-            "nullable": true
-          },
-          "EnableSimpleArtistDetection": {
-            "type": "boolean"
-          },
-          "UninstalledPlugins": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "EnableSlowResponseWarning": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether slow server responses should be logged as a warning."
-          },
-          "SlowResponseThresholdMs": {
-            "type": "integer",
-            "description": "Gets or sets the threshold for the slow response time warning in ms.",
-            "format": "int64"
-          },
-          "CorsHosts": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the cors hosts.",
-            "nullable": true
-          },
-          "KnownProxies": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the known proxies.",
-            "nullable": true
-          },
-          "ActivityLogRetentionDays": {
-            "type": "integer",
-            "description": "Gets or sets the number of days we should retain activity logs.",
-            "format": "int32",
-            "nullable": true
-          },
-          "LibraryScanFanoutConcurrency": {
-            "type": "integer",
-            "description": "Gets or sets the how the library scan fans out.",
-            "format": "int32"
-          },
-          "LibraryMetadataRefreshConcurrency": {
-            "type": "integer",
-            "description": "Gets or sets the how many metadata refreshes can run concurrently.",
-            "format": "int32"
-          },
-          "RemoveOldPlugins": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether older plugins should automatically be deleted from the plugin folder."
-          },
-          "DisablePluginImages": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether plugin image should be disabled."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Represents the server configuration."
-      },
-      "MediaEncoderPathDto": {
-        "type": "object",
-        "properties": {
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets media encoder path.",
-            "nullable": true
-          },
-          "PathType": {
-            "type": "string",
-            "description": "Gets or sets media encoder path type.",
             "nullable": true
           }
         },
-        "additionalProperties": false,
-        "description": "Media Encoder Path Dto."
-      },
-      "ProblemDetails": {
-        "type": "object",
-        "properties": {
-          "type": {
-            "type": "string",
-            "nullable": true
-          },
-          "title": {
-            "type": "string",
-            "nullable": true
-          },
-          "status": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "detail": {
-            "type": "string",
-            "nullable": true
-          },
-          "instance": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": { }
-      },
-      "ConfigurationPageType": {
-        "enum": [
-          "PluginConfiguration",
-          "None"
-        ],
-        "type": "string",
-        "description": "Enum ConfigurationPageType."
+        "additionalProperties": false
       },
       "ConfigurationPageInfo": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "EnableInMainMenu": {
             "type": "boolean",
@@ -48285,9 +46658,6 @@
             "description": "Gets or sets the display name.",
             "nullable": true
           },
-          "ConfigurationPageType": {
-            "$ref": "#/components/schemas/ConfigurationPageType"
-          },
           "PluginId": {
             "type": "string",
             "description": "Gets or sets the plugin id.",
@@ -48298,6 +46668,1348 @@
         "additionalProperties": false,
         "description": "The configuration page info."
       },
+      "ContainerProfile": {
+        "type": "object",
+        "properties": {
+          "Type": {
+            "enum": [
+              "Audio",
+              "Video",
+              "Photo",
+              "Subtitle",
+              "Lyric"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DlnaProfileType"
+              }
+            ],
+            "description": "Gets or sets the MediaBrowser.Model.Dlna.DlnaProfileType which this container must meet."
+          },
+          "Conditions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ProfileCondition"
+            },
+            "description": "Gets or sets the list of MediaBrowser.Model.Dlna.ProfileCondition which this container will be applied to."
+          },
+          "Container": {
+            "type": "string",
+            "description": "Gets or sets the container(s) which this container must meet.",
+            "nullable": true
+          },
+          "SubContainer": {
+            "type": "string",
+            "description": "Gets or sets the sub container(s) which this container must meet.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Model.Dlna.ContainerProfile."
+      },
+      "CountryInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "DisplayName": {
+            "type": "string",
+            "description": "Gets or sets the display name.",
+            "nullable": true
+          },
+          "TwoLetterISORegionName": {
+            "type": "string",
+            "description": "Gets or sets the name of the two letter ISO region.",
+            "nullable": true
+          },
+          "ThreeLetterISORegionName": {
+            "type": "string",
+            "description": "Gets or sets the name of the three letter ISO region.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class CountryInfo."
+      },
+      "CreatePlaylistDto": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of the new playlist."
+          },
+          "Ids": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets item ids to add to the playlist."
+          },
+          "UserId": {
+            "type": "string",
+            "description": "Gets or sets the user id.",
+            "format": "uuid",
+            "nullable": true
+          },
+          "MediaType": {
+            "enum": [
+              "Unknown",
+              "Video",
+              "Audio",
+              "Photo",
+              "Book"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaType"
+              }
+            ],
+            "description": "Gets or sets the media type.",
+            "nullable": true
+          },
+          "Users": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/PlaylistUserPermissions"
+            },
+            "description": "Gets or sets the playlist users."
+          },
+          "IsPublic": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the playlist is public."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Create new playlist dto."
+      },
+      "CreateUserByName": {
+        "required": [
+          "Name"
+        ],
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the username."
+          },
+          "Password": {
+            "type": "string",
+            "description": "Gets or sets the password.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "The create user by name request body."
+      },
+      "CultureDto": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets the name."
+          },
+          "DisplayName": {
+            "type": "string",
+            "description": "Gets the display name."
+          },
+          "TwoLetterISOLanguageName": {
+            "type": "string",
+            "description": "Gets the name of the two letter ISO language."
+          },
+          "ThreeLetterISOLanguageName": {
+            "type": "string",
+            "description": "Gets the name of the three letter ISO language.",
+            "nullable": true,
+            "readOnly": true
+          },
+          "ThreeLetterISOLanguageNames": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class CultureDto."
+      },
+      "DayOfWeek": {
+        "enum": [
+          "Sunday",
+          "Monday",
+          "Tuesday",
+          "Wednesday",
+          "Thursday",
+          "Friday",
+          "Saturday"
+        ],
+        "type": "string"
+      },
+      "DayPattern": {
+        "enum": [
+          "Daily",
+          "Weekdays",
+          "Weekends"
+        ],
+        "type": "string"
+      },
+      "DefaultDirectoryBrowserInfoDto": {
+        "type": "object",
+        "properties": {
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Default directory browser info."
+      },
+      "DeinterlaceMethod": {
+        "enum": [
+          "yadif",
+          "bwdif"
+        ],
+        "type": "string",
+        "description": "Enum containing deinterlace methods."
+      },
+      "DeviceInfoDto": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "CustomName": {
+            "type": "string",
+            "description": "Gets or sets the custom name.",
+            "nullable": true
+          },
+          "AccessToken": {
+            "type": "string",
+            "description": "Gets or sets the access token.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the identifier.",
+            "nullable": true
+          },
+          "LastUserName": {
+            "type": "string",
+            "description": "Gets or sets the last name of the user.",
+            "nullable": true
+          },
+          "AppName": {
+            "type": "string",
+            "description": "Gets or sets the name of the application.",
+            "nullable": true
+          },
+          "AppVersion": {
+            "type": "string",
+            "description": "Gets or sets the application version.",
+            "nullable": true
+          },
+          "LastUserId": {
+            "type": "string",
+            "description": "Gets or sets the last user identifier.",
+            "format": "uuid",
+            "nullable": true
+          },
+          "DateLastActivity": {
+            "type": "string",
+            "description": "Gets or sets the date last modified.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "Capabilities": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ClientCapabilitiesDto"
+              }
+            ],
+            "description": "Gets or sets the capabilities."
+          },
+          "IconUrl": {
+            "type": "string",
+            "description": "Gets or sets the icon URL.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "A DTO representing device information."
+      },
+      "DeviceInfoDtoQueryResult": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/DeviceInfoDto"
+            },
+            "description": "Gets or sets the items."
+          },
+          "TotalRecordCount": {
+            "type": "integer",
+            "description": "Gets or sets the total number of records available.",
+            "format": "int32"
+          },
+          "StartIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the first record in Items.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Query result container."
+      },
+      "DeviceOptionsDto": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "integer",
+            "description": "Gets or sets the id.",
+            "format": "int32"
+          },
+          "DeviceId": {
+            "type": "string",
+            "description": "Gets or sets the device id.",
+            "nullable": true
+          },
+          "CustomName": {
+            "type": "string",
+            "description": "Gets or sets the custom name.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "A dto representing custom options for a device."
+      },
+      "DeviceProfile": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of this device profile. User profiles must have a unique name.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the unique internal identifier.",
+            "format": "uuid",
+            "nullable": true
+          },
+          "MaxStreamingBitrate": {
+            "type": "integer",
+            "description": "Gets or sets the maximum allowed bitrate for all streamed content.",
+            "format": "int32",
+            "nullable": true
+          },
+          "MaxStaticBitrate": {
+            "type": "integer",
+            "description": "Gets or sets the maximum allowed bitrate for statically streamed content (= direct played files).",
+            "format": "int32",
+            "nullable": true
+          },
+          "MusicStreamingTranscodingBitrate": {
+            "type": "integer",
+            "description": "Gets or sets the maximum allowed bitrate for transcoded music streams.",
+            "format": "int32",
+            "nullable": true
+          },
+          "MaxStaticMusicBitrate": {
+            "type": "integer",
+            "description": "Gets or sets the maximum allowed bitrate for statically streamed (= direct played) music files.",
+            "format": "int32",
+            "nullable": true
+          },
+          "DirectPlayProfiles": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/DirectPlayProfile"
+            },
+            "description": "Gets or sets the direct play profiles."
+          },
+          "TranscodingProfiles": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TranscodingProfile"
+            },
+            "description": "Gets or sets the transcoding profiles."
+          },
+          "ContainerProfiles": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ContainerProfile"
+            },
+            "description": "Gets or sets the container profiles. Failing to meet these optional conditions causes transcoding to occur."
+          },
+          "CodecProfiles": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/CodecProfile"
+            },
+            "description": "Gets or sets the codec profiles."
+          },
+          "SubtitleProfiles": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SubtitleProfile"
+            },
+            "description": "Gets or sets the subtitle profiles."
+          }
+        },
+        "additionalProperties": false,
+        "description": "A MediaBrowser.Model.Dlna.DeviceProfile represents a set of metadata which determines which content a certain device is able to play.\r\n<br />\r\nSpecifically, it defines the supported <see cref=\"P:MediaBrowser.Model.Dlna.DeviceProfile.ContainerProfiles\">containers</see> and\r\n<see cref=\"P:MediaBrowser.Model.Dlna.DeviceProfile.CodecProfiles\">codecs</see> (video and/or audio, including codec profiles and levels)\r\nthe device is able to direct play (without transcoding or remuxing),\r\nas well as which <see cref=\"P:MediaBrowser.Model.Dlna.DeviceProfile.TranscodingProfiles\">containers/codecs to transcode to</see> in case it isn't."
+      },
+      "DirectPlayProfile": {
+        "type": "object",
+        "properties": {
+          "Container": {
+            "type": "string",
+            "description": "Gets or sets the container."
+          },
+          "AudioCodec": {
+            "type": "string",
+            "description": "Gets or sets the audio codec.",
+            "nullable": true
+          },
+          "VideoCodec": {
+            "type": "string",
+            "description": "Gets or sets the video codec.",
+            "nullable": true
+          },
+          "Type": {
+            "enum": [
+              "Audio",
+              "Video",
+              "Photo",
+              "Subtitle",
+              "Lyric"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DlnaProfileType"
+              }
+            ],
+            "description": "Gets or sets the Dlna profile type."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Model.Dlna.DirectPlayProfile."
+      },
+      "DisplayPreferencesDto": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the user id.",
+            "nullable": true
+          },
+          "ViewType": {
+            "type": "string",
+            "description": "Gets or sets the type of the view.",
+            "nullable": true
+          },
+          "SortBy": {
+            "type": "string",
+            "description": "Gets or sets the sort by.",
+            "nullable": true
+          },
+          "IndexBy": {
+            "type": "string",
+            "description": "Gets or sets the index by.",
+            "nullable": true
+          },
+          "RememberIndexing": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [remember indexing]."
+          },
+          "PrimaryImageHeight": {
+            "type": "integer",
+            "description": "Gets or sets the height of the primary image.",
+            "format": "int32"
+          },
+          "PrimaryImageWidth": {
+            "type": "integer",
+            "description": "Gets or sets the width of the primary image.",
+            "format": "int32"
+          },
+          "CustomPrefs": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the custom prefs."
+          },
+          "ScrollDirection": {
+            "enum": [
+              "Horizontal",
+              "Vertical"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ScrollDirection"
+              }
+            ],
+            "description": "An enum representing the axis that should be scrolled."
+          },
+          "ShowBackdrop": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to show backdrops on this item."
+          },
+          "RememberSorting": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [remember sorting]."
+          },
+          "SortOrder": {
+            "enum": [
+              "Ascending",
+              "Descending"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SortOrder"
+              }
+            ],
+            "description": "An enum representing the sorting order."
+          },
+          "ShowSidebar": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [show sidebar]."
+          },
+          "Client": {
+            "type": "string",
+            "description": "Gets or sets the client.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the display preferences for any item that supports them (usually Folders)."
+      },
+      "DlnaProfileType": {
+        "enum": [
+          "Audio",
+          "Video",
+          "Photo",
+          "Subtitle",
+          "Lyric"
+        ],
+        "type": "string"
+      },
+      "DownMixStereoAlgorithms": {
+        "enum": [
+          "None",
+          "Dave750",
+          "NightmodeDialogue",
+          "Rfc7845",
+          "Ac4"
+        ],
+        "type": "string",
+        "description": "An enum representing an algorithm to downmix surround sound to stereo."
+      },
+      "DynamicDayOfWeek": {
+        "enum": [
+          "Sunday",
+          "Monday",
+          "Tuesday",
+          "Wednesday",
+          "Thursday",
+          "Friday",
+          "Saturday",
+          "Everyday",
+          "Weekday",
+          "Weekend"
+        ],
+        "type": "string",
+        "description": "An enum that represents a day of the week, weekdays, weekends, or all days."
+      },
+      "EmbeddedSubtitleOptions": {
+        "enum": [
+          "AllowAll",
+          "AllowText",
+          "AllowImage",
+          "AllowNone"
+        ],
+        "type": "string",
+        "description": "An enum representing the options to disable embedded subs."
+      },
+      "EncoderPreset": {
+        "enum": [
+          "auto",
+          "placebo",
+          "veryslow",
+          "slower",
+          "slow",
+          "medium",
+          "fast",
+          "faster",
+          "veryfast",
+          "superfast",
+          "ultrafast"
+        ],
+        "type": "string",
+        "description": "Enum containing encoder presets."
+      },
+      "EncodingContext": {
+        "enum": [
+          "Streaming",
+          "Static"
+        ],
+        "type": "string"
+      },
+      "EncodingOptions": {
+        "type": "object",
+        "properties": {
+          "EncodingThreadCount": {
+            "type": "integer",
+            "description": "Gets or sets the thread count used for encoding.",
+            "format": "int32"
+          },
+          "TranscodingTempPath": {
+            "type": "string",
+            "description": "Gets or sets the temporary transcoding path.",
+            "nullable": true
+          },
+          "FallbackFontPath": {
+            "type": "string",
+            "description": "Gets or sets the path to the fallback font.",
+            "nullable": true
+          },
+          "EnableFallbackFont": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to use the fallback font."
+          },
+          "EnableAudioVbr": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether audio VBR is enabled."
+          },
+          "DownMixAudioBoost": {
+            "type": "number",
+            "description": "Gets or sets the audio boost applied when downmixing audio.",
+            "format": "double"
+          },
+          "DownMixStereoAlgorithm": {
+            "enum": [
+              "None",
+              "Dave750",
+              "NightmodeDialogue",
+              "Rfc7845",
+              "Ac4"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DownMixStereoAlgorithms"
+              }
+            ],
+            "description": "Gets or sets the algorithm used for downmixing audio to stereo."
+          },
+          "MaxMuxingQueueSize": {
+            "type": "integer",
+            "description": "Gets or sets the maximum size of the muxing queue.",
+            "format": "int32"
+          },
+          "EnableThrottling": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether throttling is enabled."
+          },
+          "ThrottleDelaySeconds": {
+            "type": "integer",
+            "description": "Gets or sets the delay after which throttling happens.",
+            "format": "int32"
+          },
+          "EnableSegmentDeletion": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether segment deletion is enabled."
+          },
+          "SegmentKeepSeconds": {
+            "type": "integer",
+            "description": "Gets or sets seconds for which segments should be kept before being deleted.",
+            "format": "int32"
+          },
+          "HardwareAccelerationType": {
+            "enum": [
+              "none",
+              "amf",
+              "qsv",
+              "nvenc",
+              "v4l2m2m",
+              "vaapi",
+              "videotoolbox",
+              "rkmpp"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/HardwareAccelerationType"
+              }
+            ],
+            "description": "Gets or sets the hardware acceleration type."
+          },
+          "EncoderAppPath": {
+            "type": "string",
+            "description": "Gets or sets the FFmpeg path as set by the user via the UI.",
+            "nullable": true
+          },
+          "EncoderAppPathDisplay": {
+            "type": "string",
+            "description": "Gets or sets the current FFmpeg path being used by the system and displayed on the transcode page.",
+            "nullable": true
+          },
+          "VaapiDevice": {
+            "type": "string",
+            "description": "Gets or sets the VA-API device.",
+            "nullable": true
+          },
+          "QsvDevice": {
+            "type": "string",
+            "description": "Gets or sets the QSV device.",
+            "nullable": true
+          },
+          "EnableTonemapping": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether tonemapping is enabled."
+          },
+          "EnableVppTonemapping": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether VPP tonemapping is enabled."
+          },
+          "EnableVideoToolboxTonemapping": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether videotoolbox tonemapping is enabled."
+          },
+          "TonemappingAlgorithm": {
+            "enum": [
+              "none",
+              "clip",
+              "linear",
+              "gamma",
+              "reinhard",
+              "hable",
+              "mobius",
+              "bt2390"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TonemappingAlgorithm"
+              }
+            ],
+            "description": "Gets or sets the tone-mapping algorithm."
+          },
+          "TonemappingMode": {
+            "enum": [
+              "auto",
+              "max",
+              "rgb",
+              "lum",
+              "itp"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TonemappingMode"
+              }
+            ],
+            "description": "Gets or sets the tone-mapping mode."
+          },
+          "TonemappingRange": {
+            "enum": [
+              "auto",
+              "tv",
+              "pc"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TonemappingRange"
+              }
+            ],
+            "description": "Gets or sets the tone-mapping range."
+          },
+          "TonemappingDesat": {
+            "type": "number",
+            "description": "Gets or sets the tone-mapping desaturation.",
+            "format": "double"
+          },
+          "TonemappingPeak": {
+            "type": "number",
+            "description": "Gets or sets the tone-mapping peak.",
+            "format": "double"
+          },
+          "TonemappingParam": {
+            "type": "number",
+            "description": "Gets or sets the tone-mapping parameters.",
+            "format": "double"
+          },
+          "VppTonemappingBrightness": {
+            "type": "number",
+            "description": "Gets or sets the VPP tone-mapping brightness.",
+            "format": "double"
+          },
+          "VppTonemappingContrast": {
+            "type": "number",
+            "description": "Gets or sets the VPP tone-mapping contrast.",
+            "format": "double"
+          },
+          "H264Crf": {
+            "type": "integer",
+            "description": "Gets or sets the H264 CRF.",
+            "format": "int32"
+          },
+          "H265Crf": {
+            "type": "integer",
+            "description": "Gets or sets the H265 CRF.",
+            "format": "int32"
+          },
+          "EncoderPreset": {
+            "enum": [
+              "auto",
+              "placebo",
+              "veryslow",
+              "slower",
+              "slow",
+              "medium",
+              "fast",
+              "faster",
+              "veryfast",
+              "superfast",
+              "ultrafast"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/EncoderPreset"
+              }
+            ],
+            "description": "Gets or sets the encoder preset.",
+            "nullable": true
+          },
+          "DeinterlaceDoubleRate": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the framerate is doubled when deinterlacing."
+          },
+          "DeinterlaceMethod": {
+            "enum": [
+              "yadif",
+              "bwdif"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DeinterlaceMethod"
+              }
+            ],
+            "description": "Gets or sets the deinterlace method."
+          },
+          "EnableDecodingColorDepth10Hevc": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether 10bit HEVC decoding is enabled."
+          },
+          "EnableDecodingColorDepth10Vp9": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether 10bit VP9 decoding is enabled."
+          },
+          "EnableDecodingColorDepth10HevcRext": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether 8/10bit HEVC RExt decoding is enabled."
+          },
+          "EnableDecodingColorDepth12HevcRext": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether 12bit HEVC RExt decoding is enabled."
+          },
+          "EnableEnhancedNvdecDecoder": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the enhanced NVDEC is enabled."
+          },
+          "PreferSystemNativeHwDecoder": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the system native hardware decoder should be used."
+          },
+          "EnableIntelLowPowerH264HwEncoder": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the Intel H264 low-power hardware encoder should be used."
+          },
+          "EnableIntelLowPowerHevcHwEncoder": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the Intel HEVC low-power hardware encoder should be used."
+          },
+          "EnableHardwareEncoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether hardware encoding is enabled."
+          },
+          "AllowHevcEncoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether HEVC encoding is enabled."
+          },
+          "AllowAv1Encoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether AV1 encoding is enabled."
+          },
+          "EnableSubtitleExtraction": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether subtitle extraction is enabled."
+          },
+          "HardwareDecodingCodecs": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the codecs hardware encoding is used for.",
+            "nullable": true
+          },
+          "AllowOnDemandMetadataBasedKeyframeExtractionForExtensions": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the file extensions on-demand metadata based keyframe extraction is enabled for.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class EncodingOptions."
+      },
+      "EndPointInfo": {
+        "type": "object",
+        "properties": {
+          "IsLocal": {
+            "type": "boolean"
+          },
+          "IsInNetwork": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "ExternalIdInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the display name of the external id provider (IE: IMDB, MusicBrainz, etc)."
+          },
+          "Key": {
+            "type": "string",
+            "description": "Gets or sets the unique key for this id. This key should be unique across all providers."
+          },
+          "Type": {
+            "enum": [
+              "Album",
+              "AlbumArtist",
+              "Artist",
+              "BoxSet",
+              "Episode",
+              "Movie",
+              "OtherArtist",
+              "Person",
+              "ReleaseGroup",
+              "Season",
+              "Series",
+              "Track",
+              "Book"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ExternalIdMediaType"
+              }
+            ],
+            "description": "Gets or sets the specific media type for this id. This is used to distinguish between the different\r\nexternal id types for providers with multiple ids.\r\nA null value indicates there is no specific media type associated with the external id, or this is the\r\ndefault id for the external provider so there is no need to specify a type.",
+            "nullable": true
+          },
+          "UrlFormatString": {
+            "type": "string",
+            "description": "Gets or sets the URL format string.",
+            "nullable": true,
+            "deprecated": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Represents the external id information for serialization to the client."
+      },
+      "ExternalIdMediaType": {
+        "enum": [
+          "Album",
+          "AlbumArtist",
+          "Artist",
+          "BoxSet",
+          "Episode",
+          "Movie",
+          "OtherArtist",
+          "Person",
+          "ReleaseGroup",
+          "Season",
+          "Series",
+          "Track",
+          "Book"
+        ],
+        "type": "string",
+        "description": "The specific media type of an MediaBrowser.Model.Providers.ExternalIdInfo."
+      },
+      "ExternalUrl": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Url": {
+            "type": "string",
+            "description": "Gets or sets the type of the item.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "ExtraType": {
+        "enum": [
+          "Unknown",
+          "Clip",
+          "Trailer",
+          "BehindTheScenes",
+          "DeletedScene",
+          "Interview",
+          "Scene",
+          "Sample",
+          "ThemeSong",
+          "ThemeVideo",
+          "Featurette",
+          "Short"
+        ],
+        "type": "string"
+      },
+      "FileSystemEntryInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets the name."
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets the path."
+          },
+          "Type": {
+            "enum": [
+              "File",
+              "Directory",
+              "NetworkComputer",
+              "NetworkShare"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/FileSystemEntryType"
+              }
+            ],
+            "description": "Gets the type."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class FileSystemEntryInfo."
+      },
+      "FileSystemEntryType": {
+        "enum": [
+          "File",
+          "Directory",
+          "NetworkComputer",
+          "NetworkShare"
+        ],
+        "type": "string",
+        "description": "Enum FileSystemEntryType."
+      },
+      "FontFile": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Size": {
+            "type": "integer",
+            "description": "Gets or sets the size.",
+            "format": "int64"
+          },
+          "DateCreated": {
+            "type": "string",
+            "description": "Gets or sets the date created.",
+            "format": "date-time"
+          },
+          "DateModified": {
+            "type": "string",
+            "description": "Gets or sets the date modified.",
+            "format": "date-time"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class FontFile."
+      },
+      "ForceKeepAliveMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "integer",
+            "description": "Gets or sets the data.",
+            "format": "int32"
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ForceKeepAlive",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Force keep alive websocket messages."
+      },
+      "ForgotPasswordAction": {
+        "enum": [
+          "ContactAdmin",
+          "PinCode",
+          "InNetworkRequired"
+        ],
+        "type": "string"
+      },
+      "ForgotPasswordDto": {
+        "required": [
+          "EnteredUsername"
+        ],
+        "type": "object",
+        "properties": {
+          "EnteredUsername": {
+            "type": "string",
+            "description": "Gets or sets the entered username to have its password reset."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Forgot Password request body DTO."
+      },
+      "ForgotPasswordPinDto": {
+        "required": [
+          "Pin"
+        ],
+        "type": "object",
+        "properties": {
+          "Pin": {
+            "type": "string",
+            "description": "Gets or sets the entered pin to have the password reset."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Forgot Password Pin enter request body DTO."
+      },
+      "ForgotPasswordResult": {
+        "type": "object",
+        "properties": {
+          "Action": {
+            "enum": [
+              "ContactAdmin",
+              "PinCode",
+              "InNetworkRequired"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ForgotPasswordAction"
+              }
+            ],
+            "description": "Gets or sets the action."
+          },
+          "PinFile": {
+            "type": "string",
+            "description": "Gets or sets the pin file.",
+            "nullable": true
+          },
+          "PinExpirationDate": {
+            "type": "string",
+            "description": "Gets or sets the pin expiration date.",
+            "format": "date-time",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "GeneralCommand": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "enum": [
+              "MoveUp",
+              "MoveDown",
+              "MoveLeft",
+              "MoveRight",
+              "PageUp",
+              "PageDown",
+              "PreviousLetter",
+              "NextLetter",
+              "ToggleOsd",
+              "ToggleContextMenu",
+              "Select",
+              "Back",
+              "TakeScreenshot",
+              "SendKey",
+              "SendString",
+              "GoHome",
+              "GoToSettings",
+              "VolumeUp",
+              "VolumeDown",
+              "Mute",
+              "Unmute",
+              "ToggleMute",
+              "SetVolume",
+              "SetAudioStreamIndex",
+              "SetSubtitleStreamIndex",
+              "ToggleFullscreen",
+              "DisplayContent",
+              "GoToSearch",
+              "DisplayMessage",
+              "SetRepeatMode",
+              "ChannelUp",
+              "ChannelDown",
+              "Guide",
+              "ToggleStats",
+              "PlayMediaSource",
+              "PlayTrailers",
+              "SetShuffleQueue",
+              "PlayState",
+              "PlayNext",
+              "ToggleOsdMenu",
+              "Play",
+              "SetMaxStreamingBitrate",
+              "SetPlaybackOrder"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GeneralCommandType"
+              }
+            ],
+            "description": "This exists simply to identify a set of known commands."
+          },
+          "ControllingUserId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "Arguments": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            }
+          }
+        },
+        "additionalProperties": false
+      },
+      "GeneralCommandMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GeneralCommand"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "GeneralCommand",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "General command websocket message."
+      },
       "GeneralCommandType": {
         "enum": [
           "MoveUp",
@@ -48340,980 +48052,515 @@
           "PlayState",
           "PlayNext",
           "ToggleOsdMenu",
-          "Play"
+          "Play",
+          "SetMaxStreamingBitrate",
+          "SetPlaybackOrder"
         ],
         "type": "string",
         "description": "This exists simply to identify a set of known commands."
       },
-      "HeaderMatchType": {
-        "enum": [
-          "Equals",
-          "Regex",
-          "Substring"
-        ],
-        "type": "string"
-      },
-      "HttpHeaderInfo": {
+      "GetProgramsDto": {
         "type": "object",
         "properties": {
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "Value": {
-            "type": "string",
-            "nullable": true
-          },
-          "Match": {
-            "$ref": "#/components/schemas/HeaderMatchType"
-          }
-        },
-        "additionalProperties": false
-      },
-      "DeviceIdentification": {
-        "type": "object",
-        "properties": {
-          "FriendlyName": {
-            "type": "string",
-            "description": "Gets or sets the name of the friendly.",
-            "nullable": true
-          },
-          "ModelNumber": {
-            "type": "string",
-            "description": "Gets or sets the model number.",
-            "nullable": true
-          },
-          "SerialNumber": {
-            "type": "string",
-            "description": "Gets or sets the serial number.",
-            "nullable": true
-          },
-          "ModelName": {
-            "type": "string",
-            "description": "Gets or sets the name of the model.",
-            "nullable": true
-          },
-          "ModelDescription": {
-            "type": "string",
-            "description": "Gets or sets the model description.",
-            "nullable": true
-          },
-          "ModelUrl": {
-            "type": "string",
-            "description": "Gets or sets the model URL.",
-            "nullable": true
-          },
-          "Manufacturer": {
-            "type": "string",
-            "description": "Gets or sets the manufacturer.",
-            "nullable": true
-          },
-          "ManufacturerUrl": {
-            "type": "string",
-            "description": "Gets or sets the manufacturer URL.",
-            "nullable": true
-          },
-          "Headers": {
+          "ChannelIds": {
             "type": "array",
             "items": {
-              "$ref": "#/components/schemas/HttpHeaderInfo"
+              "type": "string",
+              "format": "uuid"
             },
-            "description": "Gets or sets the headers.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "XmlAttribute": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name of the attribute.",
-            "nullable": true
-          },
-          "Value": {
-            "type": "string",
-            "description": "Gets or sets the value of the attribute.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the MediaBrowser.Model.Dlna.XmlAttribute."
-      },
-      "DlnaProfileType": {
-        "enum": [
-          "Audio",
-          "Video",
-          "Photo"
-        ],
-        "type": "string"
-      },
-      "DirectPlayProfile": {
-        "type": "object",
-        "properties": {
-          "Container": {
-            "type": "string",
-            "nullable": true
-          },
-          "AudioCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "VideoCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/DlnaProfileType"
-          }
-        },
-        "additionalProperties": false
-      },
-      "TranscodeSeekInfo": {
-        "enum": [
-          "Auto",
-          "Bytes"
-        ],
-        "type": "string"
-      },
-      "TranscodingProfile": {
-        "type": "object",
-        "properties": {
-          "Container": {
-            "type": "string",
-            "nullable": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/DlnaProfileType"
-          },
-          "VideoCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "AudioCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "Protocol": {
-            "type": "string",
-            "nullable": true
-          },
-          "EstimateContentLength": {
-            "type": "boolean"
-          },
-          "EnableMpegtsM2TsMode": {
-            "type": "boolean"
-          },
-          "TranscodeSeekInfo": {
-            "$ref": "#/components/schemas/TranscodeSeekInfo"
-          },
-          "CopyTimestamps": {
-            "type": "boolean"
-          },
-          "Context": {
-            "$ref": "#/components/schemas/EncodingContext"
-          },
-          "EnableSubtitlesInManifest": {
-            "type": "boolean"
-          },
-          "MaxAudioChannels": {
-            "type": "string",
-            "nullable": true
-          },
-          "MinSegments": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "SegmentLength": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "BreakOnNonKeyFrames": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "ProfileConditionType": {
-        "enum": [
-          "Equals",
-          "NotEquals",
-          "LessThanEqual",
-          "GreaterThanEqual",
-          "EqualsAny"
-        ],
-        "type": "string"
-      },
-      "ProfileConditionValue": {
-        "enum": [
-          "AudioChannels",
-          "AudioBitrate",
-          "AudioProfile",
-          "Width",
-          "Height",
-          "Has64BitOffsets",
-          "PacketLength",
-          "VideoBitDepth",
-          "VideoBitrate",
-          "VideoFramerate",
-          "VideoLevel",
-          "VideoProfile",
-          "VideoTimestamp",
-          "IsAnamorphic",
-          "RefFrames",
-          "NumAudioStreams",
-          "NumVideoStreams",
-          "IsSecondaryAudio",
-          "VideoCodecTag",
-          "IsAvc",
-          "IsInterlaced",
-          "AudioSampleRate",
-          "AudioBitDepth"
-        ],
-        "type": "string"
-      },
-      "ProfileCondition": {
-        "type": "object",
-        "properties": {
-          "Condition": {
-            "$ref": "#/components/schemas/ProfileConditionType"
-          },
-          "Property": {
-            "$ref": "#/components/schemas/ProfileConditionValue"
-          },
-          "Value": {
-            "type": "string",
-            "nullable": true
-          },
-          "IsRequired": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "ContainerProfile": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "$ref": "#/components/schemas/DlnaProfileType"
-          },
-          "Conditions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ProfileCondition"
-            },
-            "nullable": true
-          },
-          "Container": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "CodecType": {
-        "enum": [
-          "Video",
-          "VideoAudio",
-          "Audio"
-        ],
-        "type": "string"
-      },
-      "CodecProfile": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "$ref": "#/components/schemas/CodecType"
-          },
-          "Conditions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ProfileCondition"
-            },
-            "nullable": true
-          },
-          "ApplyConditions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ProfileCondition"
-            },
-            "nullable": true
-          },
-          "Codec": {
-            "type": "string",
-            "nullable": true
-          },
-          "Container": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ResponseProfile": {
-        "type": "object",
-        "properties": {
-          "Container": {
-            "type": "string",
-            "nullable": true
-          },
-          "AudioCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "VideoCodec": {
-            "type": "string",
-            "nullable": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/DlnaProfileType"
-          },
-          "OrgPn": {
-            "type": "string",
-            "nullable": true
-          },
-          "MimeType": {
-            "type": "string",
-            "nullable": true
-          },
-          "Conditions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ProfileCondition"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "SubtitleProfile": {
-        "type": "object",
-        "properties": {
-          "Format": {
-            "type": "string",
-            "nullable": true
-          },
-          "Method": {
-            "$ref": "#/components/schemas/SubtitleDeliveryMethod"
-          },
-          "DidlMode": {
-            "type": "string",
-            "nullable": true
-          },
-          "Language": {
-            "type": "string",
-            "nullable": true
-          },
-          "Container": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "DeviceProfile": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the Name.",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the Id.",
-            "nullable": true
-          },
-          "Identification": {
-            "$ref": "#/components/schemas/DeviceIdentification"
-          },
-          "FriendlyName": {
-            "type": "string",
-            "description": "Gets or sets the FriendlyName.",
-            "nullable": true
-          },
-          "Manufacturer": {
-            "type": "string",
-            "description": "Gets or sets the Manufacturer.",
-            "nullable": true
-          },
-          "ManufacturerUrl": {
-            "type": "string",
-            "description": "Gets or sets the ManufacturerUrl.",
-            "nullable": true
-          },
-          "ModelName": {
-            "type": "string",
-            "description": "Gets or sets the ModelName.",
-            "nullable": true
-          },
-          "ModelDescription": {
-            "type": "string",
-            "description": "Gets or sets the ModelDescription.",
-            "nullable": true
-          },
-          "ModelNumber": {
-            "type": "string",
-            "description": "Gets or sets the ModelNumber.",
-            "nullable": true
-          },
-          "ModelUrl": {
-            "type": "string",
-            "description": "Gets or sets the ModelUrl.",
-            "nullable": true
-          },
-          "SerialNumber": {
-            "type": "string",
-            "description": "Gets or sets the SerialNumber.",
-            "nullable": true
-          },
-          "EnableAlbumArtInDidl": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether EnableAlbumArtInDidl."
-          },
-          "EnableSingleAlbumArtLimit": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether EnableSingleAlbumArtLimit."
-          },
-          "EnableSingleSubtitleLimit": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether EnableSingleSubtitleLimit."
-          },
-          "SupportedMediaTypes": {
-            "type": "string",
-            "description": "Gets or sets the SupportedMediaTypes.",
+            "description": "Gets or sets the channels to return guide information for.",
             "nullable": true
           },
           "UserId": {
             "type": "string",
-            "description": "Gets or sets the UserId.",
+            "description": "Gets or sets optional. Filter by user id.",
+            "format": "uuid",
             "nullable": true
           },
-          "AlbumArtPn": {
+          "MinStartDate": {
             "type": "string",
-            "description": "Gets or sets the AlbumArtPn.",
+            "description": "Gets or sets the minimum premiere start date.",
+            "format": "date-time",
             "nullable": true
           },
-          "MaxAlbumArtWidth": {
-            "type": "integer",
-            "description": "Gets or sets the MaxAlbumArtWidth.",
-            "format": "int32"
-          },
-          "MaxAlbumArtHeight": {
-            "type": "integer",
-            "description": "Gets or sets the MaxAlbumArtHeight.",
-            "format": "int32"
-          },
-          "MaxIconWidth": {
-            "type": "integer",
-            "description": "Gets or sets the MaxIconWidth.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MaxIconHeight": {
-            "type": "integer",
-            "description": "Gets or sets the MaxIconHeight.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MaxStreamingBitrate": {
-            "type": "integer",
-            "description": "Gets or sets the MaxStreamingBitrate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MaxStaticBitrate": {
-            "type": "integer",
-            "description": "Gets or sets the MaxStaticBitrate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MusicStreamingTranscodingBitrate": {
-            "type": "integer",
-            "description": "Gets or sets the MusicStreamingTranscodingBitrate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MaxStaticMusicBitrate": {
-            "type": "integer",
-            "description": "Gets or sets the MaxStaticMusicBitrate.",
-            "format": "int32",
-            "nullable": true
-          },
-          "SonyAggregationFlags": {
-            "type": "string",
-            "description": "Gets or sets the content of the aggregationFlags element in the urn:schemas-sonycom:av namespace.",
-            "nullable": true
-          },
-          "ProtocolInfo": {
-            "type": "string",
-            "description": "Gets or sets the ProtocolInfo.",
-            "nullable": true
-          },
-          "TimelineOffsetSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the TimelineOffsetSeconds.",
-            "format": "int32"
-          },
-          "RequiresPlainVideoItems": {
+          "HasAired": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether RequiresPlainVideoItems."
+            "description": "Gets or sets filter by programs that have completed airing, or not.",
+            "nullable": true
           },
-          "RequiresPlainFolders": {
+          "IsAiring": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether RequiresPlainFolders."
+            "description": "Gets or sets filter by programs that are currently airing, or not.",
+            "nullable": true
           },
-          "EnableMSMediaReceiverRegistrar": {
+          "MaxStartDate": {
+            "type": "string",
+            "description": "Gets or sets the maximum premiere start date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "MinEndDate": {
+            "type": "string",
+            "description": "Gets or sets the minimum premiere end date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "MaxEndDate": {
+            "type": "string",
+            "description": "Gets or sets the maximum premiere end date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsMovie": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether EnableMSMediaReceiverRegistrar."
+            "description": "Gets or sets filter for movies.",
+            "nullable": true
           },
-          "IgnoreTranscodeByteRangeRequests": {
+          "IsSeries": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether IgnoreTranscodeByteRangeRequests."
-          },
-          "XmlRootAttributes": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/XmlAttribute"
-            },
-            "description": "Gets or sets the XmlRootAttributes.",
+            "description": "Gets or sets filter for series.",
             "nullable": true
           },
-          "DirectPlayProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/DirectPlayProfile"
-            },
-            "description": "Gets or sets the direct play profiles.",
+          "IsNews": {
+            "type": "boolean",
+            "description": "Gets or sets filter for news.",
             "nullable": true
           },
-          "TranscodingProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/TranscodingProfile"
-            },
-            "description": "Gets or sets the transcoding profiles.",
+          "IsKids": {
+            "type": "boolean",
+            "description": "Gets or sets filter for kids.",
             "nullable": true
           },
-          "ContainerProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ContainerProfile"
-            },
-            "description": "Gets or sets the ContainerProfiles.",
+          "IsSports": {
+            "type": "boolean",
+            "description": "Gets or sets filter for sports.",
             "nullable": true
           },
-          "CodecProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/CodecProfile"
-            },
-            "description": "Gets or sets the CodecProfiles.",
-            "nullable": true
-          },
-          "ResponseProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ResponseProfile"
-            },
-            "description": "Gets or sets the ResponseProfiles.",
-            "nullable": true
-          },
-          "SubtitleProfiles": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/SubtitleProfile"
-            },
-            "description": "Gets or sets the SubtitleProfiles.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the MediaBrowser.Model.Dlna.DeviceProfile."
-      },
-      "ClientCapabilities": {
-        "type": "object",
-        "properties": {
-          "PlayableMediaTypes": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "SupportedCommands": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/GeneralCommandType"
-            },
-            "nullable": true
-          },
-          "SupportsMediaControl": {
-            "type": "boolean"
-          },
-          "SupportsContentUploading": {
-            "type": "boolean"
-          },
-          "MessageCallbackUrl": {
-            "type": "string",
-            "nullable": true
-          },
-          "SupportsPersistentIdentifier": {
-            "type": "boolean"
-          },
-          "SupportsSync": {
-            "type": "boolean"
-          },
-          "DeviceProfile": {
-            "$ref": "#/components/schemas/DeviceProfile"
-          },
-          "AppStoreUrl": {
-            "type": "string",
-            "nullable": true
-          },
-          "IconUrl": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "DeviceInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the identifier.",
-            "nullable": true
-          },
-          "LastUserName": {
-            "type": "string",
-            "description": "Gets or sets the last name of the user.",
-            "nullable": true
-          },
-          "AppName": {
-            "type": "string",
-            "description": "Gets or sets the name of the application.",
-            "nullable": true
-          },
-          "AppVersion": {
-            "type": "string",
-            "description": "Gets or sets the application version.",
-            "nullable": true
-          },
-          "LastUserId": {
-            "type": "string",
-            "description": "Gets or sets the last user identifier.",
-            "format": "uuid"
-          },
-          "DateLastActivity": {
-            "type": "string",
-            "description": "Gets or sets the date last modified.",
-            "format": "date-time"
-          },
-          "Capabilities": {
-            "$ref": "#/components/schemas/ClientCapabilities"
-          },
-          "IconUrl": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "DeviceInfoQueryResult": {
-        "type": "object",
-        "properties": {
-          "Items": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/DeviceInfo"
-            },
-            "description": "Gets or sets the items.",
-            "nullable": true
-          },
-          "TotalRecordCount": {
-            "type": "integer",
-            "description": "The total number of records available.",
-            "format": "int32"
-          },
           "StartIndex": {
             "type": "integer",
-            "description": "The index of the first record in Items.",
-            "format": "int32"
-          }
-        },
-        "additionalProperties": false
-      },
-      "DeviceOptions": {
-        "type": "object",
-        "properties": {
-          "CustomName": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ScrollDirection": {
-        "enum": [
-          "Horizontal",
-          "Vertical"
-        ],
-        "type": "string",
-        "description": "An enum representing the axis that should be scrolled."
-      },
-      "SortOrder": {
-        "enum": [
-          "Ascending",
-          "Descending"
-        ],
-        "type": "string",
-        "description": "An enum representing the sorting order."
-      },
-      "DisplayPreferencesDto": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the user id.",
+            "description": "Gets or sets the record index to start at. All items with a lower index will be dropped from the results.",
+            "format": "int32",
             "nullable": true
           },
-          "ViewType": {
-            "type": "string",
-            "description": "Gets or sets the type of the view.",
+          "Limit": {
+            "type": "integer",
+            "description": "Gets or sets the maximum number of records to return.",
+            "format": "int32",
             "nullable": true
           },
           "SortBy": {
-            "type": "string",
-            "description": "Gets or sets the sort by.",
-            "nullable": true
-          },
-          "IndexBy": {
-            "type": "string",
-            "description": "Gets or sets the index by.",
-            "nullable": true
-          },
-          "RememberIndexing": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [remember indexing]."
-          },
-          "PrimaryImageHeight": {
-            "type": "integer",
-            "description": "Gets or sets the height of the primary image.",
-            "format": "int32"
-          },
-          "PrimaryImageWidth": {
-            "type": "integer",
-            "description": "Gets or sets the width of the primary image.",
-            "format": "int32"
-          },
-          "CustomPrefs": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ItemSortBy"
             },
-            "description": "Gets or sets the custom prefs.",
+            "description": "Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.",
             "nullable": true
           },
-          "ScrollDirection": {
-            "$ref": "#/components/schemas/ScrollDirection"
-          },
-          "ShowBackdrop": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to show backdrops on this item."
-          },
-          "RememberSorting": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [remember sorting]."
-          },
           "SortOrder": {
-            "$ref": "#/components/schemas/SortOrder"
-          },
-          "ShowSidebar": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [show sidebar]."
-          },
-          "Client": {
-            "type": "string",
-            "description": "Gets or sets the client.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the display preferences for any item that supports them (usually Folders)."
-      },
-      "DeviceProfileType": {
-        "enum": [
-          "System",
-          "User"
-        ],
-        "type": "string"
-      },
-      "DeviceProfileInfo": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the identifier.",
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SortOrder"
+            },
+            "description": "Gets or sets sort order.",
             "nullable": true
           },
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/DeviceProfileType"
-          }
-        },
-        "additionalProperties": false
-      },
-      "ControlResponse": {
-        "type": "object",
-        "properties": {
-          "Headers": {
-            "type": "object",
-            "additionalProperties": {
+          "Genres": {
+            "type": "array",
+            "items": {
               "type": "string"
             },
-            "nullable": true,
-            "readOnly": true
-          },
-          "Xml": {
-            "type": "string",
+            "description": "Gets or sets the genres to return guide information for.",
             "nullable": true
           },
-          "IsSuccessful": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "DefaultDirectoryBrowserInfoDto": {
-        "type": "object",
-        "properties": {
-          "Path": {
+          "GenreIds": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the genre ids to return guide information for.",
+            "nullable": true
+          },
+          "EnableImages": {
+            "type": "boolean",
+            "description": "Gets or sets include image information in output.",
+            "nullable": true
+          },
+          "EnableTotalRecordCount": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether retrieve total record count.",
+            "default": true
+          },
+          "ImageTypeLimit": {
+            "type": "integer",
+            "description": "Gets or sets the max number of images to return, per image type.",
+            "format": "int32",
+            "nullable": true
+          },
+          "EnableImageTypes": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ImageType"
+            },
+            "description": "Gets or sets the image types to include in the output.",
+            "nullable": true
+          },
+          "EnableUserData": {
+            "type": "boolean",
+            "description": "Gets or sets include user data.",
+            "nullable": true
+          },
+          "SeriesTimerId": {
             "type": "string",
-            "description": "Gets or sets the path.",
+            "description": "Gets or sets filter by series timer id.",
+            "nullable": true
+          },
+          "LibrarySeriesId": {
+            "type": "string",
+            "description": "Gets or sets filter by library series id.",
+            "format": "uuid",
+            "nullable": true
+          },
+          "Fields": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ItemFields"
+            },
+            "description": "Gets or sets specify additional fields of information to return in the output.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Default directory browser info."
+        "description": "Get programs dto."
       },
-      "FileSystemEntryType": {
+      "GroupInfoDto": {
+        "type": "object",
+        "properties": {
+          "GroupId": {
+            "type": "string",
+            "description": "Gets the group identifier.",
+            "format": "uuid"
+          },
+          "GroupName": {
+            "type": "string",
+            "description": "Gets the group name."
+          },
+          "State": {
+            "enum": [
+              "Idle",
+              "Waiting",
+              "Paused",
+              "Playing"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupStateType"
+              }
+            ],
+            "description": "Gets the group state."
+          },
+          "Participants": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets the participants."
+          },
+          "LastUpdatedAt": {
+            "type": "string",
+            "description": "Gets the date when this DTO has been created.",
+            "format": "date-time"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class GroupInfoDto."
+      },
+      "GroupInfoDtoGroupUpdate": {
+        "type": "object",
+        "properties": {
+          "GroupId": {
+            "type": "string",
+            "description": "Gets the group identifier.",
+            "format": "uuid",
+            "readOnly": true
+          },
+          "Type": {
+            "enum": [
+              "UserJoined",
+              "UserLeft",
+              "GroupJoined",
+              "GroupLeft",
+              "StateUpdate",
+              "PlayQueue",
+              "NotInGroup",
+              "GroupDoesNotExist",
+              "CreateGroupDenied",
+              "JoinGroupDenied",
+              "LibraryAccessDenied"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdateType"
+              }
+            ],
+            "description": "Gets the update type."
+          },
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupInfoDto"
+              }
+            ],
+            "description": "Gets the update data."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class GroupUpdate."
+      },
+      "GroupQueueMode": {
         "enum": [
-          "File",
-          "Directory",
-          "NetworkComputer",
-          "NetworkShare"
+          "Queue",
+          "QueueNext"
         ],
         "type": "string",
-        "description": "Enum FileSystemEntryType."
+        "description": "Enum GroupQueueMode."
       },
-      "FileSystemEntryInfo": {
+      "GroupRepeatMode": {
+        "enum": [
+          "RepeatOne",
+          "RepeatAll",
+          "RepeatNone"
+        ],
+        "type": "string",
+        "description": "Enum GroupRepeatMode."
+      },
+      "GroupShuffleMode": {
+        "enum": [
+          "Sorted",
+          "Shuffle"
+        ],
+        "type": "string",
+        "description": "Enum GroupShuffleMode."
+      },
+      "GroupStateType": {
+        "enum": [
+          "Idle",
+          "Waiting",
+          "Paused",
+          "Playing"
+        ],
+        "type": "string",
+        "description": "Enum GroupState."
+      },
+      "GroupStateUpdate": {
         "type": "object",
         "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets the name.",
-            "nullable": true,
-            "readOnly": true
+          "State": {
+            "enum": [
+              "Idle",
+              "Waiting",
+              "Paused",
+              "Playing"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupStateType"
+              }
+            ],
+            "description": "Gets the state of the group."
           },
-          "Path": {
+          "Reason": {
+            "enum": [
+              "Play",
+              "SetPlaylistItem",
+              "RemoveFromPlaylist",
+              "MovePlaylistItem",
+              "Queue",
+              "Unpause",
+              "Pause",
+              "Stop",
+              "Seek",
+              "Buffer",
+              "Ready",
+              "NextItem",
+              "PreviousItem",
+              "SetRepeatMode",
+              "SetShuffleMode",
+              "Ping",
+              "IgnoreWait"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaybackRequestType"
+              }
+            ],
+            "description": "Gets the reason of the state change."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class GroupStateUpdate."
+      },
+      "GroupStateUpdateGroupUpdate": {
+        "type": "object",
+        "properties": {
+          "GroupId": {
             "type": "string",
-            "description": "Gets the path.",
-            "nullable": true,
+            "description": "Gets the group identifier.",
+            "format": "uuid",
             "readOnly": true
           },
           "Type": {
-            "$ref": "#/components/schemas/FileSystemEntryType"
+            "enum": [
+              "UserJoined",
+              "UserLeft",
+              "GroupJoined",
+              "GroupLeft",
+              "StateUpdate",
+              "PlayQueue",
+              "NotInGroup",
+              "GroupDoesNotExist",
+              "CreateGroupDenied",
+              "JoinGroupDenied",
+              "LibraryAccessDenied"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdateType"
+              }
+            ],
+            "description": "Gets the update type."
+          },
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupStateUpdate"
+              }
+            ],
+            "description": "Gets the update data."
           }
         },
         "additionalProperties": false,
-        "description": "Class FileSystemEntryInfo."
+        "description": "Class GroupUpdate."
       },
-      "ValidatePathDto": {
+      "GroupUpdate": {
         "type": "object",
-        "properties": {
-          "ValidateWritable": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether validate if path is writable."
+        "oneOf": [
+          {
+            "$ref": "#/components/schemas/GroupInfoDtoGroupUpdate"
           },
-          "Path": {
+          {
+            "$ref": "#/components/schemas/GroupStateUpdateGroupUpdate"
+          },
+          {
+            "$ref": "#/components/schemas/StringGroupUpdate"
+          },
+          {
+            "$ref": "#/components/schemas/PlayQueueUpdateGroupUpdate"
+          }
+        ],
+        "properties": {
+          "GroupId": {
             "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
+            "description": "Gets the group identifier.",
+            "format": "uuid",
+            "readOnly": true
           },
-          "IsFile": {
-            "type": "boolean",
-            "description": "Gets or sets is path file.",
-            "nullable": true
+          "Type": {
+            "enum": [
+              "UserJoined",
+              "UserLeft",
+              "GroupJoined",
+              "GroupLeft",
+              "StateUpdate",
+              "PlayQueue",
+              "NotInGroup",
+              "GroupDoesNotExist",
+              "CreateGroupDenied",
+              "JoinGroupDenied",
+              "LibraryAccessDenied"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdateType"
+              }
+            ],
+            "description": "Gets the update type."
           }
         },
         "additionalProperties": false,
-        "description": "Validate path object."
+        "description": "Group update without data.",
+        "discriminator": {
+          "propertyName": "Type",
+          "mapping": {
+            "UserJoined": "#/components/schemas/StringGroupUpdate",
+            "UserLeft": "#/components/schemas/StringGroupUpdate",
+            "GroupJoined": "#/components/schemas/GroupInfoDtoGroupUpdate",
+            "GroupLeft": "#/components/schemas/StringGroupUpdate",
+            "StateUpdate": "#/components/schemas/GroupStateUpdateGroupUpdate",
+            "PlayQueue": "#/components/schemas/PlayQueueUpdateGroupUpdate",
+            "NotInGroup": "#/components/schemas/StringGroupUpdate",
+            "GroupDoesNotExist": "#/components/schemas/StringGroupUpdate",
+            "LibraryAccessDenied": "#/components/schemas/StringGroupUpdate"
+          }
+        }
       },
-      "QueryFiltersLegacy": {
+      "GroupUpdateType": {
+        "enum": [
+          "UserJoined",
+          "UserLeft",
+          "GroupJoined",
+          "GroupLeft",
+          "StateUpdate",
+          "PlayQueue",
+          "NotInGroup",
+          "GroupDoesNotExist",
+          "CreateGroupDenied",
+          "JoinGroupDenied",
+          "LibraryAccessDenied"
+        ],
+        "type": "string",
+        "description": "Enum GroupUpdateType."
+      },
+      "GuideInfo": {
         "type": "object",
         "properties": {
-          "Genres": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
+          "StartDate": {
+            "type": "string",
+            "description": "Gets or sets the start date.",
+            "format": "date-time"
           },
-          "Tags": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "OfficialRatings": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "Years": {
-            "type": "array",
-            "items": {
-              "type": "integer",
-              "format": "int32"
-            },
-            "nullable": true
+          "EndDate": {
+            "type": "string",
+            "description": "Gets or sets the end date.",
+            "format": "date-time"
           }
         },
         "additionalProperties": false
       },
-      "QueryFilters": {
+      "HardwareAccelerationType": {
+        "enum": [
+          "none",
+          "amf",
+          "qsv",
+          "nvenc",
+          "v4l2m2m",
+          "vaapi",
+          "videotoolbox",
+          "rkmpp"
+        ],
+        "type": "string",
+        "description": "Enum containing hardware acceleration types."
+      },
+      "IgnoreWaitRequestDto": {
         "type": "object",
         "properties": {
-          "Genres": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NameGuidPair"
-            },
-            "nullable": true
-          },
-          "Tags": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
+          "IgnoreWait": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the client should be ignored."
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Class IgnoreWaitRequestDto."
       },
       "ImageFormat": {
         "enum": [
@@ -49321,7 +48568,8 @@
           "Gif",
           "Jpg",
           "Png",
-          "Webp"
+          "Webp",
+          "Svg"
         ],
         "type": "string",
         "description": "Enum ImageOutputFormat."
@@ -49330,7 +48578,27 @@
         "type": "object",
         "properties": {
           "ImageType": {
-            "$ref": "#/components/schemas/ImageType"
+            "enum": [
+              "Primary",
+              "Art",
+              "Backdrop",
+              "Banner",
+              "Logo",
+              "Thumb",
+              "Disc",
+              "Box",
+              "Screenshot",
+              "Menu",
+              "Chapter",
+              "BoxRear",
+              "Profile"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageType"
+              }
+            ],
+            "description": "Gets or sets the type of the image."
           },
           "ImageIndex": {
             "type": "integer",
@@ -49374,1169 +48642,310 @@
         "additionalProperties": false,
         "description": "Class ImageInfo."
       },
-      "ImageByNameInfo": {
+      "ImageOption": {
         "type": "object",
         "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Theme": {
-            "type": "string",
-            "description": "Gets or sets the theme.",
-            "nullable": true
-          },
-          "Context": {
-            "type": "string",
-            "description": "Gets or sets the context.",
-            "nullable": true
-          },
-          "FileLength": {
-            "type": "integer",
-            "description": "Gets or sets the length of the file.",
-            "format": "int64"
-          },
-          "Format": {
-            "type": "string",
-            "description": "Gets or sets the format.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ExternalIdMediaType": {
-        "enum": [
-          "Album",
-          "AlbumArtist",
-          "Artist",
-          "BoxSet",
-          "Episode",
-          "Movie",
-          "OtherArtist",
-          "Person",
-          "ReleaseGroup",
-          "Season",
-          "Series",
-          "Track"
-        ],
-        "type": "string",
-        "description": "The specific media type of an MediaBrowser.Model.Providers.ExternalIdInfo."
-      },
-      "ExternalIdInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the display name of the external id provider (IE: IMDB, MusicBrainz, etc).",
-            "nullable": true
-          },
-          "Key": {
-            "type": "string",
-            "description": "Gets or sets the unique key for this id. This key should be unique across all providers.",
-            "nullable": true
-          },
           "Type": {
-            "$ref": "#/components/schemas/ExternalIdMediaType"
+            "enum": [
+              "Primary",
+              "Art",
+              "Backdrop",
+              "Banner",
+              "Logo",
+              "Thumb",
+              "Disc",
+              "Box",
+              "Screenshot",
+              "Menu",
+              "Chapter",
+              "BoxRear",
+              "Profile"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageType"
+              }
+            ],
+            "description": "Gets or sets the type."
           },
-          "UrlFormatString": {
-            "type": "string",
-            "description": "Gets or sets the URL format string.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Represents the external id information for serialization to the client."
-      },
-      "RemoteSearchResult": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "ProductionYear": {
+          "Limit": {
             "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
+            "description": "Gets or sets the limit.",
+            "format": "int32"
           },
-          "IndexNumber": {
+          "MinWidth": {
             "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumberEnd": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "ImageUrl": {
-            "type": "string",
-            "nullable": true
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "nullable": true
-          },
-          "Overview": {
-            "type": "string",
-            "nullable": true
-          },
-          "AlbumArtist": {
-            "$ref": "#/components/schemas/RemoteSearchResult"
-          },
-          "Artists": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/RemoteSearchResult"
-            },
-            "nullable": true
+            "description": "Gets or sets the minimum width.",
+            "format": "int32"
           }
         },
         "additionalProperties": false
       },
-      "BookInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          },
-          "SeriesName": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "BookInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/BookInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "BoxSetInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "BoxSetInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/BoxSetInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "MovieInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "MovieInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/MovieInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "SongInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          },
-          "AlbumArtists": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "Album": {
-            "type": "string",
-            "nullable": true
-          },
-          "Artists": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "AlbumInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          },
-          "AlbumArtists": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the album artist.",
-            "nullable": true
-          },
-          "ArtistProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the artist provider ids.",
-            "nullable": true
-          },
-          "SongInfos": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/SongInfo"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "AlbumInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/AlbumInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "ArtistInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          },
-          "SongInfos": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/SongInfo"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ArtistInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/ArtistInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "MusicVideoInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          },
-          "Artists": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "MusicVideoInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/MusicVideoInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "PersonLookupInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "PersonLookupInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/PersonLookupInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "SeriesInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "SeriesInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/SeriesInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "TrailerInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path.",
-            "nullable": true
-          },
-          "MetadataLanguage": {
-            "type": "string",
-            "description": "Gets or sets the metadata language.",
-            "nullable": true
-          },
-          "MetadataCountryCode": {
-            "type": "string",
-            "description": "Gets or sets the metadata country code.",
-            "nullable": true
-          },
-          "ProviderIds": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the provider ids.",
-            "nullable": true
-          },
-          "Year": {
-            "type": "integer",
-            "description": "Gets or sets the year.",
-            "format": "int32",
-            "nullable": true
-          },
-          "IndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "ParentIndexNumber": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "PremiereDate": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsAutomated": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "TrailerInfoRemoteSearchQuery": {
-        "type": "object",
-        "properties": {
-          "SearchInfo": {
-            "$ref": "#/components/schemas/TrailerInfo"
-          },
-          "ItemId": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "SearchProviderName": {
-            "type": "string",
-            "description": "Will only search within the given provider when set.",
-            "nullable": true
-          },
-          "IncludeDisabledProviders": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether disabled providers should be included."
-          }
-        },
-        "additionalProperties": false
-      },
-      "MetadataRefreshMode": {
+      "ImageOrientation": {
         "enum": [
-          "None",
-          "ValidationOnly",
-          "Default",
-          "FullRefresh"
+          "TopLeft",
+          "TopRight",
+          "BottomRight",
+          "BottomLeft",
+          "LeftTop",
+          "RightTop",
+          "RightBottom",
+          "LeftBottom"
         ],
         "type": "string"
       },
-      "SeriesStatus": {
+      "ImageProviderInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets the name."
+          },
+          "SupportedImages": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ImageType"
+            },
+            "description": "Gets the supported image types."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class ImageProviderInfo."
+      },
+      "ImageResolution": {
         "enum": [
-          "Continuing",
-          "Ended"
+          "MatchSource",
+          "P144",
+          "P240",
+          "P360",
+          "P480",
+          "P720",
+          "P1080",
+          "P1440",
+          "P2160"
         ],
         "type": "string",
-        "description": "Enum SeriesStatus."
+        "description": "Enum ImageResolution."
       },
-      "ParentalRating": {
+      "ImageSavingConvention": {
+        "enum": [
+          "Legacy",
+          "Compatible"
+        ],
+        "type": "string"
+      },
+      "ImageType": {
+        "enum": [
+          "Primary",
+          "Art",
+          "Backdrop",
+          "Banner",
+          "Logo",
+          "Thumb",
+          "Disc",
+          "Box",
+          "Screenshot",
+          "Menu",
+          "Chapter",
+          "BoxRear",
+          "Profile"
+        ],
+        "type": "string",
+        "description": "Enum ImageType."
+      },
+      "InboundKeepAliveMessage": {
         "type": "object",
         "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Value": {
-            "type": "integer",
-            "description": "Gets or sets the value.",
-            "format": "int32"
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "KeepAlive",
+            "readOnly": true
           }
         },
         "additionalProperties": false,
-        "description": "Class ParentalRating."
+        "description": "Keep alive websocket messages."
       },
-      "CountryInfo": {
+      "InboundWebSocketMessage": {
+        "type": "object",
+        "oneOf": [
+          {
+            "$ref": "#/components/schemas/ActivityLogEntryStartMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ActivityLogEntryStopMessage"
+          },
+          {
+            "$ref": "#/components/schemas/InboundKeepAliveMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ScheduledTasksInfoStartMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ScheduledTasksInfoStopMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SessionsStartMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SessionsStopMessage"
+          }
+        ],
+        "description": "Represents the list of possible inbound websocket types",
+        "discriminator": {
+          "propertyName": "MessageType",
+          "mapping": {
+            "ActivityLogEntryStart": "#/components/schemas/ActivityLogEntryStartMessage",
+            "ActivityLogEntryStop": "#/components/schemas/ActivityLogEntryStopMessage",
+            "KeepAlive": "#/components/schemas/InboundKeepAliveMessage",
+            "ScheduledTasksInfoStart": "#/components/schemas/ScheduledTasksInfoStartMessage",
+            "ScheduledTasksInfoStop": "#/components/schemas/ScheduledTasksInfoStopMessage",
+            "SessionsStart": "#/components/schemas/SessionsStartMessage",
+            "SessionsStop": "#/components/schemas/SessionsStopMessage"
+          }
+        }
+      },
+      "InstallationInfo": {
         "type": "object",
         "properties": {
+          "Guid": {
+            "type": "string",
+            "description": "Gets or sets the Id.",
+            "format": "uuid"
+          },
           "Name": {
             "type": "string",
             "description": "Gets or sets the name.",
             "nullable": true
           },
-          "DisplayName": {
+          "Version": {
             "type": "string",
-            "description": "Gets or sets the display name.",
+            "description": "Gets or sets the version.",
             "nullable": true
           },
-          "TwoLetterISORegionName": {
+          "Changelog": {
             "type": "string",
-            "description": "Gets or sets the name of the two letter ISO region.",
+            "description": "Gets or sets the changelog for this version.",
             "nullable": true
           },
-          "ThreeLetterISORegionName": {
+          "SourceUrl": {
             "type": "string",
-            "description": "Gets or sets the name of the three letter ISO region.",
+            "description": "Gets or sets the source URL.",
+            "nullable": true
+          },
+          "Checksum": {
+            "type": "string",
+            "description": "Gets or sets a checksum for the binary.",
+            "nullable": true
+          },
+          "PackageInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PackageInfo"
+              }
+            ],
+            "description": "Gets or sets package information for the installation.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Class CountryInfo."
+        "description": "Class InstallationInfo."
       },
-      "CultureDto": {
+      "IPlugin": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "DisplayName": {
-            "type": "string",
-            "description": "Gets or sets the display name.",
-            "nullable": true
-          },
-          "TwoLetterISOLanguageName": {
-            "type": "string",
-            "description": "Gets or sets the name of the two letter ISO language.",
-            "nullable": true
-          },
-          "ThreeLetterISOLanguageName": {
-            "type": "string",
-            "description": "Gets or sets the name of the three letter ISO language.",
+            "description": "Gets the name of the plugin.",
             "nullable": true,
             "readOnly": true
           },
-          "ThreeLetterISOLanguageNames": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
+          "Description": {
+            "type": "string",
+            "description": "Gets the Description.",
+            "nullable": true,
+            "readOnly": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets the unique id.",
+            "format": "uuid",
+            "readOnly": true
+          },
+          "Version": {
+            "type": "string",
+            "description": "Gets the plugin version.",
+            "nullable": true,
+            "readOnly": true
+          },
+          "AssemblyFilePath": {
+            "type": "string",
+            "description": "Gets the path to the assembly file.",
+            "nullable": true,
+            "readOnly": true
+          },
+          "CanUninstall": {
+            "type": "boolean",
+            "description": "Gets a value indicating whether the plugin can be uninstalled.",
+            "readOnly": true
+          },
+          "DataFolderPath": {
+            "type": "string",
+            "description": "Gets the full path to the data folder, where the plugin can store any miscellaneous files needed.",
+            "nullable": true,
+            "readOnly": true
           }
         },
         "additionalProperties": false,
-        "description": "Class CultureDto."
+        "description": "Defines the MediaBrowser.Common.Plugins.IPlugin."
       },
-      "MetadataEditorInfo": {
-        "type": "object",
-        "properties": {
-          "ParentalRatingOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ParentalRating"
-            },
-            "nullable": true
-          },
-          "Countries": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/CountryInfo"
-            },
-            "nullable": true
-          },
-          "Cultures": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/CultureDto"
-            },
-            "nullable": true
-          },
-          "ExternalIdInfos": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ExternalIdInfo"
-            },
-            "nullable": true
-          },
-          "ContentType": {
-            "type": "string",
-            "nullable": true
-          },
-          "ContentTypeOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NameValuePair"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ThemeMediaResult": {
-        "type": "object",
-        "properties": {
-          "Items": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/BaseItemDto"
-            },
-            "description": "Gets or sets the items.",
-            "nullable": true
-          },
-          "TotalRecordCount": {
-            "type": "integer",
-            "description": "The total number of records available.",
-            "format": "int32"
-          },
-          "StartIndex": {
-            "type": "integer",
-            "description": "The index of the first record in Items.",
-            "format": "int32"
-          },
-          "OwnerId": {
-            "type": "string",
-            "description": "Gets or sets the owner id.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class ThemeMediaResult."
-      },
-      "AllThemeMediaResult": {
-        "type": "object",
-        "properties": {
-          "ThemeVideosResult": {
-            "$ref": "#/components/schemas/ThemeMediaResult"
-          },
-          "ThemeSongsResult": {
-            "$ref": "#/components/schemas/ThemeMediaResult"
-          },
-          "SoundtrackSongsResult": {
-            "$ref": "#/components/schemas/ThemeMediaResult"
-          }
-        },
-        "additionalProperties": false
+      "IsoType": {
+        "enum": [
+          "Dvd",
+          "BluRay"
+        ],
+        "type": "string",
+        "description": "Enum IsoType."
       },
       "ItemCounts": {
         "type": "object",
@@ -50605,6 +49014,213 @@
         "additionalProperties": false,
         "description": "Class LibrarySummary."
       },
+      "ItemFields": {
+        "enum": [
+          "AirTime",
+          "CanDelete",
+          "CanDownload",
+          "ChannelInfo",
+          "Chapters",
+          "Trickplay",
+          "ChildCount",
+          "CumulativeRunTimeTicks",
+          "CustomRating",
+          "DateCreated",
+          "DateLastMediaAdded",
+          "DisplayPreferencesId",
+          "Etag",
+          "ExternalUrls",
+          "Genres",
+          "HomePageUrl",
+          "ItemCounts",
+          "MediaSourceCount",
+          "MediaSources",
+          "OriginalTitle",
+          "Overview",
+          "ParentId",
+          "Path",
+          "People",
+          "PlayAccess",
+          "ProductionLocations",
+          "ProviderIds",
+          "PrimaryImageAspectRatio",
+          "RecursiveItemCount",
+          "Settings",
+          "ScreenshotImageTags",
+          "SeriesPrimaryImage",
+          "SeriesStudio",
+          "SortName",
+          "SpecialEpisodeNumbers",
+          "Studios",
+          "Taglines",
+          "Tags",
+          "RemoteTrailers",
+          "MediaStreams",
+          "SeasonUserData",
+          "ServiceName",
+          "ThemeSongIds",
+          "ThemeVideoIds",
+          "ExternalEtag",
+          "PresentationUniqueKey",
+          "InheritedParentalRatingValue",
+          "ExternalSeriesId",
+          "SeriesPresentationUniqueKey",
+          "DateLastRefreshed",
+          "DateLastSaved",
+          "RefreshState",
+          "ChannelImage",
+          "EnableMediaSourceDisplay",
+          "Width",
+          "Height",
+          "ExtraIds",
+          "LocalTrailerCount",
+          "IsHD",
+          "SpecialFeatureCount"
+        ],
+        "type": "string",
+        "description": "Used to control the data that gets attached to DtoBaseItems."
+      },
+      "ItemFilter": {
+        "enum": [
+          "IsFolder",
+          "IsNotFolder",
+          "IsUnplayed",
+          "IsPlayed",
+          "IsFavorite",
+          "IsResumable",
+          "Likes",
+          "Dislikes",
+          "IsFavoriteOrLikes"
+        ],
+        "type": "string",
+        "description": "Enum ItemFilter."
+      },
+      "ItemSortBy": {
+        "enum": [
+          "Default",
+          "AiredEpisodeOrder",
+          "Album",
+          "AlbumArtist",
+          "Artist",
+          "DateCreated",
+          "OfficialRating",
+          "DatePlayed",
+          "PremiereDate",
+          "StartDate",
+          "SortName",
+          "Name",
+          "Random",
+          "Runtime",
+          "CommunityRating",
+          "ProductionYear",
+          "PlayCount",
+          "CriticRating",
+          "IsFolder",
+          "IsUnplayed",
+          "IsPlayed",
+          "SeriesSortName",
+          "VideoBitRate",
+          "AirTime",
+          "Studio",
+          "IsFavoriteOrLiked",
+          "DateLastContentAdded",
+          "SeriesDatePlayed",
+          "ParentIndexNumber",
+          "IndexNumber",
+          "SimilarityScore",
+          "SearchScore"
+        ],
+        "type": "string",
+        "description": "These represent sort orders."
+      },
+      "JoinGroupRequestDto": {
+        "type": "object",
+        "properties": {
+          "GroupId": {
+            "type": "string",
+            "description": "Gets or sets the group identifier.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class JoinGroupRequestDto."
+      },
+      "KeepUntil": {
+        "enum": [
+          "UntilDeleted",
+          "UntilSpaceNeeded",
+          "UntilWatched",
+          "UntilDate"
+        ],
+        "type": "string"
+      },
+      "LibraryChangedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LibraryUpdateInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "LibraryChanged",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Library changed message."
+      },
       "LibraryOptionInfoDto": {
         "type": "object",
         "properties": {
@@ -50621,211 +49237,45 @@
         "additionalProperties": false,
         "description": "Library option info dto."
       },
-      "ImageOption": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "$ref": "#/components/schemas/ImageType"
-          },
-          "Limit": {
-            "type": "integer",
-            "description": "Gets or sets the limit.",
-            "format": "int32"
-          },
-          "MinWidth": {
-            "type": "integer",
-            "description": "Gets or sets the minimum width.",
-            "format": "int32"
-          }
-        },
-        "additionalProperties": false
-      },
-      "LibraryTypeOptionsDto": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
-          },
-          "MetadataFetchers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryOptionInfoDto"
-            },
-            "description": "Gets or sets the metadata fetchers.",
-            "nullable": true
-          },
-          "ImageFetchers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryOptionInfoDto"
-            },
-            "description": "Gets or sets the image fetchers.",
-            "nullable": true
-          },
-          "SupportedImageTypes": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ImageType"
-            },
-            "description": "Gets or sets the supported image types.",
-            "nullable": true
-          },
-          "DefaultImageOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ImageOption"
-            },
-            "description": "Gets or sets the default image options.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Library type options dto."
-      },
-      "LibraryOptionsResultDto": {
-        "type": "object",
-        "properties": {
-          "MetadataSavers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryOptionInfoDto"
-            },
-            "description": "Gets or sets the metadata savers.",
-            "nullable": true
-          },
-          "MetadataReaders": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryOptionInfoDto"
-            },
-            "description": "Gets or sets the metadata readers.",
-            "nullable": true
-          },
-          "SubtitleFetchers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryOptionInfoDto"
-            },
-            "description": "Gets or sets the subtitle fetchers.",
-            "nullable": true
-          },
-          "TypeOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LibraryTypeOptionsDto"
-            },
-            "description": "Gets or sets the type options.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Library options result dto."
-      },
-      "MediaUpdateInfoDto": {
-        "type": "object",
-        "properties": {
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets media path.",
-            "nullable": true
-          },
-          "UpdateType": {
-            "type": "string",
-            "description": "Gets or sets media update type.\r\nCreated, Modified, Deleted.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Media Update Info Dto."
-      },
-      "MediaPathInfo": {
-        "type": "object",
-        "properties": {
-          "Path": {
-            "type": "string",
-            "nullable": true
-          },
-          "NetworkPath": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "TypeOptions": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "type": "string",
-            "nullable": true
-          },
-          "MetadataFetchers": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "MetadataFetcherOrder": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "ImageFetchers": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "ImageFetcherOrder": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "ImageOptions": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ImageOption"
-            },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
       "LibraryOptions": {
         "type": "object",
         "properties": {
+          "Enabled": {
+            "type": "boolean"
+          },
           "EnablePhotos": {
             "type": "boolean"
           },
           "EnableRealtimeMonitor": {
             "type": "boolean"
           },
+          "EnableLUFSScan": {
+            "type": "boolean"
+          },
           "EnableChapterImageExtraction": {
             "type": "boolean"
           },
           "ExtractChapterImagesDuringLibraryScan": {
             "type": "boolean"
           },
+          "EnableTrickplayImageExtraction": {
+            "type": "boolean"
+          },
+          "ExtractTrickplayImagesDuringLibraryScan": {
+            "type": "boolean"
+          },
           "PathInfos": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/MediaPathInfo"
-            },
-            "nullable": true
+            }
           },
           "SaveLocalMetadata": {
             "type": "boolean"
           },
           "EnableInternetProviders": {
-            "type": "boolean"
+            "type": "boolean",
+            "deprecated": true
           },
           "EnableAutomaticSeriesGrouping": {
             "type": "boolean"
@@ -50833,6 +49283,9 @@
           "EnableEmbeddedTitles": {
             "type": "boolean"
           },
+          "EnableEmbeddedExtrasTitles": {
+            "type": "boolean"
+          },
           "EnableEmbeddedEpisodeInfos": {
             "type": "boolean"
           },
@@ -50851,8 +49304,7 @@
             "nullable": true
           },
           "SeasonZeroDisplayName": {
-            "type": "string",
-            "nullable": true
+            "type": "string"
           },
           "MetadataSavers": {
             "type": "array",
@@ -50865,8 +49317,7 @@
             "type": "array",
             "items": {
               "type": "string"
-            },
-            "nullable": true
+            }
           },
           "LocalMetadataReaderOrder": {
             "type": "array",
@@ -50879,15 +49330,25 @@
             "type": "array",
             "items": {
               "type": "string"
-            },
-            "nullable": true
+            }
           },
           "SubtitleFetcherOrder": {
             "type": "array",
             "items": {
               "type": "string"
-            },
-            "nullable": true
+            }
+          },
+          "DisabledMediaSegmentProviders": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "MediaSegmentProvideOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
           },
           "SkipSubtitlesIfEmbeddedSubtitlesPresent": {
             "type": "boolean"
@@ -50908,301 +49369,205 @@
           "SaveSubtitlesWithMedia": {
             "type": "boolean"
           },
+          "SaveLyricsWithMedia": {
+            "type": "boolean",
+            "default": false
+          },
+          "SaveTrickplayWithMedia": {
+            "type": "boolean",
+            "default": false
+          },
+          "DisabledLyricFetchers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "LyricFetcherOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "PreferNonstandardArtistsTag": {
+            "type": "boolean",
+            "default": false
+          },
+          "UseCustomTagDelimiters": {
+            "type": "boolean",
+            "default": false
+          },
+          "CustomTagDelimiters": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "DelimiterWhitelist": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "AutomaticallyAddToCollection": {
+            "type": "boolean"
+          },
+          "AllowEmbeddedSubtitles": {
+            "enum": [
+              "AllowAll",
+              "AllowText",
+              "AllowImage",
+              "AllowNone"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/EmbeddedSubtitleOptions"
+              }
+            ],
+            "description": "An enum representing the options to disable embedded subs."
+          },
           "TypeOptions": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/TypeOptions"
-            },
-            "nullable": true
+            }
           }
         },
         "additionalProperties": false
       },
-      "VirtualFolderInfo": {
+      "LibraryOptionsResultDto": {
         "type": "object",
         "properties": {
-          "Name": {
+          "MetadataSavers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the metadata savers."
+          },
+          "MetadataReaders": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the metadata readers."
+          },
+          "SubtitleFetchers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the subtitle fetchers."
+          },
+          "LyricFetchers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the list of lyric fetchers."
+          },
+          "TypeOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryTypeOptionsDto"
+            },
+            "description": "Gets or sets the type options."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Library options result dto."
+      },
+      "LibraryTypeOptionsDto": {
+        "type": "object",
+        "properties": {
+          "Type": {
             "type": "string",
-            "description": "Gets or sets the name.",
+            "description": "Gets or sets the type.",
             "nullable": true
           },
-          "Locations": {
+          "MetadataFetchers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the metadata fetchers."
+          },
+          "ImageFetchers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LibraryOptionInfoDto"
+            },
+            "description": "Gets or sets the image fetchers."
+          },
+          "SupportedImageTypes": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ImageType"
+            },
+            "description": "Gets or sets the supported image types."
+          },
+          "DefaultImageOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ImageOption"
+            },
+            "description": "Gets or sets the default image options."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Library type options dto."
+      },
+      "LibraryUpdateInfo": {
+        "type": "object",
+        "properties": {
+          "FoldersAddedTo": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "description": "Gets or sets the locations.",
-            "nullable": true
+            "description": "Gets or sets the folders added to."
           },
-          "CollectionType": {
-            "type": "string",
-            "description": "Gets or sets the type of the collection.",
-            "nullable": true
-          },
-          "LibraryOptions": {
-            "$ref": "#/components/schemas/LibraryOptions"
-          },
-          "ItemId": {
-            "type": "string",
-            "description": "Gets or sets the item identifier.",
-            "nullable": true
-          },
-          "PrimaryImageItemId": {
-            "type": "string",
-            "description": "Gets or sets the primary image item identifier.",
-            "nullable": true
-          },
-          "RefreshProgress": {
-            "type": "number",
-            "format": "double",
-            "nullable": true
-          },
-          "RefreshStatus": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Used to hold information about a user's list of configured virtual folders."
-      },
-      "AddVirtualFolderDto": {
-        "type": "object",
-        "properties": {
-          "LibraryOptions": {
-            "$ref": "#/components/schemas/LibraryOptions"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Add virtual folder dto."
-      },
-      "UpdateLibraryOptionsDto": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the library item id.",
-            "format": "uuid"
-          },
-          "LibraryOptions": {
-            "$ref": "#/components/schemas/LibraryOptions"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Update library options dto."
-      },
-      "MediaPathDto": {
-        "required": [
-          "Name"
-        ],
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name of the library."
-          },
-          "Path": {
-            "type": "string",
-            "description": "Gets or sets the path to add.",
-            "nullable": true
-          },
-          "PathInfo": {
-            "$ref": "#/components/schemas/MediaPathInfo"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Media Path dto."
-      },
-      "TunerChannelMapping": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "ProviderChannelName": {
-            "type": "string",
-            "nullable": true
-          },
-          "ProviderChannelId": {
-            "type": "string",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "NameIdPair": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the identifier.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "ChannelMappingOptionsDto": {
-        "type": "object",
-        "properties": {
-          "TunerChannels": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/TunerChannelMapping"
-            },
-            "description": "Gets or sets list of tuner channels.",
-            "nullable": true
-          },
-          "ProviderChannels": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NameIdPair"
-            },
-            "description": "Gets or sets list of provider channels.",
-            "nullable": true
-          },
-          "Mappings": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NameValuePair"
-            },
-            "description": "Gets or sets list of mappings.",
-            "nullable": true
-          },
-          "ProviderName": {
-            "type": "string",
-            "description": "Gets or sets provider name.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Channel mapping options dto."
-      },
-      "SetChannelMappingDto": {
-        "required": [
-          "ProviderChannelId",
-          "ProviderId",
-          "TunerChannelId"
-        ],
-        "type": "object",
-        "properties": {
-          "ProviderId": {
-            "type": "string",
-            "description": "Gets or sets the provider id."
-          },
-          "TunerChannelId": {
-            "type": "string",
-            "description": "Gets or sets the tuner channel id."
-          },
-          "ProviderChannelId": {
-            "type": "string",
-            "description": "Gets or sets the provider channel id."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Set channel mapping dto."
-      },
-      "GuideInfo": {
-        "type": "object",
-        "properties": {
-          "StartDate": {
-            "type": "string",
-            "description": "Gets or sets the start date.",
-            "format": "date-time"
-          },
-          "EndDate": {
-            "type": "string",
-            "description": "Gets or sets the end date.",
-            "format": "date-time"
-          }
-        },
-        "additionalProperties": false
-      },
-      "LiveTvServiceStatus": {
-        "enum": [
-          "Ok",
-          "Unavailable"
-        ],
-        "type": "string"
-      },
-      "LiveTvServiceInfo": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
-          },
-          "HomePageUrl": {
-            "type": "string",
-            "description": "Gets or sets the home page URL.",
-            "nullable": true
-          },
-          "Status": {
-            "$ref": "#/components/schemas/LiveTvServiceStatus"
-          },
-          "StatusMessage": {
-            "type": "string",
-            "description": "Gets or sets the status message.",
-            "nullable": true
-          },
-          "Version": {
-            "type": "string",
-            "description": "Gets or sets the version.",
-            "nullable": true
-          },
-          "HasUpdateAvailable": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance has update available."
-          },
-          "IsVisible": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is visible."
-          },
-          "Tuners": {
+          "FoldersRemovedFrom": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class ServiceInfo."
-      },
-      "LiveTvInfo": {
-        "type": "object",
-        "properties": {
-          "Services": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/LiveTvServiceInfo"
-            },
-            "description": "Gets or sets the services.",
-            "nullable": true
+            "description": "Gets or sets the folders removed from."
           },
-          "IsEnabled": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is enabled."
-          },
-          "EnabledUsers": {
+          "ItemsAdded": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "description": "Gets or sets the enabled users.",
-            "nullable": true
+            "description": "Gets or sets the items added."
+          },
+          "ItemsRemoved": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the items removed."
+          },
+          "ItemsUpdated": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the items updated."
+          },
+          "CollectionFolders": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "IsEmpty": {
+            "type": "boolean",
+            "readOnly": true
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Class LibraryUpdateInfo."
       },
       "ListingsProviderInfo": {
         "type": "object",
@@ -51299,611 +49664,175 @@
         },
         "additionalProperties": false
       },
-      "GetProgramsDto": {
+      "LiveStreamResponse": {
         "type": "object",
         "properties": {
-          "ChannelIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the channels to return guide information for.",
-            "nullable": true
-          },
-          "UserId": {
-            "type": "string",
-            "description": "Gets or sets optional. Filter by user id.",
-            "format": "uuid"
-          },
-          "MinStartDate": {
-            "type": "string",
-            "description": "Gets or sets the minimum premiere start date.\r\nOptional.",
-            "format": "date-time",
-            "nullable": true
-          },
-          "HasAired": {
-            "type": "boolean",
-            "description": "Gets or sets filter by programs that have completed airing, or not.\r\nOptional.",
-            "nullable": true
-          },
-          "IsAiring": {
-            "type": "boolean",
-            "description": "Gets or sets filter by programs that are currently airing, or not.\r\nOptional.",
-            "nullable": true
-          },
-          "MaxStartDate": {
-            "type": "string",
-            "description": "Gets or sets the maximum premiere start date.\r\nOptional.",
-            "format": "date-time",
-            "nullable": true
-          },
-          "MinEndDate": {
-            "type": "string",
-            "description": "Gets or sets the minimum premiere end date.\r\nOptional.",
-            "format": "date-time",
-            "nullable": true
-          },
-          "MaxEndDate": {
-            "type": "string",
-            "description": "Gets or sets the maximum premiere end date.\r\nOptional.",
-            "format": "date-time",
-            "nullable": true
-          },
-          "IsMovie": {
-            "type": "boolean",
-            "description": "Gets or sets filter for movies.\r\nOptional.",
-            "nullable": true
-          },
-          "IsSeries": {
-            "type": "boolean",
-            "description": "Gets or sets filter for series.\r\nOptional.",
-            "nullable": true
-          },
-          "IsNews": {
-            "type": "boolean",
-            "description": "Gets or sets filter for news.\r\nOptional.",
-            "nullable": true
-          },
-          "IsKids": {
-            "type": "boolean",
-            "description": "Gets or sets filter for kids.\r\nOptional.",
-            "nullable": true
-          },
-          "IsSports": {
-            "type": "boolean",
-            "description": "Gets or sets filter for sports.\r\nOptional.",
-            "nullable": true
-          },
-          "StartIndex": {
-            "type": "integer",
-            "description": "Gets or sets the record index to start at. All items with a lower index will be dropped from the results.\r\nOptional.",
-            "format": "int32",
-            "nullable": true
-          },
-          "Limit": {
-            "type": "integer",
-            "description": "Gets or sets the maximum number of records to return.\r\nOptional.",
-            "format": "int32",
-            "nullable": true
-          },
-          "SortBy": {
-            "type": "string",
-            "description": "Gets or sets specify one or more sort orders, comma delimited. Options: Name, StartDate.\r\nOptional.",
-            "nullable": true
-          },
-          "SortOrder": {
-            "type": "string",
-            "description": "Gets or sets sort Order - Ascending,Descending.",
-            "nullable": true
-          },
-          "Genres": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the genres to return guide information for.",
-            "nullable": true
-          },
-          "GenreIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the genre ids to return guide information for.",
-            "nullable": true
-          },
-          "EnableImages": {
-            "type": "boolean",
-            "description": "Gets or sets include image information in output.\r\nOptional.",
-            "nullable": true
-          },
-          "EnableTotalRecordCount": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether retrieve total record count."
-          },
-          "ImageTypeLimit": {
-            "type": "integer",
-            "description": "Gets or sets the max number of images to return, per image type.\r\nOptional.",
-            "format": "int32",
-            "nullable": true
-          },
-          "EnableImageTypes": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ImageType"
-            },
-            "description": "Gets or sets the image types to include in the output.\r\nOptional.",
-            "nullable": true
-          },
-          "EnableUserData": {
-            "type": "boolean",
-            "description": "Gets or sets include user data.\r\nOptional.",
-            "nullable": true
-          },
-          "SeriesTimerId": {
-            "type": "string",
-            "description": "Gets or sets filter by series timer id.\r\nOptional.",
-            "nullable": true
-          },
-          "LibrarySeriesId": {
-            "type": "string",
-            "description": "Gets or sets filter by library series id.\r\nOptional.",
-            "format": "uuid"
-          },
-          "Fields": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ItemFields"
-            },
-            "description": "Gets or sets specify additional fields of information to return in the output. This allows multiple, comma delimited. Options: Budget, Chapters, DateCreated, Genres, HomePageUrl, IndexOptions, MediaStreams, Overview, ParentId, Path, People, ProviderIds, PrimaryImageAspectRatio, Revenue, SortName, Studios, Taglines.\r\nOptional.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Get programs dto."
-      },
-      "RecordingStatus": {
-        "enum": [
-          "New",
-          "InProgress",
-          "Completed",
-          "Cancelled",
-          "ConflictedOk",
-          "ConflictedNotOk",
-          "Error"
-        ],
-        "type": "string"
-      },
-      "KeepUntil": {
-        "enum": [
-          "UntilDeleted",
-          "UntilSpaceNeeded",
-          "UntilWatched",
-          "UntilDate"
-        ],
-        "type": "string"
-      },
-      "DayPattern": {
-        "enum": [
-          "Daily",
-          "Weekdays",
-          "Weekends"
-        ],
-        "type": "string"
-      },
-      "SeriesTimerInfoDto": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Id of the recording.",
-            "nullable": true
-          },
-          "Type": {
-            "type": "string",
-            "nullable": true
-          },
-          "ServerId": {
-            "type": "string",
-            "description": "Gets or sets the server identifier.",
-            "nullable": true
-          },
-          "ExternalId": {
-            "type": "string",
-            "description": "Gets or sets the external identifier.",
-            "nullable": true
-          },
-          "ChannelId": {
-            "type": "string",
-            "description": "ChannelId of the recording.",
-            "format": "uuid"
-          },
-          "ExternalChannelId": {
-            "type": "string",
-            "description": "Gets or sets the external channel identifier.",
-            "nullable": true
-          },
-          "ChannelName": {
-            "type": "string",
-            "description": "ChannelName of the recording.",
-            "nullable": true
-          },
-          "ChannelPrimaryImageTag": {
-            "type": "string",
-            "nullable": true
-          },
-          "ProgramId": {
-            "type": "string",
-            "description": "Gets or sets the program identifier.",
-            "nullable": true
-          },
-          "ExternalProgramId": {
-            "type": "string",
-            "description": "Gets or sets the external program identifier.",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "description": "Name of the recording.",
-            "nullable": true
-          },
-          "Overview": {
-            "type": "string",
-            "description": "Description of the recording.",
-            "nullable": true
-          },
-          "StartDate": {
-            "type": "string",
-            "description": "The start date of the recording, in UTC.",
-            "format": "date-time"
-          },
-          "EndDate": {
-            "type": "string",
-            "description": "The end date of the recording, in UTC.",
-            "format": "date-time"
-          },
-          "ServiceName": {
-            "type": "string",
-            "description": "Gets or sets the name of the service.",
-            "nullable": true
-          },
-          "Priority": {
-            "type": "integer",
-            "description": "Gets or sets the priority.",
-            "format": "int32"
-          },
-          "PrePaddingSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the pre padding seconds.",
-            "format": "int32"
-          },
-          "PostPaddingSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the post padding seconds.",
-            "format": "int32"
-          },
-          "IsPrePaddingRequired": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is pre padding required."
-          },
-          "ParentBackdropItemId": {
-            "type": "string",
-            "description": "If the item does not have any backdrops, this will hold the Id of the Parent that has one.",
-            "nullable": true
-          },
-          "ParentBackdropImageTags": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the parent backdrop image tags.",
-            "nullable": true
-          },
-          "IsPostPaddingRequired": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is post padding required."
-          },
-          "KeepUntil": {
-            "$ref": "#/components/schemas/KeepUntil"
-          },
-          "RecordAnyTime": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [record any time]."
-          },
-          "SkipEpisodesInLibrary": {
-            "type": "boolean"
-          },
-          "RecordAnyChannel": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [record any channel]."
-          },
-          "KeepUpTo": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "RecordNewOnly": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether [record new only]."
-          },
-          "Days": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/DayOfWeek"
-            },
-            "description": "Gets or sets the days.",
-            "nullable": true
-          },
-          "DayPattern": {
-            "$ref": "#/components/schemas/DayPattern"
-          },
-          "ImageTags": {
-            "type": "object",
-            "additionalProperties": {
-              "type": "string"
-            },
-            "description": "Gets or sets the image tags.",
-            "nullable": true
-          },
-          "ParentThumbItemId": {
-            "type": "string",
-            "description": "Gets or sets the parent thumb item id.",
-            "nullable": true
-          },
-          "ParentThumbImageTag": {
-            "type": "string",
-            "description": "Gets or sets the parent thumb image tag.",
-            "nullable": true
-          },
-          "ParentPrimaryImageItemId": {
-            "type": "string",
-            "description": "Gets or sets the parent primary image item identifier.",
-            "nullable": true
-          },
-          "ParentPrimaryImageTag": {
-            "type": "string",
-            "description": "Gets or sets the parent primary image tag.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SeriesTimerInfoDto."
-      },
-      "SeriesTimerInfoDtoQueryResult": {
-        "type": "object",
-        "properties": {
-          "Items": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/SeriesTimerInfoDto"
-            },
-            "description": "Gets or sets the items.",
-            "nullable": true
-          },
-          "TotalRecordCount": {
-            "type": "integer",
-            "description": "The total number of records available.",
-            "format": "int32"
-          },
-          "StartIndex": {
-            "type": "integer",
-            "description": "The index of the first record in Items.",
-            "format": "int32"
+          "MediaSource": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaSourceInfo"
+              }
+            ]
           }
         },
         "additionalProperties": false
       },
-      "TimerInfoDto": {
+      "LiveTvInfo": {
         "type": "object",
         "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Id of the recording.",
-            "nullable": true
+          "Services": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/LiveTvServiceInfo"
+            },
+            "description": "Gets or sets the services."
           },
-          "Type": {
-            "type": "string",
-            "nullable": true
-          },
-          "ServerId": {
-            "type": "string",
-            "description": "Gets or sets the server identifier.",
-            "nullable": true
-          },
-          "ExternalId": {
-            "type": "string",
-            "description": "Gets or sets the external identifier.",
-            "nullable": true
-          },
-          "ChannelId": {
-            "type": "string",
-            "description": "ChannelId of the recording.",
-            "format": "uuid"
-          },
-          "ExternalChannelId": {
-            "type": "string",
-            "description": "Gets or sets the external channel identifier.",
-            "nullable": true
-          },
-          "ChannelName": {
-            "type": "string",
-            "description": "ChannelName of the recording.",
-            "nullable": true
-          },
-          "ChannelPrimaryImageTag": {
-            "type": "string",
-            "nullable": true
-          },
-          "ProgramId": {
-            "type": "string",
-            "description": "Gets or sets the program identifier.",
-            "nullable": true
-          },
-          "ExternalProgramId": {
-            "type": "string",
-            "description": "Gets or sets the external program identifier.",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "description": "Name of the recording.",
-            "nullable": true
-          },
-          "Overview": {
-            "type": "string",
-            "description": "Description of the recording.",
-            "nullable": true
-          },
-          "StartDate": {
-            "type": "string",
-            "description": "The start date of the recording, in UTC.",
-            "format": "date-time"
-          },
-          "EndDate": {
-            "type": "string",
-            "description": "The end date of the recording, in UTC.",
-            "format": "date-time"
-          },
-          "ServiceName": {
-            "type": "string",
-            "description": "Gets or sets the name of the service.",
-            "nullable": true
-          },
-          "Priority": {
-            "type": "integer",
-            "description": "Gets or sets the priority.",
-            "format": "int32"
-          },
-          "PrePaddingSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the pre padding seconds.",
-            "format": "int32"
-          },
-          "PostPaddingSeconds": {
-            "type": "integer",
-            "description": "Gets or sets the post padding seconds.",
-            "format": "int32"
-          },
-          "IsPrePaddingRequired": {
+          "IsEnabled": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is pre padding required."
+            "description": "Gets or sets a value indicating whether this instance is enabled."
           },
-          "ParentBackdropItemId": {
-            "type": "string",
-            "description": "If the item does not have any backdrops, this will hold the Id of the Parent that has one.",
-            "nullable": true
-          },
-          "ParentBackdropImageTags": {
+          "EnabledUsers": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "description": "Gets or sets the parent backdrop image tags.",
+            "description": "Gets or sets the enabled users."
+          }
+        },
+        "additionalProperties": false
+      },
+      "LiveTvOptions": {
+        "type": "object",
+        "properties": {
+          "GuideDays": {
+            "type": "integer",
+            "format": "int32",
             "nullable": true
           },
-          "IsPostPaddingRequired": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is post padding required."
+          "RecordingPath": {
+            "type": "string",
+            "nullable": true
           },
-          "KeepUntil": {
-            "$ref": "#/components/schemas/KeepUntil"
+          "MovieRecordingPath": {
+            "type": "string",
+            "nullable": true
+          },
+          "SeriesRecordingPath": {
+            "type": "string",
+            "nullable": true
+          },
+          "EnableRecordingSubfolders": {
+            "type": "boolean"
+          },
+          "EnableOriginalAudioWithEncodedRecordings": {
+            "type": "boolean"
+          },
+          "TunerHosts": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TunerHostInfo"
+            },
+            "nullable": true
+          },
+          "ListingProviders": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ListingsProviderInfo"
+            },
+            "nullable": true
+          },
+          "PrePaddingSeconds": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "PostPaddingSeconds": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "MediaLocationsCreated": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "RecordingPostProcessor": {
+            "type": "string",
+            "nullable": true
+          },
+          "RecordingPostProcessorArguments": {
+            "type": "string",
+            "nullable": true
+          },
+          "SaveRecordingNFO": {
+            "type": "boolean"
+          },
+          "SaveRecordingImages": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "LiveTvServiceInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "HomePageUrl": {
+            "type": "string",
+            "description": "Gets or sets the home page URL.",
+            "nullable": true
           },
           "Status": {
-            "$ref": "#/components/schemas/RecordingStatus"
+            "enum": [
+              "Ok",
+              "Unavailable"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LiveTvServiceStatus"
+              }
+            ],
+            "description": "Gets or sets the status."
           },
-          "SeriesTimerId": {
+          "StatusMessage": {
             "type": "string",
-            "description": "Gets or sets the series timer identifier.",
+            "description": "Gets or sets the status message.",
             "nullable": true
           },
-          "ExternalSeriesTimerId": {
+          "Version": {
             "type": "string",
-            "description": "Gets or sets the external series timer identifier.",
+            "description": "Gets or sets the version.",
             "nullable": true
           },
-          "RunTimeTicks": {
-            "type": "integer",
-            "description": "Gets or sets the run time ticks.",
-            "format": "int64",
-            "nullable": true
+          "HasUpdateAvailable": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance has update available."
           },
-          "ProgramInfo": {
-            "$ref": "#/components/schemas/BaseItemDto"
-          }
-        },
-        "additionalProperties": false
-      },
-      "TimerInfoDtoQueryResult": {
-        "type": "object",
-        "properties": {
-          "Items": {
+          "IsVisible": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is visible."
+          },
+          "Tuners": {
             "type": "array",
             "items": {
-              "$ref": "#/components/schemas/TimerInfoDto"
+              "type": "string"
             },
-            "description": "Gets or sets the items.",
             "nullable": true
-          },
-          "TotalRecordCount": {
-            "type": "integer",
-            "description": "The total number of records available.",
-            "format": "int32"
-          },
-          "StartIndex": {
-            "type": "integer",
-            "description": "The index of the first record in Items.",
-            "format": "int32"
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Class ServiceInfo."
       },
-      "TunerHostInfo": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "nullable": true
-          },
-          "Url": {
-            "type": "string",
-            "nullable": true
-          },
-          "Type": {
-            "type": "string",
-            "nullable": true
-          },
-          "DeviceId": {
-            "type": "string",
-            "nullable": true
-          },
-          "FriendlyName": {
-            "type": "string",
-            "nullable": true
-          },
-          "ImportFavoritesOnly": {
-            "type": "boolean"
-          },
-          "AllowHWTranscoding": {
-            "type": "boolean"
-          },
-          "EnableStreamLooping": {
-            "type": "boolean"
-          },
-          "Source": {
-            "type": "string",
-            "nullable": true
-          },
-          "TunerCount": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "UserAgent": {
-            "type": "string",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
+      "LiveTvServiceStatus": {
+        "enum": [
+          "Ok",
+          "Unavailable"
+        ],
+        "type": "string"
       },
       "LocalizationOption": {
         "type": "object",
@@ -51919,122 +49848,1627 @@
         },
         "additionalProperties": false
       },
-      "PlaybackErrorCode": {
+      "LocationType": {
         "enum": [
-          "NotAllowed",
-          "NoCompatibleStream",
-          "RateLimitExceeded"
+          "FileSystem",
+          "Remote",
+          "Virtual",
+          "Offline"
+        ],
+        "type": "string",
+        "description": "Enum LocationType."
+      },
+      "LogFile": {
+        "type": "object",
+        "properties": {
+          "DateCreated": {
+            "type": "string",
+            "description": "Gets or sets the date created.",
+            "format": "date-time"
+          },
+          "DateModified": {
+            "type": "string",
+            "description": "Gets or sets the date modified.",
+            "format": "date-time"
+          },
+          "Size": {
+            "type": "integer",
+            "description": "Gets or sets the size.",
+            "format": "int64"
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name."
+          }
+        },
+        "additionalProperties": false
+      },
+      "LogLevel": {
+        "enum": [
+          "Trace",
+          "Debug",
+          "Information",
+          "Warning",
+          "Error",
+          "Critical",
+          "None"
         ],
         "type": "string"
       },
-      "PlaybackInfoResponse": {
+      "LyricDto": {
         "type": "object",
         "properties": {
-          "MediaSources": {
+          "Metadata": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LyricMetadata"
+              }
+            ],
+            "description": "Gets or sets Metadata for the lyrics."
+          },
+          "Lyrics": {
             "type": "array",
             "items": {
-              "$ref": "#/components/schemas/MediaSourceInfo"
+              "$ref": "#/components/schemas/LyricLine"
             },
-            "description": "Gets or sets the media sources.",
-            "nullable": true
-          },
-          "PlaySessionId": {
-            "type": "string",
-            "description": "Gets or sets the play session identifier.",
-            "nullable": true
-          },
-          "ErrorCode": {
-            "$ref": "#/components/schemas/PlaybackErrorCode"
+            "description": "Gets or sets a collection of individual lyric lines."
           }
         },
         "additionalProperties": false,
-        "description": "Class PlaybackInfoResponse."
+        "description": "LyricResponse model."
       },
-      "PlaybackInfoDto": {
+      "LyricLine": {
         "type": "object",
         "properties": {
-          "UserId": {
+          "Text": {
             "type": "string",
-            "description": "Gets or sets the playback userId.",
-            "format": "uuid",
+            "description": "Gets the text of this lyric line."
+          },
+          "Start": {
+            "type": "integer",
+            "description": "Gets the start time in ticks.",
+            "format": "int64",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Lyric model."
+      },
+      "LyricMetadata": {
+        "type": "object",
+        "properties": {
+          "Artist": {
+            "type": "string",
+            "description": "Gets or sets the song artist.",
             "nullable": true
           },
-          "MaxStreamingBitrate": {
-            "type": "integer",
-            "description": "Gets or sets the max streaming bitrate.",
-            "format": "int32",
+          "Album": {
+            "type": "string",
+            "description": "Gets or sets the album this song is on.",
             "nullable": true
           },
-          "StartTimeTicks": {
+          "Title": {
+            "type": "string",
+            "description": "Gets or sets the title of the song.",
+            "nullable": true
+          },
+          "Author": {
+            "type": "string",
+            "description": "Gets or sets the author of the lyric data.",
+            "nullable": true
+          },
+          "Length": {
             "type": "integer",
-            "description": "Gets or sets the start time in ticks.",
+            "description": "Gets or sets the length of the song in ticks.",
             "format": "int64",
             "nullable": true
           },
-          "AudioStreamIndex": {
-            "type": "integer",
-            "description": "Gets or sets the audio stream index.",
-            "format": "int32",
-            "nullable": true
-          },
-          "SubtitleStreamIndex": {
-            "type": "integer",
-            "description": "Gets or sets the subtitle stream index.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MaxAudioChannels": {
-            "type": "integer",
-            "description": "Gets or sets the max audio channels.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MediaSourceId": {
+          "By": {
             "type": "string",
-            "description": "Gets or sets the media source id.",
+            "description": "Gets or sets who the LRC file was created by.",
             "nullable": true
           },
-          "LiveStreamId": {
+          "Offset": {
+            "type": "integer",
+            "description": "Gets or sets the lyric offset compared to audio in ticks.",
+            "format": "int64",
+            "nullable": true
+          },
+          "Creator": {
             "type": "string",
-            "description": "Gets or sets the live stream id.",
+            "description": "Gets or sets the software used to create the LRC file.",
             "nullable": true
           },
-          "DeviceProfile": {
-            "$ref": "#/components/schemas/DeviceProfile"
-          },
-          "EnableDirectPlay": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable direct play.",
+          "Version": {
+            "type": "string",
+            "description": "Gets or sets the version of the creator used.",
             "nullable": true
           },
-          "EnableDirectStream": {
+          "IsSynced": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable direct stream.",
-            "nullable": true
-          },
-          "EnableTranscoding": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable transcoding.",
-            "nullable": true
-          },
-          "AllowVideoStreamCopy": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to enable video stream copy.",
-            "nullable": true
-          },
-          "AllowAudioStreamCopy": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to allow audio stream copy.",
-            "nullable": true
-          },
-          "AutoOpenLiveStream": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to auto open the live stream.",
+            "description": "Gets or sets a value indicating whether this lyric is synced.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Plabyback info dto."
+        "description": "LyricMetadata model."
+      },
+      "MediaAttachment": {
+        "type": "object",
+        "properties": {
+          "Codec": {
+            "type": "string",
+            "description": "Gets or sets the codec.",
+            "nullable": true
+          },
+          "CodecTag": {
+            "type": "string",
+            "description": "Gets or sets the codec tag.",
+            "nullable": true
+          },
+          "Comment": {
+            "type": "string",
+            "description": "Gets or sets the comment.",
+            "nullable": true
+          },
+          "Index": {
+            "type": "integer",
+            "description": "Gets or sets the index.",
+            "format": "int32"
+          },
+          "FileName": {
+            "type": "string",
+            "description": "Gets or sets the filename.",
+            "nullable": true
+          },
+          "MimeType": {
+            "type": "string",
+            "description": "Gets or sets the MIME type.",
+            "nullable": true
+          },
+          "DeliveryUrl": {
+            "type": "string",
+            "description": "Gets or sets the delivery URL.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class MediaAttachment."
+      },
+      "MediaPathDto": {
+        "required": [
+          "Name"
+        ],
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of the library."
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path to add.",
+            "nullable": true
+          },
+          "PathInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaPathInfo"
+              }
+            ],
+            "description": "Gets or sets the path info.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Media Path dto."
+      },
+      "MediaPathInfo": {
+        "type": "object",
+        "properties": {
+          "Path": {
+            "type": "string"
+          }
+        },
+        "additionalProperties": false
+      },
+      "MediaProtocol": {
+        "enum": [
+          "File",
+          "Http",
+          "Rtmp",
+          "Rtsp",
+          "Udp",
+          "Rtp",
+          "Ftp"
+        ],
+        "type": "string"
+      },
+      "MediaSegmentDto": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the id of the media segment.",
+            "format": "uuid"
+          },
+          "ItemId": {
+            "type": "string",
+            "description": "Gets or sets the id of the associated item.",
+            "format": "uuid"
+          },
+          "Type": {
+            "enum": [
+              "Unknown",
+              "Commercial",
+              "Preview",
+              "Recap",
+              "Outro",
+              "Intro"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaSegmentType"
+              }
+            ],
+            "description": "Defines the types of content an individual Jellyfin.Data.Entities.MediaSegment represents."
+          },
+          "StartTicks": {
+            "type": "integer",
+            "description": "Gets or sets the start of the segment.",
+            "format": "int64"
+          },
+          "EndTicks": {
+            "type": "integer",
+            "description": "Gets or sets the end of the segment.",
+            "format": "int64"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Api model for MediaSegment's."
+      },
+      "MediaSegmentDtoQueryResult": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaSegmentDto"
+            },
+            "description": "Gets or sets the items."
+          },
+          "TotalRecordCount": {
+            "type": "integer",
+            "description": "Gets or sets the total number of records available.",
+            "format": "int32"
+          },
+          "StartIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the first record in Items.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Query result container."
+      },
+      "MediaSegmentType": {
+        "enum": [
+          "Unknown",
+          "Commercial",
+          "Preview",
+          "Recap",
+          "Outro",
+          "Intro"
+        ],
+        "type": "string",
+        "description": "Defines the types of content an individual Jellyfin.Data.Entities.MediaSegment represents."
+      },
+      "MediaSourceInfo": {
+        "type": "object",
+        "properties": {
+          "Protocol": {
+            "enum": [
+              "File",
+              "Http",
+              "Rtmp",
+              "Rtsp",
+              "Udp",
+              "Rtp",
+              "Ftp"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaProtocol"
+              }
+            ]
+          },
+          "Id": {
+            "type": "string",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "nullable": true
+          },
+          "EncoderPath": {
+            "type": "string",
+            "nullable": true
+          },
+          "EncoderProtocol": {
+            "enum": [
+              "File",
+              "Http",
+              "Rtmp",
+              "Rtsp",
+              "Udp",
+              "Rtp",
+              "Ftp"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaProtocol"
+              }
+            ],
+            "nullable": true
+          },
+          "Type": {
+            "enum": [
+              "Default",
+              "Grouping",
+              "Placeholder"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaSourceType"
+              }
+            ]
+          },
+          "Container": {
+            "type": "string",
+            "nullable": true
+          },
+          "Size": {
+            "type": "integer",
+            "format": "int64",
+            "nullable": true
+          },
+          "Name": {
+            "type": "string",
+            "nullable": true
+          },
+          "IsRemote": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the media is remote.\r\nDifferentiate internet url vs local network."
+          },
+          "ETag": {
+            "type": "string",
+            "nullable": true
+          },
+          "RunTimeTicks": {
+            "type": "integer",
+            "format": "int64",
+            "nullable": true
+          },
+          "ReadAtNativeFramerate": {
+            "type": "boolean"
+          },
+          "IgnoreDts": {
+            "type": "boolean"
+          },
+          "IgnoreIndex": {
+            "type": "boolean"
+          },
+          "GenPtsInput": {
+            "type": "boolean"
+          },
+          "SupportsTranscoding": {
+            "type": "boolean"
+          },
+          "SupportsDirectStream": {
+            "type": "boolean"
+          },
+          "SupportsDirectPlay": {
+            "type": "boolean"
+          },
+          "IsInfiniteStream": {
+            "type": "boolean"
+          },
+          "UseMostCompatibleTranscodingProfile": {
+            "type": "boolean",
+            "default": false
+          },
+          "RequiresOpening": {
+            "type": "boolean"
+          },
+          "OpenToken": {
+            "type": "string",
+            "nullable": true
+          },
+          "RequiresClosing": {
+            "type": "boolean"
+          },
+          "LiveStreamId": {
+            "type": "string",
+            "nullable": true
+          },
+          "BufferMs": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "RequiresLooping": {
+            "type": "boolean"
+          },
+          "SupportsProbing": {
+            "type": "boolean"
+          },
+          "VideoType": {
+            "enum": [
+              "VideoFile",
+              "Iso",
+              "Dvd",
+              "BluRay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/VideoType"
+              }
+            ],
+            "nullable": true
+          },
+          "IsoType": {
+            "enum": [
+              "Dvd",
+              "BluRay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/IsoType"
+              }
+            ],
+            "nullable": true
+          },
+          "Video3DFormat": {
+            "enum": [
+              "HalfSideBySide",
+              "FullSideBySide",
+              "FullTopAndBottom",
+              "HalfTopAndBottom",
+              "MVC"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/Video3DFormat"
+              }
+            ],
+            "nullable": true
+          },
+          "MediaStreams": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaStream"
+            },
+            "nullable": true
+          },
+          "MediaAttachments": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaAttachment"
+            },
+            "nullable": true
+          },
+          "Formats": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "Bitrate": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "FallbackMaxStreamingBitrate": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "Timestamp": {
+            "enum": [
+              "None",
+              "Zero",
+              "Valid"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TransportStreamTimestamp"
+              }
+            ],
+            "nullable": true
+          },
+          "RequiredHttpHeaders": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "nullable": true
+          },
+          "TranscodingUrl": {
+            "type": "string",
+            "nullable": true
+          },
+          "TranscodingSubProtocol": {
+            "enum": [
+              "http",
+              "hls"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaStreamProtocol"
+              }
+            ],
+            "description": "Media streaming protocol.\r\nLowercase for backwards compatibility."
+          },
+          "TranscodingContainer": {
+            "type": "string",
+            "nullable": true
+          },
+          "AnalyzeDurationMs": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "DefaultAudioStreamIndex": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "DefaultSubtitleStreamIndex": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "HasSegments": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "MediaSourceType": {
+        "enum": [
+          "Default",
+          "Grouping",
+          "Placeholder"
+        ],
+        "type": "string"
+      },
+      "MediaStream": {
+        "type": "object",
+        "properties": {
+          "Codec": {
+            "type": "string",
+            "description": "Gets or sets the codec.",
+            "nullable": true
+          },
+          "CodecTag": {
+            "type": "string",
+            "description": "Gets or sets the codec tag.",
+            "nullable": true
+          },
+          "Language": {
+            "type": "string",
+            "description": "Gets or sets the language.",
+            "nullable": true
+          },
+          "ColorRange": {
+            "type": "string",
+            "description": "Gets or sets the color range.",
+            "nullable": true
+          },
+          "ColorSpace": {
+            "type": "string",
+            "description": "Gets or sets the color space.",
+            "nullable": true
+          },
+          "ColorTransfer": {
+            "type": "string",
+            "description": "Gets or sets the color transfer.",
+            "nullable": true
+          },
+          "ColorPrimaries": {
+            "type": "string",
+            "description": "Gets or sets the color primaries.",
+            "nullable": true
+          },
+          "DvVersionMajor": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision version major.",
+            "format": "int32",
+            "nullable": true
+          },
+          "DvVersionMinor": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision version minor.",
+            "format": "int32",
+            "nullable": true
+          },
+          "DvProfile": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision profile.",
+            "format": "int32",
+            "nullable": true
+          },
+          "DvLevel": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision level.",
+            "format": "int32",
+            "nullable": true
+          },
+          "RpuPresentFlag": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision rpu present flag.",
+            "format": "int32",
+            "nullable": true
+          },
+          "ElPresentFlag": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision el present flag.",
+            "format": "int32",
+            "nullable": true
+          },
+          "BlPresentFlag": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision bl present flag.",
+            "format": "int32",
+            "nullable": true
+          },
+          "DvBlSignalCompatibilityId": {
+            "type": "integer",
+            "description": "Gets or sets the Dolby Vision bl signal compatibility id.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Rotation": {
+            "type": "integer",
+            "description": "Gets or sets the Rotation in degrees.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Comment": {
+            "type": "string",
+            "description": "Gets or sets the comment.",
+            "nullable": true
+          },
+          "TimeBase": {
+            "type": "string",
+            "description": "Gets or sets the time base.",
+            "nullable": true
+          },
+          "CodecTimeBase": {
+            "type": "string",
+            "description": "Gets or sets the codec time base.",
+            "nullable": true
+          },
+          "Title": {
+            "type": "string",
+            "description": "Gets or sets the title.",
+            "nullable": true
+          },
+          "VideoRange": {
+            "enum": [
+              "Unknown",
+              "SDR",
+              "HDR"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/VideoRange"
+              }
+            ],
+            "description": "An enum representing video ranges.",
+            "readOnly": true
+          },
+          "VideoRangeType": {
+            "enum": [
+              "Unknown",
+              "SDR",
+              "HDR10",
+              "HLG",
+              "DOVI",
+              "DOVIWithHDR10",
+              "DOVIWithHLG",
+              "DOVIWithSDR",
+              "HDR10Plus"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/VideoRangeType"
+              }
+            ],
+            "description": "An enum representing types of video ranges.",
+            "readOnly": true
+          },
+          "VideoDoViTitle": {
+            "type": "string",
+            "description": "Gets the video dovi title.",
+            "nullable": true,
+            "readOnly": true
+          },
+          "AudioSpatialFormat": {
+            "enum": [
+              "None",
+              "DolbyAtmos",
+              "DTSX"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/AudioSpatialFormat"
+              }
+            ],
+            "description": "An enum representing formats of spatial audio.",
+            "default": "None",
+            "readOnly": true
+          },
+          "LocalizedUndefined": {
+            "type": "string",
+            "nullable": true
+          },
+          "LocalizedDefault": {
+            "type": "string",
+            "nullable": true
+          },
+          "LocalizedForced": {
+            "type": "string",
+            "nullable": true
+          },
+          "LocalizedExternal": {
+            "type": "string",
+            "nullable": true
+          },
+          "LocalizedHearingImpaired": {
+            "type": "string",
+            "nullable": true
+          },
+          "DisplayTitle": {
+            "type": "string",
+            "nullable": true,
+            "readOnly": true
+          },
+          "NalLengthSize": {
+            "type": "string",
+            "nullable": true
+          },
+          "IsInterlaced": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is interlaced."
+          },
+          "IsAVC": {
+            "type": "boolean",
+            "nullable": true
+          },
+          "ChannelLayout": {
+            "type": "string",
+            "description": "Gets or sets the channel layout.",
+            "nullable": true
+          },
+          "BitRate": {
+            "type": "integer",
+            "description": "Gets or sets the bit rate.",
+            "format": "int32",
+            "nullable": true
+          },
+          "BitDepth": {
+            "type": "integer",
+            "description": "Gets or sets the bit depth.",
+            "format": "int32",
+            "nullable": true
+          },
+          "RefFrames": {
+            "type": "integer",
+            "description": "Gets or sets the reference frames.",
+            "format": "int32",
+            "nullable": true
+          },
+          "PacketLength": {
+            "type": "integer",
+            "description": "Gets or sets the length of the packet.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Channels": {
+            "type": "integer",
+            "description": "Gets or sets the channels.",
+            "format": "int32",
+            "nullable": true
+          },
+          "SampleRate": {
+            "type": "integer",
+            "description": "Gets or sets the sample rate.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IsDefault": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is default."
+          },
+          "IsForced": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is forced."
+          },
+          "IsHearingImpaired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is for the hearing impaired."
+          },
+          "Height": {
+            "type": "integer",
+            "description": "Gets or sets the height.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Width": {
+            "type": "integer",
+            "description": "Gets or sets the width.",
+            "format": "int32",
+            "nullable": true
+          },
+          "AverageFrameRate": {
+            "type": "number",
+            "description": "Gets or sets the average frame rate.",
+            "format": "float",
+            "nullable": true
+          },
+          "RealFrameRate": {
+            "type": "number",
+            "description": "Gets or sets the real frame rate.",
+            "format": "float",
+            "nullable": true
+          },
+          "ReferenceFrameRate": {
+            "type": "number",
+            "description": "Gets the framerate used as reference.\r\nPrefer AverageFrameRate, if that is null or an unrealistic value\r\nthen fallback to RealFrameRate.",
+            "format": "float",
+            "nullable": true,
+            "readOnly": true
+          },
+          "Profile": {
+            "type": "string",
+            "description": "Gets or sets the profile.",
+            "nullable": true
+          },
+          "Type": {
+            "enum": [
+              "Audio",
+              "Video",
+              "Subtitle",
+              "EmbeddedImage",
+              "Data",
+              "Lyric"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaStreamType"
+              }
+            ],
+            "description": "Gets or sets the type."
+          },
+          "AspectRatio": {
+            "type": "string",
+            "description": "Gets or sets the aspect ratio.",
+            "nullable": true
+          },
+          "Index": {
+            "type": "integer",
+            "description": "Gets or sets the index.",
+            "format": "int32"
+          },
+          "Score": {
+            "type": "integer",
+            "description": "Gets or sets the score.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IsExternal": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is external."
+          },
+          "DeliveryMethod": {
+            "enum": [
+              "Encode",
+              "Embed",
+              "External",
+              "Hls",
+              "Drop"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              }
+            ],
+            "description": "Gets or sets the method.",
+            "nullable": true
+          },
+          "DeliveryUrl": {
+            "type": "string",
+            "description": "Gets or sets the delivery URL.",
+            "nullable": true
+          },
+          "IsExternalUrl": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is external URL.",
+            "nullable": true
+          },
+          "IsTextSubtitleStream": {
+            "type": "boolean",
+            "readOnly": true
+          },
+          "SupportsExternalStream": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [supports external stream]."
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the filename.",
+            "nullable": true
+          },
+          "PixelFormat": {
+            "type": "string",
+            "description": "Gets or sets the pixel format.",
+            "nullable": true
+          },
+          "Level": {
+            "type": "number",
+            "description": "Gets or sets the level.",
+            "format": "double",
+            "nullable": true
+          },
+          "IsAnamorphic": {
+            "type": "boolean",
+            "description": "Gets or sets whether this instance is anamorphic.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class MediaStream."
+      },
+      "MediaStreamProtocol": {
+        "enum": [
+          "http",
+          "hls"
+        ],
+        "type": "string",
+        "description": "Media streaming protocol.\r\nLowercase for backwards compatibility."
+      },
+      "MediaStreamType": {
+        "enum": [
+          "Audio",
+          "Video",
+          "Subtitle",
+          "EmbeddedImage",
+          "Data",
+          "Lyric"
+        ],
+        "type": "string",
+        "description": "Enum MediaStreamType."
+      },
+      "MediaType": {
+        "enum": [
+          "Unknown",
+          "Video",
+          "Audio",
+          "Photo",
+          "Book"
+        ],
+        "type": "string",
+        "description": "Media types."
+      },
+      "MediaUpdateInfoDto": {
+        "type": "object",
+        "properties": {
+          "Updates": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaUpdateInfoPathDto"
+            },
+            "description": "Gets or sets the list of updates."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Media Update Info Dto."
+      },
+      "MediaUpdateInfoPathDto": {
+        "type": "object",
+        "properties": {
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets media path.",
+            "nullable": true
+          },
+          "UpdateType": {
+            "type": "string",
+            "description": "Gets or sets media update type.\r\nCreated, Modified, Deleted.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "The media update info path."
+      },
+      "MediaUrl": {
+        "type": "object",
+        "properties": {
+          "Url": {
+            "type": "string",
+            "nullable": true
+          },
+          "Name": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "MessageCommand": {
+        "required": [
+          "Text"
+        ],
+        "type": "object",
+        "properties": {
+          "Header": {
+            "type": "string",
+            "nullable": true
+          },
+          "Text": {
+            "type": "string"
+          },
+          "TimeoutMs": {
+            "type": "integer",
+            "format": "int64",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "MetadataConfiguration": {
+        "type": "object",
+        "properties": {
+          "UseFileCreationTimeForDateAdded": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "MetadataEditorInfo": {
+        "type": "object",
+        "properties": {
+          "ParentalRatingOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ParentalRating"
+            }
+          },
+          "Countries": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/CountryInfo"
+            }
+          },
+          "Cultures": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/CultureDto"
+            }
+          },
+          "ExternalIdInfos": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ExternalIdInfo"
+            }
+          },
+          "ContentType": {
+            "enum": [
+              "unknown",
+              "movies",
+              "tvshows",
+              "music",
+              "musicvideos",
+              "trailers",
+              "homevideos",
+              "boxsets",
+              "books",
+              "photos",
+              "livetv",
+              "playlists",
+              "folders"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/CollectionType"
+              }
+            ],
+            "nullable": true
+          },
+          "ContentTypeOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/NameValuePair"
+            }
+          }
+        },
+        "additionalProperties": false
+      },
+      "MetadataField": {
+        "enum": [
+          "Cast",
+          "Genres",
+          "ProductionLocations",
+          "Studios",
+          "Tags",
+          "Name",
+          "Overview",
+          "Runtime",
+          "OfficialRating"
+        ],
+        "type": "string",
+        "description": "Enum MetadataFields."
+      },
+      "MetadataOptions": {
+        "type": "object",
+        "properties": {
+          "ItemType": {
+            "type": "string",
+            "nullable": true
+          },
+          "DisabledMetadataSavers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "LocalMetadataReaderOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "DisabledMetadataFetchers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "MetadataFetcherOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "DisabledImageFetchers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "ImageFetcherOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class MetadataOptions."
+      },
+      "MetadataRefreshMode": {
+        "enum": [
+          "None",
+          "ValidationOnly",
+          "Default",
+          "FullRefresh"
+        ],
+        "type": "string"
+      },
+      "MovePlaylistItemRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playlist identifier of the item.",
+            "format": "uuid"
+          },
+          "NewIndex": {
+            "type": "integer",
+            "description": "Gets or sets the new position.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class MovePlaylistItemRequestDto."
+      },
+      "MovieInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "MovieInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MovieInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "MusicVideoInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          },
+          "Artists": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "MusicVideoInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MusicVideoInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "NameGuidPair": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false
+      },
+      "NameIdPair": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the identifier.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "NameValuePair": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Value": {
+            "type": "string",
+            "description": "Gets or sets the value.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "NetworkConfiguration": {
+        "type": "object",
+        "properties": {
+          "BaseUrl": {
+            "type": "string",
+            "description": "Gets or sets a value used to specify the URL prefix that your Jellyfin instance can be accessed at."
+          },
+          "EnableHttps": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to use HTTPS."
+          },
+          "RequireHttps": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the server should force connections over HTTPS."
+          },
+          "CertificatePath": {
+            "type": "string",
+            "description": "Gets or sets the filesystem path of an X.509 certificate to use for SSL."
+          },
+          "CertificatePassword": {
+            "type": "string",
+            "description": "Gets or sets the password required to access the X.509 certificate data in the file specified by MediaBrowser.Common.Net.NetworkConfiguration.CertificatePath."
+          },
+          "InternalHttpPort": {
+            "type": "integer",
+            "description": "Gets or sets the internal HTTP server port.",
+            "format": "int32"
+          },
+          "InternalHttpsPort": {
+            "type": "integer",
+            "description": "Gets or sets the internal HTTPS server port.",
+            "format": "int32"
+          },
+          "PublicHttpPort": {
+            "type": "integer",
+            "description": "Gets or sets the public HTTP port.",
+            "format": "int32"
+          },
+          "PublicHttpsPort": {
+            "type": "integer",
+            "description": "Gets or sets the public HTTPS port.",
+            "format": "int32"
+          },
+          "AutoDiscovery": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether Autodiscovery is enabled."
+          },
+          "EnableUPnP": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable automatic port forwarding."
+          },
+          "EnableIPv4": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether IPv6 is enabled."
+          },
+          "EnableIPv6": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether IPv6 is enabled."
+          },
+          "EnableRemoteAccess": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether access from outside of the LAN is permitted."
+          },
+          "LocalNetworkSubnets": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the subnets that are deemed to make up the LAN."
+          },
+          "LocalNetworkAddresses": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the interface addresses which Jellyfin will bind to. If empty, all interfaces will be used."
+          },
+          "KnownProxies": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the known proxies."
+          },
+          "IgnoreVirtualInterfaces": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether address names that match MediaBrowser.Common.Net.NetworkConfiguration.VirtualInterfaceNames should be ignored for the purposes of binding."
+          },
+          "VirtualInterfaceNames": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets a value indicating the interface name prefixes that should be ignored. The list can be comma separated and values are case-insensitive. <seealso cref=\"P:MediaBrowser.Common.Net.NetworkConfiguration.IgnoreVirtualInterfaces\" />."
+          },
+          "EnablePublishedServerUriByRequest": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the published server uri is based on information in HTTP requests."
+          },
+          "PublishedServerUriBySubnet": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the PublishedServerUriBySubnet\r\nGets or sets PublishedServerUri to advertise for specific subnets."
+          },
+          "RemoteIPFilter": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the filter for remote IP connectivity. Used in conjunction with <seealso cref=\"P:MediaBrowser.Common.Net.NetworkConfiguration.IsRemoteIPFilterBlacklist\" />."
+          },
+          "IsRemoteIPFilterBlacklist": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether <seealso cref=\"P:MediaBrowser.Common.Net.NetworkConfiguration.RemoteIPFilter\" /> contains a blacklist or a whitelist. Default is a whitelist."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Common.Net.NetworkConfiguration."
+      },
+      "NewGroupRequestDto": {
+        "type": "object",
+        "properties": {
+          "GroupName": {
+            "type": "string",
+            "description": "Gets or sets the group name."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class NewGroupRequestDto."
+      },
+      "NextItemRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playing item identifier.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class NextItemRequestDto."
       },
       "OpenLiveStreamDto": {
         "type": "object",
@@ -52101,266 +51535,246 @@
             "description": "Gets or sets a value indicating whether to enale direct stream.",
             "nullable": true
           },
+          "AlwaysBurnInSubtitleWhenTranscoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether always burn in subtitles when transcoding.",
+            "nullable": true
+          },
           "DeviceProfile": {
-            "$ref": "#/components/schemas/DeviceProfile"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DeviceProfile"
+              }
+            ],
+            "description": "Gets or sets the device profile.",
+            "nullable": true
           },
           "DirectPlayProtocols": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/MediaProtocol"
             },
-            "description": "Gets or sets the device play protocols.",
-            "nullable": true
+            "description": "Gets or sets the device play protocols."
           }
         },
         "additionalProperties": false,
         "description": "Open live stream dto."
       },
-      "LiveStreamResponse": {
+      "OutboundKeepAliveMessage": {
         "type": "object",
         "properties": {
-          "MediaSource": {
-            "$ref": "#/components/schemas/MediaSourceInfo"
-          }
-        },
-        "additionalProperties": false
-      },
-      "RecommendationType": {
-        "enum": [
-          "SimilarToRecentlyPlayed",
-          "SimilarToLikedItem",
-          "HasDirectorFromRecentlyPlayed",
-          "HasActorFromRecentlyPlayed",
-          "HasLikedDirector",
-          "HasLikedActor"
-        ],
-        "type": "string"
-      },
-      "RecommendationDto": {
-        "type": "object",
-        "properties": {
-          "Items": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/BaseItemDto"
-            },
-            "nullable": true
-          },
-          "RecommendationType": {
-            "$ref": "#/components/schemas/RecommendationType"
-          },
-          "BaselineItemName": {
-            "type": "string",
-            "nullable": true
-          },
-          "CategoryId": {
+          "MessageId": {
             "type": "string",
+            "description": "Gets or sets the message id.",
             "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "KeepAlive",
+            "readOnly": true
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Keep alive websocket messages."
       },
-      "NotificationLevel": {
-        "enum": [
-          "Normal",
-          "Warning",
-          "Error"
+      "OutboundWebSocketMessage": {
+        "type": "object",
+        "oneOf": [
+          {
+            "$ref": "#/components/schemas/ActivityLogEntryMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ForceKeepAliveMessage"
+          },
+          {
+            "$ref": "#/components/schemas/GeneralCommandMessage"
+          },
+          {
+            "$ref": "#/components/schemas/LibraryChangedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/OutboundKeepAliveMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PlayMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PlaystateMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PluginInstallationCancelledMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PluginInstallationCompletedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PluginInstallationFailedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PluginInstallingMessage"
+          },
+          {
+            "$ref": "#/components/schemas/PluginUninstalledMessage"
+          },
+          {
+            "$ref": "#/components/schemas/RefreshProgressMessage"
+          },
+          {
+            "$ref": "#/components/schemas/RestartRequiredMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ScheduledTaskEndedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ScheduledTasksInfoMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SeriesTimerCancelledMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SeriesTimerCreatedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ServerRestartingMessage"
+          },
+          {
+            "$ref": "#/components/schemas/ServerShuttingDownMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SessionsMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SyncPlayCommandMessage"
+          },
+          {
+            "$ref": "#/components/schemas/SyncPlayGroupUpdateCommandMessage"
+          },
+          {
+            "$ref": "#/components/schemas/TimerCancelledMessage"
+          },
+          {
+            "$ref": "#/components/schemas/TimerCreatedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/UserDataChangedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/UserDeletedMessage"
+          },
+          {
+            "$ref": "#/components/schemas/UserUpdatedMessage"
+          }
         ],
-        "type": "string"
-      },
-      "NotificationDto": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the notification ID. Defaults to an empty string.",
-            "nullable": true
-          },
-          "UserId": {
-            "type": "string",
-            "description": "Gets or sets the notification's user ID. Defaults to an empty string.",
-            "nullable": true
-          },
-          "Date": {
-            "type": "string",
-            "description": "Gets or sets the notification date.",
-            "format": "date-time"
-          },
-          "IsRead": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the notification has been read. Defaults to false."
-          },
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the notification's name. Defaults to an empty string.",
-            "nullable": true
-          },
-          "Description": {
-            "type": "string",
-            "description": "Gets or sets the notification's description. Defaults to an empty string.",
-            "nullable": true
-          },
-          "Url": {
-            "type": "string",
-            "description": "Gets or sets the notification's URL. Defaults to an empty string.",
-            "nullable": true
-          },
-          "Level": {
-            "$ref": "#/components/schemas/NotificationLevel"
+        "description": "Represents the list of possible outbound websocket types",
+        "discriminator": {
+          "propertyName": "MessageType",
+          "mapping": {
+            "ActivityLogEntry": "#/components/schemas/ActivityLogEntryMessage",
+            "ForceKeepAlive": "#/components/schemas/ForceKeepAliveMessage",
+            "GeneralCommand": "#/components/schemas/GeneralCommandMessage",
+            "LibraryChanged": "#/components/schemas/LibraryChangedMessage",
+            "KeepAlive": "#/components/schemas/OutboundKeepAliveMessage",
+            "Play": "#/components/schemas/PlayMessage",
+            "Playstate": "#/components/schemas/PlaystateMessage",
+            "PackageInstallationCancelled": "#/components/schemas/PluginInstallationCancelledMessage",
+            "PackageInstallationCompleted": "#/components/schemas/PluginInstallationCompletedMessage",
+            "PackageInstallationFailed": "#/components/schemas/PluginInstallationFailedMessage",
+            "PackageInstalling": "#/components/schemas/PluginInstallingMessage",
+            "PackageUninstalled": "#/components/schemas/PluginUninstalledMessage",
+            "RefreshProgress": "#/components/schemas/RefreshProgressMessage",
+            "RestartRequired": "#/components/schemas/RestartRequiredMessage",
+            "ScheduledTaskEnded": "#/components/schemas/ScheduledTaskEndedMessage",
+            "ScheduledTasksInfo": "#/components/schemas/ScheduledTasksInfoMessage",
+            "SeriesTimerCancelled": "#/components/schemas/SeriesTimerCancelledMessage",
+            "SeriesTimerCreated": "#/components/schemas/SeriesTimerCreatedMessage",
+            "ServerRestarting": "#/components/schemas/ServerRestartingMessage",
+            "ServerShuttingDown": "#/components/schemas/ServerShuttingDownMessage",
+            "Sessions": "#/components/schemas/SessionsMessage",
+            "SyncPlayCommand": "#/components/schemas/SyncPlayCommandMessage",
+            "SyncPlayGroupUpdate": "#/components/schemas/SyncPlayGroupUpdateCommandMessage",
+            "TimerCancelled": "#/components/schemas/TimerCancelledMessage",
+            "TimerCreated": "#/components/schemas/TimerCreatedMessage",
+            "UserDataChanged": "#/components/schemas/UserDataChangedMessage",
+            "UserDeleted": "#/components/schemas/UserDeletedMessage",
+            "UserUpdated": "#/components/schemas/UserUpdatedMessage"
           }
-        },
-        "additionalProperties": false,
-        "description": "The notification DTO."
-      },
-      "NotificationResultDto": {
-        "type": "object",
-        "properties": {
-          "Notifications": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/NotificationDto"
-            },
-            "description": "Gets or sets the current page of notifications.",
-            "nullable": true
-          },
-          "TotalRecordCount": {
-            "type": "integer",
-            "description": "Gets or sets the total number of notifications.",
-            "format": "int32"
-          }
-        },
-        "additionalProperties": false,
-        "description": "A list of notifications with the total record count for pagination."
-      },
-      "NotificationsSummaryDto": {
-        "type": "object",
-        "properties": {
-          "UnreadCount": {
-            "type": "integer",
-            "description": "Gets or sets the number of unread notifications.",
-            "format": "int32"
-          },
-          "MaxUnreadNotificationLevel": {
-            "$ref": "#/components/schemas/NotificationLevel"
-          }
-        },
-        "additionalProperties": false,
-        "description": "The notification summary DTO."
-      },
-      "NotificationTypeInfo": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "type": "string",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "Enabled": {
-            "type": "boolean"
-          },
-          "Category": {
-            "type": "string",
-            "nullable": true
-          },
-          "IsBasedOnUserEvent": {
-            "type": "boolean"
-          }
-        },
-        "additionalProperties": false
-      },
-      "VersionInfo": {
-        "type": "object",
-        "properties": {
-          "version": {
-            "type": "string",
-            "description": "Gets or sets the version.",
-            "nullable": true
-          },
-          "VersionNumber": {
-            "$ref": "#/components/schemas/Version"
-          },
-          "changelog": {
-            "type": "string",
-            "description": "Gets or sets the changelog for this version.",
-            "nullable": true
-          },
-          "targetAbi": {
-            "type": "string",
-            "description": "Gets or sets the ABI that this version was built against.",
-            "nullable": true
-          },
-          "sourceUrl": {
-            "type": "string",
-            "description": "Gets or sets the source URL.",
-            "nullable": true
-          },
-          "checksum": {
-            "type": "string",
-            "description": "Gets or sets a checksum for the binary.",
-            "nullable": true
-          },
-          "timestamp": {
-            "type": "string",
-            "description": "Gets or sets a timestamp of when the binary was built.",
-            "nullable": true
-          },
-          "repositoryName": {
-            "type": "string",
-            "description": "Gets or sets the repository name.",
-            "nullable": true
-          },
-          "repositoryUrl": {
-            "type": "string",
-            "description": "Gets or sets the repository url.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the MediaBrowser.Model.Updates.VersionInfo class."
+        }
       },
       "PackageInfo": {
         "type": "object",
         "properties": {
           "name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "description": {
             "type": "string",
-            "description": "Gets or sets a long description of the plugin containing features or helpful explanations.",
-            "nullable": true
+            "description": "Gets or sets a long description of the plugin containing features or helpful explanations."
           },
           "overview": {
             "type": "string",
-            "description": "Gets or sets a short overview of what the plugin does.",
-            "nullable": true
+            "description": "Gets or sets a short overview of what the plugin does."
           },
           "owner": {
             "type": "string",
-            "description": "Gets or sets the owner.",
-            "nullable": true
+            "description": "Gets or sets the owner."
           },
           "category": {
             "type": "string",
-            "description": "Gets or sets the category.",
-            "nullable": true
+            "description": "Gets or sets the category."
           },
           "guid": {
             "type": "string",
             "description": "Gets or sets the guid of the assembly associated with this plugin.\r\nThis is used to identify the proper item for automatic updates.",
-            "nullable": true
+            "format": "uuid"
           },
           "versions": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/VersionInfo"
             },
-            "description": "Gets or sets the versions.",
-            "nullable": true
+            "description": "Gets or sets the versions."
           },
           "imageUrl": {
             "type": "string",
@@ -52371,180 +51785,342 @@
         "additionalProperties": false,
         "description": "Class PackageInfo."
       },
-      "CreatePlaylistDto": {
+      "ParentalRating": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name of the new playlist.",
+            "description": "Gets or sets the name.",
             "nullable": true
           },
-          "Ids": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets item ids to add to the playlist.",
-            "nullable": true
-          },
-          "UserId": {
-            "type": "string",
-            "description": "Gets or sets the user id.",
-            "format": "uuid",
-            "nullable": true
-          },
-          "MediaType": {
-            "type": "string",
-            "description": "Gets or sets the media type.",
+          "Value": {
+            "type": "integer",
+            "description": "Gets or sets the value.",
+            "format": "int32",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Create new playlist dto."
+        "description": "Class ParentalRating."
       },
-      "PlaylistCreationResult": {
+      "PathSubstitution": {
         "type": "object",
         "properties": {
-          "Id": {
+          "From": {
             "type": "string",
-            "nullable": true,
-            "readOnly": true
+            "description": "Gets or sets the value to substitute."
+          },
+          "To": {
+            "type": "string",
+            "description": "Gets or sets the value to substitution with."
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Model.Configuration.PathSubstitution."
       },
-      "PlayMethod": {
+      "PersonKind": {
         "enum": [
-          "Transcode",
-          "DirectStream",
-          "DirectPlay"
+          "Unknown",
+          "Actor",
+          "Director",
+          "Composer",
+          "Writer",
+          "GuestStar",
+          "Producer",
+          "Conductor",
+          "Lyricist",
+          "Arranger",
+          "Engineer",
+          "Mixer",
+          "Remixer",
+          "Creator",
+          "Artist",
+          "AlbumArtist",
+          "Author",
+          "Illustrator",
+          "Penciller",
+          "Inker",
+          "Colorist",
+          "Letterer",
+          "CoverArtist",
+          "Editor",
+          "Translator"
         ],
-        "type": "string"
+        "type": "string",
+        "description": "The person kind."
       },
-      "RepeatMode": {
-        "enum": [
-          "RepeatNone",
-          "RepeatAll",
-          "RepeatOne"
-        ],
-        "type": "string"
-      },
-      "QueueItem": {
+      "PersonLookupInfo": {
         "type": "object",
         "properties": {
-          "Id": {
-            "type": "string",
-            "format": "uuid"
-          },
-          "PlaylistItemId": {
+          "Name": {
             "type": "string",
+            "description": "Gets or sets the name.",
             "nullable": true
+          },
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
           }
         },
         "additionalProperties": false
       },
-      "PlaybackStartInfo": {
+      "PersonLookupInfoRemoteSearchQuery": {
         "type": "object",
         "properties": {
-          "CanSeek": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance can seek."
-          },
-          "Item": {
-            "$ref": "#/components/schemas/BaseItemDto"
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PersonLookupInfo"
+              }
+            ],
+            "nullable": true
           },
           "ItemId": {
             "type": "string",
-            "description": "Gets or sets the item identifier.",
             "format": "uuid"
           },
-          "SessionId": {
+          "SearchProviderName": {
             "type": "string",
-            "description": "Gets or sets the session id.",
+            "description": "Gets or sets the provider name to search within if set.",
             "nullable": true
           },
-          "MediaSourceId": {
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "PingRequestDto": {
+        "type": "object",
+        "properties": {
+          "Ping": {
+            "type": "integer",
+            "description": "Gets or sets the ping time.",
+            "format": "int64"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PingRequestDto."
+      },
+      "PinRedeemResult": {
+        "type": "object",
+        "properties": {
+          "Success": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Users.PinRedeemResult is success."
+          },
+          "UsersReset": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the users reset."
+          }
+        },
+        "additionalProperties": false
+      },
+      "PlayAccess": {
+        "enum": [
+          "Full",
+          "None"
+        ],
+        "type": "string"
+      },
+      "PlaybackErrorCode": {
+        "enum": [
+          "NotAllowed",
+          "NoCompatibleStream",
+          "RateLimitExceeded"
+        ],
+        "type": "string"
+      },
+      "PlaybackInfoDto": {
+        "type": "object",
+        "properties": {
+          "UserId": {
             "type": "string",
-            "description": "Gets or sets the media version identifier.",
+            "description": "Gets or sets the playback userId.",
+            "format": "uuid",
+            "nullable": true
+          },
+          "MaxStreamingBitrate": {
+            "type": "integer",
+            "description": "Gets or sets the max streaming bitrate.",
+            "format": "int32",
+            "nullable": true
+          },
+          "StartTimeTicks": {
+            "type": "integer",
+            "description": "Gets or sets the start time in ticks.",
+            "format": "int64",
             "nullable": true
           },
           "AudioStreamIndex": {
             "type": "integer",
-            "description": "Gets or sets the index of the audio stream.",
+            "description": "Gets or sets the audio stream index.",
             "format": "int32",
             "nullable": true
           },
           "SubtitleStreamIndex": {
             "type": "integer",
-            "description": "Gets or sets the index of the subtitle stream.",
+            "description": "Gets or sets the subtitle stream index.",
             "format": "int32",
             "nullable": true
           },
-          "IsPaused": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is paused."
-          },
-          "IsMuted": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is muted."
-          },
-          "PositionTicks": {
+          "MaxAudioChannels": {
             "type": "integer",
-            "description": "Gets or sets the position ticks.",
-            "format": "int64",
-            "nullable": true
-          },
-          "PlaybackStartTimeTicks": {
-            "type": "integer",
-            "format": "int64",
-            "nullable": true
-          },
-          "VolumeLevel": {
-            "type": "integer",
-            "description": "Gets or sets the volume level.",
+            "description": "Gets or sets the max audio channels.",
             "format": "int32",
             "nullable": true
           },
-          "Brightness": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "AspectRatio": {
+          "MediaSourceId": {
             "type": "string",
+            "description": "Gets or sets the media source id.",
             "nullable": true
           },
-          "PlayMethod": {
-            "$ref": "#/components/schemas/PlayMethod"
-          },
           "LiveStreamId": {
             "type": "string",
-            "description": "Gets or sets the live stream identifier.",
+            "description": "Gets or sets the live stream id.",
             "nullable": true
           },
+          "DeviceProfile": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DeviceProfile"
+              }
+            ],
+            "description": "Gets or sets the device profile.",
+            "nullable": true
+          },
+          "EnableDirectPlay": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable direct play.",
+            "nullable": true
+          },
+          "EnableDirectStream": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable direct stream.",
+            "nullable": true
+          },
+          "EnableTranscoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable transcoding.",
+            "nullable": true
+          },
+          "AllowVideoStreamCopy": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable video stream copy.",
+            "nullable": true
+          },
+          "AllowAudioStreamCopy": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to allow audio stream copy.",
+            "nullable": true
+          },
+          "AutoOpenLiveStream": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to auto open the live stream.",
+            "nullable": true
+          },
+          "AlwaysBurnInSubtitleWhenTranscoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether always burn in subtitles when transcoding.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Plabyback info dto."
+      },
+      "PlaybackInfoResponse": {
+        "type": "object",
+        "properties": {
+          "MediaSources": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MediaSourceInfo"
+            },
+            "description": "Gets or sets the media sources."
+          },
           "PlaySessionId": {
             "type": "string",
             "description": "Gets or sets the play session identifier.",
             "nullable": true
           },
-          "RepeatMode": {
-            "$ref": "#/components/schemas/RepeatMode"
-          },
-          "NowPlayingQueue": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/QueueItem"
-            },
-            "nullable": true
-          },
-          "PlaylistItemId": {
-            "type": "string",
+          "ErrorCode": {
+            "enum": [
+              "NotAllowed",
+              "NoCompatibleStream",
+              "RateLimitExceeded"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaybackErrorCode"
+              }
+            ],
+            "description": "Gets or sets the error code.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Class PlaybackStartInfo."
+        "description": "Class PlaybackInfoResponse."
+      },
+      "PlaybackOrder": {
+        "enum": [
+          "Default",
+          "Shuffle"
+        ],
+        "type": "string",
+        "description": "Enum PlaybackOrder."
       },
       "PlaybackProgressInfo": {
         "type": "object",
@@ -52554,7 +52130,13 @@
             "description": "Gets or sets a value indicating whether this instance can seek."
           },
           "Item": {
-            "$ref": "#/components/schemas/BaseItemDto"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the item.",
+            "nullable": true
           },
           "ItemId": {
             "type": "string",
@@ -52618,7 +52200,17 @@
             "nullable": true
           },
           "PlayMethod": {
-            "$ref": "#/components/schemas/PlayMethod"
+            "enum": [
+              "Transcode",
+              "DirectStream",
+              "DirectPlay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayMethod"
+              }
+            ],
+            "description": "Gets or sets the play method."
           },
           "LiveStreamId": {
             "type": "string",
@@ -52631,7 +52223,29 @@
             "nullable": true
           },
           "RepeatMode": {
-            "$ref": "#/components/schemas/RepeatMode"
+            "enum": [
+              "RepeatNone",
+              "RepeatAll",
+              "RepeatOne"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RepeatMode"
+              }
+            ],
+            "description": "Gets or sets the repeat mode."
+          },
+          "PlaybackOrder": {
+            "enum": [
+              "Default",
+              "Shuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaybackOrder"
+              }
+            ],
+            "description": "Gets or sets the playback order."
           },
           "NowPlayingQueue": {
             "type": "array",
@@ -52648,11 +52262,180 @@
         "additionalProperties": false,
         "description": "Class PlaybackProgressInfo."
       },
+      "PlaybackRequestType": {
+        "enum": [
+          "Play",
+          "SetPlaylistItem",
+          "RemoveFromPlaylist",
+          "MovePlaylistItem",
+          "Queue",
+          "Unpause",
+          "Pause",
+          "Stop",
+          "Seek",
+          "Buffer",
+          "Ready",
+          "NextItem",
+          "PreviousItem",
+          "SetRepeatMode",
+          "SetShuffleMode",
+          "Ping",
+          "IgnoreWait"
+        ],
+        "type": "string",
+        "description": "Enum PlaybackRequestType."
+      },
+      "PlaybackStartInfo": {
+        "type": "object",
+        "properties": {
+          "CanSeek": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance can seek."
+          },
+          "Item": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the item.",
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "description": "Gets or sets the item identifier.",
+            "format": "uuid"
+          },
+          "SessionId": {
+            "type": "string",
+            "description": "Gets or sets the session id.",
+            "nullable": true
+          },
+          "MediaSourceId": {
+            "type": "string",
+            "description": "Gets or sets the media version identifier.",
+            "nullable": true
+          },
+          "AudioStreamIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the audio stream.",
+            "format": "int32",
+            "nullable": true
+          },
+          "SubtitleStreamIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the subtitle stream.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IsPaused": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is paused."
+          },
+          "IsMuted": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is muted."
+          },
+          "PositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the position ticks.",
+            "format": "int64",
+            "nullable": true
+          },
+          "PlaybackStartTimeTicks": {
+            "type": "integer",
+            "format": "int64",
+            "nullable": true
+          },
+          "VolumeLevel": {
+            "type": "integer",
+            "description": "Gets or sets the volume level.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Brightness": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "AspectRatio": {
+            "type": "string",
+            "nullable": true
+          },
+          "PlayMethod": {
+            "enum": [
+              "Transcode",
+              "DirectStream",
+              "DirectPlay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayMethod"
+              }
+            ],
+            "description": "Gets or sets the play method."
+          },
+          "LiveStreamId": {
+            "type": "string",
+            "description": "Gets or sets the live stream identifier.",
+            "nullable": true
+          },
+          "PlaySessionId": {
+            "type": "string",
+            "description": "Gets or sets the play session identifier.",
+            "nullable": true
+          },
+          "RepeatMode": {
+            "enum": [
+              "RepeatNone",
+              "RepeatAll",
+              "RepeatOne"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RepeatMode"
+              }
+            ],
+            "description": "Gets or sets the repeat mode."
+          },
+          "PlaybackOrder": {
+            "enum": [
+              "Default",
+              "Shuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaybackOrder"
+              }
+            ],
+            "description": "Gets or sets the playback order."
+          },
+          "NowPlayingQueue": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/QueueItem"
+            },
+            "nullable": true
+          },
+          "PlaylistItemId": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PlaybackStartInfo."
+      },
       "PlaybackStopInfo": {
         "type": "object",
         "properties": {
           "Item": {
-            "$ref": "#/components/schemas/BaseItemDto"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the item.",
+            "nullable": true
           },
           "ItemId": {
             "type": "string",
@@ -52708,29 +52491,583 @@
         "additionalProperties": false,
         "description": "Class PlaybackStopInfo."
       },
-      "PluginStatus": {
+      "PlayCommand": {
         "enum": [
-          "Active",
-          "Restart",
-          "Deleted",
-          "Superceded",
-          "Malfunctioned",
-          "NotSupported",
-          "Disabled"
+          "PlayNow",
+          "PlayNext",
+          "PlayLast",
+          "PlayInstantMix",
+          "PlayShuffle"
         ],
         "type": "string",
-        "description": "Plugin load status."
+        "description": "Enum PlayCommand."
+      },
+      "PlayerStateInfo": {
+        "type": "object",
+        "properties": {
+          "PositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the now playing position ticks.",
+            "format": "int64",
+            "nullable": true
+          },
+          "CanSeek": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance can seek."
+          },
+          "IsPaused": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is paused."
+          },
+          "IsMuted": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is muted."
+          },
+          "VolumeLevel": {
+            "type": "integer",
+            "description": "Gets or sets the volume level.",
+            "format": "int32",
+            "nullable": true
+          },
+          "AudioStreamIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the now playing audio stream.",
+            "format": "int32",
+            "nullable": true
+          },
+          "SubtitleStreamIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the now playing subtitle stream.",
+            "format": "int32",
+            "nullable": true
+          },
+          "MediaSourceId": {
+            "type": "string",
+            "description": "Gets or sets the now playing media version identifier.",
+            "nullable": true
+          },
+          "PlayMethod": {
+            "enum": [
+              "Transcode",
+              "DirectStream",
+              "DirectPlay"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayMethod"
+              }
+            ],
+            "description": "Gets or sets the play method.",
+            "nullable": true
+          },
+          "RepeatMode": {
+            "enum": [
+              "RepeatNone",
+              "RepeatAll",
+              "RepeatOne"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RepeatMode"
+              }
+            ],
+            "description": "Gets or sets the repeat mode."
+          },
+          "PlaybackOrder": {
+            "enum": [
+              "Default",
+              "Shuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaybackOrder"
+              }
+            ],
+            "description": "Gets or sets the playback order."
+          },
+          "LiveStreamId": {
+            "type": "string",
+            "description": "Gets or sets the now playing live stream identifier.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "PlaylistCreationResult": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string"
+          }
+        },
+        "additionalProperties": false
+      },
+      "PlaylistDto": {
+        "type": "object",
+        "properties": {
+          "OpenAccess": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the playlist is publicly readable."
+          },
+          "Shares": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/PlaylistUserPermissions"
+            },
+            "description": "Gets or sets the share permissions."
+          },
+          "ItemIds": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the item ids."
+          }
+        },
+        "additionalProperties": false,
+        "description": "DTO for playlists."
+      },
+      "PlaylistUserPermissions": {
+        "type": "object",
+        "properties": {
+          "UserId": {
+            "type": "string",
+            "description": "Gets or sets the user id.",
+            "format": "uuid"
+          },
+          "CanEdit": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the user has edit permissions."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class to hold data on user permissions for playlists."
+      },
+      "PlayMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayRequest"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "Play",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Play command websocket message."
+      },
+      "PlayMethod": {
+        "enum": [
+          "Transcode",
+          "DirectStream",
+          "DirectPlay"
+        ],
+        "type": "string"
+      },
+      "PlayQueueUpdate": {
+        "type": "object",
+        "properties": {
+          "Reason": {
+            "enum": [
+              "NewPlaylist",
+              "SetCurrentItem",
+              "RemoveItems",
+              "MoveItem",
+              "Queue",
+              "QueueNext",
+              "NextItem",
+              "PreviousItem",
+              "RepeatMode",
+              "ShuffleMode"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayQueueUpdateReason"
+              }
+            ],
+            "description": "Gets the request type that originated this update."
+          },
+          "LastUpdate": {
+            "type": "string",
+            "description": "Gets the UTC time of the last change to the playing queue.",
+            "format": "date-time"
+          },
+          "Playlist": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SyncPlayQueueItem"
+            },
+            "description": "Gets the playlist."
+          },
+          "PlayingItemIndex": {
+            "type": "integer",
+            "description": "Gets the playing item index in the playlist.",
+            "format": "int32"
+          },
+          "StartPositionTicks": {
+            "type": "integer",
+            "description": "Gets the start position ticks.",
+            "format": "int64"
+          },
+          "IsPlaying": {
+            "type": "boolean",
+            "description": "Gets a value indicating whether the current item is playing."
+          },
+          "ShuffleMode": {
+            "enum": [
+              "Sorted",
+              "Shuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupShuffleMode"
+              }
+            ],
+            "description": "Gets the shuffle mode."
+          },
+          "RepeatMode": {
+            "enum": [
+              "RepeatOne",
+              "RepeatAll",
+              "RepeatNone"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupRepeatMode"
+              }
+            ],
+            "description": "Gets the repeat mode."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PlayQueueUpdate."
+      },
+      "PlayQueueUpdateGroupUpdate": {
+        "type": "object",
+        "properties": {
+          "GroupId": {
+            "type": "string",
+            "description": "Gets the group identifier.",
+            "format": "uuid",
+            "readOnly": true
+          },
+          "Type": {
+            "enum": [
+              "UserJoined",
+              "UserLeft",
+              "GroupJoined",
+              "GroupLeft",
+              "StateUpdate",
+              "PlayQueue",
+              "NotInGroup",
+              "GroupDoesNotExist",
+              "CreateGroupDenied",
+              "JoinGroupDenied",
+              "LibraryAccessDenied"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdateType"
+              }
+            ],
+            "description": "Gets the update type."
+          },
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayQueueUpdate"
+              }
+            ],
+            "description": "Gets the update data."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class GroupUpdate."
+      },
+      "PlayQueueUpdateReason": {
+        "enum": [
+          "NewPlaylist",
+          "SetCurrentItem",
+          "RemoveItems",
+          "MoveItem",
+          "Queue",
+          "QueueNext",
+          "NextItem",
+          "PreviousItem",
+          "RepeatMode",
+          "ShuffleMode"
+        ],
+        "type": "string",
+        "description": "Enum PlayQueueUpdateReason."
+      },
+      "PlayRequest": {
+        "type": "object",
+        "properties": {
+          "ItemIds": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the item ids.",
+            "nullable": true
+          },
+          "StartPositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the start position ticks that the first item should be played at.",
+            "format": "int64",
+            "nullable": true
+          },
+          "PlayCommand": {
+            "enum": [
+              "PlayNow",
+              "PlayNext",
+              "PlayLast",
+              "PlayInstantMix",
+              "PlayShuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayCommand"
+              }
+            ],
+            "description": "Gets or sets the play command."
+          },
+          "ControllingUserId": {
+            "type": "string",
+            "description": "Gets or sets the controlling user identifier.",
+            "format": "uuid"
+          },
+          "SubtitleStreamIndex": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "AudioStreamIndex": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "MediaSourceId": {
+            "type": "string",
+            "nullable": true
+          },
+          "StartIndex": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PlayRequest."
+      },
+      "PlayRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlayingQueue": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the playing queue."
+          },
+          "PlayingItemPosition": {
+            "type": "integer",
+            "description": "Gets or sets the position of the playing item in the queue.",
+            "format": "int32"
+          },
+          "StartPositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the start position ticks.",
+            "format": "int64"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PlayRequestDto."
+      },
+      "PlaystateCommand": {
+        "enum": [
+          "Stop",
+          "Pause",
+          "Unpause",
+          "NextTrack",
+          "PreviousTrack",
+          "Seek",
+          "Rewind",
+          "FastForward",
+          "PlayPause"
+        ],
+        "type": "string",
+        "description": "Enum PlaystateCommand."
+      },
+      "PlaystateMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaystateRequest"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "Playstate",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Playstate message."
+      },
+      "PlaystateRequest": {
+        "type": "object",
+        "properties": {
+          "Command": {
+            "enum": [
+              "Stop",
+              "Pause",
+              "Unpause",
+              "NextTrack",
+              "PreviousTrack",
+              "Seek",
+              "Rewind",
+              "FastForward",
+              "PlayPause"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlaystateCommand"
+              }
+            ],
+            "description": "Enum PlaystateCommand."
+          },
+          "SeekPositionTicks": {
+            "type": "integer",
+            "format": "int64",
+            "nullable": true
+          },
+          "ControllingUserId": {
+            "type": "string",
+            "description": "Gets or sets the controlling user identifier.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
       },
       "PluginInfo": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "Version": {
-            "$ref": "#/components/schemas/Version"
+            "type": "string",
+            "description": "Gets or sets the version."
           },
           "ConfigurationFileName": {
             "type": "string",
@@ -52739,8 +53076,7 @@
           },
           "Description": {
             "type": "string",
-            "description": "Gets or sets the description.",
-            "nullable": true
+            "description": "Gets or sets the description."
           },
           "Id": {
             "type": "string",
@@ -52756,79 +53092,725 @@
             "description": "Gets or sets a value indicating whether this plugin has a valid image."
           },
           "Status": {
-            "$ref": "#/components/schemas/PluginStatus"
+            "enum": [
+              "Active",
+              "Restart",
+              "Deleted",
+              "Superceded",
+              "Malfunctioned",
+              "NotSupported",
+              "Disabled"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PluginStatus"
+              }
+            ],
+            "description": "Gets or sets a value indicating the status of the plugin."
           }
         },
         "additionalProperties": false,
         "description": "This is a serializable stub class that is used by the api to provide information about installed plugins."
       },
-      "BasePluginConfiguration": {
-        "type": "object",
-        "additionalProperties": false,
-        "description": "Class BasePluginConfiguration."
-      },
-      "PluginSecurityInfo": {
+      "PluginInstallationCancelledMessage": {
         "type": "object",
         "properties": {
-          "SupporterKey": {
-            "type": "string",
-            "description": "Gets or sets the supporter key.",
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/InstallationInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
             "nullable": true
           },
-          "IsMbSupporter": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether is mb supporter."
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "PackageInstallationCancelled",
+            "readOnly": true
           }
         },
         "additionalProperties": false,
-        "description": "Plugin security info."
+        "description": "Plugin installation cancelled message."
       },
-      "QuickConnectState": {
+      "PluginInstallationCompletedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/InstallationInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "PackageInstallationCompleted",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Plugin installation completed message."
+      },
+      "PluginInstallationFailedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/InstallationInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "PackageInstallationFailed",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Plugin installation failed message."
+      },
+      "PluginInstallingMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/InstallationInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "PackageInstalling",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Package installing message."
+      },
+      "PluginStatus": {
         "enum": [
-          "Unavailable",
-          "Available",
-          "Active"
+          "Active",
+          "Restart",
+          "Deleted",
+          "Superceded",
+          "Malfunctioned",
+          "NotSupported",
+          "Disabled"
         ],
         "type": "string",
-        "description": "Quick connect state."
+        "description": "Plugin load status."
+      },
+      "PluginUninstalledMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PluginInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "PackageUninstalled",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Plugin uninstalled message."
+      },
+      "PreviousItemRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playing item identifier.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class PreviousItemRequestDto."
+      },
+      "ProblemDetails": {
+        "type": "object",
+        "properties": {
+          "type": {
+            "type": "string",
+            "nullable": true
+          },
+          "title": {
+            "type": "string",
+            "nullable": true
+          },
+          "status": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "detail": {
+            "type": "string",
+            "nullable": true
+          },
+          "instance": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": { }
+      },
+      "ProcessPriorityClass": {
+        "enum": [
+          "Normal",
+          "Idle",
+          "High",
+          "RealTime",
+          "BelowNormal",
+          "AboveNormal"
+        ],
+        "type": "string"
+      },
+      "ProfileCondition": {
+        "type": "object",
+        "properties": {
+          "Condition": {
+            "enum": [
+              "Equals",
+              "NotEquals",
+              "LessThanEqual",
+              "GreaterThanEqual",
+              "EqualsAny"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ProfileConditionType"
+              }
+            ]
+          },
+          "Property": {
+            "enum": [
+              "AudioChannels",
+              "AudioBitrate",
+              "AudioProfile",
+              "Width",
+              "Height",
+              "Has64BitOffsets",
+              "PacketLength",
+              "VideoBitDepth",
+              "VideoBitrate",
+              "VideoFramerate",
+              "VideoLevel",
+              "VideoProfile",
+              "VideoTimestamp",
+              "IsAnamorphic",
+              "RefFrames",
+              "NumAudioStreams",
+              "NumVideoStreams",
+              "IsSecondaryAudio",
+              "VideoCodecTag",
+              "IsAvc",
+              "IsInterlaced",
+              "AudioSampleRate",
+              "AudioBitDepth",
+              "VideoRangeType"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ProfileConditionValue"
+              }
+            ]
+          },
+          "Value": {
+            "type": "string",
+            "nullable": true
+          },
+          "IsRequired": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "ProfileConditionType": {
+        "enum": [
+          "Equals",
+          "NotEquals",
+          "LessThanEqual",
+          "GreaterThanEqual",
+          "EqualsAny"
+        ],
+        "type": "string"
+      },
+      "ProfileConditionValue": {
+        "enum": [
+          "AudioChannels",
+          "AudioBitrate",
+          "AudioProfile",
+          "Width",
+          "Height",
+          "Has64BitOffsets",
+          "PacketLength",
+          "VideoBitDepth",
+          "VideoBitrate",
+          "VideoFramerate",
+          "VideoLevel",
+          "VideoProfile",
+          "VideoTimestamp",
+          "IsAnamorphic",
+          "RefFrames",
+          "NumAudioStreams",
+          "NumVideoStreams",
+          "IsSecondaryAudio",
+          "VideoCodecTag",
+          "IsAvc",
+          "IsInterlaced",
+          "AudioSampleRate",
+          "AudioBitDepth",
+          "VideoRangeType"
+        ],
+        "type": "string"
+      },
+      "ProgramAudio": {
+        "enum": [
+          "Mono",
+          "Stereo",
+          "Dolby",
+          "DolbyDigital",
+          "Thx",
+          "Atmos"
+        ],
+        "type": "string"
+      },
+      "PublicSystemInfo": {
+        "type": "object",
+        "properties": {
+          "LocalAddress": {
+            "type": "string",
+            "description": "Gets or sets the local address.",
+            "nullable": true
+          },
+          "ServerName": {
+            "type": "string",
+            "description": "Gets or sets the name of the server.",
+            "nullable": true
+          },
+          "Version": {
+            "type": "string",
+            "description": "Gets or sets the server version.",
+            "nullable": true
+          },
+          "ProductName": {
+            "type": "string",
+            "description": "Gets or sets the product name. This is the AssemblyProduct name.",
+            "nullable": true
+          },
+          "OperatingSystem": {
+            "type": "string",
+            "description": "Gets or sets the operating system.",
+            "nullable": true,
+            "deprecated": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the id.",
+            "nullable": true
+          },
+          "StartupWizardCompleted": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the startup wizard is completed.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "QueryFilters": {
+        "type": "object",
+        "properties": {
+          "Genres": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/NameGuidPair"
+            },
+            "nullable": true
+          },
+          "Tags": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "QueryFiltersLegacy": {
+        "type": "object",
+        "properties": {
+          "Genres": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "Tags": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "OfficialRatings": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "Years": {
+            "type": "array",
+            "items": {
+              "type": "integer",
+              "format": "int32"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "QueueItem": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "PlaylistItemId": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "QueueRequestDto": {
+        "type": "object",
+        "properties": {
+          "ItemIds": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the items to enqueue."
+          },
+          "Mode": {
+            "enum": [
+              "Queue",
+              "QueueNext"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupQueueMode"
+              }
+            ],
+            "description": "Gets or sets the mode in which to add the new items."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class QueueRequestDto."
+      },
+      "QuickConnectDto": {
+        "required": [
+          "Secret"
+        ],
+        "type": "object",
+        "properties": {
+          "Secret": {
+            "type": "string",
+            "description": "Gets or sets the quick connect secret."
+          }
+        },
+        "additionalProperties": false,
+        "description": "The quick connect request body."
       },
       "QuickConnectResult": {
         "type": "object",
         "properties": {
           "Authenticated": {
             "type": "boolean",
-            "description": "Gets a value indicating whether this request is authorized.",
-            "readOnly": true
+            "description": "Gets or sets a value indicating whether this request is authorized."
           },
           "Secret": {
             "type": "string",
-            "description": "Gets or sets the secret value used to uniquely identify this request. Can be used to retrieve authentication information.",
-            "nullable": true
+            "description": "Gets the secret value used to uniquely identify this request. Can be used to retrieve authentication information."
           },
           "Code": {
             "type": "string",
-            "description": "Gets or sets the user facing code used so the user can quickly differentiate this request from others.",
-            "nullable": true
+            "description": "Gets the user facing code used so the user can quickly differentiate this request from others."
           },
-          "Authentication": {
+          "DeviceId": {
             "type": "string",
-            "description": "Gets or sets the private access token.",
-            "nullable": true
+            "description": "Gets the requesting device id."
           },
-          "Error": {
+          "DeviceName": {
             "type": "string",
-            "description": "Gets or sets an error message.",
-            "nullable": true
+            "description": "Gets the requesting device name."
+          },
+          "AppName": {
+            "type": "string",
+            "description": "Gets the requesting app name."
+          },
+          "AppVersion": {
+            "type": "string",
+            "description": "Gets the requesting app version."
           },
           "DateAdded": {
             "type": "string",
             "description": "Gets or sets the DateTime that this request was created.",
-            "format": "date-time",
-            "nullable": true
+            "format": "date-time"
           }
         },
         "additionalProperties": false,
-        "description": "Stores the result of an incoming quick connect request."
+        "description": "Stores the state of an quick connect request."
       },
       "RatingType": {
         "enum": [
@@ -52837,6 +53819,158 @@
         ],
         "type": "string"
       },
+      "ReadyRequestDto": {
+        "type": "object",
+        "properties": {
+          "When": {
+            "type": "string",
+            "description": "Gets or sets when the request has been made by the client.",
+            "format": "date-time"
+          },
+          "PositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the position ticks.",
+            "format": "int64"
+          },
+          "IsPlaying": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the client playback is unpaused."
+          },
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playlist item identifier of the playing item.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class ReadyRequest."
+      },
+      "RecommendationDto": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/BaseItemDto"
+            },
+            "nullable": true
+          },
+          "RecommendationType": {
+            "enum": [
+              "SimilarToRecentlyPlayed",
+              "SimilarToLikedItem",
+              "HasDirectorFromRecentlyPlayed",
+              "HasActorFromRecentlyPlayed",
+              "HasLikedDirector",
+              "HasLikedActor"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RecommendationType"
+              }
+            ]
+          },
+          "BaselineItemName": {
+            "type": "string",
+            "nullable": true
+          },
+          "CategoryId": {
+            "type": "string",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false
+      },
+      "RecommendationType": {
+        "enum": [
+          "SimilarToRecentlyPlayed",
+          "SimilarToLikedItem",
+          "HasDirectorFromRecentlyPlayed",
+          "HasActorFromRecentlyPlayed",
+          "HasLikedDirector",
+          "HasLikedActor"
+        ],
+        "type": "string"
+      },
+      "RecordingStatus": {
+        "enum": [
+          "New",
+          "InProgress",
+          "Completed",
+          "Cancelled",
+          "ConflictedOk",
+          "ConflictedNotOk",
+          "Error"
+        ],
+        "type": "string"
+      },
+      "RefreshProgressMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "RefreshProgress",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Refresh progress message."
+      },
       "RemoteImageInfo": {
         "type": "object",
         "properties": {
@@ -52852,7 +53986,7 @@
           },
           "ThumbnailUrl": {
             "type": "string",
-            "description": "Gets a url used for previewing a smaller version.",
+            "description": "Gets or sets a url used for previewing a smaller version.",
             "nullable": true
           },
           "Height": {
@@ -52885,10 +54019,39 @@
             "nullable": true
           },
           "Type": {
-            "$ref": "#/components/schemas/ImageType"
+            "enum": [
+              "Primary",
+              "Art",
+              "Backdrop",
+              "Banner",
+              "Logo",
+              "Thumb",
+              "Disc",
+              "Box",
+              "Screenshot",
+              "Menu",
+              "Chapter",
+              "BoxRear",
+              "Profile"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageType"
+              }
+            ],
+            "description": "Gets or sets the type."
           },
           "RatingType": {
-            "$ref": "#/components/schemas/RatingType"
+            "enum": [
+              "Score",
+              "Likes"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RatingType"
+              }
+            ],
+            "description": "Gets or sets the type of the rating."
           }
         },
         "additionalProperties": false,
@@ -52922,180 +54085,537 @@
         "additionalProperties": false,
         "description": "Class RemoteImageResult."
       },
-      "ImageProviderInfo": {
+      "RemoteLyricInfoDto": {
         "type": "object",
         "properties": {
-          "Name": {
+          "Id": {
             "type": "string",
-            "description": "Gets the name.",
-            "nullable": true,
-            "readOnly": true
+            "description": "Gets or sets the id for the lyric."
           },
-          "SupportedImages": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/ImageType"
-            },
-            "description": "Gets the supported image types.",
-            "nullable": true,
-            "readOnly": true
+          "ProviderName": {
+            "type": "string",
+            "description": "Gets the provider name."
+          },
+          "Lyrics": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LyricDto"
+              }
+            ],
+            "description": "Gets the lyrics."
           }
         },
         "additionalProperties": false,
-        "description": "Class ImageProviderInfo."
+        "description": "The remote lyric info dto."
       },
-      "TaskState": {
-        "enum": [
-          "Idle",
-          "Cancelling",
-          "Running"
-        ],
-        "type": "string",
-        "description": "Enum TaskState."
-      },
-      "TaskCompletionStatus": {
-        "enum": [
-          "Completed",
-          "Failed",
-          "Cancelled",
-          "Aborted"
-        ],
-        "type": "string",
-        "description": "Enum TaskCompletionStatus."
-      },
-      "TaskResult": {
+      "RemoteSearchResult": {
         "type": "object",
         "properties": {
-          "StartTimeUtc": {
-            "type": "string",
-            "description": "Gets or sets the start time UTC.",
-            "format": "date-time"
-          },
-          "EndTimeUtc": {
-            "type": "string",
-            "description": "Gets or sets the end time UTC.",
-            "format": "date-time"
-          },
-          "Status": {
-            "$ref": "#/components/schemas/TaskCompletionStatus"
-          },
           "Name": {
             "type": "string",
             "description": "Gets or sets the name.",
             "nullable": true
           },
-          "Key": {
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "ProductionYear": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumberEnd": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "ImageUrl": {
+            "type": "string",
+            "nullable": true
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "nullable": true
+          },
+          "Overview": {
+            "type": "string",
+            "nullable": true
+          },
+          "AlbumArtist": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RemoteSearchResult"
+              }
+            ],
+            "nullable": true
+          },
+          "Artists": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/RemoteSearchResult"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "RemoteSubtitleInfo": {
+        "type": "object",
+        "properties": {
+          "ThreeLetterISOLanguageName": {
             "type": "string",
-            "description": "Gets or sets the key.",
             "nullable": true
           },
           "Id": {
             "type": "string",
-            "description": "Gets or sets the id.",
             "nullable": true
           },
-          "ErrorMessage": {
+          "ProviderName": {
             "type": "string",
-            "description": "Gets or sets the error message.",
             "nullable": true
           },
-          "LongErrorMessage": {
-            "type": "string",
-            "description": "Gets or sets the long error message.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class TaskExecutionInfo."
-      },
-      "TaskTriggerInfo": {
-        "type": "object",
-        "properties": {
-          "Type": {
-            "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
-          },
-          "TimeOfDayTicks": {
-            "type": "integer",
-            "description": "Gets or sets the time of day.",
-            "format": "int64",
-            "nullable": true
-          },
-          "IntervalTicks": {
-            "type": "integer",
-            "description": "Gets or sets the interval.",
-            "format": "int64",
-            "nullable": true
-          },
-          "DayOfWeek": {
-            "$ref": "#/components/schemas/DayOfWeek"
-          },
-          "MaxRuntimeTicks": {
-            "type": "integer",
-            "description": "Gets or sets the maximum runtime ticks.",
-            "format": "int64",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class TaskTriggerInfo."
-      },
-      "TaskInfo": {
-        "type": "object",
-        "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
             "nullable": true
           },
-          "State": {
-            "$ref": "#/components/schemas/TaskState"
+          "Format": {
+            "type": "string",
+            "nullable": true
           },
-          "CurrentProgressPercentage": {
+          "Author": {
+            "type": "string",
+            "nullable": true
+          },
+          "Comment": {
+            "type": "string",
+            "nullable": true
+          },
+          "DateCreated": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "CommunityRating": {
             "type": "number",
-            "description": "Gets or sets the progress.",
-            "format": "double",
+            "format": "float",
             "nullable": true
           },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the id.",
+          "FrameRate": {
+            "type": "number",
+            "format": "float",
             "nullable": true
           },
-          "LastExecutionResult": {
-            "$ref": "#/components/schemas/TaskResult"
-          },
-          "Triggers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/TaskTriggerInfo"
-            },
-            "description": "Gets or sets the triggers.",
+          "DownloadCount": {
+            "type": "integer",
+            "format": "int32",
             "nullable": true
           },
-          "Description": {
-            "type": "string",
-            "description": "Gets or sets the description.",
-            "nullable": true
-          },
-          "Category": {
-            "type": "string",
-            "description": "Gets or sets the category.",
-            "nullable": true
-          },
-          "IsHidden": {
+          "IsHashMatch": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is hidden."
+            "nullable": true
           },
-          "Key": {
-            "type": "string",
-            "description": "Gets or sets the key.",
+          "AiTranslated": {
+            "type": "boolean",
+            "nullable": true
+          },
+          "MachineTranslated": {
+            "type": "boolean",
+            "nullable": true
+          },
+          "Forced": {
+            "type": "boolean",
+            "nullable": true
+          },
+          "HearingImpaired": {
+            "type": "boolean",
             "nullable": true
           }
         },
+        "additionalProperties": false
+      },
+      "RemoveFromPlaylistRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlaylistItemIds": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets the playlist identifiers of the items. Ignored when clearing the playlist."
+          },
+          "ClearPlaylist": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the entire playlist should be cleared."
+          },
+          "ClearPlayingItem": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the playing item should be removed as well. Used only when clearing the playlist."
+          }
+        },
         "additionalProperties": false,
-        "description": "Class TaskInfo."
+        "description": "Class RemoveFromPlaylistRequestDto."
+      },
+      "RepeatMode": {
+        "enum": [
+          "RepeatNone",
+          "RepeatAll",
+          "RepeatOne"
+        ],
+        "type": "string"
+      },
+      "RepositoryInfo": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "Url": {
+            "type": "string",
+            "description": "Gets or sets the URL.",
+            "nullable": true
+          },
+          "Enabled": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the repository is enabled."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class RepositoryInfo."
+      },
+      "RestartRequiredMessage": {
+        "type": "object",
+        "properties": {
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "RestartRequired",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Restart required."
+      },
+      "ScheduledTaskEndedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TaskResult"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ScheduledTaskEnded",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Scheduled task ended message."
+      },
+      "ScheduledTasksInfoMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TaskInfo"
+            },
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ScheduledTasksInfo",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Scheduled tasks info message."
+      },
+      "ScheduledTasksInfoStartMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "string",
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ScheduledTasksInfoStart",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Scheduled tasks info start message.\r\nData is the timing data encoded as \"$initialDelay,$interval\" in ms."
+      },
+      "ScheduledTasksInfoStopMessage": {
+        "type": "object",
+        "properties": {
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ScheduledTasksInfoStop",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Scheduled tasks info stop message."
+      },
+      "ScrollDirection": {
+        "enum": [
+          "Horizontal",
+          "Vertical"
+        ],
+        "type": "string",
+        "description": "An enum representing the axis that should be scrolled."
       },
       "SearchHint": {
         "type": "object",
@@ -53103,16 +54623,17 @@
           "ItemId": {
             "type": "string",
             "description": "Gets or sets the item id.",
-            "format": "uuid"
+            "format": "uuid",
+            "deprecated": true
           },
           "Id": {
             "type": "string",
+            "description": "Gets or sets the item id.",
             "format": "uuid"
           },
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
-            "nullable": true
+            "description": "Gets or sets the name."
           },
           "MatchedTerm": {
             "type": "string",
@@ -53163,12 +54684,55 @@
             "nullable": true
           },
           "Type": {
-            "type": "string",
-            "description": "Gets or sets the type.",
-            "nullable": true
+            "enum": [
+              "AggregateFolder",
+              "Audio",
+              "AudioBook",
+              "BasePluginFolder",
+              "Book",
+              "BoxSet",
+              "Channel",
+              "ChannelFolderItem",
+              "CollectionFolder",
+              "Episode",
+              "Folder",
+              "Genre",
+              "ManualPlaylistsFolder",
+              "Movie",
+              "LiveTvChannel",
+              "LiveTvProgram",
+              "MusicAlbum",
+              "MusicArtist",
+              "MusicGenre",
+              "MusicVideo",
+              "Person",
+              "Photo",
+              "PhotoAlbum",
+              "Playlist",
+              "PlaylistsFolder",
+              "Program",
+              "Recording",
+              "Season",
+              "Series",
+              "Studio",
+              "Trailer",
+              "TvChannel",
+              "TvProgram",
+              "UserRootFolder",
+              "UserView",
+              "Video",
+              "Year"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemKind"
+              }
+            ],
+            "description": "The base item kind."
           },
           "IsFolder": {
             "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is folder.",
             "nullable": true
           },
           "RunTimeTicks": {
@@ -53178,17 +54742,29 @@
             "nullable": true
           },
           "MediaType": {
-            "type": "string",
-            "description": "Gets or sets the type of the media.",
-            "nullable": true
+            "enum": [
+              "Unknown",
+              "Video",
+              "Audio",
+              "Photo",
+              "Book"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaType"
+              }
+            ],
+            "description": "Media types."
           },
           "StartDate": {
             "type": "string",
+            "description": "Gets or sets the start date.",
             "format": "date-time",
             "nullable": true
           },
           "EndDate": {
             "type": "string",
+            "description": "Gets or sets the end date.",
             "format": "date-time",
             "nullable": true
           },
@@ -53199,6 +54775,7 @@
           },
           "Status": {
             "type": "string",
+            "description": "Gets or sets the status.",
             "nullable": true
           },
           "Album": {
@@ -53208,7 +54785,9 @@
           },
           "AlbumId": {
             "type": "string",
-            "format": "uuid"
+            "description": "Gets or sets the album id.",
+            "format": "uuid",
+            "nullable": true
           },
           "AlbumArtist": {
             "type": "string",
@@ -53220,8 +54799,7 @@
             "items": {
               "type": "string"
             },
-            "description": "Gets or sets the artists.",
-            "nullable": true
+            "description": "Gets or sets the artists."
           },
           "SongCount": {
             "type": "integer",
@@ -53238,7 +54816,8 @@
           "ChannelId": {
             "type": "string",
             "description": "Gets or sets the channel identifier.",
-            "format": "uuid"
+            "format": "uuid",
+            "nullable": true
           },
           "ChannelName": {
             "type": "string",
@@ -53263,251 +54842,994 @@
             "items": {
               "$ref": "#/components/schemas/SearchHint"
             },
-            "description": "Gets or sets the search hints.",
-            "nullable": true
+            "description": "Gets the search hints."
           },
           "TotalRecordCount": {
             "type": "integer",
-            "description": "Gets or sets the total record count.",
+            "description": "Gets the total record count.",
             "format": "int32"
           }
         },
         "additionalProperties": false,
         "description": "Class SearchHintResult."
       },
-      "PlayerStateInfo": {
+      "SeekRequestDto": {
         "type": "object",
         "properties": {
           "PositionTicks": {
             "type": "integer",
-            "description": "Gets or sets the now playing position ticks.",
-            "format": "int64",
-            "nullable": true
-          },
-          "CanSeek": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance can seek."
-          },
-          "IsPaused": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is paused."
-          },
-          "IsMuted": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance is muted."
-          },
-          "VolumeLevel": {
-            "type": "integer",
-            "description": "Gets or sets the volume level.",
-            "format": "int32",
-            "nullable": true
-          },
-          "AudioStreamIndex": {
-            "type": "integer",
-            "description": "Gets or sets the index of the now playing audio stream.",
-            "format": "int32",
-            "nullable": true
-          },
-          "SubtitleStreamIndex": {
-            "type": "integer",
-            "description": "Gets or sets the index of the now playing subtitle stream.",
-            "format": "int32",
-            "nullable": true
-          },
-          "MediaSourceId": {
-            "type": "string",
-            "description": "Gets or sets the now playing media version identifier.",
-            "nullable": true
-          },
-          "PlayMethod": {
-            "$ref": "#/components/schemas/PlayMethod"
-          },
-          "RepeatMode": {
-            "$ref": "#/components/schemas/RepeatMode"
+            "description": "Gets or sets the position ticks.",
+            "format": "int64"
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Class SeekRequestDto."
       },
-      "SessionUserInfo": {
+      "SendCommand": {
         "type": "object",
         "properties": {
-          "UserId": {
+          "GroupId": {
             "type": "string",
-            "description": "Gets or sets the user identifier.",
+            "description": "Gets the group identifier.",
             "format": "uuid"
           },
-          "UserName": {
+          "PlaylistItemId": {
             "type": "string",
-            "description": "Gets or sets the name of the user.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SessionUserInfo."
-      },
-      "BaseItem": {
-        "type": "object",
-        "properties": {
-          "Size": {
+            "description": "Gets the playlist identifier of the playing item.",
+            "format": "uuid"
+          },
+          "When": {
+            "type": "string",
+            "description": "Gets or sets the UTC time when to execute the command.",
+            "format": "date-time"
+          },
+          "PositionTicks": {
             "type": "integer",
+            "description": "Gets the position ticks.",
             "format": "int64",
             "nullable": true
           },
-          "Container": {
-            "type": "string",
-            "nullable": true
+          "Command": {
+            "enum": [
+              "Unpause",
+              "Pause",
+              "Stop",
+              "Seek"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SendCommandType"
+              }
+            ],
+            "description": "Gets the command."
           },
-          "DateLastSaved": {
+          "EmittedAt": {
             "type": "string",
+            "description": "Gets the UTC time when this command has been emitted.",
             "format": "date-time"
-          },
-          "RemoteTrailers": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/MediaUrl"
-            },
-            "description": "Gets or sets the remote trailers.",
-            "nullable": true
-          },
-          "IsHD": {
-            "type": "boolean",
-            "readOnly": true
-          },
-          "IsShortcut": {
-            "type": "boolean"
-          },
-          "ShortcutPath": {
-            "type": "string",
-            "nullable": true
-          },
-          "Width": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "Height": {
-            "type": "integer",
-            "format": "int32"
-          },
-          "ExtraIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "nullable": true
-          },
-          "SupportsExternalTransfer": {
-            "type": "boolean",
-            "readOnly": true
           }
         },
         "additionalProperties": false,
-        "description": "Class BaseItem."
+        "description": "Class SendCommand."
       },
-      "TranscodeReason": {
+      "SendCommandType": {
         "enum": [
-          "ContainerNotSupported",
-          "VideoCodecNotSupported",
-          "AudioCodecNotSupported",
-          "ContainerBitrateExceedsLimit",
-          "AudioBitrateNotSupported",
-          "AudioChannelsNotSupported",
-          "VideoResolutionNotSupported",
-          "UnknownVideoStreamInfo",
-          "UnknownAudioStreamInfo",
-          "AudioProfileNotSupported",
-          "AudioSampleRateNotSupported",
-          "AnamorphicVideoNotSupported",
-          "InterlacedVideoNotSupported",
-          "SecondaryAudioNotSupported",
-          "RefFramesNotSupported",
-          "VideoBitDepthNotSupported",
-          "VideoBitrateNotSupported",
-          "VideoFramerateNotSupported",
-          "VideoLevelNotSupported",
-          "VideoProfileNotSupported",
-          "AudioBitDepthNotSupported",
-          "SubtitleCodecNotSupported",
-          "DirectPlayError"
+          "Unpause",
+          "Pause",
+          "Stop",
+          "Seek"
         ],
-        "type": "string"
+        "type": "string",
+        "description": "Enum SendCommandType."
       },
-      "TranscodingInfo": {
+      "SeriesInfo": {
         "type": "object",
         "properties": {
-          "AudioCodec": {
+          "Name": {
             "type": "string",
+            "description": "Gets or sets the name.",
             "nullable": true
           },
-          "VideoCodec": {
+          "OriginalTitle": {
             "type": "string",
+            "description": "Gets or sets the original title.",
             "nullable": true
           },
-          "Container": {
+          "Path": {
             "type": "string",
+            "description": "Gets or sets the path.",
             "nullable": true
           },
-          "IsVideoDirect": {
-            "type": "boolean"
-          },
-          "IsAudioDirect": {
-            "type": "boolean"
-          },
-          "Bitrate": {
-            "type": "integer",
-            "format": "int32",
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
             "nullable": true
           },
-          "Framerate": {
-            "type": "number",
-            "format": "float",
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
             "nullable": true
           },
-          "CompletionPercentage": {
-            "type": "number",
-            "format": "double",
-            "nullable": true
-          },
-          "Width": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "Height": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "AudioChannels": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "TranscodeReasons": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/TranscodeReason"
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
             },
+            "description": "Gets or sets the provider ids.",
             "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
           }
         },
         "additionalProperties": false
       },
-      "SessionInfo": {
+      "SeriesInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SeriesInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "SeriesStatus": {
+        "enum": [
+          "Continuing",
+          "Ended",
+          "Unreleased"
+        ],
+        "type": "string",
+        "description": "The status of a series."
+      },
+      "SeriesTimerCancelledMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TimerEventInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SeriesTimerCancelled",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Series timer cancelled message."
+      },
+      "SeriesTimerCreatedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TimerEventInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SeriesTimerCreated",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Series timer created message."
+      },
+      "SeriesTimerInfoDto": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the Id of the recording.",
+            "nullable": true
+          },
+          "Type": {
+            "type": "string",
+            "nullable": true
+          },
+          "ServerId": {
+            "type": "string",
+            "description": "Gets or sets the server identifier.",
+            "nullable": true
+          },
+          "ExternalId": {
+            "type": "string",
+            "description": "Gets or sets the external identifier.",
+            "nullable": true
+          },
+          "ChannelId": {
+            "type": "string",
+            "description": "Gets or sets the channel id of the recording.",
+            "format": "uuid"
+          },
+          "ExternalChannelId": {
+            "type": "string",
+            "description": "Gets or sets the external channel identifier.",
+            "nullable": true
+          },
+          "ChannelName": {
+            "type": "string",
+            "description": "Gets or sets the channel name of the recording.",
+            "nullable": true
+          },
+          "ChannelPrimaryImageTag": {
+            "type": "string",
+            "nullable": true
+          },
+          "ProgramId": {
+            "type": "string",
+            "description": "Gets or sets the program identifier.",
+            "nullable": true
+          },
+          "ExternalProgramId": {
+            "type": "string",
+            "description": "Gets or sets the external program identifier.",
+            "nullable": true
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of the recording.",
+            "nullable": true
+          },
+          "Overview": {
+            "type": "string",
+            "description": "Gets or sets the description of the recording.",
+            "nullable": true
+          },
+          "StartDate": {
+            "type": "string",
+            "description": "Gets or sets the start date of the recording, in UTC.",
+            "format": "date-time"
+          },
+          "EndDate": {
+            "type": "string",
+            "description": "Gets or sets the end date of the recording, in UTC.",
+            "format": "date-time"
+          },
+          "ServiceName": {
+            "type": "string",
+            "description": "Gets or sets the name of the service.",
+            "nullable": true
+          },
+          "Priority": {
+            "type": "integer",
+            "description": "Gets or sets the priority.",
+            "format": "int32"
+          },
+          "PrePaddingSeconds": {
+            "type": "integer",
+            "description": "Gets or sets the pre padding seconds.",
+            "format": "int32"
+          },
+          "PostPaddingSeconds": {
+            "type": "integer",
+            "description": "Gets or sets the post padding seconds.",
+            "format": "int32"
+          },
+          "IsPrePaddingRequired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is pre padding required."
+          },
+          "ParentBackdropItemId": {
+            "type": "string",
+            "description": "Gets or sets the Id of the Parent that has a backdrop if the item does not have one.",
+            "nullable": true
+          },
+          "ParentBackdropImageTags": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the parent backdrop image tags.",
+            "nullable": true
+          },
+          "IsPostPaddingRequired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is post padding required."
+          },
+          "KeepUntil": {
+            "enum": [
+              "UntilDeleted",
+              "UntilSpaceNeeded",
+              "UntilWatched",
+              "UntilDate"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/KeepUntil"
+              }
+            ]
+          },
+          "RecordAnyTime": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [record any time]."
+          },
+          "SkipEpisodesInLibrary": {
+            "type": "boolean"
+          },
+          "RecordAnyChannel": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [record any channel]."
+          },
+          "KeepUpTo": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "RecordNewOnly": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [record new only]."
+          },
+          "Days": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/DayOfWeek"
+            },
+            "description": "Gets or sets the days.",
+            "nullable": true
+          },
+          "DayPattern": {
+            "enum": [
+              "Daily",
+              "Weekdays",
+              "Weekends"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DayPattern"
+              }
+            ],
+            "description": "Gets or sets the day pattern.",
+            "nullable": true
+          },
+          "ImageTags": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string"
+            },
+            "description": "Gets or sets the image tags.",
+            "nullable": true
+          },
+          "ParentThumbItemId": {
+            "type": "string",
+            "description": "Gets or sets the parent thumb item id.",
+            "nullable": true
+          },
+          "ParentThumbImageTag": {
+            "type": "string",
+            "description": "Gets or sets the parent thumb image tag.",
+            "nullable": true
+          },
+          "ParentPrimaryImageItemId": {
+            "type": "string",
+            "description": "Gets or sets the parent primary image item identifier.",
+            "nullable": true
+          },
+          "ParentPrimaryImageTag": {
+            "type": "string",
+            "description": "Gets or sets the parent primary image tag.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class SeriesTimerInfoDto."
+      },
+      "SeriesTimerInfoDtoQueryResult": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SeriesTimerInfoDto"
+            },
+            "description": "Gets or sets the items."
+          },
+          "TotalRecordCount": {
+            "type": "integer",
+            "description": "Gets or sets the total number of records available.",
+            "format": "int32"
+          },
+          "StartIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the first record in Items.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Query result container."
+      },
+      "ServerConfiguration": {
+        "type": "object",
+        "properties": {
+          "LogFileRetentionDays": {
+            "type": "integer",
+            "description": "Gets or sets the number of days we should retain log files.",
+            "format": "int32"
+          },
+          "IsStartupWizardCompleted": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is first run."
+          },
+          "CachePath": {
+            "type": "string",
+            "description": "Gets or sets the cache path.",
+            "nullable": true
+          },
+          "PreviousVersion": {
+            "type": "string",
+            "description": "Gets or sets the last known version that was ran using the configuration.",
+            "nullable": true
+          },
+          "PreviousVersionStr": {
+            "type": "string",
+            "description": "Gets or sets the stringified PreviousVersion to be stored/loaded,\r\nbecause System.Version itself isn't xml-serializable.",
+            "nullable": true
+          },
+          "EnableMetrics": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to enable prometheus metrics exporting."
+          },
+          "EnableNormalizedItemByNameIds": {
+            "type": "boolean"
+          },
+          "IsPortAuthorized": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is port authorized."
+          },
+          "QuickConnectAvailable": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether quick connect is available for use on this server."
+          },
+          "EnableCaseSensitiveItemIds": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether [enable case sensitive item ids]."
+          },
+          "DisableLiveTvChannelUserDataName": {
+            "type": "boolean"
+          },
+          "MetadataPath": {
+            "type": "string",
+            "description": "Gets or sets the metadata path."
+          },
+          "PreferredMetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the preferred metadata language."
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code."
+          },
+          "SortReplaceCharacters": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets characters to be replaced with a ' ' in strings to create a sort name."
+          },
+          "SortRemoveCharacters": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets characters to be removed from strings to create a sort name."
+          },
+          "SortRemoveWords": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets words to be removed from strings to create a sort name."
+          },
+          "MinResumePct": {
+            "type": "integer",
+            "description": "Gets or sets the minimum percentage of an item that must be played in order for playstate to be updated.",
+            "format": "int32"
+          },
+          "MaxResumePct": {
+            "type": "integer",
+            "description": "Gets or sets the maximum percentage of an item that can be played while still saving playstate. If this percentage is crossed playstate will be reset to the beginning and the item will be marked watched.",
+            "format": "int32"
+          },
+          "MinResumeDurationSeconds": {
+            "type": "integer",
+            "description": "Gets or sets the minimum duration that an item must have in order to be eligible for playstate updates..",
+            "format": "int32"
+          },
+          "MinAudiobookResume": {
+            "type": "integer",
+            "description": "Gets or sets the minimum minutes of a book that must be played in order for playstate to be updated.",
+            "format": "int32"
+          },
+          "MaxAudiobookResume": {
+            "type": "integer",
+            "description": "Gets or sets the remaining minutes of a book that can be played while still saving playstate. If this percentage is crossed playstate will be reset to the beginning and the item will be marked watched.",
+            "format": "int32"
+          },
+          "InactiveSessionThreshold": {
+            "type": "integer",
+            "description": "Gets or sets the threshold in minutes after a inactive session gets closed automatically.\r\nIf set to 0 the check for inactive sessions gets disabled.",
+            "format": "int32"
+          },
+          "LibraryMonitorDelay": {
+            "type": "integer",
+            "description": "Gets or sets the delay in seconds that we will wait after a file system change to try and discover what has been added/removed\r\nSome delay is necessary with some items because their creation is not atomic.  It involves the creation of several\r\ndifferent directories and files.",
+            "format": "int32"
+          },
+          "LibraryUpdateDuration": {
+            "type": "integer",
+            "description": "Gets or sets the duration in seconds that we will wait after a library updated event before executing the library changed notification.",
+            "format": "int32"
+          },
+          "ImageSavingConvention": {
+            "enum": [
+              "Legacy",
+              "Compatible"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageSavingConvention"
+              }
+            ],
+            "description": "Gets or sets the image saving convention."
+          },
+          "MetadataOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/MetadataOptions"
+            }
+          },
+          "SkipDeserializationForBasicTypes": {
+            "type": "boolean"
+          },
+          "ServerName": {
+            "type": "string"
+          },
+          "UICulture": {
+            "type": "string"
+          },
+          "SaveMetadataHidden": {
+            "type": "boolean"
+          },
+          "ContentTypes": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/NameValuePair"
+            }
+          },
+          "RemoteClientBitrateLimit": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "EnableFolderView": {
+            "type": "boolean"
+          },
+          "EnableGroupingIntoCollections": {
+            "type": "boolean"
+          },
+          "DisplaySpecialsWithinSeasons": {
+            "type": "boolean"
+          },
+          "CodecsUsed": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            }
+          },
+          "PluginRepositories": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/RepositoryInfo"
+            }
+          },
+          "EnableExternalContentInSuggestions": {
+            "type": "boolean"
+          },
+          "ImageExtractionTimeoutMs": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "PathSubstitutions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/PathSubstitution"
+            }
+          },
+          "EnableSlowResponseWarning": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether slow server responses should be logged as a warning."
+          },
+          "SlowResponseThresholdMs": {
+            "type": "integer",
+            "description": "Gets or sets the threshold for the slow response time warning in ms.",
+            "format": "int64"
+          },
+          "CorsHosts": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the cors hosts."
+          },
+          "ActivityLogRetentionDays": {
+            "type": "integer",
+            "description": "Gets or sets the number of days we should retain activity logs.",
+            "format": "int32",
+            "nullable": true
+          },
+          "LibraryScanFanoutConcurrency": {
+            "type": "integer",
+            "description": "Gets or sets the how the library scan fans out.",
+            "format": "int32"
+          },
+          "LibraryMetadataRefreshConcurrency": {
+            "type": "integer",
+            "description": "Gets or sets the how many metadata refreshes can run concurrently.",
+            "format": "int32"
+          },
+          "RemoveOldPlugins": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether older plugins should automatically be deleted from the plugin folder."
+          },
+          "AllowClientLogUpload": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether clients should be allowed to upload logs."
+          },
+          "DummyChapterDuration": {
+            "type": "integer",
+            "description": "Gets or sets the dummy chapter duration in seconds, use 0 (zero) or less to disable generation alltogether.",
+            "format": "int32"
+          },
+          "ChapterImageResolution": {
+            "enum": [
+              "MatchSource",
+              "P144",
+              "P240",
+              "P360",
+              "P480",
+              "P720",
+              "P1080",
+              "P1440",
+              "P2160"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ImageResolution"
+              }
+            ],
+            "description": "Gets or sets the chapter image resolution."
+          },
+          "ParallelImageEncodingLimit": {
+            "type": "integer",
+            "description": "Gets or sets the limit for parallel image encoding.",
+            "format": "int32"
+          },
+          "CastReceiverApplications": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/CastReceiverApplication"
+            },
+            "description": "Gets or sets the list of cast receiver applications."
+          },
+          "TrickplayOptions": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TrickplayOptions"
+              }
+            ],
+            "description": "Gets or sets the trickplay options."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Represents the server configuration."
+      },
+      "ServerDiscoveryInfo": {
+        "type": "object",
+        "properties": {
+          "Address": {
+            "type": "string",
+            "description": "Gets the address."
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets the server identifier."
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets the name."
+          },
+          "EndpointAddress": {
+            "type": "string",
+            "description": "Gets the endpoint address.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "The server discovery info model."
+      },
+      "ServerRestartingMessage": {
+        "type": "object",
+        "properties": {
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ServerRestarting",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Server restarting down message."
+      },
+      "ServerShuttingDownMessage": {
+        "type": "object",
+        "properties": {
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "ServerShuttingDown",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Server shutting down message."
+      },
+      "SessionInfoDto": {
         "type": "object",
         "properties": {
           "PlayState": {
-            "$ref": "#/components/schemas/PlayerStateInfo"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/PlayerStateInfo"
+              }
+            ],
+            "description": "Gets or sets the play state.",
+            "nullable": true
           },
           "AdditionalUsers": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/SessionUserInfo"
             },
+            "description": "Gets or sets the additional users.",
             "nullable": true
           },
           "Capabilities": {
-            "$ref": "#/components/schemas/ClientCapabilities"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ClientCapabilitiesDto"
+              }
+            ],
+            "description": "Gets or sets the client capabilities.",
+            "nullable": true
           },
           "RemoteEndPoint": {
             "type": "string",
@@ -53517,11 +55839,9 @@
           "PlayableMediaTypes": {
             "type": "array",
             "items": {
-              "type": "string"
+              "$ref": "#/components/schemas/MediaType"
             },
-            "description": "Gets or sets the playable media types.",
-            "nullable": true,
-            "readOnly": true
+            "description": "Gets or sets the playable media types."
           },
           "Id": {
             "type": "string",
@@ -53553,6 +55873,12 @@
             "description": "Gets or sets the last playback check in.",
             "format": "date-time"
           },
+          "LastPausedDate": {
+            "type": "string",
+            "description": "Gets or sets the last paused date.",
+            "format": "date-time",
+            "nullable": true
+          },
           "DeviceName": {
             "type": "string",
             "description": "Gets or sets the name of the device.",
@@ -53564,13 +55890,22 @@
             "nullable": true
           },
           "NowPlayingItem": {
-            "$ref": "#/components/schemas/BaseItemDto"
-          },
-          "FullNowPlayingItem": {
-            "$ref": "#/components/schemas/BaseItem"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the now playing item.",
+            "nullable": true
           },
           "NowViewingItem": {
-            "$ref": "#/components/schemas/BaseItemDto"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the now viewing item.",
+            "nullable": true
           },
           "DeviceId": {
             "type": "string",
@@ -53583,41 +55918,59 @@
             "nullable": true
           },
           "TranscodingInfo": {
-            "$ref": "#/components/schemas/TranscodingInfo"
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TranscodingInfo"
+              }
+            ],
+            "description": "Gets or sets the transcoding info.",
+            "nullable": true
           },
           "IsActive": {
             "type": "boolean",
-            "description": "Gets a value indicating whether this instance is active.",
-            "readOnly": true
+            "description": "Gets or sets a value indicating whether this session is active."
           },
           "SupportsMediaControl": {
             "type": "boolean",
-            "readOnly": true
+            "description": "Gets or sets a value indicating whether the session supports media control."
           },
           "SupportsRemoteControl": {
             "type": "boolean",
-            "readOnly": true
+            "description": "Gets or sets a value indicating whether the session supports remote control."
           },
           "NowPlayingQueue": {
             "type": "array",
             "items": {
               "$ref": "#/components/schemas/QueueItem"
             },
+            "description": "Gets or sets the now playing queue.",
+            "nullable": true
+          },
+          "NowPlayingQueueFullItems": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/BaseItemDto"
+            },
+            "description": "Gets or sets the now playing queue full items.",
             "nullable": true
           },
           "HasCustomDeviceName": {
-            "type": "boolean"
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the session has a custom device name."
           },
           "PlaylistItemId": {
             "type": "string",
+            "description": "Gets or sets the playlist item id.",
             "nullable": true
           },
           "ServerId": {
             "type": "string",
+            "description": "Gets or sets the server id.",
             "nullable": true
           },
           "UserPrimaryImageTag": {
             "type": "string",
+            "description": "Gets or sets the user primary image tag.",
             "nullable": true
           },
           "SupportedCommands": {
@@ -53625,27 +55978,396 @@
             "items": {
               "$ref": "#/components/schemas/GeneralCommandType"
             },
-            "description": "Gets or sets the supported commands.",
-            "nullable": true,
+            "description": "Gets or sets the supported commands."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Session info DTO."
+      },
+      "SessionMessageType": {
+        "enum": [
+          "ForceKeepAlive",
+          "GeneralCommand",
+          "UserDataChanged",
+          "Sessions",
+          "Play",
+          "SyncPlayCommand",
+          "SyncPlayGroupUpdate",
+          "Playstate",
+          "RestartRequired",
+          "ServerShuttingDown",
+          "ServerRestarting",
+          "LibraryChanged",
+          "UserDeleted",
+          "UserUpdated",
+          "SeriesTimerCreated",
+          "TimerCreated",
+          "SeriesTimerCancelled",
+          "TimerCancelled",
+          "RefreshProgress",
+          "ScheduledTaskEnded",
+          "PackageInstallationCancelled",
+          "PackageInstallationFailed",
+          "PackageInstallationCompleted",
+          "PackageInstalling",
+          "PackageUninstalled",
+          "ActivityLogEntry",
+          "ScheduledTasksInfo",
+          "ActivityLogEntryStart",
+          "ActivityLogEntryStop",
+          "SessionsStart",
+          "SessionsStop",
+          "ScheduledTasksInfoStart",
+          "ScheduledTasksInfoStop",
+          "KeepAlive"
+        ],
+        "type": "string",
+        "description": "The different kinds of messages that are used in the WebSocket api."
+      },
+      "SessionsMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/SessionInfoDto"
+            },
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "Sessions",
             "readOnly": true
           }
         },
         "additionalProperties": false,
-        "description": "Class SessionInfo."
+        "description": "Sessions message."
       },
-      "GeneralCommand": {
+      "SessionsStartMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "string",
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SessionsStart",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Sessions start message.\r\nData is the timing data encoded as \"$initialDelay,$interval\" in ms."
+      },
+      "SessionsStopMessage": {
+        "type": "object",
+        "properties": {
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SessionsStop",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Sessions stop message."
+      },
+      "SessionUserInfo": {
+        "type": "object",
+        "properties": {
+          "UserId": {
+            "type": "string",
+            "description": "Gets or sets the user identifier.",
+            "format": "uuid"
+          },
+          "UserName": {
+            "type": "string",
+            "description": "Gets or sets the name of the user.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class SessionUserInfo."
+      },
+      "SetChannelMappingDto": {
+        "required": [
+          "ProviderChannelId",
+          "ProviderId",
+          "TunerChannelId"
+        ],
+        "type": "object",
+        "properties": {
+          "ProviderId": {
+            "type": "string",
+            "description": "Gets or sets the provider id."
+          },
+          "TunerChannelId": {
+            "type": "string",
+            "description": "Gets or sets the tuner channel id."
+          },
+          "ProviderChannelId": {
+            "type": "string",
+            "description": "Gets or sets the provider channel id."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Set channel mapping dto."
+      },
+      "SetPlaylistItemRequestDto": {
+        "type": "object",
+        "properties": {
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets or sets the playlist identifier of the playing item.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class SetPlaylistItemRequestDto."
+      },
+      "SetRepeatModeRequestDto": {
+        "type": "object",
+        "properties": {
+          "Mode": {
+            "enum": [
+              "RepeatOne",
+              "RepeatAll",
+              "RepeatNone"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupRepeatMode"
+              }
+            ],
+            "description": "Gets or sets the repeat mode."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class SetRepeatModeRequestDto."
+      },
+      "SetShuffleModeRequestDto": {
+        "type": "object",
+        "properties": {
+          "Mode": {
+            "enum": [
+              "Sorted",
+              "Shuffle"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupShuffleMode"
+              }
+            ],
+            "description": "Gets or sets the shuffle mode."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class SetShuffleModeRequestDto."
+      },
+      "SongInfo": {
         "type": "object",
         "properties": {
           "Name": {
-            "$ref": "#/components/schemas/GeneralCommandType"
-          },
-          "ControllingUserId": {
             "type": "string",
-            "format": "uuid"
+            "description": "Gets or sets the name.",
+            "nullable": true
           },
-          "Arguments": {
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
             "type": "object",
             "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
+            "type": "string",
+            "format": "date-time",
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          },
+          "AlbumArtists": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "Album": {
+            "type": "string",
+            "nullable": true
+          },
+          "Artists": {
+            "type": "array",
+            "items": {
               "type": "string"
             },
             "nullable": true
@@ -53653,88 +56375,30 @@
         },
         "additionalProperties": false
       },
-      "PlayCommand": {
+      "SortOrder": {
         "enum": [
-          "PlayNow",
-          "PlayNext",
-          "PlayLast",
-          "PlayInstantMix",
-          "PlayShuffle"
+          "Ascending",
+          "Descending"
         ],
         "type": "string",
-        "description": "Enum PlayCommand."
+        "description": "An enum representing the sorting order."
       },
-      "PlaystateCommand": {
-        "enum": [
-          "Stop",
-          "Pause",
-          "Unpause",
-          "NextTrack",
-          "PreviousTrack",
-          "Seek",
-          "Rewind",
-          "FastForward",
-          "PlayPause"
-        ],
-        "type": "string",
-        "description": "Enum PlaystateCommand."
-      },
-      "ClientCapabilitiesDto": {
+      "SpecialViewOptionDto": {
         "type": "object",
         "properties": {
-          "PlayableMediaTypes": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the list of playable media types.",
-            "nullable": true
-          },
-          "SupportedCommands": {
-            "type": "array",
-            "items": {
-              "$ref": "#/components/schemas/GeneralCommandType"
-            },
-            "description": "Gets or sets the list of supported commands.",
-            "nullable": true
-          },
-          "SupportsMediaControl": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether session supports media control."
-          },
-          "SupportsContentUploading": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether session supports content uploading."
-          },
-          "MessageCallbackUrl": {
+          "Name": {
             "type": "string",
-            "description": "Gets or sets the message callback url.",
+            "description": "Gets or sets view option name.",
             "nullable": true
           },
-          "SupportsPersistentIdentifier": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether session supports a persistent identifier."
-          },
-          "SupportsSync": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether session supports sync."
-          },
-          "DeviceProfile": {
-            "$ref": "#/components/schemas/DeviceProfile"
-          },
-          "AppStoreUrl": {
+          "Id": {
             "type": "string",
-            "description": "Gets or sets the app store url.",
-            "nullable": true
-          },
-          "IconUrl": {
-            "type": "string",
-            "description": "Gets or sets the icon url.",
+            "description": "Gets or sets view option id.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Client capabilities dto."
+        "description": "Special view option dto."
       },
       "StartupConfigurationDto": {
         "type": "object",
@@ -53758,23 +56422,6 @@
         "additionalProperties": false,
         "description": "The startup configuration DTO."
       },
-      "StartupUserDto": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the username.",
-            "nullable": true
-          },
-          "Password": {
-            "type": "string",
-            "description": "Gets or sets the user's password.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "The startup user DTO."
-      },
       "StartupRemoteAccessDto": {
         "required": [
           "EnableAutomaticPortMapping",
@@ -53794,164 +56441,24 @@
         "additionalProperties": false,
         "description": "Startup remote access dto."
       },
-      "FontFile": {
+      "StartupUserDto": {
         "type": "object",
         "properties": {
           "Name": {
             "type": "string",
-            "description": "Gets or sets the name.",
+            "description": "Gets or sets the username.",
             "nullable": true
           },
-          "Size": {
-            "type": "integer",
-            "description": "Gets or sets the size.",
-            "format": "int64"
-          },
-          "DateCreated": {
+          "Password": {
             "type": "string",
-            "description": "Gets or sets the date created.",
-            "format": "date-time"
-          },
-          "DateModified": {
-            "type": "string",
-            "description": "Gets or sets the date modified.",
-            "format": "date-time"
+            "description": "Gets or sets the user's password.",
+            "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Class FontFile."
+        "description": "The startup user DTO."
       },
-      "RemoteSubtitleInfo": {
-        "type": "object",
-        "properties": {
-          "ThreeLetterISOLanguageName": {
-            "type": "string",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "nullable": true
-          },
-          "ProviderName": {
-            "type": "string",
-            "nullable": true
-          },
-          "Name": {
-            "type": "string",
-            "nullable": true
-          },
-          "Format": {
-            "type": "string",
-            "nullable": true
-          },
-          "Author": {
-            "type": "string",
-            "nullable": true
-          },
-          "Comment": {
-            "type": "string",
-            "nullable": true
-          },
-          "DateCreated": {
-            "type": "string",
-            "format": "date-time",
-            "nullable": true
-          },
-          "CommunityRating": {
-            "type": "number",
-            "format": "float",
-            "nullable": true
-          },
-          "DownloadCount": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "IsHashMatch": {
-            "type": "boolean",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "UploadSubtitleDto": {
-        "required": [
-          "Data",
-          "Format",
-          "IsForced",
-          "Language"
-        ],
-        "type": "object",
-        "properties": {
-          "Language": {
-            "type": "string",
-            "description": "Gets or sets the subtitle language."
-          },
-          "Format": {
-            "type": "string",
-            "description": "Gets or sets the subtitle format."
-          },
-          "IsForced": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the subtitle is forced."
-          },
-          "Data": {
-            "type": "string",
-            "description": "Gets or sets the subtitle data."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Upload subtitles dto."
-      },
-      "BufferRequestDto": {
-        "type": "object",
-        "properties": {
-          "When": {
-            "type": "string",
-            "description": "Gets or sets when the request has been made by the client.",
-            "format": "date-time"
-          },
-          "PositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the position ticks.",
-            "format": "int64"
-          },
-          "IsPlaying": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the client playback is unpaused."
-          },
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playlist item identifier of the playing item.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class BufferRequestDto."
-      },
-      "JoinGroupRequestDto": {
-        "type": "object",
-        "properties": {
-          "GroupId": {
-            "type": "string",
-            "description": "Gets or sets the group identifier.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class JoinGroupRequestDto."
-      },
-      "GroupStateType": {
-        "enum": [
-          "Idle",
-          "Waiting",
-          "Paused",
-          "Playing"
-        ],
-        "type": "string",
-        "description": "Enum GroupState."
-      },
-      "GroupInfoDto": {
+      "StringGroupUpdate": {
         "type": "object",
         "properties": {
           "GroupId": {
@@ -53960,332 +56467,298 @@
             "format": "uuid",
             "readOnly": true
           },
-          "GroupName": {
+          "Type": {
+            "enum": [
+              "UserJoined",
+              "UserLeft",
+              "GroupJoined",
+              "GroupLeft",
+              "StateUpdate",
+              "PlayQueue",
+              "NotInGroup",
+              "GroupDoesNotExist",
+              "CreateGroupDenied",
+              "JoinGroupDenied",
+              "LibraryAccessDenied"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdateType"
+              }
+            ],
+            "description": "Gets the update type."
+          },
+          "Data": {
             "type": "string",
-            "description": "Gets the group name.",
-            "nullable": true,
-            "readOnly": true
+            "description": "Gets the update data."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class GroupUpdate."
+      },
+      "SubtitleDeliveryMethod": {
+        "enum": [
+          "Encode",
+          "Embed",
+          "External",
+          "Hls",
+          "Drop"
+        ],
+        "type": "string",
+        "description": "Delivery method to use during playback of a specific subtitle format."
+      },
+      "SubtitleOptions": {
+        "type": "object",
+        "properties": {
+          "SkipIfEmbeddedSubtitlesPresent": {
+            "type": "boolean"
           },
-          "State": {
-            "$ref": "#/components/schemas/GroupStateType"
+          "SkipIfAudioTrackMatches": {
+            "type": "boolean"
           },
-          "Participants": {
+          "DownloadLanguages": {
             "type": "array",
             "items": {
               "type": "string"
             },
-            "description": "Gets the participants.",
-            "nullable": true,
-            "readOnly": true
-          },
-          "LastUpdatedAt": {
-            "type": "string",
-            "description": "Gets the date when this DTO has been created.",
-            "format": "date-time",
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class GroupInfoDto."
-      },
-      "MovePlaylistItemRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playlist identifier of the item.",
-            "format": "uuid"
-          },
-          "NewIndex": {
-            "type": "integer",
-            "description": "Gets or sets the new position.",
-            "format": "int32"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class MovePlaylistItemRequestDto."
-      },
-      "NewGroupRequestDto": {
-        "type": "object",
-        "properties": {
-          "GroupName": {
-            "type": "string",
-            "description": "Gets or sets the group name.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class NewGroupRequestDto."
-      },
-      "NextItemRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playing item identifier.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class NextItemRequestDto."
-      },
-      "PingRequestDto": {
-        "type": "object",
-        "properties": {
-          "Ping": {
-            "type": "integer",
-            "description": "Gets or sets the ping time.",
-            "format": "int64"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class PingRequestDto."
-      },
-      "PreviousItemRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playing item identifier.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class PreviousItemRequestDto."
-      },
-      "GroupQueueMode": {
-        "enum": [
-          "Queue",
-          "QueueNext"
-        ],
-        "type": "string",
-        "description": "Enum GroupQueueMode."
-      },
-      "QueueRequestDto": {
-        "type": "object",
-        "properties": {
-          "ItemIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the items to enqueue.",
             "nullable": true
           },
-          "Mode": {
-            "$ref": "#/components/schemas/GroupQueueMode"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class QueueRequestDto."
-      },
-      "ReadyRequestDto": {
-        "type": "object",
-        "properties": {
-          "When": {
-            "type": "string",
-            "description": "Gets or sets when the request has been made by the client.",
-            "format": "date-time"
-          },
-          "PositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the position ticks.",
-            "format": "int64"
-          },
-          "IsPlaying": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the client playback is unpaused."
-          },
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playlist item identifier of the playing item.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class ReadyRequest."
-      },
-      "RemoveFromPlaylistRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlaylistItemIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the playlist identifiers ot the items.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class RemoveFromPlaylistRequestDto."
-      },
-      "SeekRequestDto": {
-        "type": "object",
-        "properties": {
-          "PositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the position ticks.",
-            "format": "int64"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SeekRequestDto."
-      },
-      "IgnoreWaitRequestDto": {
-        "type": "object",
-        "properties": {
-          "IgnoreWait": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether the client should be ignored."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class IgnoreWaitRequestDto."
-      },
-      "PlayRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlayingQueue": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the playing queue.",
-            "nullable": true
-          },
-          "PlayingItemPosition": {
-            "type": "integer",
-            "description": "Gets or sets the position of the playing item in the queue.",
-            "format": "int32"
-          },
-          "StartPositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the start position ticks.",
-            "format": "int64"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class PlayRequestDto."
-      },
-      "SetPlaylistItemRequestDto": {
-        "type": "object",
-        "properties": {
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets or sets the playlist identifier of the playing item.",
-            "format": "uuid"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SetPlaylistItemRequestDto."
-      },
-      "GroupRepeatMode": {
-        "enum": [
-          "RepeatOne",
-          "RepeatAll",
-          "RepeatNone"
-        ],
-        "type": "string",
-        "description": "Enum GroupRepeatMode."
-      },
-      "SetRepeatModeRequestDto": {
-        "type": "object",
-        "properties": {
-          "Mode": {
-            "$ref": "#/components/schemas/GroupRepeatMode"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SetRepeatModeRequestDto."
-      },
-      "GroupShuffleMode": {
-        "enum": [
-          "Sorted",
-          "Shuffle"
-        ],
-        "type": "string",
-        "description": "Enum GroupShuffleMode."
-      },
-      "SetShuffleModeRequestDto": {
-        "type": "object",
-        "properties": {
-          "Mode": {
-            "$ref": "#/components/schemas/GroupShuffleMode"
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SetShuffleModeRequestDto."
-      },
-      "EndPointInfo": {
-        "type": "object",
-        "properties": {
-          "IsLocal": {
+          "DownloadMovieSubtitles": {
             "type": "boolean"
           },
-          "IsInNetwork": {
+          "DownloadEpisodeSubtitles": {
+            "type": "boolean"
+          },
+          "OpenSubtitlesUsername": {
+            "type": "string",
+            "nullable": true
+          },
+          "OpenSubtitlesPasswordHash": {
+            "type": "string",
+            "nullable": true
+          },
+          "IsOpenSubtitleVipAccount": {
+            "type": "boolean"
+          },
+          "RequirePerfectMatch": {
             "type": "boolean"
           }
         },
         "additionalProperties": false
       },
-      "InstallationInfo": {
+      "SubtitlePlaybackMode": {
+        "enum": [
+          "Default",
+          "Always",
+          "OnlyForced",
+          "None",
+          "Smart"
+        ],
+        "type": "string",
+        "description": "An enum representing a subtitle playback mode."
+      },
+      "SubtitleProfile": {
         "type": "object",
         "properties": {
-          "Guid": {
+          "Format": {
             "type": "string",
-            "description": "Gets or sets the Id.",
-            "format": "uuid"
-          },
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the name.",
+            "description": "Gets or sets the format.",
             "nullable": true
           },
-          "Version": {
-            "$ref": "#/components/schemas/Version"
+          "Method": {
+            "enum": [
+              "Encode",
+              "Embed",
+              "External",
+              "Hls",
+              "Drop"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SubtitleDeliveryMethod"
+              }
+            ],
+            "description": "Gets or sets the delivery method."
           },
-          "Changelog": {
+          "DidlMode": {
             "type": "string",
-            "description": "Gets or sets the changelog for this version.",
+            "description": "Gets or sets the DIDL mode.",
             "nullable": true
           },
-          "SourceUrl": {
+          "Language": {
             "type": "string",
-            "description": "Gets or sets the source URL.",
+            "description": "Gets or sets the language.",
             "nullable": true
           },
-          "Checksum": {
+          "Container": {
             "type": "string",
-            "description": "Gets or sets a checksum for the binary.",
+            "description": "Gets or sets the container.",
             "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Class InstallationInfo."
+        "description": "A class for subtitle profile information."
       },
-      "FFmpegLocation": {
+      "SyncPlayCommandMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SendCommand"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SyncPlayCommand",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Sync play command."
+      },
+      "SyncPlayGroupUpdateCommandMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/GroupUpdate"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "SyncPlayGroupUpdate",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Untyped sync play command."
+      },
+      "SyncPlayQueueItem": {
+        "type": "object",
+        "properties": {
+          "ItemId": {
+            "type": "string",
+            "description": "Gets the item identifier.",
+            "format": "uuid"
+          },
+          "PlaylistItemId": {
+            "type": "string",
+            "description": "Gets the playlist identifier of the item.",
+            "format": "uuid",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class QueueItem."
+      },
+      "SyncPlayUserAccessType": {
         "enum": [
-          "NotFound",
-          "SetByArgument",
-          "Custom",
-          "System"
+          "CreateAndJoinGroups",
+          "JoinGroups",
+          "None"
         ],
         "type": "string",
-        "description": "Enum describing the location of the FFmpeg tool."
-      },
-      "Architecture": {
-        "enum": [
-          "X86",
-          "X64",
-          "Arm",
-          "Arm64",
-          "Wasm"
-        ],
-        "type": "string"
+        "description": "Enum SyncPlayUserAccessType."
       },
       "SystemInfo": {
         "type": "object",
@@ -54313,7 +56786,8 @@
           "OperatingSystem": {
             "type": "string",
             "description": "Gets or sets the operating system.",
-            "nullable": true
+            "nullable": true,
+            "deprecated": true
           },
           "Id": {
             "type": "string",
@@ -54328,11 +56802,12 @@
           "OperatingSystemDisplayName": {
             "type": "string",
             "description": "Gets or sets the display name of the operating system.",
-            "nullable": true
+            "nullable": true,
+            "deprecated": true
           },
           "PackageName": {
             "type": "string",
-            "description": "Get or sets the package name.",
+            "description": "Gets or sets the package name.",
             "nullable": true
           },
           "HasPendingRestart": {
@@ -54361,10 +56836,14 @@
           },
           "CanSelfRestart": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance can self restart."
+            "description": "Gets or sets a value indicating whether this instance can self restart.",
+            "default": true,
+            "deprecated": true
           },
           "CanLaunchWebBrowser": {
-            "type": "boolean"
+            "type": "boolean",
+            "default": false,
+            "deprecated": true
           },
           "ProgramDataPath": {
             "type": "string",
@@ -54401,46 +56880,71 @@
             "description": "Gets or sets the transcode path.",
             "nullable": true
           },
+          "CastReceiverApplications": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/CastReceiverApplication"
+            },
+            "description": "Gets or sets the list of cast receiver applications.",
+            "nullable": true
+          },
           "HasUpdateAvailable": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance has update available."
+            "description": "Gets or sets a value indicating whether this instance has update available.",
+            "default": false,
+            "deprecated": true
           },
           "EncoderLocation": {
-            "$ref": "#/components/schemas/FFmpegLocation"
+            "type": "string",
+            "default": "System",
+            "nullable": true,
+            "deprecated": true
           },
           "SystemArchitecture": {
-            "$ref": "#/components/schemas/Architecture"
+            "type": "string",
+            "default": "X64",
+            "nullable": true,
+            "deprecated": true
           }
         },
         "additionalProperties": false,
         "description": "Class SystemInfo."
       },
-      "PublicSystemInfo": {
+      "TaskCompletionStatus": {
+        "enum": [
+          "Completed",
+          "Failed",
+          "Cancelled",
+          "Aborted"
+        ],
+        "type": "string",
+        "description": "Enum TaskCompletionStatus."
+      },
+      "TaskInfo": {
         "type": "object",
         "properties": {
-          "LocalAddress": {
+          "Name": {
             "type": "string",
-            "description": "Gets or sets the local address.",
+            "description": "Gets or sets the name.",
             "nullable": true
           },
-          "ServerName": {
-            "type": "string",
-            "description": "Gets or sets the name of the server.",
-            "nullable": true
+          "State": {
+            "enum": [
+              "Idle",
+              "Cancelling",
+              "Running"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TaskState"
+              }
+            ],
+            "description": "Gets or sets the state of the task."
           },
-          "Version": {
-            "type": "string",
-            "description": "Gets or sets the server version.",
-            "nullable": true
-          },
-          "ProductName": {
-            "type": "string",
-            "description": "Gets or sets the product name. This is the AssemblyProduct name.",
-            "nullable": true
-          },
-          "OperatingSystem": {
-            "type": "string",
-            "description": "Gets or sets the operating system.",
+          "CurrentProgressPercentage": {
+            "type": "number",
+            "description": "Gets or sets the progress.",
+            "format": "double",
             "nullable": true
           },
           "Id": {
@@ -54448,86 +56952,1441 @@
             "description": "Gets or sets the id.",
             "nullable": true
           },
-          "StartupWizardCompleted": {
+          "LastExecutionResult": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TaskResult"
+              }
+            ],
+            "description": "Gets or sets the last execution result.",
+            "nullable": true
+          },
+          "Triggers": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TaskTriggerInfo"
+            },
+            "description": "Gets or sets the triggers.",
+            "nullable": true
+          },
+          "Description": {
+            "type": "string",
+            "description": "Gets or sets the description.",
+            "nullable": true
+          },
+          "Category": {
+            "type": "string",
+            "description": "Gets or sets the category.",
+            "nullable": true
+          },
+          "IsHidden": {
             "type": "boolean",
-            "description": "Gets or sets a value indicating whether the startup wizard is completed.",
+            "description": "Gets or sets a value indicating whether this instance is hidden."
+          },
+          "Key": {
+            "type": "string",
+            "description": "Gets or sets the key.",
             "nullable": true
           }
         },
-        "additionalProperties": false
+        "additionalProperties": false,
+        "description": "Class TaskInfo."
       },
-      "LogFile": {
+      "TaskResult": {
         "type": "object",
         "properties": {
-          "DateCreated": {
+          "StartTimeUtc": {
             "type": "string",
-            "description": "Gets or sets the date created.",
+            "description": "Gets or sets the start time UTC.",
             "format": "date-time"
           },
-          "DateModified": {
+          "EndTimeUtc": {
             "type": "string",
-            "description": "Gets or sets the date modified.",
+            "description": "Gets or sets the end time UTC.",
             "format": "date-time"
           },
-          "Size": {
-            "type": "integer",
-            "description": "Gets or sets the size.",
-            "format": "int64"
+          "Status": {
+            "enum": [
+              "Completed",
+              "Failed",
+              "Cancelled",
+              "Aborted"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TaskCompletionStatus"
+              }
+            ],
+            "description": "Gets or sets the status."
           },
           "Name": {
             "type": "string",
             "description": "Gets or sets the name.",
             "nullable": true
+          },
+          "Key": {
+            "type": "string",
+            "description": "Gets or sets the key.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the id.",
+            "nullable": true
+          },
+          "ErrorMessage": {
+            "type": "string",
+            "description": "Gets or sets the error message.",
+            "nullable": true
+          },
+          "LongErrorMessage": {
+            "type": "string",
+            "description": "Gets or sets the long error message.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class TaskExecutionInfo."
+      },
+      "TaskState": {
+        "enum": [
+          "Idle",
+          "Cancelling",
+          "Running"
+        ],
+        "type": "string",
+        "description": "Enum TaskState."
+      },
+      "TaskTriggerInfo": {
+        "type": "object",
+        "properties": {
+          "Type": {
+            "type": "string",
+            "description": "Gets or sets the type.",
+            "nullable": true
+          },
+          "TimeOfDayTicks": {
+            "type": "integer",
+            "description": "Gets or sets the time of day.",
+            "format": "int64",
+            "nullable": true
+          },
+          "IntervalTicks": {
+            "type": "integer",
+            "description": "Gets or sets the interval.",
+            "format": "int64",
+            "nullable": true
+          },
+          "DayOfWeek": {
+            "enum": [
+              "Sunday",
+              "Monday",
+              "Tuesday",
+              "Wednesday",
+              "Thursday",
+              "Friday",
+              "Saturday"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DayOfWeek"
+              }
+            ],
+            "description": "Gets or sets the day of week.",
+            "nullable": true
+          },
+          "MaxRuntimeTicks": {
+            "type": "integer",
+            "description": "Gets or sets the maximum runtime ticks.",
+            "format": "int64",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class TaskTriggerInfo."
+      },
+      "ThemeMediaResult": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/BaseItemDto"
+            },
+            "description": "Gets or sets the items."
+          },
+          "TotalRecordCount": {
+            "type": "integer",
+            "description": "Gets or sets the total number of records available.",
+            "format": "int32"
+          },
+          "StartIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the first record in Items.",
+            "format": "int32"
+          },
+          "OwnerId": {
+            "type": "string",
+            "description": "Gets or sets the owner id.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class ThemeMediaResult."
+      },
+      "TimerCancelledMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TimerEventInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "TimerCancelled",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Timer cancelled message."
+      },
+      "TimerCreatedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TimerEventInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "TimerCreated",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Timer created message."
+      },
+      "TimerEventInfo": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string"
+          },
+          "ProgramId": {
+            "type": "string",
+            "format": "uuid",
+            "nullable": true
           }
         },
         "additionalProperties": false
       },
-      "WakeOnLanInfo": {
+      "TimerInfoDto": {
         "type": "object",
         "properties": {
-          "MacAddress": {
+          "Id": {
             "type": "string",
-            "description": "Gets the MAC address of the device.",
+            "description": "Gets or sets the Id of the recording.",
             "nullable": true
           },
-          "Port": {
+          "Type": {
+            "type": "string",
+            "nullable": true
+          },
+          "ServerId": {
+            "type": "string",
+            "description": "Gets or sets the server identifier.",
+            "nullable": true
+          },
+          "ExternalId": {
+            "type": "string",
+            "description": "Gets or sets the external identifier.",
+            "nullable": true
+          },
+          "ChannelId": {
+            "type": "string",
+            "description": "Gets or sets the channel id of the recording.",
+            "format": "uuid"
+          },
+          "ExternalChannelId": {
+            "type": "string",
+            "description": "Gets or sets the external channel identifier.",
+            "nullable": true
+          },
+          "ChannelName": {
+            "type": "string",
+            "description": "Gets or sets the channel name of the recording.",
+            "nullable": true
+          },
+          "ChannelPrimaryImageTag": {
+            "type": "string",
+            "nullable": true
+          },
+          "ProgramId": {
+            "type": "string",
+            "description": "Gets or sets the program identifier.",
+            "nullable": true
+          },
+          "ExternalProgramId": {
+            "type": "string",
+            "description": "Gets or sets the external program identifier.",
+            "nullable": true
+          },
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of the recording.",
+            "nullable": true
+          },
+          "Overview": {
+            "type": "string",
+            "description": "Gets or sets the description of the recording.",
+            "nullable": true
+          },
+          "StartDate": {
+            "type": "string",
+            "description": "Gets or sets the start date of the recording, in UTC.",
+            "format": "date-time"
+          },
+          "EndDate": {
+            "type": "string",
+            "description": "Gets or sets the end date of the recording, in UTC.",
+            "format": "date-time"
+          },
+          "ServiceName": {
+            "type": "string",
+            "description": "Gets or sets the name of the service.",
+            "nullable": true
+          },
+          "Priority": {
             "type": "integer",
-            "description": "Gets or sets the wake-on-LAN port.",
+            "description": "Gets or sets the priority.",
+            "format": "int32"
+          },
+          "PrePaddingSeconds": {
+            "type": "integer",
+            "description": "Gets or sets the pre padding seconds.",
+            "format": "int32"
+          },
+          "PostPaddingSeconds": {
+            "type": "integer",
+            "description": "Gets or sets the post padding seconds.",
+            "format": "int32"
+          },
+          "IsPrePaddingRequired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is pre padding required."
+          },
+          "ParentBackdropItemId": {
+            "type": "string",
+            "description": "Gets or sets the Id of the Parent that has a backdrop if the item does not have one.",
+            "nullable": true
+          },
+          "ParentBackdropImageTags": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the parent backdrop image tags.",
+            "nullable": true
+          },
+          "IsPostPaddingRequired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is post padding required."
+          },
+          "KeepUntil": {
+            "enum": [
+              "UntilDeleted",
+              "UntilSpaceNeeded",
+              "UntilWatched",
+              "UntilDate"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/KeepUntil"
+              }
+            ]
+          },
+          "Status": {
+            "enum": [
+              "New",
+              "InProgress",
+              "Completed",
+              "Cancelled",
+              "ConflictedOk",
+              "ConflictedNotOk",
+              "Error"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/RecordingStatus"
+              }
+            ],
+            "description": "Gets or sets the status."
+          },
+          "SeriesTimerId": {
+            "type": "string",
+            "description": "Gets or sets the series timer identifier.",
+            "nullable": true
+          },
+          "ExternalSeriesTimerId": {
+            "type": "string",
+            "description": "Gets or sets the external series timer identifier.",
+            "nullable": true
+          },
+          "RunTimeTicks": {
+            "type": "integer",
+            "description": "Gets or sets the run time ticks.",
+            "format": "int64",
+            "nullable": true
+          },
+          "ProgramInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/BaseItemDto"
+              }
+            ],
+            "description": "Gets or sets the program information.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "TimerInfoDtoQueryResult": {
+        "type": "object",
+        "properties": {
+          "Items": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TimerInfoDto"
+            },
+            "description": "Gets or sets the items."
+          },
+          "TotalRecordCount": {
+            "type": "integer",
+            "description": "Gets or sets the total number of records available.",
+            "format": "int32"
+          },
+          "StartIndex": {
+            "type": "integer",
+            "description": "Gets or sets the index of the first record in Items.",
             "format": "int32"
           }
         },
         "additionalProperties": false,
-        "description": "Provides the MAC address and port for wake-on-LAN functionality."
+        "description": "Query result container."
       },
-      "UtcTimeResponse": {
+      "TonemappingAlgorithm": {
+        "enum": [
+          "none",
+          "clip",
+          "linear",
+          "gamma",
+          "reinhard",
+          "hable",
+          "mobius",
+          "bt2390"
+        ],
+        "type": "string",
+        "description": "Enum containing tonemapping algorithms."
+      },
+      "TonemappingMode": {
+        "enum": [
+          "auto",
+          "max",
+          "rgb",
+          "lum",
+          "itp"
+        ],
+        "type": "string",
+        "description": "Enum containing tonemapping modes."
+      },
+      "TonemappingRange": {
+        "enum": [
+          "auto",
+          "tv",
+          "pc"
+        ],
+        "type": "string",
+        "description": "Enum containing tonemapping ranges."
+      },
+      "TrailerInfo": {
         "type": "object",
         "properties": {
-          "RequestReceptionTime": {
+          "Name": {
             "type": "string",
-            "description": "Gets the UTC time when request has been received.",
-            "format": "date-time",
-            "readOnly": true
+            "description": "Gets or sets the name.",
+            "nullable": true
           },
-          "ResponseTransmissionTime": {
+          "OriginalTitle": {
+            "type": "string",
+            "description": "Gets or sets the original title.",
+            "nullable": true
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "MetadataLanguage": {
+            "type": "string",
+            "description": "Gets or sets the metadata language.",
+            "nullable": true
+          },
+          "MetadataCountryCode": {
+            "type": "string",
+            "description": "Gets or sets the metadata country code.",
+            "nullable": true
+          },
+          "ProviderIds": {
+            "type": "object",
+            "additionalProperties": {
+              "type": "string",
+              "nullable": true
+            },
+            "description": "Gets or sets the provider ids.",
+            "nullable": true
+          },
+          "Year": {
+            "type": "integer",
+            "description": "Gets or sets the year.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "ParentIndexNumber": {
+            "type": "integer",
+            "format": "int32",
+            "nullable": true
+          },
+          "PremiereDate": {
             "type": "string",
-            "description": "Gets the UTC time when response has been sent.",
             "format": "date-time",
-            "readOnly": true
+            "nullable": true
+          },
+          "IsAutomated": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "TrailerInfoRemoteSearchQuery": {
+        "type": "object",
+        "properties": {
+          "SearchInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TrailerInfo"
+              }
+            ],
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "format": "uuid"
+          },
+          "SearchProviderName": {
+            "type": "string",
+            "description": "Gets or sets the provider name to search within if set.",
+            "nullable": true
+          },
+          "IncludeDisabledProviders": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether disabled providers should be included."
+          }
+        },
+        "additionalProperties": false
+      },
+      "TranscodeReason": {
+        "enum": [
+          "ContainerNotSupported",
+          "VideoCodecNotSupported",
+          "AudioCodecNotSupported",
+          "SubtitleCodecNotSupported",
+          "AudioIsExternal",
+          "SecondaryAudioNotSupported",
+          "VideoProfileNotSupported",
+          "VideoLevelNotSupported",
+          "VideoResolutionNotSupported",
+          "VideoBitDepthNotSupported",
+          "VideoFramerateNotSupported",
+          "RefFramesNotSupported",
+          "AnamorphicVideoNotSupported",
+          "InterlacedVideoNotSupported",
+          "AudioChannelsNotSupported",
+          "AudioProfileNotSupported",
+          "AudioSampleRateNotSupported",
+          "AudioBitDepthNotSupported",
+          "ContainerBitrateExceedsLimit",
+          "VideoBitrateNotSupported",
+          "AudioBitrateNotSupported",
+          "UnknownVideoStreamInfo",
+          "UnknownAudioStreamInfo",
+          "DirectPlayError",
+          "VideoRangeTypeNotSupported",
+          "VideoCodecTagNotSupported"
+        ],
+        "type": "string"
+      },
+      "TranscodeSeekInfo": {
+        "enum": [
+          "Auto",
+          "Bytes"
+        ],
+        "type": "string"
+      },
+      "TranscodingInfo": {
+        "type": "object",
+        "properties": {
+          "AudioCodec": {
+            "type": "string",
+            "description": "Gets or sets the thread count used for encoding.",
+            "nullable": true
+          },
+          "VideoCodec": {
+            "type": "string",
+            "description": "Gets or sets the thread count used for encoding.",
+            "nullable": true
+          },
+          "Container": {
+            "type": "string",
+            "description": "Gets or sets the thread count used for encoding.",
+            "nullable": true
+          },
+          "IsVideoDirect": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the video is passed through."
+          },
+          "IsAudioDirect": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the audio is passed through."
+          },
+          "Bitrate": {
+            "type": "integer",
+            "description": "Gets or sets the bitrate.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Framerate": {
+            "type": "number",
+            "description": "Gets or sets the framerate.",
+            "format": "float",
+            "nullable": true
+          },
+          "CompletionPercentage": {
+            "type": "number",
+            "description": "Gets or sets the completion percentage.",
+            "format": "double",
+            "nullable": true
+          },
+          "Width": {
+            "type": "integer",
+            "description": "Gets or sets the video width.",
+            "format": "int32",
+            "nullable": true
+          },
+          "Height": {
+            "type": "integer",
+            "description": "Gets or sets the video height.",
+            "format": "int32",
+            "nullable": true
+          },
+          "AudioChannels": {
+            "type": "integer",
+            "description": "Gets or sets the audio channels.",
+            "format": "int32",
+            "nullable": true
+          },
+          "HardwareAccelerationType": {
+            "enum": [
+              "none",
+              "amf",
+              "qsv",
+              "nvenc",
+              "v4l2m2m",
+              "vaapi",
+              "videotoolbox",
+              "rkmpp"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/HardwareAccelerationType"
+              }
+            ],
+            "description": "Gets or sets the hardware acceleration type.",
+            "nullable": true
+          },
+          "TranscodeReasons": {
+            "enum": [
+              "ContainerNotSupported",
+              "VideoCodecNotSupported",
+              "AudioCodecNotSupported",
+              "SubtitleCodecNotSupported",
+              "AudioIsExternal",
+              "SecondaryAudioNotSupported",
+              "VideoProfileNotSupported",
+              "VideoLevelNotSupported",
+              "VideoResolutionNotSupported",
+              "VideoBitDepthNotSupported",
+              "VideoFramerateNotSupported",
+              "RefFramesNotSupported",
+              "AnamorphicVideoNotSupported",
+              "InterlacedVideoNotSupported",
+              "AudioChannelsNotSupported",
+              "AudioProfileNotSupported",
+              "AudioSampleRateNotSupported",
+              "AudioBitDepthNotSupported",
+              "ContainerBitrateExceedsLimit",
+              "VideoBitrateNotSupported",
+              "AudioBitrateNotSupported",
+              "UnknownVideoStreamInfo",
+              "UnknownAudioStreamInfo",
+              "DirectPlayError",
+              "VideoRangeTypeNotSupported",
+              "VideoCodecTagNotSupported"
+            ],
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/TranscodeReason"
+            },
+            "description": "Gets or sets the transcode reasons."
           }
         },
         "additionalProperties": false,
-        "description": "Class UtcTimeResponse."
+        "description": "Class holding information on a runnning transcode."
       },
-      "SubtitlePlaybackMode": {
+      "TranscodingProfile": {
+        "type": "object",
+        "properties": {
+          "Container": {
+            "type": "string",
+            "description": "Gets or sets the container."
+          },
+          "Type": {
+            "enum": [
+              "Audio",
+              "Video",
+              "Photo",
+              "Subtitle",
+              "Lyric"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/DlnaProfileType"
+              }
+            ],
+            "description": "Gets or sets the DLNA profile type."
+          },
+          "VideoCodec": {
+            "type": "string",
+            "description": "Gets or sets the video codec."
+          },
+          "AudioCodec": {
+            "type": "string",
+            "description": "Gets or sets the audio codec."
+          },
+          "Protocol": {
+            "enum": [
+              "http",
+              "hls"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaStreamProtocol"
+              }
+            ],
+            "description": "Media streaming protocol.\r\nLowercase for backwards compatibility."
+          },
+          "EstimateContentLength": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the content length should be estimated.",
+            "default": false
+          },
+          "EnableMpegtsM2TsMode": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether M2TS mode is enabled.",
+            "default": false
+          },
+          "TranscodeSeekInfo": {
+            "enum": [
+              "Auto",
+              "Bytes"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TranscodeSeekInfo"
+              }
+            ],
+            "description": "Gets or sets the transcoding seek info mode.",
+            "default": "Auto"
+          },
+          "CopyTimestamps": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether timestamps should be copied.",
+            "default": false
+          },
+          "Context": {
+            "enum": [
+              "Streaming",
+              "Static"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/EncodingContext"
+              }
+            ],
+            "description": "Gets or sets the encoding context.",
+            "default": "Streaming"
+          },
+          "EnableSubtitlesInManifest": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether subtitles are allowed in the manifest.",
+            "default": false
+          },
+          "MaxAudioChannels": {
+            "type": "string",
+            "description": "Gets or sets the maximum audio channels.",
+            "nullable": true
+          },
+          "MinSegments": {
+            "type": "integer",
+            "description": "Gets or sets the minimum amount of segments.",
+            "format": "int32",
+            "default": 0
+          },
+          "SegmentLength": {
+            "type": "integer",
+            "description": "Gets or sets the segment length.",
+            "format": "int32",
+            "default": 0
+          },
+          "BreakOnNonKeyFrames": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether breaking the video stream on non-keyframes is supported.",
+            "default": false
+          },
+          "Conditions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ProfileCondition"
+            },
+            "description": "Gets or sets the profile conditions."
+          },
+          "EnableAudioVbrEncoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether variable bitrate encoding is supported.",
+            "default": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "A class for transcoding profile information.\r\nNote for client developers: Conditions defined in MediaBrowser.Model.Dlna.CodecProfile has higher priority and can override values defined here."
+      },
+      "TransportStreamTimestamp": {
         "enum": [
-          "Default",
-          "Always",
-          "OnlyForced",
           "None",
-          "Smart"
+          "Zero",
+          "Valid"
+        ],
+        "type": "string"
+      },
+      "TrickplayInfo": {
+        "type": "object",
+        "properties": {
+          "Width": {
+            "type": "integer",
+            "description": "Gets or sets width of an individual thumbnail.",
+            "format": "int32"
+          },
+          "Height": {
+            "type": "integer",
+            "description": "Gets or sets height of an individual thumbnail.",
+            "format": "int32"
+          },
+          "TileWidth": {
+            "type": "integer",
+            "description": "Gets or sets amount of thumbnails per row.",
+            "format": "int32"
+          },
+          "TileHeight": {
+            "type": "integer",
+            "description": "Gets or sets amount of thumbnails per column.",
+            "format": "int32"
+          },
+          "ThumbnailCount": {
+            "type": "integer",
+            "description": "Gets or sets total amount of non-black thumbnails.",
+            "format": "int32"
+          },
+          "Interval": {
+            "type": "integer",
+            "description": "Gets or sets interval in milliseconds between each trickplay thumbnail.",
+            "format": "int32"
+          },
+          "Bandwidth": {
+            "type": "integer",
+            "description": "Gets or sets peak bandwith usage in bits per second.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "An entity representing the metadata for a group of trickplay tiles."
+      },
+      "TrickplayOptions": {
+        "type": "object",
+        "properties": {
+          "EnableHwAcceleration": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether or not to use HW acceleration."
+          },
+          "EnableHwEncoding": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether or not to use HW accelerated MJPEG encoding."
+          },
+          "EnableKeyFrameOnlyExtraction": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to only extract key frames.\r\nSignificantly faster, but is not compatible with all decoders and/or video files."
+          },
+          "ScanBehavior": {
+            "enum": [
+              "Blocking",
+              "NonBlocking"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/TrickplayScanBehavior"
+              }
+            ],
+            "description": "Gets or sets the behavior used by trickplay provider on library scan/update."
+          },
+          "ProcessPriority": {
+            "enum": [
+              "Normal",
+              "Idle",
+              "High",
+              "RealTime",
+              "BelowNormal",
+              "AboveNormal"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/ProcessPriorityClass"
+              }
+            ],
+            "description": "Gets or sets the process priority for the ffmpeg process."
+          },
+          "Interval": {
+            "type": "integer",
+            "description": "Gets or sets the interval, in ms, between each new trickplay image.",
+            "format": "int32"
+          },
+          "WidthResolutions": {
+            "type": "array",
+            "items": {
+              "type": "integer",
+              "format": "int32"
+            },
+            "description": "Gets or sets the target width resolutions, in px, to generates preview images for."
+          },
+          "TileWidth": {
+            "type": "integer",
+            "description": "Gets or sets number of tile images to allow in X dimension.",
+            "format": "int32"
+          },
+          "TileHeight": {
+            "type": "integer",
+            "description": "Gets or sets number of tile images to allow in Y dimension.",
+            "format": "int32"
+          },
+          "Qscale": {
+            "type": "integer",
+            "description": "Gets or sets the ffmpeg output quality level.",
+            "format": "int32"
+          },
+          "JpegQuality": {
+            "type": "integer",
+            "description": "Gets or sets the jpeg quality to use for image tiles.",
+            "format": "int32"
+          },
+          "ProcessThreads": {
+            "type": "integer",
+            "description": "Gets or sets the number of threads to be used by ffmpeg.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class TrickplayOptions."
+      },
+      "TrickplayScanBehavior": {
+        "enum": [
+          "Blocking",
+          "NonBlocking"
         ],
         "type": "string",
-        "description": "An enum representing a subtitle playback mode."
+        "description": "Enum TrickplayScanBehavior."
+      },
+      "TunerChannelMapping": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "nullable": true
+          },
+          "ProviderChannelName": {
+            "type": "string",
+            "nullable": true
+          },
+          "ProviderChannelId": {
+            "type": "string",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "TunerHostInfo": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "nullable": true
+          },
+          "Url": {
+            "type": "string",
+            "nullable": true
+          },
+          "Type": {
+            "type": "string",
+            "nullable": true
+          },
+          "DeviceId": {
+            "type": "string",
+            "nullable": true
+          },
+          "FriendlyName": {
+            "type": "string",
+            "nullable": true
+          },
+          "ImportFavoritesOnly": {
+            "type": "boolean"
+          },
+          "AllowHWTranscoding": {
+            "type": "boolean"
+          },
+          "AllowFmp4TranscodingContainer": {
+            "type": "boolean"
+          },
+          "AllowStreamSharing": {
+            "type": "boolean"
+          },
+          "FallbackMaxStreamingBitrate": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "EnableStreamLooping": {
+            "type": "boolean"
+          },
+          "Source": {
+            "type": "string",
+            "nullable": true
+          },
+          "TunerCount": {
+            "type": "integer",
+            "format": "int32"
+          },
+          "UserAgent": {
+            "type": "string",
+            "nullable": true
+          },
+          "IgnoreDts": {
+            "type": "boolean"
+          }
+        },
+        "additionalProperties": false
+      },
+      "TypeOptions": {
+        "type": "object",
+        "properties": {
+          "Type": {
+            "type": "string",
+            "nullable": true
+          },
+          "MetadataFetchers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "MetadataFetcherOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "ImageFetchers": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "ImageFetcherOrder": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
+          "ImageOptions": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/ImageOption"
+            },
+            "nullable": true
+          }
+        },
+        "additionalProperties": false
+      },
+      "UnratedItem": {
+        "enum": [
+          "Movie",
+          "Trailer",
+          "Series",
+          "Music",
+          "Book",
+          "LiveTvChannel",
+          "LiveTvProgram",
+          "ChannelContent",
+          "Other"
+        ],
+        "type": "string",
+        "description": "An enum representing an unrated item."
+      },
+      "UpdateLibraryOptionsDto": {
+        "type": "object",
+        "properties": {
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the library item id.",
+            "format": "uuid"
+          },
+          "LibraryOptions": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LibraryOptions"
+              }
+            ],
+            "description": "Gets or sets library options.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Update library options dto."
+      },
+      "UpdateMediaPathRequestDto": {
+        "required": [
+          "Name",
+          "PathInfo"
+        ],
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the library name."
+          },
+          "PathInfo": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/MediaPathInfo"
+              }
+            ],
+            "description": "Gets or sets library folder path information."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Update library options dto."
+      },
+      "UpdatePlaylistDto": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name of the new playlist.",
+            "nullable": true
+          },
+          "Ids": {
+            "type": "array",
+            "items": {
+              "type": "string",
+              "format": "uuid"
+            },
+            "description": "Gets or sets item ids of the playlist.",
+            "nullable": true
+          },
+          "Users": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/PlaylistUserPermissions"
+            },
+            "description": "Gets or sets the playlist users.",
+            "nullable": true
+          },
+          "IsPublic": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the playlist is public.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Update existing playlist dto. Fields set to `null` will not be updated and keep their current values."
+      },
+      "UpdatePlaylistUserDto": {
+        "type": "object",
+        "properties": {
+          "CanEdit": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the user can edit the playlist.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Update existing playlist user dto. Fields set to `null` will not be updated and keep their current values."
+      },
+      "UpdateUserItemDataDto": {
+        "type": "object",
+        "properties": {
+          "Rating": {
+            "type": "number",
+            "description": "Gets or sets the rating.",
+            "format": "double",
+            "nullable": true
+          },
+          "PlayedPercentage": {
+            "type": "number",
+            "description": "Gets or sets the played percentage.",
+            "format": "double",
+            "nullable": true
+          },
+          "UnplayedItemCount": {
+            "type": "integer",
+            "description": "Gets or sets the unplayed item count.",
+            "format": "int32",
+            "nullable": true
+          },
+          "PlaybackPositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the playback position ticks.",
+            "format": "int64",
+            "nullable": true
+          },
+          "PlayCount": {
+            "type": "integer",
+            "description": "Gets or sets the play count.",
+            "format": "int32",
+            "nullable": true
+          },
+          "IsFavorite": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is favorite.",
+            "nullable": true
+          },
+          "Likes": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UpdateUserItemDataDto is likes.",
+            "nullable": true
+          },
+          "LastPlayedDate": {
+            "type": "string",
+            "description": "Gets or sets the last played date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "Played": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is played.",
+            "nullable": true
+          },
+          "Key": {
+            "type": "string",
+            "description": "Gets or sets the key.",
+            "nullable": true
+          },
+          "ItemId": {
+            "type": "string",
+            "description": "Gets or sets the item identifier.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "This is used by the api to get information about a item user data."
+      },
+      "UpdateUserPassword": {
+        "type": "object",
+        "properties": {
+          "CurrentPassword": {
+            "type": "string",
+            "description": "Gets or sets the current sha1-hashed password.",
+            "nullable": true
+          },
+          "CurrentPw": {
+            "type": "string",
+            "description": "Gets or sets the current plain text password.",
+            "nullable": true
+          },
+          "NewPw": {
+            "type": "string",
+            "description": "Gets or sets the new plain text password.",
+            "nullable": true
+          },
+          "ResetPassword": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether to reset the password."
+          }
+        },
+        "additionalProperties": false,
+        "description": "The update user password request body."
+      },
+      "UploadSubtitleDto": {
+        "required": [
+          "Data",
+          "Format",
+          "IsForced",
+          "IsHearingImpaired",
+          "Language"
+        ],
+        "type": "object",
+        "properties": {
+          "Language": {
+            "type": "string",
+            "description": "Gets or sets the subtitle language."
+          },
+          "Format": {
+            "type": "string",
+            "description": "Gets or sets the subtitle format."
+          },
+          "IsForced": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the subtitle is forced."
+          },
+          "IsHearingImpaired": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether the subtitle is for hearing impaired."
+          },
+          "Data": {
+            "type": "string",
+            "description": "Gets or sets the subtitle data."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Upload subtitles dto."
       },
       "UserConfiguration": {
         "type": "object",
@@ -54552,12 +58411,24 @@
           "GroupedFolders": {
             "type": "array",
             "items": {
-              "type": "string"
-            },
-            "nullable": true
+              "type": "string",
+              "format": "uuid"
+            }
           },
           "SubtitleMode": {
-            "$ref": "#/components/schemas/SubtitlePlaybackMode"
+            "enum": [
+              "Default",
+              "Always",
+              "OnlyForced",
+              "None",
+              "Smart"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SubtitlePlaybackMode"
+              }
+            ],
+            "description": "An enum representing a subtitle playback mode."
           },
           "DisplayCollectionsView": {
             "type": "boolean"
@@ -54568,23 +58439,23 @@
           "OrderedViews": {
             "type": "array",
             "items": {
-              "type": "string"
-            },
-            "nullable": true
+              "type": "string",
+              "format": "uuid"
+            }
           },
           "LatestItemsExcludes": {
             "type": "array",
             "items": {
-              "type": "string"
-            },
-            "nullable": true
+              "type": "string",
+              "format": "uuid"
+            }
           },
           "MyMediaExcludes": {
             "type": "array",
             "items": {
-              "type": "string"
-            },
-            "nullable": true
+              "type": "string",
+              "format": "uuid"
+            }
           },
           "HidePlayedInLatest": {
             "type": "boolean"
@@ -54597,91 +58468,319 @@
           },
           "EnableNextEpisodeAutoPlay": {
             "type": "boolean"
+          },
+          "CastReceiverId": {
+            "type": "string",
+            "description": "Gets or sets the id of the selected cast receiver.",
+            "nullable": true
           }
         },
         "additionalProperties": false,
         "description": "Class UserConfiguration."
       },
-      "DynamicDayOfWeek": {
-        "enum": [
-          "Sunday",
-          "Monday",
-          "Tuesday",
-          "Wednesday",
-          "Thursday",
-          "Friday",
-          "Saturday",
-          "Everyday",
-          "Weekday",
-          "Weekend"
-        ],
-        "type": "string",
-        "description": "An enum that represents a day of the week, weekdays, weekends, or all days."
-      },
-      "AccessSchedule": {
-        "required": [
-          "DayOfWeek",
-          "EndHour",
-          "Id",
-          "StartHour",
-          "UserId"
-        ],
+      "UserDataChangedMessage": {
         "type": "object",
         "properties": {
-          "Id": {
-            "type": "integer",
-            "description": "Gets or sets the id of this instance.",
-            "format": "int32",
-            "readOnly": true
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserDataChangeInfo"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
           },
-          "UserId": {
+          "MessageId": {
             "type": "string",
-            "description": "Gets or sets the id of the associated user.",
-            "format": "uuid",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "UserDataChanged",
             "readOnly": true
-          },
-          "DayOfWeek": {
-            "$ref": "#/components/schemas/DynamicDayOfWeek"
-          },
-          "StartHour": {
-            "type": "number",
-            "description": "Gets or sets the start hour.",
-            "format": "double"
-          },
-          "EndHour": {
-            "type": "number",
-            "description": "Gets or sets the end hour.",
-            "format": "double"
           }
         },
         "additionalProperties": false,
-        "description": "An entity representing a user's access schedule."
+        "description": "User data changed message."
       },
-      "UnratedItem": {
-        "enum": [
-          "Movie",
-          "Trailer",
-          "Series",
-          "Music",
-          "Book",
-          "LiveTvChannel",
-          "LiveTvProgram",
-          "ChannelContent",
-          "Other"
-        ],
-        "type": "string",
-        "description": "An enum representing an unrated item."
+      "UserDataChangeInfo": {
+        "type": "object",
+        "properties": {
+          "UserId": {
+            "type": "string",
+            "description": "Gets or sets the user id.",
+            "format": "uuid"
+          },
+          "UserDataList": {
+            "type": "array",
+            "items": {
+              "$ref": "#/components/schemas/UserItemDataDto"
+            },
+            "description": "Gets or sets the user data list."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class UserDataChangeInfo."
       },
-      "SyncPlayUserAccessType": {
-        "enum": [
-          "CreateAndJoinGroups",
-          "JoinGroups",
-          "None"
-        ],
-        "type": "string",
-        "description": "Enum SyncPlayUserAccessType."
+      "UserDeletedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "type": "string",
+            "description": "Gets or sets the data.",
+            "format": "uuid"
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "UserDeleted",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "User deleted message."
+      },
+      "UserDto": {
+        "type": "object",
+        "properties": {
+          "Name": {
+            "type": "string",
+            "description": "Gets or sets the name.",
+            "nullable": true
+          },
+          "ServerId": {
+            "type": "string",
+            "description": "Gets or sets the server identifier.",
+            "nullable": true
+          },
+          "ServerName": {
+            "type": "string",
+            "description": "Gets or sets the name of the server.\r\nThis is not used by the server and is for client-side usage only.",
+            "nullable": true
+          },
+          "Id": {
+            "type": "string",
+            "description": "Gets or sets the id.",
+            "format": "uuid"
+          },
+          "PrimaryImageTag": {
+            "type": "string",
+            "description": "Gets or sets the primary image tag.",
+            "nullable": true
+          },
+          "HasPassword": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance has password."
+          },
+          "HasConfiguredPassword": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance has configured password."
+          },
+          "HasConfiguredEasyPassword": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance has configured easy password.",
+            "deprecated": true
+          },
+          "EnableAutoLogin": {
+            "type": "boolean",
+            "description": "Gets or sets whether async login is enabled or not.",
+            "nullable": true
+          },
+          "LastLoginDate": {
+            "type": "string",
+            "description": "Gets or sets the last login date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "LastActivityDate": {
+            "type": "string",
+            "description": "Gets or sets the last activity date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "Configuration": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserConfiguration"
+              }
+            ],
+            "description": "Gets or sets the configuration.",
+            "nullable": true
+          },
+          "Policy": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserPolicy"
+              }
+            ],
+            "description": "Gets or sets the policy.",
+            "nullable": true
+          },
+          "PrimaryImageAspectRatio": {
+            "type": "number",
+            "description": "Gets or sets the primary image aspect ratio.",
+            "format": "double",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class UserDto."
+      },
+      "UserItemDataDto": {
+        "type": "object",
+        "properties": {
+          "Rating": {
+            "type": "number",
+            "description": "Gets or sets the rating.",
+            "format": "double",
+            "nullable": true
+          },
+          "PlayedPercentage": {
+            "type": "number",
+            "description": "Gets or sets the played percentage.",
+            "format": "double",
+            "nullable": true
+          },
+          "UnplayedItemCount": {
+            "type": "integer",
+            "description": "Gets or sets the unplayed item count.",
+            "format": "int32",
+            "nullable": true
+          },
+          "PlaybackPositionTicks": {
+            "type": "integer",
+            "description": "Gets or sets the playback position ticks.",
+            "format": "int64"
+          },
+          "PlayCount": {
+            "type": "integer",
+            "description": "Gets or sets the play count.",
+            "format": "int32"
+          },
+          "IsFavorite": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance is favorite."
+          },
+          "Likes": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is likes.",
+            "nullable": true
+          },
+          "LastPlayedDate": {
+            "type": "string",
+            "description": "Gets or sets the last played date.",
+            "format": "date-time",
+            "nullable": true
+          },
+          "Played": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Dto.UserItemDataDto is played."
+          },
+          "Key": {
+            "type": "string",
+            "description": "Gets or sets the key."
+          },
+          "ItemId": {
+            "type": "string",
+            "description": "Gets or sets the item identifier.",
+            "format": "uuid"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class UserItemDataDto."
       },
       "UserPolicy": {
+        "required": [
+          "AuthenticationProviderId",
+          "PasswordResetProviderId"
+        ],
         "type": "object",
         "properties": {
           "IsAdministrator": {
@@ -54692,6 +58791,21 @@
             "type": "boolean",
             "description": "Gets or sets a value indicating whether this instance is hidden."
           },
+          "EnableCollectionManagement": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance can manage collections.",
+            "default": false
+          },
+          "EnableSubtitleManagement": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this instance can manage subtitles.",
+            "default": false
+          },
+          "EnableLyricManagement": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether this user can manage lyrics.",
+            "default": false
+          },
           "IsDisabled": {
             "type": "boolean",
             "description": "Gets or sets a value indicating whether this instance is disabled."
@@ -54709,6 +58823,13 @@
             },
             "nullable": true
           },
+          "AllowedTags": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "nullable": true
+          },
           "EnableUserPreferenceAccess": {
             "type": "boolean"
           },
@@ -54844,20 +58965,226 @@
             "format": "int32"
           },
           "AuthenticationProviderId": {
-            "type": "string",
-            "nullable": true
+            "type": "string"
           },
           "PasswordResetProviderId": {
-            "type": "string",
-            "nullable": true
+            "type": "string"
           },
           "SyncPlayAccess": {
-            "$ref": "#/components/schemas/SyncPlayUserAccessType"
+            "enum": [
+              "CreateAndJoinGroups",
+              "JoinGroups",
+              "None"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SyncPlayUserAccessType"
+              }
+            ],
+            "description": "Enum SyncPlayUserAccessType."
           }
         },
         "additionalProperties": false
       },
-      "UserDto": {
+      "UserUpdatedMessage": {
+        "type": "object",
+        "properties": {
+          "Data": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/UserDto"
+              }
+            ],
+            "description": "Gets or sets the data.",
+            "nullable": true
+          },
+          "MessageId": {
+            "type": "string",
+            "description": "Gets or sets the message id.",
+            "format": "uuid"
+          },
+          "MessageType": {
+            "enum": [
+              "ForceKeepAlive",
+              "GeneralCommand",
+              "UserDataChanged",
+              "Sessions",
+              "Play",
+              "SyncPlayCommand",
+              "SyncPlayGroupUpdate",
+              "Playstate",
+              "RestartRequired",
+              "ServerShuttingDown",
+              "ServerRestarting",
+              "LibraryChanged",
+              "UserDeleted",
+              "UserUpdated",
+              "SeriesTimerCreated",
+              "TimerCreated",
+              "SeriesTimerCancelled",
+              "TimerCancelled",
+              "RefreshProgress",
+              "ScheduledTaskEnded",
+              "PackageInstallationCancelled",
+              "PackageInstallationFailed",
+              "PackageInstallationCompleted",
+              "PackageInstalling",
+              "PackageUninstalled",
+              "ActivityLogEntry",
+              "ScheduledTasksInfo",
+              "ActivityLogEntryStart",
+              "ActivityLogEntryStop",
+              "SessionsStart",
+              "SessionsStop",
+              "ScheduledTasksInfoStart",
+              "ScheduledTasksInfoStop",
+              "KeepAlive"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/SessionMessageType"
+              }
+            ],
+            "description": "The different kinds of messages that are used in the WebSocket api.",
+            "default": "UserUpdated",
+            "readOnly": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "User updated message."
+      },
+      "UtcTimeResponse": {
+        "type": "object",
+        "properties": {
+          "RequestReceptionTime": {
+            "type": "string",
+            "description": "Gets the UTC time when request has been received.",
+            "format": "date-time"
+          },
+          "ResponseTransmissionTime": {
+            "type": "string",
+            "description": "Gets the UTC time when response has been sent.",
+            "format": "date-time"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Class UtcTimeResponse."
+      },
+      "ValidatePathDto": {
+        "type": "object",
+        "properties": {
+          "ValidateWritable": {
+            "type": "boolean",
+            "description": "Gets or sets a value indicating whether validate if path is writable."
+          },
+          "Path": {
+            "type": "string",
+            "description": "Gets or sets the path.",
+            "nullable": true
+          },
+          "IsFile": {
+            "type": "boolean",
+            "description": "Gets or sets is path file.",
+            "nullable": true
+          }
+        },
+        "additionalProperties": false,
+        "description": "Validate path object."
+      },
+      "VersionInfo": {
+        "type": "object",
+        "properties": {
+          "version": {
+            "type": "string",
+            "description": "Gets or sets the version."
+          },
+          "VersionNumber": {
+            "type": "string",
+            "description": "Gets the version as a System.Version.",
+            "readOnly": true
+          },
+          "changelog": {
+            "type": "string",
+            "description": "Gets or sets the changelog for this version.",
+            "nullable": true
+          },
+          "targetAbi": {
+            "type": "string",
+            "description": "Gets or sets the ABI that this version was built against.",
+            "nullable": true
+          },
+          "sourceUrl": {
+            "type": "string",
+            "description": "Gets or sets the source URL.",
+            "nullable": true
+          },
+          "checksum": {
+            "type": "string",
+            "description": "Gets or sets a checksum for the binary.",
+            "nullable": true
+          },
+          "timestamp": {
+            "type": "string",
+            "description": "Gets or sets a timestamp of when the binary was built.",
+            "nullable": true
+          },
+          "repositoryName": {
+            "type": "string",
+            "description": "Gets or sets the repository name."
+          },
+          "repositoryUrl": {
+            "type": "string",
+            "description": "Gets or sets the repository url."
+          }
+        },
+        "additionalProperties": false,
+        "description": "Defines the MediaBrowser.Model.Updates.VersionInfo class."
+      },
+      "Video3DFormat": {
+        "enum": [
+          "HalfSideBySide",
+          "FullSideBySide",
+          "FullTopAndBottom",
+          "HalfTopAndBottom",
+          "MVC"
+        ],
+        "type": "string"
+      },
+      "VideoRange": {
+        "enum": [
+          "Unknown",
+          "SDR",
+          "HDR"
+        ],
+        "type": "string",
+        "description": "An enum representing video ranges."
+      },
+      "VideoRangeType": {
+        "enum": [
+          "Unknown",
+          "SDR",
+          "HDR10",
+          "HLG",
+          "DOVI",
+          "DOVIWithHDR10",
+          "DOVIWithHLG",
+          "DOVIWithSDR",
+          "HDR10Plus"
+        ],
+        "type": "string",
+        "description": "An enum representing types of video ranges."
+      },
+      "VideoType": {
+        "enum": [
+          "VideoFile",
+          "Iso",
+          "Dvd",
+          "BluRay"
+        ],
+        "type": "string",
+        "description": "Enum VideoType."
+      },
+      "VirtualFolderInfo": {
         "type": "object",
         "properties": {
           "Name": {
@@ -54865,551 +59192,123 @@
             "description": "Gets or sets the name.",
             "nullable": true
           },
-          "ServerId": {
-            "type": "string",
-            "description": "Gets or sets the server identifier.",
+          "Locations": {
+            "type": "array",
+            "items": {
+              "type": "string"
+            },
+            "description": "Gets or sets the locations.",
             "nullable": true
           },
-          "ServerName": {
-            "type": "string",
-            "description": "Gets or sets the name of the server.\r\nThis is not used by the server and is for client-side usage only.",
+          "CollectionType": {
+            "enum": [
+              "movies",
+              "tvshows",
+              "music",
+              "musicvideos",
+              "homevideos",
+              "boxsets",
+              "books",
+              "mixed"
+            ],
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/CollectionTypeOptions"
+              }
+            ],
+            "description": "Gets or sets the type of the collection.",
             "nullable": true
           },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets the id.",
-            "format": "uuid"
-          },
-          "PrimaryImageTag": {
-            "type": "string",
-            "description": "Gets or sets the primary image tag.",
+          "LibraryOptions": {
+            "allOf": [
+              {
+                "$ref": "#/components/schemas/LibraryOptions"
+              }
+            ],
             "nullable": true
           },
-          "HasPassword": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance has password."
-          },
-          "HasConfiguredPassword": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance has configured password."
-          },
-          "HasConfiguredEasyPassword": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this instance has configured easy password."
-          },
-          "EnableAutoLogin": {
-            "type": "boolean",
-            "description": "Gets or sets whether async login is enabled or not.",
-            "nullable": true
-          },
-          "LastLoginDate": {
+          "ItemId": {
             "type": "string",
-            "description": "Gets or sets the last login date.",
-            "format": "date-time",
+            "description": "Gets or sets the item identifier.",
             "nullable": true
           },
-          "LastActivityDate": {
+          "PrimaryImageItemId": {
             "type": "string",
-            "description": "Gets or sets the last activity date.",
-            "format": "date-time",
+            "description": "Gets or sets the primary image item identifier.",
             "nullable": true
           },
-          "Configuration": {
-            "$ref": "#/components/schemas/UserConfiguration"
-          },
-          "Policy": {
-            "$ref": "#/components/schemas/UserPolicy"
-          },
-          "PrimaryImageAspectRatio": {
+          "RefreshProgress": {
             "type": "number",
-            "description": "Gets or sets the primary image aspect ratio.",
             "format": "double",
             "nullable": true
+          },
+          "RefreshStatus": {
+            "type": "string",
+            "nullable": true
           }
         },
         "additionalProperties": false,
-        "description": "Class UserDto."
+        "description": "Used to hold information about a user's list of configured virtual folders."
       },
-      "AuthenticationResult": {
+      "WakeOnLanInfo": {
         "type": "object",
         "properties": {
-          "User": {
-            "$ref": "#/components/schemas/UserDto"
+          "MacAddress": {
+            "type": "string",
+            "description": "Gets the MAC address of the device.",
+            "nullable": true
           },
-          "SessionInfo": {
-            "$ref": "#/components/schemas/SessionInfo"
+          "Port": {
+            "type": "integer",
+            "description": "Gets or sets the wake-on-LAN port.",
+            "format": "int32"
+          }
+        },
+        "additionalProperties": false,
+        "description": "Provides the MAC address and port for wake-on-LAN functionality."
+      },
+      "WebSocketMessage": {
+        "type": "object",
+        "oneOf": [
+          {
+            "$ref": "#/components/schemas/InboundWebSocketMessage"
           },
-          "AccessToken": {
+          {
+            "$ref": "#/components/schemas/OutboundWebSocketMessage"
+          }
+        ],
+        "description": "Represents the possible websocket types"
+      },
+      "XbmcMetadataOptions": {
+        "type": "object",
+        "properties": {
+          "UserId": {
             "type": "string",
             "nullable": true
           },
-          "ServerId": {
-            "type": "string",
-            "nullable": true
+          "ReleaseDateFormat": {
+            "type": "string"
+          },
+          "SaveImagePathsInNfo": {
+            "type": "boolean"
+          },
+          "EnablePathSubstitution": {
+            "type": "boolean"
+          },
+          "EnableExtraThumbsDuplication": {
+            "type": "boolean"
           }
         },
         "additionalProperties": false
-      },
-      "UpdateUserEasyPassword": {
-        "type": "object",
-        "properties": {
-          "NewPassword": {
-            "type": "string",
-            "description": "Gets or sets the new sha1-hashed password.",
-            "nullable": true
-          },
-          "NewPw": {
-            "type": "string",
-            "description": "Gets or sets the new password.",
-            "nullable": true
-          },
-          "ResetPassword": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to reset the password."
-          }
-        },
-        "additionalProperties": false,
-        "description": "The update user easy password request body."
-      },
-      "UpdateUserPassword": {
-        "type": "object",
-        "properties": {
-          "CurrentPassword": {
-            "type": "string",
-            "description": "Gets or sets the current sha1-hashed password.",
-            "nullable": true
-          },
-          "CurrentPw": {
-            "type": "string",
-            "description": "Gets or sets the current plain text password.",
-            "nullable": true
-          },
-          "NewPw": {
-            "type": "string",
-            "description": "Gets or sets the new plain text password.",
-            "nullable": true
-          },
-          "ResetPassword": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether to reset the password."
-          }
-        },
-        "additionalProperties": false,
-        "description": "The update user password request body."
-      },
-      "AuthenticateUserByName": {
-        "type": "object",
-        "properties": {
-          "Username": {
-            "type": "string",
-            "description": "Gets or sets the username.",
-            "nullable": true
-          },
-          "Pw": {
-            "type": "string",
-            "description": "Gets or sets the plain text password.",
-            "nullable": true
-          },
-          "Password": {
-            "type": "string",
-            "description": "Gets or sets the sha1-hashed password.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "The authenticate user by name request body."
-      },
-      "QuickConnectDto": {
-        "required": [
-          "Token"
-        ],
-        "type": "object",
-        "properties": {
-          "Token": {
-            "type": "string",
-            "description": "Gets or sets the quick connect token."
-          }
-        },
-        "additionalProperties": false,
-        "description": "The quick connect request body."
-      },
-      "ForgotPasswordDto": {
-        "required": [
-          "EnteredUsername"
-        ],
-        "type": "object",
-        "properties": {
-          "EnteredUsername": {
-            "type": "string",
-            "description": "Gets or sets the entered username to have its password reset."
-          }
-        },
-        "additionalProperties": false,
-        "description": "Forgot Password request body DTO."
-      },
-      "ForgotPasswordAction": {
-        "enum": [
-          "ContactAdmin",
-          "PinCode",
-          "InNetworkRequired"
-        ],
-        "type": "string"
-      },
-      "ForgotPasswordResult": {
-        "type": "object",
-        "properties": {
-          "Action": {
-            "$ref": "#/components/schemas/ForgotPasswordAction"
-          },
-          "PinFile": {
-            "type": "string",
-            "description": "Gets or sets the pin file.",
-            "nullable": true
-          },
-          "PinExpirationDate": {
-            "type": "string",
-            "description": "Gets or sets the pin expiration date.",
-            "format": "date-time",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "PinRedeemResult": {
-        "type": "object",
-        "properties": {
-          "Success": {
-            "type": "boolean",
-            "description": "Gets or sets a value indicating whether this MediaBrowser.Model.Users.PinRedeemResult is success."
-          },
-          "UsersReset": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the users reset.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "CreateUserByName": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets the username.",
-            "nullable": true
-          },
-          "Password": {
-            "type": "string",
-            "description": "Gets or sets the password.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "The create user by name request body."
-      },
-      "SpecialViewOptionDto": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets or sets view option name.",
-            "nullable": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets or sets view option id.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Special view option dto."
-      },
-      "LibraryUpdateInfo": {
-        "type": "object",
-        "properties": {
-          "FoldersAddedTo": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the folders added to.",
-            "nullable": true
-          },
-          "FoldersRemovedFrom": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the folders removed from.",
-            "nullable": true
-          },
-          "ItemsAdded": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the items added.",
-            "nullable": true
-          },
-          "ItemsRemoved": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the items removed.",
-            "nullable": true
-          },
-          "ItemsUpdated": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "description": "Gets or sets the items updated.",
-            "nullable": true
-          },
-          "CollectionFolders": {
-            "type": "array",
-            "items": {
-              "type": "string"
-            },
-            "nullable": true
-          },
-          "IsEmpty": {
-            "type": "boolean",
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class LibraryUpdateInfo."
-      },
-      "IPlugin": {
-        "type": "object",
-        "properties": {
-          "Name": {
-            "type": "string",
-            "description": "Gets the name of the plugin.",
-            "nullable": true,
-            "readOnly": true
-          },
-          "Description": {
-            "type": "string",
-            "description": "Gets the Description.",
-            "nullable": true,
-            "readOnly": true
-          },
-          "Id": {
-            "type": "string",
-            "description": "Gets the unique id.",
-            "format": "uuid",
-            "readOnly": true
-          },
-          "Version": {
-            "$ref": "#/components/schemas/Version"
-          },
-          "AssemblyFilePath": {
-            "type": "string",
-            "description": "Gets the path to the assembly file.",
-            "nullable": true,
-            "readOnly": true
-          },
-          "CanUninstall": {
-            "type": "boolean",
-            "description": "Gets a value indicating whether the plugin can be uninstalled.",
-            "readOnly": true
-          },
-          "DataFolderPath": {
-            "type": "string",
-            "description": "Gets the full path to the data folder, where the plugin can store any miscellaneous files needed.",
-            "nullable": true,
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Defines the MediaBrowser.Common.Plugins.IPlugin."
-      },
-      "PlayRequest": {
-        "type": "object",
-        "properties": {
-          "ItemIds": {
-            "type": "array",
-            "items": {
-              "type": "string",
-              "format": "uuid"
-            },
-            "description": "Gets or sets the item ids.",
-            "nullable": true
-          },
-          "StartPositionTicks": {
-            "type": "integer",
-            "description": "Gets or sets the start position ticks that the first item should be played at.",
-            "format": "int64",
-            "nullable": true
-          },
-          "PlayCommand": {
-            "$ref": "#/components/schemas/PlayCommand"
-          },
-          "ControllingUserId": {
-            "type": "string",
-            "description": "Gets or sets the controlling user identifier.",
-            "format": "uuid"
-          },
-          "SubtitleStreamIndex": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "AudioStreamIndex": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          },
-          "MediaSourceId": {
-            "type": "string",
-            "nullable": true
-          },
-          "StartIndex": {
-            "type": "integer",
-            "format": "int32",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class PlayRequest."
-      },
-      "PlaystateRequest": {
-        "type": "object",
-        "properties": {
-          "Command": {
-            "$ref": "#/components/schemas/PlaystateCommand"
-          },
-          "SeekPositionTicks": {
-            "type": "integer",
-            "format": "int64",
-            "nullable": true
-          },
-          "ControllingUserId": {
-            "type": "string",
-            "description": "Gets or sets the controlling user identifier.",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "TimerEventInfo": {
-        "type": "object",
-        "properties": {
-          "Id": {
-            "type": "string",
-            "nullable": true,
-            "readOnly": true
-          },
-          "ProgramId": {
-            "type": "string",
-            "format": "uuid",
-            "nullable": true
-          }
-        },
-        "additionalProperties": false
-      },
-      "SendCommandType": {
-        "enum": [
-          "Unpause",
-          "Pause",
-          "Stop",
-          "Seek"
-        ],
-        "type": "string",
-        "description": "Enum SendCommandType."
-      },
-      "SendCommand": {
-        "type": "object",
-        "properties": {
-          "GroupId": {
-            "type": "string",
-            "description": "Gets the group identifier.",
-            "format": "uuid",
-            "readOnly": true
-          },
-          "PlaylistItemId": {
-            "type": "string",
-            "description": "Gets the playlist identifier of the playing item.",
-            "format": "uuid",
-            "readOnly": true
-          },
-          "When": {
-            "type": "string",
-            "description": "Gets or sets the UTC time when to execute the command.",
-            "format": "date-time"
-          },
-          "PositionTicks": {
-            "type": "integer",
-            "description": "Gets the position ticks.",
-            "format": "int64",
-            "nullable": true,
-            "readOnly": true
-          },
-          "Command": {
-            "$ref": "#/components/schemas/SendCommandType"
-          },
-          "EmittedAt": {
-            "type": "string",
-            "description": "Gets the UTC time when this command has been emitted.",
-            "format": "date-time",
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class SendCommand."
-      },
-      "GroupUpdateType": {
-        "enum": [
-          "UserJoined",
-          "UserLeft",
-          "GroupJoined",
-          "GroupLeft",
-          "StateUpdate",
-          "PlayQueue",
-          "NotInGroup",
-          "GroupDoesNotExist",
-          "CreateGroupDenied",
-          "JoinGroupDenied",
-          "LibraryAccessDenied"
-        ],
-        "type": "string",
-        "description": "Enum GroupUpdateType."
-      },
-      "ObjectGroupUpdate": {
-        "type": "object",
-        "properties": {
-          "GroupId": {
-            "type": "string",
-            "description": "Gets the group identifier.",
-            "format": "uuid",
-            "readOnly": true
-          },
-          "Type": {
-            "$ref": "#/components/schemas/GroupUpdateType"
-          },
-          "Data": {
-            "description": "Gets the update data.",
-            "nullable": true,
-            "readOnly": true
-          }
-        },
-        "additionalProperties": false,
-        "description": "Class GroupUpdate."
       }
     },
     "securitySchemes": {
       "CustomAuthentication": {
         "type": "apiKey",
         "description": "API key header parameter",
-        "name": "X-Emby-Authorization",
+        "name": "Authorization",
         "in": "header"
       }
     }
   }
-}
+}
\ No newline at end of file
diff --git a/core/src/dto/activitylogentry.cpp b/core/src/dto/activitylogentry.cpp
index ba9f0db..842c66f 100644
--- a/core/src/dto/activitylogentry.cpp
+++ b/core/src/dto/activitylogentry.cpp
@@ -35,11 +35,15 @@ namespace DTO {
 ActivityLogEntry::ActivityLogEntry() {}
 ActivityLogEntry::ActivityLogEntry (
 		qint64 jellyfinId, 
+		QString name, 
+		QString type, 
 		QDateTime date, 
 		QString userId, 
 		LogLevel severity 
 		) :
 	m_jellyfinId(jellyfinId),
+	m_name(name),
+	m_type(type),
 	m_date(date),
 	m_userId(userId),
 	m_severity(severity) { }
@@ -98,11 +102,7 @@ QJsonObject ActivityLogEntry::toJson() const {
 	QJsonObject result;
 	
 	result["Id"] = Jellyfin::Support::toJsonValue<qint64>(m_jellyfinId);		
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
 	
 	if (!(m_overview.isNull())) {
 		result["Overview"] = Jellyfin::Support::toJsonValue<QString>(m_overview);
@@ -113,11 +113,7 @@ QJsonObject ActivityLogEntry::toJson() const {
 		result["ShortOverview"] = Jellyfin::Support::toJsonValue<QString>(m_shortOverview);
 	}
 			
-	
-	if (!(m_type.isNull())) {
-		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
-	}
-			
+	result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);		
 	
 	if (!(m_itemId.isNull())) {
 		result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);
@@ -145,14 +141,7 @@ QString ActivityLogEntry::name() const { return m_name; }
 void ActivityLogEntry::setName(QString newName) {
 	m_name = newName;
 }
-bool ActivityLogEntry::nameNull() const {
-	return m_name.isNull();
-}
 
-void ActivityLogEntry::setNameNull() {
-	m_name.clear();
-
-}
 QString ActivityLogEntry::overview() const { return m_overview; }
 
 void ActivityLogEntry::setOverview(QString newOverview) {
@@ -184,14 +173,7 @@ QString ActivityLogEntry::type() const { return m_type; }
 void ActivityLogEntry::setType(QString newType) {
 	m_type = newType;
 }
-bool ActivityLogEntry::typeNull() const {
-	return m_type.isNull();
-}
 
-void ActivityLogEntry::setTypeNull() {
-	m_type.clear();
-
-}
 QString ActivityLogEntry::itemId() const { return m_itemId; }
 
 void ActivityLogEntry::setItemId(QString newItemId) {
diff --git a/core/src/dto/activitylogentrymessage.cpp b/core/src/dto/activitylogentrymessage.cpp
new file mode 100644
index 0000000..7e3be56
--- /dev/null
+++ b/core/src/dto/activitylogentrymessage.cpp
@@ -0,0 +1,129 @@
+/*
+ * 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/dto/activitylogentrymessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ActivityLogEntryMessage::ActivityLogEntryMessage() {}
+ActivityLogEntryMessage::ActivityLogEntryMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ActivityLogEntryMessage::ActivityLogEntryMessage(const ActivityLogEntryMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ActivityLogEntryMessage::replaceData(ActivityLogEntryMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ActivityLogEntryMessage ActivityLogEntryMessage::fromJson(QJsonObject source) {
+	ActivityLogEntryMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ActivityLogEntryMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QList<ActivityLogEntry>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ActivityLogEntryMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.size() == 0)) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QList<ActivityLogEntry>>(m_data);
+	}
+			
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QList<ActivityLogEntry> ActivityLogEntryMessage::data() const { return m_data; }
+
+void ActivityLogEntryMessage::setData(QList<ActivityLogEntry> newData) {
+	m_data = newData;
+}
+bool ActivityLogEntryMessage::dataNull() const {
+	return m_data.size() == 0;
+}
+
+void ActivityLogEntryMessage::setDataNull() {
+	m_data.clear();
+
+}
+QString ActivityLogEntryMessage::messageId() const { return m_messageId; }
+
+void ActivityLogEntryMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ActivityLogEntryMessage::messageType() const { return m_messageType; }
+
+void ActivityLogEntryMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryMessage = Jellyfin::DTO::ActivityLogEntryMessage;
+
+template <>
+ActivityLogEntryMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ActivityLogEntryMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryMessage &source, convertType<ActivityLogEntryMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/activitylogentryqueryresult.cpp b/core/src/dto/activitylogentryqueryresult.cpp
index 9132b74..987484c 100644
--- a/core/src/dto/activitylogentryqueryresult.cpp
+++ b/core/src/dto/activitylogentryqueryresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 ActivityLogEntryQueryResult::ActivityLogEntryQueryResult() {}
 ActivityLogEntryQueryResult::ActivityLogEntryQueryResult (
+		QList<ActivityLogEntry> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
@@ -72,11 +74,7 @@ void ActivityLogEntryQueryResult::setFromJson(QJsonObject source) {
 QJsonObject ActivityLogEntryQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<ActivityLogEntry>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<ActivityLogEntry>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
@@ -87,14 +85,7 @@ QList<ActivityLogEntry> ActivityLogEntryQueryResult::items() const { return m_it
 void ActivityLogEntryQueryResult::setItems(QList<ActivityLogEntry> newItems) {
 	m_items = newItems;
 }
-bool ActivityLogEntryQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void ActivityLogEntryQueryResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 ActivityLogEntryQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void ActivityLogEntryQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/activitylogentrystartmessage.cpp b/core/src/dto/activitylogentrystartmessage.cpp
new file mode 100644
index 0000000..8e3fdd0
--- /dev/null
+++ b/core/src/dto/activitylogentrystartmessage.cpp
@@ -0,0 +1,117 @@
+/*
+ * 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/dto/activitylogentrystartmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ActivityLogEntryStartMessage::ActivityLogEntryStartMessage() {}
+ActivityLogEntryStartMessage::ActivityLogEntryStartMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+ActivityLogEntryStartMessage::ActivityLogEntryStartMessage(const ActivityLogEntryStartMessage &other) :
+
+	m_data(other.m_data),
+	m_messageType(other.m_messageType){}
+
+
+void ActivityLogEntryStartMessage::replaceData(ActivityLogEntryStartMessage &other) {
+	m_data = other.m_data;
+	m_messageType = other.m_messageType;
+}
+
+ActivityLogEntryStartMessage ActivityLogEntryStartMessage::fromJson(QJsonObject source) {
+	ActivityLogEntryStartMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ActivityLogEntryStartMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ActivityLogEntryStartMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.isNull())) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);
+	}
+			
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString ActivityLogEntryStartMessage::data() const { return m_data; }
+
+void ActivityLogEntryStartMessage::setData(QString newData) {
+	m_data = newData;
+}
+bool ActivityLogEntryStartMessage::dataNull() const {
+	return m_data.isNull();
+}
+
+void ActivityLogEntryStartMessage::setDataNull() {
+	m_data.clear();
+
+}
+SessionMessageType ActivityLogEntryStartMessage::messageType() const { return m_messageType; }
+
+void ActivityLogEntryStartMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryStartMessage = Jellyfin::DTO::ActivityLogEntryStartMessage;
+
+template <>
+ActivityLogEntryStartMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryStartMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ActivityLogEntryStartMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryStartMessage &source, convertType<ActivityLogEntryStartMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/activitylogentrystopmessage.cpp b/core/src/dto/activitylogentrystopmessage.cpp
new file mode 100644
index 0000000..def3f9c
--- /dev/null
+++ b/core/src/dto/activitylogentrystopmessage.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/activitylogentrystopmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ActivityLogEntryStopMessage::ActivityLogEntryStopMessage() {}
+ActivityLogEntryStopMessage::ActivityLogEntryStopMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+ActivityLogEntryStopMessage::ActivityLogEntryStopMessage(const ActivityLogEntryStopMessage &other) :
+
+	m_messageType(other.m_messageType){}
+
+
+void ActivityLogEntryStopMessage::replaceData(ActivityLogEntryStopMessage &other) {
+	m_messageType = other.m_messageType;
+}
+
+ActivityLogEntryStopMessage ActivityLogEntryStopMessage::fromJson(QJsonObject source) {
+	ActivityLogEntryStopMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ActivityLogEntryStopMessage::setFromJson(QJsonObject source) {
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ActivityLogEntryStopMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+SessionMessageType ActivityLogEntryStopMessage::messageType() const { return m_messageType; }
+
+void ActivityLogEntryStopMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ActivityLogEntryStopMessage = Jellyfin::DTO::ActivityLogEntryStopMessage;
+
+template <>
+ActivityLogEntryStopMessage fromJsonValue(const QJsonValue &source, convertType<ActivityLogEntryStopMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ActivityLogEntryStopMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ActivityLogEntryStopMessage &source, convertType<ActivityLogEntryStopMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/albuminfo.cpp b/core/src/dto/albuminfo.cpp
index 2c0aa86..f76bd50 100644
--- a/core/src/dto/albuminfo.cpp
+++ b/core/src/dto/albuminfo.cpp
@@ -34,15 +34,22 @@ namespace DTO {
 
 AlbumInfo::AlbumInfo() {}
 AlbumInfo::AlbumInfo (
-		bool isAutomated 
+		bool isAutomated, 
+		QStringList albumArtists, 
+		QJsonObject artistProviderIds, 
+		QList<SongInfo> songInfos 
 		) :
-	m_isAutomated(isAutomated) { }
+	m_isAutomated(isAutomated),
+	m_albumArtists(albumArtists),
+	m_artistProviderIds(artistProviderIds),
+	m_songInfos(songInfos) { }
 
 
 
 AlbumInfo::AlbumInfo(const AlbumInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -59,6 +66,7 @@ AlbumInfo::AlbumInfo(const AlbumInfo &other) :
 
 void AlbumInfo::replaceData(AlbumInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -82,6 +90,7 @@ AlbumInfo AlbumInfo::fromJson(QJsonObject source) {
 
 void AlbumInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -106,6 +115,11 @@ QJsonObject AlbumInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -146,21 +160,9 @@ QJsonObject AlbumInfo::toJson() const {
 	}
 			
 	result["IsAutomated"] = Jellyfin::Support::toJsonValue<bool>(m_isAutomated);		
-	
-	if (!(m_albumArtists.size() == 0)) {
-		result["AlbumArtists"] = Jellyfin::Support::toJsonValue<QStringList>(m_albumArtists);
-	}
-			
-	
-	if (!(m_artistProviderIds.isEmpty())) {
-		result["ArtistProviderIds"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_artistProviderIds);
-	}
-			
-	
-	if (!(m_songInfos.size() == 0)) {
-		result["SongInfos"] = Jellyfin::Support::toJsonValue<QList<SongInfo>>(m_songInfos);
-	}
-		
+	result["AlbumArtists"] = Jellyfin::Support::toJsonValue<QStringList>(m_albumArtists);		
+	result["ArtistProviderIds"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_artistProviderIds);		
+	result["SongInfos"] = Jellyfin::Support::toJsonValue<QList<SongInfo>>(m_songInfos);	
 	return result;
 }
 
@@ -176,6 +178,19 @@ bool AlbumInfo::nameNull() const {
 void AlbumInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString AlbumInfo::originalTitle() const { return m_originalTitle; }
+
+void AlbumInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool AlbumInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void AlbumInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString AlbumInfo::path() const { return m_path; }
 
@@ -292,40 +307,19 @@ QStringList AlbumInfo::albumArtists() const { return m_albumArtists; }
 void AlbumInfo::setAlbumArtists(QStringList newAlbumArtists) {
 	m_albumArtists = newAlbumArtists;
 }
-bool AlbumInfo::albumArtistsNull() const {
-	return m_albumArtists.size() == 0;
-}
 
-void AlbumInfo::setAlbumArtistsNull() {
-	m_albumArtists.clear();
-
-}
 QJsonObject AlbumInfo::artistProviderIds() const { return m_artistProviderIds; }
 
 void AlbumInfo::setArtistProviderIds(QJsonObject newArtistProviderIds) {
 	m_artistProviderIds = newArtistProviderIds;
 }
-bool AlbumInfo::artistProviderIdsNull() const {
-	return m_artistProviderIds.isEmpty();
-}
 
-void AlbumInfo::setArtistProviderIdsNull() {
-	m_artistProviderIds= QJsonObject();
-
-}
 QList<SongInfo> AlbumInfo::songInfos() const { return m_songInfos; }
 
 void AlbumInfo::setSongInfos(QList<SongInfo> newSongInfos) {
 	m_songInfos = newSongInfos;
 }
-bool AlbumInfo::songInfosNull() const {
-	return m_songInfos.size() == 0;
-}
 
-void AlbumInfo::setSongInfosNull() {
-	m_songInfos.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/artistinfo.cpp b/core/src/dto/artistinfo.cpp
index d628873..8001c05 100644
--- a/core/src/dto/artistinfo.cpp
+++ b/core/src/dto/artistinfo.cpp
@@ -34,15 +34,18 @@ namespace DTO {
 
 ArtistInfo::ArtistInfo() {}
 ArtistInfo::ArtistInfo (
-		bool isAutomated 
+		bool isAutomated, 
+		QList<SongInfo> songInfos 
 		) :
-	m_isAutomated(isAutomated) { }
+	m_isAutomated(isAutomated),
+	m_songInfos(songInfos) { }
 
 
 
 ArtistInfo::ArtistInfo(const ArtistInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -57,6 +60,7 @@ ArtistInfo::ArtistInfo(const ArtistInfo &other) :
 
 void ArtistInfo::replaceData(ArtistInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -78,6 +82,7 @@ ArtistInfo ArtistInfo::fromJson(QJsonObject source) {
 
 void ArtistInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -100,6 +105,11 @@ QJsonObject ArtistInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -140,11 +150,7 @@ QJsonObject ArtistInfo::toJson() const {
 	}
 			
 	result["IsAutomated"] = Jellyfin::Support::toJsonValue<bool>(m_isAutomated);		
-	
-	if (!(m_songInfos.size() == 0)) {
-		result["SongInfos"] = Jellyfin::Support::toJsonValue<QList<SongInfo>>(m_songInfos);
-	}
-		
+	result["SongInfos"] = Jellyfin::Support::toJsonValue<QList<SongInfo>>(m_songInfos);	
 	return result;
 }
 
@@ -160,6 +166,19 @@ bool ArtistInfo::nameNull() const {
 void ArtistInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString ArtistInfo::originalTitle() const { return m_originalTitle; }
+
+void ArtistInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool ArtistInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void ArtistInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString ArtistInfo::path() const { return m_path; }
 
@@ -276,14 +295,7 @@ QList<SongInfo> ArtistInfo::songInfos() const { return m_songInfos; }
 void ArtistInfo::setSongInfos(QList<SongInfo> newSongInfos) {
 	m_songInfos = newSongInfos;
 }
-bool ArtistInfo::songInfosNull() const {
-	return m_songInfos.size() == 0;
-}
 
-void ArtistInfo::setSongInfosNull() {
-	m_songInfos.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/configurationpagetype.cpp b/core/src/dto/audiospatialformat.cpp
similarity index 64%
rename from core/src/dto/configurationpagetype.cpp
rename to core/src/dto/audiospatialformat.cpp
index df299c0..1ebada8 100644
--- a/core/src/dto/configurationpagetype.cpp
+++ b/core/src/dto/audiospatialformat.cpp
@@ -27,43 +27,48 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/configurationpagetype.h>
+#include <JellyfinQt/dto/audiospatialformat.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-ConfigurationPageTypeClass::ConfigurationPageTypeClass() {}
+AudioSpatialFormatClass::AudioSpatialFormatClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using ConfigurationPageType = Jellyfin::DTO::ConfigurationPageType;
+using AudioSpatialFormat = Jellyfin::DTO::AudioSpatialFormat;
 
 template <>
-ConfigurationPageType fromJsonValue(const QJsonValue &source, convertType<ConfigurationPageType>) {
-	if (!source.isString()) return ConfigurationPageType::EnumNotSet;
+AudioSpatialFormat fromJsonValue(const QJsonValue &source, convertType<AudioSpatialFormat>) {
+	if (!source.isString()) return AudioSpatialFormat::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("PluginConfiguration")) {
-		return ConfigurationPageType::PluginConfiguration;
-	}
 	if (str == QStringLiteral("None")) {
-		return ConfigurationPageType::None;
+		return AudioSpatialFormat::None;
+	}
+	if (str == QStringLiteral("DolbyAtmos")) {
+		return AudioSpatialFormat::DolbyAtmos;
+	}
+	if (str == QStringLiteral("DTSX")) {
+		return AudioSpatialFormat::DTSX;
 	}
 	
-	return ConfigurationPageType::EnumNotSet;
+	return AudioSpatialFormat::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const ConfigurationPageType &source, convertType<ConfigurationPageType>) {
+QJsonValue toJsonValue(const AudioSpatialFormat &source, convertType<AudioSpatialFormat>) {
 	switch(source) {
-	case ConfigurationPageType::PluginConfiguration:
-		return QStringLiteral("PluginConfiguration");
-	case ConfigurationPageType::None:
+	case AudioSpatialFormat::None:
 		return QStringLiteral("None");
+	case AudioSpatialFormat::DolbyAtmos:
+		return QStringLiteral("DolbyAtmos");
+	case AudioSpatialFormat::DTSX:
+		return QStringLiteral("DTSX");
 
-	case ConfigurationPageType::EnumNotSet: // Fallthrough
+	case AudioSpatialFormat::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/authenticateuserbyname.cpp b/core/src/dto/authenticateuserbyname.cpp
index faead69..d3e925d 100644
--- a/core/src/dto/authenticateuserbyname.cpp
+++ b/core/src/dto/authenticateuserbyname.cpp
@@ -37,14 +37,12 @@ AuthenticateUserByName::AuthenticateUserByName() {}
 AuthenticateUserByName::AuthenticateUserByName(const AuthenticateUserByName &other) :
 
 	m_username(other.m_username),
-	m_pw(other.m_pw),
-	m_password(other.m_password){}
+	m_pw(other.m_pw){}
 
 
 void AuthenticateUserByName::replaceData(AuthenticateUserByName &other) {
 	m_username = other.m_username;
 	m_pw = other.m_pw;
-	m_password = other.m_password;
 }
 
 AuthenticateUserByName AuthenticateUserByName::fromJson(QJsonObject source) {
@@ -57,7 +55,6 @@ AuthenticateUserByName AuthenticateUserByName::fromJson(QJsonObject source) {
 void AuthenticateUserByName::setFromJson(QJsonObject source) {
 	m_username = Jellyfin::Support::fromJsonValue<QString>(source["Username"]);
 	m_pw = Jellyfin::Support::fromJsonValue<QString>(source["Pw"]);
-	m_password = Jellyfin::Support::fromJsonValue<QString>(source["Password"]);
 
 }
 	
@@ -73,11 +70,6 @@ QJsonObject AuthenticateUserByName::toJson() const {
 	if (!(m_pw.isNull())) {
 		result["Pw"] = Jellyfin::Support::toJsonValue<QString>(m_pw);
 	}
-			
-	
-	if (!(m_password.isNull())) {
-		result["Password"] = Jellyfin::Support::toJsonValue<QString>(m_password);
-	}
 		
 	return result;
 }
@@ -107,19 +99,6 @@ bool AuthenticateUserByName::pwNull() const {
 void AuthenticateUserByName::setPwNull() {
 	m_pw.clear();
 
-}
-QString AuthenticateUserByName::password() const { return m_password; }
-
-void AuthenticateUserByName::setPassword(QString newPassword) {
-	m_password = newPassword;
-}
-bool AuthenticateUserByName::passwordNull() const {
-	return m_password.isNull();
-}
-
-void AuthenticateUserByName::setPasswordNull() {
-	m_password.clear();
-
 }
 
 } // NS DTO
diff --git a/core/src/dto/authenticationinfoqueryresult.cpp b/core/src/dto/authenticationinfoqueryresult.cpp
index e3df55f..22f8e22 100644
--- a/core/src/dto/authenticationinfoqueryresult.cpp
+++ b/core/src/dto/authenticationinfoqueryresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 AuthenticationInfoQueryResult::AuthenticationInfoQueryResult() {}
 AuthenticationInfoQueryResult::AuthenticationInfoQueryResult (
+		QList<AuthenticationInfo> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
@@ -72,11 +74,7 @@ void AuthenticationInfoQueryResult::setFromJson(QJsonObject source) {
 QJsonObject AuthenticationInfoQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<AuthenticationInfo>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<AuthenticationInfo>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
@@ -87,14 +85,7 @@ QList<AuthenticationInfo> AuthenticationInfoQueryResult::items() const { return
 void AuthenticationInfoQueryResult::setItems(QList<AuthenticationInfo> newItems) {
 	m_items = newItems;
 }
-bool AuthenticationInfoQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void AuthenticationInfoQueryResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 AuthenticationInfoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void AuthenticationInfoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/authenticationresult.cpp b/core/src/dto/authenticationresult.cpp
index 7924caf..480b242 100644
--- a/core/src/dto/authenticationresult.cpp
+++ b/core/src/dto/authenticationresult.cpp
@@ -35,7 +35,7 @@ namespace DTO {
 AuthenticationResult::AuthenticationResult() {}
 AuthenticationResult::AuthenticationResult (
 		QSharedPointer<UserDto> user, 
-		QSharedPointer<SessionInfo> sessionInfo 
+		QSharedPointer<SessionInfoDto> sessionInfo 
 		) :
 	m_user(user),
 	m_sessionInfo(sessionInfo) { }
@@ -66,7 +66,7 @@ AuthenticationResult AuthenticationResult::fromJson(QJsonObject source) {
 
 void AuthenticationResult::setFromJson(QJsonObject source) {
 	m_user = Jellyfin::Support::fromJsonValue<QSharedPointer<UserDto>>(source["User"]);
-	m_sessionInfo = Jellyfin::Support::fromJsonValue<QSharedPointer<SessionInfo>>(source["SessionInfo"]);
+	m_sessionInfo = Jellyfin::Support::fromJsonValue<QSharedPointer<SessionInfoDto>>(source["SessionInfo"]);
 	m_accessToken = Jellyfin::Support::fromJsonValue<QString>(source["AccessToken"]);
 	m_serverId = Jellyfin::Support::fromJsonValue<QString>(source["ServerId"]);
 
@@ -76,7 +76,7 @@ QJsonObject AuthenticationResult::toJson() const {
 	QJsonObject result;
 	
 	result["User"] = Jellyfin::Support::toJsonValue<QSharedPointer<UserDto>>(m_user);		
-	result["SessionInfo"] = Jellyfin::Support::toJsonValue<QSharedPointer<SessionInfo>>(m_sessionInfo);		
+	result["SessionInfo"] = Jellyfin::Support::toJsonValue<QSharedPointer<SessionInfoDto>>(m_sessionInfo);		
 	
 	if (!(m_accessToken.isNull())) {
 		result["AccessToken"] = Jellyfin::Support::toJsonValue<QString>(m_accessToken);
@@ -96,9 +96,9 @@ void AuthenticationResult::setUser(QSharedPointer<UserDto> newUser) {
 	m_user = newUser;
 }
 
-QSharedPointer<SessionInfo> AuthenticationResult::sessionInfo() const { return m_sessionInfo; }
+QSharedPointer<SessionInfoDto> AuthenticationResult::sessionInfo() const { return m_sessionInfo; }
 
-void AuthenticationResult::setSessionInfo(QSharedPointer<SessionInfo> newSessionInfo) {
+void AuthenticationResult::setSessionInfo(QSharedPointer<SessionInfoDto> newSessionInfo) {
 	m_sessionInfo = newSessionInfo;
 }
 
diff --git a/core/src/dto/baseitem.cpp b/core/src/dto/baseitem.cpp
deleted file mode 100644
index d322f8c..0000000
--- a/core/src/dto/baseitem.cpp
+++ /dev/null
@@ -1,261 +0,0 @@
-/*
- * 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/dto/baseitem.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-BaseItem::BaseItem() {}
-BaseItem::BaseItem (
-		QDateTime dateLastSaved, 
-		bool isHD, 
-		bool isShortcut, 
-		qint32 width, 
-		qint32 height, 
-		bool supportsExternalTransfer 
-		) :
-	m_dateLastSaved(dateLastSaved),
-	m_isHD(isHD),
-	m_isShortcut(isShortcut),
-	m_width(width),
-	m_height(height),
-	m_supportsExternalTransfer(supportsExternalTransfer) { }
-
-
-
-BaseItem::BaseItem(const BaseItem &other) :
-
-	m_size(other.m_size),
-	m_container(other.m_container),
-	m_dateLastSaved(other.m_dateLastSaved),
-	m_remoteTrailers(other.m_remoteTrailers),
-	m_isHD(other.m_isHD),
-	m_isShortcut(other.m_isShortcut),
-	m_shortcutPath(other.m_shortcutPath),
-	m_width(other.m_width),
-	m_height(other.m_height),
-	m_extraIds(other.m_extraIds),
-	m_supportsExternalTransfer(other.m_supportsExternalTransfer){}
-
-
-void BaseItem::replaceData(BaseItem &other) {
-	m_size = other.m_size;
-	m_container = other.m_container;
-	m_dateLastSaved = other.m_dateLastSaved;
-	m_remoteTrailers = other.m_remoteTrailers;
-	m_isHD = other.m_isHD;
-	m_isShortcut = other.m_isShortcut;
-	m_shortcutPath = other.m_shortcutPath;
-	m_width = other.m_width;
-	m_height = other.m_height;
-	m_extraIds = other.m_extraIds;
-	m_supportsExternalTransfer = other.m_supportsExternalTransfer;
-}
-
-BaseItem BaseItem::fromJson(QJsonObject source) {
-	BaseItem instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void BaseItem::setFromJson(QJsonObject source) {
-	m_size = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["Size"]);
-	m_container = Jellyfin::Support::fromJsonValue<QString>(source["Container"]);
-	m_dateLastSaved = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateLastSaved"]);
-	m_remoteTrailers = Jellyfin::Support::fromJsonValue<QList<MediaUrl>>(source["RemoteTrailers"]);
-	m_isHD = Jellyfin::Support::fromJsonValue<bool>(source["IsHD"]);
-	m_isShortcut = Jellyfin::Support::fromJsonValue<bool>(source["IsShortcut"]);
-	m_shortcutPath = Jellyfin::Support::fromJsonValue<QString>(source["ShortcutPath"]);
-	m_width = Jellyfin::Support::fromJsonValue<qint32>(source["Width"]);
-	m_height = Jellyfin::Support::fromJsonValue<qint32>(source["Height"]);
-	m_extraIds = Jellyfin::Support::fromJsonValue<QStringList>(source["ExtraIds"]);
-	m_supportsExternalTransfer = Jellyfin::Support::fromJsonValue<bool>(source["SupportsExternalTransfer"]);
-
-}
-	
-QJsonObject BaseItem::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(!m_size.has_value())) {
-		result["Size"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_size);
-	}
-			
-	
-	if (!(m_container.isNull())) {
-		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
-	}
-			
-	result["DateLastSaved"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateLastSaved);		
-	
-	if (!(m_remoteTrailers.size() == 0)) {
-		result["RemoteTrailers"] = Jellyfin::Support::toJsonValue<QList<MediaUrl>>(m_remoteTrailers);
-	}
-			
-	result["IsHD"] = Jellyfin::Support::toJsonValue<bool>(m_isHD);		
-	result["IsShortcut"] = Jellyfin::Support::toJsonValue<bool>(m_isShortcut);		
-	
-	if (!(m_shortcutPath.isNull())) {
-		result["ShortcutPath"] = Jellyfin::Support::toJsonValue<QString>(m_shortcutPath);
-	}
-			
-	result["Width"] = Jellyfin::Support::toJsonValue<qint32>(m_width);		
-	result["Height"] = Jellyfin::Support::toJsonValue<qint32>(m_height);		
-	
-	if (!(m_extraIds.size() == 0)) {
-		result["ExtraIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_extraIds);
-	}
-			
-	result["SupportsExternalTransfer"] = Jellyfin::Support::toJsonValue<bool>(m_supportsExternalTransfer);	
-	return result;
-}
-
-std::optional<qint64> BaseItem::size() const { return m_size; }
-
-void BaseItem::setSize(std::optional<qint64> newSize) {
-	m_size = newSize;
-}
-bool BaseItem::sizeNull() const {
-	return !m_size.has_value();
-}
-
-void BaseItem::setSizeNull() {
-	m_size = std::nullopt;
-
-}
-QString BaseItem::container() const { return m_container; }
-
-void BaseItem::setContainer(QString newContainer) {
-	m_container = newContainer;
-}
-bool BaseItem::containerNull() const {
-	return m_container.isNull();
-}
-
-void BaseItem::setContainerNull() {
-	m_container.clear();
-
-}
-QDateTime BaseItem::dateLastSaved() const { return m_dateLastSaved; }
-
-void BaseItem::setDateLastSaved(QDateTime newDateLastSaved) {
-	m_dateLastSaved = newDateLastSaved;
-}
-
-QList<MediaUrl> BaseItem::remoteTrailers() const { return m_remoteTrailers; }
-
-void BaseItem::setRemoteTrailers(QList<MediaUrl> newRemoteTrailers) {
-	m_remoteTrailers = newRemoteTrailers;
-}
-bool BaseItem::remoteTrailersNull() const {
-	return m_remoteTrailers.size() == 0;
-}
-
-void BaseItem::setRemoteTrailersNull() {
-	m_remoteTrailers.clear();
-
-}
-bool BaseItem::isHD() const { return m_isHD; }
-
-void BaseItem::setIsHD(bool newIsHD) {
-	m_isHD = newIsHD;
-}
-
-bool BaseItem::isShortcut() const { return m_isShortcut; }
-
-void BaseItem::setIsShortcut(bool newIsShortcut) {
-	m_isShortcut = newIsShortcut;
-}
-
-QString BaseItem::shortcutPath() const { return m_shortcutPath; }
-
-void BaseItem::setShortcutPath(QString newShortcutPath) {
-	m_shortcutPath = newShortcutPath;
-}
-bool BaseItem::shortcutPathNull() const {
-	return m_shortcutPath.isNull();
-}
-
-void BaseItem::setShortcutPathNull() {
-	m_shortcutPath.clear();
-
-}
-qint32 BaseItem::width() const { return m_width; }
-
-void BaseItem::setWidth(qint32 newWidth) {
-	m_width = newWidth;
-}
-
-qint32 BaseItem::height() const { return m_height; }
-
-void BaseItem::setHeight(qint32 newHeight) {
-	m_height = newHeight;
-}
-
-QStringList BaseItem::extraIds() const { return m_extraIds; }
-
-void BaseItem::setExtraIds(QStringList newExtraIds) {
-	m_extraIds = newExtraIds;
-}
-bool BaseItem::extraIdsNull() const {
-	return m_extraIds.size() == 0;
-}
-
-void BaseItem::setExtraIdsNull() {
-	m_extraIds.clear();
-
-}
-bool BaseItem::supportsExternalTransfer() const { return m_supportsExternalTransfer; }
-
-void BaseItem::setSupportsExternalTransfer(bool newSupportsExternalTransfer) {
-	m_supportsExternalTransfer = newSupportsExternalTransfer;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using BaseItem = Jellyfin::DTO::BaseItem;
-
-template <>
-BaseItem fromJsonValue(const QJsonValue &source, convertType<BaseItem>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return BaseItem::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const BaseItem &source, convertType<BaseItem>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/baseitemdto.cpp b/core/src/dto/baseitemdto.cpp
index de284dd..0fef533 100644
--- a/core/src/dto/baseitemdto.cpp
+++ b/core/src/dto/baseitemdto.cpp
@@ -35,24 +35,32 @@ namespace DTO {
 BaseItemDto::BaseItemDto() {}
 BaseItemDto::BaseItemDto (
 		QString jellyfinId, 
+		ExtraType extraType, 
 		Video3DFormat video3DFormat, 
 		PlayAccess playAccess, 
+		BaseItemKind type, 
 		QSharedPointer<UserItemDataDto> userData, 
+		CollectionType collectionType, 
 		VideoType videoType, 
 		LocationType locationType, 
 		IsoType isoType, 
+		MediaType mediaType, 
 		ImageOrientation imageOrientation, 
 		ChannelType channelType, 
 		ProgramAudio audio, 
 		QSharedPointer<BaseItemDto> currentProgram 
 		) :
 	m_jellyfinId(jellyfinId),
+	m_extraType(extraType),
 	m_video3DFormat(video3DFormat),
 	m_playAccess(playAccess),
+	m_type(type),
 	m_userData(userData),
+	m_collectionType(collectionType),
 	m_videoType(videoType),
 	m_locationType(locationType),
 	m_isoType(isoType),
+	m_mediaType(mediaType),
 	m_imageOrientation(imageOrientation),
 	m_channelType(channelType),
 	m_audio(audio),
@@ -77,10 +85,10 @@ BaseItemDto::BaseItemDto(const BaseItemDto &other) :
 	m_airsBeforeEpisodeNumber(other.m_airsBeforeEpisodeNumber),
 	m_canDelete(other.m_canDelete),
 	m_canDownload(other.m_canDownload),
+	m_hasLyrics(other.m_hasLyrics),
 	m_hasSubtitles(other.m_hasSubtitles),
 	m_preferredMetadataLanguage(other.m_preferredMetadataLanguage),
 	m_preferredMetadataCountryCode(other.m_preferredMetadataCountryCode),
-	m_supportsSync(other.m_supportsSync),
 	m_container(other.m_container),
 	m_sortName(other.m_sortName),
 	m_forcedSortName(other.m_forcedSortName),
@@ -166,6 +174,7 @@ BaseItemDto::BaseItemDto(const BaseItemDto &other) :
 	m_parentPrimaryImageItemId(other.m_parentPrimaryImageItemId),
 	m_parentPrimaryImageTag(other.m_parentPrimaryImageTag),
 	m_chapters(other.m_chapters),
+	m_trickplay(other.m_trickplay),
 	m_locationType(other.m_locationType),
 	m_isoType(other.m_isoType),
 	m_mediaType(other.m_mediaType),
@@ -212,6 +221,7 @@ BaseItemDto::BaseItemDto(const BaseItemDto &other) :
 	m_isKids(other.m_isKids),
 	m_isPremiere(other.m_isPremiere),
 	m_timerId(other.m_timerId),
+	m_normalizationGain(other.m_normalizationGain),
 	m_currentProgram(other.m_currentProgram){}
 
 
@@ -231,10 +241,10 @@ void BaseItemDto::replaceData(BaseItemDto &other) {
 	m_airsBeforeEpisodeNumber = other.m_airsBeforeEpisodeNumber;
 	m_canDelete = other.m_canDelete;
 	m_canDownload = other.m_canDownload;
+	m_hasLyrics = other.m_hasLyrics;
 	m_hasSubtitles = other.m_hasSubtitles;
 	m_preferredMetadataLanguage = other.m_preferredMetadataLanguage;
 	m_preferredMetadataCountryCode = other.m_preferredMetadataCountryCode;
-	m_supportsSync = other.m_supportsSync;
 	m_container = other.m_container;
 	m_sortName = other.m_sortName;
 	m_forcedSortName = other.m_forcedSortName;
@@ -320,6 +330,7 @@ void BaseItemDto::replaceData(BaseItemDto &other) {
 	m_parentPrimaryImageItemId = other.m_parentPrimaryImageItemId;
 	m_parentPrimaryImageTag = other.m_parentPrimaryImageTag;
 	m_chapters = other.m_chapters;
+	m_trickplay = other.m_trickplay;
 	m_locationType = other.m_locationType;
 	m_isoType = other.m_isoType;
 	m_mediaType = other.m_mediaType;
@@ -366,6 +377,7 @@ void BaseItemDto::replaceData(BaseItemDto &other) {
 	m_isKids = other.m_isKids;
 	m_isPremiere = other.m_isPremiere;
 	m_timerId = other.m_timerId;
+	m_normalizationGain = other.m_normalizationGain;
 	m_currentProgram = other.m_currentProgram;
 }
 
@@ -386,16 +398,16 @@ void BaseItemDto::setFromJson(QJsonObject source) {
 	m_playlistItemId = Jellyfin::Support::fromJsonValue<QString>(source["PlaylistItemId"]);
 	m_dateCreated = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateCreated"]);
 	m_dateLastMediaAdded = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateLastMediaAdded"]);
-	m_extraType = Jellyfin::Support::fromJsonValue<QString>(source["ExtraType"]);
+	m_extraType = Jellyfin::Support::fromJsonValue<ExtraType>(source["ExtraType"]);
 	m_airsBeforeSeasonNumber = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["AirsBeforeSeasonNumber"]);
 	m_airsAfterSeasonNumber = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["AirsAfterSeasonNumber"]);
 	m_airsBeforeEpisodeNumber = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["AirsBeforeEpisodeNumber"]);
 	m_canDelete = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CanDelete"]);
 	m_canDownload = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CanDownload"]);
+	m_hasLyrics = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["HasLyrics"]);
 	m_hasSubtitles = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["HasSubtitles"]);
 	m_preferredMetadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["PreferredMetadataLanguage"]);
 	m_preferredMetadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["PreferredMetadataCountryCode"]);
-	m_supportsSync = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["SupportsSync"]);
 	m_container = Jellyfin::Support::fromJsonValue<QString>(source["Container"]);
 	m_sortName = Jellyfin::Support::fromJsonValue<QString>(source["SortName"]);
 	m_forcedSortName = Jellyfin::Support::fromJsonValue<QString>(source["ForcedSortName"]);
@@ -431,7 +443,7 @@ void BaseItemDto::setFromJson(QJsonObject source) {
 	m_isHD = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsHD"]);
 	m_isFolder = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsFolder"]);
 	m_parentId = Jellyfin::Support::fromJsonValue<QString>(source["ParentId"]);
-	m_type = Jellyfin::Support::fromJsonValue<QString>(source["Type"]);
+	m_type = Jellyfin::Support::fromJsonValue<BaseItemKind>(source["Type"]);
 	m_people = Jellyfin::Support::fromJsonValue<QList<BaseItemPerson>>(source["People"]);
 	m_studios = Jellyfin::Support::fromJsonValue<QList<NameGuidPair>>(source["Studios"]);
 	m_genreItems = Jellyfin::Support::fromJsonValue<QList<NameGuidPair>>(source["GenreItems"]);
@@ -455,7 +467,7 @@ void BaseItemDto::setFromJson(QJsonObject source) {
 	m_artists = Jellyfin::Support::fromJsonValue<QStringList>(source["Artists"]);
 	m_artistItems = Jellyfin::Support::fromJsonValue<QList<NameGuidPair>>(source["ArtistItems"]);
 	m_album = Jellyfin::Support::fromJsonValue<QString>(source["Album"]);
-	m_collectionType = Jellyfin::Support::fromJsonValue<QString>(source["CollectionType"]);
+	m_collectionType = Jellyfin::Support::fromJsonValue<CollectionType>(source["CollectionType"]);
 	m_displayOrder = Jellyfin::Support::fromJsonValue<QString>(source["DisplayOrder"]);
 	m_albumId = Jellyfin::Support::fromJsonValue<QString>(source["AlbumId"]);
 	m_albumPrimaryImageTag = Jellyfin::Support::fromJsonValue<QString>(source["AlbumPrimaryImageTag"]);
@@ -481,9 +493,10 @@ void BaseItemDto::setFromJson(QJsonObject source) {
 	m_parentPrimaryImageItemId = Jellyfin::Support::fromJsonValue<QString>(source["ParentPrimaryImageItemId"]);
 	m_parentPrimaryImageTag = Jellyfin::Support::fromJsonValue<QString>(source["ParentPrimaryImageTag"]);
 	m_chapters = Jellyfin::Support::fromJsonValue<QList<ChapterInfo>>(source["Chapters"]);
+	m_trickplay = Jellyfin::Support::fromJsonValue<QJsonObject>(source["Trickplay"]);
 	m_locationType = Jellyfin::Support::fromJsonValue<LocationType>(source["LocationType"]);
 	m_isoType = Jellyfin::Support::fromJsonValue<IsoType>(source["IsoType"]);
-	m_mediaType = Jellyfin::Support::fromJsonValue<QString>(source["MediaType"]);
+	m_mediaType = Jellyfin::Support::fromJsonValue<MediaType>(source["MediaType"]);
 	m_endDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["EndDate"]);
 	m_lockedFields = Jellyfin::Support::fromJsonValue<QList<MetadataField>>(source["LockedFields"]);
 	m_trailerCount = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["TrailerCount"]);
@@ -527,6 +540,7 @@ void BaseItemDto::setFromJson(QJsonObject source) {
 	m_isKids = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsKids"]);
 	m_isPremiere = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsPremiere"]);
 	m_timerId = Jellyfin::Support::fromJsonValue<QString>(source["TimerId"]);
+	m_normalizationGain = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["NormalizationGain"]);
 	m_currentProgram = Jellyfin::Support::fromJsonValue<QSharedPointer<BaseItemDto>>(source["CurrentProgram"]);
 
 }
@@ -575,11 +589,7 @@ QJsonObject BaseItemDto::toJson() const {
 		result["DateLastMediaAdded"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateLastMediaAdded);
 	}
 			
-	
-	if (!(m_extraType.isNull())) {
-		result["ExtraType"] = Jellyfin::Support::toJsonValue<QString>(m_extraType);
-	}
-			
+	result["ExtraType"] = Jellyfin::Support::toJsonValue<ExtraType>(m_extraType);		
 	
 	if (!(!m_airsBeforeSeasonNumber.has_value())) {
 		result["AirsBeforeSeasonNumber"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_airsBeforeSeasonNumber);
@@ -606,6 +616,11 @@ QJsonObject BaseItemDto::toJson() const {
 	}
 			
 	
+	if (!(!m_hasLyrics.has_value())) {
+		result["HasLyrics"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_hasLyrics);
+	}
+			
+	
 	if (!(!m_hasSubtitles.has_value())) {
 		result["HasSubtitles"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_hasSubtitles);
 	}
@@ -621,11 +636,6 @@ QJsonObject BaseItemDto::toJson() const {
 	}
 			
 	
-	if (!(!m_supportsSync.has_value())) {
-		result["SupportsSync"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_supportsSync);
-	}
-			
-	
 	if (!(m_container.isNull())) {
 		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
 	}
@@ -792,11 +802,7 @@ QJsonObject BaseItemDto::toJson() const {
 		result["ParentId"] = Jellyfin::Support::toJsonValue<QString>(m_parentId);
 	}
 			
-	
-	if (!(m_type.isNull())) {
-		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
-	}
-			
+	result["Type"] = Jellyfin::Support::toJsonValue<BaseItemKind>(m_type);		
 	
 	if (!(m_people.size() == 0)) {
 		result["People"] = Jellyfin::Support::toJsonValue<QList<BaseItemPerson>>(m_people);
@@ -908,11 +914,7 @@ QJsonObject BaseItemDto::toJson() const {
 		result["Album"] = Jellyfin::Support::toJsonValue<QString>(m_album);
 	}
 			
-	
-	if (!(m_collectionType.isNull())) {
-		result["CollectionType"] = Jellyfin::Support::toJsonValue<QString>(m_collectionType);
-	}
-			
+	result["CollectionType"] = Jellyfin::Support::toJsonValue<CollectionType>(m_collectionType);		
 	
 	if (!(m_displayOrder.isNull())) {
 		result["DisplayOrder"] = Jellyfin::Support::toJsonValue<QString>(m_displayOrder);
@@ -1034,13 +1036,14 @@ QJsonObject BaseItemDto::toJson() const {
 		result["Chapters"] = Jellyfin::Support::toJsonValue<QList<ChapterInfo>>(m_chapters);
 	}
 			
-	result["LocationType"] = Jellyfin::Support::toJsonValue<LocationType>(m_locationType);		
-	result["IsoType"] = Jellyfin::Support::toJsonValue<IsoType>(m_isoType);		
 	
-	if (!(m_mediaType.isNull())) {
-		result["MediaType"] = Jellyfin::Support::toJsonValue<QString>(m_mediaType);
+	if (!(m_trickplay.isEmpty())) {
+		result["Trickplay"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_trickplay);
 	}
 			
+	result["LocationType"] = Jellyfin::Support::toJsonValue<LocationType>(m_locationType);		
+	result["IsoType"] = Jellyfin::Support::toJsonValue<IsoType>(m_isoType);		
+	result["MediaType"] = Jellyfin::Support::toJsonValue<MediaType>(m_mediaType);		
 	
 	if (!(m_endDate.isNull())) {
 		result["EndDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_endDate);
@@ -1244,6 +1247,11 @@ QJsonObject BaseItemDto::toJson() const {
 		result["TimerId"] = Jellyfin::Support::toJsonValue<QString>(m_timerId);
 	}
 			
+	
+	if (!(!m_normalizationGain.has_value())) {
+		result["NormalizationGain"] = Jellyfin::Support::toJsonValue<std::optional<float>>(m_normalizationGain);
+	}
+			
 	result["CurrentProgram"] = Jellyfin::Support::toJsonValue<QSharedPointer<BaseItemDto>>(m_currentProgram);	
 	return result;
 }
@@ -1358,19 +1366,12 @@ void BaseItemDto::setDateLastMediaAddedNull() {
 	m_dateLastMediaAdded= QDateTime();
 
 }
-QString BaseItemDto::extraType() const { return m_extraType; }
+ExtraType BaseItemDto::extraType() const { return m_extraType; }
 
-void BaseItemDto::setExtraType(QString newExtraType) {
+void BaseItemDto::setExtraType(ExtraType newExtraType) {
 	m_extraType = newExtraType;
 }
-bool BaseItemDto::extraTypeNull() const {
-	return m_extraType.isNull();
-}
 
-void BaseItemDto::setExtraTypeNull() {
-	m_extraType.clear();
-
-}
 std::optional<qint32> BaseItemDto::airsBeforeSeasonNumber() const { return m_airsBeforeSeasonNumber; }
 
 void BaseItemDto::setAirsBeforeSeasonNumber(std::optional<qint32> newAirsBeforeSeasonNumber) {
@@ -1435,6 +1436,19 @@ bool BaseItemDto::canDownloadNull() const {
 void BaseItemDto::setCanDownloadNull() {
 	m_canDownload = std::nullopt;
 
+}
+std::optional<bool> BaseItemDto::hasLyrics() const { return m_hasLyrics; }
+
+void BaseItemDto::setHasLyrics(std::optional<bool> newHasLyrics) {
+	m_hasLyrics = newHasLyrics;
+}
+bool BaseItemDto::hasLyricsNull() const {
+	return !m_hasLyrics.has_value();
+}
+
+void BaseItemDto::setHasLyricsNull() {
+	m_hasLyrics = std::nullopt;
+
 }
 std::optional<bool> BaseItemDto::hasSubtitles() const { return m_hasSubtitles; }
 
@@ -1474,19 +1488,6 @@ bool BaseItemDto::preferredMetadataCountryCodeNull() const {
 void BaseItemDto::setPreferredMetadataCountryCodeNull() {
 	m_preferredMetadataCountryCode.clear();
 
-}
-std::optional<bool> BaseItemDto::supportsSync() const { return m_supportsSync; }
-
-void BaseItemDto::setSupportsSync(std::optional<bool> newSupportsSync) {
-	m_supportsSync = newSupportsSync;
-}
-bool BaseItemDto::supportsSyncNull() const {
-	return !m_supportsSync.has_value();
-}
-
-void BaseItemDto::setSupportsSyncNull() {
-	m_supportsSync = std::nullopt;
-
 }
 QString BaseItemDto::container() const { return m_container; }
 
@@ -1929,19 +1930,12 @@ void BaseItemDto::setParentIdNull() {
 	m_parentId.clear();
 
 }
-QString BaseItemDto::type() const { return m_type; }
+BaseItemKind BaseItemDto::type() const { return m_type; }
 
-void BaseItemDto::setType(QString newType) {
+void BaseItemDto::setType(BaseItemKind newType) {
 	m_type = newType;
 }
-bool BaseItemDto::typeNull() const {
-	return m_type.isNull();
-}
 
-void BaseItemDto::setTypeNull() {
-	m_type.clear();
-
-}
 QList<BaseItemPerson> BaseItemDto::people() const { return m_people; }
 
 void BaseItemDto::setPeople(QList<BaseItemPerson> newPeople) {
@@ -2234,19 +2228,12 @@ void BaseItemDto::setAlbumNull() {
 	m_album.clear();
 
 }
-QString BaseItemDto::collectionType() const { return m_collectionType; }
+CollectionType BaseItemDto::collectionType() const { return m_collectionType; }
 
-void BaseItemDto::setCollectionType(QString newCollectionType) {
+void BaseItemDto::setCollectionType(CollectionType newCollectionType) {
 	m_collectionType = newCollectionType;
 }
-bool BaseItemDto::collectionTypeNull() const {
-	return m_collectionType.isNull();
-}
 
-void BaseItemDto::setCollectionTypeNull() {
-	m_collectionType.clear();
-
-}
 QString BaseItemDto::displayOrder() const { return m_displayOrder; }
 
 void BaseItemDto::setDisplayOrder(QString newDisplayOrder) {
@@ -2564,6 +2551,19 @@ bool BaseItemDto::chaptersNull() const {
 void BaseItemDto::setChaptersNull() {
 	m_chapters.clear();
 
+}
+QJsonObject BaseItemDto::trickplay() const { return m_trickplay; }
+
+void BaseItemDto::setTrickplay(QJsonObject newTrickplay) {
+	m_trickplay = newTrickplay;
+}
+bool BaseItemDto::trickplayNull() const {
+	return m_trickplay.isEmpty();
+}
+
+void BaseItemDto::setTrickplayNull() {
+	m_trickplay= QJsonObject();
+
 }
 LocationType BaseItemDto::locationType() const { return m_locationType; }
 
@@ -2577,19 +2577,12 @@ void BaseItemDto::setIsoType(IsoType newIsoType) {
 	m_isoType = newIsoType;
 }
 
-QString BaseItemDto::mediaType() const { return m_mediaType; }
+MediaType BaseItemDto::mediaType() const { return m_mediaType; }
 
-void BaseItemDto::setMediaType(QString newMediaType) {
+void BaseItemDto::setMediaType(MediaType newMediaType) {
 	m_mediaType = newMediaType;
 }
-bool BaseItemDto::mediaTypeNull() const {
-	return m_mediaType.isNull();
-}
 
-void BaseItemDto::setMediaTypeNull() {
-	m_mediaType.clear();
-
-}
 QDateTime BaseItemDto::endDate() const { return m_endDate; }
 
 void BaseItemDto::setEndDate(QDateTime newEndDate) {
@@ -3127,6 +3120,19 @@ bool BaseItemDto::timerIdNull() const {
 void BaseItemDto::setTimerIdNull() {
 	m_timerId.clear();
 
+}
+std::optional<float> BaseItemDto::normalizationGain() const { return m_normalizationGain; }
+
+void BaseItemDto::setNormalizationGain(std::optional<float> newNormalizationGain) {
+	m_normalizationGain = newNormalizationGain;
+}
+bool BaseItemDto::normalizationGainNull() const {
+	return !m_normalizationGain.has_value();
+}
+
+void BaseItemDto::setNormalizationGainNull() {
+	m_normalizationGain = std::nullopt;
+
 }
 QSharedPointer<BaseItemDto> BaseItemDto::currentProgram() const { return m_currentProgram; }
 
diff --git a/core/src/dto/baseitemdtoqueryresult.cpp b/core/src/dto/baseitemdtoqueryresult.cpp
index 336a110..b7d7a7f 100644
--- a/core/src/dto/baseitemdtoqueryresult.cpp
+++ b/core/src/dto/baseitemdtoqueryresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 BaseItemDtoQueryResult::BaseItemDtoQueryResult() {}
 BaseItemDtoQueryResult::BaseItemDtoQueryResult (
+		QList<BaseItemDto> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
@@ -72,11 +74,7 @@ void BaseItemDtoQueryResult::setFromJson(QJsonObject source) {
 QJsonObject BaseItemDtoQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<BaseItemDto>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<BaseItemDto>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
@@ -87,14 +85,7 @@ QList<BaseItemDto> BaseItemDtoQueryResult::items() const { return m_items; }
 void BaseItemDtoQueryResult::setItems(QList<BaseItemDto> newItems) {
 	m_items = newItems;
 }
-bool BaseItemDtoQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void BaseItemDtoQueryResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 BaseItemDtoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void BaseItemDtoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/baseitemkind.cpp b/core/src/dto/baseitemkind.cpp
new file mode 100644
index 0000000..3655e61
--- /dev/null
+++ b/core/src/dto/baseitemkind.cpp
@@ -0,0 +1,248 @@
+/*
+ * 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/dto/baseitemkind.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+BaseItemKindClass::BaseItemKindClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using BaseItemKind = Jellyfin::DTO::BaseItemKind;
+
+template <>
+BaseItemKind fromJsonValue(const QJsonValue &source, convertType<BaseItemKind>) {
+	if (!source.isString()) return BaseItemKind::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("AggregateFolder")) {
+		return BaseItemKind::AggregateFolder;
+	}
+	if (str == QStringLiteral("Audio")) {
+		return BaseItemKind::Audio;
+	}
+	if (str == QStringLiteral("AudioBook")) {
+		return BaseItemKind::AudioBook;
+	}
+	if (str == QStringLiteral("BasePluginFolder")) {
+		return BaseItemKind::BasePluginFolder;
+	}
+	if (str == QStringLiteral("Book")) {
+		return BaseItemKind::Book;
+	}
+	if (str == QStringLiteral("BoxSet")) {
+		return BaseItemKind::BoxSet;
+	}
+	if (str == QStringLiteral("Channel")) {
+		return BaseItemKind::Channel;
+	}
+	if (str == QStringLiteral("ChannelFolderItem")) {
+		return BaseItemKind::ChannelFolderItem;
+	}
+	if (str == QStringLiteral("CollectionFolder")) {
+		return BaseItemKind::CollectionFolder;
+	}
+	if (str == QStringLiteral("Episode")) {
+		return BaseItemKind::Episode;
+	}
+	if (str == QStringLiteral("Folder")) {
+		return BaseItemKind::Folder;
+	}
+	if (str == QStringLiteral("Genre")) {
+		return BaseItemKind::Genre;
+	}
+	if (str == QStringLiteral("ManualPlaylistsFolder")) {
+		return BaseItemKind::ManualPlaylistsFolder;
+	}
+	if (str == QStringLiteral("Movie")) {
+		return BaseItemKind::Movie;
+	}
+	if (str == QStringLiteral("LiveTvChannel")) {
+		return BaseItemKind::LiveTvChannel;
+	}
+	if (str == QStringLiteral("LiveTvProgram")) {
+		return BaseItemKind::LiveTvProgram;
+	}
+	if (str == QStringLiteral("MusicAlbum")) {
+		return BaseItemKind::MusicAlbum;
+	}
+	if (str == QStringLiteral("MusicArtist")) {
+		return BaseItemKind::MusicArtist;
+	}
+	if (str == QStringLiteral("MusicGenre")) {
+		return BaseItemKind::MusicGenre;
+	}
+	if (str == QStringLiteral("MusicVideo")) {
+		return BaseItemKind::MusicVideo;
+	}
+	if (str == QStringLiteral("Person")) {
+		return BaseItemKind::Person;
+	}
+	if (str == QStringLiteral("Photo")) {
+		return BaseItemKind::Photo;
+	}
+	if (str == QStringLiteral("PhotoAlbum")) {
+		return BaseItemKind::PhotoAlbum;
+	}
+	if (str == QStringLiteral("Playlist")) {
+		return BaseItemKind::Playlist;
+	}
+	if (str == QStringLiteral("PlaylistsFolder")) {
+		return BaseItemKind::PlaylistsFolder;
+	}
+	if (str == QStringLiteral("Program")) {
+		return BaseItemKind::Program;
+	}
+	if (str == QStringLiteral("Recording")) {
+		return BaseItemKind::Recording;
+	}
+	if (str == QStringLiteral("Season")) {
+		return BaseItemKind::Season;
+	}
+	if (str == QStringLiteral("Series")) {
+		return BaseItemKind::Series;
+	}
+	if (str == QStringLiteral("Studio")) {
+		return BaseItemKind::Studio;
+	}
+	if (str == QStringLiteral("Trailer")) {
+		return BaseItemKind::Trailer;
+	}
+	if (str == QStringLiteral("TvChannel")) {
+		return BaseItemKind::TvChannel;
+	}
+	if (str == QStringLiteral("TvProgram")) {
+		return BaseItemKind::TvProgram;
+	}
+	if (str == QStringLiteral("UserRootFolder")) {
+		return BaseItemKind::UserRootFolder;
+	}
+	if (str == QStringLiteral("UserView")) {
+		return BaseItemKind::UserView;
+	}
+	if (str == QStringLiteral("Video")) {
+		return BaseItemKind::Video;
+	}
+	if (str == QStringLiteral("Year")) {
+		return BaseItemKind::Year;
+	}
+	
+	return BaseItemKind::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const BaseItemKind &source, convertType<BaseItemKind>) {
+	switch(source) {
+	case BaseItemKind::AggregateFolder:
+		return QStringLiteral("AggregateFolder");
+	case BaseItemKind::Audio:
+		return QStringLiteral("Audio");
+	case BaseItemKind::AudioBook:
+		return QStringLiteral("AudioBook");
+	case BaseItemKind::BasePluginFolder:
+		return QStringLiteral("BasePluginFolder");
+	case BaseItemKind::Book:
+		return QStringLiteral("Book");
+	case BaseItemKind::BoxSet:
+		return QStringLiteral("BoxSet");
+	case BaseItemKind::Channel:
+		return QStringLiteral("Channel");
+	case BaseItemKind::ChannelFolderItem:
+		return QStringLiteral("ChannelFolderItem");
+	case BaseItemKind::CollectionFolder:
+		return QStringLiteral("CollectionFolder");
+	case BaseItemKind::Episode:
+		return QStringLiteral("Episode");
+	case BaseItemKind::Folder:
+		return QStringLiteral("Folder");
+	case BaseItemKind::Genre:
+		return QStringLiteral("Genre");
+	case BaseItemKind::ManualPlaylistsFolder:
+		return QStringLiteral("ManualPlaylistsFolder");
+	case BaseItemKind::Movie:
+		return QStringLiteral("Movie");
+	case BaseItemKind::LiveTvChannel:
+		return QStringLiteral("LiveTvChannel");
+	case BaseItemKind::LiveTvProgram:
+		return QStringLiteral("LiveTvProgram");
+	case BaseItemKind::MusicAlbum:
+		return QStringLiteral("MusicAlbum");
+	case BaseItemKind::MusicArtist:
+		return QStringLiteral("MusicArtist");
+	case BaseItemKind::MusicGenre:
+		return QStringLiteral("MusicGenre");
+	case BaseItemKind::MusicVideo:
+		return QStringLiteral("MusicVideo");
+	case BaseItemKind::Person:
+		return QStringLiteral("Person");
+	case BaseItemKind::Photo:
+		return QStringLiteral("Photo");
+	case BaseItemKind::PhotoAlbum:
+		return QStringLiteral("PhotoAlbum");
+	case BaseItemKind::Playlist:
+		return QStringLiteral("Playlist");
+	case BaseItemKind::PlaylistsFolder:
+		return QStringLiteral("PlaylistsFolder");
+	case BaseItemKind::Program:
+		return QStringLiteral("Program");
+	case BaseItemKind::Recording:
+		return QStringLiteral("Recording");
+	case BaseItemKind::Season:
+		return QStringLiteral("Season");
+	case BaseItemKind::Series:
+		return QStringLiteral("Series");
+	case BaseItemKind::Studio:
+		return QStringLiteral("Studio");
+	case BaseItemKind::Trailer:
+		return QStringLiteral("Trailer");
+	case BaseItemKind::TvChannel:
+		return QStringLiteral("TvChannel");
+	case BaseItemKind::TvProgram:
+		return QStringLiteral("TvProgram");
+	case BaseItemKind::UserRootFolder:
+		return QStringLiteral("UserRootFolder");
+	case BaseItemKind::UserView:
+		return QStringLiteral("UserView");
+	case BaseItemKind::Video:
+		return QStringLiteral("Video");
+	case BaseItemKind::Year:
+		return QStringLiteral("Year");
+
+	case BaseItemKind::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/baseitemperson.cpp b/core/src/dto/baseitemperson.cpp
index a838d0f..95cb0e1 100644
--- a/core/src/dto/baseitemperson.cpp
+++ b/core/src/dto/baseitemperson.cpp
@@ -33,6 +33,14 @@ namespace Jellyfin {
 namespace DTO {
 
 BaseItemPerson::BaseItemPerson() {}
+BaseItemPerson::BaseItemPerson (
+		QString jellyfinId, 
+		PersonKind type 
+		) :
+	m_jellyfinId(jellyfinId),
+	m_type(type) { }
+
+
 
 BaseItemPerson::BaseItemPerson(const BaseItemPerson &other) :
 
@@ -64,7 +72,7 @@ void BaseItemPerson::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
 	m_role = Jellyfin::Support::fromJsonValue<QString>(source["Role"]);
-	m_type = Jellyfin::Support::fromJsonValue<QString>(source["Type"]);
+	m_type = Jellyfin::Support::fromJsonValue<PersonKind>(source["Type"]);
 	m_primaryImageTag = Jellyfin::Support::fromJsonValue<QString>(source["PrimaryImageTag"]);
 	m_imageBlurHashes = Jellyfin::Support::fromJsonValue<QJsonObject>(source["ImageBlurHashes"]);
 
@@ -78,21 +86,13 @@ QJsonObject BaseItemPerson::toJson() const {
 		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
 	}
 			
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-			
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
 	
 	if (!(m_role.isNull())) {
 		result["Role"] = Jellyfin::Support::toJsonValue<QString>(m_role);
 	}
 			
-	
-	if (!(m_type.isNull())) {
-		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
-	}
-			
+	result["Type"] = Jellyfin::Support::toJsonValue<PersonKind>(m_type);		
 	
 	if (!(m_primaryImageTag.isNull())) {
 		result["PrimaryImageTag"] = Jellyfin::Support::toJsonValue<QString>(m_primaryImageTag);
@@ -124,14 +124,7 @@ QString BaseItemPerson::jellyfinId() const { return m_jellyfinId; }
 void BaseItemPerson::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool BaseItemPerson::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
 
-void BaseItemPerson::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
 QString BaseItemPerson::role() const { return m_role; }
 
 void BaseItemPerson::setRole(QString newRole) {
@@ -145,19 +138,12 @@ void BaseItemPerson::setRoleNull() {
 	m_role.clear();
 
 }
-QString BaseItemPerson::type() const { return m_type; }
+PersonKind BaseItemPerson::type() const { return m_type; }
 
-void BaseItemPerson::setType(QString newType) {
+void BaseItemPerson::setType(PersonKind newType) {
 	m_type = newType;
 }
-bool BaseItemPerson::typeNull() const {
-	return m_type.isNull();
-}
 
-void BaseItemPerson::setTypeNull() {
-	m_type.clear();
-
-}
 QString BaseItemPerson::primaryImageTag() const { return m_primaryImageTag; }
 
 void BaseItemPerson::setPrimaryImageTag(QString newPrimaryImageTag) {
diff --git a/core/src/dto/bookinfo.cpp b/core/src/dto/bookinfo.cpp
index 9f66d08..0183e36 100644
--- a/core/src/dto/bookinfo.cpp
+++ b/core/src/dto/bookinfo.cpp
@@ -43,6 +43,7 @@ BookInfo::BookInfo (
 BookInfo::BookInfo(const BookInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -57,6 +58,7 @@ BookInfo::BookInfo(const BookInfo &other) :
 
 void BookInfo::replaceData(BookInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -78,6 +80,7 @@ BookInfo BookInfo::fromJson(QJsonObject source) {
 
 void BookInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -100,6 +103,11 @@ QJsonObject BookInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -160,6 +168,19 @@ bool BookInfo::nameNull() const {
 void BookInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString BookInfo::originalTitle() const { return m_originalTitle; }
+
+void BookInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool BookInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void BookInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString BookInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/boxsetinfo.cpp b/core/src/dto/boxsetinfo.cpp
index 05a5ddf..602d172 100644
--- a/core/src/dto/boxsetinfo.cpp
+++ b/core/src/dto/boxsetinfo.cpp
@@ -43,6 +43,7 @@ BoxSetInfo::BoxSetInfo (
 BoxSetInfo::BoxSetInfo(const BoxSetInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -56,6 +57,7 @@ BoxSetInfo::BoxSetInfo(const BoxSetInfo &other) :
 
 void BoxSetInfo::replaceData(BoxSetInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -76,6 +78,7 @@ BoxSetInfo BoxSetInfo::fromJson(QJsonObject source) {
 
 void BoxSetInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -97,6 +100,11 @@ QJsonObject BoxSetInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -152,6 +160,19 @@ bool BoxSetInfo::nameNull() const {
 void BoxSetInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString BoxSetInfo::originalTitle() const { return m_originalTitle; }
+
+void BoxSetInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool BoxSetInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void BoxSetInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString BoxSetInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/brandingoptions.cpp b/core/src/dto/brandingoptions.cpp
index 7a7f6b6..5ffc5e4 100644
--- a/core/src/dto/brandingoptions.cpp
+++ b/core/src/dto/brandingoptions.cpp
@@ -33,16 +33,24 @@ namespace Jellyfin {
 namespace DTO {
 
 BrandingOptions::BrandingOptions() {}
+BrandingOptions::BrandingOptions (
+		bool splashscreenEnabled 
+		) :
+	m_splashscreenEnabled(splashscreenEnabled) { }
+
+
 
 BrandingOptions::BrandingOptions(const BrandingOptions &other) :
 
 	m_loginDisclaimer(other.m_loginDisclaimer),
-	m_customCss(other.m_customCss){}
+	m_customCss(other.m_customCss),
+	m_splashscreenEnabled(other.m_splashscreenEnabled){}
 
 
 void BrandingOptions::replaceData(BrandingOptions &other) {
 	m_loginDisclaimer = other.m_loginDisclaimer;
 	m_customCss = other.m_customCss;
+	m_splashscreenEnabled = other.m_splashscreenEnabled;
 }
 
 BrandingOptions BrandingOptions::fromJson(QJsonObject source) {
@@ -55,6 +63,7 @@ BrandingOptions BrandingOptions::fromJson(QJsonObject source) {
 void BrandingOptions::setFromJson(QJsonObject source) {
 	m_loginDisclaimer = Jellyfin::Support::fromJsonValue<QString>(source["LoginDisclaimer"]);
 	m_customCss = Jellyfin::Support::fromJsonValue<QString>(source["CustomCss"]);
+	m_splashscreenEnabled = Jellyfin::Support::fromJsonValue<bool>(source["SplashscreenEnabled"]);
 
 }
 	
@@ -70,7 +79,8 @@ QJsonObject BrandingOptions::toJson() const {
 	if (!(m_customCss.isNull())) {
 		result["CustomCss"] = Jellyfin::Support::toJsonValue<QString>(m_customCss);
 	}
-		
+			
+	result["SplashscreenEnabled"] = Jellyfin::Support::toJsonValue<bool>(m_splashscreenEnabled);	
 	return result;
 }
 
@@ -100,6 +110,12 @@ void BrandingOptions::setCustomCssNull() {
 	m_customCss.clear();
 
 }
+bool BrandingOptions::splashscreenEnabled() const { return m_splashscreenEnabled; }
+
+void BrandingOptions::setSplashscreenEnabled(bool newSplashscreenEnabled) {
+	m_splashscreenEnabled = newSplashscreenEnabled;
+}
+
 
 } // NS DTO
 
diff --git a/core/src/dto/xmlattribute.cpp b/core/src/dto/castreceiverapplication.cpp
similarity index 52%
rename from core/src/dto/xmlattribute.cpp
rename to core/src/dto/castreceiverapplication.cpp
index 83cf0bd..288d29d 100644
--- a/core/src/dto/xmlattribute.cpp
+++ b/core/src/dto/castreceiverapplication.cpp
@@ -27,94 +27,80 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/xmlattribute.h>
+#include <JellyfinQt/dto/castreceiverapplication.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-XmlAttribute::XmlAttribute() {}
-
-XmlAttribute::XmlAttribute(const XmlAttribute &other) :
-
-	m_name(other.m_name),
-	m_value(other.m_value){}
+CastReceiverApplication::CastReceiverApplication() {}
+CastReceiverApplication::CastReceiverApplication (
+		QString jellyfinId, 
+		QString name 
+		) :
+	m_jellyfinId(jellyfinId),
+	m_name(name) { }
 
 
-void XmlAttribute::replaceData(XmlAttribute &other) {
+
+CastReceiverApplication::CastReceiverApplication(const CastReceiverApplication &other) :
+
+	m_jellyfinId(other.m_jellyfinId),
+	m_name(other.m_name){}
+
+
+void CastReceiverApplication::replaceData(CastReceiverApplication &other) {
+	m_jellyfinId = other.m_jellyfinId;
 	m_name = other.m_name;
-	m_value = other.m_value;
 }
 
-XmlAttribute XmlAttribute::fromJson(QJsonObject source) {
-	XmlAttribute instance;
+CastReceiverApplication CastReceiverApplication::fromJson(QJsonObject source) {
+	CastReceiverApplication instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void XmlAttribute::setFromJson(QJsonObject source) {
+void CastReceiverApplication::setFromJson(QJsonObject source) {
+	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_value = Jellyfin::Support::fromJsonValue<QString>(source["Value"]);
 
 }
 	
-QJsonObject XmlAttribute::toJson() const {
+QJsonObject CastReceiverApplication::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_value.isNull())) {
-		result["Value"] = Jellyfin::Support::toJsonValue<QString>(m_value);
-	}
-		
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);	
 	return result;
 }
 
-QString XmlAttribute::name() const { return m_name; }
+QString CastReceiverApplication::jellyfinId() const { return m_jellyfinId; }
 
-void XmlAttribute::setName(QString newName) {
+void CastReceiverApplication::setJellyfinId(QString newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
+}
+
+QString CastReceiverApplication::name() const { return m_name; }
+
+void CastReceiverApplication::setName(QString newName) {
 	m_name = newName;
 }
-bool XmlAttribute::nameNull() const {
-	return m_name.isNull();
-}
 
-void XmlAttribute::setNameNull() {
-	m_name.clear();
-
-}
-QString XmlAttribute::value() const { return m_value; }
-
-void XmlAttribute::setValue(QString newValue) {
-	m_value = newValue;
-}
-bool XmlAttribute::valueNull() const {
-	return m_value.isNull();
-}
-
-void XmlAttribute::setValueNull() {
-	m_value.clear();
-
-}
 
 } // NS DTO
 
 namespace Support {
 
-using XmlAttribute = Jellyfin::DTO::XmlAttribute;
+using CastReceiverApplication = Jellyfin::DTO::CastReceiverApplication;
 
 template <>
-XmlAttribute fromJsonValue(const QJsonValue &source, convertType<XmlAttribute>) {
+CastReceiverApplication fromJsonValue(const QJsonValue &source, convertType<CastReceiverApplication>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return XmlAttribute::fromJson(source.toObject());
+	return CastReceiverApplication::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const XmlAttribute &source, convertType<XmlAttribute>) {
+QJsonValue toJsonValue(const CastReceiverApplication &source, convertType<CastReceiverApplication>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/channelfeatures.cpp b/core/src/dto/channelfeatures.cpp
index 6f9d728..b35de6e 100644
--- a/core/src/dto/channelfeatures.cpp
+++ b/core/src/dto/channelfeatures.cpp
@@ -34,13 +34,23 @@ namespace DTO {
 
 ChannelFeatures::ChannelFeatures() {}
 ChannelFeatures::ChannelFeatures (
+		QString name, 
+		QString jellyfinId, 
 		bool canSearch, 
+		QList<ChannelMediaType> mediaTypes, 
+		QList<ChannelMediaContentType> contentTypes, 
+		QList<ChannelItemSortField> defaultSortFields, 
 		bool supportsSortOrderToggle, 
 		bool supportsLatestMedia, 
 		bool canFilter, 
 		bool supportsContentDownloading 
 		) :
+	m_name(name),
+	m_jellyfinId(jellyfinId),
 	m_canSearch(canSearch),
+	m_mediaTypes(mediaTypes),
+	m_contentTypes(contentTypes),
+	m_defaultSortFields(defaultSortFields),
 	m_supportsSortOrderToggle(supportsSortOrderToggle),
 	m_supportsLatestMedia(supportsLatestMedia),
 	m_canFilter(canFilter),
@@ -105,27 +115,11 @@ void ChannelFeatures::setFromJson(QJsonObject source) {
 QJsonObject ChannelFeatures::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
 	result["CanSearch"] = Jellyfin::Support::toJsonValue<bool>(m_canSearch);		
-	
-	if (!(m_mediaTypes.size() == 0)) {
-		result["MediaTypes"] = Jellyfin::Support::toJsonValue<QList<ChannelMediaType>>(m_mediaTypes);
-	}
-			
-	
-	if (!(m_contentTypes.size() == 0)) {
-		result["ContentTypes"] = Jellyfin::Support::toJsonValue<QList<ChannelMediaContentType>>(m_contentTypes);
-	}
-			
+	result["MediaTypes"] = Jellyfin::Support::toJsonValue<QList<ChannelMediaType>>(m_mediaTypes);		
+	result["ContentTypes"] = Jellyfin::Support::toJsonValue<QList<ChannelMediaContentType>>(m_contentTypes);		
 	
 	if (!(!m_maxPageSize.has_value())) {
 		result["MaxPageSize"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_maxPageSize);
@@ -136,11 +130,7 @@ QJsonObject ChannelFeatures::toJson() const {
 		result["AutoRefreshLevels"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_autoRefreshLevels);
 	}
 			
-	
-	if (!(m_defaultSortFields.size() == 0)) {
-		result["DefaultSortFields"] = Jellyfin::Support::toJsonValue<QList<ChannelItemSortField>>(m_defaultSortFields);
-	}
-			
+	result["DefaultSortFields"] = Jellyfin::Support::toJsonValue<QList<ChannelItemSortField>>(m_defaultSortFields);		
 	result["SupportsSortOrderToggle"] = Jellyfin::Support::toJsonValue<bool>(m_supportsSortOrderToggle);		
 	result["SupportsLatestMedia"] = Jellyfin::Support::toJsonValue<bool>(m_supportsLatestMedia);		
 	result["CanFilter"] = Jellyfin::Support::toJsonValue<bool>(m_canFilter);		
@@ -153,27 +143,13 @@ QString ChannelFeatures::name() const { return m_name; }
 void ChannelFeatures::setName(QString newName) {
 	m_name = newName;
 }
-bool ChannelFeatures::nameNull() const {
-	return m_name.isNull();
-}
 
-void ChannelFeatures::setNameNull() {
-	m_name.clear();
-
-}
 QString ChannelFeatures::jellyfinId() const { return m_jellyfinId; }
 
 void ChannelFeatures::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool ChannelFeatures::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
 
-void ChannelFeatures::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
 bool ChannelFeatures::canSearch() const { return m_canSearch; }
 
 void ChannelFeatures::setCanSearch(bool newCanSearch) {
@@ -185,27 +161,13 @@ QList<ChannelMediaType> ChannelFeatures::mediaTypes() const { return m_mediaType
 void ChannelFeatures::setMediaTypes(QList<ChannelMediaType> newMediaTypes) {
 	m_mediaTypes = newMediaTypes;
 }
-bool ChannelFeatures::mediaTypesNull() const {
-	return m_mediaTypes.size() == 0;
-}
 
-void ChannelFeatures::setMediaTypesNull() {
-	m_mediaTypes.clear();
-
-}
 QList<ChannelMediaContentType> ChannelFeatures::contentTypes() const { return m_contentTypes; }
 
 void ChannelFeatures::setContentTypes(QList<ChannelMediaContentType> newContentTypes) {
 	m_contentTypes = newContentTypes;
 }
-bool ChannelFeatures::contentTypesNull() const {
-	return m_contentTypes.size() == 0;
-}
 
-void ChannelFeatures::setContentTypesNull() {
-	m_contentTypes.clear();
-
-}
 std::optional<qint32> ChannelFeatures::maxPageSize() const { return m_maxPageSize; }
 
 void ChannelFeatures::setMaxPageSize(std::optional<qint32> newMaxPageSize) {
@@ -237,14 +199,7 @@ QList<ChannelItemSortField> ChannelFeatures::defaultSortFields() const { return
 void ChannelFeatures::setDefaultSortFields(QList<ChannelItemSortField> newDefaultSortFields) {
 	m_defaultSortFields = newDefaultSortFields;
 }
-bool ChannelFeatures::defaultSortFieldsNull() const {
-	return m_defaultSortFields.size() == 0;
-}
 
-void ChannelFeatures::setDefaultSortFieldsNull() {
-	m_defaultSortFields.clear();
-
-}
 bool ChannelFeatures::supportsSortOrderToggle() const { return m_supportsSortOrderToggle; }
 
 void ChannelFeatures::setSupportsSortOrderToggle(bool newSupportsSortOrderToggle) {
diff --git a/core/src/dto/channelmappingoptionsdto.cpp b/core/src/dto/channelmappingoptionsdto.cpp
index b248361..fa1e70d 100644
--- a/core/src/dto/channelmappingoptionsdto.cpp
+++ b/core/src/dto/channelmappingoptionsdto.cpp
@@ -33,6 +33,16 @@ namespace Jellyfin {
 namespace DTO {
 
 ChannelMappingOptionsDto::ChannelMappingOptionsDto() {}
+ChannelMappingOptionsDto::ChannelMappingOptionsDto (
+		QList<TunerChannelMapping> tunerChannels, 
+		QList<NameIdPair> providerChannels, 
+		QList<NameValuePair> mappings 
+		) :
+	m_tunerChannels(tunerChannels),
+	m_providerChannels(providerChannels),
+	m_mappings(mappings) { }
+
+
 
 ChannelMappingOptionsDto::ChannelMappingOptionsDto(const ChannelMappingOptionsDto &other) :
 
@@ -67,21 +77,9 @@ void ChannelMappingOptionsDto::setFromJson(QJsonObject source) {
 QJsonObject ChannelMappingOptionsDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_tunerChannels.size() == 0)) {
-		result["TunerChannels"] = Jellyfin::Support::toJsonValue<QList<TunerChannelMapping>>(m_tunerChannels);
-	}
-			
-	
-	if (!(m_providerChannels.size() == 0)) {
-		result["ProviderChannels"] = Jellyfin::Support::toJsonValue<QList<NameIdPair>>(m_providerChannels);
-	}
-			
-	
-	if (!(m_mappings.size() == 0)) {
-		result["Mappings"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_mappings);
-	}
-			
+	result["TunerChannels"] = Jellyfin::Support::toJsonValue<QList<TunerChannelMapping>>(m_tunerChannels);		
+	result["ProviderChannels"] = Jellyfin::Support::toJsonValue<QList<NameIdPair>>(m_providerChannels);		
+	result["Mappings"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_mappings);		
 	
 	if (!(m_providerName.isNull())) {
 		result["ProviderName"] = Jellyfin::Support::toJsonValue<QString>(m_providerName);
@@ -95,40 +93,19 @@ QList<TunerChannelMapping> ChannelMappingOptionsDto::tunerChannels() const { ret
 void ChannelMappingOptionsDto::setTunerChannels(QList<TunerChannelMapping> newTunerChannels) {
 	m_tunerChannels = newTunerChannels;
 }
-bool ChannelMappingOptionsDto::tunerChannelsNull() const {
-	return m_tunerChannels.size() == 0;
-}
 
-void ChannelMappingOptionsDto::setTunerChannelsNull() {
-	m_tunerChannels.clear();
-
-}
 QList<NameIdPair> ChannelMappingOptionsDto::providerChannels() const { return m_providerChannels; }
 
 void ChannelMappingOptionsDto::setProviderChannels(QList<NameIdPair> newProviderChannels) {
 	m_providerChannels = newProviderChannels;
 }
-bool ChannelMappingOptionsDto::providerChannelsNull() const {
-	return m_providerChannels.size() == 0;
-}
 
-void ChannelMappingOptionsDto::setProviderChannelsNull() {
-	m_providerChannels.clear();
-
-}
 QList<NameValuePair> ChannelMappingOptionsDto::mappings() const { return m_mappings; }
 
 void ChannelMappingOptionsDto::setMappings(QList<NameValuePair> newMappings) {
 	m_mappings = newMappings;
 }
-bool ChannelMappingOptionsDto::mappingsNull() const {
-	return m_mappings.size() == 0;
-}
 
-void ChannelMappingOptionsDto::setMappingsNull() {
-	m_mappings.clear();
-
-}
 QString ChannelMappingOptionsDto::providerName() const { return m_providerName; }
 
 void ChannelMappingOptionsDto::setProviderName(QString newProviderName) {
diff --git a/core/src/dto/clientcapabilities.cpp b/core/src/dto/clientcapabilities.cpp
deleted file mode 100644
index bf07b9a..0000000
--- a/core/src/dto/clientcapabilities.cpp
+++ /dev/null
@@ -1,249 +0,0 @@
-/*
- * 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/dto/clientcapabilities.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-ClientCapabilities::ClientCapabilities() {}
-ClientCapabilities::ClientCapabilities (
-		bool supportsMediaControl, 
-		bool supportsContentUploading, 
-		bool supportsPersistentIdentifier, 
-		bool supportsSync, 
-		QSharedPointer<DeviceProfile> deviceProfile 
-		) :
-	m_supportsMediaControl(supportsMediaControl),
-	m_supportsContentUploading(supportsContentUploading),
-	m_supportsPersistentIdentifier(supportsPersistentIdentifier),
-	m_supportsSync(supportsSync),
-	m_deviceProfile(deviceProfile) { }
-
-
-
-ClientCapabilities::ClientCapabilities(const ClientCapabilities &other) :
-
-	m_playableMediaTypes(other.m_playableMediaTypes),
-	m_supportedCommands(other.m_supportedCommands),
-	m_supportsMediaControl(other.m_supportsMediaControl),
-	m_supportsContentUploading(other.m_supportsContentUploading),
-	m_messageCallbackUrl(other.m_messageCallbackUrl),
-	m_supportsPersistentIdentifier(other.m_supportsPersistentIdentifier),
-	m_supportsSync(other.m_supportsSync),
-	m_deviceProfile(other.m_deviceProfile),
-	m_appStoreUrl(other.m_appStoreUrl),
-	m_iconUrl(other.m_iconUrl){}
-
-
-void ClientCapabilities::replaceData(ClientCapabilities &other) {
-	m_playableMediaTypes = other.m_playableMediaTypes;
-	m_supportedCommands = other.m_supportedCommands;
-	m_supportsMediaControl = other.m_supportsMediaControl;
-	m_supportsContentUploading = other.m_supportsContentUploading;
-	m_messageCallbackUrl = other.m_messageCallbackUrl;
-	m_supportsPersistentIdentifier = other.m_supportsPersistentIdentifier;
-	m_supportsSync = other.m_supportsSync;
-	m_deviceProfile = other.m_deviceProfile;
-	m_appStoreUrl = other.m_appStoreUrl;
-	m_iconUrl = other.m_iconUrl;
-}
-
-ClientCapabilities ClientCapabilities::fromJson(QJsonObject source) {
-	ClientCapabilities instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void ClientCapabilities::setFromJson(QJsonObject source) {
-	m_playableMediaTypes = Jellyfin::Support::fromJsonValue<QStringList>(source["PlayableMediaTypes"]);
-	m_supportedCommands = Jellyfin::Support::fromJsonValue<QList<GeneralCommandType>>(source["SupportedCommands"]);
-	m_supportsMediaControl = Jellyfin::Support::fromJsonValue<bool>(source["SupportsMediaControl"]);
-	m_supportsContentUploading = Jellyfin::Support::fromJsonValue<bool>(source["SupportsContentUploading"]);
-	m_messageCallbackUrl = Jellyfin::Support::fromJsonValue<QString>(source["MessageCallbackUrl"]);
-	m_supportsPersistentIdentifier = Jellyfin::Support::fromJsonValue<bool>(source["SupportsPersistentIdentifier"]);
-	m_supportsSync = Jellyfin::Support::fromJsonValue<bool>(source["SupportsSync"]);
-	m_deviceProfile = Jellyfin::Support::fromJsonValue<QSharedPointer<DeviceProfile>>(source["DeviceProfile"]);
-	m_appStoreUrl = Jellyfin::Support::fromJsonValue<QString>(source["AppStoreUrl"]);
-	m_iconUrl = Jellyfin::Support::fromJsonValue<QString>(source["IconUrl"]);
-
-}
-	
-QJsonObject ClientCapabilities::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_playableMediaTypes.size() == 0)) {
-		result["PlayableMediaTypes"] = Jellyfin::Support::toJsonValue<QStringList>(m_playableMediaTypes);
-	}
-			
-	
-	if (!(m_supportedCommands.size() == 0)) {
-		result["SupportedCommands"] = Jellyfin::Support::toJsonValue<QList<GeneralCommandType>>(m_supportedCommands);
-	}
-			
-	result["SupportsMediaControl"] = Jellyfin::Support::toJsonValue<bool>(m_supportsMediaControl);		
-	result["SupportsContentUploading"] = Jellyfin::Support::toJsonValue<bool>(m_supportsContentUploading);		
-	
-	if (!(m_messageCallbackUrl.isNull())) {
-		result["MessageCallbackUrl"] = Jellyfin::Support::toJsonValue<QString>(m_messageCallbackUrl);
-	}
-			
-	result["SupportsPersistentIdentifier"] = Jellyfin::Support::toJsonValue<bool>(m_supportsPersistentIdentifier);		
-	result["SupportsSync"] = Jellyfin::Support::toJsonValue<bool>(m_supportsSync);		
-	result["DeviceProfile"] = Jellyfin::Support::toJsonValue<QSharedPointer<DeviceProfile>>(m_deviceProfile);		
-	
-	if (!(m_appStoreUrl.isNull())) {
-		result["AppStoreUrl"] = Jellyfin::Support::toJsonValue<QString>(m_appStoreUrl);
-	}
-			
-	
-	if (!(m_iconUrl.isNull())) {
-		result["IconUrl"] = Jellyfin::Support::toJsonValue<QString>(m_iconUrl);
-	}
-		
-	return result;
-}
-
-QStringList ClientCapabilities::playableMediaTypes() const { return m_playableMediaTypes; }
-
-void ClientCapabilities::setPlayableMediaTypes(QStringList newPlayableMediaTypes) {
-	m_playableMediaTypes = newPlayableMediaTypes;
-}
-bool ClientCapabilities::playableMediaTypesNull() const {
-	return m_playableMediaTypes.size() == 0;
-}
-
-void ClientCapabilities::setPlayableMediaTypesNull() {
-	m_playableMediaTypes.clear();
-
-}
-QList<GeneralCommandType> ClientCapabilities::supportedCommands() const { return m_supportedCommands; }
-
-void ClientCapabilities::setSupportedCommands(QList<GeneralCommandType> newSupportedCommands) {
-	m_supportedCommands = newSupportedCommands;
-}
-bool ClientCapabilities::supportedCommandsNull() const {
-	return m_supportedCommands.size() == 0;
-}
-
-void ClientCapabilities::setSupportedCommandsNull() {
-	m_supportedCommands.clear();
-
-}
-bool ClientCapabilities::supportsMediaControl() const { return m_supportsMediaControl; }
-
-void ClientCapabilities::setSupportsMediaControl(bool newSupportsMediaControl) {
-	m_supportsMediaControl = newSupportsMediaControl;
-}
-
-bool ClientCapabilities::supportsContentUploading() const { return m_supportsContentUploading; }
-
-void ClientCapabilities::setSupportsContentUploading(bool newSupportsContentUploading) {
-	m_supportsContentUploading = newSupportsContentUploading;
-}
-
-QString ClientCapabilities::messageCallbackUrl() const { return m_messageCallbackUrl; }
-
-void ClientCapabilities::setMessageCallbackUrl(QString newMessageCallbackUrl) {
-	m_messageCallbackUrl = newMessageCallbackUrl;
-}
-bool ClientCapabilities::messageCallbackUrlNull() const {
-	return m_messageCallbackUrl.isNull();
-}
-
-void ClientCapabilities::setMessageCallbackUrlNull() {
-	m_messageCallbackUrl.clear();
-
-}
-bool ClientCapabilities::supportsPersistentIdentifier() const { return m_supportsPersistentIdentifier; }
-
-void ClientCapabilities::setSupportsPersistentIdentifier(bool newSupportsPersistentIdentifier) {
-	m_supportsPersistentIdentifier = newSupportsPersistentIdentifier;
-}
-
-bool ClientCapabilities::supportsSync() const { return m_supportsSync; }
-
-void ClientCapabilities::setSupportsSync(bool newSupportsSync) {
-	m_supportsSync = newSupportsSync;
-}
-
-QSharedPointer<DeviceProfile> ClientCapabilities::deviceProfile() const { return m_deviceProfile; }
-
-void ClientCapabilities::setDeviceProfile(QSharedPointer<DeviceProfile> newDeviceProfile) {
-	m_deviceProfile = newDeviceProfile;
-}
-
-QString ClientCapabilities::appStoreUrl() const { return m_appStoreUrl; }
-
-void ClientCapabilities::setAppStoreUrl(QString newAppStoreUrl) {
-	m_appStoreUrl = newAppStoreUrl;
-}
-bool ClientCapabilities::appStoreUrlNull() const {
-	return m_appStoreUrl.isNull();
-}
-
-void ClientCapabilities::setAppStoreUrlNull() {
-	m_appStoreUrl.clear();
-
-}
-QString ClientCapabilities::iconUrl() const { return m_iconUrl; }
-
-void ClientCapabilities::setIconUrl(QString newIconUrl) {
-	m_iconUrl = newIconUrl;
-}
-bool ClientCapabilities::iconUrlNull() const {
-	return m_iconUrl.isNull();
-}
-
-void ClientCapabilities::setIconUrlNull() {
-	m_iconUrl.clear();
-
-}
-
-} // NS DTO
-
-namespace Support {
-
-using ClientCapabilities = Jellyfin::DTO::ClientCapabilities;
-
-template <>
-ClientCapabilities fromJsonValue(const QJsonValue &source, convertType<ClientCapabilities>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return ClientCapabilities::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const ClientCapabilities &source, convertType<ClientCapabilities>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/clientcapabilitiesdto.cpp b/core/src/dto/clientcapabilitiesdto.cpp
index 07ad948..80a9e3b 100644
--- a/core/src/dto/clientcapabilitiesdto.cpp
+++ b/core/src/dto/clientcapabilitiesdto.cpp
@@ -34,16 +34,16 @@ namespace DTO {
 
 ClientCapabilitiesDto::ClientCapabilitiesDto() {}
 ClientCapabilitiesDto::ClientCapabilitiesDto (
+		QList<MediaType> playableMediaTypes, 
+		QList<GeneralCommandType> supportedCommands, 
 		bool supportsMediaControl, 
-		bool supportsContentUploading, 
 		bool supportsPersistentIdentifier, 
-		bool supportsSync, 
 		QSharedPointer<DeviceProfile> deviceProfile 
 		) :
+	m_playableMediaTypes(playableMediaTypes),
+	m_supportedCommands(supportedCommands),
 	m_supportsMediaControl(supportsMediaControl),
-	m_supportsContentUploading(supportsContentUploading),
 	m_supportsPersistentIdentifier(supportsPersistentIdentifier),
-	m_supportsSync(supportsSync),
 	m_deviceProfile(deviceProfile) { }
 
 
@@ -53,10 +53,7 @@ ClientCapabilitiesDto::ClientCapabilitiesDto(const ClientCapabilitiesDto &other)
 	m_playableMediaTypes(other.m_playableMediaTypes),
 	m_supportedCommands(other.m_supportedCommands),
 	m_supportsMediaControl(other.m_supportsMediaControl),
-	m_supportsContentUploading(other.m_supportsContentUploading),
-	m_messageCallbackUrl(other.m_messageCallbackUrl),
 	m_supportsPersistentIdentifier(other.m_supportsPersistentIdentifier),
-	m_supportsSync(other.m_supportsSync),
 	m_deviceProfile(other.m_deviceProfile),
 	m_appStoreUrl(other.m_appStoreUrl),
 	m_iconUrl(other.m_iconUrl){}
@@ -66,10 +63,7 @@ void ClientCapabilitiesDto::replaceData(ClientCapabilitiesDto &other) {
 	m_playableMediaTypes = other.m_playableMediaTypes;
 	m_supportedCommands = other.m_supportedCommands;
 	m_supportsMediaControl = other.m_supportsMediaControl;
-	m_supportsContentUploading = other.m_supportsContentUploading;
-	m_messageCallbackUrl = other.m_messageCallbackUrl;
 	m_supportsPersistentIdentifier = other.m_supportsPersistentIdentifier;
-	m_supportsSync = other.m_supportsSync;
 	m_deviceProfile = other.m_deviceProfile;
 	m_appStoreUrl = other.m_appStoreUrl;
 	m_iconUrl = other.m_iconUrl;
@@ -83,13 +77,10 @@ ClientCapabilitiesDto ClientCapabilitiesDto::fromJson(QJsonObject source) {
 
 
 void ClientCapabilitiesDto::setFromJson(QJsonObject source) {
-	m_playableMediaTypes = Jellyfin::Support::fromJsonValue<QStringList>(source["PlayableMediaTypes"]);
+	m_playableMediaTypes = Jellyfin::Support::fromJsonValue<QList<MediaType>>(source["PlayableMediaTypes"]);
 	m_supportedCommands = Jellyfin::Support::fromJsonValue<QList<GeneralCommandType>>(source["SupportedCommands"]);
 	m_supportsMediaControl = Jellyfin::Support::fromJsonValue<bool>(source["SupportsMediaControl"]);
-	m_supportsContentUploading = Jellyfin::Support::fromJsonValue<bool>(source["SupportsContentUploading"]);
-	m_messageCallbackUrl = Jellyfin::Support::fromJsonValue<QString>(source["MessageCallbackUrl"]);
 	m_supportsPersistentIdentifier = Jellyfin::Support::fromJsonValue<bool>(source["SupportsPersistentIdentifier"]);
-	m_supportsSync = Jellyfin::Support::fromJsonValue<bool>(source["SupportsSync"]);
 	m_deviceProfile = Jellyfin::Support::fromJsonValue<QSharedPointer<DeviceProfile>>(source["DeviceProfile"]);
 	m_appStoreUrl = Jellyfin::Support::fromJsonValue<QString>(source["AppStoreUrl"]);
 	m_iconUrl = Jellyfin::Support::fromJsonValue<QString>(source["IconUrl"]);
@@ -99,25 +90,10 @@ void ClientCapabilitiesDto::setFromJson(QJsonObject source) {
 QJsonObject ClientCapabilitiesDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_playableMediaTypes.size() == 0)) {
-		result["PlayableMediaTypes"] = Jellyfin::Support::toJsonValue<QStringList>(m_playableMediaTypes);
-	}
-			
-	
-	if (!(m_supportedCommands.size() == 0)) {
-		result["SupportedCommands"] = Jellyfin::Support::toJsonValue<QList<GeneralCommandType>>(m_supportedCommands);
-	}
-			
+	result["PlayableMediaTypes"] = Jellyfin::Support::toJsonValue<QList<MediaType>>(m_playableMediaTypes);		
+	result["SupportedCommands"] = Jellyfin::Support::toJsonValue<QList<GeneralCommandType>>(m_supportedCommands);		
 	result["SupportsMediaControl"] = Jellyfin::Support::toJsonValue<bool>(m_supportsMediaControl);		
-	result["SupportsContentUploading"] = Jellyfin::Support::toJsonValue<bool>(m_supportsContentUploading);		
-	
-	if (!(m_messageCallbackUrl.isNull())) {
-		result["MessageCallbackUrl"] = Jellyfin::Support::toJsonValue<QString>(m_messageCallbackUrl);
-	}
-			
 	result["SupportsPersistentIdentifier"] = Jellyfin::Support::toJsonValue<bool>(m_supportsPersistentIdentifier);		
-	result["SupportsSync"] = Jellyfin::Support::toJsonValue<bool>(m_supportsSync);		
 	result["DeviceProfile"] = Jellyfin::Support::toJsonValue<QSharedPointer<DeviceProfile>>(m_deviceProfile);		
 	
 	if (!(m_appStoreUrl.isNull())) {
@@ -132,69 +108,30 @@ QJsonObject ClientCapabilitiesDto::toJson() const {
 	return result;
 }
 
-QStringList ClientCapabilitiesDto::playableMediaTypes() const { return m_playableMediaTypes; }
+QList<MediaType> ClientCapabilitiesDto::playableMediaTypes() const { return m_playableMediaTypes; }
 
-void ClientCapabilitiesDto::setPlayableMediaTypes(QStringList newPlayableMediaTypes) {
+void ClientCapabilitiesDto::setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes) {
 	m_playableMediaTypes = newPlayableMediaTypes;
 }
-bool ClientCapabilitiesDto::playableMediaTypesNull() const {
-	return m_playableMediaTypes.size() == 0;
-}
 
-void ClientCapabilitiesDto::setPlayableMediaTypesNull() {
-	m_playableMediaTypes.clear();
-
-}
 QList<GeneralCommandType> ClientCapabilitiesDto::supportedCommands() const { return m_supportedCommands; }
 
 void ClientCapabilitiesDto::setSupportedCommands(QList<GeneralCommandType> newSupportedCommands) {
 	m_supportedCommands = newSupportedCommands;
 }
-bool ClientCapabilitiesDto::supportedCommandsNull() const {
-	return m_supportedCommands.size() == 0;
-}
 
-void ClientCapabilitiesDto::setSupportedCommandsNull() {
-	m_supportedCommands.clear();
-
-}
 bool ClientCapabilitiesDto::supportsMediaControl() const { return m_supportsMediaControl; }
 
 void ClientCapabilitiesDto::setSupportsMediaControl(bool newSupportsMediaControl) {
 	m_supportsMediaControl = newSupportsMediaControl;
 }
 
-bool ClientCapabilitiesDto::supportsContentUploading() const { return m_supportsContentUploading; }
-
-void ClientCapabilitiesDto::setSupportsContentUploading(bool newSupportsContentUploading) {
-	m_supportsContentUploading = newSupportsContentUploading;
-}
-
-QString ClientCapabilitiesDto::messageCallbackUrl() const { return m_messageCallbackUrl; }
-
-void ClientCapabilitiesDto::setMessageCallbackUrl(QString newMessageCallbackUrl) {
-	m_messageCallbackUrl = newMessageCallbackUrl;
-}
-bool ClientCapabilitiesDto::messageCallbackUrlNull() const {
-	return m_messageCallbackUrl.isNull();
-}
-
-void ClientCapabilitiesDto::setMessageCallbackUrlNull() {
-	m_messageCallbackUrl.clear();
-
-}
 bool ClientCapabilitiesDto::supportsPersistentIdentifier() const { return m_supportsPersistentIdentifier; }
 
 void ClientCapabilitiesDto::setSupportsPersistentIdentifier(bool newSupportsPersistentIdentifier) {
 	m_supportsPersistentIdentifier = newSupportsPersistentIdentifier;
 }
 
-bool ClientCapabilitiesDto::supportsSync() const { return m_supportsSync; }
-
-void ClientCapabilitiesDto::setSupportsSync(bool newSupportsSync) {
-	m_supportsSync = newSupportsSync;
-}
-
 QSharedPointer<DeviceProfile> ClientCapabilitiesDto::deviceProfile() const { return m_deviceProfile; }
 
 void ClientCapabilitiesDto::setDeviceProfile(QSharedPointer<DeviceProfile> newDeviceProfile) {
diff --git a/core/src/dto/clientlogdocumentresponsedto.cpp b/core/src/dto/clientlogdocumentresponsedto.cpp
new file mode 100644
index 0000000..bbe959b
--- /dev/null
+++ b/core/src/dto/clientlogdocumentresponsedto.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/clientlogdocumentresponsedto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ClientLogDocumentResponseDto::ClientLogDocumentResponseDto() {}
+ClientLogDocumentResponseDto::ClientLogDocumentResponseDto (
+		QString fileName 
+		) :
+	m_fileName(fileName) { }
+
+
+
+ClientLogDocumentResponseDto::ClientLogDocumentResponseDto(const ClientLogDocumentResponseDto &other) :
+
+	m_fileName(other.m_fileName){}
+
+
+void ClientLogDocumentResponseDto::replaceData(ClientLogDocumentResponseDto &other) {
+	m_fileName = other.m_fileName;
+}
+
+ClientLogDocumentResponseDto ClientLogDocumentResponseDto::fromJson(QJsonObject source) {
+	ClientLogDocumentResponseDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ClientLogDocumentResponseDto::setFromJson(QJsonObject source) {
+	m_fileName = Jellyfin::Support::fromJsonValue<QString>(source["FileName"]);
+
+}
+	
+QJsonObject ClientLogDocumentResponseDto::toJson() const {
+	QJsonObject result;
+	
+	result["FileName"] = Jellyfin::Support::toJsonValue<QString>(m_fileName);	
+	return result;
+}
+
+QString ClientLogDocumentResponseDto::fileName() const { return m_fileName; }
+
+void ClientLogDocumentResponseDto::setFileName(QString newFileName) {
+	m_fileName = newFileName;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ClientLogDocumentResponseDto = Jellyfin::DTO::ClientLogDocumentResponseDto;
+
+template <>
+ClientLogDocumentResponseDto fromJsonValue(const QJsonValue &source, convertType<ClientLogDocumentResponseDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ClientLogDocumentResponseDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ClientLogDocumentResponseDto &source, convertType<ClientLogDocumentResponseDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/codecprofile.cpp b/core/src/dto/codecprofile.cpp
index 0e30a8d..4ce629c 100644
--- a/core/src/dto/codecprofile.cpp
+++ b/core/src/dto/codecprofile.cpp
@@ -34,9 +34,13 @@ namespace DTO {
 
 CodecProfile::CodecProfile() {}
 CodecProfile::CodecProfile (
-		CodecType type 
+		CodecType type, 
+		QList<ProfileCondition> conditions, 
+		QList<ProfileCondition> applyConditions 
 		) :
-	m_type(type) { }
+	m_type(type),
+	m_conditions(conditions),
+	m_applyConditions(applyConditions) { }
 
 
 
@@ -46,7 +50,8 @@ CodecProfile::CodecProfile(const CodecProfile &other) :
 	m_conditions(other.m_conditions),
 	m_applyConditions(other.m_applyConditions),
 	m_codec(other.m_codec),
-	m_container(other.m_container){}
+	m_container(other.m_container),
+	m_subContainer(other.m_subContainer){}
 
 
 void CodecProfile::replaceData(CodecProfile &other) {
@@ -55,6 +60,7 @@ void CodecProfile::replaceData(CodecProfile &other) {
 	m_applyConditions = other.m_applyConditions;
 	m_codec = other.m_codec;
 	m_container = other.m_container;
+	m_subContainer = other.m_subContainer;
 }
 
 CodecProfile CodecProfile::fromJson(QJsonObject source) {
@@ -70,6 +76,7 @@ void CodecProfile::setFromJson(QJsonObject source) {
 	m_applyConditions = Jellyfin::Support::fromJsonValue<QList<ProfileCondition>>(source["ApplyConditions"]);
 	m_codec = Jellyfin::Support::fromJsonValue<QString>(source["Codec"]);
 	m_container = Jellyfin::Support::fromJsonValue<QString>(source["Container"]);
+	m_subContainer = Jellyfin::Support::fromJsonValue<QString>(source["SubContainer"]);
 
 }
 	
@@ -77,16 +84,8 @@ QJsonObject CodecProfile::toJson() const {
 	QJsonObject result;
 	
 	result["Type"] = Jellyfin::Support::toJsonValue<CodecType>(m_type);		
-	
-	if (!(m_conditions.size() == 0)) {
-		result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);
-	}
-			
-	
-	if (!(m_applyConditions.size() == 0)) {
-		result["ApplyConditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_applyConditions);
-	}
-			
+	result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);		
+	result["ApplyConditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_applyConditions);		
 	
 	if (!(m_codec.isNull())) {
 		result["Codec"] = Jellyfin::Support::toJsonValue<QString>(m_codec);
@@ -96,6 +95,11 @@ QJsonObject CodecProfile::toJson() const {
 	if (!(m_container.isNull())) {
 		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
 	}
+			
+	
+	if (!(m_subContainer.isNull())) {
+		result["SubContainer"] = Jellyfin::Support::toJsonValue<QString>(m_subContainer);
+	}
 		
 	return result;
 }
@@ -111,27 +115,13 @@ QList<ProfileCondition> CodecProfile::conditions() const { return m_conditions;
 void CodecProfile::setConditions(QList<ProfileCondition> newConditions) {
 	m_conditions = newConditions;
 }
-bool CodecProfile::conditionsNull() const {
-	return m_conditions.size() == 0;
-}
 
-void CodecProfile::setConditionsNull() {
-	m_conditions.clear();
-
-}
 QList<ProfileCondition> CodecProfile::applyConditions() const { return m_applyConditions; }
 
 void CodecProfile::setApplyConditions(QList<ProfileCondition> newApplyConditions) {
 	m_applyConditions = newApplyConditions;
 }
-bool CodecProfile::applyConditionsNull() const {
-	return m_applyConditions.size() == 0;
-}
 
-void CodecProfile::setApplyConditionsNull() {
-	m_applyConditions.clear();
-
-}
 QString CodecProfile::codec() const { return m_codec; }
 
 void CodecProfile::setCodec(QString newCodec) {
@@ -157,6 +147,19 @@ bool CodecProfile::containerNull() const {
 void CodecProfile::setContainerNull() {
 	m_container.clear();
 
+}
+QString CodecProfile::subContainer() const { return m_subContainer; }
+
+void CodecProfile::setSubContainer(QString newSubContainer) {
+	m_subContainer = newSubContainer;
+}
+bool CodecProfile::subContainerNull() const {
+	return m_subContainer.isNull();
+}
+
+void CodecProfile::setSubContainerNull() {
+	m_subContainer.clear();
+
 }
 
 } // NS DTO
diff --git a/core/src/dto/collectiontype.cpp b/core/src/dto/collectiontype.cpp
new file mode 100644
index 0000000..0fb429d
--- /dev/null
+++ b/core/src/dto/collectiontype.cpp
@@ -0,0 +1,128 @@
+/*
+ * 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/dto/collectiontype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+CollectionTypeClass::CollectionTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using CollectionType = Jellyfin::DTO::CollectionType;
+
+template <>
+CollectionType fromJsonValue(const QJsonValue &source, convertType<CollectionType>) {
+	if (!source.isString()) return CollectionType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("unknown")) {
+		return CollectionType::Unknown;
+	}
+	if (str == QStringLiteral("movies")) {
+		return CollectionType::Movies;
+	}
+	if (str == QStringLiteral("tvshows")) {
+		return CollectionType::Tvshows;
+	}
+	if (str == QStringLiteral("music")) {
+		return CollectionType::Music;
+	}
+	if (str == QStringLiteral("musicvideos")) {
+		return CollectionType::Musicvideos;
+	}
+	if (str == QStringLiteral("trailers")) {
+		return CollectionType::Trailers;
+	}
+	if (str == QStringLiteral("homevideos")) {
+		return CollectionType::Homevideos;
+	}
+	if (str == QStringLiteral("boxsets")) {
+		return CollectionType::Boxsets;
+	}
+	if (str == QStringLiteral("books")) {
+		return CollectionType::Books;
+	}
+	if (str == QStringLiteral("photos")) {
+		return CollectionType::Photos;
+	}
+	if (str == QStringLiteral("livetv")) {
+		return CollectionType::Livetv;
+	}
+	if (str == QStringLiteral("playlists")) {
+		return CollectionType::Playlists;
+	}
+	if (str == QStringLiteral("folders")) {
+		return CollectionType::Folders;
+	}
+	
+	return CollectionType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const CollectionType &source, convertType<CollectionType>) {
+	switch(source) {
+	case CollectionType::Unknown:
+		return QStringLiteral("unknown");
+	case CollectionType::Movies:
+		return QStringLiteral("movies");
+	case CollectionType::Tvshows:
+		return QStringLiteral("tvshows");
+	case CollectionType::Music:
+		return QStringLiteral("music");
+	case CollectionType::Musicvideos:
+		return QStringLiteral("musicvideos");
+	case CollectionType::Trailers:
+		return QStringLiteral("trailers");
+	case CollectionType::Homevideos:
+		return QStringLiteral("homevideos");
+	case CollectionType::Boxsets:
+		return QStringLiteral("boxsets");
+	case CollectionType::Books:
+		return QStringLiteral("books");
+	case CollectionType::Photos:
+		return QStringLiteral("photos");
+	case CollectionType::Livetv:
+		return QStringLiteral("livetv");
+	case CollectionType::Playlists:
+		return QStringLiteral("playlists");
+	case CollectionType::Folders:
+		return QStringLiteral("folders");
+
+	case CollectionType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/collectiontypeoptions.cpp b/core/src/dto/collectiontypeoptions.cpp
new file mode 100644
index 0000000..7235245
--- /dev/null
+++ b/core/src/dto/collectiontypeoptions.cpp
@@ -0,0 +1,103 @@
+/*
+ * 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/dto/collectiontypeoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+CollectionTypeOptionsClass::CollectionTypeOptionsClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using CollectionTypeOptions = Jellyfin::DTO::CollectionTypeOptions;
+
+template <>
+CollectionTypeOptions fromJsonValue(const QJsonValue &source, convertType<CollectionTypeOptions>) {
+	if (!source.isString()) return CollectionTypeOptions::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("movies")) {
+		return CollectionTypeOptions::Movies;
+	}
+	if (str == QStringLiteral("tvshows")) {
+		return CollectionTypeOptions::Tvshows;
+	}
+	if (str == QStringLiteral("music")) {
+		return CollectionTypeOptions::Music;
+	}
+	if (str == QStringLiteral("musicvideos")) {
+		return CollectionTypeOptions::Musicvideos;
+	}
+	if (str == QStringLiteral("homevideos")) {
+		return CollectionTypeOptions::Homevideos;
+	}
+	if (str == QStringLiteral("boxsets")) {
+		return CollectionTypeOptions::Boxsets;
+	}
+	if (str == QStringLiteral("books")) {
+		return CollectionTypeOptions::Books;
+	}
+	if (str == QStringLiteral("mixed")) {
+		return CollectionTypeOptions::Mixed;
+	}
+	
+	return CollectionTypeOptions::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const CollectionTypeOptions &source, convertType<CollectionTypeOptions>) {
+	switch(source) {
+	case CollectionTypeOptions::Movies:
+		return QStringLiteral("movies");
+	case CollectionTypeOptions::Tvshows:
+		return QStringLiteral("tvshows");
+	case CollectionTypeOptions::Music:
+		return QStringLiteral("music");
+	case CollectionTypeOptions::Musicvideos:
+		return QStringLiteral("musicvideos");
+	case CollectionTypeOptions::Homevideos:
+		return QStringLiteral("homevideos");
+	case CollectionTypeOptions::Boxsets:
+		return QStringLiteral("boxsets");
+	case CollectionTypeOptions::Books:
+		return QStringLiteral("books");
+	case CollectionTypeOptions::Mixed:
+		return QStringLiteral("mixed");
+
+	case CollectionTypeOptions::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/configimagetypes.cpp b/core/src/dto/configimagetypes.cpp
new file mode 100644
index 0000000..8f67239
--- /dev/null
+++ b/core/src/dto/configimagetypes.cpp
@@ -0,0 +1,227 @@
+/*
+ * 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/dto/configimagetypes.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ConfigImageTypes::ConfigImageTypes() {}
+
+ConfigImageTypes::ConfigImageTypes(const ConfigImageTypes &other) :
+
+	m_backdropSizes(other.m_backdropSizes),
+	m_baseUrl(other.m_baseUrl),
+	m_logoSizes(other.m_logoSizes),
+	m_posterSizes(other.m_posterSizes),
+	m_profileSizes(other.m_profileSizes),
+	m_secureBaseUrl(other.m_secureBaseUrl),
+	m_stillSizes(other.m_stillSizes){}
+
+
+void ConfigImageTypes::replaceData(ConfigImageTypes &other) {
+	m_backdropSizes = other.m_backdropSizes;
+	m_baseUrl = other.m_baseUrl;
+	m_logoSizes = other.m_logoSizes;
+	m_posterSizes = other.m_posterSizes;
+	m_profileSizes = other.m_profileSizes;
+	m_secureBaseUrl = other.m_secureBaseUrl;
+	m_stillSizes = other.m_stillSizes;
+}
+
+ConfigImageTypes ConfigImageTypes::fromJson(QJsonObject source) {
+	ConfigImageTypes instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ConfigImageTypes::setFromJson(QJsonObject source) {
+	m_backdropSizes = Jellyfin::Support::fromJsonValue<QStringList>(source["BackdropSizes"]);
+	m_baseUrl = Jellyfin::Support::fromJsonValue<QString>(source["BaseUrl"]);
+	m_logoSizes = Jellyfin::Support::fromJsonValue<QStringList>(source["LogoSizes"]);
+	m_posterSizes = Jellyfin::Support::fromJsonValue<QStringList>(source["PosterSizes"]);
+	m_profileSizes = Jellyfin::Support::fromJsonValue<QStringList>(source["ProfileSizes"]);
+	m_secureBaseUrl = Jellyfin::Support::fromJsonValue<QString>(source["SecureBaseUrl"]);
+	m_stillSizes = Jellyfin::Support::fromJsonValue<QStringList>(source["StillSizes"]);
+
+}
+	
+QJsonObject ConfigImageTypes::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_backdropSizes.size() == 0)) {
+		result["BackdropSizes"] = Jellyfin::Support::toJsonValue<QStringList>(m_backdropSizes);
+	}
+			
+	
+	if (!(m_baseUrl.isNull())) {
+		result["BaseUrl"] = Jellyfin::Support::toJsonValue<QString>(m_baseUrl);
+	}
+			
+	
+	if (!(m_logoSizes.size() == 0)) {
+		result["LogoSizes"] = Jellyfin::Support::toJsonValue<QStringList>(m_logoSizes);
+	}
+			
+	
+	if (!(m_posterSizes.size() == 0)) {
+		result["PosterSizes"] = Jellyfin::Support::toJsonValue<QStringList>(m_posterSizes);
+	}
+			
+	
+	if (!(m_profileSizes.size() == 0)) {
+		result["ProfileSizes"] = Jellyfin::Support::toJsonValue<QStringList>(m_profileSizes);
+	}
+			
+	
+	if (!(m_secureBaseUrl.isNull())) {
+		result["SecureBaseUrl"] = Jellyfin::Support::toJsonValue<QString>(m_secureBaseUrl);
+	}
+			
+	
+	if (!(m_stillSizes.size() == 0)) {
+		result["StillSizes"] = Jellyfin::Support::toJsonValue<QStringList>(m_stillSizes);
+	}
+		
+	return result;
+}
+
+QStringList ConfigImageTypes::backdropSizes() const { return m_backdropSizes; }
+
+void ConfigImageTypes::setBackdropSizes(QStringList newBackdropSizes) {
+	m_backdropSizes = newBackdropSizes;
+}
+bool ConfigImageTypes::backdropSizesNull() const {
+	return m_backdropSizes.size() == 0;
+}
+
+void ConfigImageTypes::setBackdropSizesNull() {
+	m_backdropSizes.clear();
+
+}
+QString ConfigImageTypes::baseUrl() const { return m_baseUrl; }
+
+void ConfigImageTypes::setBaseUrl(QString newBaseUrl) {
+	m_baseUrl = newBaseUrl;
+}
+bool ConfigImageTypes::baseUrlNull() const {
+	return m_baseUrl.isNull();
+}
+
+void ConfigImageTypes::setBaseUrlNull() {
+	m_baseUrl.clear();
+
+}
+QStringList ConfigImageTypes::logoSizes() const { return m_logoSizes; }
+
+void ConfigImageTypes::setLogoSizes(QStringList newLogoSizes) {
+	m_logoSizes = newLogoSizes;
+}
+bool ConfigImageTypes::logoSizesNull() const {
+	return m_logoSizes.size() == 0;
+}
+
+void ConfigImageTypes::setLogoSizesNull() {
+	m_logoSizes.clear();
+
+}
+QStringList ConfigImageTypes::posterSizes() const { return m_posterSizes; }
+
+void ConfigImageTypes::setPosterSizes(QStringList newPosterSizes) {
+	m_posterSizes = newPosterSizes;
+}
+bool ConfigImageTypes::posterSizesNull() const {
+	return m_posterSizes.size() == 0;
+}
+
+void ConfigImageTypes::setPosterSizesNull() {
+	m_posterSizes.clear();
+
+}
+QStringList ConfigImageTypes::profileSizes() const { return m_profileSizes; }
+
+void ConfigImageTypes::setProfileSizes(QStringList newProfileSizes) {
+	m_profileSizes = newProfileSizes;
+}
+bool ConfigImageTypes::profileSizesNull() const {
+	return m_profileSizes.size() == 0;
+}
+
+void ConfigImageTypes::setProfileSizesNull() {
+	m_profileSizes.clear();
+
+}
+QString ConfigImageTypes::secureBaseUrl() const { return m_secureBaseUrl; }
+
+void ConfigImageTypes::setSecureBaseUrl(QString newSecureBaseUrl) {
+	m_secureBaseUrl = newSecureBaseUrl;
+}
+bool ConfigImageTypes::secureBaseUrlNull() const {
+	return m_secureBaseUrl.isNull();
+}
+
+void ConfigImageTypes::setSecureBaseUrlNull() {
+	m_secureBaseUrl.clear();
+
+}
+QStringList ConfigImageTypes::stillSizes() const { return m_stillSizes; }
+
+void ConfigImageTypes::setStillSizes(QStringList newStillSizes) {
+	m_stillSizes = newStillSizes;
+}
+bool ConfigImageTypes::stillSizesNull() const {
+	return m_stillSizes.size() == 0;
+}
+
+void ConfigImageTypes::setStillSizesNull() {
+	m_stillSizes.clear();
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using ConfigImageTypes = Jellyfin::DTO::ConfigImageTypes;
+
+template <>
+ConfigImageTypes fromJsonValue(const QJsonValue &source, convertType<ConfigImageTypes>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ConfigImageTypes::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ConfigImageTypes &source, convertType<ConfigImageTypes>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/configurationpageinfo.cpp b/core/src/dto/configurationpageinfo.cpp
index 459c702..6dfe4cb 100644
--- a/core/src/dto/configurationpageinfo.cpp
+++ b/core/src/dto/configurationpageinfo.cpp
@@ -34,11 +34,11 @@ namespace DTO {
 
 ConfigurationPageInfo::ConfigurationPageInfo() {}
 ConfigurationPageInfo::ConfigurationPageInfo (
-		bool enableInMainMenu, 
-		ConfigurationPageType configurationPageType 
+		QString name, 
+		bool enableInMainMenu 
 		) :
-	m_enableInMainMenu(enableInMainMenu),
-	m_configurationPageType(configurationPageType) { }
+	m_name(name),
+	m_enableInMainMenu(enableInMainMenu) { }
 
 
 
@@ -49,7 +49,6 @@ ConfigurationPageInfo::ConfigurationPageInfo(const ConfigurationPageInfo &other)
 	m_menuSection(other.m_menuSection),
 	m_menuIcon(other.m_menuIcon),
 	m_displayName(other.m_displayName),
-	m_configurationPageType(other.m_configurationPageType),
 	m_pluginId(other.m_pluginId){}
 
 
@@ -59,7 +58,6 @@ void ConfigurationPageInfo::replaceData(ConfigurationPageInfo &other) {
 	m_menuSection = other.m_menuSection;
 	m_menuIcon = other.m_menuIcon;
 	m_displayName = other.m_displayName;
-	m_configurationPageType = other.m_configurationPageType;
 	m_pluginId = other.m_pluginId;
 }
 
@@ -76,7 +74,6 @@ void ConfigurationPageInfo::setFromJson(QJsonObject source) {
 	m_menuSection = Jellyfin::Support::fromJsonValue<QString>(source["MenuSection"]);
 	m_menuIcon = Jellyfin::Support::fromJsonValue<QString>(source["MenuIcon"]);
 	m_displayName = Jellyfin::Support::fromJsonValue<QString>(source["DisplayName"]);
-	m_configurationPageType = Jellyfin::Support::fromJsonValue<ConfigurationPageType>(source["ConfigurationPageType"]);
 	m_pluginId = Jellyfin::Support::fromJsonValue<QString>(source["PluginId"]);
 
 }
@@ -84,11 +81,7 @@ void ConfigurationPageInfo::setFromJson(QJsonObject source) {
 QJsonObject ConfigurationPageInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
 	result["EnableInMainMenu"] = Jellyfin::Support::toJsonValue<bool>(m_enableInMainMenu);		
 	
 	if (!(m_menuSection.isNull())) {
@@ -105,7 +98,6 @@ QJsonObject ConfigurationPageInfo::toJson() const {
 		result["DisplayName"] = Jellyfin::Support::toJsonValue<QString>(m_displayName);
 	}
 			
-	result["ConfigurationPageType"] = Jellyfin::Support::toJsonValue<ConfigurationPageType>(m_configurationPageType);		
 	
 	if (!(m_pluginId.isNull())) {
 		result["PluginId"] = Jellyfin::Support::toJsonValue<QString>(m_pluginId);
@@ -119,14 +111,7 @@ QString ConfigurationPageInfo::name() const { return m_name; }
 void ConfigurationPageInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool ConfigurationPageInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void ConfigurationPageInfo::setNameNull() {
-	m_name.clear();
-
-}
 bool ConfigurationPageInfo::enableInMainMenu() const { return m_enableInMainMenu; }
 
 void ConfigurationPageInfo::setEnableInMainMenu(bool newEnableInMainMenu) {
@@ -172,12 +157,6 @@ void ConfigurationPageInfo::setDisplayNameNull() {
 	m_displayName.clear();
 
 }
-ConfigurationPageType ConfigurationPageInfo::configurationPageType() const { return m_configurationPageType; }
-
-void ConfigurationPageInfo::setConfigurationPageType(ConfigurationPageType newConfigurationPageType) {
-	m_configurationPageType = newConfigurationPageType;
-}
-
 QString ConfigurationPageInfo::pluginId() const { return m_pluginId; }
 
 void ConfigurationPageInfo::setPluginId(QString newPluginId) {
diff --git a/core/src/dto/containerprofile.cpp b/core/src/dto/containerprofile.cpp
index 531d905..4b6856c 100644
--- a/core/src/dto/containerprofile.cpp
+++ b/core/src/dto/containerprofile.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 ContainerProfile::ContainerProfile() {}
 ContainerProfile::ContainerProfile (
-		DlnaProfileType type 
+		DlnaProfileType type, 
+		QList<ProfileCondition> conditions 
 		) :
-	m_type(type) { }
+	m_type(type),
+	m_conditions(conditions) { }
 
 
 
@@ -44,13 +46,15 @@ ContainerProfile::ContainerProfile(const ContainerProfile &other) :
 
 	m_type(other.m_type),
 	m_conditions(other.m_conditions),
-	m_container(other.m_container){}
+	m_container(other.m_container),
+	m_subContainer(other.m_subContainer){}
 
 
 void ContainerProfile::replaceData(ContainerProfile &other) {
 	m_type = other.m_type;
 	m_conditions = other.m_conditions;
 	m_container = other.m_container;
+	m_subContainer = other.m_subContainer;
 }
 
 ContainerProfile ContainerProfile::fromJson(QJsonObject source) {
@@ -64,6 +68,7 @@ void ContainerProfile::setFromJson(QJsonObject source) {
 	m_type = Jellyfin::Support::fromJsonValue<DlnaProfileType>(source["Type"]);
 	m_conditions = Jellyfin::Support::fromJsonValue<QList<ProfileCondition>>(source["Conditions"]);
 	m_container = Jellyfin::Support::fromJsonValue<QString>(source["Container"]);
+	m_subContainer = Jellyfin::Support::fromJsonValue<QString>(source["SubContainer"]);
 
 }
 	
@@ -71,15 +76,16 @@ QJsonObject ContainerProfile::toJson() const {
 	QJsonObject result;
 	
 	result["Type"] = Jellyfin::Support::toJsonValue<DlnaProfileType>(m_type);		
-	
-	if (!(m_conditions.size() == 0)) {
-		result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);
-	}
-			
+	result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);		
 	
 	if (!(m_container.isNull())) {
 		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
 	}
+			
+	
+	if (!(m_subContainer.isNull())) {
+		result["SubContainer"] = Jellyfin::Support::toJsonValue<QString>(m_subContainer);
+	}
 		
 	return result;
 }
@@ -95,14 +101,7 @@ QList<ProfileCondition> ContainerProfile::conditions() const { return m_conditio
 void ContainerProfile::setConditions(QList<ProfileCondition> newConditions) {
 	m_conditions = newConditions;
 }
-bool ContainerProfile::conditionsNull() const {
-	return m_conditions.size() == 0;
-}
 
-void ContainerProfile::setConditionsNull() {
-	m_conditions.clear();
-
-}
 QString ContainerProfile::container() const { return m_container; }
 
 void ContainerProfile::setContainer(QString newContainer) {
@@ -115,6 +114,19 @@ bool ContainerProfile::containerNull() const {
 void ContainerProfile::setContainerNull() {
 	m_container.clear();
 
+}
+QString ContainerProfile::subContainer() const { return m_subContainer; }
+
+void ContainerProfile::setSubContainer(QString newSubContainer) {
+	m_subContainer = newSubContainer;
+}
+bool ContainerProfile::subContainerNull() const {
+	return m_subContainer.isNull();
+}
+
+void ContainerProfile::setSubContainerNull() {
+	m_subContainer.clear();
+
 }
 
 } // NS DTO
diff --git a/core/src/dto/controlresponse.cpp b/core/src/dto/controlresponse.cpp
deleted file mode 100644
index d98f9fb..0000000
--- a/core/src/dto/controlresponse.cpp
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * 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/dto/controlresponse.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-ControlResponse::ControlResponse() {}
-ControlResponse::ControlResponse (
-		bool isSuccessful 
-		) :
-	m_isSuccessful(isSuccessful) { }
-
-
-
-ControlResponse::ControlResponse(const ControlResponse &other) :
-
-	m_headers(other.m_headers),
-	m_xml(other.m_xml),
-	m_isSuccessful(other.m_isSuccessful){}
-
-
-void ControlResponse::replaceData(ControlResponse &other) {
-	m_headers = other.m_headers;
-	m_xml = other.m_xml;
-	m_isSuccessful = other.m_isSuccessful;
-}
-
-ControlResponse ControlResponse::fromJson(QJsonObject source) {
-	ControlResponse instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void ControlResponse::setFromJson(QJsonObject source) {
-	m_headers = Jellyfin::Support::fromJsonValue<QJsonObject>(source["Headers"]);
-	m_xml = Jellyfin::Support::fromJsonValue<QString>(source["Xml"]);
-	m_isSuccessful = Jellyfin::Support::fromJsonValue<bool>(source["IsSuccessful"]);
-
-}
-	
-QJsonObject ControlResponse::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_headers.isEmpty())) {
-		result["Headers"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_headers);
-	}
-			
-	
-	if (!(m_xml.isNull())) {
-		result["Xml"] = Jellyfin::Support::toJsonValue<QString>(m_xml);
-	}
-			
-	result["IsSuccessful"] = Jellyfin::Support::toJsonValue<bool>(m_isSuccessful);	
-	return result;
-}
-
-QJsonObject ControlResponse::headers() const { return m_headers; }
-
-void ControlResponse::setHeaders(QJsonObject newHeaders) {
-	m_headers = newHeaders;
-}
-bool ControlResponse::headersNull() const {
-	return m_headers.isEmpty();
-}
-
-void ControlResponse::setHeadersNull() {
-	m_headers= QJsonObject();
-
-}
-QString ControlResponse::xml() const { return m_xml; }
-
-void ControlResponse::setXml(QString newXml) {
-	m_xml = newXml;
-}
-bool ControlResponse::xmlNull() const {
-	return m_xml.isNull();
-}
-
-void ControlResponse::setXmlNull() {
-	m_xml.clear();
-
-}
-bool ControlResponse::isSuccessful() const { return m_isSuccessful; }
-
-void ControlResponse::setIsSuccessful(bool newIsSuccessful) {
-	m_isSuccessful = newIsSuccessful;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using ControlResponse = Jellyfin::DTO::ControlResponse;
-
-template <>
-ControlResponse fromJsonValue(const QJsonValue &source, convertType<ControlResponse>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return ControlResponse::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const ControlResponse &source, convertType<ControlResponse>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/createplaylistdto.cpp b/core/src/dto/createplaylistdto.cpp
index c4e611f..697e10f 100644
--- a/core/src/dto/createplaylistdto.cpp
+++ b/core/src/dto/createplaylistdto.cpp
@@ -33,13 +33,29 @@ namespace Jellyfin {
 namespace DTO {
 
 CreatePlaylistDto::CreatePlaylistDto() {}
+CreatePlaylistDto::CreatePlaylistDto (
+		QString name, 
+		QStringList ids, 
+		MediaType mediaType, 
+		QList<PlaylistUserPermissions> users, 
+		bool isPublic 
+		) :
+	m_name(name),
+	m_ids(ids),
+	m_mediaType(mediaType),
+	m_users(users),
+	m_isPublic(isPublic) { }
+
+
 
 CreatePlaylistDto::CreatePlaylistDto(const CreatePlaylistDto &other) :
 
 	m_name(other.m_name),
 	m_ids(other.m_ids),
 	m_userId(other.m_userId),
-	m_mediaType(other.m_mediaType){}
+	m_mediaType(other.m_mediaType),
+	m_users(other.m_users),
+	m_isPublic(other.m_isPublic){}
 
 
 void CreatePlaylistDto::replaceData(CreatePlaylistDto &other) {
@@ -47,6 +63,8 @@ void CreatePlaylistDto::replaceData(CreatePlaylistDto &other) {
 	m_ids = other.m_ids;
 	m_userId = other.m_userId;
 	m_mediaType = other.m_mediaType;
+	m_users = other.m_users;
+	m_isPublic = other.m_isPublic;
 }
 
 CreatePlaylistDto CreatePlaylistDto::fromJson(QJsonObject source) {
@@ -60,33 +78,25 @@ void CreatePlaylistDto::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
 	m_ids = Jellyfin::Support::fromJsonValue<QStringList>(source["Ids"]);
 	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
-	m_mediaType = Jellyfin::Support::fromJsonValue<QString>(source["MediaType"]);
+	m_mediaType = Jellyfin::Support::fromJsonValue<MediaType>(source["MediaType"]);
+	m_users = Jellyfin::Support::fromJsonValue<QList<PlaylistUserPermissions>>(source["Users"]);
+	m_isPublic = Jellyfin::Support::fromJsonValue<bool>(source["IsPublic"]);
 
 }
 	
 QJsonObject CreatePlaylistDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_ids.size() == 0)) {
-		result["Ids"] = Jellyfin::Support::toJsonValue<QStringList>(m_ids);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["Ids"] = Jellyfin::Support::toJsonValue<QStringList>(m_ids);		
 	
 	if (!(m_userId.isNull())) {
 		result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);
 	}
 			
-	
-	if (!(m_mediaType.isNull())) {
-		result["MediaType"] = Jellyfin::Support::toJsonValue<QString>(m_mediaType);
-	}
-		
+	result["MediaType"] = Jellyfin::Support::toJsonValue<MediaType>(m_mediaType);		
+	result["Users"] = Jellyfin::Support::toJsonValue<QList<PlaylistUserPermissions>>(m_users);		
+	result["IsPublic"] = Jellyfin::Support::toJsonValue<bool>(m_isPublic);	
 	return result;
 }
 
@@ -95,27 +105,13 @@ QString CreatePlaylistDto::name() const { return m_name; }
 void CreatePlaylistDto::setName(QString newName) {
 	m_name = newName;
 }
-bool CreatePlaylistDto::nameNull() const {
-	return m_name.isNull();
-}
 
-void CreatePlaylistDto::setNameNull() {
-	m_name.clear();
-
-}
 QStringList CreatePlaylistDto::ids() const { return m_ids; }
 
 void CreatePlaylistDto::setIds(QStringList newIds) {
 	m_ids = newIds;
 }
-bool CreatePlaylistDto::idsNull() const {
-	return m_ids.size() == 0;
-}
 
-void CreatePlaylistDto::setIdsNull() {
-	m_ids.clear();
-
-}
 QString CreatePlaylistDto::userId() const { return m_userId; }
 
 void CreatePlaylistDto::setUserId(QString newUserId) {
@@ -129,20 +125,25 @@ void CreatePlaylistDto::setUserIdNull() {
 	m_userId.clear();
 
 }
-QString CreatePlaylistDto::mediaType() const { return m_mediaType; }
+MediaType CreatePlaylistDto::mediaType() const { return m_mediaType; }
 
-void CreatePlaylistDto::setMediaType(QString newMediaType) {
+void CreatePlaylistDto::setMediaType(MediaType newMediaType) {
 	m_mediaType = newMediaType;
 }
-bool CreatePlaylistDto::mediaTypeNull() const {
-	return m_mediaType.isNull();
+
+QList<PlaylistUserPermissions> CreatePlaylistDto::users() const { return m_users; }
+
+void CreatePlaylistDto::setUsers(QList<PlaylistUserPermissions> newUsers) {
+	m_users = newUsers;
 }
 
-void CreatePlaylistDto::setMediaTypeNull() {
-	m_mediaType.clear();
+bool CreatePlaylistDto::isPublic() const { return m_isPublic; }
 
+void CreatePlaylistDto::setIsPublic(bool newIsPublic) {
+	m_isPublic = newIsPublic;
 }
 
+
 } // NS DTO
 
 namespace Support {
diff --git a/core/src/dto/createuserbyname.cpp b/core/src/dto/createuserbyname.cpp
index d4074bb..048ad65 100644
--- a/core/src/dto/createuserbyname.cpp
+++ b/core/src/dto/createuserbyname.cpp
@@ -33,6 +33,12 @@ namespace Jellyfin {
 namespace DTO {
 
 CreateUserByName::CreateUserByName() {}
+CreateUserByName::CreateUserByName (
+		QString name 
+		) :
+	m_name(name) { }
+
+
 
 CreateUserByName::CreateUserByName(const CreateUserByName &other) :
 
@@ -61,11 +67,7 @@ void CreateUserByName::setFromJson(QJsonObject source) {
 QJsonObject CreateUserByName::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
 	
 	if (!(m_password.isNull())) {
 		result["Password"] = Jellyfin::Support::toJsonValue<QString>(m_password);
@@ -79,14 +81,7 @@ QString CreateUserByName::name() const { return m_name; }
 void CreateUserByName::setName(QString newName) {
 	m_name = newName;
 }
-bool CreateUserByName::nameNull() const {
-	return m_name.isNull();
-}
 
-void CreateUserByName::setNameNull() {
-	m_name.clear();
-
-}
 QString CreateUserByName::password() const { return m_password; }
 
 void CreateUserByName::setPassword(QString newPassword) {
diff --git a/core/src/dto/culturedto.cpp b/core/src/dto/culturedto.cpp
index 469e48f..1372c72 100644
--- a/core/src/dto/culturedto.cpp
+++ b/core/src/dto/culturedto.cpp
@@ -33,6 +33,18 @@ namespace Jellyfin {
 namespace DTO {
 
 CultureDto::CultureDto() {}
+CultureDto::CultureDto (
+		QString name, 
+		QString displayName, 
+		QString twoLetterISOLanguageName, 
+		QStringList threeLetterISOLanguageNames 
+		) :
+	m_name(name),
+	m_displayName(displayName),
+	m_twoLetterISOLanguageName(twoLetterISOLanguageName),
+	m_threeLetterISOLanguageNames(threeLetterISOLanguageNames) { }
+
+
 
 CultureDto::CultureDto(const CultureDto &other) :
 
@@ -70,31 +82,15 @@ void CultureDto::setFromJson(QJsonObject source) {
 QJsonObject CultureDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_displayName.isNull())) {
-		result["DisplayName"] = Jellyfin::Support::toJsonValue<QString>(m_displayName);
-	}
-			
-	
-	if (!(m_twoLetterISOLanguageName.isNull())) {
-		result["TwoLetterISOLanguageName"] = Jellyfin::Support::toJsonValue<QString>(m_twoLetterISOLanguageName);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["DisplayName"] = Jellyfin::Support::toJsonValue<QString>(m_displayName);		
+	result["TwoLetterISOLanguageName"] = Jellyfin::Support::toJsonValue<QString>(m_twoLetterISOLanguageName);		
 	
 	if (!(m_threeLetterISOLanguageName.isNull())) {
 		result["ThreeLetterISOLanguageName"] = Jellyfin::Support::toJsonValue<QString>(m_threeLetterISOLanguageName);
 	}
 			
-	
-	if (!(m_threeLetterISOLanguageNames.size() == 0)) {
-		result["ThreeLetterISOLanguageNames"] = Jellyfin::Support::toJsonValue<QStringList>(m_threeLetterISOLanguageNames);
-	}
-		
+	result["ThreeLetterISOLanguageNames"] = Jellyfin::Support::toJsonValue<QStringList>(m_threeLetterISOLanguageNames);	
 	return result;
 }
 
@@ -103,40 +99,19 @@ QString CultureDto::name() const { return m_name; }
 void CultureDto::setName(QString newName) {
 	m_name = newName;
 }
-bool CultureDto::nameNull() const {
-	return m_name.isNull();
-}
 
-void CultureDto::setNameNull() {
-	m_name.clear();
-
-}
 QString CultureDto::displayName() const { return m_displayName; }
 
 void CultureDto::setDisplayName(QString newDisplayName) {
 	m_displayName = newDisplayName;
 }
-bool CultureDto::displayNameNull() const {
-	return m_displayName.isNull();
-}
 
-void CultureDto::setDisplayNameNull() {
-	m_displayName.clear();
-
-}
 QString CultureDto::twoLetterISOLanguageName() const { return m_twoLetterISOLanguageName; }
 
 void CultureDto::setTwoLetterISOLanguageName(QString newTwoLetterISOLanguageName) {
 	m_twoLetterISOLanguageName = newTwoLetterISOLanguageName;
 }
-bool CultureDto::twoLetterISOLanguageNameNull() const {
-	return m_twoLetterISOLanguageName.isNull();
-}
 
-void CultureDto::setTwoLetterISOLanguageNameNull() {
-	m_twoLetterISOLanguageName.clear();
-
-}
 QString CultureDto::threeLetterISOLanguageName() const { return m_threeLetterISOLanguageName; }
 
 void CultureDto::setThreeLetterISOLanguageName(QString newThreeLetterISOLanguageName) {
@@ -155,14 +130,7 @@ QStringList CultureDto::threeLetterISOLanguageNames() const { return m_threeLett
 void CultureDto::setThreeLetterISOLanguageNames(QStringList newThreeLetterISOLanguageNames) {
 	m_threeLetterISOLanguageNames = newThreeLetterISOLanguageNames;
 }
-bool CultureDto::threeLetterISOLanguageNamesNull() const {
-	return m_threeLetterISOLanguageNames.size() == 0;
-}
 
-void CultureDto::setThreeLetterISOLanguageNamesNull() {
-	m_threeLetterISOLanguageNames.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/deviceprofiletype.cpp b/core/src/dto/deinterlacemethod.cpp
similarity index 66%
rename from core/src/dto/deviceprofiletype.cpp
rename to core/src/dto/deinterlacemethod.cpp
index b64d7fa..d9ed894 100644
--- a/core/src/dto/deviceprofiletype.cpp
+++ b/core/src/dto/deinterlacemethod.cpp
@@ -27,43 +27,43 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/deviceprofiletype.h>
+#include <JellyfinQt/dto/deinterlacemethod.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-DeviceProfileTypeClass::DeviceProfileTypeClass() {}
+DeinterlaceMethodClass::DeinterlaceMethodClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using DeviceProfileType = Jellyfin::DTO::DeviceProfileType;
+using DeinterlaceMethod = Jellyfin::DTO::DeinterlaceMethod;
 
 template <>
-DeviceProfileType fromJsonValue(const QJsonValue &source, convertType<DeviceProfileType>) {
-	if (!source.isString()) return DeviceProfileType::EnumNotSet;
+DeinterlaceMethod fromJsonValue(const QJsonValue &source, convertType<DeinterlaceMethod>) {
+	if (!source.isString()) return DeinterlaceMethod::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("System")) {
-		return DeviceProfileType::System;
+	if (str == QStringLiteral("yadif")) {
+		return DeinterlaceMethod::Yadif;
 	}
-	if (str == QStringLiteral("User")) {
-		return DeviceProfileType::User;
+	if (str == QStringLiteral("bwdif")) {
+		return DeinterlaceMethod::Bwdif;
 	}
 	
-	return DeviceProfileType::EnumNotSet;
+	return DeinterlaceMethod::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const DeviceProfileType &source, convertType<DeviceProfileType>) {
+QJsonValue toJsonValue(const DeinterlaceMethod &source, convertType<DeinterlaceMethod>) {
 	switch(source) {
-	case DeviceProfileType::System:
-		return QStringLiteral("System");
-	case DeviceProfileType::User:
-		return QStringLiteral("User");
+	case DeinterlaceMethod::Yadif:
+		return QStringLiteral("yadif");
+	case DeinterlaceMethod::Bwdif:
+		return QStringLiteral("bwdif");
 
-	case DeviceProfileType::EnumNotSet: // Fallthrough
+	case DeinterlaceMethod::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/deviceidentification.cpp b/core/src/dto/deviceidentification.cpp
deleted file mode 100644
index a3bf50e..0000000
--- a/core/src/dto/deviceidentification.cpp
+++ /dev/null
@@ -1,269 +0,0 @@
-/*
- * 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/dto/deviceidentification.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-DeviceIdentification::DeviceIdentification() {}
-
-DeviceIdentification::DeviceIdentification(const DeviceIdentification &other) :
-
-	m_friendlyName(other.m_friendlyName),
-	m_modelNumber(other.m_modelNumber),
-	m_serialNumber(other.m_serialNumber),
-	m_modelName(other.m_modelName),
-	m_modelDescription(other.m_modelDescription),
-	m_modelUrl(other.m_modelUrl),
-	m_manufacturer(other.m_manufacturer),
-	m_manufacturerUrl(other.m_manufacturerUrl),
-	m_headers(other.m_headers){}
-
-
-void DeviceIdentification::replaceData(DeviceIdentification &other) {
-	m_friendlyName = other.m_friendlyName;
-	m_modelNumber = other.m_modelNumber;
-	m_serialNumber = other.m_serialNumber;
-	m_modelName = other.m_modelName;
-	m_modelDescription = other.m_modelDescription;
-	m_modelUrl = other.m_modelUrl;
-	m_manufacturer = other.m_manufacturer;
-	m_manufacturerUrl = other.m_manufacturerUrl;
-	m_headers = other.m_headers;
-}
-
-DeviceIdentification DeviceIdentification::fromJson(QJsonObject source) {
-	DeviceIdentification instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void DeviceIdentification::setFromJson(QJsonObject source) {
-	m_friendlyName = Jellyfin::Support::fromJsonValue<QString>(source["FriendlyName"]);
-	m_modelNumber = Jellyfin::Support::fromJsonValue<QString>(source["ModelNumber"]);
-	m_serialNumber = Jellyfin::Support::fromJsonValue<QString>(source["SerialNumber"]);
-	m_modelName = Jellyfin::Support::fromJsonValue<QString>(source["ModelName"]);
-	m_modelDescription = Jellyfin::Support::fromJsonValue<QString>(source["ModelDescription"]);
-	m_modelUrl = Jellyfin::Support::fromJsonValue<QString>(source["ModelUrl"]);
-	m_manufacturer = Jellyfin::Support::fromJsonValue<QString>(source["Manufacturer"]);
-	m_manufacturerUrl = Jellyfin::Support::fromJsonValue<QString>(source["ManufacturerUrl"]);
-	m_headers = Jellyfin::Support::fromJsonValue<QList<HttpHeaderInfo>>(source["Headers"]);
-
-}
-	
-QJsonObject DeviceIdentification::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_friendlyName.isNull())) {
-		result["FriendlyName"] = Jellyfin::Support::toJsonValue<QString>(m_friendlyName);
-	}
-			
-	
-	if (!(m_modelNumber.isNull())) {
-		result["ModelNumber"] = Jellyfin::Support::toJsonValue<QString>(m_modelNumber);
-	}
-			
-	
-	if (!(m_serialNumber.isNull())) {
-		result["SerialNumber"] = Jellyfin::Support::toJsonValue<QString>(m_serialNumber);
-	}
-			
-	
-	if (!(m_modelName.isNull())) {
-		result["ModelName"] = Jellyfin::Support::toJsonValue<QString>(m_modelName);
-	}
-			
-	
-	if (!(m_modelDescription.isNull())) {
-		result["ModelDescription"] = Jellyfin::Support::toJsonValue<QString>(m_modelDescription);
-	}
-			
-	
-	if (!(m_modelUrl.isNull())) {
-		result["ModelUrl"] = Jellyfin::Support::toJsonValue<QString>(m_modelUrl);
-	}
-			
-	
-	if (!(m_manufacturer.isNull())) {
-		result["Manufacturer"] = Jellyfin::Support::toJsonValue<QString>(m_manufacturer);
-	}
-			
-	
-	if (!(m_manufacturerUrl.isNull())) {
-		result["ManufacturerUrl"] = Jellyfin::Support::toJsonValue<QString>(m_manufacturerUrl);
-	}
-			
-	
-	if (!(m_headers.size() == 0)) {
-		result["Headers"] = Jellyfin::Support::toJsonValue<QList<HttpHeaderInfo>>(m_headers);
-	}
-		
-	return result;
-}
-
-QString DeviceIdentification::friendlyName() const { return m_friendlyName; }
-
-void DeviceIdentification::setFriendlyName(QString newFriendlyName) {
-	m_friendlyName = newFriendlyName;
-}
-bool DeviceIdentification::friendlyNameNull() const {
-	return m_friendlyName.isNull();
-}
-
-void DeviceIdentification::setFriendlyNameNull() {
-	m_friendlyName.clear();
-
-}
-QString DeviceIdentification::modelNumber() const { return m_modelNumber; }
-
-void DeviceIdentification::setModelNumber(QString newModelNumber) {
-	m_modelNumber = newModelNumber;
-}
-bool DeviceIdentification::modelNumberNull() const {
-	return m_modelNumber.isNull();
-}
-
-void DeviceIdentification::setModelNumberNull() {
-	m_modelNumber.clear();
-
-}
-QString DeviceIdentification::serialNumber() const { return m_serialNumber; }
-
-void DeviceIdentification::setSerialNumber(QString newSerialNumber) {
-	m_serialNumber = newSerialNumber;
-}
-bool DeviceIdentification::serialNumberNull() const {
-	return m_serialNumber.isNull();
-}
-
-void DeviceIdentification::setSerialNumberNull() {
-	m_serialNumber.clear();
-
-}
-QString DeviceIdentification::modelName() const { return m_modelName; }
-
-void DeviceIdentification::setModelName(QString newModelName) {
-	m_modelName = newModelName;
-}
-bool DeviceIdentification::modelNameNull() const {
-	return m_modelName.isNull();
-}
-
-void DeviceIdentification::setModelNameNull() {
-	m_modelName.clear();
-
-}
-QString DeviceIdentification::modelDescription() const { return m_modelDescription; }
-
-void DeviceIdentification::setModelDescription(QString newModelDescription) {
-	m_modelDescription = newModelDescription;
-}
-bool DeviceIdentification::modelDescriptionNull() const {
-	return m_modelDescription.isNull();
-}
-
-void DeviceIdentification::setModelDescriptionNull() {
-	m_modelDescription.clear();
-
-}
-QString DeviceIdentification::modelUrl() const { return m_modelUrl; }
-
-void DeviceIdentification::setModelUrl(QString newModelUrl) {
-	m_modelUrl = newModelUrl;
-}
-bool DeviceIdentification::modelUrlNull() const {
-	return m_modelUrl.isNull();
-}
-
-void DeviceIdentification::setModelUrlNull() {
-	m_modelUrl.clear();
-
-}
-QString DeviceIdentification::manufacturer() const { return m_manufacturer; }
-
-void DeviceIdentification::setManufacturer(QString newManufacturer) {
-	m_manufacturer = newManufacturer;
-}
-bool DeviceIdentification::manufacturerNull() const {
-	return m_manufacturer.isNull();
-}
-
-void DeviceIdentification::setManufacturerNull() {
-	m_manufacturer.clear();
-
-}
-QString DeviceIdentification::manufacturerUrl() const { return m_manufacturerUrl; }
-
-void DeviceIdentification::setManufacturerUrl(QString newManufacturerUrl) {
-	m_manufacturerUrl = newManufacturerUrl;
-}
-bool DeviceIdentification::manufacturerUrlNull() const {
-	return m_manufacturerUrl.isNull();
-}
-
-void DeviceIdentification::setManufacturerUrlNull() {
-	m_manufacturerUrl.clear();
-
-}
-QList<HttpHeaderInfo> DeviceIdentification::headers() const { return m_headers; }
-
-void DeviceIdentification::setHeaders(QList<HttpHeaderInfo> newHeaders) {
-	m_headers = newHeaders;
-}
-bool DeviceIdentification::headersNull() const {
-	return m_headers.size() == 0;
-}
-
-void DeviceIdentification::setHeadersNull() {
-	m_headers.clear();
-
-}
-
-} // NS DTO
-
-namespace Support {
-
-using DeviceIdentification = Jellyfin::DTO::DeviceIdentification;
-
-template <>
-DeviceIdentification fromJsonValue(const QJsonValue &source, convertType<DeviceIdentification>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return DeviceIdentification::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const DeviceIdentification &source, convertType<DeviceIdentification>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/deviceinfo.cpp b/core/src/dto/deviceinfodto.cpp
similarity index 50%
rename from core/src/dto/deviceinfo.cpp
rename to core/src/dto/deviceinfodto.cpp
index c4b2de0..ef5f658 100644
--- a/core/src/dto/deviceinfo.cpp
+++ b/core/src/dto/deviceinfodto.cpp
@@ -27,26 +27,24 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/deviceinfo.h>
+#include <JellyfinQt/dto/deviceinfodto.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-DeviceInfo::DeviceInfo() {}
-DeviceInfo::DeviceInfo (
-		QString lastUserId, 
-		QDateTime dateLastActivity, 
-		QSharedPointer<ClientCapabilities> capabilities 
+DeviceInfoDto::DeviceInfoDto() {}
+DeviceInfoDto::DeviceInfoDto (
+		QSharedPointer<ClientCapabilitiesDto> capabilities 
 		) :
-	m_lastUserId(lastUserId),
-	m_dateLastActivity(dateLastActivity),
 	m_capabilities(capabilities) { }
 
 
 
-DeviceInfo::DeviceInfo(const DeviceInfo &other) :
+DeviceInfoDto::DeviceInfoDto(const DeviceInfoDto &other) :
 
 	m_name(other.m_name),
+	m_customName(other.m_customName),
+	m_accessToken(other.m_accessToken),
 	m_jellyfinId(other.m_jellyfinId),
 	m_lastUserName(other.m_lastUserName),
 	m_appName(other.m_appName),
@@ -57,8 +55,10 @@ DeviceInfo::DeviceInfo(const DeviceInfo &other) :
 	m_iconUrl(other.m_iconUrl){}
 
 
-void DeviceInfo::replaceData(DeviceInfo &other) {
+void DeviceInfoDto::replaceData(DeviceInfoDto &other) {
 	m_name = other.m_name;
+	m_customName = other.m_customName;
+	m_accessToken = other.m_accessToken;
 	m_jellyfinId = other.m_jellyfinId;
 	m_lastUserName = other.m_lastUserName;
 	m_appName = other.m_appName;
@@ -69,27 +69,29 @@ void DeviceInfo::replaceData(DeviceInfo &other) {
 	m_iconUrl = other.m_iconUrl;
 }
 
-DeviceInfo DeviceInfo::fromJson(QJsonObject source) {
-	DeviceInfo instance;
+DeviceInfoDto DeviceInfoDto::fromJson(QJsonObject source) {
+	DeviceInfoDto instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void DeviceInfo::setFromJson(QJsonObject source) {
+void DeviceInfoDto::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_customName = Jellyfin::Support::fromJsonValue<QString>(source["CustomName"]);
+	m_accessToken = Jellyfin::Support::fromJsonValue<QString>(source["AccessToken"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
 	m_lastUserName = Jellyfin::Support::fromJsonValue<QString>(source["LastUserName"]);
 	m_appName = Jellyfin::Support::fromJsonValue<QString>(source["AppName"]);
 	m_appVersion = Jellyfin::Support::fromJsonValue<QString>(source["AppVersion"]);
 	m_lastUserId = Jellyfin::Support::fromJsonValue<QString>(source["LastUserId"]);
 	m_dateLastActivity = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateLastActivity"]);
-	m_capabilities = Jellyfin::Support::fromJsonValue<QSharedPointer<ClientCapabilities>>(source["Capabilities"]);
+	m_capabilities = Jellyfin::Support::fromJsonValue<QSharedPointer<ClientCapabilitiesDto>>(source["Capabilities"]);
 	m_iconUrl = Jellyfin::Support::fromJsonValue<QString>(source["IconUrl"]);
 
 }
 	
-QJsonObject DeviceInfo::toJson() const {
+QJsonObject DeviceInfoDto::toJson() const {
 	QJsonObject result;
 	
 	
@@ -98,6 +100,16 @@ QJsonObject DeviceInfo::toJson() const {
 	}
 			
 	
+	if (!(m_customName.isNull())) {
+		result["CustomName"] = Jellyfin::Support::toJsonValue<QString>(m_customName);
+	}
+			
+	
+	if (!(m_accessToken.isNull())) {
+		result["AccessToken"] = Jellyfin::Support::toJsonValue<QString>(m_accessToken);
+	}
+			
+	
 	if (!(m_jellyfinId.isNull())) {
 		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
 	}
@@ -117,9 +129,17 @@ QJsonObject DeviceInfo::toJson() const {
 		result["AppVersion"] = Jellyfin::Support::toJsonValue<QString>(m_appVersion);
 	}
 			
-	result["LastUserId"] = Jellyfin::Support::toJsonValue<QString>(m_lastUserId);		
-	result["DateLastActivity"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateLastActivity);		
-	result["Capabilities"] = Jellyfin::Support::toJsonValue<QSharedPointer<ClientCapabilities>>(m_capabilities);		
+	
+	if (!(m_lastUserId.isNull())) {
+		result["LastUserId"] = Jellyfin::Support::toJsonValue<QString>(m_lastUserId);
+	}
+			
+	
+	if (!(m_dateLastActivity.isNull())) {
+		result["DateLastActivity"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateLastActivity);
+	}
+			
+	result["Capabilities"] = Jellyfin::Support::toJsonValue<QSharedPointer<ClientCapabilitiesDto>>(m_capabilities);		
 	
 	if (!(m_iconUrl.isNull())) {
 		result["IconUrl"] = Jellyfin::Support::toJsonValue<QString>(m_iconUrl);
@@ -128,99 +148,139 @@ QJsonObject DeviceInfo::toJson() const {
 	return result;
 }
 
-QString DeviceInfo::name() const { return m_name; }
+QString DeviceInfoDto::name() const { return m_name; }
 
-void DeviceInfo::setName(QString newName) {
+void DeviceInfoDto::setName(QString newName) {
 	m_name = newName;
 }
-bool DeviceInfo::nameNull() const {
+bool DeviceInfoDto::nameNull() const {
 	return m_name.isNull();
 }
 
-void DeviceInfo::setNameNull() {
+void DeviceInfoDto::setNameNull() {
 	m_name.clear();
 
 }
-QString DeviceInfo::jellyfinId() const { return m_jellyfinId; }
+QString DeviceInfoDto::customName() const { return m_customName; }
 
-void DeviceInfo::setJellyfinId(QString newJellyfinId) {
+void DeviceInfoDto::setCustomName(QString newCustomName) {
+	m_customName = newCustomName;
+}
+bool DeviceInfoDto::customNameNull() const {
+	return m_customName.isNull();
+}
+
+void DeviceInfoDto::setCustomNameNull() {
+	m_customName.clear();
+
+}
+QString DeviceInfoDto::accessToken() const { return m_accessToken; }
+
+void DeviceInfoDto::setAccessToken(QString newAccessToken) {
+	m_accessToken = newAccessToken;
+}
+bool DeviceInfoDto::accessTokenNull() const {
+	return m_accessToken.isNull();
+}
+
+void DeviceInfoDto::setAccessTokenNull() {
+	m_accessToken.clear();
+
+}
+QString DeviceInfoDto::jellyfinId() const { return m_jellyfinId; }
+
+void DeviceInfoDto::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool DeviceInfo::jellyfinIdNull() const {
+bool DeviceInfoDto::jellyfinIdNull() const {
 	return m_jellyfinId.isNull();
 }
 
-void DeviceInfo::setJellyfinIdNull() {
+void DeviceInfoDto::setJellyfinIdNull() {
 	m_jellyfinId.clear();
 
 }
-QString DeviceInfo::lastUserName() const { return m_lastUserName; }
+QString DeviceInfoDto::lastUserName() const { return m_lastUserName; }
 
-void DeviceInfo::setLastUserName(QString newLastUserName) {
+void DeviceInfoDto::setLastUserName(QString newLastUserName) {
 	m_lastUserName = newLastUserName;
 }
-bool DeviceInfo::lastUserNameNull() const {
+bool DeviceInfoDto::lastUserNameNull() const {
 	return m_lastUserName.isNull();
 }
 
-void DeviceInfo::setLastUserNameNull() {
+void DeviceInfoDto::setLastUserNameNull() {
 	m_lastUserName.clear();
 
 }
-QString DeviceInfo::appName() const { return m_appName; }
+QString DeviceInfoDto::appName() const { return m_appName; }
 
-void DeviceInfo::setAppName(QString newAppName) {
+void DeviceInfoDto::setAppName(QString newAppName) {
 	m_appName = newAppName;
 }
-bool DeviceInfo::appNameNull() const {
+bool DeviceInfoDto::appNameNull() const {
 	return m_appName.isNull();
 }
 
-void DeviceInfo::setAppNameNull() {
+void DeviceInfoDto::setAppNameNull() {
 	m_appName.clear();
 
 }
-QString DeviceInfo::appVersion() const { return m_appVersion; }
+QString DeviceInfoDto::appVersion() const { return m_appVersion; }
 
-void DeviceInfo::setAppVersion(QString newAppVersion) {
+void DeviceInfoDto::setAppVersion(QString newAppVersion) {
 	m_appVersion = newAppVersion;
 }
-bool DeviceInfo::appVersionNull() const {
+bool DeviceInfoDto::appVersionNull() const {
 	return m_appVersion.isNull();
 }
 
-void DeviceInfo::setAppVersionNull() {
+void DeviceInfoDto::setAppVersionNull() {
 	m_appVersion.clear();
 
 }
-QString DeviceInfo::lastUserId() const { return m_lastUserId; }
+QString DeviceInfoDto::lastUserId() const { return m_lastUserId; }
 
-void DeviceInfo::setLastUserId(QString newLastUserId) {
+void DeviceInfoDto::setLastUserId(QString newLastUserId) {
 	m_lastUserId = newLastUserId;
 }
-
-QDateTime DeviceInfo::dateLastActivity() const { return m_dateLastActivity; }
-
-void DeviceInfo::setDateLastActivity(QDateTime newDateLastActivity) {
-	m_dateLastActivity = newDateLastActivity;
+bool DeviceInfoDto::lastUserIdNull() const {
+	return m_lastUserId.isNull();
 }
 
-QSharedPointer<ClientCapabilities> DeviceInfo::capabilities() const { return m_capabilities; }
+void DeviceInfoDto::setLastUserIdNull() {
+	m_lastUserId.clear();
 
-void DeviceInfo::setCapabilities(QSharedPointer<ClientCapabilities> newCapabilities) {
+}
+QDateTime DeviceInfoDto::dateLastActivity() const { return m_dateLastActivity; }
+
+void DeviceInfoDto::setDateLastActivity(QDateTime newDateLastActivity) {
+	m_dateLastActivity = newDateLastActivity;
+}
+bool DeviceInfoDto::dateLastActivityNull() const {
+	return m_dateLastActivity.isNull();
+}
+
+void DeviceInfoDto::setDateLastActivityNull() {
+	m_dateLastActivity= QDateTime();
+
+}
+QSharedPointer<ClientCapabilitiesDto> DeviceInfoDto::capabilities() const { return m_capabilities; }
+
+void DeviceInfoDto::setCapabilities(QSharedPointer<ClientCapabilitiesDto> newCapabilities) {
 	m_capabilities = newCapabilities;
 }
 
-QString DeviceInfo::iconUrl() const { return m_iconUrl; }
+QString DeviceInfoDto::iconUrl() const { return m_iconUrl; }
 
-void DeviceInfo::setIconUrl(QString newIconUrl) {
+void DeviceInfoDto::setIconUrl(QString newIconUrl) {
 	m_iconUrl = newIconUrl;
 }
-bool DeviceInfo::iconUrlNull() const {
+bool DeviceInfoDto::iconUrlNull() const {
 	return m_iconUrl.isNull();
 }
 
-void DeviceInfo::setIconUrlNull() {
+void DeviceInfoDto::setIconUrlNull() {
 	m_iconUrl.clear();
 
 }
@@ -229,16 +289,16 @@ void DeviceInfo::setIconUrlNull() {
 
 namespace Support {
 
-using DeviceInfo = Jellyfin::DTO::DeviceInfo;
+using DeviceInfoDto = Jellyfin::DTO::DeviceInfoDto;
 
 template <>
-DeviceInfo fromJsonValue(const QJsonValue &source, convertType<DeviceInfo>) {
+DeviceInfoDto fromJsonValue(const QJsonValue &source, convertType<DeviceInfoDto>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return DeviceInfo::fromJson(source.toObject());
+	return DeviceInfoDto::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const DeviceInfo &source, convertType<DeviceInfo>) {
+QJsonValue toJsonValue(const DeviceInfoDto &source, convertType<DeviceInfoDto>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/deviceinfoqueryresult.cpp b/core/src/dto/deviceinfodtoqueryresult.cpp
similarity index 59%
rename from core/src/dto/deviceinfoqueryresult.cpp
rename to core/src/dto/deviceinfodtoqueryresult.cpp
index 380eaae..f362525 100644
--- a/core/src/dto/deviceinfoqueryresult.cpp
+++ b/core/src/dto/deviceinfodtoqueryresult.cpp
@@ -27,83 +27,74 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/deviceinfoqueryresult.h>
+#include <JellyfinQt/dto/deviceinfodtoqueryresult.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-DeviceInfoQueryResult::DeviceInfoQueryResult() {}
-DeviceInfoQueryResult::DeviceInfoQueryResult (
+DeviceInfoDtoQueryResult::DeviceInfoDtoQueryResult() {}
+DeviceInfoDtoQueryResult::DeviceInfoDtoQueryResult (
+		QList<DeviceInfoDto> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
 
 
-DeviceInfoQueryResult::DeviceInfoQueryResult(const DeviceInfoQueryResult &other) :
+DeviceInfoDtoQueryResult::DeviceInfoDtoQueryResult(const DeviceInfoDtoQueryResult &other) :
 
 	m_items(other.m_items),
 	m_totalRecordCount(other.m_totalRecordCount),
 	m_startIndex(other.m_startIndex){}
 
 
-void DeviceInfoQueryResult::replaceData(DeviceInfoQueryResult &other) {
+void DeviceInfoDtoQueryResult::replaceData(DeviceInfoDtoQueryResult &other) {
 	m_items = other.m_items;
 	m_totalRecordCount = other.m_totalRecordCount;
 	m_startIndex = other.m_startIndex;
 }
 
-DeviceInfoQueryResult DeviceInfoQueryResult::fromJson(QJsonObject source) {
-	DeviceInfoQueryResult instance;
+DeviceInfoDtoQueryResult DeviceInfoDtoQueryResult::fromJson(QJsonObject source) {
+	DeviceInfoDtoQueryResult instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void DeviceInfoQueryResult::setFromJson(QJsonObject source) {
-	m_items = Jellyfin::Support::fromJsonValue<QList<DeviceInfo>>(source["Items"]);
+void DeviceInfoDtoQueryResult::setFromJson(QJsonObject source) {
+	m_items = Jellyfin::Support::fromJsonValue<QList<DeviceInfoDto>>(source["Items"]);
 	m_totalRecordCount = Jellyfin::Support::fromJsonValue<qint32>(source["TotalRecordCount"]);
 	m_startIndex = Jellyfin::Support::fromJsonValue<qint32>(source["StartIndex"]);
 
 }
 	
-QJsonObject DeviceInfoQueryResult::toJson() const {
+QJsonObject DeviceInfoDtoQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<DeviceInfo>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<DeviceInfoDto>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
 }
 
-QList<DeviceInfo> DeviceInfoQueryResult::items() const { return m_items; }
+QList<DeviceInfoDto> DeviceInfoDtoQueryResult::items() const { return m_items; }
 
-void DeviceInfoQueryResult::setItems(QList<DeviceInfo> newItems) {
+void DeviceInfoDtoQueryResult::setItems(QList<DeviceInfoDto> newItems) {
 	m_items = newItems;
 }
-bool DeviceInfoQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void DeviceInfoQueryResult::setItemsNull() {
-	m_items.clear();
+qint32 DeviceInfoDtoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
-}
-qint32 DeviceInfoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
-
-void DeviceInfoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
+void DeviceInfoDtoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
 	m_totalRecordCount = newTotalRecordCount;
 }
 
-qint32 DeviceInfoQueryResult::startIndex() const { return m_startIndex; }
+qint32 DeviceInfoDtoQueryResult::startIndex() const { return m_startIndex; }
 
-void DeviceInfoQueryResult::setStartIndex(qint32 newStartIndex) {
+void DeviceInfoDtoQueryResult::setStartIndex(qint32 newStartIndex) {
 	m_startIndex = newStartIndex;
 }
 
@@ -112,16 +103,16 @@ void DeviceInfoQueryResult::setStartIndex(qint32 newStartIndex) {
 
 namespace Support {
 
-using DeviceInfoQueryResult = Jellyfin::DTO::DeviceInfoQueryResult;
+using DeviceInfoDtoQueryResult = Jellyfin::DTO::DeviceInfoDtoQueryResult;
 
 template <>
-DeviceInfoQueryResult fromJsonValue(const QJsonValue &source, convertType<DeviceInfoQueryResult>) {
+DeviceInfoDtoQueryResult fromJsonValue(const QJsonValue &source, convertType<DeviceInfoDtoQueryResult>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return DeviceInfoQueryResult::fromJson(source.toObject());
+	return DeviceInfoDtoQueryResult::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const DeviceInfoQueryResult &source, convertType<DeviceInfoQueryResult>) {
+QJsonValue toJsonValue(const DeviceInfoDtoQueryResult &source, convertType<DeviceInfoDtoQueryResult>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/deviceoptionsdto.cpp b/core/src/dto/deviceoptionsdto.cpp
new file mode 100644
index 0000000..164343e
--- /dev/null
+++ b/core/src/dto/deviceoptionsdto.cpp
@@ -0,0 +1,138 @@
+/*
+ * 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/dto/deviceoptionsdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+DeviceOptionsDto::DeviceOptionsDto() {}
+DeviceOptionsDto::DeviceOptionsDto (
+		qint32 jellyfinId 
+		) :
+	m_jellyfinId(jellyfinId) { }
+
+
+
+DeviceOptionsDto::DeviceOptionsDto(const DeviceOptionsDto &other) :
+
+	m_jellyfinId(other.m_jellyfinId),
+	m_deviceId(other.m_deviceId),
+	m_customName(other.m_customName){}
+
+
+void DeviceOptionsDto::replaceData(DeviceOptionsDto &other) {
+	m_jellyfinId = other.m_jellyfinId;
+	m_deviceId = other.m_deviceId;
+	m_customName = other.m_customName;
+}
+
+DeviceOptionsDto DeviceOptionsDto::fromJson(QJsonObject source) {
+	DeviceOptionsDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void DeviceOptionsDto::setFromJson(QJsonObject source) {
+	m_jellyfinId = Jellyfin::Support::fromJsonValue<qint32>(source["Id"]);
+	m_deviceId = Jellyfin::Support::fromJsonValue<QString>(source["DeviceId"]);
+	m_customName = Jellyfin::Support::fromJsonValue<QString>(source["CustomName"]);
+
+}
+	
+QJsonObject DeviceOptionsDto::toJson() const {
+	QJsonObject result;
+	
+	result["Id"] = Jellyfin::Support::toJsonValue<qint32>(m_jellyfinId);		
+	
+	if (!(m_deviceId.isNull())) {
+		result["DeviceId"] = Jellyfin::Support::toJsonValue<QString>(m_deviceId);
+	}
+			
+	
+	if (!(m_customName.isNull())) {
+		result["CustomName"] = Jellyfin::Support::toJsonValue<QString>(m_customName);
+	}
+		
+	return result;
+}
+
+qint32 DeviceOptionsDto::jellyfinId() const { return m_jellyfinId; }
+
+void DeviceOptionsDto::setJellyfinId(qint32 newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
+}
+
+QString DeviceOptionsDto::deviceId() const { return m_deviceId; }
+
+void DeviceOptionsDto::setDeviceId(QString newDeviceId) {
+	m_deviceId = newDeviceId;
+}
+bool DeviceOptionsDto::deviceIdNull() const {
+	return m_deviceId.isNull();
+}
+
+void DeviceOptionsDto::setDeviceIdNull() {
+	m_deviceId.clear();
+
+}
+QString DeviceOptionsDto::customName() const { return m_customName; }
+
+void DeviceOptionsDto::setCustomName(QString newCustomName) {
+	m_customName = newCustomName;
+}
+bool DeviceOptionsDto::customNameNull() const {
+	return m_customName.isNull();
+}
+
+void DeviceOptionsDto::setCustomNameNull() {
+	m_customName.clear();
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using DeviceOptionsDto = Jellyfin::DTO::DeviceOptionsDto;
+
+template <>
+DeviceOptionsDto fromJsonValue(const QJsonValue &source, convertType<DeviceOptionsDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return DeviceOptionsDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const DeviceOptionsDto &source, convertType<DeviceOptionsDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/deviceprofile.cpp b/core/src/dto/deviceprofile.cpp
index 26f40b7..47750a8 100644
--- a/core/src/dto/deviceprofile.cpp
+++ b/core/src/dto/deviceprofile.cpp
@@ -34,29 +34,17 @@ namespace DTO {
 
 DeviceProfile::DeviceProfile() {}
 DeviceProfile::DeviceProfile (
-		QSharedPointer<DeviceIdentification> identification, 
-		bool enableAlbumArtInDidl, 
-		bool enableSingleAlbumArtLimit, 
-		bool enableSingleSubtitleLimit, 
-		qint32 maxAlbumArtWidth, 
-		qint32 maxAlbumArtHeight, 
-		qint32 timelineOffsetSeconds, 
-		bool requiresPlainVideoItems, 
-		bool requiresPlainFolders, 
-		bool enableMSMediaReceiverRegistrar, 
-		bool ignoreTranscodeByteRangeRequests 
+		QList<DirectPlayProfile> directPlayProfiles, 
+		QList<TranscodingProfile> transcodingProfiles, 
+		QList<ContainerProfile> containerProfiles, 
+		QList<CodecProfile> codecProfiles, 
+		QList<SubtitleProfile> subtitleProfiles 
 		) :
-	m_identification(identification),
-	m_enableAlbumArtInDidl(enableAlbumArtInDidl),
-	m_enableSingleAlbumArtLimit(enableSingleAlbumArtLimit),
-	m_enableSingleSubtitleLimit(enableSingleSubtitleLimit),
-	m_maxAlbumArtWidth(maxAlbumArtWidth),
-	m_maxAlbumArtHeight(maxAlbumArtHeight),
-	m_timelineOffsetSeconds(timelineOffsetSeconds),
-	m_requiresPlainVideoItems(requiresPlainVideoItems),
-	m_requiresPlainFolders(requiresPlainFolders),
-	m_enableMSMediaReceiverRegistrar(enableMSMediaReceiverRegistrar),
-	m_ignoreTranscodeByteRangeRequests(ignoreTranscodeByteRangeRequests) { }
+	m_directPlayProfiles(directPlayProfiles),
+	m_transcodingProfiles(transcodingProfiles),
+	m_containerProfiles(containerProfiles),
+	m_codecProfiles(codecProfiles),
+	m_subtitleProfiles(subtitleProfiles) { }
 
 
 
@@ -64,84 +52,28 @@ DeviceProfile::DeviceProfile(const DeviceProfile &other) :
 
 	m_name(other.m_name),
 	m_jellyfinId(other.m_jellyfinId),
-	m_identification(other.m_identification),
-	m_friendlyName(other.m_friendlyName),
-	m_manufacturer(other.m_manufacturer),
-	m_manufacturerUrl(other.m_manufacturerUrl),
-	m_modelName(other.m_modelName),
-	m_modelDescription(other.m_modelDescription),
-	m_modelNumber(other.m_modelNumber),
-	m_modelUrl(other.m_modelUrl),
-	m_serialNumber(other.m_serialNumber),
-	m_enableAlbumArtInDidl(other.m_enableAlbumArtInDidl),
-	m_enableSingleAlbumArtLimit(other.m_enableSingleAlbumArtLimit),
-	m_enableSingleSubtitleLimit(other.m_enableSingleSubtitleLimit),
-	m_supportedMediaTypes(other.m_supportedMediaTypes),
-	m_userId(other.m_userId),
-	m_albumArtPn(other.m_albumArtPn),
-	m_maxAlbumArtWidth(other.m_maxAlbumArtWidth),
-	m_maxAlbumArtHeight(other.m_maxAlbumArtHeight),
-	m_maxIconWidth(other.m_maxIconWidth),
-	m_maxIconHeight(other.m_maxIconHeight),
 	m_maxStreamingBitrate(other.m_maxStreamingBitrate),
 	m_maxStaticBitrate(other.m_maxStaticBitrate),
 	m_musicStreamingTranscodingBitrate(other.m_musicStreamingTranscodingBitrate),
 	m_maxStaticMusicBitrate(other.m_maxStaticMusicBitrate),
-	m_sonyAggregationFlags(other.m_sonyAggregationFlags),
-	m_protocolInfo(other.m_protocolInfo),
-	m_timelineOffsetSeconds(other.m_timelineOffsetSeconds),
-	m_requiresPlainVideoItems(other.m_requiresPlainVideoItems),
-	m_requiresPlainFolders(other.m_requiresPlainFolders),
-	m_enableMSMediaReceiverRegistrar(other.m_enableMSMediaReceiverRegistrar),
-	m_ignoreTranscodeByteRangeRequests(other.m_ignoreTranscodeByteRangeRequests),
-	m_xmlRootAttributes(other.m_xmlRootAttributes),
 	m_directPlayProfiles(other.m_directPlayProfiles),
 	m_transcodingProfiles(other.m_transcodingProfiles),
 	m_containerProfiles(other.m_containerProfiles),
 	m_codecProfiles(other.m_codecProfiles),
-	m_responseProfiles(other.m_responseProfiles),
 	m_subtitleProfiles(other.m_subtitleProfiles){}
 
 
 void DeviceProfile::replaceData(DeviceProfile &other) {
 	m_name = other.m_name;
 	m_jellyfinId = other.m_jellyfinId;
-	m_identification = other.m_identification;
-	m_friendlyName = other.m_friendlyName;
-	m_manufacturer = other.m_manufacturer;
-	m_manufacturerUrl = other.m_manufacturerUrl;
-	m_modelName = other.m_modelName;
-	m_modelDescription = other.m_modelDescription;
-	m_modelNumber = other.m_modelNumber;
-	m_modelUrl = other.m_modelUrl;
-	m_serialNumber = other.m_serialNumber;
-	m_enableAlbumArtInDidl = other.m_enableAlbumArtInDidl;
-	m_enableSingleAlbumArtLimit = other.m_enableSingleAlbumArtLimit;
-	m_enableSingleSubtitleLimit = other.m_enableSingleSubtitleLimit;
-	m_supportedMediaTypes = other.m_supportedMediaTypes;
-	m_userId = other.m_userId;
-	m_albumArtPn = other.m_albumArtPn;
-	m_maxAlbumArtWidth = other.m_maxAlbumArtWidth;
-	m_maxAlbumArtHeight = other.m_maxAlbumArtHeight;
-	m_maxIconWidth = other.m_maxIconWidth;
-	m_maxIconHeight = other.m_maxIconHeight;
 	m_maxStreamingBitrate = other.m_maxStreamingBitrate;
 	m_maxStaticBitrate = other.m_maxStaticBitrate;
 	m_musicStreamingTranscodingBitrate = other.m_musicStreamingTranscodingBitrate;
 	m_maxStaticMusicBitrate = other.m_maxStaticMusicBitrate;
-	m_sonyAggregationFlags = other.m_sonyAggregationFlags;
-	m_protocolInfo = other.m_protocolInfo;
-	m_timelineOffsetSeconds = other.m_timelineOffsetSeconds;
-	m_requiresPlainVideoItems = other.m_requiresPlainVideoItems;
-	m_requiresPlainFolders = other.m_requiresPlainFolders;
-	m_enableMSMediaReceiverRegistrar = other.m_enableMSMediaReceiverRegistrar;
-	m_ignoreTranscodeByteRangeRequests = other.m_ignoreTranscodeByteRangeRequests;
-	m_xmlRootAttributes = other.m_xmlRootAttributes;
 	m_directPlayProfiles = other.m_directPlayProfiles;
 	m_transcodingProfiles = other.m_transcodingProfiles;
 	m_containerProfiles = other.m_containerProfiles;
 	m_codecProfiles = other.m_codecProfiles;
-	m_responseProfiles = other.m_responseProfiles;
 	m_subtitleProfiles = other.m_subtitleProfiles;
 }
 
@@ -155,42 +87,14 @@ DeviceProfile DeviceProfile::fromJson(QJsonObject source) {
 void DeviceProfile::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
-	m_identification = Jellyfin::Support::fromJsonValue<QSharedPointer<DeviceIdentification>>(source["Identification"]);
-	m_friendlyName = Jellyfin::Support::fromJsonValue<QString>(source["FriendlyName"]);
-	m_manufacturer = Jellyfin::Support::fromJsonValue<QString>(source["Manufacturer"]);
-	m_manufacturerUrl = Jellyfin::Support::fromJsonValue<QString>(source["ManufacturerUrl"]);
-	m_modelName = Jellyfin::Support::fromJsonValue<QString>(source["ModelName"]);
-	m_modelDescription = Jellyfin::Support::fromJsonValue<QString>(source["ModelDescription"]);
-	m_modelNumber = Jellyfin::Support::fromJsonValue<QString>(source["ModelNumber"]);
-	m_modelUrl = Jellyfin::Support::fromJsonValue<QString>(source["ModelUrl"]);
-	m_serialNumber = Jellyfin::Support::fromJsonValue<QString>(source["SerialNumber"]);
-	m_enableAlbumArtInDidl = Jellyfin::Support::fromJsonValue<bool>(source["EnableAlbumArtInDidl"]);
-	m_enableSingleAlbumArtLimit = Jellyfin::Support::fromJsonValue<bool>(source["EnableSingleAlbumArtLimit"]);
-	m_enableSingleSubtitleLimit = Jellyfin::Support::fromJsonValue<bool>(source["EnableSingleSubtitleLimit"]);
-	m_supportedMediaTypes = Jellyfin::Support::fromJsonValue<QString>(source["SupportedMediaTypes"]);
-	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
-	m_albumArtPn = Jellyfin::Support::fromJsonValue<QString>(source["AlbumArtPn"]);
-	m_maxAlbumArtWidth = Jellyfin::Support::fromJsonValue<qint32>(source["MaxAlbumArtWidth"]);
-	m_maxAlbumArtHeight = Jellyfin::Support::fromJsonValue<qint32>(source["MaxAlbumArtHeight"]);
-	m_maxIconWidth = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxIconWidth"]);
-	m_maxIconHeight = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxIconHeight"]);
 	m_maxStreamingBitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxStreamingBitrate"]);
 	m_maxStaticBitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxStaticBitrate"]);
 	m_musicStreamingTranscodingBitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MusicStreamingTranscodingBitrate"]);
 	m_maxStaticMusicBitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxStaticMusicBitrate"]);
-	m_sonyAggregationFlags = Jellyfin::Support::fromJsonValue<QString>(source["SonyAggregationFlags"]);
-	m_protocolInfo = Jellyfin::Support::fromJsonValue<QString>(source["ProtocolInfo"]);
-	m_timelineOffsetSeconds = Jellyfin::Support::fromJsonValue<qint32>(source["TimelineOffsetSeconds"]);
-	m_requiresPlainVideoItems = Jellyfin::Support::fromJsonValue<bool>(source["RequiresPlainVideoItems"]);
-	m_requiresPlainFolders = Jellyfin::Support::fromJsonValue<bool>(source["RequiresPlainFolders"]);
-	m_enableMSMediaReceiverRegistrar = Jellyfin::Support::fromJsonValue<bool>(source["EnableMSMediaReceiverRegistrar"]);
-	m_ignoreTranscodeByteRangeRequests = Jellyfin::Support::fromJsonValue<bool>(source["IgnoreTranscodeByteRangeRequests"]);
-	m_xmlRootAttributes = Jellyfin::Support::fromJsonValue<QList<XmlAttribute>>(source["XmlRootAttributes"]);
 	m_directPlayProfiles = Jellyfin::Support::fromJsonValue<QList<DirectPlayProfile>>(source["DirectPlayProfiles"]);
 	m_transcodingProfiles = Jellyfin::Support::fromJsonValue<QList<TranscodingProfile>>(source["TranscodingProfiles"]);
 	m_containerProfiles = Jellyfin::Support::fromJsonValue<QList<ContainerProfile>>(source["ContainerProfiles"]);
 	m_codecProfiles = Jellyfin::Support::fromJsonValue<QList<CodecProfile>>(source["CodecProfiles"]);
-	m_responseProfiles = Jellyfin::Support::fromJsonValue<QList<ResponseProfile>>(source["ResponseProfiles"]);
 	m_subtitleProfiles = Jellyfin::Support::fromJsonValue<QList<SubtitleProfile>>(source["SubtitleProfiles"]);
 
 }
@@ -208,77 +112,6 @@ QJsonObject DeviceProfile::toJson() const {
 		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
 	}
 			
-	result["Identification"] = Jellyfin::Support::toJsonValue<QSharedPointer<DeviceIdentification>>(m_identification);		
-	
-	if (!(m_friendlyName.isNull())) {
-		result["FriendlyName"] = Jellyfin::Support::toJsonValue<QString>(m_friendlyName);
-	}
-			
-	
-	if (!(m_manufacturer.isNull())) {
-		result["Manufacturer"] = Jellyfin::Support::toJsonValue<QString>(m_manufacturer);
-	}
-			
-	
-	if (!(m_manufacturerUrl.isNull())) {
-		result["ManufacturerUrl"] = Jellyfin::Support::toJsonValue<QString>(m_manufacturerUrl);
-	}
-			
-	
-	if (!(m_modelName.isNull())) {
-		result["ModelName"] = Jellyfin::Support::toJsonValue<QString>(m_modelName);
-	}
-			
-	
-	if (!(m_modelDescription.isNull())) {
-		result["ModelDescription"] = Jellyfin::Support::toJsonValue<QString>(m_modelDescription);
-	}
-			
-	
-	if (!(m_modelNumber.isNull())) {
-		result["ModelNumber"] = Jellyfin::Support::toJsonValue<QString>(m_modelNumber);
-	}
-			
-	
-	if (!(m_modelUrl.isNull())) {
-		result["ModelUrl"] = Jellyfin::Support::toJsonValue<QString>(m_modelUrl);
-	}
-			
-	
-	if (!(m_serialNumber.isNull())) {
-		result["SerialNumber"] = Jellyfin::Support::toJsonValue<QString>(m_serialNumber);
-	}
-			
-	result["EnableAlbumArtInDidl"] = Jellyfin::Support::toJsonValue<bool>(m_enableAlbumArtInDidl);		
-	result["EnableSingleAlbumArtLimit"] = Jellyfin::Support::toJsonValue<bool>(m_enableSingleAlbumArtLimit);		
-	result["EnableSingleSubtitleLimit"] = Jellyfin::Support::toJsonValue<bool>(m_enableSingleSubtitleLimit);		
-	
-	if (!(m_supportedMediaTypes.isNull())) {
-		result["SupportedMediaTypes"] = Jellyfin::Support::toJsonValue<QString>(m_supportedMediaTypes);
-	}
-			
-	
-	if (!(m_userId.isNull())) {
-		result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);
-	}
-			
-	
-	if (!(m_albumArtPn.isNull())) {
-		result["AlbumArtPn"] = Jellyfin::Support::toJsonValue<QString>(m_albumArtPn);
-	}
-			
-	result["MaxAlbumArtWidth"] = Jellyfin::Support::toJsonValue<qint32>(m_maxAlbumArtWidth);		
-	result["MaxAlbumArtHeight"] = Jellyfin::Support::toJsonValue<qint32>(m_maxAlbumArtHeight);		
-	
-	if (!(!m_maxIconWidth.has_value())) {
-		result["MaxIconWidth"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_maxIconWidth);
-	}
-			
-	
-	if (!(!m_maxIconHeight.has_value())) {
-		result["MaxIconHeight"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_maxIconHeight);
-	}
-			
 	
 	if (!(!m_maxStreamingBitrate.has_value())) {
 		result["MaxStreamingBitrate"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_maxStreamingBitrate);
@@ -299,56 +132,11 @@ QJsonObject DeviceProfile::toJson() const {
 		result["MaxStaticMusicBitrate"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_maxStaticMusicBitrate);
 	}
 			
-	
-	if (!(m_sonyAggregationFlags.isNull())) {
-		result["SonyAggregationFlags"] = Jellyfin::Support::toJsonValue<QString>(m_sonyAggregationFlags);
-	}
-			
-	
-	if (!(m_protocolInfo.isNull())) {
-		result["ProtocolInfo"] = Jellyfin::Support::toJsonValue<QString>(m_protocolInfo);
-	}
-			
-	result["TimelineOffsetSeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_timelineOffsetSeconds);		
-	result["RequiresPlainVideoItems"] = Jellyfin::Support::toJsonValue<bool>(m_requiresPlainVideoItems);		
-	result["RequiresPlainFolders"] = Jellyfin::Support::toJsonValue<bool>(m_requiresPlainFolders);		
-	result["EnableMSMediaReceiverRegistrar"] = Jellyfin::Support::toJsonValue<bool>(m_enableMSMediaReceiverRegistrar);		
-	result["IgnoreTranscodeByteRangeRequests"] = Jellyfin::Support::toJsonValue<bool>(m_ignoreTranscodeByteRangeRequests);		
-	
-	if (!(m_xmlRootAttributes.size() == 0)) {
-		result["XmlRootAttributes"] = Jellyfin::Support::toJsonValue<QList<XmlAttribute>>(m_xmlRootAttributes);
-	}
-			
-	
-	if (!(m_directPlayProfiles.size() == 0)) {
-		result["DirectPlayProfiles"] = Jellyfin::Support::toJsonValue<QList<DirectPlayProfile>>(m_directPlayProfiles);
-	}
-			
-	
-	if (!(m_transcodingProfiles.size() == 0)) {
-		result["TranscodingProfiles"] = Jellyfin::Support::toJsonValue<QList<TranscodingProfile>>(m_transcodingProfiles);
-	}
-			
-	
-	if (!(m_containerProfiles.size() == 0)) {
-		result["ContainerProfiles"] = Jellyfin::Support::toJsonValue<QList<ContainerProfile>>(m_containerProfiles);
-	}
-			
-	
-	if (!(m_codecProfiles.size() == 0)) {
-		result["CodecProfiles"] = Jellyfin::Support::toJsonValue<QList<CodecProfile>>(m_codecProfiles);
-	}
-			
-	
-	if (!(m_responseProfiles.size() == 0)) {
-		result["ResponseProfiles"] = Jellyfin::Support::toJsonValue<QList<ResponseProfile>>(m_responseProfiles);
-	}
-			
-	
-	if (!(m_subtitleProfiles.size() == 0)) {
-		result["SubtitleProfiles"] = Jellyfin::Support::toJsonValue<QList<SubtitleProfile>>(m_subtitleProfiles);
-	}
-		
+	result["DirectPlayProfiles"] = Jellyfin::Support::toJsonValue<QList<DirectPlayProfile>>(m_directPlayProfiles);		
+	result["TranscodingProfiles"] = Jellyfin::Support::toJsonValue<QList<TranscodingProfile>>(m_transcodingProfiles);		
+	result["ContainerProfiles"] = Jellyfin::Support::toJsonValue<QList<ContainerProfile>>(m_containerProfiles);		
+	result["CodecProfiles"] = Jellyfin::Support::toJsonValue<QList<CodecProfile>>(m_codecProfiles);		
+	result["SubtitleProfiles"] = Jellyfin::Support::toJsonValue<QList<SubtitleProfile>>(m_subtitleProfiles);	
 	return result;
 }
 
@@ -377,211 +165,6 @@ bool DeviceProfile::jellyfinIdNull() const {
 void DeviceProfile::setJellyfinIdNull() {
 	m_jellyfinId.clear();
 
-}
-QSharedPointer<DeviceIdentification> DeviceProfile::identification() const { return m_identification; }
-
-void DeviceProfile::setIdentification(QSharedPointer<DeviceIdentification> newIdentification) {
-	m_identification = newIdentification;
-}
-
-QString DeviceProfile::friendlyName() const { return m_friendlyName; }
-
-void DeviceProfile::setFriendlyName(QString newFriendlyName) {
-	m_friendlyName = newFriendlyName;
-}
-bool DeviceProfile::friendlyNameNull() const {
-	return m_friendlyName.isNull();
-}
-
-void DeviceProfile::setFriendlyNameNull() {
-	m_friendlyName.clear();
-
-}
-QString DeviceProfile::manufacturer() const { return m_manufacturer; }
-
-void DeviceProfile::setManufacturer(QString newManufacturer) {
-	m_manufacturer = newManufacturer;
-}
-bool DeviceProfile::manufacturerNull() const {
-	return m_manufacturer.isNull();
-}
-
-void DeviceProfile::setManufacturerNull() {
-	m_manufacturer.clear();
-
-}
-QString DeviceProfile::manufacturerUrl() const { return m_manufacturerUrl; }
-
-void DeviceProfile::setManufacturerUrl(QString newManufacturerUrl) {
-	m_manufacturerUrl = newManufacturerUrl;
-}
-bool DeviceProfile::manufacturerUrlNull() const {
-	return m_manufacturerUrl.isNull();
-}
-
-void DeviceProfile::setManufacturerUrlNull() {
-	m_manufacturerUrl.clear();
-
-}
-QString DeviceProfile::modelName() const { return m_modelName; }
-
-void DeviceProfile::setModelName(QString newModelName) {
-	m_modelName = newModelName;
-}
-bool DeviceProfile::modelNameNull() const {
-	return m_modelName.isNull();
-}
-
-void DeviceProfile::setModelNameNull() {
-	m_modelName.clear();
-
-}
-QString DeviceProfile::modelDescription() const { return m_modelDescription; }
-
-void DeviceProfile::setModelDescription(QString newModelDescription) {
-	m_modelDescription = newModelDescription;
-}
-bool DeviceProfile::modelDescriptionNull() const {
-	return m_modelDescription.isNull();
-}
-
-void DeviceProfile::setModelDescriptionNull() {
-	m_modelDescription.clear();
-
-}
-QString DeviceProfile::modelNumber() const { return m_modelNumber; }
-
-void DeviceProfile::setModelNumber(QString newModelNumber) {
-	m_modelNumber = newModelNumber;
-}
-bool DeviceProfile::modelNumberNull() const {
-	return m_modelNumber.isNull();
-}
-
-void DeviceProfile::setModelNumberNull() {
-	m_modelNumber.clear();
-
-}
-QString DeviceProfile::modelUrl() const { return m_modelUrl; }
-
-void DeviceProfile::setModelUrl(QString newModelUrl) {
-	m_modelUrl = newModelUrl;
-}
-bool DeviceProfile::modelUrlNull() const {
-	return m_modelUrl.isNull();
-}
-
-void DeviceProfile::setModelUrlNull() {
-	m_modelUrl.clear();
-
-}
-QString DeviceProfile::serialNumber() const { return m_serialNumber; }
-
-void DeviceProfile::setSerialNumber(QString newSerialNumber) {
-	m_serialNumber = newSerialNumber;
-}
-bool DeviceProfile::serialNumberNull() const {
-	return m_serialNumber.isNull();
-}
-
-void DeviceProfile::setSerialNumberNull() {
-	m_serialNumber.clear();
-
-}
-bool DeviceProfile::enableAlbumArtInDidl() const { return m_enableAlbumArtInDidl; }
-
-void DeviceProfile::setEnableAlbumArtInDidl(bool newEnableAlbumArtInDidl) {
-	m_enableAlbumArtInDidl = newEnableAlbumArtInDidl;
-}
-
-bool DeviceProfile::enableSingleAlbumArtLimit() const { return m_enableSingleAlbumArtLimit; }
-
-void DeviceProfile::setEnableSingleAlbumArtLimit(bool newEnableSingleAlbumArtLimit) {
-	m_enableSingleAlbumArtLimit = newEnableSingleAlbumArtLimit;
-}
-
-bool DeviceProfile::enableSingleSubtitleLimit() const { return m_enableSingleSubtitleLimit; }
-
-void DeviceProfile::setEnableSingleSubtitleLimit(bool newEnableSingleSubtitleLimit) {
-	m_enableSingleSubtitleLimit = newEnableSingleSubtitleLimit;
-}
-
-QString DeviceProfile::supportedMediaTypes() const { return m_supportedMediaTypes; }
-
-void DeviceProfile::setSupportedMediaTypes(QString newSupportedMediaTypes) {
-	m_supportedMediaTypes = newSupportedMediaTypes;
-}
-bool DeviceProfile::supportedMediaTypesNull() const {
-	return m_supportedMediaTypes.isNull();
-}
-
-void DeviceProfile::setSupportedMediaTypesNull() {
-	m_supportedMediaTypes.clear();
-
-}
-QString DeviceProfile::userId() const { return m_userId; }
-
-void DeviceProfile::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-bool DeviceProfile::userIdNull() const {
-	return m_userId.isNull();
-}
-
-void DeviceProfile::setUserIdNull() {
-	m_userId.clear();
-
-}
-QString DeviceProfile::albumArtPn() const { return m_albumArtPn; }
-
-void DeviceProfile::setAlbumArtPn(QString newAlbumArtPn) {
-	m_albumArtPn = newAlbumArtPn;
-}
-bool DeviceProfile::albumArtPnNull() const {
-	return m_albumArtPn.isNull();
-}
-
-void DeviceProfile::setAlbumArtPnNull() {
-	m_albumArtPn.clear();
-
-}
-qint32 DeviceProfile::maxAlbumArtWidth() const { return m_maxAlbumArtWidth; }
-
-void DeviceProfile::setMaxAlbumArtWidth(qint32 newMaxAlbumArtWidth) {
-	m_maxAlbumArtWidth = newMaxAlbumArtWidth;
-}
-
-qint32 DeviceProfile::maxAlbumArtHeight() const { return m_maxAlbumArtHeight; }
-
-void DeviceProfile::setMaxAlbumArtHeight(qint32 newMaxAlbumArtHeight) {
-	m_maxAlbumArtHeight = newMaxAlbumArtHeight;
-}
-
-std::optional<qint32> DeviceProfile::maxIconWidth() const { return m_maxIconWidth; }
-
-void DeviceProfile::setMaxIconWidth(std::optional<qint32> newMaxIconWidth) {
-	m_maxIconWidth = newMaxIconWidth;
-}
-bool DeviceProfile::maxIconWidthNull() const {
-	return !m_maxIconWidth.has_value();
-}
-
-void DeviceProfile::setMaxIconWidthNull() {
-	m_maxIconWidth = std::nullopt;
-
-}
-std::optional<qint32> DeviceProfile::maxIconHeight() const { return m_maxIconHeight; }
-
-void DeviceProfile::setMaxIconHeight(std::optional<qint32> newMaxIconHeight) {
-	m_maxIconHeight = newMaxIconHeight;
-}
-bool DeviceProfile::maxIconHeightNull() const {
-	return !m_maxIconHeight.has_value();
-}
-
-void DeviceProfile::setMaxIconHeightNull() {
-	m_maxIconHeight = std::nullopt;
-
 }
 std::optional<qint32> DeviceProfile::maxStreamingBitrate() const { return m_maxStreamingBitrate; }
 
@@ -634,154 +217,37 @@ bool DeviceProfile::maxStaticMusicBitrateNull() const {
 void DeviceProfile::setMaxStaticMusicBitrateNull() {
 	m_maxStaticMusicBitrate = std::nullopt;
 
-}
-QString DeviceProfile::sonyAggregationFlags() const { return m_sonyAggregationFlags; }
-
-void DeviceProfile::setSonyAggregationFlags(QString newSonyAggregationFlags) {
-	m_sonyAggregationFlags = newSonyAggregationFlags;
-}
-bool DeviceProfile::sonyAggregationFlagsNull() const {
-	return m_sonyAggregationFlags.isNull();
-}
-
-void DeviceProfile::setSonyAggregationFlagsNull() {
-	m_sonyAggregationFlags.clear();
-
-}
-QString DeviceProfile::protocolInfo() const { return m_protocolInfo; }
-
-void DeviceProfile::setProtocolInfo(QString newProtocolInfo) {
-	m_protocolInfo = newProtocolInfo;
-}
-bool DeviceProfile::protocolInfoNull() const {
-	return m_protocolInfo.isNull();
-}
-
-void DeviceProfile::setProtocolInfoNull() {
-	m_protocolInfo.clear();
-
-}
-qint32 DeviceProfile::timelineOffsetSeconds() const { return m_timelineOffsetSeconds; }
-
-void DeviceProfile::setTimelineOffsetSeconds(qint32 newTimelineOffsetSeconds) {
-	m_timelineOffsetSeconds = newTimelineOffsetSeconds;
-}
-
-bool DeviceProfile::requiresPlainVideoItems() const { return m_requiresPlainVideoItems; }
-
-void DeviceProfile::setRequiresPlainVideoItems(bool newRequiresPlainVideoItems) {
-	m_requiresPlainVideoItems = newRequiresPlainVideoItems;
-}
-
-bool DeviceProfile::requiresPlainFolders() const { return m_requiresPlainFolders; }
-
-void DeviceProfile::setRequiresPlainFolders(bool newRequiresPlainFolders) {
-	m_requiresPlainFolders = newRequiresPlainFolders;
-}
-
-bool DeviceProfile::enableMSMediaReceiverRegistrar() const { return m_enableMSMediaReceiverRegistrar; }
-
-void DeviceProfile::setEnableMSMediaReceiverRegistrar(bool newEnableMSMediaReceiverRegistrar) {
-	m_enableMSMediaReceiverRegistrar = newEnableMSMediaReceiverRegistrar;
-}
-
-bool DeviceProfile::ignoreTranscodeByteRangeRequests() const { return m_ignoreTranscodeByteRangeRequests; }
-
-void DeviceProfile::setIgnoreTranscodeByteRangeRequests(bool newIgnoreTranscodeByteRangeRequests) {
-	m_ignoreTranscodeByteRangeRequests = newIgnoreTranscodeByteRangeRequests;
-}
-
-QList<XmlAttribute> DeviceProfile::xmlRootAttributes() const { return m_xmlRootAttributes; }
-
-void DeviceProfile::setXmlRootAttributes(QList<XmlAttribute> newXmlRootAttributes) {
-	m_xmlRootAttributes = newXmlRootAttributes;
-}
-bool DeviceProfile::xmlRootAttributesNull() const {
-	return m_xmlRootAttributes.size() == 0;
-}
-
-void DeviceProfile::setXmlRootAttributesNull() {
-	m_xmlRootAttributes.clear();
-
 }
 QList<DirectPlayProfile> DeviceProfile::directPlayProfiles() const { return m_directPlayProfiles; }
 
 void DeviceProfile::setDirectPlayProfiles(QList<DirectPlayProfile> newDirectPlayProfiles) {
 	m_directPlayProfiles = newDirectPlayProfiles;
 }
-bool DeviceProfile::directPlayProfilesNull() const {
-	return m_directPlayProfiles.size() == 0;
-}
 
-void DeviceProfile::setDirectPlayProfilesNull() {
-	m_directPlayProfiles.clear();
-
-}
 QList<TranscodingProfile> DeviceProfile::transcodingProfiles() const { return m_transcodingProfiles; }
 
 void DeviceProfile::setTranscodingProfiles(QList<TranscodingProfile> newTranscodingProfiles) {
 	m_transcodingProfiles = newTranscodingProfiles;
 }
-bool DeviceProfile::transcodingProfilesNull() const {
-	return m_transcodingProfiles.size() == 0;
-}
 
-void DeviceProfile::setTranscodingProfilesNull() {
-	m_transcodingProfiles.clear();
-
-}
 QList<ContainerProfile> DeviceProfile::containerProfiles() const { return m_containerProfiles; }
 
 void DeviceProfile::setContainerProfiles(QList<ContainerProfile> newContainerProfiles) {
 	m_containerProfiles = newContainerProfiles;
 }
-bool DeviceProfile::containerProfilesNull() const {
-	return m_containerProfiles.size() == 0;
-}
 
-void DeviceProfile::setContainerProfilesNull() {
-	m_containerProfiles.clear();
-
-}
 QList<CodecProfile> DeviceProfile::codecProfiles() const { return m_codecProfiles; }
 
 void DeviceProfile::setCodecProfiles(QList<CodecProfile> newCodecProfiles) {
 	m_codecProfiles = newCodecProfiles;
 }
-bool DeviceProfile::codecProfilesNull() const {
-	return m_codecProfiles.size() == 0;
-}
 
-void DeviceProfile::setCodecProfilesNull() {
-	m_codecProfiles.clear();
-
-}
-QList<ResponseProfile> DeviceProfile::responseProfiles() const { return m_responseProfiles; }
-
-void DeviceProfile::setResponseProfiles(QList<ResponseProfile> newResponseProfiles) {
-	m_responseProfiles = newResponseProfiles;
-}
-bool DeviceProfile::responseProfilesNull() const {
-	return m_responseProfiles.size() == 0;
-}
-
-void DeviceProfile::setResponseProfilesNull() {
-	m_responseProfiles.clear();
-
-}
 QList<SubtitleProfile> DeviceProfile::subtitleProfiles() const { return m_subtitleProfiles; }
 
 void DeviceProfile::setSubtitleProfiles(QList<SubtitleProfile> newSubtitleProfiles) {
 	m_subtitleProfiles = newSubtitleProfiles;
 }
-bool DeviceProfile::subtitleProfilesNull() const {
-	return m_subtitleProfiles.size() == 0;
-}
 
-void DeviceProfile::setSubtitleProfilesNull() {
-	m_subtitleProfiles.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/deviceprofileinfo.cpp b/core/src/dto/deviceprofileinfo.cpp
deleted file mode 100644
index 903a48c..0000000
--- a/core/src/dto/deviceprofileinfo.cpp
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * 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/dto/deviceprofileinfo.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-DeviceProfileInfo::DeviceProfileInfo() {}
-DeviceProfileInfo::DeviceProfileInfo (
-		DeviceProfileType type 
-		) :
-	m_type(type) { }
-
-
-
-DeviceProfileInfo::DeviceProfileInfo(const DeviceProfileInfo &other) :
-
-	m_jellyfinId(other.m_jellyfinId),
-	m_name(other.m_name),
-	m_type(other.m_type){}
-
-
-void DeviceProfileInfo::replaceData(DeviceProfileInfo &other) {
-	m_jellyfinId = other.m_jellyfinId;
-	m_name = other.m_name;
-	m_type = other.m_type;
-}
-
-DeviceProfileInfo DeviceProfileInfo::fromJson(QJsonObject source) {
-	DeviceProfileInfo instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void DeviceProfileInfo::setFromJson(QJsonObject source) {
-	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
-	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_type = Jellyfin::Support::fromJsonValue<DeviceProfileType>(source["Type"]);
-
-}
-	
-QJsonObject DeviceProfileInfo::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-			
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	result["Type"] = Jellyfin::Support::toJsonValue<DeviceProfileType>(m_type);	
-	return result;
-}
-
-QString DeviceProfileInfo::jellyfinId() const { return m_jellyfinId; }
-
-void DeviceProfileInfo::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
-}
-bool DeviceProfileInfo::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
-
-void DeviceProfileInfo::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
-QString DeviceProfileInfo::name() const { return m_name; }
-
-void DeviceProfileInfo::setName(QString newName) {
-	m_name = newName;
-}
-bool DeviceProfileInfo::nameNull() const {
-	return m_name.isNull();
-}
-
-void DeviceProfileInfo::setNameNull() {
-	m_name.clear();
-
-}
-DeviceProfileType DeviceProfileInfo::type() const { return m_type; }
-
-void DeviceProfileInfo::setType(DeviceProfileType newType) {
-	m_type = newType;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using DeviceProfileInfo = Jellyfin::DTO::DeviceProfileInfo;
-
-template <>
-DeviceProfileInfo fromJsonValue(const QJsonValue &source, convertType<DeviceProfileInfo>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return DeviceProfileInfo::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const DeviceProfileInfo &source, convertType<DeviceProfileInfo>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/directplayprofile.cpp b/core/src/dto/directplayprofile.cpp
index 519e23a..9105654 100644
--- a/core/src/dto/directplayprofile.cpp
+++ b/core/src/dto/directplayprofile.cpp
@@ -34,8 +34,10 @@ namespace DTO {
 
 DirectPlayProfile::DirectPlayProfile() {}
 DirectPlayProfile::DirectPlayProfile (
+		QString container, 
 		DlnaProfileType type 
 		) :
+	m_container(container),
 	m_type(type) { }
 
 
@@ -73,11 +75,7 @@ void DirectPlayProfile::setFromJson(QJsonObject source) {
 QJsonObject DirectPlayProfile::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_container.isNull())) {
-		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
-	}
-			
+	result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);		
 	
 	if (!(m_audioCodec.isNull())) {
 		result["AudioCodec"] = Jellyfin::Support::toJsonValue<QString>(m_audioCodec);
@@ -97,14 +95,7 @@ QString DirectPlayProfile::container() const { return m_container; }
 void DirectPlayProfile::setContainer(QString newContainer) {
 	m_container = newContainer;
 }
-bool DirectPlayProfile::containerNull() const {
-	return m_container.isNull();
-}
 
-void DirectPlayProfile::setContainerNull() {
-	m_container.clear();
-
-}
 QString DirectPlayProfile::audioCodec() const { return m_audioCodec; }
 
 void DirectPlayProfile::setAudioCodec(QString newAudioCodec) {
diff --git a/core/src/dto/displaypreferencesdto.cpp b/core/src/dto/displaypreferencesdto.cpp
index cb510db..79a5a3c 100644
--- a/core/src/dto/displaypreferencesdto.cpp
+++ b/core/src/dto/displaypreferencesdto.cpp
@@ -37,6 +37,7 @@ DisplayPreferencesDto::DisplayPreferencesDto (
 		bool rememberIndexing, 
 		qint32 primaryImageHeight, 
 		qint32 primaryImageWidth, 
+		QJsonObject customPrefs, 
 		ScrollDirection scrollDirection, 
 		bool showBackdrop, 
 		bool rememberSorting, 
@@ -46,6 +47,7 @@ DisplayPreferencesDto::DisplayPreferencesDto (
 	m_rememberIndexing(rememberIndexing),
 	m_primaryImageHeight(primaryImageHeight),
 	m_primaryImageWidth(primaryImageWidth),
+	m_customPrefs(customPrefs),
 	m_scrollDirection(scrollDirection),
 	m_showBackdrop(showBackdrop),
 	m_rememberSorting(rememberSorting),
@@ -140,11 +142,7 @@ QJsonObject DisplayPreferencesDto::toJson() const {
 	result["RememberIndexing"] = Jellyfin::Support::toJsonValue<bool>(m_rememberIndexing);		
 	result["PrimaryImageHeight"] = Jellyfin::Support::toJsonValue<qint32>(m_primaryImageHeight);		
 	result["PrimaryImageWidth"] = Jellyfin::Support::toJsonValue<qint32>(m_primaryImageWidth);		
-	
-	if (!(m_customPrefs.isEmpty())) {
-		result["CustomPrefs"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_customPrefs);
-	}
-			
+	result["CustomPrefs"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_customPrefs);		
 	result["ScrollDirection"] = Jellyfin::Support::toJsonValue<ScrollDirection>(m_scrollDirection);		
 	result["ShowBackdrop"] = Jellyfin::Support::toJsonValue<bool>(m_showBackdrop);		
 	result["RememberSorting"] = Jellyfin::Support::toJsonValue<bool>(m_rememberSorting);		
@@ -233,14 +231,7 @@ QJsonObject DisplayPreferencesDto::customPrefs() const { return m_customPrefs; }
 void DisplayPreferencesDto::setCustomPrefs(QJsonObject newCustomPrefs) {
 	m_customPrefs = newCustomPrefs;
 }
-bool DisplayPreferencesDto::customPrefsNull() const {
-	return m_customPrefs.isEmpty();
-}
 
-void DisplayPreferencesDto::setCustomPrefsNull() {
-	m_customPrefs= QJsonObject();
-
-}
 ScrollDirection DisplayPreferencesDto::scrollDirection() const { return m_scrollDirection; }
 
 void DisplayPreferencesDto::setScrollDirection(ScrollDirection newScrollDirection) {
diff --git a/core/src/dto/dlnaprofiletype.cpp b/core/src/dto/dlnaprofiletype.cpp
index 611edb9..2f5563d 100644
--- a/core/src/dto/dlnaprofiletype.cpp
+++ b/core/src/dto/dlnaprofiletype.cpp
@@ -54,6 +54,12 @@ DlnaProfileType fromJsonValue(const QJsonValue &source, convertType<DlnaProfileT
 	if (str == QStringLiteral("Photo")) {
 		return DlnaProfileType::Photo;
 	}
+	if (str == QStringLiteral("Subtitle")) {
+		return DlnaProfileType::Subtitle;
+	}
+	if (str == QStringLiteral("Lyric")) {
+		return DlnaProfileType::Lyric;
+	}
 	
 	return DlnaProfileType::EnumNotSet;
 }
@@ -67,6 +73,10 @@ QJsonValue toJsonValue(const DlnaProfileType &source, convertType<DlnaProfileTyp
 		return QStringLiteral("Video");
 	case DlnaProfileType::Photo:
 		return QStringLiteral("Photo");
+	case DlnaProfileType::Subtitle:
+		return QStringLiteral("Subtitle");
+	case DlnaProfileType::Lyric:
+		return QStringLiteral("Lyric");
 
 	case DlnaProfileType::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/downmixstereoalgorithms.cpp b/core/src/dto/downmixstereoalgorithms.cpp
new file mode 100644
index 0000000..42cf054
--- /dev/null
+++ b/core/src/dto/downmixstereoalgorithms.cpp
@@ -0,0 +1,88 @@
+/*
+ * 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/dto/downmixstereoalgorithms.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+DownMixStereoAlgorithmsClass::DownMixStereoAlgorithmsClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using DownMixStereoAlgorithms = Jellyfin::DTO::DownMixStereoAlgorithms;
+
+template <>
+DownMixStereoAlgorithms fromJsonValue(const QJsonValue &source, convertType<DownMixStereoAlgorithms>) {
+	if (!source.isString()) return DownMixStereoAlgorithms::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("None")) {
+		return DownMixStereoAlgorithms::None;
+	}
+	if (str == QStringLiteral("Dave750")) {
+		return DownMixStereoAlgorithms::Dave750;
+	}
+	if (str == QStringLiteral("NightmodeDialogue")) {
+		return DownMixStereoAlgorithms::NightmodeDialogue;
+	}
+	if (str == QStringLiteral("Rfc7845")) {
+		return DownMixStereoAlgorithms::Rfc7845;
+	}
+	if (str == QStringLiteral("Ac4")) {
+		return DownMixStereoAlgorithms::Ac4;
+	}
+	
+	return DownMixStereoAlgorithms::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const DownMixStereoAlgorithms &source, convertType<DownMixStereoAlgorithms>) {
+	switch(source) {
+	case DownMixStereoAlgorithms::None:
+		return QStringLiteral("None");
+	case DownMixStereoAlgorithms::Dave750:
+		return QStringLiteral("Dave750");
+	case DownMixStereoAlgorithms::NightmodeDialogue:
+		return QStringLiteral("NightmodeDialogue");
+	case DownMixStereoAlgorithms::Rfc7845:
+		return QStringLiteral("Rfc7845");
+	case DownMixStereoAlgorithms::Ac4:
+		return QStringLiteral("Ac4");
+
+	case DownMixStereoAlgorithms::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/ffmpeglocation.cpp b/core/src/dto/embeddedsubtitleoptions.cpp
similarity index 55%
rename from core/src/dto/ffmpeglocation.cpp
rename to core/src/dto/embeddedsubtitleoptions.cpp
index 8df09f6..0576077 100644
--- a/core/src/dto/ffmpeglocation.cpp
+++ b/core/src/dto/embeddedsubtitleoptions.cpp
@@ -27,53 +27,53 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/ffmpeglocation.h>
+#include <JellyfinQt/dto/embeddedsubtitleoptions.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-FFmpegLocationClass::FFmpegLocationClass() {}
+EmbeddedSubtitleOptionsClass::EmbeddedSubtitleOptionsClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using FFmpegLocation = Jellyfin::DTO::FFmpegLocation;
+using EmbeddedSubtitleOptions = Jellyfin::DTO::EmbeddedSubtitleOptions;
 
 template <>
-FFmpegLocation fromJsonValue(const QJsonValue &source, convertType<FFmpegLocation>) {
-	if (!source.isString()) return FFmpegLocation::EnumNotSet;
+EmbeddedSubtitleOptions fromJsonValue(const QJsonValue &source, convertType<EmbeddedSubtitleOptions>) {
+	if (!source.isString()) return EmbeddedSubtitleOptions::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("NotFound")) {
-		return FFmpegLocation::NotFound;
+	if (str == QStringLiteral("AllowAll")) {
+		return EmbeddedSubtitleOptions::AllowAll;
 	}
-	if (str == QStringLiteral("SetByArgument")) {
-		return FFmpegLocation::SetByArgument;
+	if (str == QStringLiteral("AllowText")) {
+		return EmbeddedSubtitleOptions::AllowText;
 	}
-	if (str == QStringLiteral("Custom")) {
-		return FFmpegLocation::Custom;
+	if (str == QStringLiteral("AllowImage")) {
+		return EmbeddedSubtitleOptions::AllowImage;
 	}
-	if (str == QStringLiteral("System")) {
-		return FFmpegLocation::System;
+	if (str == QStringLiteral("AllowNone")) {
+		return EmbeddedSubtitleOptions::AllowNone;
 	}
 	
-	return FFmpegLocation::EnumNotSet;
+	return EmbeddedSubtitleOptions::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const FFmpegLocation &source, convertType<FFmpegLocation>) {
+QJsonValue toJsonValue(const EmbeddedSubtitleOptions &source, convertType<EmbeddedSubtitleOptions>) {
 	switch(source) {
-	case FFmpegLocation::NotFound:
-		return QStringLiteral("NotFound");
-	case FFmpegLocation::SetByArgument:
-		return QStringLiteral("SetByArgument");
-	case FFmpegLocation::Custom:
-		return QStringLiteral("Custom");
-	case FFmpegLocation::System:
-		return QStringLiteral("System");
+	case EmbeddedSubtitleOptions::AllowAll:
+		return QStringLiteral("AllowAll");
+	case EmbeddedSubtitleOptions::AllowText:
+		return QStringLiteral("AllowText");
+	case EmbeddedSubtitleOptions::AllowImage:
+		return QStringLiteral("AllowImage");
+	case EmbeddedSubtitleOptions::AllowNone:
+		return QStringLiteral("AllowNone");
 
-	case FFmpegLocation::EnumNotSet: // Fallthrough
+	case EmbeddedSubtitleOptions::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/encoderpreset.cpp b/core/src/dto/encoderpreset.cpp
new file mode 100644
index 0000000..bfd4d70
--- /dev/null
+++ b/core/src/dto/encoderpreset.cpp
@@ -0,0 +1,118 @@
+/*
+ * 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/dto/encoderpreset.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+EncoderPresetClass::EncoderPresetClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using EncoderPreset = Jellyfin::DTO::EncoderPreset;
+
+template <>
+EncoderPreset fromJsonValue(const QJsonValue &source, convertType<EncoderPreset>) {
+	if (!source.isString()) return EncoderPreset::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("auto")) {
+		return EncoderPreset::Automatic;
+	}
+	if (str == QStringLiteral("placebo")) {
+		return EncoderPreset::Placebo;
+	}
+	if (str == QStringLiteral("veryslow")) {
+		return EncoderPreset::Veryslow;
+	}
+	if (str == QStringLiteral("slower")) {
+		return EncoderPreset::Slower;
+	}
+	if (str == QStringLiteral("slow")) {
+		return EncoderPreset::Slow;
+	}
+	if (str == QStringLiteral("medium")) {
+		return EncoderPreset::Medium;
+	}
+	if (str == QStringLiteral("fast")) {
+		return EncoderPreset::Fast;
+	}
+	if (str == QStringLiteral("faster")) {
+		return EncoderPreset::Faster;
+	}
+	if (str == QStringLiteral("veryfast")) {
+		return EncoderPreset::Veryfast;
+	}
+	if (str == QStringLiteral("superfast")) {
+		return EncoderPreset::Superfast;
+	}
+	if (str == QStringLiteral("ultrafast")) {
+		return EncoderPreset::Ultrafast;
+	}
+	
+	return EncoderPreset::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const EncoderPreset &source, convertType<EncoderPreset>) {
+	switch(source) {
+	case EncoderPreset::Automatic:
+		return QStringLiteral("auto");
+	case EncoderPreset::Placebo:
+		return QStringLiteral("placebo");
+	case EncoderPreset::Veryslow:
+		return QStringLiteral("veryslow");
+	case EncoderPreset::Slower:
+		return QStringLiteral("slower");
+	case EncoderPreset::Slow:
+		return QStringLiteral("slow");
+	case EncoderPreset::Medium:
+		return QStringLiteral("medium");
+	case EncoderPreset::Fast:
+		return QStringLiteral("fast");
+	case EncoderPreset::Faster:
+		return QStringLiteral("faster");
+	case EncoderPreset::Veryfast:
+		return QStringLiteral("veryfast");
+	case EncoderPreset::Superfast:
+		return QStringLiteral("superfast");
+	case EncoderPreset::Ultrafast:
+		return QStringLiteral("ultrafast");
+
+	case EncoderPreset::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/encodingoptions.cpp b/core/src/dto/encodingoptions.cpp
new file mode 100644
index 0000000..fecb42c
--- /dev/null
+++ b/core/src/dto/encodingoptions.cpp
@@ -0,0 +1,720 @@
+/*
+ * 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/dto/encodingoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+EncodingOptions::EncodingOptions() {}
+EncodingOptions::EncodingOptions (
+		qint32 encodingThreadCount, 
+		bool enableFallbackFont, 
+		bool enableAudioVbr, 
+		double downMixAudioBoost, 
+		DownMixStereoAlgorithms downMixStereoAlgorithm, 
+		qint32 maxMuxingQueueSize, 
+		bool enableThrottling, 
+		qint32 throttleDelaySeconds, 
+		bool enableSegmentDeletion, 
+		qint32 segmentKeepSeconds, 
+		HardwareAccelerationType hardwareAccelerationType, 
+		bool enableTonemapping, 
+		bool enableVppTonemapping, 
+		bool enableVideoToolboxTonemapping, 
+		TonemappingAlgorithm tonemappingAlgorithm, 
+		TonemappingMode tonemappingMode, 
+		TonemappingRange tonemappingRange, 
+		double tonemappingDesat, 
+		double tonemappingPeak, 
+		double tonemappingParam, 
+		double vppTonemappingBrightness, 
+		double vppTonemappingContrast, 
+		qint32 h264Crf, 
+		qint32 h265Crf, 
+		EncoderPreset encoderPreset, 
+		bool deinterlaceDoubleRate, 
+		DeinterlaceMethod deinterlaceMethod, 
+		bool enableDecodingColorDepth10Hevc, 
+		bool enableDecodingColorDepth10Vp9, 
+		bool enableDecodingColorDepth10HevcRext, 
+		bool enableDecodingColorDepth12HevcRext, 
+		bool enableEnhancedNvdecDecoder, 
+		bool preferSystemNativeHwDecoder, 
+		bool enableIntelLowPowerH264HwEncoder, 
+		bool enableIntelLowPowerHevcHwEncoder, 
+		bool enableHardwareEncoding, 
+		bool allowHevcEncoding, 
+		bool allowAv1Encoding, 
+		bool enableSubtitleExtraction 
+		) :
+	m_encodingThreadCount(encodingThreadCount),
+	m_enableFallbackFont(enableFallbackFont),
+	m_enableAudioVbr(enableAudioVbr),
+	m_downMixAudioBoost(downMixAudioBoost),
+	m_downMixStereoAlgorithm(downMixStereoAlgorithm),
+	m_maxMuxingQueueSize(maxMuxingQueueSize),
+	m_enableThrottling(enableThrottling),
+	m_throttleDelaySeconds(throttleDelaySeconds),
+	m_enableSegmentDeletion(enableSegmentDeletion),
+	m_segmentKeepSeconds(segmentKeepSeconds),
+	m_hardwareAccelerationType(hardwareAccelerationType),
+	m_enableTonemapping(enableTonemapping),
+	m_enableVppTonemapping(enableVppTonemapping),
+	m_enableVideoToolboxTonemapping(enableVideoToolboxTonemapping),
+	m_tonemappingAlgorithm(tonemappingAlgorithm),
+	m_tonemappingMode(tonemappingMode),
+	m_tonemappingRange(tonemappingRange),
+	m_tonemappingDesat(tonemappingDesat),
+	m_tonemappingPeak(tonemappingPeak),
+	m_tonemappingParam(tonemappingParam),
+	m_vppTonemappingBrightness(vppTonemappingBrightness),
+	m_vppTonemappingContrast(vppTonemappingContrast),
+	m_h264Crf(h264Crf),
+	m_h265Crf(h265Crf),
+	m_encoderPreset(encoderPreset),
+	m_deinterlaceDoubleRate(deinterlaceDoubleRate),
+	m_deinterlaceMethod(deinterlaceMethod),
+	m_enableDecodingColorDepth10Hevc(enableDecodingColorDepth10Hevc),
+	m_enableDecodingColorDepth10Vp9(enableDecodingColorDepth10Vp9),
+	m_enableDecodingColorDepth10HevcRext(enableDecodingColorDepth10HevcRext),
+	m_enableDecodingColorDepth12HevcRext(enableDecodingColorDepth12HevcRext),
+	m_enableEnhancedNvdecDecoder(enableEnhancedNvdecDecoder),
+	m_preferSystemNativeHwDecoder(preferSystemNativeHwDecoder),
+	m_enableIntelLowPowerH264HwEncoder(enableIntelLowPowerH264HwEncoder),
+	m_enableIntelLowPowerHevcHwEncoder(enableIntelLowPowerHevcHwEncoder),
+	m_enableHardwareEncoding(enableHardwareEncoding),
+	m_allowHevcEncoding(allowHevcEncoding),
+	m_allowAv1Encoding(allowAv1Encoding),
+	m_enableSubtitleExtraction(enableSubtitleExtraction) { }
+
+
+
+EncodingOptions::EncodingOptions(const EncodingOptions &other) :
+
+	m_encodingThreadCount(other.m_encodingThreadCount),
+	m_transcodingTempPath(other.m_transcodingTempPath),
+	m_fallbackFontPath(other.m_fallbackFontPath),
+	m_enableFallbackFont(other.m_enableFallbackFont),
+	m_enableAudioVbr(other.m_enableAudioVbr),
+	m_downMixAudioBoost(other.m_downMixAudioBoost),
+	m_downMixStereoAlgorithm(other.m_downMixStereoAlgorithm),
+	m_maxMuxingQueueSize(other.m_maxMuxingQueueSize),
+	m_enableThrottling(other.m_enableThrottling),
+	m_throttleDelaySeconds(other.m_throttleDelaySeconds),
+	m_enableSegmentDeletion(other.m_enableSegmentDeletion),
+	m_segmentKeepSeconds(other.m_segmentKeepSeconds),
+	m_hardwareAccelerationType(other.m_hardwareAccelerationType),
+	m_encoderAppPath(other.m_encoderAppPath),
+	m_encoderAppPathDisplay(other.m_encoderAppPathDisplay),
+	m_vaapiDevice(other.m_vaapiDevice),
+	m_qsvDevice(other.m_qsvDevice),
+	m_enableTonemapping(other.m_enableTonemapping),
+	m_enableVppTonemapping(other.m_enableVppTonemapping),
+	m_enableVideoToolboxTonemapping(other.m_enableVideoToolboxTonemapping),
+	m_tonemappingAlgorithm(other.m_tonemappingAlgorithm),
+	m_tonemappingMode(other.m_tonemappingMode),
+	m_tonemappingRange(other.m_tonemappingRange),
+	m_tonemappingDesat(other.m_tonemappingDesat),
+	m_tonemappingPeak(other.m_tonemappingPeak),
+	m_tonemappingParam(other.m_tonemappingParam),
+	m_vppTonemappingBrightness(other.m_vppTonemappingBrightness),
+	m_vppTonemappingContrast(other.m_vppTonemappingContrast),
+	m_h264Crf(other.m_h264Crf),
+	m_h265Crf(other.m_h265Crf),
+	m_encoderPreset(other.m_encoderPreset),
+	m_deinterlaceDoubleRate(other.m_deinterlaceDoubleRate),
+	m_deinterlaceMethod(other.m_deinterlaceMethod),
+	m_enableDecodingColorDepth10Hevc(other.m_enableDecodingColorDepth10Hevc),
+	m_enableDecodingColorDepth10Vp9(other.m_enableDecodingColorDepth10Vp9),
+	m_enableDecodingColorDepth10HevcRext(other.m_enableDecodingColorDepth10HevcRext),
+	m_enableDecodingColorDepth12HevcRext(other.m_enableDecodingColorDepth12HevcRext),
+	m_enableEnhancedNvdecDecoder(other.m_enableEnhancedNvdecDecoder),
+	m_preferSystemNativeHwDecoder(other.m_preferSystemNativeHwDecoder),
+	m_enableIntelLowPowerH264HwEncoder(other.m_enableIntelLowPowerH264HwEncoder),
+	m_enableIntelLowPowerHevcHwEncoder(other.m_enableIntelLowPowerHevcHwEncoder),
+	m_enableHardwareEncoding(other.m_enableHardwareEncoding),
+	m_allowHevcEncoding(other.m_allowHevcEncoding),
+	m_allowAv1Encoding(other.m_allowAv1Encoding),
+	m_enableSubtitleExtraction(other.m_enableSubtitleExtraction),
+	m_hardwareDecodingCodecs(other.m_hardwareDecodingCodecs),
+	m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions(other.m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions){}
+
+
+void EncodingOptions::replaceData(EncodingOptions &other) {
+	m_encodingThreadCount = other.m_encodingThreadCount;
+	m_transcodingTempPath = other.m_transcodingTempPath;
+	m_fallbackFontPath = other.m_fallbackFontPath;
+	m_enableFallbackFont = other.m_enableFallbackFont;
+	m_enableAudioVbr = other.m_enableAudioVbr;
+	m_downMixAudioBoost = other.m_downMixAudioBoost;
+	m_downMixStereoAlgorithm = other.m_downMixStereoAlgorithm;
+	m_maxMuxingQueueSize = other.m_maxMuxingQueueSize;
+	m_enableThrottling = other.m_enableThrottling;
+	m_throttleDelaySeconds = other.m_throttleDelaySeconds;
+	m_enableSegmentDeletion = other.m_enableSegmentDeletion;
+	m_segmentKeepSeconds = other.m_segmentKeepSeconds;
+	m_hardwareAccelerationType = other.m_hardwareAccelerationType;
+	m_encoderAppPath = other.m_encoderAppPath;
+	m_encoderAppPathDisplay = other.m_encoderAppPathDisplay;
+	m_vaapiDevice = other.m_vaapiDevice;
+	m_qsvDevice = other.m_qsvDevice;
+	m_enableTonemapping = other.m_enableTonemapping;
+	m_enableVppTonemapping = other.m_enableVppTonemapping;
+	m_enableVideoToolboxTonemapping = other.m_enableVideoToolboxTonemapping;
+	m_tonemappingAlgorithm = other.m_tonemappingAlgorithm;
+	m_tonemappingMode = other.m_tonemappingMode;
+	m_tonemappingRange = other.m_tonemappingRange;
+	m_tonemappingDesat = other.m_tonemappingDesat;
+	m_tonemappingPeak = other.m_tonemappingPeak;
+	m_tonemappingParam = other.m_tonemappingParam;
+	m_vppTonemappingBrightness = other.m_vppTonemappingBrightness;
+	m_vppTonemappingContrast = other.m_vppTonemappingContrast;
+	m_h264Crf = other.m_h264Crf;
+	m_h265Crf = other.m_h265Crf;
+	m_encoderPreset = other.m_encoderPreset;
+	m_deinterlaceDoubleRate = other.m_deinterlaceDoubleRate;
+	m_deinterlaceMethod = other.m_deinterlaceMethod;
+	m_enableDecodingColorDepth10Hevc = other.m_enableDecodingColorDepth10Hevc;
+	m_enableDecodingColorDepth10Vp9 = other.m_enableDecodingColorDepth10Vp9;
+	m_enableDecodingColorDepth10HevcRext = other.m_enableDecodingColorDepth10HevcRext;
+	m_enableDecodingColorDepth12HevcRext = other.m_enableDecodingColorDepth12HevcRext;
+	m_enableEnhancedNvdecDecoder = other.m_enableEnhancedNvdecDecoder;
+	m_preferSystemNativeHwDecoder = other.m_preferSystemNativeHwDecoder;
+	m_enableIntelLowPowerH264HwEncoder = other.m_enableIntelLowPowerH264HwEncoder;
+	m_enableIntelLowPowerHevcHwEncoder = other.m_enableIntelLowPowerHevcHwEncoder;
+	m_enableHardwareEncoding = other.m_enableHardwareEncoding;
+	m_allowHevcEncoding = other.m_allowHevcEncoding;
+	m_allowAv1Encoding = other.m_allowAv1Encoding;
+	m_enableSubtitleExtraction = other.m_enableSubtitleExtraction;
+	m_hardwareDecodingCodecs = other.m_hardwareDecodingCodecs;
+	m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions = other.m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions;
+}
+
+EncodingOptions EncodingOptions::fromJson(QJsonObject source) {
+	EncodingOptions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void EncodingOptions::setFromJson(QJsonObject source) {
+	m_encodingThreadCount = Jellyfin::Support::fromJsonValue<qint32>(source["EncodingThreadCount"]);
+	m_transcodingTempPath = Jellyfin::Support::fromJsonValue<QString>(source["TranscodingTempPath"]);
+	m_fallbackFontPath = Jellyfin::Support::fromJsonValue<QString>(source["FallbackFontPath"]);
+	m_enableFallbackFont = Jellyfin::Support::fromJsonValue<bool>(source["EnableFallbackFont"]);
+	m_enableAudioVbr = Jellyfin::Support::fromJsonValue<bool>(source["EnableAudioVbr"]);
+	m_downMixAudioBoost = Jellyfin::Support::fromJsonValue<double>(source["DownMixAudioBoost"]);
+	m_downMixStereoAlgorithm = Jellyfin::Support::fromJsonValue<DownMixStereoAlgorithms>(source["DownMixStereoAlgorithm"]);
+	m_maxMuxingQueueSize = Jellyfin::Support::fromJsonValue<qint32>(source["MaxMuxingQueueSize"]);
+	m_enableThrottling = Jellyfin::Support::fromJsonValue<bool>(source["EnableThrottling"]);
+	m_throttleDelaySeconds = Jellyfin::Support::fromJsonValue<qint32>(source["ThrottleDelaySeconds"]);
+	m_enableSegmentDeletion = Jellyfin::Support::fromJsonValue<bool>(source["EnableSegmentDeletion"]);
+	m_segmentKeepSeconds = Jellyfin::Support::fromJsonValue<qint32>(source["SegmentKeepSeconds"]);
+	m_hardwareAccelerationType = Jellyfin::Support::fromJsonValue<HardwareAccelerationType>(source["HardwareAccelerationType"]);
+	m_encoderAppPath = Jellyfin::Support::fromJsonValue<QString>(source["EncoderAppPath"]);
+	m_encoderAppPathDisplay = Jellyfin::Support::fromJsonValue<QString>(source["EncoderAppPathDisplay"]);
+	m_vaapiDevice = Jellyfin::Support::fromJsonValue<QString>(source["VaapiDevice"]);
+	m_qsvDevice = Jellyfin::Support::fromJsonValue<QString>(source["QsvDevice"]);
+	m_enableTonemapping = Jellyfin::Support::fromJsonValue<bool>(source["EnableTonemapping"]);
+	m_enableVppTonemapping = Jellyfin::Support::fromJsonValue<bool>(source["EnableVppTonemapping"]);
+	m_enableVideoToolboxTonemapping = Jellyfin::Support::fromJsonValue<bool>(source["EnableVideoToolboxTonemapping"]);
+	m_tonemappingAlgorithm = Jellyfin::Support::fromJsonValue<TonemappingAlgorithm>(source["TonemappingAlgorithm"]);
+	m_tonemappingMode = Jellyfin::Support::fromJsonValue<TonemappingMode>(source["TonemappingMode"]);
+	m_tonemappingRange = Jellyfin::Support::fromJsonValue<TonemappingRange>(source["TonemappingRange"]);
+	m_tonemappingDesat = Jellyfin::Support::fromJsonValue<double>(source["TonemappingDesat"]);
+	m_tonemappingPeak = Jellyfin::Support::fromJsonValue<double>(source["TonemappingPeak"]);
+	m_tonemappingParam = Jellyfin::Support::fromJsonValue<double>(source["TonemappingParam"]);
+	m_vppTonemappingBrightness = Jellyfin::Support::fromJsonValue<double>(source["VppTonemappingBrightness"]);
+	m_vppTonemappingContrast = Jellyfin::Support::fromJsonValue<double>(source["VppTonemappingContrast"]);
+	m_h264Crf = Jellyfin::Support::fromJsonValue<qint32>(source["H264Crf"]);
+	m_h265Crf = Jellyfin::Support::fromJsonValue<qint32>(source["H265Crf"]);
+	m_encoderPreset = Jellyfin::Support::fromJsonValue<EncoderPreset>(source["EncoderPreset"]);
+	m_deinterlaceDoubleRate = Jellyfin::Support::fromJsonValue<bool>(source["DeinterlaceDoubleRate"]);
+	m_deinterlaceMethod = Jellyfin::Support::fromJsonValue<DeinterlaceMethod>(source["DeinterlaceMethod"]);
+	m_enableDecodingColorDepth10Hevc = Jellyfin::Support::fromJsonValue<bool>(source["EnableDecodingColorDepth10Hevc"]);
+	m_enableDecodingColorDepth10Vp9 = Jellyfin::Support::fromJsonValue<bool>(source["EnableDecodingColorDepth10Vp9"]);
+	m_enableDecodingColorDepth10HevcRext = Jellyfin::Support::fromJsonValue<bool>(source["EnableDecodingColorDepth10HevcRext"]);
+	m_enableDecodingColorDepth12HevcRext = Jellyfin::Support::fromJsonValue<bool>(source["EnableDecodingColorDepth12HevcRext"]);
+	m_enableEnhancedNvdecDecoder = Jellyfin::Support::fromJsonValue<bool>(source["EnableEnhancedNvdecDecoder"]);
+	m_preferSystemNativeHwDecoder = Jellyfin::Support::fromJsonValue<bool>(source["PreferSystemNativeHwDecoder"]);
+	m_enableIntelLowPowerH264HwEncoder = Jellyfin::Support::fromJsonValue<bool>(source["EnableIntelLowPowerH264HwEncoder"]);
+	m_enableIntelLowPowerHevcHwEncoder = Jellyfin::Support::fromJsonValue<bool>(source["EnableIntelLowPowerHevcHwEncoder"]);
+	m_enableHardwareEncoding = Jellyfin::Support::fromJsonValue<bool>(source["EnableHardwareEncoding"]);
+	m_allowHevcEncoding = Jellyfin::Support::fromJsonValue<bool>(source["AllowHevcEncoding"]);
+	m_allowAv1Encoding = Jellyfin::Support::fromJsonValue<bool>(source["AllowAv1Encoding"]);
+	m_enableSubtitleExtraction = Jellyfin::Support::fromJsonValue<bool>(source["EnableSubtitleExtraction"]);
+	m_hardwareDecodingCodecs = Jellyfin::Support::fromJsonValue<QStringList>(source["HardwareDecodingCodecs"]);
+	m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions = Jellyfin::Support::fromJsonValue<QStringList>(source["AllowOnDemandMetadataBasedKeyframeExtractionForExtensions"]);
+
+}
+	
+QJsonObject EncodingOptions::toJson() const {
+	QJsonObject result;
+	
+	result["EncodingThreadCount"] = Jellyfin::Support::toJsonValue<qint32>(m_encodingThreadCount);		
+	
+	if (!(m_transcodingTempPath.isNull())) {
+		result["TranscodingTempPath"] = Jellyfin::Support::toJsonValue<QString>(m_transcodingTempPath);
+	}
+			
+	
+	if (!(m_fallbackFontPath.isNull())) {
+		result["FallbackFontPath"] = Jellyfin::Support::toJsonValue<QString>(m_fallbackFontPath);
+	}
+			
+	result["EnableFallbackFont"] = Jellyfin::Support::toJsonValue<bool>(m_enableFallbackFont);		
+	result["EnableAudioVbr"] = Jellyfin::Support::toJsonValue<bool>(m_enableAudioVbr);		
+	result["DownMixAudioBoost"] = Jellyfin::Support::toJsonValue<double>(m_downMixAudioBoost);		
+	result["DownMixStereoAlgorithm"] = Jellyfin::Support::toJsonValue<DownMixStereoAlgorithms>(m_downMixStereoAlgorithm);		
+	result["MaxMuxingQueueSize"] = Jellyfin::Support::toJsonValue<qint32>(m_maxMuxingQueueSize);		
+	result["EnableThrottling"] = Jellyfin::Support::toJsonValue<bool>(m_enableThrottling);		
+	result["ThrottleDelaySeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_throttleDelaySeconds);		
+	result["EnableSegmentDeletion"] = Jellyfin::Support::toJsonValue<bool>(m_enableSegmentDeletion);		
+	result["SegmentKeepSeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_segmentKeepSeconds);		
+	result["HardwareAccelerationType"] = Jellyfin::Support::toJsonValue<HardwareAccelerationType>(m_hardwareAccelerationType);		
+	
+	if (!(m_encoderAppPath.isNull())) {
+		result["EncoderAppPath"] = Jellyfin::Support::toJsonValue<QString>(m_encoderAppPath);
+	}
+			
+	
+	if (!(m_encoderAppPathDisplay.isNull())) {
+		result["EncoderAppPathDisplay"] = Jellyfin::Support::toJsonValue<QString>(m_encoderAppPathDisplay);
+	}
+			
+	
+	if (!(m_vaapiDevice.isNull())) {
+		result["VaapiDevice"] = Jellyfin::Support::toJsonValue<QString>(m_vaapiDevice);
+	}
+			
+	
+	if (!(m_qsvDevice.isNull())) {
+		result["QsvDevice"] = Jellyfin::Support::toJsonValue<QString>(m_qsvDevice);
+	}
+			
+	result["EnableTonemapping"] = Jellyfin::Support::toJsonValue<bool>(m_enableTonemapping);		
+	result["EnableVppTonemapping"] = Jellyfin::Support::toJsonValue<bool>(m_enableVppTonemapping);		
+	result["EnableVideoToolboxTonemapping"] = Jellyfin::Support::toJsonValue<bool>(m_enableVideoToolboxTonemapping);		
+	result["TonemappingAlgorithm"] = Jellyfin::Support::toJsonValue<TonemappingAlgorithm>(m_tonemappingAlgorithm);		
+	result["TonemappingMode"] = Jellyfin::Support::toJsonValue<TonemappingMode>(m_tonemappingMode);		
+	result["TonemappingRange"] = Jellyfin::Support::toJsonValue<TonemappingRange>(m_tonemappingRange);		
+	result["TonemappingDesat"] = Jellyfin::Support::toJsonValue<double>(m_tonemappingDesat);		
+	result["TonemappingPeak"] = Jellyfin::Support::toJsonValue<double>(m_tonemappingPeak);		
+	result["TonemappingParam"] = Jellyfin::Support::toJsonValue<double>(m_tonemappingParam);		
+	result["VppTonemappingBrightness"] = Jellyfin::Support::toJsonValue<double>(m_vppTonemappingBrightness);		
+	result["VppTonemappingContrast"] = Jellyfin::Support::toJsonValue<double>(m_vppTonemappingContrast);		
+	result["H264Crf"] = Jellyfin::Support::toJsonValue<qint32>(m_h264Crf);		
+	result["H265Crf"] = Jellyfin::Support::toJsonValue<qint32>(m_h265Crf);		
+	result["EncoderPreset"] = Jellyfin::Support::toJsonValue<EncoderPreset>(m_encoderPreset);		
+	result["DeinterlaceDoubleRate"] = Jellyfin::Support::toJsonValue<bool>(m_deinterlaceDoubleRate);		
+	result["DeinterlaceMethod"] = Jellyfin::Support::toJsonValue<DeinterlaceMethod>(m_deinterlaceMethod);		
+	result["EnableDecodingColorDepth10Hevc"] = Jellyfin::Support::toJsonValue<bool>(m_enableDecodingColorDepth10Hevc);		
+	result["EnableDecodingColorDepth10Vp9"] = Jellyfin::Support::toJsonValue<bool>(m_enableDecodingColorDepth10Vp9);		
+	result["EnableDecodingColorDepth10HevcRext"] = Jellyfin::Support::toJsonValue<bool>(m_enableDecodingColorDepth10HevcRext);		
+	result["EnableDecodingColorDepth12HevcRext"] = Jellyfin::Support::toJsonValue<bool>(m_enableDecodingColorDepth12HevcRext);		
+	result["EnableEnhancedNvdecDecoder"] = Jellyfin::Support::toJsonValue<bool>(m_enableEnhancedNvdecDecoder);		
+	result["PreferSystemNativeHwDecoder"] = Jellyfin::Support::toJsonValue<bool>(m_preferSystemNativeHwDecoder);		
+	result["EnableIntelLowPowerH264HwEncoder"] = Jellyfin::Support::toJsonValue<bool>(m_enableIntelLowPowerH264HwEncoder);		
+	result["EnableIntelLowPowerHevcHwEncoder"] = Jellyfin::Support::toJsonValue<bool>(m_enableIntelLowPowerHevcHwEncoder);		
+	result["EnableHardwareEncoding"] = Jellyfin::Support::toJsonValue<bool>(m_enableHardwareEncoding);		
+	result["AllowHevcEncoding"] = Jellyfin::Support::toJsonValue<bool>(m_allowHevcEncoding);		
+	result["AllowAv1Encoding"] = Jellyfin::Support::toJsonValue<bool>(m_allowAv1Encoding);		
+	result["EnableSubtitleExtraction"] = Jellyfin::Support::toJsonValue<bool>(m_enableSubtitleExtraction);		
+	
+	if (!(m_hardwareDecodingCodecs.size() == 0)) {
+		result["HardwareDecodingCodecs"] = Jellyfin::Support::toJsonValue<QStringList>(m_hardwareDecodingCodecs);
+	}
+			
+	
+	if (!(m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions.size() == 0)) {
+		result["AllowOnDemandMetadataBasedKeyframeExtractionForExtensions"] = Jellyfin::Support::toJsonValue<QStringList>(m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions);
+	}
+		
+	return result;
+}
+
+qint32 EncodingOptions::encodingThreadCount() const { return m_encodingThreadCount; }
+
+void EncodingOptions::setEncodingThreadCount(qint32 newEncodingThreadCount) {
+	m_encodingThreadCount = newEncodingThreadCount;
+}
+
+QString EncodingOptions::transcodingTempPath() const { return m_transcodingTempPath; }
+
+void EncodingOptions::setTranscodingTempPath(QString newTranscodingTempPath) {
+	m_transcodingTempPath = newTranscodingTempPath;
+}
+bool EncodingOptions::transcodingTempPathNull() const {
+	return m_transcodingTempPath.isNull();
+}
+
+void EncodingOptions::setTranscodingTempPathNull() {
+	m_transcodingTempPath.clear();
+
+}
+QString EncodingOptions::fallbackFontPath() const { return m_fallbackFontPath; }
+
+void EncodingOptions::setFallbackFontPath(QString newFallbackFontPath) {
+	m_fallbackFontPath = newFallbackFontPath;
+}
+bool EncodingOptions::fallbackFontPathNull() const {
+	return m_fallbackFontPath.isNull();
+}
+
+void EncodingOptions::setFallbackFontPathNull() {
+	m_fallbackFontPath.clear();
+
+}
+bool EncodingOptions::enableFallbackFont() const { return m_enableFallbackFont; }
+
+void EncodingOptions::setEnableFallbackFont(bool newEnableFallbackFont) {
+	m_enableFallbackFont = newEnableFallbackFont;
+}
+
+bool EncodingOptions::enableAudioVbr() const { return m_enableAudioVbr; }
+
+void EncodingOptions::setEnableAudioVbr(bool newEnableAudioVbr) {
+	m_enableAudioVbr = newEnableAudioVbr;
+}
+
+double EncodingOptions::downMixAudioBoost() const { return m_downMixAudioBoost; }
+
+void EncodingOptions::setDownMixAudioBoost(double newDownMixAudioBoost) {
+	m_downMixAudioBoost = newDownMixAudioBoost;
+}
+
+DownMixStereoAlgorithms EncodingOptions::downMixStereoAlgorithm() const { return m_downMixStereoAlgorithm; }
+
+void EncodingOptions::setDownMixStereoAlgorithm(DownMixStereoAlgorithms newDownMixStereoAlgorithm) {
+	m_downMixStereoAlgorithm = newDownMixStereoAlgorithm;
+}
+
+qint32 EncodingOptions::maxMuxingQueueSize() const { return m_maxMuxingQueueSize; }
+
+void EncodingOptions::setMaxMuxingQueueSize(qint32 newMaxMuxingQueueSize) {
+	m_maxMuxingQueueSize = newMaxMuxingQueueSize;
+}
+
+bool EncodingOptions::enableThrottling() const { return m_enableThrottling; }
+
+void EncodingOptions::setEnableThrottling(bool newEnableThrottling) {
+	m_enableThrottling = newEnableThrottling;
+}
+
+qint32 EncodingOptions::throttleDelaySeconds() const { return m_throttleDelaySeconds; }
+
+void EncodingOptions::setThrottleDelaySeconds(qint32 newThrottleDelaySeconds) {
+	m_throttleDelaySeconds = newThrottleDelaySeconds;
+}
+
+bool EncodingOptions::enableSegmentDeletion() const { return m_enableSegmentDeletion; }
+
+void EncodingOptions::setEnableSegmentDeletion(bool newEnableSegmentDeletion) {
+	m_enableSegmentDeletion = newEnableSegmentDeletion;
+}
+
+qint32 EncodingOptions::segmentKeepSeconds() const { return m_segmentKeepSeconds; }
+
+void EncodingOptions::setSegmentKeepSeconds(qint32 newSegmentKeepSeconds) {
+	m_segmentKeepSeconds = newSegmentKeepSeconds;
+}
+
+HardwareAccelerationType EncodingOptions::hardwareAccelerationType() const { return m_hardwareAccelerationType; }
+
+void EncodingOptions::setHardwareAccelerationType(HardwareAccelerationType newHardwareAccelerationType) {
+	m_hardwareAccelerationType = newHardwareAccelerationType;
+}
+
+QString EncodingOptions::encoderAppPath() const { return m_encoderAppPath; }
+
+void EncodingOptions::setEncoderAppPath(QString newEncoderAppPath) {
+	m_encoderAppPath = newEncoderAppPath;
+}
+bool EncodingOptions::encoderAppPathNull() const {
+	return m_encoderAppPath.isNull();
+}
+
+void EncodingOptions::setEncoderAppPathNull() {
+	m_encoderAppPath.clear();
+
+}
+QString EncodingOptions::encoderAppPathDisplay() const { return m_encoderAppPathDisplay; }
+
+void EncodingOptions::setEncoderAppPathDisplay(QString newEncoderAppPathDisplay) {
+	m_encoderAppPathDisplay = newEncoderAppPathDisplay;
+}
+bool EncodingOptions::encoderAppPathDisplayNull() const {
+	return m_encoderAppPathDisplay.isNull();
+}
+
+void EncodingOptions::setEncoderAppPathDisplayNull() {
+	m_encoderAppPathDisplay.clear();
+
+}
+QString EncodingOptions::vaapiDevice() const { return m_vaapiDevice; }
+
+void EncodingOptions::setVaapiDevice(QString newVaapiDevice) {
+	m_vaapiDevice = newVaapiDevice;
+}
+bool EncodingOptions::vaapiDeviceNull() const {
+	return m_vaapiDevice.isNull();
+}
+
+void EncodingOptions::setVaapiDeviceNull() {
+	m_vaapiDevice.clear();
+
+}
+QString EncodingOptions::qsvDevice() const { return m_qsvDevice; }
+
+void EncodingOptions::setQsvDevice(QString newQsvDevice) {
+	m_qsvDevice = newQsvDevice;
+}
+bool EncodingOptions::qsvDeviceNull() const {
+	return m_qsvDevice.isNull();
+}
+
+void EncodingOptions::setQsvDeviceNull() {
+	m_qsvDevice.clear();
+
+}
+bool EncodingOptions::enableTonemapping() const { return m_enableTonemapping; }
+
+void EncodingOptions::setEnableTonemapping(bool newEnableTonemapping) {
+	m_enableTonemapping = newEnableTonemapping;
+}
+
+bool EncodingOptions::enableVppTonemapping() const { return m_enableVppTonemapping; }
+
+void EncodingOptions::setEnableVppTonemapping(bool newEnableVppTonemapping) {
+	m_enableVppTonemapping = newEnableVppTonemapping;
+}
+
+bool EncodingOptions::enableVideoToolboxTonemapping() const { return m_enableVideoToolboxTonemapping; }
+
+void EncodingOptions::setEnableVideoToolboxTonemapping(bool newEnableVideoToolboxTonemapping) {
+	m_enableVideoToolboxTonemapping = newEnableVideoToolboxTonemapping;
+}
+
+TonemappingAlgorithm EncodingOptions::tonemappingAlgorithm() const { return m_tonemappingAlgorithm; }
+
+void EncodingOptions::setTonemappingAlgorithm(TonemappingAlgorithm newTonemappingAlgorithm) {
+	m_tonemappingAlgorithm = newTonemappingAlgorithm;
+}
+
+TonemappingMode EncodingOptions::tonemappingMode() const { return m_tonemappingMode; }
+
+void EncodingOptions::setTonemappingMode(TonemappingMode newTonemappingMode) {
+	m_tonemappingMode = newTonemappingMode;
+}
+
+TonemappingRange EncodingOptions::tonemappingRange() const { return m_tonemappingRange; }
+
+void EncodingOptions::setTonemappingRange(TonemappingRange newTonemappingRange) {
+	m_tonemappingRange = newTonemappingRange;
+}
+
+double EncodingOptions::tonemappingDesat() const { return m_tonemappingDesat; }
+
+void EncodingOptions::setTonemappingDesat(double newTonemappingDesat) {
+	m_tonemappingDesat = newTonemappingDesat;
+}
+
+double EncodingOptions::tonemappingPeak() const { return m_tonemappingPeak; }
+
+void EncodingOptions::setTonemappingPeak(double newTonemappingPeak) {
+	m_tonemappingPeak = newTonemappingPeak;
+}
+
+double EncodingOptions::tonemappingParam() const { return m_tonemappingParam; }
+
+void EncodingOptions::setTonemappingParam(double newTonemappingParam) {
+	m_tonemappingParam = newTonemappingParam;
+}
+
+double EncodingOptions::vppTonemappingBrightness() const { return m_vppTonemappingBrightness; }
+
+void EncodingOptions::setVppTonemappingBrightness(double newVppTonemappingBrightness) {
+	m_vppTonemappingBrightness = newVppTonemappingBrightness;
+}
+
+double EncodingOptions::vppTonemappingContrast() const { return m_vppTonemappingContrast; }
+
+void EncodingOptions::setVppTonemappingContrast(double newVppTonemappingContrast) {
+	m_vppTonemappingContrast = newVppTonemappingContrast;
+}
+
+qint32 EncodingOptions::h264Crf() const { return m_h264Crf; }
+
+void EncodingOptions::setH264Crf(qint32 newH264Crf) {
+	m_h264Crf = newH264Crf;
+}
+
+qint32 EncodingOptions::h265Crf() const { return m_h265Crf; }
+
+void EncodingOptions::setH265Crf(qint32 newH265Crf) {
+	m_h265Crf = newH265Crf;
+}
+
+EncoderPreset EncodingOptions::encoderPreset() const { return m_encoderPreset; }
+
+void EncodingOptions::setEncoderPreset(EncoderPreset newEncoderPreset) {
+	m_encoderPreset = newEncoderPreset;
+}
+
+bool EncodingOptions::deinterlaceDoubleRate() const { return m_deinterlaceDoubleRate; }
+
+void EncodingOptions::setDeinterlaceDoubleRate(bool newDeinterlaceDoubleRate) {
+	m_deinterlaceDoubleRate = newDeinterlaceDoubleRate;
+}
+
+DeinterlaceMethod EncodingOptions::deinterlaceMethod() const { return m_deinterlaceMethod; }
+
+void EncodingOptions::setDeinterlaceMethod(DeinterlaceMethod newDeinterlaceMethod) {
+	m_deinterlaceMethod = newDeinterlaceMethod;
+}
+
+bool EncodingOptions::enableDecodingColorDepth10Hevc() const { return m_enableDecodingColorDepth10Hevc; }
+
+void EncodingOptions::setEnableDecodingColorDepth10Hevc(bool newEnableDecodingColorDepth10Hevc) {
+	m_enableDecodingColorDepth10Hevc = newEnableDecodingColorDepth10Hevc;
+}
+
+bool EncodingOptions::enableDecodingColorDepth10Vp9() const { return m_enableDecodingColorDepth10Vp9; }
+
+void EncodingOptions::setEnableDecodingColorDepth10Vp9(bool newEnableDecodingColorDepth10Vp9) {
+	m_enableDecodingColorDepth10Vp9 = newEnableDecodingColorDepth10Vp9;
+}
+
+bool EncodingOptions::enableDecodingColorDepth10HevcRext() const { return m_enableDecodingColorDepth10HevcRext; }
+
+void EncodingOptions::setEnableDecodingColorDepth10HevcRext(bool newEnableDecodingColorDepth10HevcRext) {
+	m_enableDecodingColorDepth10HevcRext = newEnableDecodingColorDepth10HevcRext;
+}
+
+bool EncodingOptions::enableDecodingColorDepth12HevcRext() const { return m_enableDecodingColorDepth12HevcRext; }
+
+void EncodingOptions::setEnableDecodingColorDepth12HevcRext(bool newEnableDecodingColorDepth12HevcRext) {
+	m_enableDecodingColorDepth12HevcRext = newEnableDecodingColorDepth12HevcRext;
+}
+
+bool EncodingOptions::enableEnhancedNvdecDecoder() const { return m_enableEnhancedNvdecDecoder; }
+
+void EncodingOptions::setEnableEnhancedNvdecDecoder(bool newEnableEnhancedNvdecDecoder) {
+	m_enableEnhancedNvdecDecoder = newEnableEnhancedNvdecDecoder;
+}
+
+bool EncodingOptions::preferSystemNativeHwDecoder() const { return m_preferSystemNativeHwDecoder; }
+
+void EncodingOptions::setPreferSystemNativeHwDecoder(bool newPreferSystemNativeHwDecoder) {
+	m_preferSystemNativeHwDecoder = newPreferSystemNativeHwDecoder;
+}
+
+bool EncodingOptions::enableIntelLowPowerH264HwEncoder() const { return m_enableIntelLowPowerH264HwEncoder; }
+
+void EncodingOptions::setEnableIntelLowPowerH264HwEncoder(bool newEnableIntelLowPowerH264HwEncoder) {
+	m_enableIntelLowPowerH264HwEncoder = newEnableIntelLowPowerH264HwEncoder;
+}
+
+bool EncodingOptions::enableIntelLowPowerHevcHwEncoder() const { return m_enableIntelLowPowerHevcHwEncoder; }
+
+void EncodingOptions::setEnableIntelLowPowerHevcHwEncoder(bool newEnableIntelLowPowerHevcHwEncoder) {
+	m_enableIntelLowPowerHevcHwEncoder = newEnableIntelLowPowerHevcHwEncoder;
+}
+
+bool EncodingOptions::enableHardwareEncoding() const { return m_enableHardwareEncoding; }
+
+void EncodingOptions::setEnableHardwareEncoding(bool newEnableHardwareEncoding) {
+	m_enableHardwareEncoding = newEnableHardwareEncoding;
+}
+
+bool EncodingOptions::allowHevcEncoding() const { return m_allowHevcEncoding; }
+
+void EncodingOptions::setAllowHevcEncoding(bool newAllowHevcEncoding) {
+	m_allowHevcEncoding = newAllowHevcEncoding;
+}
+
+bool EncodingOptions::allowAv1Encoding() const { return m_allowAv1Encoding; }
+
+void EncodingOptions::setAllowAv1Encoding(bool newAllowAv1Encoding) {
+	m_allowAv1Encoding = newAllowAv1Encoding;
+}
+
+bool EncodingOptions::enableSubtitleExtraction() const { return m_enableSubtitleExtraction; }
+
+void EncodingOptions::setEnableSubtitleExtraction(bool newEnableSubtitleExtraction) {
+	m_enableSubtitleExtraction = newEnableSubtitleExtraction;
+}
+
+QStringList EncodingOptions::hardwareDecodingCodecs() const { return m_hardwareDecodingCodecs; }
+
+void EncodingOptions::setHardwareDecodingCodecs(QStringList newHardwareDecodingCodecs) {
+	m_hardwareDecodingCodecs = newHardwareDecodingCodecs;
+}
+bool EncodingOptions::hardwareDecodingCodecsNull() const {
+	return m_hardwareDecodingCodecs.size() == 0;
+}
+
+void EncodingOptions::setHardwareDecodingCodecsNull() {
+	m_hardwareDecodingCodecs.clear();
+
+}
+QStringList EncodingOptions::allowOnDemandMetadataBasedKeyframeExtractionForExtensions() const { return m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions; }
+
+void EncodingOptions::setAllowOnDemandMetadataBasedKeyframeExtractionForExtensions(QStringList newAllowOnDemandMetadataBasedKeyframeExtractionForExtensions) {
+	m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions = newAllowOnDemandMetadataBasedKeyframeExtractionForExtensions;
+}
+bool EncodingOptions::allowOnDemandMetadataBasedKeyframeExtractionForExtensionsNull() const {
+	return m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions.size() == 0;
+}
+
+void EncodingOptions::setAllowOnDemandMetadataBasedKeyframeExtractionForExtensionsNull() {
+	m_allowOnDemandMetadataBasedKeyframeExtractionForExtensions.clear();
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using EncodingOptions = Jellyfin::DTO::EncodingOptions;
+
+template <>
+EncodingOptions fromJsonValue(const QJsonValue &source, convertType<EncodingOptions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return EncodingOptions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const EncodingOptions &source, convertType<EncodingOptions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/externalidinfo.cpp b/core/src/dto/externalidinfo.cpp
index e46c7e3..33e345b 100644
--- a/core/src/dto/externalidinfo.cpp
+++ b/core/src/dto/externalidinfo.cpp
@@ -34,8 +34,12 @@ namespace DTO {
 
 ExternalIdInfo::ExternalIdInfo() {}
 ExternalIdInfo::ExternalIdInfo (
+		QString name, 
+		QString key, 
 		ExternalIdMediaType type 
 		) :
+	m_name(name),
+	m_key(key),
 	m_type(type) { }
 
 
@@ -73,16 +77,8 @@ void ExternalIdInfo::setFromJson(QJsonObject source) {
 QJsonObject ExternalIdInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_key.isNull())) {
-		result["Key"] = Jellyfin::Support::toJsonValue<QString>(m_key);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["Key"] = Jellyfin::Support::toJsonValue<QString>(m_key);		
 	result["Type"] = Jellyfin::Support::toJsonValue<ExternalIdMediaType>(m_type);		
 	
 	if (!(m_urlFormatString.isNull())) {
@@ -97,27 +93,13 @@ QString ExternalIdInfo::name() const { return m_name; }
 void ExternalIdInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool ExternalIdInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void ExternalIdInfo::setNameNull() {
-	m_name.clear();
-
-}
 QString ExternalIdInfo::key() const { return m_key; }
 
 void ExternalIdInfo::setKey(QString newKey) {
 	m_key = newKey;
 }
-bool ExternalIdInfo::keyNull() const {
-	return m_key.isNull();
-}
 
-void ExternalIdInfo::setKeyNull() {
-	m_key.clear();
-
-}
 ExternalIdMediaType ExternalIdInfo::type() const { return m_type; }
 
 void ExternalIdInfo::setType(ExternalIdMediaType newType) {
diff --git a/core/src/dto/externalidmediatype.cpp b/core/src/dto/externalidmediatype.cpp
index 7e42dd4..5eacf60 100644
--- a/core/src/dto/externalidmediatype.cpp
+++ b/core/src/dto/externalidmediatype.cpp
@@ -81,6 +81,9 @@ ExternalIdMediaType fromJsonValue(const QJsonValue &source, convertType<External
 	if (str == QStringLiteral("Track")) {
 		return ExternalIdMediaType::Track;
 	}
+	if (str == QStringLiteral("Book")) {
+		return ExternalIdMediaType::Book;
+	}
 	
 	return ExternalIdMediaType::EnumNotSet;
 }
@@ -112,6 +115,8 @@ QJsonValue toJsonValue(const ExternalIdMediaType &source, convertType<ExternalId
 		return QStringLiteral("Series");
 	case ExternalIdMediaType::Track:
 		return QStringLiteral("Track");
+	case ExternalIdMediaType::Book:
+		return QStringLiteral("Book");
 
 	case ExternalIdMediaType::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/extratype.cpp b/core/src/dto/extratype.cpp
new file mode 100644
index 0000000..66d88f8
--- /dev/null
+++ b/core/src/dto/extratype.cpp
@@ -0,0 +1,123 @@
+/*
+ * 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/dto/extratype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ExtraTypeClass::ExtraTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using ExtraType = Jellyfin::DTO::ExtraType;
+
+template <>
+ExtraType fromJsonValue(const QJsonValue &source, convertType<ExtraType>) {
+	if (!source.isString()) return ExtraType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Unknown")) {
+		return ExtraType::Unknown;
+	}
+	if (str == QStringLiteral("Clip")) {
+		return ExtraType::Clip;
+	}
+	if (str == QStringLiteral("Trailer")) {
+		return ExtraType::Trailer;
+	}
+	if (str == QStringLiteral("BehindTheScenes")) {
+		return ExtraType::BehindTheScenes;
+	}
+	if (str == QStringLiteral("DeletedScene")) {
+		return ExtraType::DeletedScene;
+	}
+	if (str == QStringLiteral("Interview")) {
+		return ExtraType::Interview;
+	}
+	if (str == QStringLiteral("Scene")) {
+		return ExtraType::Scene;
+	}
+	if (str == QStringLiteral("Sample")) {
+		return ExtraType::Sample;
+	}
+	if (str == QStringLiteral("ThemeSong")) {
+		return ExtraType::ThemeSong;
+	}
+	if (str == QStringLiteral("ThemeVideo")) {
+		return ExtraType::ThemeVideo;
+	}
+	if (str == QStringLiteral("Featurette")) {
+		return ExtraType::Featurette;
+	}
+	if (str == QStringLiteral("Short")) {
+		return ExtraType::Short;
+	}
+	
+	return ExtraType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const ExtraType &source, convertType<ExtraType>) {
+	switch(source) {
+	case ExtraType::Unknown:
+		return QStringLiteral("Unknown");
+	case ExtraType::Clip:
+		return QStringLiteral("Clip");
+	case ExtraType::Trailer:
+		return QStringLiteral("Trailer");
+	case ExtraType::BehindTheScenes:
+		return QStringLiteral("BehindTheScenes");
+	case ExtraType::DeletedScene:
+		return QStringLiteral("DeletedScene");
+	case ExtraType::Interview:
+		return QStringLiteral("Interview");
+	case ExtraType::Scene:
+		return QStringLiteral("Scene");
+	case ExtraType::Sample:
+		return QStringLiteral("Sample");
+	case ExtraType::ThemeSong:
+		return QStringLiteral("ThemeSong");
+	case ExtraType::ThemeVideo:
+		return QStringLiteral("ThemeVideo");
+	case ExtraType::Featurette:
+		return QStringLiteral("Featurette");
+	case ExtraType::Short:
+		return QStringLiteral("Short");
+
+	case ExtraType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/filesystementryinfo.cpp b/core/src/dto/filesystementryinfo.cpp
index 614dde2..7eac834 100644
--- a/core/src/dto/filesystementryinfo.cpp
+++ b/core/src/dto/filesystementryinfo.cpp
@@ -34,8 +34,12 @@ namespace DTO {
 
 FileSystemEntryInfo::FileSystemEntryInfo() {}
 FileSystemEntryInfo::FileSystemEntryInfo (
+		QString name, 
+		QString path, 
 		FileSystemEntryType type 
 		) :
+	m_name(name),
+	m_path(path),
 	m_type(type) { }
 
 
@@ -70,16 +74,8 @@ void FileSystemEntryInfo::setFromJson(QJsonObject source) {
 QJsonObject FileSystemEntryInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_path.isNull())) {
-		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);		
 	result["Type"] = Jellyfin::Support::toJsonValue<FileSystemEntryType>(m_type);	
 	return result;
 }
@@ -89,27 +85,13 @@ QString FileSystemEntryInfo::name() const { return m_name; }
 void FileSystemEntryInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool FileSystemEntryInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void FileSystemEntryInfo::setNameNull() {
-	m_name.clear();
-
-}
 QString FileSystemEntryInfo::path() const { return m_path; }
 
 void FileSystemEntryInfo::setPath(QString newPath) {
 	m_path = newPath;
 }
-bool FileSystemEntryInfo::pathNull() const {
-	return m_path.isNull();
-}
 
-void FileSystemEntryInfo::setPathNull() {
-	m_path.clear();
-
-}
 FileSystemEntryType FileSystemEntryInfo::type() const { return m_type; }
 
 void FileSystemEntryInfo::setType(FileSystemEntryType newType) {
diff --git a/core/src/dto/forcekeepalivemessage.cpp b/core/src/dto/forcekeepalivemessage.cpp
new file mode 100644
index 0000000..85301ee
--- /dev/null
+++ b/core/src/dto/forcekeepalivemessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/forcekeepalivemessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ForceKeepAliveMessage::ForceKeepAliveMessage() {}
+ForceKeepAliveMessage::ForceKeepAliveMessage (
+		qint32 data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ForceKeepAliveMessage::ForceKeepAliveMessage(const ForceKeepAliveMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ForceKeepAliveMessage::replaceData(ForceKeepAliveMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ForceKeepAliveMessage ForceKeepAliveMessage::fromJson(QJsonObject source) {
+	ForceKeepAliveMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ForceKeepAliveMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<qint32>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ForceKeepAliveMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<qint32>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+qint32 ForceKeepAliveMessage::data() const { return m_data; }
+
+void ForceKeepAliveMessage::setData(qint32 newData) {
+	m_data = newData;
+}
+
+QString ForceKeepAliveMessage::messageId() const { return m_messageId; }
+
+void ForceKeepAliveMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ForceKeepAliveMessage::messageType() const { return m_messageType; }
+
+void ForceKeepAliveMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ForceKeepAliveMessage = Jellyfin::DTO::ForceKeepAliveMessage;
+
+template <>
+ForceKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<ForceKeepAliveMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ForceKeepAliveMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ForceKeepAliveMessage &source, convertType<ForceKeepAliveMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/deviceoptions.cpp b/core/src/dto/forgotpasswordpindto.cpp
similarity index 57%
rename from core/src/dto/deviceoptions.cpp
rename to core/src/dto/forgotpasswordpindto.cpp
index 4238131..a938032 100644
--- a/core/src/dto/deviceoptions.cpp
+++ b/core/src/dto/forgotpasswordpindto.cpp
@@ -27,73 +27,68 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/deviceoptions.h>
+#include <JellyfinQt/dto/forgotpasswordpindto.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-DeviceOptions::DeviceOptions() {}
-
-DeviceOptions::DeviceOptions(const DeviceOptions &other) :
-
-	m_customName(other.m_customName){}
+ForgotPasswordPinDto::ForgotPasswordPinDto() {}
+ForgotPasswordPinDto::ForgotPasswordPinDto (
+		QString pin 
+		) :
+	m_pin(pin) { }
 
 
-void DeviceOptions::replaceData(DeviceOptions &other) {
-	m_customName = other.m_customName;
+
+ForgotPasswordPinDto::ForgotPasswordPinDto(const ForgotPasswordPinDto &other) :
+
+	m_pin(other.m_pin){}
+
+
+void ForgotPasswordPinDto::replaceData(ForgotPasswordPinDto &other) {
+	m_pin = other.m_pin;
 }
 
-DeviceOptions DeviceOptions::fromJson(QJsonObject source) {
-	DeviceOptions instance;
+ForgotPasswordPinDto ForgotPasswordPinDto::fromJson(QJsonObject source) {
+	ForgotPasswordPinDto instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void DeviceOptions::setFromJson(QJsonObject source) {
-	m_customName = Jellyfin::Support::fromJsonValue<QString>(source["CustomName"]);
+void ForgotPasswordPinDto::setFromJson(QJsonObject source) {
+	m_pin = Jellyfin::Support::fromJsonValue<QString>(source["Pin"]);
 
 }
 	
-QJsonObject DeviceOptions::toJson() const {
+QJsonObject ForgotPasswordPinDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_customName.isNull())) {
-		result["CustomName"] = Jellyfin::Support::toJsonValue<QString>(m_customName);
-	}
-		
+	result["Pin"] = Jellyfin::Support::toJsonValue<QString>(m_pin);	
 	return result;
 }
 
-QString DeviceOptions::customName() const { return m_customName; }
+QString ForgotPasswordPinDto::pin() const { return m_pin; }
 
-void DeviceOptions::setCustomName(QString newCustomName) {
-	m_customName = newCustomName;
-}
-bool DeviceOptions::customNameNull() const {
-	return m_customName.isNull();
+void ForgotPasswordPinDto::setPin(QString newPin) {
+	m_pin = newPin;
 }
 
-void DeviceOptions::setCustomNameNull() {
-	m_customName.clear();
-
-}
 
 } // NS DTO
 
 namespace Support {
 
-using DeviceOptions = Jellyfin::DTO::DeviceOptions;
+using ForgotPasswordPinDto = Jellyfin::DTO::ForgotPasswordPinDto;
 
 template <>
-DeviceOptions fromJsonValue(const QJsonValue &source, convertType<DeviceOptions>) {
+ForgotPasswordPinDto fromJsonValue(const QJsonValue &source, convertType<ForgotPasswordPinDto>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return DeviceOptions::fromJson(source.toObject());
+	return ForgotPasswordPinDto::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const DeviceOptions &source, convertType<DeviceOptions>) {
+QJsonValue toJsonValue(const ForgotPasswordPinDto &source, convertType<ForgotPasswordPinDto>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/generalcommand.cpp b/core/src/dto/generalcommand.cpp
index 7cb2233..9de21ec 100644
--- a/core/src/dto/generalcommand.cpp
+++ b/core/src/dto/generalcommand.cpp
@@ -35,10 +35,12 @@ namespace DTO {
 GeneralCommand::GeneralCommand() {}
 GeneralCommand::GeneralCommand (
 		GeneralCommandType name, 
-		QString controllingUserId 
+		QString controllingUserId, 
+		QJsonObject arguments 
 		) :
 	m_name(name),
-	m_controllingUserId(controllingUserId) { }
+	m_controllingUserId(controllingUserId),
+	m_arguments(arguments) { }
 
 
 
@@ -74,11 +76,7 @@ QJsonObject GeneralCommand::toJson() const {
 	
 	result["Name"] = Jellyfin::Support::toJsonValue<GeneralCommandType>(m_name);		
 	result["ControllingUserId"] = Jellyfin::Support::toJsonValue<QString>(m_controllingUserId);		
-	
-	if (!(m_arguments.isEmpty())) {
-		result["Arguments"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_arguments);
-	}
-		
+	result["Arguments"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_arguments);	
 	return result;
 }
 
@@ -99,14 +97,7 @@ QJsonObject GeneralCommand::arguments() const { return m_arguments; }
 void GeneralCommand::setArguments(QJsonObject newArguments) {
 	m_arguments = newArguments;
 }
-bool GeneralCommand::argumentsNull() const {
-	return m_arguments.isEmpty();
-}
 
-void GeneralCommand::setArgumentsNull() {
-	m_arguments= QJsonObject();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/generalcommandmessage.cpp b/core/src/dto/generalcommandmessage.cpp
new file mode 100644
index 0000000..629aa98
--- /dev/null
+++ b/core/src/dto/generalcommandmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/generalcommandmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+GeneralCommandMessage::GeneralCommandMessage() {}
+GeneralCommandMessage::GeneralCommandMessage (
+		QSharedPointer<GeneralCommand> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+GeneralCommandMessage::GeneralCommandMessage(const GeneralCommandMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void GeneralCommandMessage::replaceData(GeneralCommandMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+GeneralCommandMessage GeneralCommandMessage::fromJson(QJsonObject source) {
+	GeneralCommandMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void GeneralCommandMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<GeneralCommand>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject GeneralCommandMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<GeneralCommand>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<GeneralCommand> GeneralCommandMessage::data() const { return m_data; }
+
+void GeneralCommandMessage::setData(QSharedPointer<GeneralCommand> newData) {
+	m_data = newData;
+}
+
+QString GeneralCommandMessage::messageId() const { return m_messageId; }
+
+void GeneralCommandMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType GeneralCommandMessage::messageType() const { return m_messageType; }
+
+void GeneralCommandMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using GeneralCommandMessage = Jellyfin::DTO::GeneralCommandMessage;
+
+template <>
+GeneralCommandMessage fromJsonValue(const QJsonValue &source, convertType<GeneralCommandMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return GeneralCommandMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const GeneralCommandMessage &source, convertType<GeneralCommandMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/generalcommandtype.cpp b/core/src/dto/generalcommandtype.cpp
index eb8de73..edcd1d7 100644
--- a/core/src/dto/generalcommandtype.cpp
+++ b/core/src/dto/generalcommandtype.cpp
@@ -168,6 +168,12 @@ GeneralCommandType fromJsonValue(const QJsonValue &source, convertType<GeneralCo
 	if (str == QStringLiteral("Play")) {
 		return GeneralCommandType::Play;
 	}
+	if (str == QStringLiteral("SetMaxStreamingBitrate")) {
+		return GeneralCommandType::SetMaxStreamingBitrate;
+	}
+	if (str == QStringLiteral("SetPlaybackOrder")) {
+		return GeneralCommandType::SetPlaybackOrder;
+	}
 	
 	return GeneralCommandType::EnumNotSet;
 }
@@ -257,6 +263,10 @@ QJsonValue toJsonValue(const GeneralCommandType &source, convertType<GeneralComm
 		return QStringLiteral("ToggleOsdMenu");
 	case GeneralCommandType::Play:
 		return QStringLiteral("Play");
+	case GeneralCommandType::SetMaxStreamingBitrate:
+		return QStringLiteral("SetMaxStreamingBitrate");
+	case GeneralCommandType::SetPlaybackOrder:
+		return QStringLiteral("SetPlaybackOrder");
 
 	case GeneralCommandType::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/getprogramsdto.cpp b/core/src/dto/getprogramsdto.cpp
index 7aec3f0..d9341ec 100644
--- a/core/src/dto/getprogramsdto.cpp
+++ b/core/src/dto/getprogramsdto.cpp
@@ -34,13 +34,9 @@ namespace DTO {
 
 GetProgramsDto::GetProgramsDto() {}
 GetProgramsDto::GetProgramsDto (
-		QString userId, 
-		bool enableTotalRecordCount, 
-		QString librarySeriesId 
+		std::optional<bool> enableTotalRecordCount 
 		) :
-	m_userId(userId),
-	m_enableTotalRecordCount(enableTotalRecordCount),
-	m_librarySeriesId(librarySeriesId) { }
+	m_enableTotalRecordCount(enableTotalRecordCount) { }
 
 
 
@@ -128,12 +124,12 @@ void GetProgramsDto::setFromJson(QJsonObject source) {
 	m_isSports = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsSports"]);
 	m_startIndex = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["StartIndex"]);
 	m_limit = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Limit"]);
-	m_sortBy = Jellyfin::Support::fromJsonValue<QString>(source["SortBy"]);
-	m_sortOrder = Jellyfin::Support::fromJsonValue<QString>(source["SortOrder"]);
+	m_sortBy = Jellyfin::Support::fromJsonValue<QList<ItemSortBy>>(source["SortBy"]);
+	m_sortOrder = Jellyfin::Support::fromJsonValue<QList<SortOrder>>(source["SortOrder"]);
 	m_genres = Jellyfin::Support::fromJsonValue<QStringList>(source["Genres"]);
 	m_genreIds = Jellyfin::Support::fromJsonValue<QStringList>(source["GenreIds"]);
 	m_enableImages = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableImages"]);
-	m_enableTotalRecordCount = Jellyfin::Support::fromJsonValue<bool>(source["EnableTotalRecordCount"]);
+	m_enableTotalRecordCount = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableTotalRecordCount"]);
 	m_imageTypeLimit = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["ImageTypeLimit"]);
 	m_enableImageTypes = Jellyfin::Support::fromJsonValue<QList<ImageType>>(source["EnableImageTypes"]);
 	m_enableUserData = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableUserData"]);
@@ -151,7 +147,11 @@ QJsonObject GetProgramsDto::toJson() const {
 		result["ChannelIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_channelIds);
 	}
 			
-	result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);		
+	
+	if (!(m_userId.isNull())) {
+		result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);
+	}
+			
 	
 	if (!(m_minStartDate.isNull())) {
 		result["MinStartDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_minStartDate);
@@ -218,13 +218,13 @@ QJsonObject GetProgramsDto::toJson() const {
 	}
 			
 	
-	if (!(m_sortBy.isNull())) {
-		result["SortBy"] = Jellyfin::Support::toJsonValue<QString>(m_sortBy);
+	if (!(m_sortBy.size() == 0)) {
+		result["SortBy"] = Jellyfin::Support::toJsonValue<QList<ItemSortBy>>(m_sortBy);
 	}
 			
 	
-	if (!(m_sortOrder.isNull())) {
-		result["SortOrder"] = Jellyfin::Support::toJsonValue<QString>(m_sortOrder);
+	if (!(m_sortOrder.size() == 0)) {
+		result["SortOrder"] = Jellyfin::Support::toJsonValue<QList<SortOrder>>(m_sortOrder);
 	}
 			
 	
@@ -242,7 +242,7 @@ QJsonObject GetProgramsDto::toJson() const {
 		result["EnableImages"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableImages);
 	}
 			
-	result["EnableTotalRecordCount"] = Jellyfin::Support::toJsonValue<bool>(m_enableTotalRecordCount);		
+	result["EnableTotalRecordCount"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableTotalRecordCount);		
 	
 	if (!(!m_imageTypeLimit.has_value())) {
 		result["ImageTypeLimit"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_imageTypeLimit);
@@ -263,7 +263,11 @@ QJsonObject GetProgramsDto::toJson() const {
 		result["SeriesTimerId"] = Jellyfin::Support::toJsonValue<QString>(m_seriesTimerId);
 	}
 			
-	result["LibrarySeriesId"] = Jellyfin::Support::toJsonValue<QString>(m_librarySeriesId);		
+	
+	if (!(m_librarySeriesId.isNull())) {
+		result["LibrarySeriesId"] = Jellyfin::Support::toJsonValue<QString>(m_librarySeriesId);
+	}
+			
 	
 	if (!(m_fields.size() == 0)) {
 		result["Fields"] = Jellyfin::Support::toJsonValue<QList<ItemFields>>(m_fields);
@@ -290,7 +294,14 @@ QString GetProgramsDto::userId() const { return m_userId; }
 void GetProgramsDto::setUserId(QString newUserId) {
 	m_userId = newUserId;
 }
+bool GetProgramsDto::userIdNull() const {
+	return m_userId.isNull();
+}
 
+void GetProgramsDto::setUserIdNull() {
+	m_userId.clear();
+
+}
 QDateTime GetProgramsDto::minStartDate() const { return m_minStartDate; }
 
 void GetProgramsDto::setMinStartDate(QDateTime newMinStartDate) {
@@ -460,26 +471,26 @@ void GetProgramsDto::setLimitNull() {
 	m_limit = std::nullopt;
 
 }
-QString GetProgramsDto::sortBy() const { return m_sortBy; }
+QList<ItemSortBy> GetProgramsDto::sortBy() const { return m_sortBy; }
 
-void GetProgramsDto::setSortBy(QString newSortBy) {
+void GetProgramsDto::setSortBy(QList<ItemSortBy> newSortBy) {
 	m_sortBy = newSortBy;
 }
 bool GetProgramsDto::sortByNull() const {
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetProgramsDto::setSortByNull() {
 	m_sortBy.clear();
 
 }
-QString GetProgramsDto::sortOrder() const { return m_sortOrder; }
+QList<SortOrder> GetProgramsDto::sortOrder() const { return m_sortOrder; }
 
-void GetProgramsDto::setSortOrder(QString newSortOrder) {
+void GetProgramsDto::setSortOrder(QList<SortOrder> newSortOrder) {
 	m_sortOrder = newSortOrder;
 }
 bool GetProgramsDto::sortOrderNull() const {
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetProgramsDto::setSortOrderNull() {
@@ -525,9 +536,9 @@ void GetProgramsDto::setEnableImagesNull() {
 	m_enableImages = std::nullopt;
 
 }
-bool GetProgramsDto::enableTotalRecordCount() const { return m_enableTotalRecordCount; }
+std::optional<bool> GetProgramsDto::enableTotalRecordCount() const { return m_enableTotalRecordCount; }
 
-void GetProgramsDto::setEnableTotalRecordCount(bool newEnableTotalRecordCount) {
+void GetProgramsDto::setEnableTotalRecordCount(std::optional<bool> newEnableTotalRecordCount) {
 	m_enableTotalRecordCount = newEnableTotalRecordCount;
 }
 
@@ -588,7 +599,14 @@ QString GetProgramsDto::librarySeriesId() const { return m_librarySeriesId; }
 void GetProgramsDto::setLibrarySeriesId(QString newLibrarySeriesId) {
 	m_librarySeriesId = newLibrarySeriesId;
 }
+bool GetProgramsDto::librarySeriesIdNull() const {
+	return m_librarySeriesId.isNull();
+}
 
+void GetProgramsDto::setLibrarySeriesIdNull() {
+	m_librarySeriesId.clear();
+
+}
 QList<ItemFields> GetProgramsDto::fields() const { return m_fields; }
 
 void GetProgramsDto::setFields(QList<ItemFields> newFields) {
diff --git a/core/src/dto/groupinfodto.cpp b/core/src/dto/groupinfodto.cpp
index fa998ad..292a50e 100644
--- a/core/src/dto/groupinfodto.cpp
+++ b/core/src/dto/groupinfodto.cpp
@@ -35,11 +35,15 @@ namespace DTO {
 GroupInfoDto::GroupInfoDto() {}
 GroupInfoDto::GroupInfoDto (
 		QString groupId, 
+		QString groupName, 
 		GroupStateType state, 
+		QStringList participants, 
 		QDateTime lastUpdatedAt 
 		) :
 	m_groupId(groupId),
+	m_groupName(groupName),
 	m_state(state),
+	m_participants(participants),
 	m_lastUpdatedAt(lastUpdatedAt) { }
 
 
@@ -81,17 +85,9 @@ QJsonObject GroupInfoDto::toJson() const {
 	QJsonObject result;
 	
 	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
-	
-	if (!(m_groupName.isNull())) {
-		result["GroupName"] = Jellyfin::Support::toJsonValue<QString>(m_groupName);
-	}
-			
+	result["GroupName"] = Jellyfin::Support::toJsonValue<QString>(m_groupName);		
 	result["State"] = Jellyfin::Support::toJsonValue<GroupStateType>(m_state);		
-	
-	if (!(m_participants.size() == 0)) {
-		result["Participants"] = Jellyfin::Support::toJsonValue<QStringList>(m_participants);
-	}
-			
+	result["Participants"] = Jellyfin::Support::toJsonValue<QStringList>(m_participants);		
 	result["LastUpdatedAt"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastUpdatedAt);	
 	return result;
 }
@@ -107,14 +103,7 @@ QString GroupInfoDto::groupName() const { return m_groupName; }
 void GroupInfoDto::setGroupName(QString newGroupName) {
 	m_groupName = newGroupName;
 }
-bool GroupInfoDto::groupNameNull() const {
-	return m_groupName.isNull();
-}
 
-void GroupInfoDto::setGroupNameNull() {
-	m_groupName.clear();
-
-}
 GroupStateType GroupInfoDto::state() const { return m_state; }
 
 void GroupInfoDto::setState(GroupStateType newState) {
@@ -126,14 +115,7 @@ QStringList GroupInfoDto::participants() const { return m_participants; }
 void GroupInfoDto::setParticipants(QStringList newParticipants) {
 	m_participants = newParticipants;
 }
-bool GroupInfoDto::participantsNull() const {
-	return m_participants.size() == 0;
-}
 
-void GroupInfoDto::setParticipantsNull() {
-	m_participants.clear();
-
-}
 QDateTime GroupInfoDto::lastUpdatedAt() const { return m_lastUpdatedAt; }
 
 void GroupInfoDto::setLastUpdatedAt(QDateTime newLastUpdatedAt) {
diff --git a/core/src/dto/groupinfodtogroupupdate.cpp b/core/src/dto/groupinfodtogroupupdate.cpp
new file mode 100644
index 0000000..e001e7d
--- /dev/null
+++ b/core/src/dto/groupinfodtogroupupdate.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/groupinfodtogroupupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+GroupInfoDtoGroupUpdate::GroupInfoDtoGroupUpdate() {}
+GroupInfoDtoGroupUpdate::GroupInfoDtoGroupUpdate (
+		QString groupId, 
+		GroupUpdateType type, 
+		QSharedPointer<GroupInfoDto> data 
+		) :
+	m_groupId(groupId),
+	m_type(type),
+	m_data(data) { }
+
+
+
+GroupInfoDtoGroupUpdate::GroupInfoDtoGroupUpdate(const GroupInfoDtoGroupUpdate &other) :
+
+	m_groupId(other.m_groupId),
+	m_type(other.m_type),
+	m_data(other.m_data){}
+
+
+void GroupInfoDtoGroupUpdate::replaceData(GroupInfoDtoGroupUpdate &other) {
+	m_groupId = other.m_groupId;
+	m_type = other.m_type;
+	m_data = other.m_data;
+}
+
+GroupInfoDtoGroupUpdate GroupInfoDtoGroupUpdate::fromJson(QJsonObject source) {
+	GroupInfoDtoGroupUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void GroupInfoDtoGroupUpdate::setFromJson(QJsonObject source) {
+	m_groupId = Jellyfin::Support::fromJsonValue<QString>(source["GroupId"]);
+	m_type = Jellyfin::Support::fromJsonValue<GroupUpdateType>(source["Type"]);
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<GroupInfoDto>>(source["Data"]);
+
+}
+	
+QJsonObject GroupInfoDtoGroupUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
+	result["Type"] = Jellyfin::Support::toJsonValue<GroupUpdateType>(m_type);		
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<GroupInfoDto>>(m_data);	
+	return result;
+}
+
+QString GroupInfoDtoGroupUpdate::groupId() const { return m_groupId; }
+
+void GroupInfoDtoGroupUpdate::setGroupId(QString newGroupId) {
+	m_groupId = newGroupId;
+}
+
+GroupUpdateType GroupInfoDtoGroupUpdate::type() const { return m_type; }
+
+void GroupInfoDtoGroupUpdate::setType(GroupUpdateType newType) {
+	m_type = newType;
+}
+
+QSharedPointer<GroupInfoDto> GroupInfoDtoGroupUpdate::data() const { return m_data; }
+
+void GroupInfoDtoGroupUpdate::setData(QSharedPointer<GroupInfoDto> newData) {
+	m_data = newData;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupInfoDtoGroupUpdate = Jellyfin::DTO::GroupInfoDtoGroupUpdate;
+
+template <>
+GroupInfoDtoGroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupInfoDtoGroupUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return GroupInfoDtoGroupUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const GroupInfoDtoGroupUpdate &source, convertType<GroupInfoDtoGroupUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/groupstateupdate.cpp b/core/src/dto/groupstateupdate.cpp
new file mode 100644
index 0000000..26a1b23
--- /dev/null
+++ b/core/src/dto/groupstateupdate.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/groupstateupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+GroupStateUpdate::GroupStateUpdate() {}
+GroupStateUpdate::GroupStateUpdate (
+		GroupStateType state, 
+		PlaybackRequestType reason 
+		) :
+	m_state(state),
+	m_reason(reason) { }
+
+
+
+GroupStateUpdate::GroupStateUpdate(const GroupStateUpdate &other) :
+
+	m_state(other.m_state),
+	m_reason(other.m_reason){}
+
+
+void GroupStateUpdate::replaceData(GroupStateUpdate &other) {
+	m_state = other.m_state;
+	m_reason = other.m_reason;
+}
+
+GroupStateUpdate GroupStateUpdate::fromJson(QJsonObject source) {
+	GroupStateUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void GroupStateUpdate::setFromJson(QJsonObject source) {
+	m_state = Jellyfin::Support::fromJsonValue<GroupStateType>(source["State"]);
+	m_reason = Jellyfin::Support::fromJsonValue<PlaybackRequestType>(source["Reason"]);
+
+}
+	
+QJsonObject GroupStateUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["State"] = Jellyfin::Support::toJsonValue<GroupStateType>(m_state);		
+	result["Reason"] = Jellyfin::Support::toJsonValue<PlaybackRequestType>(m_reason);	
+	return result;
+}
+
+GroupStateType GroupStateUpdate::state() const { return m_state; }
+
+void GroupStateUpdate::setState(GroupStateType newState) {
+	m_state = newState;
+}
+
+PlaybackRequestType GroupStateUpdate::reason() const { return m_reason; }
+
+void GroupStateUpdate::setReason(PlaybackRequestType newReason) {
+	m_reason = newReason;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupStateUpdate = Jellyfin::DTO::GroupStateUpdate;
+
+template <>
+GroupStateUpdate fromJsonValue(const QJsonValue &source, convertType<GroupStateUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return GroupStateUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const GroupStateUpdate &source, convertType<GroupStateUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/groupstateupdategroupupdate.cpp b/core/src/dto/groupstateupdategroupupdate.cpp
new file mode 100644
index 0000000..1892100
--- /dev/null
+++ b/core/src/dto/groupstateupdategroupupdate.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/groupstateupdategroupupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+GroupStateUpdateGroupUpdate::GroupStateUpdateGroupUpdate() {}
+GroupStateUpdateGroupUpdate::GroupStateUpdateGroupUpdate (
+		QString groupId, 
+		GroupUpdateType type, 
+		QSharedPointer<GroupStateUpdate> data 
+		) :
+	m_groupId(groupId),
+	m_type(type),
+	m_data(data) { }
+
+
+
+GroupStateUpdateGroupUpdate::GroupStateUpdateGroupUpdate(const GroupStateUpdateGroupUpdate &other) :
+
+	m_groupId(other.m_groupId),
+	m_type(other.m_type),
+	m_data(other.m_data){}
+
+
+void GroupStateUpdateGroupUpdate::replaceData(GroupStateUpdateGroupUpdate &other) {
+	m_groupId = other.m_groupId;
+	m_type = other.m_type;
+	m_data = other.m_data;
+}
+
+GroupStateUpdateGroupUpdate GroupStateUpdateGroupUpdate::fromJson(QJsonObject source) {
+	GroupStateUpdateGroupUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void GroupStateUpdateGroupUpdate::setFromJson(QJsonObject source) {
+	m_groupId = Jellyfin::Support::fromJsonValue<QString>(source["GroupId"]);
+	m_type = Jellyfin::Support::fromJsonValue<GroupUpdateType>(source["Type"]);
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<GroupStateUpdate>>(source["Data"]);
+
+}
+	
+QJsonObject GroupStateUpdateGroupUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
+	result["Type"] = Jellyfin::Support::toJsonValue<GroupUpdateType>(m_type);		
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<GroupStateUpdate>>(m_data);	
+	return result;
+}
+
+QString GroupStateUpdateGroupUpdate::groupId() const { return m_groupId; }
+
+void GroupStateUpdateGroupUpdate::setGroupId(QString newGroupId) {
+	m_groupId = newGroupId;
+}
+
+GroupUpdateType GroupStateUpdateGroupUpdate::type() const { return m_type; }
+
+void GroupStateUpdateGroupUpdate::setType(GroupUpdateType newType) {
+	m_type = newType;
+}
+
+QSharedPointer<GroupStateUpdate> GroupStateUpdateGroupUpdate::data() const { return m_data; }
+
+void GroupStateUpdateGroupUpdate::setData(QSharedPointer<GroupStateUpdate> newData) {
+	m_data = newData;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupStateUpdateGroupUpdate = Jellyfin::DTO::GroupStateUpdateGroupUpdate;
+
+template <>
+GroupStateUpdateGroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupStateUpdateGroupUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return GroupStateUpdateGroupUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const GroupStateUpdateGroupUpdate &source, convertType<GroupStateUpdateGroupUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/groupupdate.cpp b/core/src/dto/groupupdate.cpp
new file mode 100644
index 0000000..c37cf19
--- /dev/null
+++ b/core/src/dto/groupupdate.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/groupupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+GroupUpdate::GroupUpdate() {}
+GroupUpdate::GroupUpdate (
+		QString groupId, 
+		GroupUpdateType type 
+		) :
+	m_groupId(groupId),
+	m_type(type) { }
+
+
+
+GroupUpdate::GroupUpdate(const GroupUpdate &other) :
+
+	m_groupId(other.m_groupId),
+	m_type(other.m_type){}
+
+
+void GroupUpdate::replaceData(GroupUpdate &other) {
+	m_groupId = other.m_groupId;
+	m_type = other.m_type;
+}
+
+GroupUpdate GroupUpdate::fromJson(QJsonObject source) {
+	GroupUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void GroupUpdate::setFromJson(QJsonObject source) {
+	m_groupId = Jellyfin::Support::fromJsonValue<QString>(source["GroupId"]);
+	m_type = Jellyfin::Support::fromJsonValue<GroupUpdateType>(source["Type"]);
+
+}
+	
+QJsonObject GroupUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
+	result["Type"] = Jellyfin::Support::toJsonValue<GroupUpdateType>(m_type);	
+	return result;
+}
+
+QString GroupUpdate::groupId() const { return m_groupId; }
+
+void GroupUpdate::setGroupId(QString newGroupId) {
+	m_groupId = newGroupId;
+}
+
+GroupUpdateType GroupUpdate::type() const { return m_type; }
+
+void GroupUpdate::setType(GroupUpdateType newType) {
+	m_type = newType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using GroupUpdate = Jellyfin::DTO::GroupUpdate;
+
+template <>
+GroupUpdate fromJsonValue(const QJsonValue &source, convertType<GroupUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return GroupUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const GroupUpdate &source, convertType<GroupUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/hardwareaccelerationtype.cpp b/core/src/dto/hardwareaccelerationtype.cpp
new file mode 100644
index 0000000..a29a8c6
--- /dev/null
+++ b/core/src/dto/hardwareaccelerationtype.cpp
@@ -0,0 +1,103 @@
+/*
+ * 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/dto/hardwareaccelerationtype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+HardwareAccelerationTypeClass::HardwareAccelerationTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using HardwareAccelerationType = Jellyfin::DTO::HardwareAccelerationType;
+
+template <>
+HardwareAccelerationType fromJsonValue(const QJsonValue &source, convertType<HardwareAccelerationType>) {
+	if (!source.isString()) return HardwareAccelerationType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("none")) {
+		return HardwareAccelerationType::None;
+	}
+	if (str == QStringLiteral("amf")) {
+		return HardwareAccelerationType::Amf;
+	}
+	if (str == QStringLiteral("qsv")) {
+		return HardwareAccelerationType::Qsv;
+	}
+	if (str == QStringLiteral("nvenc")) {
+		return HardwareAccelerationType::Nvenc;
+	}
+	if (str == QStringLiteral("v4l2m2m")) {
+		return HardwareAccelerationType::V4l2m2m;
+	}
+	if (str == QStringLiteral("vaapi")) {
+		return HardwareAccelerationType::Vaapi;
+	}
+	if (str == QStringLiteral("videotoolbox")) {
+		return HardwareAccelerationType::Videotoolbox;
+	}
+	if (str == QStringLiteral("rkmpp")) {
+		return HardwareAccelerationType::Rkmpp;
+	}
+	
+	return HardwareAccelerationType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const HardwareAccelerationType &source, convertType<HardwareAccelerationType>) {
+	switch(source) {
+	case HardwareAccelerationType::None:
+		return QStringLiteral("none");
+	case HardwareAccelerationType::Amf:
+		return QStringLiteral("amf");
+	case HardwareAccelerationType::Qsv:
+		return QStringLiteral("qsv");
+	case HardwareAccelerationType::Nvenc:
+		return QStringLiteral("nvenc");
+	case HardwareAccelerationType::V4l2m2m:
+		return QStringLiteral("v4l2m2m");
+	case HardwareAccelerationType::Vaapi:
+		return QStringLiteral("vaapi");
+	case HardwareAccelerationType::Videotoolbox:
+		return QStringLiteral("videotoolbox");
+	case HardwareAccelerationType::Rkmpp:
+		return QStringLiteral("rkmpp");
+
+	case HardwareAccelerationType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/httpheaderinfo.cpp b/core/src/dto/httpheaderinfo.cpp
deleted file mode 100644
index cde83e0..0000000
--- a/core/src/dto/httpheaderinfo.cpp
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * 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/dto/httpheaderinfo.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-HttpHeaderInfo::HttpHeaderInfo() {}
-HttpHeaderInfo::HttpHeaderInfo (
-		HeaderMatchType match 
-		) :
-	m_match(match) { }
-
-
-
-HttpHeaderInfo::HttpHeaderInfo(const HttpHeaderInfo &other) :
-
-	m_name(other.m_name),
-	m_value(other.m_value),
-	m_match(other.m_match){}
-
-
-void HttpHeaderInfo::replaceData(HttpHeaderInfo &other) {
-	m_name = other.m_name;
-	m_value = other.m_value;
-	m_match = other.m_match;
-}
-
-HttpHeaderInfo HttpHeaderInfo::fromJson(QJsonObject source) {
-	HttpHeaderInfo instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void HttpHeaderInfo::setFromJson(QJsonObject source) {
-	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_value = Jellyfin::Support::fromJsonValue<QString>(source["Value"]);
-	m_match = Jellyfin::Support::fromJsonValue<HeaderMatchType>(source["Match"]);
-
-}
-	
-QJsonObject HttpHeaderInfo::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_value.isNull())) {
-		result["Value"] = Jellyfin::Support::toJsonValue<QString>(m_value);
-	}
-			
-	result["Match"] = Jellyfin::Support::toJsonValue<HeaderMatchType>(m_match);	
-	return result;
-}
-
-QString HttpHeaderInfo::name() const { return m_name; }
-
-void HttpHeaderInfo::setName(QString newName) {
-	m_name = newName;
-}
-bool HttpHeaderInfo::nameNull() const {
-	return m_name.isNull();
-}
-
-void HttpHeaderInfo::setNameNull() {
-	m_name.clear();
-
-}
-QString HttpHeaderInfo::value() const { return m_value; }
-
-void HttpHeaderInfo::setValue(QString newValue) {
-	m_value = newValue;
-}
-bool HttpHeaderInfo::valueNull() const {
-	return m_value.isNull();
-}
-
-void HttpHeaderInfo::setValueNull() {
-	m_value.clear();
-
-}
-HeaderMatchType HttpHeaderInfo::match() const { return m_match; }
-
-void HttpHeaderInfo::setMatch(HeaderMatchType newMatch) {
-	m_match = newMatch;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using HttpHeaderInfo = Jellyfin::DTO::HttpHeaderInfo;
-
-template <>
-HttpHeaderInfo fromJsonValue(const QJsonValue &source, convertType<HttpHeaderInfo>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return HttpHeaderInfo::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const HttpHeaderInfo &source, convertType<HttpHeaderInfo>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/imagebynameinfo.cpp b/core/src/dto/imagebynameinfo.cpp
deleted file mode 100644
index 120eb3f..0000000
--- a/core/src/dto/imagebynameinfo.cpp
+++ /dev/null
@@ -1,180 +0,0 @@
-/*
- * 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/dto/imagebynameinfo.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-ImageByNameInfo::ImageByNameInfo() {}
-ImageByNameInfo::ImageByNameInfo (
-		qint64 fileLength 
-		) :
-	m_fileLength(fileLength) { }
-
-
-
-ImageByNameInfo::ImageByNameInfo(const ImageByNameInfo &other) :
-
-	m_name(other.m_name),
-	m_theme(other.m_theme),
-	m_context(other.m_context),
-	m_fileLength(other.m_fileLength),
-	m_format(other.m_format){}
-
-
-void ImageByNameInfo::replaceData(ImageByNameInfo &other) {
-	m_name = other.m_name;
-	m_theme = other.m_theme;
-	m_context = other.m_context;
-	m_fileLength = other.m_fileLength;
-	m_format = other.m_format;
-}
-
-ImageByNameInfo ImageByNameInfo::fromJson(QJsonObject source) {
-	ImageByNameInfo instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void ImageByNameInfo::setFromJson(QJsonObject source) {
-	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_theme = Jellyfin::Support::fromJsonValue<QString>(source["Theme"]);
-	m_context = Jellyfin::Support::fromJsonValue<QString>(source["Context"]);
-	m_fileLength = Jellyfin::Support::fromJsonValue<qint64>(source["FileLength"]);
-	m_format = Jellyfin::Support::fromJsonValue<QString>(source["Format"]);
-
-}
-	
-QJsonObject ImageByNameInfo::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_theme.isNull())) {
-		result["Theme"] = Jellyfin::Support::toJsonValue<QString>(m_theme);
-	}
-			
-	
-	if (!(m_context.isNull())) {
-		result["Context"] = Jellyfin::Support::toJsonValue<QString>(m_context);
-	}
-			
-	result["FileLength"] = Jellyfin::Support::toJsonValue<qint64>(m_fileLength);		
-	
-	if (!(m_format.isNull())) {
-		result["Format"] = Jellyfin::Support::toJsonValue<QString>(m_format);
-	}
-		
-	return result;
-}
-
-QString ImageByNameInfo::name() const { return m_name; }
-
-void ImageByNameInfo::setName(QString newName) {
-	m_name = newName;
-}
-bool ImageByNameInfo::nameNull() const {
-	return m_name.isNull();
-}
-
-void ImageByNameInfo::setNameNull() {
-	m_name.clear();
-
-}
-QString ImageByNameInfo::theme() const { return m_theme; }
-
-void ImageByNameInfo::setTheme(QString newTheme) {
-	m_theme = newTheme;
-}
-bool ImageByNameInfo::themeNull() const {
-	return m_theme.isNull();
-}
-
-void ImageByNameInfo::setThemeNull() {
-	m_theme.clear();
-
-}
-QString ImageByNameInfo::context() const { return m_context; }
-
-void ImageByNameInfo::setContext(QString newContext) {
-	m_context = newContext;
-}
-bool ImageByNameInfo::contextNull() const {
-	return m_context.isNull();
-}
-
-void ImageByNameInfo::setContextNull() {
-	m_context.clear();
-
-}
-qint64 ImageByNameInfo::fileLength() const { return m_fileLength; }
-
-void ImageByNameInfo::setFileLength(qint64 newFileLength) {
-	m_fileLength = newFileLength;
-}
-
-QString ImageByNameInfo::format() const { return m_format; }
-
-void ImageByNameInfo::setFormat(QString newFormat) {
-	m_format = newFormat;
-}
-bool ImageByNameInfo::formatNull() const {
-	return m_format.isNull();
-}
-
-void ImageByNameInfo::setFormatNull() {
-	m_format.clear();
-
-}
-
-} // NS DTO
-
-namespace Support {
-
-using ImageByNameInfo = Jellyfin::DTO::ImageByNameInfo;
-
-template <>
-ImageByNameInfo fromJsonValue(const QJsonValue &source, convertType<ImageByNameInfo>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return ImageByNameInfo::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const ImageByNameInfo &source, convertType<ImageByNameInfo>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/imageformat.cpp b/core/src/dto/imageformat.cpp
index d081d58..20f29c0 100644
--- a/core/src/dto/imageformat.cpp
+++ b/core/src/dto/imageformat.cpp
@@ -60,6 +60,9 @@ ImageFormat fromJsonValue(const QJsonValue &source, convertType<ImageFormat>) {
 	if (str == QStringLiteral("Webp")) {
 		return ImageFormat::Webp;
 	}
+	if (str == QStringLiteral("Svg")) {
+		return ImageFormat::Svg;
+	}
 	
 	return ImageFormat::EnumNotSet;
 }
@@ -77,6 +80,8 @@ QJsonValue toJsonValue(const ImageFormat &source, convertType<ImageFormat>) {
 		return QStringLiteral("Png");
 	case ImageFormat::Webp:
 		return QStringLiteral("Webp");
+	case ImageFormat::Svg:
+		return QStringLiteral("Svg");
 
 	case ImageFormat::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/imageproviderinfo.cpp b/core/src/dto/imageproviderinfo.cpp
index e667656..1567a8a 100644
--- a/core/src/dto/imageproviderinfo.cpp
+++ b/core/src/dto/imageproviderinfo.cpp
@@ -33,6 +33,14 @@ namespace Jellyfin {
 namespace DTO {
 
 ImageProviderInfo::ImageProviderInfo() {}
+ImageProviderInfo::ImageProviderInfo (
+		QString name, 
+		QList<ImageType> supportedImages 
+		) :
+	m_name(name),
+	m_supportedImages(supportedImages) { }
+
+
 
 ImageProviderInfo::ImageProviderInfo(const ImageProviderInfo &other) :
 
@@ -61,16 +69,8 @@ void ImageProviderInfo::setFromJson(QJsonObject source) {
 QJsonObject ImageProviderInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_supportedImages.size() == 0)) {
-		result["SupportedImages"] = Jellyfin::Support::toJsonValue<QList<ImageType>>(m_supportedImages);
-	}
-		
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["SupportedImages"] = Jellyfin::Support::toJsonValue<QList<ImageType>>(m_supportedImages);	
 	return result;
 }
 
@@ -79,27 +79,13 @@ QString ImageProviderInfo::name() const { return m_name; }
 void ImageProviderInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool ImageProviderInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void ImageProviderInfo::setNameNull() {
-	m_name.clear();
-
-}
 QList<ImageType> ImageProviderInfo::supportedImages() const { return m_supportedImages; }
 
 void ImageProviderInfo::setSupportedImages(QList<ImageType> newSupportedImages) {
 	m_supportedImages = newSupportedImages;
 }
-bool ImageProviderInfo::supportedImagesNull() const {
-	return m_supportedImages.size() == 0;
-}
 
-void ImageProviderInfo::setSupportedImagesNull() {
-	m_supportedImages.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/imageresolution.cpp b/core/src/dto/imageresolution.cpp
new file mode 100644
index 0000000..38eed8f
--- /dev/null
+++ b/core/src/dto/imageresolution.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/imageresolution.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ImageResolutionClass::ImageResolutionClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using ImageResolution = Jellyfin::DTO::ImageResolution;
+
+template <>
+ImageResolution fromJsonValue(const QJsonValue &source, convertType<ImageResolution>) {
+	if (!source.isString()) return ImageResolution::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("MatchSource")) {
+		return ImageResolution::MatchSource;
+	}
+	if (str == QStringLiteral("P144")) {
+		return ImageResolution::P144;
+	}
+	if (str == QStringLiteral("P240")) {
+		return ImageResolution::P240;
+	}
+	if (str == QStringLiteral("P360")) {
+		return ImageResolution::P360;
+	}
+	if (str == QStringLiteral("P480")) {
+		return ImageResolution::P480;
+	}
+	if (str == QStringLiteral("P720")) {
+		return ImageResolution::P720;
+	}
+	if (str == QStringLiteral("P1080")) {
+		return ImageResolution::P1080;
+	}
+	if (str == QStringLiteral("P1440")) {
+		return ImageResolution::P1440;
+	}
+	if (str == QStringLiteral("P2160")) {
+		return ImageResolution::P2160;
+	}
+	
+	return ImageResolution::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const ImageResolution &source, convertType<ImageResolution>) {
+	switch(source) {
+	case ImageResolution::MatchSource:
+		return QStringLiteral("MatchSource");
+	case ImageResolution::P144:
+		return QStringLiteral("P144");
+	case ImageResolution::P240:
+		return QStringLiteral("P240");
+	case ImageResolution::P360:
+		return QStringLiteral("P360");
+	case ImageResolution::P480:
+		return QStringLiteral("P480");
+	case ImageResolution::P720:
+		return QStringLiteral("P720");
+	case ImageResolution::P1080:
+		return QStringLiteral("P1080");
+	case ImageResolution::P1440:
+		return QStringLiteral("P1440");
+	case ImageResolution::P2160:
+		return QStringLiteral("P2160");
+
+	case ImageResolution::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/inboundkeepalivemessage.cpp b/core/src/dto/inboundkeepalivemessage.cpp
new file mode 100644
index 0000000..51b1852
--- /dev/null
+++ b/core/src/dto/inboundkeepalivemessage.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/inboundkeepalivemessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+InboundKeepAliveMessage::InboundKeepAliveMessage() {}
+InboundKeepAliveMessage::InboundKeepAliveMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+InboundKeepAliveMessage::InboundKeepAliveMessage(const InboundKeepAliveMessage &other) :
+
+	m_messageType(other.m_messageType){}
+
+
+void InboundKeepAliveMessage::replaceData(InboundKeepAliveMessage &other) {
+	m_messageType = other.m_messageType;
+}
+
+InboundKeepAliveMessage InboundKeepAliveMessage::fromJson(QJsonObject source) {
+	InboundKeepAliveMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void InboundKeepAliveMessage::setFromJson(QJsonObject source) {
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject InboundKeepAliveMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+SessionMessageType InboundKeepAliveMessage::messageType() const { return m_messageType; }
+
+void InboundKeepAliveMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using InboundKeepAliveMessage = Jellyfin::DTO::InboundKeepAliveMessage;
+
+template <>
+InboundKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<InboundKeepAliveMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return InboundKeepAliveMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const InboundKeepAliveMessage &source, convertType<InboundKeepAliveMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/loader/http/dlnaserver.cpp b/core/src/dto/inboundwebsocketmessage.cpp
similarity index 90%
rename from core/src/loader/http/dlnaserver.cpp
rename to core/src/dto/inboundwebsocketmessage.cpp
index ed3dbd0..7c78853 100644
--- a/core/src/loader/http/dlnaserver.cpp
+++ b/core/src/dto/inboundwebsocketmessage.cpp
@@ -27,15 +27,11 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/loader/http/dlnaserver.h>
+#include <JellyfinQt/dto/inboundwebsocketmessage.h>
 
 namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
+namespace DTO {
 
 
-} // NS HTTP
-} // NS Loader
+} // NS DTO
 } // NS Jellyfin
diff --git a/core/src/dto/installationinfo.cpp b/core/src/dto/installationinfo.cpp
index 7d72af3..6530e70 100644
--- a/core/src/dto/installationinfo.cpp
+++ b/core/src/dto/installationinfo.cpp
@@ -35,10 +35,10 @@ namespace DTO {
 InstallationInfo::InstallationInfo() {}
 InstallationInfo::InstallationInfo (
 		QString guid, 
-		QSharedPointer<Version> version 
+		QSharedPointer<PackageInfo> packageInfo 
 		) :
 	m_guid(guid),
-	m_version(version) { }
+	m_packageInfo(packageInfo) { }
 
 
 
@@ -49,7 +49,8 @@ InstallationInfo::InstallationInfo(const InstallationInfo &other) :
 	m_version(other.m_version),
 	m_changelog(other.m_changelog),
 	m_sourceUrl(other.m_sourceUrl),
-	m_checksum(other.m_checksum){}
+	m_checksum(other.m_checksum),
+	m_packageInfo(other.m_packageInfo){}
 
 
 void InstallationInfo::replaceData(InstallationInfo &other) {
@@ -59,6 +60,7 @@ void InstallationInfo::replaceData(InstallationInfo &other) {
 	m_changelog = other.m_changelog;
 	m_sourceUrl = other.m_sourceUrl;
 	m_checksum = other.m_checksum;
+	m_packageInfo = other.m_packageInfo;
 }
 
 InstallationInfo InstallationInfo::fromJson(QJsonObject source) {
@@ -71,10 +73,11 @@ InstallationInfo InstallationInfo::fromJson(QJsonObject source) {
 void InstallationInfo::setFromJson(QJsonObject source) {
 	m_guid = Jellyfin::Support::fromJsonValue<QString>(source["Guid"]);
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_version = Jellyfin::Support::fromJsonValue<QSharedPointer<Version>>(source["Version"]);
+	m_version = Jellyfin::Support::fromJsonValue<QString>(source["Version"]);
 	m_changelog = Jellyfin::Support::fromJsonValue<QString>(source["Changelog"]);
 	m_sourceUrl = Jellyfin::Support::fromJsonValue<QString>(source["SourceUrl"]);
 	m_checksum = Jellyfin::Support::fromJsonValue<QString>(source["Checksum"]);
+	m_packageInfo = Jellyfin::Support::fromJsonValue<QSharedPointer<PackageInfo>>(source["PackageInfo"]);
 
 }
 	
@@ -87,7 +90,11 @@ QJsonObject InstallationInfo::toJson() const {
 		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
 	}
 			
-	result["Version"] = Jellyfin::Support::toJsonValue<QSharedPointer<Version>>(m_version);		
+	
+	if (!(m_version.isNull())) {
+		result["Version"] = Jellyfin::Support::toJsonValue<QString>(m_version);
+	}
+			
 	
 	if (!(m_changelog.isNull())) {
 		result["Changelog"] = Jellyfin::Support::toJsonValue<QString>(m_changelog);
@@ -102,7 +109,8 @@ QJsonObject InstallationInfo::toJson() const {
 	if (!(m_checksum.isNull())) {
 		result["Checksum"] = Jellyfin::Support::toJsonValue<QString>(m_checksum);
 	}
-		
+			
+	result["PackageInfo"] = Jellyfin::Support::toJsonValue<QSharedPointer<PackageInfo>>(m_packageInfo);	
 	return result;
 }
 
@@ -125,12 +133,19 @@ void InstallationInfo::setNameNull() {
 	m_name.clear();
 
 }
-QSharedPointer<Version> InstallationInfo::version() const { return m_version; }
+QString InstallationInfo::version() const { return m_version; }
 
-void InstallationInfo::setVersion(QSharedPointer<Version> newVersion) {
+void InstallationInfo::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
+bool InstallationInfo::versionNull() const {
+	return m_version.isNull();
+}
 
+void InstallationInfo::setVersionNull() {
+	m_version.clear();
+
+}
 QString InstallationInfo::changelog() const { return m_changelog; }
 
 void InstallationInfo::setChangelog(QString newChangelog) {
@@ -170,6 +185,12 @@ void InstallationInfo::setChecksumNull() {
 	m_checksum.clear();
 
 }
+QSharedPointer<PackageInfo> InstallationInfo::packageInfo() const { return m_packageInfo; }
+
+void InstallationInfo::setPackageInfo(QSharedPointer<PackageInfo> newPackageInfo) {
+	m_packageInfo = newPackageInfo;
+}
+
 
 } // NS DTO
 
diff --git a/core/src/dto/iplugin.cpp b/core/src/dto/iplugin.cpp
index b414a0e..5c5baf3 100644
--- a/core/src/dto/iplugin.cpp
+++ b/core/src/dto/iplugin.cpp
@@ -35,11 +35,9 @@ namespace DTO {
 IPlugin::IPlugin() {}
 IPlugin::IPlugin (
 		QString jellyfinId, 
-		QSharedPointer<Version> version, 
 		bool canUninstall 
 		) :
 	m_jellyfinId(jellyfinId),
-	m_version(version),
 	m_canUninstall(canUninstall) { }
 
 
@@ -76,7 +74,7 @@ void IPlugin::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
 	m_description = Jellyfin::Support::fromJsonValue<QString>(source["Description"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
-	m_version = Jellyfin::Support::fromJsonValue<QSharedPointer<Version>>(source["Version"]);
+	m_version = Jellyfin::Support::fromJsonValue<QString>(source["Version"]);
 	m_assemblyFilePath = Jellyfin::Support::fromJsonValue<QString>(source["AssemblyFilePath"]);
 	m_canUninstall = Jellyfin::Support::fromJsonValue<bool>(source["CanUninstall"]);
 	m_dataFolderPath = Jellyfin::Support::fromJsonValue<QString>(source["DataFolderPath"]);
@@ -97,7 +95,11 @@ QJsonObject IPlugin::toJson() const {
 	}
 			
 	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
-	result["Version"] = Jellyfin::Support::toJsonValue<QSharedPointer<Version>>(m_version);		
+	
+	if (!(m_version.isNull())) {
+		result["Version"] = Jellyfin::Support::toJsonValue<QString>(m_version);
+	}
+			
 	
 	if (!(m_assemblyFilePath.isNull())) {
 		result["AssemblyFilePath"] = Jellyfin::Support::toJsonValue<QString>(m_assemblyFilePath);
@@ -144,12 +146,19 @@ void IPlugin::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
 
-QSharedPointer<Version> IPlugin::version() const { return m_version; }
+QString IPlugin::version() const { return m_version; }
 
-void IPlugin::setVersion(QSharedPointer<Version> newVersion) {
+void IPlugin::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
+bool IPlugin::versionNull() const {
+	return m_version.isNull();
+}
 
+void IPlugin::setVersionNull() {
+	m_version.clear();
+
+}
 QString IPlugin::assemblyFilePath() const { return m_assemblyFilePath; }
 
 void IPlugin::setAssemblyFilePath(QString newAssemblyFilePath) {
diff --git a/core/src/dto/itemfields.cpp b/core/src/dto/itemfields.cpp
index b832e31..2ecb4a3 100644
--- a/core/src/dto/itemfields.cpp
+++ b/core/src/dto/itemfields.cpp
@@ -60,6 +60,9 @@ ItemFields fromJsonValue(const QJsonValue &source, convertType<ItemFields>) {
 	if (str == QStringLiteral("Chapters")) {
 		return ItemFields::Chapters;
 	}
+	if (str == QStringLiteral("Trickplay")) {
+		return ItemFields::Trickplay;
+	}
 	if (str == QStringLiteral("ChildCount")) {
 		return ItemFields::ChildCount;
 	}
@@ -150,12 +153,6 @@ ItemFields fromJsonValue(const QJsonValue &source, convertType<ItemFields>) {
 	if (str == QStringLiteral("Studios")) {
 		return ItemFields::Studios;
 	}
-	if (str == QStringLiteral("BasicSyncInfo")) {
-		return ItemFields::BasicSyncInfo;
-	}
-	if (str == QStringLiteral("SyncInfo")) {
-		return ItemFields::SyncInfo;
-	}
 	if (str == QStringLiteral("Taglines")) {
 		return ItemFields::Taglines;
 	}
@@ -245,6 +242,8 @@ QJsonValue toJsonValue(const ItemFields &source, convertType<ItemFields>) {
 		return QStringLiteral("ChannelInfo");
 	case ItemFields::Chapters:
 		return QStringLiteral("Chapters");
+	case ItemFields::Trickplay:
+		return QStringLiteral("Trickplay");
 	case ItemFields::ChildCount:
 		return QStringLiteral("ChildCount");
 	case ItemFields::CumulativeRunTimeTicks:
@@ -305,10 +304,6 @@ QJsonValue toJsonValue(const ItemFields &source, convertType<ItemFields>) {
 		return QStringLiteral("SpecialEpisodeNumbers");
 	case ItemFields::Studios:
 		return QStringLiteral("Studios");
-	case ItemFields::BasicSyncInfo:
-		return QStringLiteral("BasicSyncInfo");
-	case ItemFields::SyncInfo:
-		return QStringLiteral("SyncInfo");
 	case ItemFields::Taglines:
 		return QStringLiteral("Taglines");
 	case ItemFields::Tags:
diff --git a/core/src/dto/itemsortby.cpp b/core/src/dto/itemsortby.cpp
new file mode 100644
index 0000000..f159070
--- /dev/null
+++ b/core/src/dto/itemsortby.cpp
@@ -0,0 +1,223 @@
+/*
+ * 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/dto/itemsortby.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ItemSortByClass::ItemSortByClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using ItemSortBy = Jellyfin::DTO::ItemSortBy;
+
+template <>
+ItemSortBy fromJsonValue(const QJsonValue &source, convertType<ItemSortBy>) {
+	if (!source.isString()) return ItemSortBy::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Default")) {
+		return ItemSortBy::Default;
+	}
+	if (str == QStringLiteral("AiredEpisodeOrder")) {
+		return ItemSortBy::AiredEpisodeOrder;
+	}
+	if (str == QStringLiteral("Album")) {
+		return ItemSortBy::Album;
+	}
+	if (str == QStringLiteral("AlbumArtist")) {
+		return ItemSortBy::AlbumArtist;
+	}
+	if (str == QStringLiteral("Artist")) {
+		return ItemSortBy::Artist;
+	}
+	if (str == QStringLiteral("DateCreated")) {
+		return ItemSortBy::DateCreated;
+	}
+	if (str == QStringLiteral("OfficialRating")) {
+		return ItemSortBy::OfficialRating;
+	}
+	if (str == QStringLiteral("DatePlayed")) {
+		return ItemSortBy::DatePlayed;
+	}
+	if (str == QStringLiteral("PremiereDate")) {
+		return ItemSortBy::PremiereDate;
+	}
+	if (str == QStringLiteral("StartDate")) {
+		return ItemSortBy::StartDate;
+	}
+	if (str == QStringLiteral("SortName")) {
+		return ItemSortBy::SortName;
+	}
+	if (str == QStringLiteral("Name")) {
+		return ItemSortBy::Name;
+	}
+	if (str == QStringLiteral("Random")) {
+		return ItemSortBy::Random;
+	}
+	if (str == QStringLiteral("Runtime")) {
+		return ItemSortBy::Runtime;
+	}
+	if (str == QStringLiteral("CommunityRating")) {
+		return ItemSortBy::CommunityRating;
+	}
+	if (str == QStringLiteral("ProductionYear")) {
+		return ItemSortBy::ProductionYear;
+	}
+	if (str == QStringLiteral("PlayCount")) {
+		return ItemSortBy::PlayCount;
+	}
+	if (str == QStringLiteral("CriticRating")) {
+		return ItemSortBy::CriticRating;
+	}
+	if (str == QStringLiteral("IsFolder")) {
+		return ItemSortBy::IsFolder;
+	}
+	if (str == QStringLiteral("IsUnplayed")) {
+		return ItemSortBy::IsUnplayed;
+	}
+	if (str == QStringLiteral("IsPlayed")) {
+		return ItemSortBy::IsPlayed;
+	}
+	if (str == QStringLiteral("SeriesSortName")) {
+		return ItemSortBy::SeriesSortName;
+	}
+	if (str == QStringLiteral("VideoBitRate")) {
+		return ItemSortBy::VideoBitRate;
+	}
+	if (str == QStringLiteral("AirTime")) {
+		return ItemSortBy::AirTime;
+	}
+	if (str == QStringLiteral("Studio")) {
+		return ItemSortBy::Studio;
+	}
+	if (str == QStringLiteral("IsFavoriteOrLiked")) {
+		return ItemSortBy::IsFavoriteOrLiked;
+	}
+	if (str == QStringLiteral("DateLastContentAdded")) {
+		return ItemSortBy::DateLastContentAdded;
+	}
+	if (str == QStringLiteral("SeriesDatePlayed")) {
+		return ItemSortBy::SeriesDatePlayed;
+	}
+	if (str == QStringLiteral("ParentIndexNumber")) {
+		return ItemSortBy::ParentIndexNumber;
+	}
+	if (str == QStringLiteral("IndexNumber")) {
+		return ItemSortBy::IndexNumber;
+	}
+	if (str == QStringLiteral("SimilarityScore")) {
+		return ItemSortBy::SimilarityScore;
+	}
+	if (str == QStringLiteral("SearchScore")) {
+		return ItemSortBy::SearchScore;
+	}
+	
+	return ItemSortBy::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const ItemSortBy &source, convertType<ItemSortBy>) {
+	switch(source) {
+	case ItemSortBy::Default:
+		return QStringLiteral("Default");
+	case ItemSortBy::AiredEpisodeOrder:
+		return QStringLiteral("AiredEpisodeOrder");
+	case ItemSortBy::Album:
+		return QStringLiteral("Album");
+	case ItemSortBy::AlbumArtist:
+		return QStringLiteral("AlbumArtist");
+	case ItemSortBy::Artist:
+		return QStringLiteral("Artist");
+	case ItemSortBy::DateCreated:
+		return QStringLiteral("DateCreated");
+	case ItemSortBy::OfficialRating:
+		return QStringLiteral("OfficialRating");
+	case ItemSortBy::DatePlayed:
+		return QStringLiteral("DatePlayed");
+	case ItemSortBy::PremiereDate:
+		return QStringLiteral("PremiereDate");
+	case ItemSortBy::StartDate:
+		return QStringLiteral("StartDate");
+	case ItemSortBy::SortName:
+		return QStringLiteral("SortName");
+	case ItemSortBy::Name:
+		return QStringLiteral("Name");
+	case ItemSortBy::Random:
+		return QStringLiteral("Random");
+	case ItemSortBy::Runtime:
+		return QStringLiteral("Runtime");
+	case ItemSortBy::CommunityRating:
+		return QStringLiteral("CommunityRating");
+	case ItemSortBy::ProductionYear:
+		return QStringLiteral("ProductionYear");
+	case ItemSortBy::PlayCount:
+		return QStringLiteral("PlayCount");
+	case ItemSortBy::CriticRating:
+		return QStringLiteral("CriticRating");
+	case ItemSortBy::IsFolder:
+		return QStringLiteral("IsFolder");
+	case ItemSortBy::IsUnplayed:
+		return QStringLiteral("IsUnplayed");
+	case ItemSortBy::IsPlayed:
+		return QStringLiteral("IsPlayed");
+	case ItemSortBy::SeriesSortName:
+		return QStringLiteral("SeriesSortName");
+	case ItemSortBy::VideoBitRate:
+		return QStringLiteral("VideoBitRate");
+	case ItemSortBy::AirTime:
+		return QStringLiteral("AirTime");
+	case ItemSortBy::Studio:
+		return QStringLiteral("Studio");
+	case ItemSortBy::IsFavoriteOrLiked:
+		return QStringLiteral("IsFavoriteOrLiked");
+	case ItemSortBy::DateLastContentAdded:
+		return QStringLiteral("DateLastContentAdded");
+	case ItemSortBy::SeriesDatePlayed:
+		return QStringLiteral("SeriesDatePlayed");
+	case ItemSortBy::ParentIndexNumber:
+		return QStringLiteral("ParentIndexNumber");
+	case ItemSortBy::IndexNumber:
+		return QStringLiteral("IndexNumber");
+	case ItemSortBy::SimilarityScore:
+		return QStringLiteral("SimilarityScore");
+	case ItemSortBy::SearchScore:
+		return QStringLiteral("SearchScore");
+
+	case ItemSortBy::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/librarychangedmessage.cpp b/core/src/dto/librarychangedmessage.cpp
new file mode 100644
index 0000000..1cc5551
--- /dev/null
+++ b/core/src/dto/librarychangedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/librarychangedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+LibraryChangedMessage::LibraryChangedMessage() {}
+LibraryChangedMessage::LibraryChangedMessage (
+		QSharedPointer<LibraryUpdateInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+LibraryChangedMessage::LibraryChangedMessage(const LibraryChangedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void LibraryChangedMessage::replaceData(LibraryChangedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+LibraryChangedMessage LibraryChangedMessage::fromJson(QJsonObject source) {
+	LibraryChangedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void LibraryChangedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<LibraryUpdateInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject LibraryChangedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<LibraryUpdateInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<LibraryUpdateInfo> LibraryChangedMessage::data() const { return m_data; }
+
+void LibraryChangedMessage::setData(QSharedPointer<LibraryUpdateInfo> newData) {
+	m_data = newData;
+}
+
+QString LibraryChangedMessage::messageId() const { return m_messageId; }
+
+void LibraryChangedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType LibraryChangedMessage::messageType() const { return m_messageType; }
+
+void LibraryChangedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using LibraryChangedMessage = Jellyfin::DTO::LibraryChangedMessage;
+
+template <>
+LibraryChangedMessage fromJsonValue(const QJsonValue &source, convertType<LibraryChangedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return LibraryChangedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const LibraryChangedMessage &source, convertType<LibraryChangedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/libraryoptions.cpp b/core/src/dto/libraryoptions.cpp
index b424d21..eb59bf6 100644
--- a/core/src/dto/libraryoptions.cpp
+++ b/core/src/dto/libraryoptions.cpp
@@ -34,49 +34,100 @@ namespace DTO {
 
 LibraryOptions::LibraryOptions() {}
 LibraryOptions::LibraryOptions (
+		bool enabled, 
 		bool enablePhotos, 
 		bool enableRealtimeMonitor, 
+		bool enableLUFSScan, 
 		bool enableChapterImageExtraction, 
 		bool extractChapterImagesDuringLibraryScan, 
+		bool enableTrickplayImageExtraction, 
+		bool extractTrickplayImagesDuringLibraryScan, 
+		QList<MediaPathInfo> pathInfos, 
 		bool saveLocalMetadata, 
 		bool enableInternetProviders, 
 		bool enableAutomaticSeriesGrouping, 
 		bool enableEmbeddedTitles, 
+		bool enableEmbeddedExtrasTitles, 
 		bool enableEmbeddedEpisodeInfos, 
 		qint32 automaticRefreshIntervalDays, 
+		QString seasonZeroDisplayName, 
+		QStringList disabledLocalMetadataReaders, 
+		QStringList disabledSubtitleFetchers, 
+		QStringList subtitleFetcherOrder, 
+		QStringList disabledMediaSegmentProviders, 
+		QStringList mediaSegmentProvideOrder, 
 		bool skipSubtitlesIfEmbeddedSubtitlesPresent, 
 		bool skipSubtitlesIfAudioTrackMatches, 
 		bool requirePerfectSubtitleMatch, 
-		bool saveSubtitlesWithMedia 
+		bool saveSubtitlesWithMedia, 
+		std::optional<bool> saveLyricsWithMedia, 
+		std::optional<bool> saveTrickplayWithMedia, 
+		QStringList disabledLyricFetchers, 
+		QStringList lyricFetcherOrder, 
+		std::optional<bool> preferNonstandardArtistsTag, 
+		std::optional<bool> useCustomTagDelimiters, 
+		QStringList customTagDelimiters, 
+		QStringList delimiterWhitelist, 
+		bool automaticallyAddToCollection, 
+		EmbeddedSubtitleOptions allowEmbeddedSubtitles, 
+		QList<TypeOptions> typeOptions 
 		) :
+	m_enabled(enabled),
 	m_enablePhotos(enablePhotos),
 	m_enableRealtimeMonitor(enableRealtimeMonitor),
+	m_enableLUFSScan(enableLUFSScan),
 	m_enableChapterImageExtraction(enableChapterImageExtraction),
 	m_extractChapterImagesDuringLibraryScan(extractChapterImagesDuringLibraryScan),
+	m_enableTrickplayImageExtraction(enableTrickplayImageExtraction),
+	m_extractTrickplayImagesDuringLibraryScan(extractTrickplayImagesDuringLibraryScan),
+	m_pathInfos(pathInfos),
 	m_saveLocalMetadata(saveLocalMetadata),
 	m_enableInternetProviders(enableInternetProviders),
 	m_enableAutomaticSeriesGrouping(enableAutomaticSeriesGrouping),
 	m_enableEmbeddedTitles(enableEmbeddedTitles),
+	m_enableEmbeddedExtrasTitles(enableEmbeddedExtrasTitles),
 	m_enableEmbeddedEpisodeInfos(enableEmbeddedEpisodeInfos),
 	m_automaticRefreshIntervalDays(automaticRefreshIntervalDays),
+	m_seasonZeroDisplayName(seasonZeroDisplayName),
+	m_disabledLocalMetadataReaders(disabledLocalMetadataReaders),
+	m_disabledSubtitleFetchers(disabledSubtitleFetchers),
+	m_subtitleFetcherOrder(subtitleFetcherOrder),
+	m_disabledMediaSegmentProviders(disabledMediaSegmentProviders),
+	m_mediaSegmentProvideOrder(mediaSegmentProvideOrder),
 	m_skipSubtitlesIfEmbeddedSubtitlesPresent(skipSubtitlesIfEmbeddedSubtitlesPresent),
 	m_skipSubtitlesIfAudioTrackMatches(skipSubtitlesIfAudioTrackMatches),
 	m_requirePerfectSubtitleMatch(requirePerfectSubtitleMatch),
-	m_saveSubtitlesWithMedia(saveSubtitlesWithMedia) { }
+	m_saveSubtitlesWithMedia(saveSubtitlesWithMedia),
+	m_saveLyricsWithMedia(saveLyricsWithMedia),
+	m_saveTrickplayWithMedia(saveTrickplayWithMedia),
+	m_disabledLyricFetchers(disabledLyricFetchers),
+	m_lyricFetcherOrder(lyricFetcherOrder),
+	m_preferNonstandardArtistsTag(preferNonstandardArtistsTag),
+	m_useCustomTagDelimiters(useCustomTagDelimiters),
+	m_customTagDelimiters(customTagDelimiters),
+	m_delimiterWhitelist(delimiterWhitelist),
+	m_automaticallyAddToCollection(automaticallyAddToCollection),
+	m_allowEmbeddedSubtitles(allowEmbeddedSubtitles),
+	m_typeOptions(typeOptions) { }
 
 
 
 LibraryOptions::LibraryOptions(const LibraryOptions &other) :
 
+	m_enabled(other.m_enabled),
 	m_enablePhotos(other.m_enablePhotos),
 	m_enableRealtimeMonitor(other.m_enableRealtimeMonitor),
+	m_enableLUFSScan(other.m_enableLUFSScan),
 	m_enableChapterImageExtraction(other.m_enableChapterImageExtraction),
 	m_extractChapterImagesDuringLibraryScan(other.m_extractChapterImagesDuringLibraryScan),
+	m_enableTrickplayImageExtraction(other.m_enableTrickplayImageExtraction),
+	m_extractTrickplayImagesDuringLibraryScan(other.m_extractTrickplayImagesDuringLibraryScan),
 	m_pathInfos(other.m_pathInfos),
 	m_saveLocalMetadata(other.m_saveLocalMetadata),
 	m_enableInternetProviders(other.m_enableInternetProviders),
 	m_enableAutomaticSeriesGrouping(other.m_enableAutomaticSeriesGrouping),
 	m_enableEmbeddedTitles(other.m_enableEmbeddedTitles),
+	m_enableEmbeddedExtrasTitles(other.m_enableEmbeddedExtrasTitles),
 	m_enableEmbeddedEpisodeInfos(other.m_enableEmbeddedEpisodeInfos),
 	m_automaticRefreshIntervalDays(other.m_automaticRefreshIntervalDays),
 	m_preferredMetadataLanguage(other.m_preferredMetadataLanguage),
@@ -87,24 +138,41 @@ LibraryOptions::LibraryOptions(const LibraryOptions &other) :
 	m_localMetadataReaderOrder(other.m_localMetadataReaderOrder),
 	m_disabledSubtitleFetchers(other.m_disabledSubtitleFetchers),
 	m_subtitleFetcherOrder(other.m_subtitleFetcherOrder),
+	m_disabledMediaSegmentProviders(other.m_disabledMediaSegmentProviders),
+	m_mediaSegmentProvideOrder(other.m_mediaSegmentProvideOrder),
 	m_skipSubtitlesIfEmbeddedSubtitlesPresent(other.m_skipSubtitlesIfEmbeddedSubtitlesPresent),
 	m_skipSubtitlesIfAudioTrackMatches(other.m_skipSubtitlesIfAudioTrackMatches),
 	m_subtitleDownloadLanguages(other.m_subtitleDownloadLanguages),
 	m_requirePerfectSubtitleMatch(other.m_requirePerfectSubtitleMatch),
 	m_saveSubtitlesWithMedia(other.m_saveSubtitlesWithMedia),
+	m_saveLyricsWithMedia(other.m_saveLyricsWithMedia),
+	m_saveTrickplayWithMedia(other.m_saveTrickplayWithMedia),
+	m_disabledLyricFetchers(other.m_disabledLyricFetchers),
+	m_lyricFetcherOrder(other.m_lyricFetcherOrder),
+	m_preferNonstandardArtistsTag(other.m_preferNonstandardArtistsTag),
+	m_useCustomTagDelimiters(other.m_useCustomTagDelimiters),
+	m_customTagDelimiters(other.m_customTagDelimiters),
+	m_delimiterWhitelist(other.m_delimiterWhitelist),
+	m_automaticallyAddToCollection(other.m_automaticallyAddToCollection),
+	m_allowEmbeddedSubtitles(other.m_allowEmbeddedSubtitles),
 	m_typeOptions(other.m_typeOptions){}
 
 
 void LibraryOptions::replaceData(LibraryOptions &other) {
+	m_enabled = other.m_enabled;
 	m_enablePhotos = other.m_enablePhotos;
 	m_enableRealtimeMonitor = other.m_enableRealtimeMonitor;
+	m_enableLUFSScan = other.m_enableLUFSScan;
 	m_enableChapterImageExtraction = other.m_enableChapterImageExtraction;
 	m_extractChapterImagesDuringLibraryScan = other.m_extractChapterImagesDuringLibraryScan;
+	m_enableTrickplayImageExtraction = other.m_enableTrickplayImageExtraction;
+	m_extractTrickplayImagesDuringLibraryScan = other.m_extractTrickplayImagesDuringLibraryScan;
 	m_pathInfos = other.m_pathInfos;
 	m_saveLocalMetadata = other.m_saveLocalMetadata;
 	m_enableInternetProviders = other.m_enableInternetProviders;
 	m_enableAutomaticSeriesGrouping = other.m_enableAutomaticSeriesGrouping;
 	m_enableEmbeddedTitles = other.m_enableEmbeddedTitles;
+	m_enableEmbeddedExtrasTitles = other.m_enableEmbeddedExtrasTitles;
 	m_enableEmbeddedEpisodeInfos = other.m_enableEmbeddedEpisodeInfos;
 	m_automaticRefreshIntervalDays = other.m_automaticRefreshIntervalDays;
 	m_preferredMetadataLanguage = other.m_preferredMetadataLanguage;
@@ -115,11 +183,23 @@ void LibraryOptions::replaceData(LibraryOptions &other) {
 	m_localMetadataReaderOrder = other.m_localMetadataReaderOrder;
 	m_disabledSubtitleFetchers = other.m_disabledSubtitleFetchers;
 	m_subtitleFetcherOrder = other.m_subtitleFetcherOrder;
+	m_disabledMediaSegmentProviders = other.m_disabledMediaSegmentProviders;
+	m_mediaSegmentProvideOrder = other.m_mediaSegmentProvideOrder;
 	m_skipSubtitlesIfEmbeddedSubtitlesPresent = other.m_skipSubtitlesIfEmbeddedSubtitlesPresent;
 	m_skipSubtitlesIfAudioTrackMatches = other.m_skipSubtitlesIfAudioTrackMatches;
 	m_subtitleDownloadLanguages = other.m_subtitleDownloadLanguages;
 	m_requirePerfectSubtitleMatch = other.m_requirePerfectSubtitleMatch;
 	m_saveSubtitlesWithMedia = other.m_saveSubtitlesWithMedia;
+	m_saveLyricsWithMedia = other.m_saveLyricsWithMedia;
+	m_saveTrickplayWithMedia = other.m_saveTrickplayWithMedia;
+	m_disabledLyricFetchers = other.m_disabledLyricFetchers;
+	m_lyricFetcherOrder = other.m_lyricFetcherOrder;
+	m_preferNonstandardArtistsTag = other.m_preferNonstandardArtistsTag;
+	m_useCustomTagDelimiters = other.m_useCustomTagDelimiters;
+	m_customTagDelimiters = other.m_customTagDelimiters;
+	m_delimiterWhitelist = other.m_delimiterWhitelist;
+	m_automaticallyAddToCollection = other.m_automaticallyAddToCollection;
+	m_allowEmbeddedSubtitles = other.m_allowEmbeddedSubtitles;
 	m_typeOptions = other.m_typeOptions;
 }
 
@@ -131,15 +211,20 @@ LibraryOptions LibraryOptions::fromJson(QJsonObject source) {
 
 
 void LibraryOptions::setFromJson(QJsonObject source) {
+	m_enabled = Jellyfin::Support::fromJsonValue<bool>(source["Enabled"]);
 	m_enablePhotos = Jellyfin::Support::fromJsonValue<bool>(source["EnablePhotos"]);
 	m_enableRealtimeMonitor = Jellyfin::Support::fromJsonValue<bool>(source["EnableRealtimeMonitor"]);
+	m_enableLUFSScan = Jellyfin::Support::fromJsonValue<bool>(source["EnableLUFSScan"]);
 	m_enableChapterImageExtraction = Jellyfin::Support::fromJsonValue<bool>(source["EnableChapterImageExtraction"]);
 	m_extractChapterImagesDuringLibraryScan = Jellyfin::Support::fromJsonValue<bool>(source["ExtractChapterImagesDuringLibraryScan"]);
+	m_enableTrickplayImageExtraction = Jellyfin::Support::fromJsonValue<bool>(source["EnableTrickplayImageExtraction"]);
+	m_extractTrickplayImagesDuringLibraryScan = Jellyfin::Support::fromJsonValue<bool>(source["ExtractTrickplayImagesDuringLibraryScan"]);
 	m_pathInfos = Jellyfin::Support::fromJsonValue<QList<MediaPathInfo>>(source["PathInfos"]);
 	m_saveLocalMetadata = Jellyfin::Support::fromJsonValue<bool>(source["SaveLocalMetadata"]);
 	m_enableInternetProviders = Jellyfin::Support::fromJsonValue<bool>(source["EnableInternetProviders"]);
 	m_enableAutomaticSeriesGrouping = Jellyfin::Support::fromJsonValue<bool>(source["EnableAutomaticSeriesGrouping"]);
 	m_enableEmbeddedTitles = Jellyfin::Support::fromJsonValue<bool>(source["EnableEmbeddedTitles"]);
+	m_enableEmbeddedExtrasTitles = Jellyfin::Support::fromJsonValue<bool>(source["EnableEmbeddedExtrasTitles"]);
 	m_enableEmbeddedEpisodeInfos = Jellyfin::Support::fromJsonValue<bool>(source["EnableEmbeddedEpisodeInfos"]);
 	m_automaticRefreshIntervalDays = Jellyfin::Support::fromJsonValue<qint32>(source["AutomaticRefreshIntervalDays"]);
 	m_preferredMetadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["PreferredMetadataLanguage"]);
@@ -150,11 +235,23 @@ void LibraryOptions::setFromJson(QJsonObject source) {
 	m_localMetadataReaderOrder = Jellyfin::Support::fromJsonValue<QStringList>(source["LocalMetadataReaderOrder"]);
 	m_disabledSubtitleFetchers = Jellyfin::Support::fromJsonValue<QStringList>(source["DisabledSubtitleFetchers"]);
 	m_subtitleFetcherOrder = Jellyfin::Support::fromJsonValue<QStringList>(source["SubtitleFetcherOrder"]);
+	m_disabledMediaSegmentProviders = Jellyfin::Support::fromJsonValue<QStringList>(source["DisabledMediaSegmentProviders"]);
+	m_mediaSegmentProvideOrder = Jellyfin::Support::fromJsonValue<QStringList>(source["MediaSegmentProvideOrder"]);
 	m_skipSubtitlesIfEmbeddedSubtitlesPresent = Jellyfin::Support::fromJsonValue<bool>(source["SkipSubtitlesIfEmbeddedSubtitlesPresent"]);
 	m_skipSubtitlesIfAudioTrackMatches = Jellyfin::Support::fromJsonValue<bool>(source["SkipSubtitlesIfAudioTrackMatches"]);
 	m_subtitleDownloadLanguages = Jellyfin::Support::fromJsonValue<QStringList>(source["SubtitleDownloadLanguages"]);
 	m_requirePerfectSubtitleMatch = Jellyfin::Support::fromJsonValue<bool>(source["RequirePerfectSubtitleMatch"]);
 	m_saveSubtitlesWithMedia = Jellyfin::Support::fromJsonValue<bool>(source["SaveSubtitlesWithMedia"]);
+	m_saveLyricsWithMedia = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["SaveLyricsWithMedia"]);
+	m_saveTrickplayWithMedia = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["SaveTrickplayWithMedia"]);
+	m_disabledLyricFetchers = Jellyfin::Support::fromJsonValue<QStringList>(source["DisabledLyricFetchers"]);
+	m_lyricFetcherOrder = Jellyfin::Support::fromJsonValue<QStringList>(source["LyricFetcherOrder"]);
+	m_preferNonstandardArtistsTag = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["PreferNonstandardArtistsTag"]);
+	m_useCustomTagDelimiters = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["UseCustomTagDelimiters"]);
+	m_customTagDelimiters = Jellyfin::Support::fromJsonValue<QStringList>(source["CustomTagDelimiters"]);
+	m_delimiterWhitelist = Jellyfin::Support::fromJsonValue<QStringList>(source["DelimiterWhitelist"]);
+	m_automaticallyAddToCollection = Jellyfin::Support::fromJsonValue<bool>(source["AutomaticallyAddToCollection"]);
+	m_allowEmbeddedSubtitles = Jellyfin::Support::fromJsonValue<EmbeddedSubtitleOptions>(source["AllowEmbeddedSubtitles"]);
 	m_typeOptions = Jellyfin::Support::fromJsonValue<QList<TypeOptions>>(source["TypeOptions"]);
 
 }
@@ -162,19 +259,20 @@ void LibraryOptions::setFromJson(QJsonObject source) {
 QJsonObject LibraryOptions::toJson() const {
 	QJsonObject result;
 	
+	result["Enabled"] = Jellyfin::Support::toJsonValue<bool>(m_enabled);		
 	result["EnablePhotos"] = Jellyfin::Support::toJsonValue<bool>(m_enablePhotos);		
 	result["EnableRealtimeMonitor"] = Jellyfin::Support::toJsonValue<bool>(m_enableRealtimeMonitor);		
+	result["EnableLUFSScan"] = Jellyfin::Support::toJsonValue<bool>(m_enableLUFSScan);		
 	result["EnableChapterImageExtraction"] = Jellyfin::Support::toJsonValue<bool>(m_enableChapterImageExtraction);		
 	result["ExtractChapterImagesDuringLibraryScan"] = Jellyfin::Support::toJsonValue<bool>(m_extractChapterImagesDuringLibraryScan);		
-	
-	if (!(m_pathInfos.size() == 0)) {
-		result["PathInfos"] = Jellyfin::Support::toJsonValue<QList<MediaPathInfo>>(m_pathInfos);
-	}
-			
+	result["EnableTrickplayImageExtraction"] = Jellyfin::Support::toJsonValue<bool>(m_enableTrickplayImageExtraction);		
+	result["ExtractTrickplayImagesDuringLibraryScan"] = Jellyfin::Support::toJsonValue<bool>(m_extractTrickplayImagesDuringLibraryScan);		
+	result["PathInfos"] = Jellyfin::Support::toJsonValue<QList<MediaPathInfo>>(m_pathInfos);		
 	result["SaveLocalMetadata"] = Jellyfin::Support::toJsonValue<bool>(m_saveLocalMetadata);		
 	result["EnableInternetProviders"] = Jellyfin::Support::toJsonValue<bool>(m_enableInternetProviders);		
 	result["EnableAutomaticSeriesGrouping"] = Jellyfin::Support::toJsonValue<bool>(m_enableAutomaticSeriesGrouping);		
 	result["EnableEmbeddedTitles"] = Jellyfin::Support::toJsonValue<bool>(m_enableEmbeddedTitles);		
+	result["EnableEmbeddedExtrasTitles"] = Jellyfin::Support::toJsonValue<bool>(m_enableEmbeddedExtrasTitles);		
 	result["EnableEmbeddedEpisodeInfos"] = Jellyfin::Support::toJsonValue<bool>(m_enableEmbeddedEpisodeInfos);		
 	result["AutomaticRefreshIntervalDays"] = Jellyfin::Support::toJsonValue<qint32>(m_automaticRefreshIntervalDays);		
 	
@@ -187,36 +285,22 @@ QJsonObject LibraryOptions::toJson() const {
 		result["MetadataCountryCode"] = Jellyfin::Support::toJsonValue<QString>(m_metadataCountryCode);
 	}
 			
-	
-	if (!(m_seasonZeroDisplayName.isNull())) {
-		result["SeasonZeroDisplayName"] = Jellyfin::Support::toJsonValue<QString>(m_seasonZeroDisplayName);
-	}
-			
+	result["SeasonZeroDisplayName"] = Jellyfin::Support::toJsonValue<QString>(m_seasonZeroDisplayName);		
 	
 	if (!(m_metadataSavers.size() == 0)) {
 		result["MetadataSavers"] = Jellyfin::Support::toJsonValue<QStringList>(m_metadataSavers);
 	}
 			
-	
-	if (!(m_disabledLocalMetadataReaders.size() == 0)) {
-		result["DisabledLocalMetadataReaders"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledLocalMetadataReaders);
-	}
-			
+	result["DisabledLocalMetadataReaders"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledLocalMetadataReaders);		
 	
 	if (!(m_localMetadataReaderOrder.size() == 0)) {
 		result["LocalMetadataReaderOrder"] = Jellyfin::Support::toJsonValue<QStringList>(m_localMetadataReaderOrder);
 	}
 			
-	
-	if (!(m_disabledSubtitleFetchers.size() == 0)) {
-		result["DisabledSubtitleFetchers"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledSubtitleFetchers);
-	}
-			
-	
-	if (!(m_subtitleFetcherOrder.size() == 0)) {
-		result["SubtitleFetcherOrder"] = Jellyfin::Support::toJsonValue<QStringList>(m_subtitleFetcherOrder);
-	}
-			
+	result["DisabledSubtitleFetchers"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledSubtitleFetchers);		
+	result["SubtitleFetcherOrder"] = Jellyfin::Support::toJsonValue<QStringList>(m_subtitleFetcherOrder);		
+	result["DisabledMediaSegmentProviders"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledMediaSegmentProviders);		
+	result["MediaSegmentProvideOrder"] = Jellyfin::Support::toJsonValue<QStringList>(m_mediaSegmentProvideOrder);		
 	result["SkipSubtitlesIfEmbeddedSubtitlesPresent"] = Jellyfin::Support::toJsonValue<bool>(m_skipSubtitlesIfEmbeddedSubtitlesPresent);		
 	result["SkipSubtitlesIfAudioTrackMatches"] = Jellyfin::Support::toJsonValue<bool>(m_skipSubtitlesIfAudioTrackMatches);		
 	
@@ -226,14 +310,26 @@ QJsonObject LibraryOptions::toJson() const {
 			
 	result["RequirePerfectSubtitleMatch"] = Jellyfin::Support::toJsonValue<bool>(m_requirePerfectSubtitleMatch);		
 	result["SaveSubtitlesWithMedia"] = Jellyfin::Support::toJsonValue<bool>(m_saveSubtitlesWithMedia);		
-	
-	if (!(m_typeOptions.size() == 0)) {
-		result["TypeOptions"] = Jellyfin::Support::toJsonValue<QList<TypeOptions>>(m_typeOptions);
-	}
-		
+	result["SaveLyricsWithMedia"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_saveLyricsWithMedia);		
+	result["SaveTrickplayWithMedia"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_saveTrickplayWithMedia);		
+	result["DisabledLyricFetchers"] = Jellyfin::Support::toJsonValue<QStringList>(m_disabledLyricFetchers);		
+	result["LyricFetcherOrder"] = Jellyfin::Support::toJsonValue<QStringList>(m_lyricFetcherOrder);		
+	result["PreferNonstandardArtistsTag"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_preferNonstandardArtistsTag);		
+	result["UseCustomTagDelimiters"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_useCustomTagDelimiters);		
+	result["CustomTagDelimiters"] = Jellyfin::Support::toJsonValue<QStringList>(m_customTagDelimiters);		
+	result["DelimiterWhitelist"] = Jellyfin::Support::toJsonValue<QStringList>(m_delimiterWhitelist);		
+	result["AutomaticallyAddToCollection"] = Jellyfin::Support::toJsonValue<bool>(m_automaticallyAddToCollection);		
+	result["AllowEmbeddedSubtitles"] = Jellyfin::Support::toJsonValue<EmbeddedSubtitleOptions>(m_allowEmbeddedSubtitles);		
+	result["TypeOptions"] = Jellyfin::Support::toJsonValue<QList<TypeOptions>>(m_typeOptions);	
 	return result;
 }
 
+bool LibraryOptions::enabled() const { return m_enabled; }
+
+void LibraryOptions::setEnabled(bool newEnabled) {
+	m_enabled = newEnabled;
+}
+
 bool LibraryOptions::enablePhotos() const { return m_enablePhotos; }
 
 void LibraryOptions::setEnablePhotos(bool newEnablePhotos) {
@@ -246,6 +342,12 @@ void LibraryOptions::setEnableRealtimeMonitor(bool newEnableRealtimeMonitor) {
 	m_enableRealtimeMonitor = newEnableRealtimeMonitor;
 }
 
+bool LibraryOptions::enableLUFSScan() const { return m_enableLUFSScan; }
+
+void LibraryOptions::setEnableLUFSScan(bool newEnableLUFSScan) {
+	m_enableLUFSScan = newEnableLUFSScan;
+}
+
 bool LibraryOptions::enableChapterImageExtraction() const { return m_enableChapterImageExtraction; }
 
 void LibraryOptions::setEnableChapterImageExtraction(bool newEnableChapterImageExtraction) {
@@ -258,19 +360,24 @@ void LibraryOptions::setExtractChapterImagesDuringLibraryScan(bool newExtractCha
 	m_extractChapterImagesDuringLibraryScan = newExtractChapterImagesDuringLibraryScan;
 }
 
+bool LibraryOptions::enableTrickplayImageExtraction() const { return m_enableTrickplayImageExtraction; }
+
+void LibraryOptions::setEnableTrickplayImageExtraction(bool newEnableTrickplayImageExtraction) {
+	m_enableTrickplayImageExtraction = newEnableTrickplayImageExtraction;
+}
+
+bool LibraryOptions::extractTrickplayImagesDuringLibraryScan() const { return m_extractTrickplayImagesDuringLibraryScan; }
+
+void LibraryOptions::setExtractTrickplayImagesDuringLibraryScan(bool newExtractTrickplayImagesDuringLibraryScan) {
+	m_extractTrickplayImagesDuringLibraryScan = newExtractTrickplayImagesDuringLibraryScan;
+}
+
 QList<MediaPathInfo> LibraryOptions::pathInfos() const { return m_pathInfos; }
 
 void LibraryOptions::setPathInfos(QList<MediaPathInfo> newPathInfos) {
 	m_pathInfos = newPathInfos;
 }
-bool LibraryOptions::pathInfosNull() const {
-	return m_pathInfos.size() == 0;
-}
 
-void LibraryOptions::setPathInfosNull() {
-	m_pathInfos.clear();
-
-}
 bool LibraryOptions::saveLocalMetadata() const { return m_saveLocalMetadata; }
 
 void LibraryOptions::setSaveLocalMetadata(bool newSaveLocalMetadata) {
@@ -295,6 +402,12 @@ void LibraryOptions::setEnableEmbeddedTitles(bool newEnableEmbeddedTitles) {
 	m_enableEmbeddedTitles = newEnableEmbeddedTitles;
 }
 
+bool LibraryOptions::enableEmbeddedExtrasTitles() const { return m_enableEmbeddedExtrasTitles; }
+
+void LibraryOptions::setEnableEmbeddedExtrasTitles(bool newEnableEmbeddedExtrasTitles) {
+	m_enableEmbeddedExtrasTitles = newEnableEmbeddedExtrasTitles;
+}
+
 bool LibraryOptions::enableEmbeddedEpisodeInfos() const { return m_enableEmbeddedEpisodeInfos; }
 
 void LibraryOptions::setEnableEmbeddedEpisodeInfos(bool newEnableEmbeddedEpisodeInfos) {
@@ -338,14 +451,7 @@ QString LibraryOptions::seasonZeroDisplayName() const { return m_seasonZeroDispl
 void LibraryOptions::setSeasonZeroDisplayName(QString newSeasonZeroDisplayName) {
 	m_seasonZeroDisplayName = newSeasonZeroDisplayName;
 }
-bool LibraryOptions::seasonZeroDisplayNameNull() const {
-	return m_seasonZeroDisplayName.isNull();
-}
 
-void LibraryOptions::setSeasonZeroDisplayNameNull() {
-	m_seasonZeroDisplayName.clear();
-
-}
 QStringList LibraryOptions::metadataSavers() const { return m_metadataSavers; }
 
 void LibraryOptions::setMetadataSavers(QStringList newMetadataSavers) {
@@ -364,14 +470,7 @@ QStringList LibraryOptions::disabledLocalMetadataReaders() const { return m_disa
 void LibraryOptions::setDisabledLocalMetadataReaders(QStringList newDisabledLocalMetadataReaders) {
 	m_disabledLocalMetadataReaders = newDisabledLocalMetadataReaders;
 }
-bool LibraryOptions::disabledLocalMetadataReadersNull() const {
-	return m_disabledLocalMetadataReaders.size() == 0;
-}
 
-void LibraryOptions::setDisabledLocalMetadataReadersNull() {
-	m_disabledLocalMetadataReaders.clear();
-
-}
 QStringList LibraryOptions::localMetadataReaderOrder() const { return m_localMetadataReaderOrder; }
 
 void LibraryOptions::setLocalMetadataReaderOrder(QStringList newLocalMetadataReaderOrder) {
@@ -390,27 +489,25 @@ QStringList LibraryOptions::disabledSubtitleFetchers() const { return m_disabled
 void LibraryOptions::setDisabledSubtitleFetchers(QStringList newDisabledSubtitleFetchers) {
 	m_disabledSubtitleFetchers = newDisabledSubtitleFetchers;
 }
-bool LibraryOptions::disabledSubtitleFetchersNull() const {
-	return m_disabledSubtitleFetchers.size() == 0;
-}
 
-void LibraryOptions::setDisabledSubtitleFetchersNull() {
-	m_disabledSubtitleFetchers.clear();
-
-}
 QStringList LibraryOptions::subtitleFetcherOrder() const { return m_subtitleFetcherOrder; }
 
 void LibraryOptions::setSubtitleFetcherOrder(QStringList newSubtitleFetcherOrder) {
 	m_subtitleFetcherOrder = newSubtitleFetcherOrder;
 }
-bool LibraryOptions::subtitleFetcherOrderNull() const {
-	return m_subtitleFetcherOrder.size() == 0;
+
+QStringList LibraryOptions::disabledMediaSegmentProviders() const { return m_disabledMediaSegmentProviders; }
+
+void LibraryOptions::setDisabledMediaSegmentProviders(QStringList newDisabledMediaSegmentProviders) {
+	m_disabledMediaSegmentProviders = newDisabledMediaSegmentProviders;
 }
 
-void LibraryOptions::setSubtitleFetcherOrderNull() {
-	m_subtitleFetcherOrder.clear();
+QStringList LibraryOptions::mediaSegmentProvideOrder() const { return m_mediaSegmentProvideOrder; }
 
+void LibraryOptions::setMediaSegmentProvideOrder(QStringList newMediaSegmentProvideOrder) {
+	m_mediaSegmentProvideOrder = newMediaSegmentProvideOrder;
 }
+
 bool LibraryOptions::skipSubtitlesIfEmbeddedSubtitlesPresent() const { return m_skipSubtitlesIfEmbeddedSubtitlesPresent; }
 
 void LibraryOptions::setSkipSubtitlesIfEmbeddedSubtitlesPresent(bool newSkipSubtitlesIfEmbeddedSubtitlesPresent) {
@@ -448,19 +545,72 @@ void LibraryOptions::setSaveSubtitlesWithMedia(bool newSaveSubtitlesWithMedia) {
 	m_saveSubtitlesWithMedia = newSaveSubtitlesWithMedia;
 }
 
+std::optional<bool> LibraryOptions::saveLyricsWithMedia() const { return m_saveLyricsWithMedia; }
+
+void LibraryOptions::setSaveLyricsWithMedia(std::optional<bool> newSaveLyricsWithMedia) {
+	m_saveLyricsWithMedia = newSaveLyricsWithMedia;
+}
+
+std::optional<bool> LibraryOptions::saveTrickplayWithMedia() const { return m_saveTrickplayWithMedia; }
+
+void LibraryOptions::setSaveTrickplayWithMedia(std::optional<bool> newSaveTrickplayWithMedia) {
+	m_saveTrickplayWithMedia = newSaveTrickplayWithMedia;
+}
+
+QStringList LibraryOptions::disabledLyricFetchers() const { return m_disabledLyricFetchers; }
+
+void LibraryOptions::setDisabledLyricFetchers(QStringList newDisabledLyricFetchers) {
+	m_disabledLyricFetchers = newDisabledLyricFetchers;
+}
+
+QStringList LibraryOptions::lyricFetcherOrder() const { return m_lyricFetcherOrder; }
+
+void LibraryOptions::setLyricFetcherOrder(QStringList newLyricFetcherOrder) {
+	m_lyricFetcherOrder = newLyricFetcherOrder;
+}
+
+std::optional<bool> LibraryOptions::preferNonstandardArtistsTag() const { return m_preferNonstandardArtistsTag; }
+
+void LibraryOptions::setPreferNonstandardArtistsTag(std::optional<bool> newPreferNonstandardArtistsTag) {
+	m_preferNonstandardArtistsTag = newPreferNonstandardArtistsTag;
+}
+
+std::optional<bool> LibraryOptions::useCustomTagDelimiters() const { return m_useCustomTagDelimiters; }
+
+void LibraryOptions::setUseCustomTagDelimiters(std::optional<bool> newUseCustomTagDelimiters) {
+	m_useCustomTagDelimiters = newUseCustomTagDelimiters;
+}
+
+QStringList LibraryOptions::customTagDelimiters() const { return m_customTagDelimiters; }
+
+void LibraryOptions::setCustomTagDelimiters(QStringList newCustomTagDelimiters) {
+	m_customTagDelimiters = newCustomTagDelimiters;
+}
+
+QStringList LibraryOptions::delimiterWhitelist() const { return m_delimiterWhitelist; }
+
+void LibraryOptions::setDelimiterWhitelist(QStringList newDelimiterWhitelist) {
+	m_delimiterWhitelist = newDelimiterWhitelist;
+}
+
+bool LibraryOptions::automaticallyAddToCollection() const { return m_automaticallyAddToCollection; }
+
+void LibraryOptions::setAutomaticallyAddToCollection(bool newAutomaticallyAddToCollection) {
+	m_automaticallyAddToCollection = newAutomaticallyAddToCollection;
+}
+
+EmbeddedSubtitleOptions LibraryOptions::allowEmbeddedSubtitles() const { return m_allowEmbeddedSubtitles; }
+
+void LibraryOptions::setAllowEmbeddedSubtitles(EmbeddedSubtitleOptions newAllowEmbeddedSubtitles) {
+	m_allowEmbeddedSubtitles = newAllowEmbeddedSubtitles;
+}
+
 QList<TypeOptions> LibraryOptions::typeOptions() const { return m_typeOptions; }
 
 void LibraryOptions::setTypeOptions(QList<TypeOptions> newTypeOptions) {
 	m_typeOptions = newTypeOptions;
 }
-bool LibraryOptions::typeOptionsNull() const {
-	return m_typeOptions.size() == 0;
-}
 
-void LibraryOptions::setTypeOptionsNull() {
-	m_typeOptions.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/libraryoptionsresultdto.cpp b/core/src/dto/libraryoptionsresultdto.cpp
index 33626dd..eff9670 100644
--- a/core/src/dto/libraryoptionsresultdto.cpp
+++ b/core/src/dto/libraryoptionsresultdto.cpp
@@ -33,12 +33,27 @@ namespace Jellyfin {
 namespace DTO {
 
 LibraryOptionsResultDto::LibraryOptionsResultDto() {}
+LibraryOptionsResultDto::LibraryOptionsResultDto (
+		QList<LibraryOptionInfoDto> metadataSavers, 
+		QList<LibraryOptionInfoDto> metadataReaders, 
+		QList<LibraryOptionInfoDto> subtitleFetchers, 
+		QList<LibraryOptionInfoDto> lyricFetchers, 
+		QList<LibraryTypeOptionsDto> typeOptions 
+		) :
+	m_metadataSavers(metadataSavers),
+	m_metadataReaders(metadataReaders),
+	m_subtitleFetchers(subtitleFetchers),
+	m_lyricFetchers(lyricFetchers),
+	m_typeOptions(typeOptions) { }
+
+
 
 LibraryOptionsResultDto::LibraryOptionsResultDto(const LibraryOptionsResultDto &other) :
 
 	m_metadataSavers(other.m_metadataSavers),
 	m_metadataReaders(other.m_metadataReaders),
 	m_subtitleFetchers(other.m_subtitleFetchers),
+	m_lyricFetchers(other.m_lyricFetchers),
 	m_typeOptions(other.m_typeOptions){}
 
 
@@ -46,6 +61,7 @@ void LibraryOptionsResultDto::replaceData(LibraryOptionsResultDto &other) {
 	m_metadataSavers = other.m_metadataSavers;
 	m_metadataReaders = other.m_metadataReaders;
 	m_subtitleFetchers = other.m_subtitleFetchers;
+	m_lyricFetchers = other.m_lyricFetchers;
 	m_typeOptions = other.m_typeOptions;
 }
 
@@ -60,6 +76,7 @@ void LibraryOptionsResultDto::setFromJson(QJsonObject source) {
 	m_metadataSavers = Jellyfin::Support::fromJsonValue<QList<LibraryOptionInfoDto>>(source["MetadataSavers"]);
 	m_metadataReaders = Jellyfin::Support::fromJsonValue<QList<LibraryOptionInfoDto>>(source["MetadataReaders"]);
 	m_subtitleFetchers = Jellyfin::Support::fromJsonValue<QList<LibraryOptionInfoDto>>(source["SubtitleFetchers"]);
+	m_lyricFetchers = Jellyfin::Support::fromJsonValue<QList<LibraryOptionInfoDto>>(source["LyricFetchers"]);
 	m_typeOptions = Jellyfin::Support::fromJsonValue<QList<LibraryTypeOptionsDto>>(source["TypeOptions"]);
 
 }
@@ -67,26 +84,11 @@ void LibraryOptionsResultDto::setFromJson(QJsonObject source) {
 QJsonObject LibraryOptionsResultDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_metadataSavers.size() == 0)) {
-		result["MetadataSavers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataSavers);
-	}
-			
-	
-	if (!(m_metadataReaders.size() == 0)) {
-		result["MetadataReaders"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataReaders);
-	}
-			
-	
-	if (!(m_subtitleFetchers.size() == 0)) {
-		result["SubtitleFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_subtitleFetchers);
-	}
-			
-	
-	if (!(m_typeOptions.size() == 0)) {
-		result["TypeOptions"] = Jellyfin::Support::toJsonValue<QList<LibraryTypeOptionsDto>>(m_typeOptions);
-	}
-		
+	result["MetadataSavers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataSavers);		
+	result["MetadataReaders"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataReaders);		
+	result["SubtitleFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_subtitleFetchers);		
+	result["LyricFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_lyricFetchers);		
+	result["TypeOptions"] = Jellyfin::Support::toJsonValue<QList<LibraryTypeOptionsDto>>(m_typeOptions);	
 	return result;
 }
 
@@ -95,53 +97,31 @@ QList<LibraryOptionInfoDto> LibraryOptionsResultDto::metadataSavers() const { re
 void LibraryOptionsResultDto::setMetadataSavers(QList<LibraryOptionInfoDto> newMetadataSavers) {
 	m_metadataSavers = newMetadataSavers;
 }
-bool LibraryOptionsResultDto::metadataSaversNull() const {
-	return m_metadataSavers.size() == 0;
-}
 
-void LibraryOptionsResultDto::setMetadataSaversNull() {
-	m_metadataSavers.clear();
-
-}
 QList<LibraryOptionInfoDto> LibraryOptionsResultDto::metadataReaders() const { return m_metadataReaders; }
 
 void LibraryOptionsResultDto::setMetadataReaders(QList<LibraryOptionInfoDto> newMetadataReaders) {
 	m_metadataReaders = newMetadataReaders;
 }
-bool LibraryOptionsResultDto::metadataReadersNull() const {
-	return m_metadataReaders.size() == 0;
-}
 
-void LibraryOptionsResultDto::setMetadataReadersNull() {
-	m_metadataReaders.clear();
-
-}
 QList<LibraryOptionInfoDto> LibraryOptionsResultDto::subtitleFetchers() const { return m_subtitleFetchers; }
 
 void LibraryOptionsResultDto::setSubtitleFetchers(QList<LibraryOptionInfoDto> newSubtitleFetchers) {
 	m_subtitleFetchers = newSubtitleFetchers;
 }
-bool LibraryOptionsResultDto::subtitleFetchersNull() const {
-	return m_subtitleFetchers.size() == 0;
+
+QList<LibraryOptionInfoDto> LibraryOptionsResultDto::lyricFetchers() const { return m_lyricFetchers; }
+
+void LibraryOptionsResultDto::setLyricFetchers(QList<LibraryOptionInfoDto> newLyricFetchers) {
+	m_lyricFetchers = newLyricFetchers;
 }
 
-void LibraryOptionsResultDto::setSubtitleFetchersNull() {
-	m_subtitleFetchers.clear();
-
-}
 QList<LibraryTypeOptionsDto> LibraryOptionsResultDto::typeOptions() const { return m_typeOptions; }
 
 void LibraryOptionsResultDto::setTypeOptions(QList<LibraryTypeOptionsDto> newTypeOptions) {
 	m_typeOptions = newTypeOptions;
 }
-bool LibraryOptionsResultDto::typeOptionsNull() const {
-	return m_typeOptions.size() == 0;
-}
 
-void LibraryOptionsResultDto::setTypeOptionsNull() {
-	m_typeOptions.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/librarytypeoptionsdto.cpp b/core/src/dto/librarytypeoptionsdto.cpp
index 73371c9..96d9b9e 100644
--- a/core/src/dto/librarytypeoptionsdto.cpp
+++ b/core/src/dto/librarytypeoptionsdto.cpp
@@ -33,6 +33,18 @@ namespace Jellyfin {
 namespace DTO {
 
 LibraryTypeOptionsDto::LibraryTypeOptionsDto() {}
+LibraryTypeOptionsDto::LibraryTypeOptionsDto (
+		QList<LibraryOptionInfoDto> metadataFetchers, 
+		QList<LibraryOptionInfoDto> imageFetchers, 
+		QList<ImageType> supportedImageTypes, 
+		QList<ImageOption> defaultImageOptions 
+		) :
+	m_metadataFetchers(metadataFetchers),
+	m_imageFetchers(imageFetchers),
+	m_supportedImageTypes(supportedImageTypes),
+	m_defaultImageOptions(defaultImageOptions) { }
+
+
 
 LibraryTypeOptionsDto::LibraryTypeOptionsDto(const LibraryTypeOptionsDto &other) :
 
@@ -75,26 +87,10 @@ QJsonObject LibraryTypeOptionsDto::toJson() const {
 		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
 	}
 			
-	
-	if (!(m_metadataFetchers.size() == 0)) {
-		result["MetadataFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataFetchers);
-	}
-			
-	
-	if (!(m_imageFetchers.size() == 0)) {
-		result["ImageFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_imageFetchers);
-	}
-			
-	
-	if (!(m_supportedImageTypes.size() == 0)) {
-		result["SupportedImageTypes"] = Jellyfin::Support::toJsonValue<QList<ImageType>>(m_supportedImageTypes);
-	}
-			
-	
-	if (!(m_defaultImageOptions.size() == 0)) {
-		result["DefaultImageOptions"] = Jellyfin::Support::toJsonValue<QList<ImageOption>>(m_defaultImageOptions);
-	}
-		
+	result["MetadataFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_metadataFetchers);		
+	result["ImageFetchers"] = Jellyfin::Support::toJsonValue<QList<LibraryOptionInfoDto>>(m_imageFetchers);		
+	result["SupportedImageTypes"] = Jellyfin::Support::toJsonValue<QList<ImageType>>(m_supportedImageTypes);		
+	result["DefaultImageOptions"] = Jellyfin::Support::toJsonValue<QList<ImageOption>>(m_defaultImageOptions);	
 	return result;
 }
 
@@ -116,53 +112,25 @@ QList<LibraryOptionInfoDto> LibraryTypeOptionsDto::metadataFetchers() const { re
 void LibraryTypeOptionsDto::setMetadataFetchers(QList<LibraryOptionInfoDto> newMetadataFetchers) {
 	m_metadataFetchers = newMetadataFetchers;
 }
-bool LibraryTypeOptionsDto::metadataFetchersNull() const {
-	return m_metadataFetchers.size() == 0;
-}
 
-void LibraryTypeOptionsDto::setMetadataFetchersNull() {
-	m_metadataFetchers.clear();
-
-}
 QList<LibraryOptionInfoDto> LibraryTypeOptionsDto::imageFetchers() const { return m_imageFetchers; }
 
 void LibraryTypeOptionsDto::setImageFetchers(QList<LibraryOptionInfoDto> newImageFetchers) {
 	m_imageFetchers = newImageFetchers;
 }
-bool LibraryTypeOptionsDto::imageFetchersNull() const {
-	return m_imageFetchers.size() == 0;
-}
 
-void LibraryTypeOptionsDto::setImageFetchersNull() {
-	m_imageFetchers.clear();
-
-}
 QList<ImageType> LibraryTypeOptionsDto::supportedImageTypes() const { return m_supportedImageTypes; }
 
 void LibraryTypeOptionsDto::setSupportedImageTypes(QList<ImageType> newSupportedImageTypes) {
 	m_supportedImageTypes = newSupportedImageTypes;
 }
-bool LibraryTypeOptionsDto::supportedImageTypesNull() const {
-	return m_supportedImageTypes.size() == 0;
-}
 
-void LibraryTypeOptionsDto::setSupportedImageTypesNull() {
-	m_supportedImageTypes.clear();
-
-}
 QList<ImageOption> LibraryTypeOptionsDto::defaultImageOptions() const { return m_defaultImageOptions; }
 
 void LibraryTypeOptionsDto::setDefaultImageOptions(QList<ImageOption> newDefaultImageOptions) {
 	m_defaultImageOptions = newDefaultImageOptions;
 }
-bool LibraryTypeOptionsDto::defaultImageOptionsNull() const {
-	return m_defaultImageOptions.size() == 0;
-}
 
-void LibraryTypeOptionsDto::setDefaultImageOptionsNull() {
-	m_defaultImageOptions.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/libraryupdateinfo.cpp b/core/src/dto/libraryupdateinfo.cpp
index 90261dd..7a493a2 100644
--- a/core/src/dto/libraryupdateinfo.cpp
+++ b/core/src/dto/libraryupdateinfo.cpp
@@ -34,8 +34,20 @@ namespace DTO {
 
 LibraryUpdateInfo::LibraryUpdateInfo() {}
 LibraryUpdateInfo::LibraryUpdateInfo (
+		QStringList foldersAddedTo, 
+		QStringList foldersRemovedFrom, 
+		QStringList itemsAdded, 
+		QStringList itemsRemoved, 
+		QStringList itemsUpdated, 
+		QStringList collectionFolders, 
 		bool isEmpty 
 		) :
+	m_foldersAddedTo(foldersAddedTo),
+	m_foldersRemovedFrom(foldersRemovedFrom),
+	m_itemsAdded(itemsAdded),
+	m_itemsRemoved(itemsRemoved),
+	m_itemsUpdated(itemsUpdated),
+	m_collectionFolders(collectionFolders),
 	m_isEmpty(isEmpty) { }
 
 
@@ -82,36 +94,12 @@ void LibraryUpdateInfo::setFromJson(QJsonObject source) {
 QJsonObject LibraryUpdateInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_foldersAddedTo.size() == 0)) {
-		result["FoldersAddedTo"] = Jellyfin::Support::toJsonValue<QStringList>(m_foldersAddedTo);
-	}
-			
-	
-	if (!(m_foldersRemovedFrom.size() == 0)) {
-		result["FoldersRemovedFrom"] = Jellyfin::Support::toJsonValue<QStringList>(m_foldersRemovedFrom);
-	}
-			
-	
-	if (!(m_itemsAdded.size() == 0)) {
-		result["ItemsAdded"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsAdded);
-	}
-			
-	
-	if (!(m_itemsRemoved.size() == 0)) {
-		result["ItemsRemoved"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsRemoved);
-	}
-			
-	
-	if (!(m_itemsUpdated.size() == 0)) {
-		result["ItemsUpdated"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsUpdated);
-	}
-			
-	
-	if (!(m_collectionFolders.size() == 0)) {
-		result["CollectionFolders"] = Jellyfin::Support::toJsonValue<QStringList>(m_collectionFolders);
-	}
-			
+	result["FoldersAddedTo"] = Jellyfin::Support::toJsonValue<QStringList>(m_foldersAddedTo);		
+	result["FoldersRemovedFrom"] = Jellyfin::Support::toJsonValue<QStringList>(m_foldersRemovedFrom);		
+	result["ItemsAdded"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsAdded);		
+	result["ItemsRemoved"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsRemoved);		
+	result["ItemsUpdated"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemsUpdated);		
+	result["CollectionFolders"] = Jellyfin::Support::toJsonValue<QStringList>(m_collectionFolders);		
 	result["IsEmpty"] = Jellyfin::Support::toJsonValue<bool>(m_isEmpty);	
 	return result;
 }
@@ -121,79 +109,37 @@ QStringList LibraryUpdateInfo::foldersAddedTo() const { return m_foldersAddedTo;
 void LibraryUpdateInfo::setFoldersAddedTo(QStringList newFoldersAddedTo) {
 	m_foldersAddedTo = newFoldersAddedTo;
 }
-bool LibraryUpdateInfo::foldersAddedToNull() const {
-	return m_foldersAddedTo.size() == 0;
-}
 
-void LibraryUpdateInfo::setFoldersAddedToNull() {
-	m_foldersAddedTo.clear();
-
-}
 QStringList LibraryUpdateInfo::foldersRemovedFrom() const { return m_foldersRemovedFrom; }
 
 void LibraryUpdateInfo::setFoldersRemovedFrom(QStringList newFoldersRemovedFrom) {
 	m_foldersRemovedFrom = newFoldersRemovedFrom;
 }
-bool LibraryUpdateInfo::foldersRemovedFromNull() const {
-	return m_foldersRemovedFrom.size() == 0;
-}
 
-void LibraryUpdateInfo::setFoldersRemovedFromNull() {
-	m_foldersRemovedFrom.clear();
-
-}
 QStringList LibraryUpdateInfo::itemsAdded() const { return m_itemsAdded; }
 
 void LibraryUpdateInfo::setItemsAdded(QStringList newItemsAdded) {
 	m_itemsAdded = newItemsAdded;
 }
-bool LibraryUpdateInfo::itemsAddedNull() const {
-	return m_itemsAdded.size() == 0;
-}
 
-void LibraryUpdateInfo::setItemsAddedNull() {
-	m_itemsAdded.clear();
-
-}
 QStringList LibraryUpdateInfo::itemsRemoved() const { return m_itemsRemoved; }
 
 void LibraryUpdateInfo::setItemsRemoved(QStringList newItemsRemoved) {
 	m_itemsRemoved = newItemsRemoved;
 }
-bool LibraryUpdateInfo::itemsRemovedNull() const {
-	return m_itemsRemoved.size() == 0;
-}
 
-void LibraryUpdateInfo::setItemsRemovedNull() {
-	m_itemsRemoved.clear();
-
-}
 QStringList LibraryUpdateInfo::itemsUpdated() const { return m_itemsUpdated; }
 
 void LibraryUpdateInfo::setItemsUpdated(QStringList newItemsUpdated) {
 	m_itemsUpdated = newItemsUpdated;
 }
-bool LibraryUpdateInfo::itemsUpdatedNull() const {
-	return m_itemsUpdated.size() == 0;
-}
 
-void LibraryUpdateInfo::setItemsUpdatedNull() {
-	m_itemsUpdated.clear();
-
-}
 QStringList LibraryUpdateInfo::collectionFolders() const { return m_collectionFolders; }
 
 void LibraryUpdateInfo::setCollectionFolders(QStringList newCollectionFolders) {
 	m_collectionFolders = newCollectionFolders;
 }
-bool LibraryUpdateInfo::collectionFoldersNull() const {
-	return m_collectionFolders.size() == 0;
-}
 
-void LibraryUpdateInfo::setCollectionFoldersNull() {
-	m_collectionFolders.clear();
-
-}
 bool LibraryUpdateInfo::isEmpty() const { return m_isEmpty; }
 
 void LibraryUpdateInfo::setIsEmpty(bool newIsEmpty) {
diff --git a/core/src/dto/livetvinfo.cpp b/core/src/dto/livetvinfo.cpp
index 3947169..843cd62 100644
--- a/core/src/dto/livetvinfo.cpp
+++ b/core/src/dto/livetvinfo.cpp
@@ -34,9 +34,13 @@ namespace DTO {
 
 LiveTvInfo::LiveTvInfo() {}
 LiveTvInfo::LiveTvInfo (
-		bool isEnabled 
+		QList<LiveTvServiceInfo> services, 
+		bool isEnabled, 
+		QStringList enabledUsers 
 		) :
-	m_isEnabled(isEnabled) { }
+	m_services(services),
+	m_isEnabled(isEnabled),
+	m_enabledUsers(enabledUsers) { }
 
 
 
@@ -70,17 +74,9 @@ void LiveTvInfo::setFromJson(QJsonObject source) {
 QJsonObject LiveTvInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_services.size() == 0)) {
-		result["Services"] = Jellyfin::Support::toJsonValue<QList<LiveTvServiceInfo>>(m_services);
-	}
-			
+	result["Services"] = Jellyfin::Support::toJsonValue<QList<LiveTvServiceInfo>>(m_services);		
 	result["IsEnabled"] = Jellyfin::Support::toJsonValue<bool>(m_isEnabled);		
-	
-	if (!(m_enabledUsers.size() == 0)) {
-		result["EnabledUsers"] = Jellyfin::Support::toJsonValue<QStringList>(m_enabledUsers);
-	}
-		
+	result["EnabledUsers"] = Jellyfin::Support::toJsonValue<QStringList>(m_enabledUsers);	
 	return result;
 }
 
@@ -89,14 +85,7 @@ QList<LiveTvServiceInfo> LiveTvInfo::services() const { return m_services; }
 void LiveTvInfo::setServices(QList<LiveTvServiceInfo> newServices) {
 	m_services = newServices;
 }
-bool LiveTvInfo::servicesNull() const {
-	return m_services.size() == 0;
-}
 
-void LiveTvInfo::setServicesNull() {
-	m_services.clear();
-
-}
 bool LiveTvInfo::isEnabled() const { return m_isEnabled; }
 
 void LiveTvInfo::setIsEnabled(bool newIsEnabled) {
@@ -108,14 +97,7 @@ QStringList LiveTvInfo::enabledUsers() const { return m_enabledUsers; }
 void LiveTvInfo::setEnabledUsers(QStringList newEnabledUsers) {
 	m_enabledUsers = newEnabledUsers;
 }
-bool LiveTvInfo::enabledUsersNull() const {
-	return m_enabledUsers.size() == 0;
-}
 
-void LiveTvInfo::setEnabledUsersNull() {
-	m_enabledUsers.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/livetvoptions.cpp b/core/src/dto/livetvoptions.cpp
new file mode 100644
index 0000000..dc5dab3
--- /dev/null
+++ b/core/src/dto/livetvoptions.cpp
@@ -0,0 +1,345 @@
+/*
+ * 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/dto/livetvoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+LiveTvOptions::LiveTvOptions() {}
+LiveTvOptions::LiveTvOptions (
+		bool enableRecordingSubfolders, 
+		bool enableOriginalAudioWithEncodedRecordings, 
+		qint32 prePaddingSeconds, 
+		qint32 postPaddingSeconds, 
+		bool saveRecordingNFO, 
+		bool saveRecordingImages 
+		) :
+	m_enableRecordingSubfolders(enableRecordingSubfolders),
+	m_enableOriginalAudioWithEncodedRecordings(enableOriginalAudioWithEncodedRecordings),
+	m_prePaddingSeconds(prePaddingSeconds),
+	m_postPaddingSeconds(postPaddingSeconds),
+	m_saveRecordingNFO(saveRecordingNFO),
+	m_saveRecordingImages(saveRecordingImages) { }
+
+
+
+LiveTvOptions::LiveTvOptions(const LiveTvOptions &other) :
+
+	m_guideDays(other.m_guideDays),
+	m_recordingPath(other.m_recordingPath),
+	m_movieRecordingPath(other.m_movieRecordingPath),
+	m_seriesRecordingPath(other.m_seriesRecordingPath),
+	m_enableRecordingSubfolders(other.m_enableRecordingSubfolders),
+	m_enableOriginalAudioWithEncodedRecordings(other.m_enableOriginalAudioWithEncodedRecordings),
+	m_tunerHosts(other.m_tunerHosts),
+	m_listingProviders(other.m_listingProviders),
+	m_prePaddingSeconds(other.m_prePaddingSeconds),
+	m_postPaddingSeconds(other.m_postPaddingSeconds),
+	m_mediaLocationsCreated(other.m_mediaLocationsCreated),
+	m_recordingPostProcessor(other.m_recordingPostProcessor),
+	m_recordingPostProcessorArguments(other.m_recordingPostProcessorArguments),
+	m_saveRecordingNFO(other.m_saveRecordingNFO),
+	m_saveRecordingImages(other.m_saveRecordingImages){}
+
+
+void LiveTvOptions::replaceData(LiveTvOptions &other) {
+	m_guideDays = other.m_guideDays;
+	m_recordingPath = other.m_recordingPath;
+	m_movieRecordingPath = other.m_movieRecordingPath;
+	m_seriesRecordingPath = other.m_seriesRecordingPath;
+	m_enableRecordingSubfolders = other.m_enableRecordingSubfolders;
+	m_enableOriginalAudioWithEncodedRecordings = other.m_enableOriginalAudioWithEncodedRecordings;
+	m_tunerHosts = other.m_tunerHosts;
+	m_listingProviders = other.m_listingProviders;
+	m_prePaddingSeconds = other.m_prePaddingSeconds;
+	m_postPaddingSeconds = other.m_postPaddingSeconds;
+	m_mediaLocationsCreated = other.m_mediaLocationsCreated;
+	m_recordingPostProcessor = other.m_recordingPostProcessor;
+	m_recordingPostProcessorArguments = other.m_recordingPostProcessorArguments;
+	m_saveRecordingNFO = other.m_saveRecordingNFO;
+	m_saveRecordingImages = other.m_saveRecordingImages;
+}
+
+LiveTvOptions LiveTvOptions::fromJson(QJsonObject source) {
+	LiveTvOptions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void LiveTvOptions::setFromJson(QJsonObject source) {
+	m_guideDays = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["GuideDays"]);
+	m_recordingPath = Jellyfin::Support::fromJsonValue<QString>(source["RecordingPath"]);
+	m_movieRecordingPath = Jellyfin::Support::fromJsonValue<QString>(source["MovieRecordingPath"]);
+	m_seriesRecordingPath = Jellyfin::Support::fromJsonValue<QString>(source["SeriesRecordingPath"]);
+	m_enableRecordingSubfolders = Jellyfin::Support::fromJsonValue<bool>(source["EnableRecordingSubfolders"]);
+	m_enableOriginalAudioWithEncodedRecordings = Jellyfin::Support::fromJsonValue<bool>(source["EnableOriginalAudioWithEncodedRecordings"]);
+	m_tunerHosts = Jellyfin::Support::fromJsonValue<QList<TunerHostInfo>>(source["TunerHosts"]);
+	m_listingProviders = Jellyfin::Support::fromJsonValue<QList<ListingsProviderInfo>>(source["ListingProviders"]);
+	m_prePaddingSeconds = Jellyfin::Support::fromJsonValue<qint32>(source["PrePaddingSeconds"]);
+	m_postPaddingSeconds = Jellyfin::Support::fromJsonValue<qint32>(source["PostPaddingSeconds"]);
+	m_mediaLocationsCreated = Jellyfin::Support::fromJsonValue<QStringList>(source["MediaLocationsCreated"]);
+	m_recordingPostProcessor = Jellyfin::Support::fromJsonValue<QString>(source["RecordingPostProcessor"]);
+	m_recordingPostProcessorArguments = Jellyfin::Support::fromJsonValue<QString>(source["RecordingPostProcessorArguments"]);
+	m_saveRecordingNFO = Jellyfin::Support::fromJsonValue<bool>(source["SaveRecordingNFO"]);
+	m_saveRecordingImages = Jellyfin::Support::fromJsonValue<bool>(source["SaveRecordingImages"]);
+
+}
+	
+QJsonObject LiveTvOptions::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(!m_guideDays.has_value())) {
+		result["GuideDays"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_guideDays);
+	}
+			
+	
+	if (!(m_recordingPath.isNull())) {
+		result["RecordingPath"] = Jellyfin::Support::toJsonValue<QString>(m_recordingPath);
+	}
+			
+	
+	if (!(m_movieRecordingPath.isNull())) {
+		result["MovieRecordingPath"] = Jellyfin::Support::toJsonValue<QString>(m_movieRecordingPath);
+	}
+			
+	
+	if (!(m_seriesRecordingPath.isNull())) {
+		result["SeriesRecordingPath"] = Jellyfin::Support::toJsonValue<QString>(m_seriesRecordingPath);
+	}
+			
+	result["EnableRecordingSubfolders"] = Jellyfin::Support::toJsonValue<bool>(m_enableRecordingSubfolders);		
+	result["EnableOriginalAudioWithEncodedRecordings"] = Jellyfin::Support::toJsonValue<bool>(m_enableOriginalAudioWithEncodedRecordings);		
+	
+	if (!(m_tunerHosts.size() == 0)) {
+		result["TunerHosts"] = Jellyfin::Support::toJsonValue<QList<TunerHostInfo>>(m_tunerHosts);
+	}
+			
+	
+	if (!(m_listingProviders.size() == 0)) {
+		result["ListingProviders"] = Jellyfin::Support::toJsonValue<QList<ListingsProviderInfo>>(m_listingProviders);
+	}
+			
+	result["PrePaddingSeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_prePaddingSeconds);		
+	result["PostPaddingSeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_postPaddingSeconds);		
+	
+	if (!(m_mediaLocationsCreated.size() == 0)) {
+		result["MediaLocationsCreated"] = Jellyfin::Support::toJsonValue<QStringList>(m_mediaLocationsCreated);
+	}
+			
+	
+	if (!(m_recordingPostProcessor.isNull())) {
+		result["RecordingPostProcessor"] = Jellyfin::Support::toJsonValue<QString>(m_recordingPostProcessor);
+	}
+			
+	
+	if (!(m_recordingPostProcessorArguments.isNull())) {
+		result["RecordingPostProcessorArguments"] = Jellyfin::Support::toJsonValue<QString>(m_recordingPostProcessorArguments);
+	}
+			
+	result["SaveRecordingNFO"] = Jellyfin::Support::toJsonValue<bool>(m_saveRecordingNFO);		
+	result["SaveRecordingImages"] = Jellyfin::Support::toJsonValue<bool>(m_saveRecordingImages);	
+	return result;
+}
+
+std::optional<qint32> LiveTvOptions::guideDays() const { return m_guideDays; }
+
+void LiveTvOptions::setGuideDays(std::optional<qint32> newGuideDays) {
+	m_guideDays = newGuideDays;
+}
+bool LiveTvOptions::guideDaysNull() const {
+	return !m_guideDays.has_value();
+}
+
+void LiveTvOptions::setGuideDaysNull() {
+	m_guideDays = std::nullopt;
+
+}
+QString LiveTvOptions::recordingPath() const { return m_recordingPath; }
+
+void LiveTvOptions::setRecordingPath(QString newRecordingPath) {
+	m_recordingPath = newRecordingPath;
+}
+bool LiveTvOptions::recordingPathNull() const {
+	return m_recordingPath.isNull();
+}
+
+void LiveTvOptions::setRecordingPathNull() {
+	m_recordingPath.clear();
+
+}
+QString LiveTvOptions::movieRecordingPath() const { return m_movieRecordingPath; }
+
+void LiveTvOptions::setMovieRecordingPath(QString newMovieRecordingPath) {
+	m_movieRecordingPath = newMovieRecordingPath;
+}
+bool LiveTvOptions::movieRecordingPathNull() const {
+	return m_movieRecordingPath.isNull();
+}
+
+void LiveTvOptions::setMovieRecordingPathNull() {
+	m_movieRecordingPath.clear();
+
+}
+QString LiveTvOptions::seriesRecordingPath() const { return m_seriesRecordingPath; }
+
+void LiveTvOptions::setSeriesRecordingPath(QString newSeriesRecordingPath) {
+	m_seriesRecordingPath = newSeriesRecordingPath;
+}
+bool LiveTvOptions::seriesRecordingPathNull() const {
+	return m_seriesRecordingPath.isNull();
+}
+
+void LiveTvOptions::setSeriesRecordingPathNull() {
+	m_seriesRecordingPath.clear();
+
+}
+bool LiveTvOptions::enableRecordingSubfolders() const { return m_enableRecordingSubfolders; }
+
+void LiveTvOptions::setEnableRecordingSubfolders(bool newEnableRecordingSubfolders) {
+	m_enableRecordingSubfolders = newEnableRecordingSubfolders;
+}
+
+bool LiveTvOptions::enableOriginalAudioWithEncodedRecordings() const { return m_enableOriginalAudioWithEncodedRecordings; }
+
+void LiveTvOptions::setEnableOriginalAudioWithEncodedRecordings(bool newEnableOriginalAudioWithEncodedRecordings) {
+	m_enableOriginalAudioWithEncodedRecordings = newEnableOriginalAudioWithEncodedRecordings;
+}
+
+QList<TunerHostInfo> LiveTvOptions::tunerHosts() const { return m_tunerHosts; }
+
+void LiveTvOptions::setTunerHosts(QList<TunerHostInfo> newTunerHosts) {
+	m_tunerHosts = newTunerHosts;
+}
+bool LiveTvOptions::tunerHostsNull() const {
+	return m_tunerHosts.size() == 0;
+}
+
+void LiveTvOptions::setTunerHostsNull() {
+	m_tunerHosts.clear();
+
+}
+QList<ListingsProviderInfo> LiveTvOptions::listingProviders() const { return m_listingProviders; }
+
+void LiveTvOptions::setListingProviders(QList<ListingsProviderInfo> newListingProviders) {
+	m_listingProviders = newListingProviders;
+}
+bool LiveTvOptions::listingProvidersNull() const {
+	return m_listingProviders.size() == 0;
+}
+
+void LiveTvOptions::setListingProvidersNull() {
+	m_listingProviders.clear();
+
+}
+qint32 LiveTvOptions::prePaddingSeconds() const { return m_prePaddingSeconds; }
+
+void LiveTvOptions::setPrePaddingSeconds(qint32 newPrePaddingSeconds) {
+	m_prePaddingSeconds = newPrePaddingSeconds;
+}
+
+qint32 LiveTvOptions::postPaddingSeconds() const { return m_postPaddingSeconds; }
+
+void LiveTvOptions::setPostPaddingSeconds(qint32 newPostPaddingSeconds) {
+	m_postPaddingSeconds = newPostPaddingSeconds;
+}
+
+QStringList LiveTvOptions::mediaLocationsCreated() const { return m_mediaLocationsCreated; }
+
+void LiveTvOptions::setMediaLocationsCreated(QStringList newMediaLocationsCreated) {
+	m_mediaLocationsCreated = newMediaLocationsCreated;
+}
+bool LiveTvOptions::mediaLocationsCreatedNull() const {
+	return m_mediaLocationsCreated.size() == 0;
+}
+
+void LiveTvOptions::setMediaLocationsCreatedNull() {
+	m_mediaLocationsCreated.clear();
+
+}
+QString LiveTvOptions::recordingPostProcessor() const { return m_recordingPostProcessor; }
+
+void LiveTvOptions::setRecordingPostProcessor(QString newRecordingPostProcessor) {
+	m_recordingPostProcessor = newRecordingPostProcessor;
+}
+bool LiveTvOptions::recordingPostProcessorNull() const {
+	return m_recordingPostProcessor.isNull();
+}
+
+void LiveTvOptions::setRecordingPostProcessorNull() {
+	m_recordingPostProcessor.clear();
+
+}
+QString LiveTvOptions::recordingPostProcessorArguments() const { return m_recordingPostProcessorArguments; }
+
+void LiveTvOptions::setRecordingPostProcessorArguments(QString newRecordingPostProcessorArguments) {
+	m_recordingPostProcessorArguments = newRecordingPostProcessorArguments;
+}
+bool LiveTvOptions::recordingPostProcessorArgumentsNull() const {
+	return m_recordingPostProcessorArguments.isNull();
+}
+
+void LiveTvOptions::setRecordingPostProcessorArgumentsNull() {
+	m_recordingPostProcessorArguments.clear();
+
+}
+bool LiveTvOptions::saveRecordingNFO() const { return m_saveRecordingNFO; }
+
+void LiveTvOptions::setSaveRecordingNFO(bool newSaveRecordingNFO) {
+	m_saveRecordingNFO = newSaveRecordingNFO;
+}
+
+bool LiveTvOptions::saveRecordingImages() const { return m_saveRecordingImages; }
+
+void LiveTvOptions::setSaveRecordingImages(bool newSaveRecordingImages) {
+	m_saveRecordingImages = newSaveRecordingImages;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using LiveTvOptions = Jellyfin::DTO::LiveTvOptions;
+
+template <>
+LiveTvOptions fromJsonValue(const QJsonValue &source, convertType<LiveTvOptions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return LiveTvOptions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const LiveTvOptions &source, convertType<LiveTvOptions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/logfile.cpp b/core/src/dto/logfile.cpp
index 4537f41..a082d8d 100644
--- a/core/src/dto/logfile.cpp
+++ b/core/src/dto/logfile.cpp
@@ -36,11 +36,13 @@ LogFile::LogFile() {}
 LogFile::LogFile (
 		QDateTime dateCreated, 
 		QDateTime dateModified, 
-		qint64 size 
+		qint64 size, 
+		QString name 
 		) :
 	m_dateCreated(dateCreated),
 	m_dateModified(dateModified),
-	m_size(size) { }
+	m_size(size),
+	m_name(name) { }
 
 
 
@@ -80,11 +82,7 @@ QJsonObject LogFile::toJson() const {
 	result["DateCreated"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateCreated);		
 	result["DateModified"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateModified);		
 	result["Size"] = Jellyfin::Support::toJsonValue<qint64>(m_size);		
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-		
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);	
 	return result;
 }
 
@@ -111,14 +109,7 @@ QString LogFile::name() const { return m_name; }
 void LogFile::setName(QString newName) {
 	m_name = newName;
 }
-bool LogFile::nameNull() const {
-	return m_name.isNull();
-}
 
-void LogFile::setNameNull() {
-	m_name.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/lyricdto.cpp b/core/src/dto/lyricdto.cpp
new file mode 100644
index 0000000..3d6a5fd
--- /dev/null
+++ b/core/src/dto/lyricdto.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/lyricdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+LyricDto::LyricDto() {}
+LyricDto::LyricDto (
+		QSharedPointer<LyricMetadata> metadata, 
+		QList<LyricLine> lyrics 
+		) :
+	m_metadata(metadata),
+	m_lyrics(lyrics) { }
+
+
+
+LyricDto::LyricDto(const LyricDto &other) :
+
+	m_metadata(other.m_metadata),
+	m_lyrics(other.m_lyrics){}
+
+
+void LyricDto::replaceData(LyricDto &other) {
+	m_metadata = other.m_metadata;
+	m_lyrics = other.m_lyrics;
+}
+
+LyricDto LyricDto::fromJson(QJsonObject source) {
+	LyricDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void LyricDto::setFromJson(QJsonObject source) {
+	m_metadata = Jellyfin::Support::fromJsonValue<QSharedPointer<LyricMetadata>>(source["Metadata"]);
+	m_lyrics = Jellyfin::Support::fromJsonValue<QList<LyricLine>>(source["Lyrics"]);
+
+}
+	
+QJsonObject LyricDto::toJson() const {
+	QJsonObject result;
+	
+	result["Metadata"] = Jellyfin::Support::toJsonValue<QSharedPointer<LyricMetadata>>(m_metadata);		
+	result["Lyrics"] = Jellyfin::Support::toJsonValue<QList<LyricLine>>(m_lyrics);	
+	return result;
+}
+
+QSharedPointer<LyricMetadata> LyricDto::metadata() const { return m_metadata; }
+
+void LyricDto::setMetadata(QSharedPointer<LyricMetadata> newMetadata) {
+	m_metadata = newMetadata;
+}
+
+QList<LyricLine> LyricDto::lyrics() const { return m_lyrics; }
+
+void LyricDto::setLyrics(QList<LyricLine> newLyrics) {
+	m_lyrics = newLyrics;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using LyricDto = Jellyfin::DTO::LyricDto;
+
+template <>
+LyricDto fromJsonValue(const QJsonValue &source, convertType<LyricDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return LyricDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const LyricDto &source, convertType<LyricDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/lyricline.cpp b/core/src/dto/lyricline.cpp
new file mode 100644
index 0000000..aa18b58
--- /dev/null
+++ b/core/src/dto/lyricline.cpp
@@ -0,0 +1,117 @@
+/*
+ * 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/dto/lyricline.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+LyricLine::LyricLine() {}
+LyricLine::LyricLine (
+		QString text 
+		) :
+	m_text(text) { }
+
+
+
+LyricLine::LyricLine(const LyricLine &other) :
+
+	m_text(other.m_text),
+	m_start(other.m_start){}
+
+
+void LyricLine::replaceData(LyricLine &other) {
+	m_text = other.m_text;
+	m_start = other.m_start;
+}
+
+LyricLine LyricLine::fromJson(QJsonObject source) {
+	LyricLine instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void LyricLine::setFromJson(QJsonObject source) {
+	m_text = Jellyfin::Support::fromJsonValue<QString>(source["Text"]);
+	m_start = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["Start"]);
+
+}
+	
+QJsonObject LyricLine::toJson() const {
+	QJsonObject result;
+	
+	result["Text"] = Jellyfin::Support::toJsonValue<QString>(m_text);		
+	
+	if (!(!m_start.has_value())) {
+		result["Start"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_start);
+	}
+		
+	return result;
+}
+
+QString LyricLine::text() const { return m_text; }
+
+void LyricLine::setText(QString newText) {
+	m_text = newText;
+}
+
+std::optional<qint64> LyricLine::start() const { return m_start; }
+
+void LyricLine::setStart(std::optional<qint64> newStart) {
+	m_start = newStart;
+}
+bool LyricLine::startNull() const {
+	return !m_start.has_value();
+}
+
+void LyricLine::setStartNull() {
+	m_start = std::nullopt;
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using LyricLine = Jellyfin::DTO::LyricLine;
+
+template <>
+LyricLine fromJsonValue(const QJsonValue &source, convertType<LyricLine>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return LyricLine::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const LyricLine &source, convertType<LyricLine>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/lyricmetadata.cpp b/core/src/dto/lyricmetadata.cpp
new file mode 100644
index 0000000..4facbef
--- /dev/null
+++ b/core/src/dto/lyricmetadata.cpp
@@ -0,0 +1,290 @@
+/*
+ * 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/dto/lyricmetadata.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+LyricMetadata::LyricMetadata() {}
+
+LyricMetadata::LyricMetadata(const LyricMetadata &other) :
+
+	m_artist(other.m_artist),
+	m_album(other.m_album),
+	m_title(other.m_title),
+	m_author(other.m_author),
+	m_length(other.m_length),
+	m_by(other.m_by),
+	m_offset(other.m_offset),
+	m_creator(other.m_creator),
+	m_version(other.m_version),
+	m_isSynced(other.m_isSynced){}
+
+
+void LyricMetadata::replaceData(LyricMetadata &other) {
+	m_artist = other.m_artist;
+	m_album = other.m_album;
+	m_title = other.m_title;
+	m_author = other.m_author;
+	m_length = other.m_length;
+	m_by = other.m_by;
+	m_offset = other.m_offset;
+	m_creator = other.m_creator;
+	m_version = other.m_version;
+	m_isSynced = other.m_isSynced;
+}
+
+LyricMetadata LyricMetadata::fromJson(QJsonObject source) {
+	LyricMetadata instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void LyricMetadata::setFromJson(QJsonObject source) {
+	m_artist = Jellyfin::Support::fromJsonValue<QString>(source["Artist"]);
+	m_album = Jellyfin::Support::fromJsonValue<QString>(source["Album"]);
+	m_title = Jellyfin::Support::fromJsonValue<QString>(source["Title"]);
+	m_author = Jellyfin::Support::fromJsonValue<QString>(source["Author"]);
+	m_length = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["Length"]);
+	m_by = Jellyfin::Support::fromJsonValue<QString>(source["By"]);
+	m_offset = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["Offset"]);
+	m_creator = Jellyfin::Support::fromJsonValue<QString>(source["Creator"]);
+	m_version = Jellyfin::Support::fromJsonValue<QString>(source["Version"]);
+	m_isSynced = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsSynced"]);
+
+}
+	
+QJsonObject LyricMetadata::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_artist.isNull())) {
+		result["Artist"] = Jellyfin::Support::toJsonValue<QString>(m_artist);
+	}
+			
+	
+	if (!(m_album.isNull())) {
+		result["Album"] = Jellyfin::Support::toJsonValue<QString>(m_album);
+	}
+			
+	
+	if (!(m_title.isNull())) {
+		result["Title"] = Jellyfin::Support::toJsonValue<QString>(m_title);
+	}
+			
+	
+	if (!(m_author.isNull())) {
+		result["Author"] = Jellyfin::Support::toJsonValue<QString>(m_author);
+	}
+			
+	
+	if (!(!m_length.has_value())) {
+		result["Length"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_length);
+	}
+			
+	
+	if (!(m_by.isNull())) {
+		result["By"] = Jellyfin::Support::toJsonValue<QString>(m_by);
+	}
+			
+	
+	if (!(!m_offset.has_value())) {
+		result["Offset"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_offset);
+	}
+			
+	
+	if (!(m_creator.isNull())) {
+		result["Creator"] = Jellyfin::Support::toJsonValue<QString>(m_creator);
+	}
+			
+	
+	if (!(m_version.isNull())) {
+		result["Version"] = Jellyfin::Support::toJsonValue<QString>(m_version);
+	}
+			
+	
+	if (!(!m_isSynced.has_value())) {
+		result["IsSynced"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_isSynced);
+	}
+		
+	return result;
+}
+
+QString LyricMetadata::artist() const { return m_artist; }
+
+void LyricMetadata::setArtist(QString newArtist) {
+	m_artist = newArtist;
+}
+bool LyricMetadata::artistNull() const {
+	return m_artist.isNull();
+}
+
+void LyricMetadata::setArtistNull() {
+	m_artist.clear();
+
+}
+QString LyricMetadata::album() const { return m_album; }
+
+void LyricMetadata::setAlbum(QString newAlbum) {
+	m_album = newAlbum;
+}
+bool LyricMetadata::albumNull() const {
+	return m_album.isNull();
+}
+
+void LyricMetadata::setAlbumNull() {
+	m_album.clear();
+
+}
+QString LyricMetadata::title() const { return m_title; }
+
+void LyricMetadata::setTitle(QString newTitle) {
+	m_title = newTitle;
+}
+bool LyricMetadata::titleNull() const {
+	return m_title.isNull();
+}
+
+void LyricMetadata::setTitleNull() {
+	m_title.clear();
+
+}
+QString LyricMetadata::author() const { return m_author; }
+
+void LyricMetadata::setAuthor(QString newAuthor) {
+	m_author = newAuthor;
+}
+bool LyricMetadata::authorNull() const {
+	return m_author.isNull();
+}
+
+void LyricMetadata::setAuthorNull() {
+	m_author.clear();
+
+}
+std::optional<qint64> LyricMetadata::length() const { return m_length; }
+
+void LyricMetadata::setLength(std::optional<qint64> newLength) {
+	m_length = newLength;
+}
+bool LyricMetadata::lengthNull() const {
+	return !m_length.has_value();
+}
+
+void LyricMetadata::setLengthNull() {
+	m_length = std::nullopt;
+
+}
+QString LyricMetadata::by() const { return m_by; }
+
+void LyricMetadata::setBy(QString newBy) {
+	m_by = newBy;
+}
+bool LyricMetadata::byNull() const {
+	return m_by.isNull();
+}
+
+void LyricMetadata::setByNull() {
+	m_by.clear();
+
+}
+std::optional<qint64> LyricMetadata::offset() const { return m_offset; }
+
+void LyricMetadata::setOffset(std::optional<qint64> newOffset) {
+	m_offset = newOffset;
+}
+bool LyricMetadata::offsetNull() const {
+	return !m_offset.has_value();
+}
+
+void LyricMetadata::setOffsetNull() {
+	m_offset = std::nullopt;
+
+}
+QString LyricMetadata::creator() const { return m_creator; }
+
+void LyricMetadata::setCreator(QString newCreator) {
+	m_creator = newCreator;
+}
+bool LyricMetadata::creatorNull() const {
+	return m_creator.isNull();
+}
+
+void LyricMetadata::setCreatorNull() {
+	m_creator.clear();
+
+}
+QString LyricMetadata::version() const { return m_version; }
+
+void LyricMetadata::setVersion(QString newVersion) {
+	m_version = newVersion;
+}
+bool LyricMetadata::versionNull() const {
+	return m_version.isNull();
+}
+
+void LyricMetadata::setVersionNull() {
+	m_version.clear();
+
+}
+std::optional<bool> LyricMetadata::isSynced() const { return m_isSynced; }
+
+void LyricMetadata::setIsSynced(std::optional<bool> newIsSynced) {
+	m_isSynced = newIsSynced;
+}
+bool LyricMetadata::isSyncedNull() const {
+	return !m_isSynced.has_value();
+}
+
+void LyricMetadata::setIsSyncedNull() {
+	m_isSynced = std::nullopt;
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using LyricMetadata = Jellyfin::DTO::LyricMetadata;
+
+template <>
+LyricMetadata fromJsonValue(const QJsonValue &source, convertType<LyricMetadata>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return LyricMetadata::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const LyricMetadata &source, convertType<LyricMetadata>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/mediapathinfo.cpp b/core/src/dto/mediapathinfo.cpp
index cef6ac6..1263c5d 100644
--- a/core/src/dto/mediapathinfo.cpp
+++ b/core/src/dto/mediapathinfo.cpp
@@ -33,16 +33,20 @@ namespace Jellyfin {
 namespace DTO {
 
 MediaPathInfo::MediaPathInfo() {}
+MediaPathInfo::MediaPathInfo (
+		QString path 
+		) :
+	m_path(path) { }
+
+
 
 MediaPathInfo::MediaPathInfo(const MediaPathInfo &other) :
 
-	m_path(other.m_path),
-	m_networkPath(other.m_networkPath){}
+	m_path(other.m_path){}
 
 
 void MediaPathInfo::replaceData(MediaPathInfo &other) {
 	m_path = other.m_path;
-	m_networkPath = other.m_networkPath;
 }
 
 MediaPathInfo MediaPathInfo::fromJson(QJsonObject source) {
@@ -54,23 +58,13 @@ MediaPathInfo MediaPathInfo::fromJson(QJsonObject source) {
 
 void MediaPathInfo::setFromJson(QJsonObject source) {
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
-	m_networkPath = Jellyfin::Support::fromJsonValue<QString>(source["NetworkPath"]);
 
 }
 	
 QJsonObject MediaPathInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_path.isNull())) {
-		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
-	}
-			
-	
-	if (!(m_networkPath.isNull())) {
-		result["NetworkPath"] = Jellyfin::Support::toJsonValue<QString>(m_networkPath);
-	}
-		
+	result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);	
 	return result;
 }
 
@@ -79,27 +73,7 @@ QString MediaPathInfo::path() const { return m_path; }
 void MediaPathInfo::setPath(QString newPath) {
 	m_path = newPath;
 }
-bool MediaPathInfo::pathNull() const {
-	return m_path.isNull();
-}
 
-void MediaPathInfo::setPathNull() {
-	m_path.clear();
-
-}
-QString MediaPathInfo::networkPath() const { return m_networkPath; }
-
-void MediaPathInfo::setNetworkPath(QString newNetworkPath) {
-	m_networkPath = newNetworkPath;
-}
-bool MediaPathInfo::networkPathNull() const {
-	return m_networkPath.isNull();
-}
-
-void MediaPathInfo::setNetworkPathNull() {
-	m_networkPath.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/mediasegmentdto.cpp b/core/src/dto/mediasegmentdto.cpp
new file mode 100644
index 0000000..feb4492
--- /dev/null
+++ b/core/src/dto/mediasegmentdto.cpp
@@ -0,0 +1,144 @@
+/*
+ * 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/dto/mediasegmentdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MediaSegmentDto::MediaSegmentDto() {}
+MediaSegmentDto::MediaSegmentDto (
+		QString jellyfinId, 
+		QString itemId, 
+		MediaSegmentType type, 
+		qint64 startTicks, 
+		qint64 endTicks 
+		) :
+	m_jellyfinId(jellyfinId),
+	m_itemId(itemId),
+	m_type(type),
+	m_startTicks(startTicks),
+	m_endTicks(endTicks) { }
+
+
+
+MediaSegmentDto::MediaSegmentDto(const MediaSegmentDto &other) :
+
+	m_jellyfinId(other.m_jellyfinId),
+	m_itemId(other.m_itemId),
+	m_type(other.m_type),
+	m_startTicks(other.m_startTicks),
+	m_endTicks(other.m_endTicks){}
+
+
+void MediaSegmentDto::replaceData(MediaSegmentDto &other) {
+	m_jellyfinId = other.m_jellyfinId;
+	m_itemId = other.m_itemId;
+	m_type = other.m_type;
+	m_startTicks = other.m_startTicks;
+	m_endTicks = other.m_endTicks;
+}
+
+MediaSegmentDto MediaSegmentDto::fromJson(QJsonObject source) {
+	MediaSegmentDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void MediaSegmentDto::setFromJson(QJsonObject source) {
+	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
+	m_itemId = Jellyfin::Support::fromJsonValue<QString>(source["ItemId"]);
+	m_type = Jellyfin::Support::fromJsonValue<MediaSegmentType>(source["Type"]);
+	m_startTicks = Jellyfin::Support::fromJsonValue<qint64>(source["StartTicks"]);
+	m_endTicks = Jellyfin::Support::fromJsonValue<qint64>(source["EndTicks"]);
+
+}
+	
+QJsonObject MediaSegmentDto::toJson() const {
+	QJsonObject result;
+	
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
+	result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);		
+	result["Type"] = Jellyfin::Support::toJsonValue<MediaSegmentType>(m_type);		
+	result["StartTicks"] = Jellyfin::Support::toJsonValue<qint64>(m_startTicks);		
+	result["EndTicks"] = Jellyfin::Support::toJsonValue<qint64>(m_endTicks);	
+	return result;
+}
+
+QString MediaSegmentDto::jellyfinId() const { return m_jellyfinId; }
+
+void MediaSegmentDto::setJellyfinId(QString newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
+}
+
+QString MediaSegmentDto::itemId() const { return m_itemId; }
+
+void MediaSegmentDto::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+MediaSegmentType MediaSegmentDto::type() const { return m_type; }
+
+void MediaSegmentDto::setType(MediaSegmentType newType) {
+	m_type = newType;
+}
+
+qint64 MediaSegmentDto::startTicks() const { return m_startTicks; }
+
+void MediaSegmentDto::setStartTicks(qint64 newStartTicks) {
+	m_startTicks = newStartTicks;
+}
+
+qint64 MediaSegmentDto::endTicks() const { return m_endTicks; }
+
+void MediaSegmentDto::setEndTicks(qint64 newEndTicks) {
+	m_endTicks = newEndTicks;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentDto = Jellyfin::DTO::MediaSegmentDto;
+
+template <>
+MediaSegmentDto fromJsonValue(const QJsonValue &source, convertType<MediaSegmentDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return MediaSegmentDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const MediaSegmentDto &source, convertType<MediaSegmentDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/mediasegmentdtoqueryresult.cpp b/core/src/dto/mediasegmentdtoqueryresult.cpp
new file mode 100644
index 0000000..2417e5c
--- /dev/null
+++ b/core/src/dto/mediasegmentdtoqueryresult.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/mediasegmentdtoqueryresult.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MediaSegmentDtoQueryResult::MediaSegmentDtoQueryResult() {}
+MediaSegmentDtoQueryResult::MediaSegmentDtoQueryResult (
+		QList<MediaSegmentDto> items, 
+		qint32 totalRecordCount, 
+		qint32 startIndex 
+		) :
+	m_items(items),
+	m_totalRecordCount(totalRecordCount),
+	m_startIndex(startIndex) { }
+
+
+
+MediaSegmentDtoQueryResult::MediaSegmentDtoQueryResult(const MediaSegmentDtoQueryResult &other) :
+
+	m_items(other.m_items),
+	m_totalRecordCount(other.m_totalRecordCount),
+	m_startIndex(other.m_startIndex){}
+
+
+void MediaSegmentDtoQueryResult::replaceData(MediaSegmentDtoQueryResult &other) {
+	m_items = other.m_items;
+	m_totalRecordCount = other.m_totalRecordCount;
+	m_startIndex = other.m_startIndex;
+}
+
+MediaSegmentDtoQueryResult MediaSegmentDtoQueryResult::fromJson(QJsonObject source) {
+	MediaSegmentDtoQueryResult instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void MediaSegmentDtoQueryResult::setFromJson(QJsonObject source) {
+	m_items = Jellyfin::Support::fromJsonValue<QList<MediaSegmentDto>>(source["Items"]);
+	m_totalRecordCount = Jellyfin::Support::fromJsonValue<qint32>(source["TotalRecordCount"]);
+	m_startIndex = Jellyfin::Support::fromJsonValue<qint32>(source["StartIndex"]);
+
+}
+	
+QJsonObject MediaSegmentDtoQueryResult::toJson() const {
+	QJsonObject result;
+	
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<MediaSegmentDto>>(m_items);		
+	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
+	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
+	return result;
+}
+
+QList<MediaSegmentDto> MediaSegmentDtoQueryResult::items() const { return m_items; }
+
+void MediaSegmentDtoQueryResult::setItems(QList<MediaSegmentDto> newItems) {
+	m_items = newItems;
+}
+
+qint32 MediaSegmentDtoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
+
+void MediaSegmentDtoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
+	m_totalRecordCount = newTotalRecordCount;
+}
+
+qint32 MediaSegmentDtoQueryResult::startIndex() const { return m_startIndex; }
+
+void MediaSegmentDtoQueryResult::setStartIndex(qint32 newStartIndex) {
+	m_startIndex = newStartIndex;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentDtoQueryResult = Jellyfin::DTO::MediaSegmentDtoQueryResult;
+
+template <>
+MediaSegmentDtoQueryResult fromJsonValue(const QJsonValue &source, convertType<MediaSegmentDtoQueryResult>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return MediaSegmentDtoQueryResult::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const MediaSegmentDtoQueryResult &source, convertType<MediaSegmentDtoQueryResult>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/mediasegmenttype.cpp b/core/src/dto/mediasegmenttype.cpp
new file mode 100644
index 0000000..a7e952f
--- /dev/null
+++ b/core/src/dto/mediasegmenttype.cpp
@@ -0,0 +1,93 @@
+/*
+ * 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/dto/mediasegmenttype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MediaSegmentTypeClass::MediaSegmentTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using MediaSegmentType = Jellyfin::DTO::MediaSegmentType;
+
+template <>
+MediaSegmentType fromJsonValue(const QJsonValue &source, convertType<MediaSegmentType>) {
+	if (!source.isString()) return MediaSegmentType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Unknown")) {
+		return MediaSegmentType::Unknown;
+	}
+	if (str == QStringLiteral("Commercial")) {
+		return MediaSegmentType::Commercial;
+	}
+	if (str == QStringLiteral("Preview")) {
+		return MediaSegmentType::Preview;
+	}
+	if (str == QStringLiteral("Recap")) {
+		return MediaSegmentType::Recap;
+	}
+	if (str == QStringLiteral("Outro")) {
+		return MediaSegmentType::Outro;
+	}
+	if (str == QStringLiteral("Intro")) {
+		return MediaSegmentType::Intro;
+	}
+	
+	return MediaSegmentType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const MediaSegmentType &source, convertType<MediaSegmentType>) {
+	switch(source) {
+	case MediaSegmentType::Unknown:
+		return QStringLiteral("Unknown");
+	case MediaSegmentType::Commercial:
+		return QStringLiteral("Commercial");
+	case MediaSegmentType::Preview:
+		return QStringLiteral("Preview");
+	case MediaSegmentType::Recap:
+		return QStringLiteral("Recap");
+	case MediaSegmentType::Outro:
+		return QStringLiteral("Outro");
+	case MediaSegmentType::Intro:
+		return QStringLiteral("Intro");
+
+	case MediaSegmentType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/mediasourceinfo.cpp b/core/src/dto/mediasourceinfo.cpp
index 22813c9..83166da 100644
--- a/core/src/dto/mediasourceinfo.cpp
+++ b/core/src/dto/mediasourceinfo.cpp
@@ -46,6 +46,7 @@ MediaSourceInfo::MediaSourceInfo (
 		bool supportsDirectStream, 
 		bool supportsDirectPlay, 
 		bool isInfiniteStream, 
+		std::optional<bool> useMostCompatibleTranscodingProfile, 
 		bool requiresOpening, 
 		bool requiresClosing, 
 		bool requiresLooping, 
@@ -53,7 +54,9 @@ MediaSourceInfo::MediaSourceInfo (
 		VideoType videoType, 
 		IsoType isoType, 
 		Video3DFormat video3DFormat, 
-		TransportStreamTimestamp timestamp 
+		TransportStreamTimestamp timestamp, 
+		MediaStreamProtocol transcodingSubProtocol, 
+		bool hasSegments 
 		) :
 	m_protocol(protocol),
 	m_encoderProtocol(encoderProtocol),
@@ -67,6 +70,7 @@ MediaSourceInfo::MediaSourceInfo (
 	m_supportsDirectStream(supportsDirectStream),
 	m_supportsDirectPlay(supportsDirectPlay),
 	m_isInfiniteStream(isInfiniteStream),
+	m_useMostCompatibleTranscodingProfile(useMostCompatibleTranscodingProfile),
 	m_requiresOpening(requiresOpening),
 	m_requiresClosing(requiresClosing),
 	m_requiresLooping(requiresLooping),
@@ -74,7 +78,9 @@ MediaSourceInfo::MediaSourceInfo (
 	m_videoType(videoType),
 	m_isoType(isoType),
 	m_video3DFormat(video3DFormat),
-	m_timestamp(timestamp) { }
+	m_timestamp(timestamp),
+	m_transcodingSubProtocol(transcodingSubProtocol),
+	m_hasSegments(hasSegments) { }
 
 
 
@@ -100,6 +106,7 @@ MediaSourceInfo::MediaSourceInfo(const MediaSourceInfo &other) :
 	m_supportsDirectStream(other.m_supportsDirectStream),
 	m_supportsDirectPlay(other.m_supportsDirectPlay),
 	m_isInfiniteStream(other.m_isInfiniteStream),
+	m_useMostCompatibleTranscodingProfile(other.m_useMostCompatibleTranscodingProfile),
 	m_requiresOpening(other.m_requiresOpening),
 	m_openToken(other.m_openToken),
 	m_requiresClosing(other.m_requiresClosing),
@@ -114,6 +121,7 @@ MediaSourceInfo::MediaSourceInfo(const MediaSourceInfo &other) :
 	m_mediaAttachments(other.m_mediaAttachments),
 	m_formats(other.m_formats),
 	m_bitrate(other.m_bitrate),
+	m_fallbackMaxStreamingBitrate(other.m_fallbackMaxStreamingBitrate),
 	m_timestamp(other.m_timestamp),
 	m_requiredHttpHeaders(other.m_requiredHttpHeaders),
 	m_transcodingUrl(other.m_transcodingUrl),
@@ -121,7 +129,8 @@ MediaSourceInfo::MediaSourceInfo(const MediaSourceInfo &other) :
 	m_transcodingContainer(other.m_transcodingContainer),
 	m_analyzeDurationMs(other.m_analyzeDurationMs),
 	m_defaultAudioStreamIndex(other.m_defaultAudioStreamIndex),
-	m_defaultSubtitleStreamIndex(other.m_defaultSubtitleStreamIndex){}
+	m_defaultSubtitleStreamIndex(other.m_defaultSubtitleStreamIndex),
+	m_hasSegments(other.m_hasSegments){}
 
 
 void MediaSourceInfo::replaceData(MediaSourceInfo &other) {
@@ -145,6 +154,7 @@ void MediaSourceInfo::replaceData(MediaSourceInfo &other) {
 	m_supportsDirectStream = other.m_supportsDirectStream;
 	m_supportsDirectPlay = other.m_supportsDirectPlay;
 	m_isInfiniteStream = other.m_isInfiniteStream;
+	m_useMostCompatibleTranscodingProfile = other.m_useMostCompatibleTranscodingProfile;
 	m_requiresOpening = other.m_requiresOpening;
 	m_openToken = other.m_openToken;
 	m_requiresClosing = other.m_requiresClosing;
@@ -159,6 +169,7 @@ void MediaSourceInfo::replaceData(MediaSourceInfo &other) {
 	m_mediaAttachments = other.m_mediaAttachments;
 	m_formats = other.m_formats;
 	m_bitrate = other.m_bitrate;
+	m_fallbackMaxStreamingBitrate = other.m_fallbackMaxStreamingBitrate;
 	m_timestamp = other.m_timestamp;
 	m_requiredHttpHeaders = other.m_requiredHttpHeaders;
 	m_transcodingUrl = other.m_transcodingUrl;
@@ -167,6 +178,7 @@ void MediaSourceInfo::replaceData(MediaSourceInfo &other) {
 	m_analyzeDurationMs = other.m_analyzeDurationMs;
 	m_defaultAudioStreamIndex = other.m_defaultAudioStreamIndex;
 	m_defaultSubtitleStreamIndex = other.m_defaultSubtitleStreamIndex;
+	m_hasSegments = other.m_hasSegments;
 }
 
 MediaSourceInfo MediaSourceInfo::fromJson(QJsonObject source) {
@@ -197,6 +209,7 @@ void MediaSourceInfo::setFromJson(QJsonObject source) {
 	m_supportsDirectStream = Jellyfin::Support::fromJsonValue<bool>(source["SupportsDirectStream"]);
 	m_supportsDirectPlay = Jellyfin::Support::fromJsonValue<bool>(source["SupportsDirectPlay"]);
 	m_isInfiniteStream = Jellyfin::Support::fromJsonValue<bool>(source["IsInfiniteStream"]);
+	m_useMostCompatibleTranscodingProfile = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["UseMostCompatibleTranscodingProfile"]);
 	m_requiresOpening = Jellyfin::Support::fromJsonValue<bool>(source["RequiresOpening"]);
 	m_openToken = Jellyfin::Support::fromJsonValue<QString>(source["OpenToken"]);
 	m_requiresClosing = Jellyfin::Support::fromJsonValue<bool>(source["RequiresClosing"]);
@@ -211,14 +224,16 @@ void MediaSourceInfo::setFromJson(QJsonObject source) {
 	m_mediaAttachments = Jellyfin::Support::fromJsonValue<QList<MediaAttachment>>(source["MediaAttachments"]);
 	m_formats = Jellyfin::Support::fromJsonValue<QStringList>(source["Formats"]);
 	m_bitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Bitrate"]);
+	m_fallbackMaxStreamingBitrate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["FallbackMaxStreamingBitrate"]);
 	m_timestamp = Jellyfin::Support::fromJsonValue<TransportStreamTimestamp>(source["Timestamp"]);
 	m_requiredHttpHeaders = Jellyfin::Support::fromJsonValue<QJsonObject>(source["RequiredHttpHeaders"]);
 	m_transcodingUrl = Jellyfin::Support::fromJsonValue<QString>(source["TranscodingUrl"]);
-	m_transcodingSubProtocol = Jellyfin::Support::fromJsonValue<QString>(source["TranscodingSubProtocol"]);
+	m_transcodingSubProtocol = Jellyfin::Support::fromJsonValue<MediaStreamProtocol>(source["TranscodingSubProtocol"]);
 	m_transcodingContainer = Jellyfin::Support::fromJsonValue<QString>(source["TranscodingContainer"]);
 	m_analyzeDurationMs = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["AnalyzeDurationMs"]);
 	m_defaultAudioStreamIndex = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DefaultAudioStreamIndex"]);
 	m_defaultSubtitleStreamIndex = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DefaultSubtitleStreamIndex"]);
+	m_hasSegments = Jellyfin::Support::fromJsonValue<bool>(source["HasSegments"]);
 
 }
 	
@@ -277,6 +292,7 @@ QJsonObject MediaSourceInfo::toJson() const {
 	result["SupportsDirectStream"] = Jellyfin::Support::toJsonValue<bool>(m_supportsDirectStream);		
 	result["SupportsDirectPlay"] = Jellyfin::Support::toJsonValue<bool>(m_supportsDirectPlay);		
 	result["IsInfiniteStream"] = Jellyfin::Support::toJsonValue<bool>(m_isInfiniteStream);		
+	result["UseMostCompatibleTranscodingProfile"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_useMostCompatibleTranscodingProfile);		
 	result["RequiresOpening"] = Jellyfin::Support::toJsonValue<bool>(m_requiresOpening);		
 	
 	if (!(m_openToken.isNull())) {
@@ -319,6 +335,11 @@ QJsonObject MediaSourceInfo::toJson() const {
 		result["Bitrate"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_bitrate);
 	}
 			
+	
+	if (!(!m_fallbackMaxStreamingBitrate.has_value())) {
+		result["FallbackMaxStreamingBitrate"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_fallbackMaxStreamingBitrate);
+	}
+			
 	result["Timestamp"] = Jellyfin::Support::toJsonValue<TransportStreamTimestamp>(m_timestamp);		
 	
 	if (!(m_requiredHttpHeaders.isEmpty())) {
@@ -330,11 +351,7 @@ QJsonObject MediaSourceInfo::toJson() const {
 		result["TranscodingUrl"] = Jellyfin::Support::toJsonValue<QString>(m_transcodingUrl);
 	}
 			
-	
-	if (!(m_transcodingSubProtocol.isNull())) {
-		result["TranscodingSubProtocol"] = Jellyfin::Support::toJsonValue<QString>(m_transcodingSubProtocol);
-	}
-			
+	result["TranscodingSubProtocol"] = Jellyfin::Support::toJsonValue<MediaStreamProtocol>(m_transcodingSubProtocol);		
 	
 	if (!(m_transcodingContainer.isNull())) {
 		result["TranscodingContainer"] = Jellyfin::Support::toJsonValue<QString>(m_transcodingContainer);
@@ -354,7 +371,8 @@ QJsonObject MediaSourceInfo::toJson() const {
 	if (!(!m_defaultSubtitleStreamIndex.has_value())) {
 		result["DefaultSubtitleStreamIndex"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_defaultSubtitleStreamIndex);
 	}
-		
+			
+	result["HasSegments"] = Jellyfin::Support::toJsonValue<bool>(m_hasSegments);	
 	return result;
 }
 
@@ -534,6 +552,12 @@ void MediaSourceInfo::setIsInfiniteStream(bool newIsInfiniteStream) {
 	m_isInfiniteStream = newIsInfiniteStream;
 }
 
+std::optional<bool> MediaSourceInfo::useMostCompatibleTranscodingProfile() const { return m_useMostCompatibleTranscodingProfile; }
+
+void MediaSourceInfo::setUseMostCompatibleTranscodingProfile(std::optional<bool> newUseMostCompatibleTranscodingProfile) {
+	m_useMostCompatibleTranscodingProfile = newUseMostCompatibleTranscodingProfile;
+}
+
 bool MediaSourceInfo::requiresOpening() const { return m_requiresOpening; }
 
 void MediaSourceInfo::setRequiresOpening(bool newRequiresOpening) {
@@ -666,6 +690,19 @@ bool MediaSourceInfo::bitrateNull() const {
 void MediaSourceInfo::setBitrateNull() {
 	m_bitrate = std::nullopt;
 
+}
+std::optional<qint32> MediaSourceInfo::fallbackMaxStreamingBitrate() const { return m_fallbackMaxStreamingBitrate; }
+
+void MediaSourceInfo::setFallbackMaxStreamingBitrate(std::optional<qint32> newFallbackMaxStreamingBitrate) {
+	m_fallbackMaxStreamingBitrate = newFallbackMaxStreamingBitrate;
+}
+bool MediaSourceInfo::fallbackMaxStreamingBitrateNull() const {
+	return !m_fallbackMaxStreamingBitrate.has_value();
+}
+
+void MediaSourceInfo::setFallbackMaxStreamingBitrateNull() {
+	m_fallbackMaxStreamingBitrate = std::nullopt;
+
 }
 TransportStreamTimestamp MediaSourceInfo::timestamp() const { return m_timestamp; }
 
@@ -699,19 +736,12 @@ void MediaSourceInfo::setTranscodingUrlNull() {
 	m_transcodingUrl.clear();
 
 }
-QString MediaSourceInfo::transcodingSubProtocol() const { return m_transcodingSubProtocol; }
+MediaStreamProtocol MediaSourceInfo::transcodingSubProtocol() const { return m_transcodingSubProtocol; }
 
-void MediaSourceInfo::setTranscodingSubProtocol(QString newTranscodingSubProtocol) {
+void MediaSourceInfo::setTranscodingSubProtocol(MediaStreamProtocol newTranscodingSubProtocol) {
 	m_transcodingSubProtocol = newTranscodingSubProtocol;
 }
-bool MediaSourceInfo::transcodingSubProtocolNull() const {
-	return m_transcodingSubProtocol.isNull();
-}
 
-void MediaSourceInfo::setTranscodingSubProtocolNull() {
-	m_transcodingSubProtocol.clear();
-
-}
 QString MediaSourceInfo::transcodingContainer() const { return m_transcodingContainer; }
 
 void MediaSourceInfo::setTranscodingContainer(QString newTranscodingContainer) {
@@ -764,6 +794,12 @@ void MediaSourceInfo::setDefaultSubtitleStreamIndexNull() {
 	m_defaultSubtitleStreamIndex = std::nullopt;
 
 }
+bool MediaSourceInfo::hasSegments() const { return m_hasSegments; }
+
+void MediaSourceInfo::setHasSegments(bool newHasSegments) {
+	m_hasSegments = newHasSegments;
+}
+
 
 } // NS DTO
 
diff --git a/core/src/dto/mediastream.cpp b/core/src/dto/mediastream.cpp
index 46707da..c4db9ec 100644
--- a/core/src/dto/mediastream.cpp
+++ b/core/src/dto/mediastream.cpp
@@ -34,9 +34,13 @@ namespace DTO {
 
 MediaStream::MediaStream() {}
 MediaStream::MediaStream (
+		VideoRange videoRange, 
+		VideoRangeType videoRangeType, 
+		AudioSpatialFormat audioSpatialFormat, 
 		bool isInterlaced, 
 		bool isDefault, 
 		bool isForced, 
+		bool isHearingImpaired, 
 		MediaStreamType type, 
 		qint32 index, 
 		bool isExternal, 
@@ -44,9 +48,13 @@ MediaStream::MediaStream (
 		bool isTextSubtitleStream, 
 		bool supportsExternalStream 
 		) :
+	m_videoRange(videoRange),
+	m_videoRangeType(videoRangeType),
+	m_audioSpatialFormat(audioSpatialFormat),
 	m_isInterlaced(isInterlaced),
 	m_isDefault(isDefault),
 	m_isForced(isForced),
+	m_isHearingImpaired(isHearingImpaired),
 	m_type(type),
 	m_index(index),
 	m_isExternal(isExternal),
@@ -65,14 +73,28 @@ MediaStream::MediaStream(const MediaStream &other) :
 	m_colorSpace(other.m_colorSpace),
 	m_colorTransfer(other.m_colorTransfer),
 	m_colorPrimaries(other.m_colorPrimaries),
+	m_dvVersionMajor(other.m_dvVersionMajor),
+	m_dvVersionMinor(other.m_dvVersionMinor),
+	m_dvProfile(other.m_dvProfile),
+	m_dvLevel(other.m_dvLevel),
+	m_rpuPresentFlag(other.m_rpuPresentFlag),
+	m_elPresentFlag(other.m_elPresentFlag),
+	m_blPresentFlag(other.m_blPresentFlag),
+	m_dvBlSignalCompatibilityId(other.m_dvBlSignalCompatibilityId),
+	m_rotation(other.m_rotation),
 	m_comment(other.m_comment),
 	m_timeBase(other.m_timeBase),
 	m_codecTimeBase(other.m_codecTimeBase),
 	m_title(other.m_title),
 	m_videoRange(other.m_videoRange),
+	m_videoRangeType(other.m_videoRangeType),
+	m_videoDoViTitle(other.m_videoDoViTitle),
+	m_audioSpatialFormat(other.m_audioSpatialFormat),
 	m_localizedUndefined(other.m_localizedUndefined),
 	m_localizedDefault(other.m_localizedDefault),
 	m_localizedForced(other.m_localizedForced),
+	m_localizedExternal(other.m_localizedExternal),
+	m_localizedHearingImpaired(other.m_localizedHearingImpaired),
 	m_displayTitle(other.m_displayTitle),
 	m_nalLengthSize(other.m_nalLengthSize),
 	m_isInterlaced(other.m_isInterlaced),
@@ -86,10 +108,12 @@ MediaStream::MediaStream(const MediaStream &other) :
 	m_sampleRate(other.m_sampleRate),
 	m_isDefault(other.m_isDefault),
 	m_isForced(other.m_isForced),
+	m_isHearingImpaired(other.m_isHearingImpaired),
 	m_height(other.m_height),
 	m_width(other.m_width),
 	m_averageFrameRate(other.m_averageFrameRate),
 	m_realFrameRate(other.m_realFrameRate),
+	m_referenceFrameRate(other.m_referenceFrameRate),
 	m_profile(other.m_profile),
 	m_type(other.m_type),
 	m_aspectRatio(other.m_aspectRatio),
@@ -115,14 +139,28 @@ void MediaStream::replaceData(MediaStream &other) {
 	m_colorSpace = other.m_colorSpace;
 	m_colorTransfer = other.m_colorTransfer;
 	m_colorPrimaries = other.m_colorPrimaries;
+	m_dvVersionMajor = other.m_dvVersionMajor;
+	m_dvVersionMinor = other.m_dvVersionMinor;
+	m_dvProfile = other.m_dvProfile;
+	m_dvLevel = other.m_dvLevel;
+	m_rpuPresentFlag = other.m_rpuPresentFlag;
+	m_elPresentFlag = other.m_elPresentFlag;
+	m_blPresentFlag = other.m_blPresentFlag;
+	m_dvBlSignalCompatibilityId = other.m_dvBlSignalCompatibilityId;
+	m_rotation = other.m_rotation;
 	m_comment = other.m_comment;
 	m_timeBase = other.m_timeBase;
 	m_codecTimeBase = other.m_codecTimeBase;
 	m_title = other.m_title;
 	m_videoRange = other.m_videoRange;
+	m_videoRangeType = other.m_videoRangeType;
+	m_videoDoViTitle = other.m_videoDoViTitle;
+	m_audioSpatialFormat = other.m_audioSpatialFormat;
 	m_localizedUndefined = other.m_localizedUndefined;
 	m_localizedDefault = other.m_localizedDefault;
 	m_localizedForced = other.m_localizedForced;
+	m_localizedExternal = other.m_localizedExternal;
+	m_localizedHearingImpaired = other.m_localizedHearingImpaired;
 	m_displayTitle = other.m_displayTitle;
 	m_nalLengthSize = other.m_nalLengthSize;
 	m_isInterlaced = other.m_isInterlaced;
@@ -136,10 +174,12 @@ void MediaStream::replaceData(MediaStream &other) {
 	m_sampleRate = other.m_sampleRate;
 	m_isDefault = other.m_isDefault;
 	m_isForced = other.m_isForced;
+	m_isHearingImpaired = other.m_isHearingImpaired;
 	m_height = other.m_height;
 	m_width = other.m_width;
 	m_averageFrameRate = other.m_averageFrameRate;
 	m_realFrameRate = other.m_realFrameRate;
+	m_referenceFrameRate = other.m_referenceFrameRate;
 	m_profile = other.m_profile;
 	m_type = other.m_type;
 	m_aspectRatio = other.m_aspectRatio;
@@ -172,14 +212,28 @@ void MediaStream::setFromJson(QJsonObject source) {
 	m_colorSpace = Jellyfin::Support::fromJsonValue<QString>(source["ColorSpace"]);
 	m_colorTransfer = Jellyfin::Support::fromJsonValue<QString>(source["ColorTransfer"]);
 	m_colorPrimaries = Jellyfin::Support::fromJsonValue<QString>(source["ColorPrimaries"]);
+	m_dvVersionMajor = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DvVersionMajor"]);
+	m_dvVersionMinor = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DvVersionMinor"]);
+	m_dvProfile = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DvProfile"]);
+	m_dvLevel = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DvLevel"]);
+	m_rpuPresentFlag = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["RpuPresentFlag"]);
+	m_elPresentFlag = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["ElPresentFlag"]);
+	m_blPresentFlag = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["BlPresentFlag"]);
+	m_dvBlSignalCompatibilityId = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DvBlSignalCompatibilityId"]);
+	m_rotation = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Rotation"]);
 	m_comment = Jellyfin::Support::fromJsonValue<QString>(source["Comment"]);
 	m_timeBase = Jellyfin::Support::fromJsonValue<QString>(source["TimeBase"]);
 	m_codecTimeBase = Jellyfin::Support::fromJsonValue<QString>(source["CodecTimeBase"]);
 	m_title = Jellyfin::Support::fromJsonValue<QString>(source["Title"]);
-	m_videoRange = Jellyfin::Support::fromJsonValue<QString>(source["VideoRange"]);
-	m_localizedUndefined = Jellyfin::Support::fromJsonValue<QString>(source["localizedUndefined"]);
-	m_localizedDefault = Jellyfin::Support::fromJsonValue<QString>(source["localizedDefault"]);
-	m_localizedForced = Jellyfin::Support::fromJsonValue<QString>(source["localizedForced"]);
+	m_videoRange = Jellyfin::Support::fromJsonValue<VideoRange>(source["VideoRange"]);
+	m_videoRangeType = Jellyfin::Support::fromJsonValue<VideoRangeType>(source["VideoRangeType"]);
+	m_videoDoViTitle = Jellyfin::Support::fromJsonValue<QString>(source["VideoDoViTitle"]);
+	m_audioSpatialFormat = Jellyfin::Support::fromJsonValue<AudioSpatialFormat>(source["AudioSpatialFormat"]);
+	m_localizedUndefined = Jellyfin::Support::fromJsonValue<QString>(source["LocalizedUndefined"]);
+	m_localizedDefault = Jellyfin::Support::fromJsonValue<QString>(source["LocalizedDefault"]);
+	m_localizedForced = Jellyfin::Support::fromJsonValue<QString>(source["LocalizedForced"]);
+	m_localizedExternal = Jellyfin::Support::fromJsonValue<QString>(source["LocalizedExternal"]);
+	m_localizedHearingImpaired = Jellyfin::Support::fromJsonValue<QString>(source["LocalizedHearingImpaired"]);
 	m_displayTitle = Jellyfin::Support::fromJsonValue<QString>(source["DisplayTitle"]);
 	m_nalLengthSize = Jellyfin::Support::fromJsonValue<QString>(source["NalLengthSize"]);
 	m_isInterlaced = Jellyfin::Support::fromJsonValue<bool>(source["IsInterlaced"]);
@@ -193,10 +247,12 @@ void MediaStream::setFromJson(QJsonObject source) {
 	m_sampleRate = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["SampleRate"]);
 	m_isDefault = Jellyfin::Support::fromJsonValue<bool>(source["IsDefault"]);
 	m_isForced = Jellyfin::Support::fromJsonValue<bool>(source["IsForced"]);
+	m_isHearingImpaired = Jellyfin::Support::fromJsonValue<bool>(source["IsHearingImpaired"]);
 	m_height = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Height"]);
 	m_width = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Width"]);
 	m_averageFrameRate = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["AverageFrameRate"]);
 	m_realFrameRate = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["RealFrameRate"]);
+	m_referenceFrameRate = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["ReferenceFrameRate"]);
 	m_profile = Jellyfin::Support::fromJsonValue<QString>(source["Profile"]);
 	m_type = Jellyfin::Support::fromJsonValue<MediaStreamType>(source["Type"]);
 	m_aspectRatio = Jellyfin::Support::fromJsonValue<QString>(source["AspectRatio"]);
@@ -254,6 +310,51 @@ QJsonObject MediaStream::toJson() const {
 	}
 			
 	
+	if (!(!m_dvVersionMajor.has_value())) {
+		result["DvVersionMajor"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_dvVersionMajor);
+	}
+			
+	
+	if (!(!m_dvVersionMinor.has_value())) {
+		result["DvVersionMinor"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_dvVersionMinor);
+	}
+			
+	
+	if (!(!m_dvProfile.has_value())) {
+		result["DvProfile"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_dvProfile);
+	}
+			
+	
+	if (!(!m_dvLevel.has_value())) {
+		result["DvLevel"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_dvLevel);
+	}
+			
+	
+	if (!(!m_rpuPresentFlag.has_value())) {
+		result["RpuPresentFlag"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_rpuPresentFlag);
+	}
+			
+	
+	if (!(!m_elPresentFlag.has_value())) {
+		result["ElPresentFlag"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_elPresentFlag);
+	}
+			
+	
+	if (!(!m_blPresentFlag.has_value())) {
+		result["BlPresentFlag"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_blPresentFlag);
+	}
+			
+	
+	if (!(!m_dvBlSignalCompatibilityId.has_value())) {
+		result["DvBlSignalCompatibilityId"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_dvBlSignalCompatibilityId);
+	}
+			
+	
+	if (!(!m_rotation.has_value())) {
+		result["Rotation"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_rotation);
+	}
+			
+	
 	if (!(m_comment.isNull())) {
 		result["Comment"] = Jellyfin::Support::toJsonValue<QString>(m_comment);
 	}
@@ -273,24 +374,37 @@ QJsonObject MediaStream::toJson() const {
 		result["Title"] = Jellyfin::Support::toJsonValue<QString>(m_title);
 	}
 			
+	result["VideoRange"] = Jellyfin::Support::toJsonValue<VideoRange>(m_videoRange);		
+	result["VideoRangeType"] = Jellyfin::Support::toJsonValue<VideoRangeType>(m_videoRangeType);		
 	
-	if (!(m_videoRange.isNull())) {
-		result["VideoRange"] = Jellyfin::Support::toJsonValue<QString>(m_videoRange);
+	if (!(m_videoDoViTitle.isNull())) {
+		result["VideoDoViTitle"] = Jellyfin::Support::toJsonValue<QString>(m_videoDoViTitle);
 	}
 			
+	result["AudioSpatialFormat"] = Jellyfin::Support::toJsonValue<AudioSpatialFormat>(m_audioSpatialFormat);		
 	
 	if (!(m_localizedUndefined.isNull())) {
-		result["localizedUndefined"] = Jellyfin::Support::toJsonValue<QString>(m_localizedUndefined);
+		result["LocalizedUndefined"] = Jellyfin::Support::toJsonValue<QString>(m_localizedUndefined);
 	}
 			
 	
 	if (!(m_localizedDefault.isNull())) {
-		result["localizedDefault"] = Jellyfin::Support::toJsonValue<QString>(m_localizedDefault);
+		result["LocalizedDefault"] = Jellyfin::Support::toJsonValue<QString>(m_localizedDefault);
 	}
 			
 	
 	if (!(m_localizedForced.isNull())) {
-		result["localizedForced"] = Jellyfin::Support::toJsonValue<QString>(m_localizedForced);
+		result["LocalizedForced"] = Jellyfin::Support::toJsonValue<QString>(m_localizedForced);
+	}
+			
+	
+	if (!(m_localizedExternal.isNull())) {
+		result["LocalizedExternal"] = Jellyfin::Support::toJsonValue<QString>(m_localizedExternal);
+	}
+			
+	
+	if (!(m_localizedHearingImpaired.isNull())) {
+		result["LocalizedHearingImpaired"] = Jellyfin::Support::toJsonValue<QString>(m_localizedHearingImpaired);
 	}
 			
 	
@@ -346,6 +460,7 @@ QJsonObject MediaStream::toJson() const {
 			
 	result["IsDefault"] = Jellyfin::Support::toJsonValue<bool>(m_isDefault);		
 	result["IsForced"] = Jellyfin::Support::toJsonValue<bool>(m_isForced);		
+	result["IsHearingImpaired"] = Jellyfin::Support::toJsonValue<bool>(m_isHearingImpaired);		
 	
 	if (!(!m_height.has_value())) {
 		result["Height"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_height);
@@ -367,6 +482,11 @@ QJsonObject MediaStream::toJson() const {
 	}
 			
 	
+	if (!(!m_referenceFrameRate.has_value())) {
+		result["ReferenceFrameRate"] = Jellyfin::Support::toJsonValue<std::optional<float>>(m_referenceFrameRate);
+	}
+			
+	
 	if (!(m_profile.isNull())) {
 		result["Profile"] = Jellyfin::Support::toJsonValue<QString>(m_profile);
 	}
@@ -510,6 +630,123 @@ bool MediaStream::colorPrimariesNull() const {
 void MediaStream::setColorPrimariesNull() {
 	m_colorPrimaries.clear();
 
+}
+std::optional<qint32> MediaStream::dvVersionMajor() const { return m_dvVersionMajor; }
+
+void MediaStream::setDvVersionMajor(std::optional<qint32> newDvVersionMajor) {
+	m_dvVersionMajor = newDvVersionMajor;
+}
+bool MediaStream::dvVersionMajorNull() const {
+	return !m_dvVersionMajor.has_value();
+}
+
+void MediaStream::setDvVersionMajorNull() {
+	m_dvVersionMajor = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::dvVersionMinor() const { return m_dvVersionMinor; }
+
+void MediaStream::setDvVersionMinor(std::optional<qint32> newDvVersionMinor) {
+	m_dvVersionMinor = newDvVersionMinor;
+}
+bool MediaStream::dvVersionMinorNull() const {
+	return !m_dvVersionMinor.has_value();
+}
+
+void MediaStream::setDvVersionMinorNull() {
+	m_dvVersionMinor = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::dvProfile() const { return m_dvProfile; }
+
+void MediaStream::setDvProfile(std::optional<qint32> newDvProfile) {
+	m_dvProfile = newDvProfile;
+}
+bool MediaStream::dvProfileNull() const {
+	return !m_dvProfile.has_value();
+}
+
+void MediaStream::setDvProfileNull() {
+	m_dvProfile = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::dvLevel() const { return m_dvLevel; }
+
+void MediaStream::setDvLevel(std::optional<qint32> newDvLevel) {
+	m_dvLevel = newDvLevel;
+}
+bool MediaStream::dvLevelNull() const {
+	return !m_dvLevel.has_value();
+}
+
+void MediaStream::setDvLevelNull() {
+	m_dvLevel = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::rpuPresentFlag() const { return m_rpuPresentFlag; }
+
+void MediaStream::setRpuPresentFlag(std::optional<qint32> newRpuPresentFlag) {
+	m_rpuPresentFlag = newRpuPresentFlag;
+}
+bool MediaStream::rpuPresentFlagNull() const {
+	return !m_rpuPresentFlag.has_value();
+}
+
+void MediaStream::setRpuPresentFlagNull() {
+	m_rpuPresentFlag = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::elPresentFlag() const { return m_elPresentFlag; }
+
+void MediaStream::setElPresentFlag(std::optional<qint32> newElPresentFlag) {
+	m_elPresentFlag = newElPresentFlag;
+}
+bool MediaStream::elPresentFlagNull() const {
+	return !m_elPresentFlag.has_value();
+}
+
+void MediaStream::setElPresentFlagNull() {
+	m_elPresentFlag = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::blPresentFlag() const { return m_blPresentFlag; }
+
+void MediaStream::setBlPresentFlag(std::optional<qint32> newBlPresentFlag) {
+	m_blPresentFlag = newBlPresentFlag;
+}
+bool MediaStream::blPresentFlagNull() const {
+	return !m_blPresentFlag.has_value();
+}
+
+void MediaStream::setBlPresentFlagNull() {
+	m_blPresentFlag = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::dvBlSignalCompatibilityId() const { return m_dvBlSignalCompatibilityId; }
+
+void MediaStream::setDvBlSignalCompatibilityId(std::optional<qint32> newDvBlSignalCompatibilityId) {
+	m_dvBlSignalCompatibilityId = newDvBlSignalCompatibilityId;
+}
+bool MediaStream::dvBlSignalCompatibilityIdNull() const {
+	return !m_dvBlSignalCompatibilityId.has_value();
+}
+
+void MediaStream::setDvBlSignalCompatibilityIdNull() {
+	m_dvBlSignalCompatibilityId = std::nullopt;
+
+}
+std::optional<qint32> MediaStream::rotation() const { return m_rotation; }
+
+void MediaStream::setRotation(std::optional<qint32> newRotation) {
+	m_rotation = newRotation;
+}
+bool MediaStream::rotationNull() const {
+	return !m_rotation.has_value();
+}
+
+void MediaStream::setRotationNull() {
+	m_rotation = std::nullopt;
+
 }
 QString MediaStream::comment() const { return m_comment; }
 
@@ -563,19 +800,37 @@ void MediaStream::setTitleNull() {
 	m_title.clear();
 
 }
-QString MediaStream::videoRange() const { return m_videoRange; }
+VideoRange MediaStream::videoRange() const { return m_videoRange; }
 
-void MediaStream::setVideoRange(QString newVideoRange) {
+void MediaStream::setVideoRange(VideoRange newVideoRange) {
 	m_videoRange = newVideoRange;
 }
-bool MediaStream::videoRangeNull() const {
-	return m_videoRange.isNull();
+
+VideoRangeType MediaStream::videoRangeType() const { return m_videoRangeType; }
+
+void MediaStream::setVideoRangeType(VideoRangeType newVideoRangeType) {
+	m_videoRangeType = newVideoRangeType;
 }
 
-void MediaStream::setVideoRangeNull() {
-	m_videoRange.clear();
+QString MediaStream::videoDoViTitle() const { return m_videoDoViTitle; }
+
+void MediaStream::setVideoDoViTitle(QString newVideoDoViTitle) {
+	m_videoDoViTitle = newVideoDoViTitle;
+}
+bool MediaStream::videoDoViTitleNull() const {
+	return m_videoDoViTitle.isNull();
+}
+
+void MediaStream::setVideoDoViTitleNull() {
+	m_videoDoViTitle.clear();
 
 }
+AudioSpatialFormat MediaStream::audioSpatialFormat() const { return m_audioSpatialFormat; }
+
+void MediaStream::setAudioSpatialFormat(AudioSpatialFormat newAudioSpatialFormat) {
+	m_audioSpatialFormat = newAudioSpatialFormat;
+}
+
 QString MediaStream::localizedUndefined() const { return m_localizedUndefined; }
 
 void MediaStream::setLocalizedUndefined(QString newLocalizedUndefined) {
@@ -614,6 +869,32 @@ bool MediaStream::localizedForcedNull() const {
 void MediaStream::setLocalizedForcedNull() {
 	m_localizedForced.clear();
 
+}
+QString MediaStream::localizedExternal() const { return m_localizedExternal; }
+
+void MediaStream::setLocalizedExternal(QString newLocalizedExternal) {
+	m_localizedExternal = newLocalizedExternal;
+}
+bool MediaStream::localizedExternalNull() const {
+	return m_localizedExternal.isNull();
+}
+
+void MediaStream::setLocalizedExternalNull() {
+	m_localizedExternal.clear();
+
+}
+QString MediaStream::localizedHearingImpaired() const { return m_localizedHearingImpaired; }
+
+void MediaStream::setLocalizedHearingImpaired(QString newLocalizedHearingImpaired) {
+	m_localizedHearingImpaired = newLocalizedHearingImpaired;
+}
+bool MediaStream::localizedHearingImpairedNull() const {
+	return m_localizedHearingImpaired.isNull();
+}
+
+void MediaStream::setLocalizedHearingImpairedNull() {
+	m_localizedHearingImpaired.clear();
+
 }
 QString MediaStream::displayTitle() const { return m_displayTitle; }
 
@@ -763,6 +1044,12 @@ void MediaStream::setIsForced(bool newIsForced) {
 	m_isForced = newIsForced;
 }
 
+bool MediaStream::isHearingImpaired() const { return m_isHearingImpaired; }
+
+void MediaStream::setIsHearingImpaired(bool newIsHearingImpaired) {
+	m_isHearingImpaired = newIsHearingImpaired;
+}
+
 std::optional<qint32> MediaStream::height() const { return m_height; }
 
 void MediaStream::setHeight(std::optional<qint32> newHeight) {
@@ -814,6 +1101,19 @@ bool MediaStream::realFrameRateNull() const {
 void MediaStream::setRealFrameRateNull() {
 	m_realFrameRate = std::nullopt;
 
+}
+std::optional<float> MediaStream::referenceFrameRate() const { return m_referenceFrameRate; }
+
+void MediaStream::setReferenceFrameRate(std::optional<float> newReferenceFrameRate) {
+	m_referenceFrameRate = newReferenceFrameRate;
+}
+bool MediaStream::referenceFrameRateNull() const {
+	return !m_referenceFrameRate.has_value();
+}
+
+void MediaStream::setReferenceFrameRateNull() {
+	m_referenceFrameRate = std::nullopt;
+
 }
 QString MediaStream::profile() const { return m_profile; }
 
diff --git a/core/src/dto/mediastreamprotocol.cpp b/core/src/dto/mediastreamprotocol.cpp
new file mode 100644
index 0000000..302e927
--- /dev/null
+++ b/core/src/dto/mediastreamprotocol.cpp
@@ -0,0 +1,73 @@
+/*
+ * 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/dto/mediastreamprotocol.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MediaStreamProtocolClass::MediaStreamProtocolClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using MediaStreamProtocol = Jellyfin::DTO::MediaStreamProtocol;
+
+template <>
+MediaStreamProtocol fromJsonValue(const QJsonValue &source, convertType<MediaStreamProtocol>) {
+	if (!source.isString()) return MediaStreamProtocol::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("http")) {
+		return MediaStreamProtocol::Http;
+	}
+	if (str == QStringLiteral("hls")) {
+		return MediaStreamProtocol::Hls;
+	}
+	
+	return MediaStreamProtocol::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const MediaStreamProtocol &source, convertType<MediaStreamProtocol>) {
+	switch(source) {
+	case MediaStreamProtocol::Http:
+		return QStringLiteral("http");
+	case MediaStreamProtocol::Hls:
+		return QStringLiteral("hls");
+
+	case MediaStreamProtocol::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/mediastreamtype.cpp b/core/src/dto/mediastreamtype.cpp
index a196d01..bfdbc3f 100644
--- a/core/src/dto/mediastreamtype.cpp
+++ b/core/src/dto/mediastreamtype.cpp
@@ -57,6 +57,12 @@ MediaStreamType fromJsonValue(const QJsonValue &source, convertType<MediaStreamT
 	if (str == QStringLiteral("EmbeddedImage")) {
 		return MediaStreamType::EmbeddedImage;
 	}
+	if (str == QStringLiteral("Data")) {
+		return MediaStreamType::Data;
+	}
+	if (str == QStringLiteral("Lyric")) {
+		return MediaStreamType::Lyric;
+	}
 	
 	return MediaStreamType::EnumNotSet;
 }
@@ -72,6 +78,10 @@ QJsonValue toJsonValue(const MediaStreamType &source, convertType<MediaStreamTyp
 		return QStringLiteral("Subtitle");
 	case MediaStreamType::EmbeddedImage:
 		return QStringLiteral("EmbeddedImage");
+	case MediaStreamType::Data:
+		return QStringLiteral("Data");
+	case MediaStreamType::Lyric:
+		return QStringLiteral("Lyric");
 
 	case MediaStreamType::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/quickconnectstate.cpp b/core/src/dto/mediatype.cpp
similarity index 60%
rename from core/src/dto/quickconnectstate.cpp
rename to core/src/dto/mediatype.cpp
index 119a0d7..6ef570a 100644
--- a/core/src/dto/quickconnectstate.cpp
+++ b/core/src/dto/mediatype.cpp
@@ -27,48 +27,58 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/quickconnectstate.h>
+#include <JellyfinQt/dto/mediatype.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-QuickConnectStateClass::QuickConnectStateClass() {}
+MediaTypeClass::MediaTypeClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using QuickConnectState = Jellyfin::DTO::QuickConnectState;
+using MediaType = Jellyfin::DTO::MediaType;
 
 template <>
-QuickConnectState fromJsonValue(const QJsonValue &source, convertType<QuickConnectState>) {
-	if (!source.isString()) return QuickConnectState::EnumNotSet;
+MediaType fromJsonValue(const QJsonValue &source, convertType<MediaType>) {
+	if (!source.isString()) return MediaType::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("Unavailable")) {
-		return QuickConnectState::Unavailable;
+	if (str == QStringLiteral("Unknown")) {
+		return MediaType::Unknown;
 	}
-	if (str == QStringLiteral("Available")) {
-		return QuickConnectState::Available;
+	if (str == QStringLiteral("Video")) {
+		return MediaType::Video;
 	}
-	if (str == QStringLiteral("Active")) {
-		return QuickConnectState::Active;
+	if (str == QStringLiteral("Audio")) {
+		return MediaType::Audio;
+	}
+	if (str == QStringLiteral("Photo")) {
+		return MediaType::Photo;
+	}
+	if (str == QStringLiteral("Book")) {
+		return MediaType::Book;
 	}
 	
-	return QuickConnectState::EnumNotSet;
+	return MediaType::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const QuickConnectState &source, convertType<QuickConnectState>) {
+QJsonValue toJsonValue(const MediaType &source, convertType<MediaType>) {
 	switch(source) {
-	case QuickConnectState::Unavailable:
-		return QStringLiteral("Unavailable");
-	case QuickConnectState::Available:
-		return QStringLiteral("Available");
-	case QuickConnectState::Active:
-		return QStringLiteral("Active");
+	case MediaType::Unknown:
+		return QStringLiteral("Unknown");
+	case MediaType::Video:
+		return QStringLiteral("Video");
+	case MediaType::Audio:
+		return QStringLiteral("Audio");
+	case MediaType::Photo:
+		return QStringLiteral("Photo");
+	case MediaType::Book:
+		return QStringLiteral("Book");
 
-	case QuickConnectState::EnumNotSet: // Fallthrough
+	case MediaType::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/mediaupdateinfodto.cpp b/core/src/dto/mediaupdateinfodto.cpp
index 100f5c3..b3cca5e 100644
--- a/core/src/dto/mediaupdateinfodto.cpp
+++ b/core/src/dto/mediaupdateinfodto.cpp
@@ -33,16 +33,20 @@ namespace Jellyfin {
 namespace DTO {
 
 MediaUpdateInfoDto::MediaUpdateInfoDto() {}
+MediaUpdateInfoDto::MediaUpdateInfoDto (
+		QList<MediaUpdateInfoPathDto> updates 
+		) :
+	m_updates(updates) { }
+
+
 
 MediaUpdateInfoDto::MediaUpdateInfoDto(const MediaUpdateInfoDto &other) :
 
-	m_path(other.m_path),
-	m_updateType(other.m_updateType){}
+	m_updates(other.m_updates){}
 
 
 void MediaUpdateInfoDto::replaceData(MediaUpdateInfoDto &other) {
-	m_path = other.m_path;
-	m_updateType = other.m_updateType;
+	m_updates = other.m_updates;
 }
 
 MediaUpdateInfoDto MediaUpdateInfoDto::fromJson(QJsonObject source) {
@@ -53,53 +57,23 @@ MediaUpdateInfoDto MediaUpdateInfoDto::fromJson(QJsonObject source) {
 
 
 void MediaUpdateInfoDto::setFromJson(QJsonObject source) {
-	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
-	m_updateType = Jellyfin::Support::fromJsonValue<QString>(source["UpdateType"]);
+	m_updates = Jellyfin::Support::fromJsonValue<QList<MediaUpdateInfoPathDto>>(source["Updates"]);
 
 }
 	
 QJsonObject MediaUpdateInfoDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_path.isNull())) {
-		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
-	}
-			
-	
-	if (!(m_updateType.isNull())) {
-		result["UpdateType"] = Jellyfin::Support::toJsonValue<QString>(m_updateType);
-	}
-		
+	result["Updates"] = Jellyfin::Support::toJsonValue<QList<MediaUpdateInfoPathDto>>(m_updates);	
 	return result;
 }
 
-QString MediaUpdateInfoDto::path() const { return m_path; }
+QList<MediaUpdateInfoPathDto> MediaUpdateInfoDto::updates() const { return m_updates; }
 
-void MediaUpdateInfoDto::setPath(QString newPath) {
-	m_path = newPath;
-}
-bool MediaUpdateInfoDto::pathNull() const {
-	return m_path.isNull();
+void MediaUpdateInfoDto::setUpdates(QList<MediaUpdateInfoPathDto> newUpdates) {
+	m_updates = newUpdates;
 }
 
-void MediaUpdateInfoDto::setPathNull() {
-	m_path.clear();
-
-}
-QString MediaUpdateInfoDto::updateType() const { return m_updateType; }
-
-void MediaUpdateInfoDto::setUpdateType(QString newUpdateType) {
-	m_updateType = newUpdateType;
-}
-bool MediaUpdateInfoDto::updateTypeNull() const {
-	return m_updateType.isNull();
-}
-
-void MediaUpdateInfoDto::setUpdateTypeNull() {
-	m_updateType.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/mediaencoderpathdto.cpp b/core/src/dto/mediaupdateinfopathdto.cpp
similarity index 54%
rename from core/src/dto/mediaencoderpathdto.cpp
rename to core/src/dto/mediaupdateinfopathdto.cpp
index 47b8931..b99f8cb 100644
--- a/core/src/dto/mediaencoderpathdto.cpp
+++ b/core/src/dto/mediaupdateinfopathdto.cpp
@@ -27,38 +27,38 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/mediaencoderpathdto.h>
+#include <JellyfinQt/dto/mediaupdateinfopathdto.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-MediaEncoderPathDto::MediaEncoderPathDto() {}
+MediaUpdateInfoPathDto::MediaUpdateInfoPathDto() {}
 
-MediaEncoderPathDto::MediaEncoderPathDto(const MediaEncoderPathDto &other) :
+MediaUpdateInfoPathDto::MediaUpdateInfoPathDto(const MediaUpdateInfoPathDto &other) :
 
 	m_path(other.m_path),
-	m_pathType(other.m_pathType){}
+	m_updateType(other.m_updateType){}
 
 
-void MediaEncoderPathDto::replaceData(MediaEncoderPathDto &other) {
+void MediaUpdateInfoPathDto::replaceData(MediaUpdateInfoPathDto &other) {
 	m_path = other.m_path;
-	m_pathType = other.m_pathType;
+	m_updateType = other.m_updateType;
 }
 
-MediaEncoderPathDto MediaEncoderPathDto::fromJson(QJsonObject source) {
-	MediaEncoderPathDto instance;
+MediaUpdateInfoPathDto MediaUpdateInfoPathDto::fromJson(QJsonObject source) {
+	MediaUpdateInfoPathDto instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void MediaEncoderPathDto::setFromJson(QJsonObject source) {
+void MediaUpdateInfoPathDto::setFromJson(QJsonObject source) {
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
-	m_pathType = Jellyfin::Support::fromJsonValue<QString>(source["PathType"]);
+	m_updateType = Jellyfin::Support::fromJsonValue<QString>(source["UpdateType"]);
 
 }
 	
-QJsonObject MediaEncoderPathDto::toJson() const {
+QJsonObject MediaUpdateInfoPathDto::toJson() const {
 	QJsonObject result;
 	
 	
@@ -67,37 +67,37 @@ QJsonObject MediaEncoderPathDto::toJson() const {
 	}
 			
 	
-	if (!(m_pathType.isNull())) {
-		result["PathType"] = Jellyfin::Support::toJsonValue<QString>(m_pathType);
+	if (!(m_updateType.isNull())) {
+		result["UpdateType"] = Jellyfin::Support::toJsonValue<QString>(m_updateType);
 	}
 		
 	return result;
 }
 
-QString MediaEncoderPathDto::path() const { return m_path; }
+QString MediaUpdateInfoPathDto::path() const { return m_path; }
 
-void MediaEncoderPathDto::setPath(QString newPath) {
+void MediaUpdateInfoPathDto::setPath(QString newPath) {
 	m_path = newPath;
 }
-bool MediaEncoderPathDto::pathNull() const {
+bool MediaUpdateInfoPathDto::pathNull() const {
 	return m_path.isNull();
 }
 
-void MediaEncoderPathDto::setPathNull() {
+void MediaUpdateInfoPathDto::setPathNull() {
 	m_path.clear();
 
 }
-QString MediaEncoderPathDto::pathType() const { return m_pathType; }
+QString MediaUpdateInfoPathDto::updateType() const { return m_updateType; }
 
-void MediaEncoderPathDto::setPathType(QString newPathType) {
-	m_pathType = newPathType;
+void MediaUpdateInfoPathDto::setUpdateType(QString newUpdateType) {
+	m_updateType = newUpdateType;
 }
-bool MediaEncoderPathDto::pathTypeNull() const {
-	return m_pathType.isNull();
+bool MediaUpdateInfoPathDto::updateTypeNull() const {
+	return m_updateType.isNull();
 }
 
-void MediaEncoderPathDto::setPathTypeNull() {
-	m_pathType.clear();
+void MediaUpdateInfoPathDto::setUpdateTypeNull() {
+	m_updateType.clear();
 
 }
 
@@ -105,16 +105,16 @@ void MediaEncoderPathDto::setPathTypeNull() {
 
 namespace Support {
 
-using MediaEncoderPathDto = Jellyfin::DTO::MediaEncoderPathDto;
+using MediaUpdateInfoPathDto = Jellyfin::DTO::MediaUpdateInfoPathDto;
 
 template <>
-MediaEncoderPathDto fromJsonValue(const QJsonValue &source, convertType<MediaEncoderPathDto>) {
+MediaUpdateInfoPathDto fromJsonValue(const QJsonValue &source, convertType<MediaUpdateInfoPathDto>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return MediaEncoderPathDto::fromJson(source.toObject());
+	return MediaUpdateInfoPathDto::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const MediaEncoderPathDto &source, convertType<MediaEncoderPathDto>) {
+QJsonValue toJsonValue(const MediaUpdateInfoPathDto &source, convertType<MediaUpdateInfoPathDto>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/messagecommand.cpp b/core/src/dto/messagecommand.cpp
new file mode 100644
index 0000000..b5ecd74
--- /dev/null
+++ b/core/src/dto/messagecommand.cpp
@@ -0,0 +1,138 @@
+/*
+ * 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/dto/messagecommand.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MessageCommand::MessageCommand() {}
+MessageCommand::MessageCommand (
+		QString text 
+		) :
+	m_text(text) { }
+
+
+
+MessageCommand::MessageCommand(const MessageCommand &other) :
+
+	m_header(other.m_header),
+	m_text(other.m_text),
+	m_timeoutMs(other.m_timeoutMs){}
+
+
+void MessageCommand::replaceData(MessageCommand &other) {
+	m_header = other.m_header;
+	m_text = other.m_text;
+	m_timeoutMs = other.m_timeoutMs;
+}
+
+MessageCommand MessageCommand::fromJson(QJsonObject source) {
+	MessageCommand instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void MessageCommand::setFromJson(QJsonObject source) {
+	m_header = Jellyfin::Support::fromJsonValue<QString>(source["Header"]);
+	m_text = Jellyfin::Support::fromJsonValue<QString>(source["Text"]);
+	m_timeoutMs = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["TimeoutMs"]);
+
+}
+	
+QJsonObject MessageCommand::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_header.isNull())) {
+		result["Header"] = Jellyfin::Support::toJsonValue<QString>(m_header);
+	}
+			
+	result["Text"] = Jellyfin::Support::toJsonValue<QString>(m_text);		
+	
+	if (!(!m_timeoutMs.has_value())) {
+		result["TimeoutMs"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_timeoutMs);
+	}
+		
+	return result;
+}
+
+QString MessageCommand::header() const { return m_header; }
+
+void MessageCommand::setHeader(QString newHeader) {
+	m_header = newHeader;
+}
+bool MessageCommand::headerNull() const {
+	return m_header.isNull();
+}
+
+void MessageCommand::setHeaderNull() {
+	m_header.clear();
+
+}
+QString MessageCommand::text() const { return m_text; }
+
+void MessageCommand::setText(QString newText) {
+	m_text = newText;
+}
+
+std::optional<qint64> MessageCommand::timeoutMs() const { return m_timeoutMs; }
+
+void MessageCommand::setTimeoutMs(std::optional<qint64> newTimeoutMs) {
+	m_timeoutMs = newTimeoutMs;
+}
+bool MessageCommand::timeoutMsNull() const {
+	return !m_timeoutMs.has_value();
+}
+
+void MessageCommand::setTimeoutMsNull() {
+	m_timeoutMs = std::nullopt;
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using MessageCommand = Jellyfin::DTO::MessageCommand;
+
+template <>
+MessageCommand fromJsonValue(const QJsonValue &source, convertType<MessageCommand>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return MessageCommand::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const MessageCommand &source, convertType<MessageCommand>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/metadataconfiguration.cpp b/core/src/dto/metadataconfiguration.cpp
new file mode 100644
index 0000000..5f3cb42
--- /dev/null
+++ b/core/src/dto/metadataconfiguration.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/metadataconfiguration.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+MetadataConfiguration::MetadataConfiguration() {}
+MetadataConfiguration::MetadataConfiguration (
+		bool useFileCreationTimeForDateAdded 
+		) :
+	m_useFileCreationTimeForDateAdded(useFileCreationTimeForDateAdded) { }
+
+
+
+MetadataConfiguration::MetadataConfiguration(const MetadataConfiguration &other) :
+
+	m_useFileCreationTimeForDateAdded(other.m_useFileCreationTimeForDateAdded){}
+
+
+void MetadataConfiguration::replaceData(MetadataConfiguration &other) {
+	m_useFileCreationTimeForDateAdded = other.m_useFileCreationTimeForDateAdded;
+}
+
+MetadataConfiguration MetadataConfiguration::fromJson(QJsonObject source) {
+	MetadataConfiguration instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void MetadataConfiguration::setFromJson(QJsonObject source) {
+	m_useFileCreationTimeForDateAdded = Jellyfin::Support::fromJsonValue<bool>(source["UseFileCreationTimeForDateAdded"]);
+
+}
+	
+QJsonObject MetadataConfiguration::toJson() const {
+	QJsonObject result;
+	
+	result["UseFileCreationTimeForDateAdded"] = Jellyfin::Support::toJsonValue<bool>(m_useFileCreationTimeForDateAdded);	
+	return result;
+}
+
+bool MetadataConfiguration::useFileCreationTimeForDateAdded() const { return m_useFileCreationTimeForDateAdded; }
+
+void MetadataConfiguration::setUseFileCreationTimeForDateAdded(bool newUseFileCreationTimeForDateAdded) {
+	m_useFileCreationTimeForDateAdded = newUseFileCreationTimeForDateAdded;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using MetadataConfiguration = Jellyfin::DTO::MetadataConfiguration;
+
+template <>
+MetadataConfiguration fromJsonValue(const QJsonValue &source, convertType<MetadataConfiguration>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return MetadataConfiguration::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const MetadataConfiguration &source, convertType<MetadataConfiguration>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/metadataeditorinfo.cpp b/core/src/dto/metadataeditorinfo.cpp
index 9d975f9..72d5062 100644
--- a/core/src/dto/metadataeditorinfo.cpp
+++ b/core/src/dto/metadataeditorinfo.cpp
@@ -33,6 +33,22 @@ namespace Jellyfin {
 namespace DTO {
 
 MetadataEditorInfo::MetadataEditorInfo() {}
+MetadataEditorInfo::MetadataEditorInfo (
+		QList<ParentalRating> parentalRatingOptions, 
+		QList<CountryInfo> countries, 
+		QList<CultureDto> cultures, 
+		QList<ExternalIdInfo> externalIdInfos, 
+		CollectionType contentType, 
+		QList<NameValuePair> contentTypeOptions 
+		) :
+	m_parentalRatingOptions(parentalRatingOptions),
+	m_countries(countries),
+	m_cultures(cultures),
+	m_externalIdInfos(externalIdInfos),
+	m_contentType(contentType),
+	m_contentTypeOptions(contentTypeOptions) { }
+
+
 
 MetadataEditorInfo::MetadataEditorInfo(const MetadataEditorInfo &other) :
 
@@ -65,7 +81,7 @@ void MetadataEditorInfo::setFromJson(QJsonObject source) {
 	m_countries = Jellyfin::Support::fromJsonValue<QList<CountryInfo>>(source["Countries"]);
 	m_cultures = Jellyfin::Support::fromJsonValue<QList<CultureDto>>(source["Cultures"]);
 	m_externalIdInfos = Jellyfin::Support::fromJsonValue<QList<ExternalIdInfo>>(source["ExternalIdInfos"]);
-	m_contentType = Jellyfin::Support::fromJsonValue<QString>(source["ContentType"]);
+	m_contentType = Jellyfin::Support::fromJsonValue<CollectionType>(source["ContentType"]);
 	m_contentTypeOptions = Jellyfin::Support::fromJsonValue<QList<NameValuePair>>(source["ContentTypeOptions"]);
 
 }
@@ -73,36 +89,12 @@ void MetadataEditorInfo::setFromJson(QJsonObject source) {
 QJsonObject MetadataEditorInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_parentalRatingOptions.size() == 0)) {
-		result["ParentalRatingOptions"] = Jellyfin::Support::toJsonValue<QList<ParentalRating>>(m_parentalRatingOptions);
-	}
-			
-	
-	if (!(m_countries.size() == 0)) {
-		result["Countries"] = Jellyfin::Support::toJsonValue<QList<CountryInfo>>(m_countries);
-	}
-			
-	
-	if (!(m_cultures.size() == 0)) {
-		result["Cultures"] = Jellyfin::Support::toJsonValue<QList<CultureDto>>(m_cultures);
-	}
-			
-	
-	if (!(m_externalIdInfos.size() == 0)) {
-		result["ExternalIdInfos"] = Jellyfin::Support::toJsonValue<QList<ExternalIdInfo>>(m_externalIdInfos);
-	}
-			
-	
-	if (!(m_contentType.isNull())) {
-		result["ContentType"] = Jellyfin::Support::toJsonValue<QString>(m_contentType);
-	}
-			
-	
-	if (!(m_contentTypeOptions.size() == 0)) {
-		result["ContentTypeOptions"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_contentTypeOptions);
-	}
-		
+	result["ParentalRatingOptions"] = Jellyfin::Support::toJsonValue<QList<ParentalRating>>(m_parentalRatingOptions);		
+	result["Countries"] = Jellyfin::Support::toJsonValue<QList<CountryInfo>>(m_countries);		
+	result["Cultures"] = Jellyfin::Support::toJsonValue<QList<CultureDto>>(m_cultures);		
+	result["ExternalIdInfos"] = Jellyfin::Support::toJsonValue<QList<ExternalIdInfo>>(m_externalIdInfos);		
+	result["ContentType"] = Jellyfin::Support::toJsonValue<CollectionType>(m_contentType);		
+	result["ContentTypeOptions"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_contentTypeOptions);	
 	return result;
 }
 
@@ -111,79 +103,37 @@ QList<ParentalRating> MetadataEditorInfo::parentalRatingOptions() const { return
 void MetadataEditorInfo::setParentalRatingOptions(QList<ParentalRating> newParentalRatingOptions) {
 	m_parentalRatingOptions = newParentalRatingOptions;
 }
-bool MetadataEditorInfo::parentalRatingOptionsNull() const {
-	return m_parentalRatingOptions.size() == 0;
-}
 
-void MetadataEditorInfo::setParentalRatingOptionsNull() {
-	m_parentalRatingOptions.clear();
-
-}
 QList<CountryInfo> MetadataEditorInfo::countries() const { return m_countries; }
 
 void MetadataEditorInfo::setCountries(QList<CountryInfo> newCountries) {
 	m_countries = newCountries;
 }
-bool MetadataEditorInfo::countriesNull() const {
-	return m_countries.size() == 0;
-}
 
-void MetadataEditorInfo::setCountriesNull() {
-	m_countries.clear();
-
-}
 QList<CultureDto> MetadataEditorInfo::cultures() const { return m_cultures; }
 
 void MetadataEditorInfo::setCultures(QList<CultureDto> newCultures) {
 	m_cultures = newCultures;
 }
-bool MetadataEditorInfo::culturesNull() const {
-	return m_cultures.size() == 0;
-}
 
-void MetadataEditorInfo::setCulturesNull() {
-	m_cultures.clear();
-
-}
 QList<ExternalIdInfo> MetadataEditorInfo::externalIdInfos() const { return m_externalIdInfos; }
 
 void MetadataEditorInfo::setExternalIdInfos(QList<ExternalIdInfo> newExternalIdInfos) {
 	m_externalIdInfos = newExternalIdInfos;
 }
-bool MetadataEditorInfo::externalIdInfosNull() const {
-	return m_externalIdInfos.size() == 0;
-}
 
-void MetadataEditorInfo::setExternalIdInfosNull() {
-	m_externalIdInfos.clear();
+CollectionType MetadataEditorInfo::contentType() const { return m_contentType; }
 
-}
-QString MetadataEditorInfo::contentType() const { return m_contentType; }
-
-void MetadataEditorInfo::setContentType(QString newContentType) {
+void MetadataEditorInfo::setContentType(CollectionType newContentType) {
 	m_contentType = newContentType;
 }
-bool MetadataEditorInfo::contentTypeNull() const {
-	return m_contentType.isNull();
-}
 
-void MetadataEditorInfo::setContentTypeNull() {
-	m_contentType.clear();
-
-}
 QList<NameValuePair> MetadataEditorInfo::contentTypeOptions() const { return m_contentTypeOptions; }
 
 void MetadataEditorInfo::setContentTypeOptions(QList<NameValuePair> newContentTypeOptions) {
 	m_contentTypeOptions = newContentTypeOptions;
 }
-bool MetadataEditorInfo::contentTypeOptionsNull() const {
-	return m_contentTypeOptions.size() == 0;
-}
 
-void MetadataEditorInfo::setContentTypeOptionsNull() {
-	m_contentTypeOptions.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/movieinfo.cpp b/core/src/dto/movieinfo.cpp
index 3afb233..a184b41 100644
--- a/core/src/dto/movieinfo.cpp
+++ b/core/src/dto/movieinfo.cpp
@@ -43,6 +43,7 @@ MovieInfo::MovieInfo (
 MovieInfo::MovieInfo(const MovieInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -56,6 +57,7 @@ MovieInfo::MovieInfo(const MovieInfo &other) :
 
 void MovieInfo::replaceData(MovieInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -76,6 +78,7 @@ MovieInfo MovieInfo::fromJson(QJsonObject source) {
 
 void MovieInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -97,6 +100,11 @@ QJsonObject MovieInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -152,6 +160,19 @@ bool MovieInfo::nameNull() const {
 void MovieInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString MovieInfo::originalTitle() const { return m_originalTitle; }
+
+void MovieInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool MovieInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void MovieInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString MovieInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/musicvideoinfo.cpp b/core/src/dto/musicvideoinfo.cpp
index c5ab83e..2e6b221 100644
--- a/core/src/dto/musicvideoinfo.cpp
+++ b/core/src/dto/musicvideoinfo.cpp
@@ -43,6 +43,7 @@ MusicVideoInfo::MusicVideoInfo (
 MusicVideoInfo::MusicVideoInfo(const MusicVideoInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -57,6 +58,7 @@ MusicVideoInfo::MusicVideoInfo(const MusicVideoInfo &other) :
 
 void MusicVideoInfo::replaceData(MusicVideoInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -78,6 +80,7 @@ MusicVideoInfo MusicVideoInfo::fromJson(QJsonObject source) {
 
 void MusicVideoInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -100,6 +103,11 @@ QJsonObject MusicVideoInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -160,6 +168,19 @@ bool MusicVideoInfo::nameNull() const {
 void MusicVideoInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString MusicVideoInfo::originalTitle() const { return m_originalTitle; }
+
+void MusicVideoInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool MusicVideoInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void MusicVideoInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString MusicVideoInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/networkconfiguration.cpp b/core/src/dto/networkconfiguration.cpp
new file mode 100644
index 0000000..937446e
--- /dev/null
+++ b/core/src/dto/networkconfiguration.cpp
@@ -0,0 +1,360 @@
+/*
+ * 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/dto/networkconfiguration.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+NetworkConfiguration::NetworkConfiguration() {}
+NetworkConfiguration::NetworkConfiguration (
+		QString baseUrl, 
+		bool enableHttps, 
+		bool requireHttps, 
+		QString certificatePath, 
+		QString certificatePassword, 
+		qint32 internalHttpPort, 
+		qint32 internalHttpsPort, 
+		qint32 publicHttpPort, 
+		qint32 publicHttpsPort, 
+		bool autoDiscovery, 
+		bool enableUPnP, 
+		bool enableIPv4, 
+		bool enableIPv6, 
+		bool enableRemoteAccess, 
+		QStringList localNetworkSubnets, 
+		QStringList localNetworkAddresses, 
+		QStringList knownProxies, 
+		bool ignoreVirtualInterfaces, 
+		QStringList virtualInterfaceNames, 
+		bool enablePublishedServerUriByRequest, 
+		QStringList publishedServerUriBySubnet, 
+		QStringList remoteIPFilter, 
+		bool isRemoteIPFilterBlacklist 
+		) :
+	m_baseUrl(baseUrl),
+	m_enableHttps(enableHttps),
+	m_requireHttps(requireHttps),
+	m_certificatePath(certificatePath),
+	m_certificatePassword(certificatePassword),
+	m_internalHttpPort(internalHttpPort),
+	m_internalHttpsPort(internalHttpsPort),
+	m_publicHttpPort(publicHttpPort),
+	m_publicHttpsPort(publicHttpsPort),
+	m_autoDiscovery(autoDiscovery),
+	m_enableUPnP(enableUPnP),
+	m_enableIPv4(enableIPv4),
+	m_enableIPv6(enableIPv6),
+	m_enableRemoteAccess(enableRemoteAccess),
+	m_localNetworkSubnets(localNetworkSubnets),
+	m_localNetworkAddresses(localNetworkAddresses),
+	m_knownProxies(knownProxies),
+	m_ignoreVirtualInterfaces(ignoreVirtualInterfaces),
+	m_virtualInterfaceNames(virtualInterfaceNames),
+	m_enablePublishedServerUriByRequest(enablePublishedServerUriByRequest),
+	m_publishedServerUriBySubnet(publishedServerUriBySubnet),
+	m_remoteIPFilter(remoteIPFilter),
+	m_isRemoteIPFilterBlacklist(isRemoteIPFilterBlacklist) { }
+
+
+
+NetworkConfiguration::NetworkConfiguration(const NetworkConfiguration &other) :
+
+	m_baseUrl(other.m_baseUrl),
+	m_enableHttps(other.m_enableHttps),
+	m_requireHttps(other.m_requireHttps),
+	m_certificatePath(other.m_certificatePath),
+	m_certificatePassword(other.m_certificatePassword),
+	m_internalHttpPort(other.m_internalHttpPort),
+	m_internalHttpsPort(other.m_internalHttpsPort),
+	m_publicHttpPort(other.m_publicHttpPort),
+	m_publicHttpsPort(other.m_publicHttpsPort),
+	m_autoDiscovery(other.m_autoDiscovery),
+	m_enableUPnP(other.m_enableUPnP),
+	m_enableIPv4(other.m_enableIPv4),
+	m_enableIPv6(other.m_enableIPv6),
+	m_enableRemoteAccess(other.m_enableRemoteAccess),
+	m_localNetworkSubnets(other.m_localNetworkSubnets),
+	m_localNetworkAddresses(other.m_localNetworkAddresses),
+	m_knownProxies(other.m_knownProxies),
+	m_ignoreVirtualInterfaces(other.m_ignoreVirtualInterfaces),
+	m_virtualInterfaceNames(other.m_virtualInterfaceNames),
+	m_enablePublishedServerUriByRequest(other.m_enablePublishedServerUriByRequest),
+	m_publishedServerUriBySubnet(other.m_publishedServerUriBySubnet),
+	m_remoteIPFilter(other.m_remoteIPFilter),
+	m_isRemoteIPFilterBlacklist(other.m_isRemoteIPFilterBlacklist){}
+
+
+void NetworkConfiguration::replaceData(NetworkConfiguration &other) {
+	m_baseUrl = other.m_baseUrl;
+	m_enableHttps = other.m_enableHttps;
+	m_requireHttps = other.m_requireHttps;
+	m_certificatePath = other.m_certificatePath;
+	m_certificatePassword = other.m_certificatePassword;
+	m_internalHttpPort = other.m_internalHttpPort;
+	m_internalHttpsPort = other.m_internalHttpsPort;
+	m_publicHttpPort = other.m_publicHttpPort;
+	m_publicHttpsPort = other.m_publicHttpsPort;
+	m_autoDiscovery = other.m_autoDiscovery;
+	m_enableUPnP = other.m_enableUPnP;
+	m_enableIPv4 = other.m_enableIPv4;
+	m_enableIPv6 = other.m_enableIPv6;
+	m_enableRemoteAccess = other.m_enableRemoteAccess;
+	m_localNetworkSubnets = other.m_localNetworkSubnets;
+	m_localNetworkAddresses = other.m_localNetworkAddresses;
+	m_knownProxies = other.m_knownProxies;
+	m_ignoreVirtualInterfaces = other.m_ignoreVirtualInterfaces;
+	m_virtualInterfaceNames = other.m_virtualInterfaceNames;
+	m_enablePublishedServerUriByRequest = other.m_enablePublishedServerUriByRequest;
+	m_publishedServerUriBySubnet = other.m_publishedServerUriBySubnet;
+	m_remoteIPFilter = other.m_remoteIPFilter;
+	m_isRemoteIPFilterBlacklist = other.m_isRemoteIPFilterBlacklist;
+}
+
+NetworkConfiguration NetworkConfiguration::fromJson(QJsonObject source) {
+	NetworkConfiguration instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void NetworkConfiguration::setFromJson(QJsonObject source) {
+	m_baseUrl = Jellyfin::Support::fromJsonValue<QString>(source["BaseUrl"]);
+	m_enableHttps = Jellyfin::Support::fromJsonValue<bool>(source["EnableHttps"]);
+	m_requireHttps = Jellyfin::Support::fromJsonValue<bool>(source["RequireHttps"]);
+	m_certificatePath = Jellyfin::Support::fromJsonValue<QString>(source["CertificatePath"]);
+	m_certificatePassword = Jellyfin::Support::fromJsonValue<QString>(source["CertificatePassword"]);
+	m_internalHttpPort = Jellyfin::Support::fromJsonValue<qint32>(source["InternalHttpPort"]);
+	m_internalHttpsPort = Jellyfin::Support::fromJsonValue<qint32>(source["InternalHttpsPort"]);
+	m_publicHttpPort = Jellyfin::Support::fromJsonValue<qint32>(source["PublicHttpPort"]);
+	m_publicHttpsPort = Jellyfin::Support::fromJsonValue<qint32>(source["PublicHttpsPort"]);
+	m_autoDiscovery = Jellyfin::Support::fromJsonValue<bool>(source["AutoDiscovery"]);
+	m_enableUPnP = Jellyfin::Support::fromJsonValue<bool>(source["EnableUPnP"]);
+	m_enableIPv4 = Jellyfin::Support::fromJsonValue<bool>(source["EnableIPv4"]);
+	m_enableIPv6 = Jellyfin::Support::fromJsonValue<bool>(source["EnableIPv6"]);
+	m_enableRemoteAccess = Jellyfin::Support::fromJsonValue<bool>(source["EnableRemoteAccess"]);
+	m_localNetworkSubnets = Jellyfin::Support::fromJsonValue<QStringList>(source["LocalNetworkSubnets"]);
+	m_localNetworkAddresses = Jellyfin::Support::fromJsonValue<QStringList>(source["LocalNetworkAddresses"]);
+	m_knownProxies = Jellyfin::Support::fromJsonValue<QStringList>(source["KnownProxies"]);
+	m_ignoreVirtualInterfaces = Jellyfin::Support::fromJsonValue<bool>(source["IgnoreVirtualInterfaces"]);
+	m_virtualInterfaceNames = Jellyfin::Support::fromJsonValue<QStringList>(source["VirtualInterfaceNames"]);
+	m_enablePublishedServerUriByRequest = Jellyfin::Support::fromJsonValue<bool>(source["EnablePublishedServerUriByRequest"]);
+	m_publishedServerUriBySubnet = Jellyfin::Support::fromJsonValue<QStringList>(source["PublishedServerUriBySubnet"]);
+	m_remoteIPFilter = Jellyfin::Support::fromJsonValue<QStringList>(source["RemoteIPFilter"]);
+	m_isRemoteIPFilterBlacklist = Jellyfin::Support::fromJsonValue<bool>(source["IsRemoteIPFilterBlacklist"]);
+
+}
+	
+QJsonObject NetworkConfiguration::toJson() const {
+	QJsonObject result;
+	
+	result["BaseUrl"] = Jellyfin::Support::toJsonValue<QString>(m_baseUrl);		
+	result["EnableHttps"] = Jellyfin::Support::toJsonValue<bool>(m_enableHttps);		
+	result["RequireHttps"] = Jellyfin::Support::toJsonValue<bool>(m_requireHttps);		
+	result["CertificatePath"] = Jellyfin::Support::toJsonValue<QString>(m_certificatePath);		
+	result["CertificatePassword"] = Jellyfin::Support::toJsonValue<QString>(m_certificatePassword);		
+	result["InternalHttpPort"] = Jellyfin::Support::toJsonValue<qint32>(m_internalHttpPort);		
+	result["InternalHttpsPort"] = Jellyfin::Support::toJsonValue<qint32>(m_internalHttpsPort);		
+	result["PublicHttpPort"] = Jellyfin::Support::toJsonValue<qint32>(m_publicHttpPort);		
+	result["PublicHttpsPort"] = Jellyfin::Support::toJsonValue<qint32>(m_publicHttpsPort);		
+	result["AutoDiscovery"] = Jellyfin::Support::toJsonValue<bool>(m_autoDiscovery);		
+	result["EnableUPnP"] = Jellyfin::Support::toJsonValue<bool>(m_enableUPnP);		
+	result["EnableIPv4"] = Jellyfin::Support::toJsonValue<bool>(m_enableIPv4);		
+	result["EnableIPv6"] = Jellyfin::Support::toJsonValue<bool>(m_enableIPv6);		
+	result["EnableRemoteAccess"] = Jellyfin::Support::toJsonValue<bool>(m_enableRemoteAccess);		
+	result["LocalNetworkSubnets"] = Jellyfin::Support::toJsonValue<QStringList>(m_localNetworkSubnets);		
+	result["LocalNetworkAddresses"] = Jellyfin::Support::toJsonValue<QStringList>(m_localNetworkAddresses);		
+	result["KnownProxies"] = Jellyfin::Support::toJsonValue<QStringList>(m_knownProxies);		
+	result["IgnoreVirtualInterfaces"] = Jellyfin::Support::toJsonValue<bool>(m_ignoreVirtualInterfaces);		
+	result["VirtualInterfaceNames"] = Jellyfin::Support::toJsonValue<QStringList>(m_virtualInterfaceNames);		
+	result["EnablePublishedServerUriByRequest"] = Jellyfin::Support::toJsonValue<bool>(m_enablePublishedServerUriByRequest);		
+	result["PublishedServerUriBySubnet"] = Jellyfin::Support::toJsonValue<QStringList>(m_publishedServerUriBySubnet);		
+	result["RemoteIPFilter"] = Jellyfin::Support::toJsonValue<QStringList>(m_remoteIPFilter);		
+	result["IsRemoteIPFilterBlacklist"] = Jellyfin::Support::toJsonValue<bool>(m_isRemoteIPFilterBlacklist);	
+	return result;
+}
+
+QString NetworkConfiguration::baseUrl() const { return m_baseUrl; }
+
+void NetworkConfiguration::setBaseUrl(QString newBaseUrl) {
+	m_baseUrl = newBaseUrl;
+}
+
+bool NetworkConfiguration::enableHttps() const { return m_enableHttps; }
+
+void NetworkConfiguration::setEnableHttps(bool newEnableHttps) {
+	m_enableHttps = newEnableHttps;
+}
+
+bool NetworkConfiguration::requireHttps() const { return m_requireHttps; }
+
+void NetworkConfiguration::setRequireHttps(bool newRequireHttps) {
+	m_requireHttps = newRequireHttps;
+}
+
+QString NetworkConfiguration::certificatePath() const { return m_certificatePath; }
+
+void NetworkConfiguration::setCertificatePath(QString newCertificatePath) {
+	m_certificatePath = newCertificatePath;
+}
+
+QString NetworkConfiguration::certificatePassword() const { return m_certificatePassword; }
+
+void NetworkConfiguration::setCertificatePassword(QString newCertificatePassword) {
+	m_certificatePassword = newCertificatePassword;
+}
+
+qint32 NetworkConfiguration::internalHttpPort() const { return m_internalHttpPort; }
+
+void NetworkConfiguration::setInternalHttpPort(qint32 newInternalHttpPort) {
+	m_internalHttpPort = newInternalHttpPort;
+}
+
+qint32 NetworkConfiguration::internalHttpsPort() const { return m_internalHttpsPort; }
+
+void NetworkConfiguration::setInternalHttpsPort(qint32 newInternalHttpsPort) {
+	m_internalHttpsPort = newInternalHttpsPort;
+}
+
+qint32 NetworkConfiguration::publicHttpPort() const { return m_publicHttpPort; }
+
+void NetworkConfiguration::setPublicHttpPort(qint32 newPublicHttpPort) {
+	m_publicHttpPort = newPublicHttpPort;
+}
+
+qint32 NetworkConfiguration::publicHttpsPort() const { return m_publicHttpsPort; }
+
+void NetworkConfiguration::setPublicHttpsPort(qint32 newPublicHttpsPort) {
+	m_publicHttpsPort = newPublicHttpsPort;
+}
+
+bool NetworkConfiguration::autoDiscovery() const { return m_autoDiscovery; }
+
+void NetworkConfiguration::setAutoDiscovery(bool newAutoDiscovery) {
+	m_autoDiscovery = newAutoDiscovery;
+}
+
+bool NetworkConfiguration::enableUPnP() const { return m_enableUPnP; }
+
+void NetworkConfiguration::setEnableUPnP(bool newEnableUPnP) {
+	m_enableUPnP = newEnableUPnP;
+}
+
+bool NetworkConfiguration::enableIPv4() const { return m_enableIPv4; }
+
+void NetworkConfiguration::setEnableIPv4(bool newEnableIPv4) {
+	m_enableIPv4 = newEnableIPv4;
+}
+
+bool NetworkConfiguration::enableIPv6() const { return m_enableIPv6; }
+
+void NetworkConfiguration::setEnableIPv6(bool newEnableIPv6) {
+	m_enableIPv6 = newEnableIPv6;
+}
+
+bool NetworkConfiguration::enableRemoteAccess() const { return m_enableRemoteAccess; }
+
+void NetworkConfiguration::setEnableRemoteAccess(bool newEnableRemoteAccess) {
+	m_enableRemoteAccess = newEnableRemoteAccess;
+}
+
+QStringList NetworkConfiguration::localNetworkSubnets() const { return m_localNetworkSubnets; }
+
+void NetworkConfiguration::setLocalNetworkSubnets(QStringList newLocalNetworkSubnets) {
+	m_localNetworkSubnets = newLocalNetworkSubnets;
+}
+
+QStringList NetworkConfiguration::localNetworkAddresses() const { return m_localNetworkAddresses; }
+
+void NetworkConfiguration::setLocalNetworkAddresses(QStringList newLocalNetworkAddresses) {
+	m_localNetworkAddresses = newLocalNetworkAddresses;
+}
+
+QStringList NetworkConfiguration::knownProxies() const { return m_knownProxies; }
+
+void NetworkConfiguration::setKnownProxies(QStringList newKnownProxies) {
+	m_knownProxies = newKnownProxies;
+}
+
+bool NetworkConfiguration::ignoreVirtualInterfaces() const { return m_ignoreVirtualInterfaces; }
+
+void NetworkConfiguration::setIgnoreVirtualInterfaces(bool newIgnoreVirtualInterfaces) {
+	m_ignoreVirtualInterfaces = newIgnoreVirtualInterfaces;
+}
+
+QStringList NetworkConfiguration::virtualInterfaceNames() const { return m_virtualInterfaceNames; }
+
+void NetworkConfiguration::setVirtualInterfaceNames(QStringList newVirtualInterfaceNames) {
+	m_virtualInterfaceNames = newVirtualInterfaceNames;
+}
+
+bool NetworkConfiguration::enablePublishedServerUriByRequest() const { return m_enablePublishedServerUriByRequest; }
+
+void NetworkConfiguration::setEnablePublishedServerUriByRequest(bool newEnablePublishedServerUriByRequest) {
+	m_enablePublishedServerUriByRequest = newEnablePublishedServerUriByRequest;
+}
+
+QStringList NetworkConfiguration::publishedServerUriBySubnet() const { return m_publishedServerUriBySubnet; }
+
+void NetworkConfiguration::setPublishedServerUriBySubnet(QStringList newPublishedServerUriBySubnet) {
+	m_publishedServerUriBySubnet = newPublishedServerUriBySubnet;
+}
+
+QStringList NetworkConfiguration::remoteIPFilter() const { return m_remoteIPFilter; }
+
+void NetworkConfiguration::setRemoteIPFilter(QStringList newRemoteIPFilter) {
+	m_remoteIPFilter = newRemoteIPFilter;
+}
+
+bool NetworkConfiguration::isRemoteIPFilterBlacklist() const { return m_isRemoteIPFilterBlacklist; }
+
+void NetworkConfiguration::setIsRemoteIPFilterBlacklist(bool newIsRemoteIPFilterBlacklist) {
+	m_isRemoteIPFilterBlacklist = newIsRemoteIPFilterBlacklist;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using NetworkConfiguration = Jellyfin::DTO::NetworkConfiguration;
+
+template <>
+NetworkConfiguration fromJsonValue(const QJsonValue &source, convertType<NetworkConfiguration>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return NetworkConfiguration::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const NetworkConfiguration &source, convertType<NetworkConfiguration>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/newgrouprequestdto.cpp b/core/src/dto/newgrouprequestdto.cpp
index dcf67ee..28a32c4 100644
--- a/core/src/dto/newgrouprequestdto.cpp
+++ b/core/src/dto/newgrouprequestdto.cpp
@@ -33,6 +33,12 @@ namespace Jellyfin {
 namespace DTO {
 
 NewGroupRequestDto::NewGroupRequestDto() {}
+NewGroupRequestDto::NewGroupRequestDto (
+		QString groupName 
+		) :
+	m_groupName(groupName) { }
+
+
 
 NewGroupRequestDto::NewGroupRequestDto(const NewGroupRequestDto &other) :
 
@@ -58,11 +64,7 @@ void NewGroupRequestDto::setFromJson(QJsonObject source) {
 QJsonObject NewGroupRequestDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_groupName.isNull())) {
-		result["GroupName"] = Jellyfin::Support::toJsonValue<QString>(m_groupName);
-	}
-		
+	result["GroupName"] = Jellyfin::Support::toJsonValue<QString>(m_groupName);	
 	return result;
 }
 
@@ -71,14 +73,7 @@ QString NewGroupRequestDto::groupName() const { return m_groupName; }
 void NewGroupRequestDto::setGroupName(QString newGroupName) {
 	m_groupName = newGroupName;
 }
-bool NewGroupRequestDto::groupNameNull() const {
-	return m_groupName.isNull();
-}
 
-void NewGroupRequestDto::setGroupNameNull() {
-	m_groupName.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/notificationdto.cpp b/core/src/dto/notificationdto.cpp
deleted file mode 100644
index 8a64a6a..0000000
--- a/core/src/dto/notificationdto.cpp
+++ /dev/null
@@ -1,225 +0,0 @@
-/*
- * 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/dto/notificationdto.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-NotificationDto::NotificationDto() {}
-NotificationDto::NotificationDto (
-		QDateTime date, 
-		bool isRead, 
-		NotificationLevel level 
-		) :
-	m_date(date),
-	m_isRead(isRead),
-	m_level(level) { }
-
-
-
-NotificationDto::NotificationDto(const NotificationDto &other) :
-
-	m_jellyfinId(other.m_jellyfinId),
-	m_userId(other.m_userId),
-	m_date(other.m_date),
-	m_isRead(other.m_isRead),
-	m_name(other.m_name),
-	m_description(other.m_description),
-	m_url(other.m_url),
-	m_level(other.m_level){}
-
-
-void NotificationDto::replaceData(NotificationDto &other) {
-	m_jellyfinId = other.m_jellyfinId;
-	m_userId = other.m_userId;
-	m_date = other.m_date;
-	m_isRead = other.m_isRead;
-	m_name = other.m_name;
-	m_description = other.m_description;
-	m_url = other.m_url;
-	m_level = other.m_level;
-}
-
-NotificationDto NotificationDto::fromJson(QJsonObject source) {
-	NotificationDto instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void NotificationDto::setFromJson(QJsonObject source) {
-	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
-	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
-	m_date = Jellyfin::Support::fromJsonValue<QDateTime>(source["Date"]);
-	m_isRead = Jellyfin::Support::fromJsonValue<bool>(source["IsRead"]);
-	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_description = Jellyfin::Support::fromJsonValue<QString>(source["Description"]);
-	m_url = Jellyfin::Support::fromJsonValue<QString>(source["Url"]);
-	m_level = Jellyfin::Support::fromJsonValue<NotificationLevel>(source["Level"]);
-
-}
-	
-QJsonObject NotificationDto::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-			
-	
-	if (!(m_userId.isNull())) {
-		result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);
-	}
-			
-	result["Date"] = Jellyfin::Support::toJsonValue<QDateTime>(m_date);		
-	result["IsRead"] = Jellyfin::Support::toJsonValue<bool>(m_isRead);		
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_description.isNull())) {
-		result["Description"] = Jellyfin::Support::toJsonValue<QString>(m_description);
-	}
-			
-	
-	if (!(m_url.isNull())) {
-		result["Url"] = Jellyfin::Support::toJsonValue<QString>(m_url);
-	}
-			
-	result["Level"] = Jellyfin::Support::toJsonValue<NotificationLevel>(m_level);	
-	return result;
-}
-
-QString NotificationDto::jellyfinId() const { return m_jellyfinId; }
-
-void NotificationDto::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
-}
-bool NotificationDto::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
-
-void NotificationDto::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
-QString NotificationDto::userId() const { return m_userId; }
-
-void NotificationDto::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-bool NotificationDto::userIdNull() const {
-	return m_userId.isNull();
-}
-
-void NotificationDto::setUserIdNull() {
-	m_userId.clear();
-
-}
-QDateTime NotificationDto::date() const { return m_date; }
-
-void NotificationDto::setDate(QDateTime newDate) {
-	m_date = newDate;
-}
-
-bool NotificationDto::isRead() const { return m_isRead; }
-
-void NotificationDto::setIsRead(bool newIsRead) {
-	m_isRead = newIsRead;
-}
-
-QString NotificationDto::name() const { return m_name; }
-
-void NotificationDto::setName(QString newName) {
-	m_name = newName;
-}
-bool NotificationDto::nameNull() const {
-	return m_name.isNull();
-}
-
-void NotificationDto::setNameNull() {
-	m_name.clear();
-
-}
-QString NotificationDto::description() const { return m_description; }
-
-void NotificationDto::setDescription(QString newDescription) {
-	m_description = newDescription;
-}
-bool NotificationDto::descriptionNull() const {
-	return m_description.isNull();
-}
-
-void NotificationDto::setDescriptionNull() {
-	m_description.clear();
-
-}
-QString NotificationDto::url() const { return m_url; }
-
-void NotificationDto::setUrl(QString newUrl) {
-	m_url = newUrl;
-}
-bool NotificationDto::urlNull() const {
-	return m_url.isNull();
-}
-
-void NotificationDto::setUrlNull() {
-	m_url.clear();
-
-}
-NotificationLevel NotificationDto::level() const { return m_level; }
-
-void NotificationDto::setLevel(NotificationLevel newLevel) {
-	m_level = newLevel;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationDto = Jellyfin::DTO::NotificationDto;
-
-template <>
-NotificationDto fromJsonValue(const QJsonValue &source, convertType<NotificationDto>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return NotificationDto::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const NotificationDto &source, convertType<NotificationDto>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/notificationresultdto.cpp b/core/src/dto/notificationresultdto.cpp
deleted file mode 100644
index 4e8f786..0000000
--- a/core/src/dto/notificationresultdto.cpp
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * 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/dto/notificationresultdto.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-NotificationResultDto::NotificationResultDto() {}
-NotificationResultDto::NotificationResultDto (
-		qint32 totalRecordCount 
-		) :
-	m_totalRecordCount(totalRecordCount) { }
-
-
-
-NotificationResultDto::NotificationResultDto(const NotificationResultDto &other) :
-
-	m_notifications(other.m_notifications),
-	m_totalRecordCount(other.m_totalRecordCount){}
-
-
-void NotificationResultDto::replaceData(NotificationResultDto &other) {
-	m_notifications = other.m_notifications;
-	m_totalRecordCount = other.m_totalRecordCount;
-}
-
-NotificationResultDto NotificationResultDto::fromJson(QJsonObject source) {
-	NotificationResultDto instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void NotificationResultDto::setFromJson(QJsonObject source) {
-	m_notifications = Jellyfin::Support::fromJsonValue<QList<NotificationDto>>(source["Notifications"]);
-	m_totalRecordCount = Jellyfin::Support::fromJsonValue<qint32>(source["TotalRecordCount"]);
-
-}
-	
-QJsonObject NotificationResultDto::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_notifications.size() == 0)) {
-		result["Notifications"] = Jellyfin::Support::toJsonValue<QList<NotificationDto>>(m_notifications);
-	}
-			
-	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);	
-	return result;
-}
-
-QList<NotificationDto> NotificationResultDto::notifications() const { return m_notifications; }
-
-void NotificationResultDto::setNotifications(QList<NotificationDto> newNotifications) {
-	m_notifications = newNotifications;
-}
-bool NotificationResultDto::notificationsNull() const {
-	return m_notifications.size() == 0;
-}
-
-void NotificationResultDto::setNotificationsNull() {
-	m_notifications.clear();
-
-}
-qint32 NotificationResultDto::totalRecordCount() const { return m_totalRecordCount; }
-
-void NotificationResultDto::setTotalRecordCount(qint32 newTotalRecordCount) {
-	m_totalRecordCount = newTotalRecordCount;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationResultDto = Jellyfin::DTO::NotificationResultDto;
-
-template <>
-NotificationResultDto fromJsonValue(const QJsonValue &source, convertType<NotificationResultDto>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return NotificationResultDto::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const NotificationResultDto &source, convertType<NotificationResultDto>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/notificationssummarydto.cpp b/core/src/dto/notificationssummarydto.cpp
deleted file mode 100644
index 3fcee0f..0000000
--- a/core/src/dto/notificationssummarydto.cpp
+++ /dev/null
@@ -1,108 +0,0 @@
-/*
- * 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/dto/notificationssummarydto.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-NotificationsSummaryDto::NotificationsSummaryDto() {}
-NotificationsSummaryDto::NotificationsSummaryDto (
-		qint32 unreadCount, 
-		NotificationLevel maxUnreadNotificationLevel 
-		) :
-	m_unreadCount(unreadCount),
-	m_maxUnreadNotificationLevel(maxUnreadNotificationLevel) { }
-
-
-
-NotificationsSummaryDto::NotificationsSummaryDto(const NotificationsSummaryDto &other) :
-
-	m_unreadCount(other.m_unreadCount),
-	m_maxUnreadNotificationLevel(other.m_maxUnreadNotificationLevel){}
-
-
-void NotificationsSummaryDto::replaceData(NotificationsSummaryDto &other) {
-	m_unreadCount = other.m_unreadCount;
-	m_maxUnreadNotificationLevel = other.m_maxUnreadNotificationLevel;
-}
-
-NotificationsSummaryDto NotificationsSummaryDto::fromJson(QJsonObject source) {
-	NotificationsSummaryDto instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void NotificationsSummaryDto::setFromJson(QJsonObject source) {
-	m_unreadCount = Jellyfin::Support::fromJsonValue<qint32>(source["UnreadCount"]);
-	m_maxUnreadNotificationLevel = Jellyfin::Support::fromJsonValue<NotificationLevel>(source["MaxUnreadNotificationLevel"]);
-
-}
-	
-QJsonObject NotificationsSummaryDto::toJson() const {
-	QJsonObject result;
-	
-	result["UnreadCount"] = Jellyfin::Support::toJsonValue<qint32>(m_unreadCount);		
-	result["MaxUnreadNotificationLevel"] = Jellyfin::Support::toJsonValue<NotificationLevel>(m_maxUnreadNotificationLevel);	
-	return result;
-}
-
-qint32 NotificationsSummaryDto::unreadCount() const { return m_unreadCount; }
-
-void NotificationsSummaryDto::setUnreadCount(qint32 newUnreadCount) {
-	m_unreadCount = newUnreadCount;
-}
-
-NotificationLevel NotificationsSummaryDto::maxUnreadNotificationLevel() const { return m_maxUnreadNotificationLevel; }
-
-void NotificationsSummaryDto::setMaxUnreadNotificationLevel(NotificationLevel newMaxUnreadNotificationLevel) {
-	m_maxUnreadNotificationLevel = newMaxUnreadNotificationLevel;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationsSummaryDto = Jellyfin::DTO::NotificationsSummaryDto;
-
-template <>
-NotificationsSummaryDto fromJsonValue(const QJsonValue &source, convertType<NotificationsSummaryDto>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return NotificationsSummaryDto::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const NotificationsSummaryDto &source, convertType<NotificationsSummaryDto>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/notificationtypeinfo.cpp b/core/src/dto/notificationtypeinfo.cpp
deleted file mode 100644
index 51ec74a..0000000
--- a/core/src/dto/notificationtypeinfo.cpp
+++ /dev/null
@@ -1,171 +0,0 @@
-/*
- * 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/dto/notificationtypeinfo.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-NotificationTypeInfo::NotificationTypeInfo() {}
-NotificationTypeInfo::NotificationTypeInfo (
-		bool enabled, 
-		bool isBasedOnUserEvent 
-		) :
-	m_enabled(enabled),
-	m_isBasedOnUserEvent(isBasedOnUserEvent) { }
-
-
-
-NotificationTypeInfo::NotificationTypeInfo(const NotificationTypeInfo &other) :
-
-	m_type(other.m_type),
-	m_name(other.m_name),
-	m_enabled(other.m_enabled),
-	m_category(other.m_category),
-	m_isBasedOnUserEvent(other.m_isBasedOnUserEvent){}
-
-
-void NotificationTypeInfo::replaceData(NotificationTypeInfo &other) {
-	m_type = other.m_type;
-	m_name = other.m_name;
-	m_enabled = other.m_enabled;
-	m_category = other.m_category;
-	m_isBasedOnUserEvent = other.m_isBasedOnUserEvent;
-}
-
-NotificationTypeInfo NotificationTypeInfo::fromJson(QJsonObject source) {
-	NotificationTypeInfo instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void NotificationTypeInfo::setFromJson(QJsonObject source) {
-	m_type = Jellyfin::Support::fromJsonValue<QString>(source["Type"]);
-	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_enabled = Jellyfin::Support::fromJsonValue<bool>(source["Enabled"]);
-	m_category = Jellyfin::Support::fromJsonValue<QString>(source["Category"]);
-	m_isBasedOnUserEvent = Jellyfin::Support::fromJsonValue<bool>(source["IsBasedOnUserEvent"]);
-
-}
-	
-QJsonObject NotificationTypeInfo::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_type.isNull())) {
-		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
-	}
-			
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	result["Enabled"] = Jellyfin::Support::toJsonValue<bool>(m_enabled);		
-	
-	if (!(m_category.isNull())) {
-		result["Category"] = Jellyfin::Support::toJsonValue<QString>(m_category);
-	}
-			
-	result["IsBasedOnUserEvent"] = Jellyfin::Support::toJsonValue<bool>(m_isBasedOnUserEvent);	
-	return result;
-}
-
-QString NotificationTypeInfo::type() const { return m_type; }
-
-void NotificationTypeInfo::setType(QString newType) {
-	m_type = newType;
-}
-bool NotificationTypeInfo::typeNull() const {
-	return m_type.isNull();
-}
-
-void NotificationTypeInfo::setTypeNull() {
-	m_type.clear();
-
-}
-QString NotificationTypeInfo::name() const { return m_name; }
-
-void NotificationTypeInfo::setName(QString newName) {
-	m_name = newName;
-}
-bool NotificationTypeInfo::nameNull() const {
-	return m_name.isNull();
-}
-
-void NotificationTypeInfo::setNameNull() {
-	m_name.clear();
-
-}
-bool NotificationTypeInfo::enabled() const { return m_enabled; }
-
-void NotificationTypeInfo::setEnabled(bool newEnabled) {
-	m_enabled = newEnabled;
-}
-
-QString NotificationTypeInfo::category() const { return m_category; }
-
-void NotificationTypeInfo::setCategory(QString newCategory) {
-	m_category = newCategory;
-}
-bool NotificationTypeInfo::categoryNull() const {
-	return m_category.isNull();
-}
-
-void NotificationTypeInfo::setCategoryNull() {
-	m_category.clear();
-
-}
-bool NotificationTypeInfo::isBasedOnUserEvent() const { return m_isBasedOnUserEvent; }
-
-void NotificationTypeInfo::setIsBasedOnUserEvent(bool newIsBasedOnUserEvent) {
-	m_isBasedOnUserEvent = newIsBasedOnUserEvent;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using NotificationTypeInfo = Jellyfin::DTO::NotificationTypeInfo;
-
-template <>
-NotificationTypeInfo fromJsonValue(const QJsonValue &source, convertType<NotificationTypeInfo>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return NotificationTypeInfo::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const NotificationTypeInfo &source, convertType<NotificationTypeInfo>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/openlivestreamdto.cpp b/core/src/dto/openlivestreamdto.cpp
index bd59be6..37f965c 100644
--- a/core/src/dto/openlivestreamdto.cpp
+++ b/core/src/dto/openlivestreamdto.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 OpenLiveStreamDto::OpenLiveStreamDto() {}
 OpenLiveStreamDto::OpenLiveStreamDto (
-		QSharedPointer<DeviceProfile> deviceProfile 
+		QSharedPointer<DeviceProfile> deviceProfile, 
+		QList<MediaProtocol> directPlayProtocols 
 		) :
-	m_deviceProfile(deviceProfile) { }
+	m_deviceProfile(deviceProfile),
+	m_directPlayProtocols(directPlayProtocols) { }
 
 
 
@@ -53,6 +55,7 @@ OpenLiveStreamDto::OpenLiveStreamDto(const OpenLiveStreamDto &other) :
 	m_itemId(other.m_itemId),
 	m_enableDirectPlay(other.m_enableDirectPlay),
 	m_enableDirectStream(other.m_enableDirectStream),
+	m_alwaysBurnInSubtitleWhenTranscoding(other.m_alwaysBurnInSubtitleWhenTranscoding),
 	m_deviceProfile(other.m_deviceProfile),
 	m_directPlayProtocols(other.m_directPlayProtocols){}
 
@@ -69,6 +72,7 @@ void OpenLiveStreamDto::replaceData(OpenLiveStreamDto &other) {
 	m_itemId = other.m_itemId;
 	m_enableDirectPlay = other.m_enableDirectPlay;
 	m_enableDirectStream = other.m_enableDirectStream;
+	m_alwaysBurnInSubtitleWhenTranscoding = other.m_alwaysBurnInSubtitleWhenTranscoding;
 	m_deviceProfile = other.m_deviceProfile;
 	m_directPlayProtocols = other.m_directPlayProtocols;
 }
@@ -92,6 +96,7 @@ void OpenLiveStreamDto::setFromJson(QJsonObject source) {
 	m_itemId = Jellyfin::Support::fromJsonValue<QString>(source["ItemId"]);
 	m_enableDirectPlay = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableDirectPlay"]);
 	m_enableDirectStream = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableDirectStream"]);
+	m_alwaysBurnInSubtitleWhenTranscoding = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AlwaysBurnInSubtitleWhenTranscoding"]);
 	m_deviceProfile = Jellyfin::Support::fromJsonValue<QSharedPointer<DeviceProfile>>(source["DeviceProfile"]);
 	m_directPlayProtocols = Jellyfin::Support::fromJsonValue<QList<MediaProtocol>>(source["DirectPlayProtocols"]);
 
@@ -155,12 +160,13 @@ QJsonObject OpenLiveStreamDto::toJson() const {
 		result["EnableDirectStream"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableDirectStream);
 	}
 			
-	result["DeviceProfile"] = Jellyfin::Support::toJsonValue<QSharedPointer<DeviceProfile>>(m_deviceProfile);		
 	
-	if (!(m_directPlayProtocols.size() == 0)) {
-		result["DirectPlayProtocols"] = Jellyfin::Support::toJsonValue<QList<MediaProtocol>>(m_directPlayProtocols);
+	if (!(!m_alwaysBurnInSubtitleWhenTranscoding.has_value())) {
+		result["AlwaysBurnInSubtitleWhenTranscoding"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_alwaysBurnInSubtitleWhenTranscoding);
 	}
-		
+			
+	result["DeviceProfile"] = Jellyfin::Support::toJsonValue<QSharedPointer<DeviceProfile>>(m_deviceProfile);		
+	result["DirectPlayProtocols"] = Jellyfin::Support::toJsonValue<QList<MediaProtocol>>(m_directPlayProtocols);	
 	return result;
 }
 
@@ -306,6 +312,19 @@ bool OpenLiveStreamDto::enableDirectStreamNull() const {
 void OpenLiveStreamDto::setEnableDirectStreamNull() {
 	m_enableDirectStream = std::nullopt;
 
+}
+std::optional<bool> OpenLiveStreamDto::alwaysBurnInSubtitleWhenTranscoding() const { return m_alwaysBurnInSubtitleWhenTranscoding; }
+
+void OpenLiveStreamDto::setAlwaysBurnInSubtitleWhenTranscoding(std::optional<bool> newAlwaysBurnInSubtitleWhenTranscoding) {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+bool OpenLiveStreamDto::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void OpenLiveStreamDto::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+
 }
 QSharedPointer<DeviceProfile> OpenLiveStreamDto::deviceProfile() const { return m_deviceProfile; }
 
@@ -318,14 +337,7 @@ QList<MediaProtocol> OpenLiveStreamDto::directPlayProtocols() const { return m_d
 void OpenLiveStreamDto::setDirectPlayProtocols(QList<MediaProtocol> newDirectPlayProtocols) {
 	m_directPlayProtocols = newDirectPlayProtocols;
 }
-bool OpenLiveStreamDto::directPlayProtocolsNull() const {
-	return m_directPlayProtocols.size() == 0;
-}
 
-void OpenLiveStreamDto::setDirectPlayProtocolsNull() {
-	m_directPlayProtocols.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/outboundkeepalivemessage.cpp b/core/src/dto/outboundkeepalivemessage.cpp
new file mode 100644
index 0000000..facd34e
--- /dev/null
+++ b/core/src/dto/outboundkeepalivemessage.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/outboundkeepalivemessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+OutboundKeepAliveMessage::OutboundKeepAliveMessage() {}
+OutboundKeepAliveMessage::OutboundKeepAliveMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+OutboundKeepAliveMessage::OutboundKeepAliveMessage(const OutboundKeepAliveMessage &other) :
+
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void OutboundKeepAliveMessage::replaceData(OutboundKeepAliveMessage &other) {
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+OutboundKeepAliveMessage OutboundKeepAliveMessage::fromJson(QJsonObject source) {
+	OutboundKeepAliveMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void OutboundKeepAliveMessage::setFromJson(QJsonObject source) {
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject OutboundKeepAliveMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString OutboundKeepAliveMessage::messageId() const { return m_messageId; }
+
+void OutboundKeepAliveMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType OutboundKeepAliveMessage::messageType() const { return m_messageType; }
+
+void OutboundKeepAliveMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using OutboundKeepAliveMessage = Jellyfin::DTO::OutboundKeepAliveMessage;
+
+template <>
+OutboundKeepAliveMessage fromJsonValue(const QJsonValue &source, convertType<OutboundKeepAliveMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return OutboundKeepAliveMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const OutboundKeepAliveMessage &source, convertType<OutboundKeepAliveMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/outboundwebsocketmessage.cpp b/core/src/dto/outboundwebsocketmessage.cpp
new file mode 100644
index 0000000..504863d
--- /dev/null
+++ b/core/src/dto/outboundwebsocketmessage.cpp
@@ -0,0 +1,37 @@
+/*
+ * 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/dto/outboundwebsocketmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/packageinfo.cpp b/core/src/dto/packageinfo.cpp
index 263c139..076b3f6 100644
--- a/core/src/dto/packageinfo.cpp
+++ b/core/src/dto/packageinfo.cpp
@@ -33,6 +33,24 @@ namespace Jellyfin {
 namespace DTO {
 
 PackageInfo::PackageInfo() {}
+PackageInfo::PackageInfo (
+		QString name, 
+		QString description, 
+		QString overview, 
+		QString owner, 
+		QString category, 
+		QString guid, 
+		QList<VersionInfo> versions 
+		) :
+	m_name(name),
+	m_description(description),
+	m_overview(overview),
+	m_owner(owner),
+	m_category(category),
+	m_guid(guid),
+	m_versions(versions) { }
+
+
 
 PackageInfo::PackageInfo(const PackageInfo &other) :
 
@@ -79,41 +97,13 @@ void PackageInfo::setFromJson(QJsonObject source) {
 QJsonObject PackageInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	
-	if (!(m_description.isNull())) {
-		result["description"] = Jellyfin::Support::toJsonValue<QString>(m_description);
-	}
-			
-	
-	if (!(m_overview.isNull())) {
-		result["overview"] = Jellyfin::Support::toJsonValue<QString>(m_overview);
-	}
-			
-	
-	if (!(m_owner.isNull())) {
-		result["owner"] = Jellyfin::Support::toJsonValue<QString>(m_owner);
-	}
-			
-	
-	if (!(m_category.isNull())) {
-		result["category"] = Jellyfin::Support::toJsonValue<QString>(m_category);
-	}
-			
-	
-	if (!(m_guid.isNull())) {
-		result["guid"] = Jellyfin::Support::toJsonValue<QString>(m_guid);
-	}
-			
-	
-	if (!(m_versions.size() == 0)) {
-		result["versions"] = Jellyfin::Support::toJsonValue<QList<VersionInfo>>(m_versions);
-	}
-			
+	result["name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["description"] = Jellyfin::Support::toJsonValue<QString>(m_description);		
+	result["overview"] = Jellyfin::Support::toJsonValue<QString>(m_overview);		
+	result["owner"] = Jellyfin::Support::toJsonValue<QString>(m_owner);		
+	result["category"] = Jellyfin::Support::toJsonValue<QString>(m_category);		
+	result["guid"] = Jellyfin::Support::toJsonValue<QString>(m_guid);		
+	result["versions"] = Jellyfin::Support::toJsonValue<QList<VersionInfo>>(m_versions);		
 	
 	if (!(m_imageUrl.isNull())) {
 		result["imageUrl"] = Jellyfin::Support::toJsonValue<QString>(m_imageUrl);
@@ -127,92 +117,43 @@ QString PackageInfo::name() const { return m_name; }
 void PackageInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool PackageInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void PackageInfo::setNameNull() {
-	m_name.clear();
-
-}
 QString PackageInfo::description() const { return m_description; }
 
 void PackageInfo::setDescription(QString newDescription) {
 	m_description = newDescription;
 }
-bool PackageInfo::descriptionNull() const {
-	return m_description.isNull();
-}
 
-void PackageInfo::setDescriptionNull() {
-	m_description.clear();
-
-}
 QString PackageInfo::overview() const { return m_overview; }
 
 void PackageInfo::setOverview(QString newOverview) {
 	m_overview = newOverview;
 }
-bool PackageInfo::overviewNull() const {
-	return m_overview.isNull();
-}
 
-void PackageInfo::setOverviewNull() {
-	m_overview.clear();
-
-}
 QString PackageInfo::owner() const { return m_owner; }
 
 void PackageInfo::setOwner(QString newOwner) {
 	m_owner = newOwner;
 }
-bool PackageInfo::ownerNull() const {
-	return m_owner.isNull();
-}
 
-void PackageInfo::setOwnerNull() {
-	m_owner.clear();
-
-}
 QString PackageInfo::category() const { return m_category; }
 
 void PackageInfo::setCategory(QString newCategory) {
 	m_category = newCategory;
 }
-bool PackageInfo::categoryNull() const {
-	return m_category.isNull();
-}
 
-void PackageInfo::setCategoryNull() {
-	m_category.clear();
-
-}
 QString PackageInfo::guid() const { return m_guid; }
 
 void PackageInfo::setGuid(QString newGuid) {
 	m_guid = newGuid;
 }
-bool PackageInfo::guidNull() const {
-	return m_guid.isNull();
-}
 
-void PackageInfo::setGuidNull() {
-	m_guid.clear();
-
-}
 QList<VersionInfo> PackageInfo::versions() const { return m_versions; }
 
 void PackageInfo::setVersions(QList<VersionInfo> newVersions) {
 	m_versions = newVersions;
 }
-bool PackageInfo::versionsNull() const {
-	return m_versions.size() == 0;
-}
 
-void PackageInfo::setVersionsNull() {
-	m_versions.clear();
-
-}
 QString PackageInfo::imageUrl() const { return m_imageUrl; }
 
 void PackageInfo::setImageUrl(QString newImageUrl) {
diff --git a/core/src/dto/parentalrating.cpp b/core/src/dto/parentalrating.cpp
index 4f1a8af..2f3c49d 100644
--- a/core/src/dto/parentalrating.cpp
+++ b/core/src/dto/parentalrating.cpp
@@ -33,12 +33,6 @@ namespace Jellyfin {
 namespace DTO {
 
 ParentalRating::ParentalRating() {}
-ParentalRating::ParentalRating (
-		qint32 value 
-		) :
-	m_value(value) { }
-
-
 
 ParentalRating::ParentalRating(const ParentalRating &other) :
 
@@ -60,7 +54,7 @@ ParentalRating ParentalRating::fromJson(QJsonObject source) {
 
 void ParentalRating::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_value = Jellyfin::Support::fromJsonValue<qint32>(source["Value"]);
+	m_value = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Value"]);
 
 }
 	
@@ -72,7 +66,11 @@ QJsonObject ParentalRating::toJson() const {
 		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
 	}
 			
-	result["Value"] = Jellyfin::Support::toJsonValue<qint32>(m_value);	
+	
+	if (!(!m_value.has_value())) {
+		result["Value"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_value);
+	}
+		
 	return result;
 }
 
@@ -89,12 +87,19 @@ void ParentalRating::setNameNull() {
 	m_name.clear();
 
 }
-qint32 ParentalRating::value() const { return m_value; }
+std::optional<qint32> ParentalRating::value() const { return m_value; }
 
-void ParentalRating::setValue(qint32 newValue) {
+void ParentalRating::setValue(std::optional<qint32> newValue) {
 	m_value = newValue;
 }
+bool ParentalRating::valueNull() const {
+	return !m_value.has_value();
+}
 
+void ParentalRating::setValueNull() {
+	m_value = std::nullopt;
+
+}
 
 } // NS DTO
 
diff --git a/core/src/dto/pathsubstitution.cpp b/core/src/dto/pathsubstitution.cpp
index a4c2caa..ef82a7d 100644
--- a/core/src/dto/pathsubstitution.cpp
+++ b/core/src/dto/pathsubstitution.cpp
@@ -33,6 +33,14 @@ namespace Jellyfin {
 namespace DTO {
 
 PathSubstitution::PathSubstitution() {}
+PathSubstitution::PathSubstitution (
+		QString from, 
+		QString to 
+		) :
+	m_from(from),
+	m_to(to) { }
+
+
 
 PathSubstitution::PathSubstitution(const PathSubstitution &other) :
 
@@ -61,16 +69,8 @@ void PathSubstitution::setFromJson(QJsonObject source) {
 QJsonObject PathSubstitution::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_from.isNull())) {
-		result["From"] = Jellyfin::Support::toJsonValue<QString>(m_from);
-	}
-			
-	
-	if (!(m_to.isNull())) {
-		result["To"] = Jellyfin::Support::toJsonValue<QString>(m_to);
-	}
-		
+	result["From"] = Jellyfin::Support::toJsonValue<QString>(m_from);		
+	result["To"] = Jellyfin::Support::toJsonValue<QString>(m_to);	
 	return result;
 }
 
@@ -79,27 +79,13 @@ QString PathSubstitution::from() const { return m_from; }
 void PathSubstitution::setFrom(QString newFrom) {
 	m_from = newFrom;
 }
-bool PathSubstitution::fromNull() const {
-	return m_from.isNull();
-}
 
-void PathSubstitution::setFromNull() {
-	m_from.clear();
-
-}
 QString PathSubstitution::to() const { return m_to; }
 
 void PathSubstitution::setTo(QString newTo) {
 	m_to = newTo;
 }
-bool PathSubstitution::toNull() const {
-	return m_to.isNull();
-}
 
-void PathSubstitution::setToNull() {
-	m_to.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/personkind.cpp b/core/src/dto/personkind.cpp
new file mode 100644
index 0000000..988c01b
--- /dev/null
+++ b/core/src/dto/personkind.cpp
@@ -0,0 +1,188 @@
+/*
+ * 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/dto/personkind.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PersonKindClass::PersonKindClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using PersonKind = Jellyfin::DTO::PersonKind;
+
+template <>
+PersonKind fromJsonValue(const QJsonValue &source, convertType<PersonKind>) {
+	if (!source.isString()) return PersonKind::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Unknown")) {
+		return PersonKind::Unknown;
+	}
+	if (str == QStringLiteral("Actor")) {
+		return PersonKind::Actor;
+	}
+	if (str == QStringLiteral("Director")) {
+		return PersonKind::Director;
+	}
+	if (str == QStringLiteral("Composer")) {
+		return PersonKind::Composer;
+	}
+	if (str == QStringLiteral("Writer")) {
+		return PersonKind::Writer;
+	}
+	if (str == QStringLiteral("GuestStar")) {
+		return PersonKind::GuestStar;
+	}
+	if (str == QStringLiteral("Producer")) {
+		return PersonKind::Producer;
+	}
+	if (str == QStringLiteral("Conductor")) {
+		return PersonKind::Conductor;
+	}
+	if (str == QStringLiteral("Lyricist")) {
+		return PersonKind::Lyricist;
+	}
+	if (str == QStringLiteral("Arranger")) {
+		return PersonKind::Arranger;
+	}
+	if (str == QStringLiteral("Engineer")) {
+		return PersonKind::Engineer;
+	}
+	if (str == QStringLiteral("Mixer")) {
+		return PersonKind::Mixer;
+	}
+	if (str == QStringLiteral("Remixer")) {
+		return PersonKind::Remixer;
+	}
+	if (str == QStringLiteral("Creator")) {
+		return PersonKind::Creator;
+	}
+	if (str == QStringLiteral("Artist")) {
+		return PersonKind::Artist;
+	}
+	if (str == QStringLiteral("AlbumArtist")) {
+		return PersonKind::AlbumArtist;
+	}
+	if (str == QStringLiteral("Author")) {
+		return PersonKind::Author;
+	}
+	if (str == QStringLiteral("Illustrator")) {
+		return PersonKind::Illustrator;
+	}
+	if (str == QStringLiteral("Penciller")) {
+		return PersonKind::Penciller;
+	}
+	if (str == QStringLiteral("Inker")) {
+		return PersonKind::Inker;
+	}
+	if (str == QStringLiteral("Colorist")) {
+		return PersonKind::Colorist;
+	}
+	if (str == QStringLiteral("Letterer")) {
+		return PersonKind::Letterer;
+	}
+	if (str == QStringLiteral("CoverArtist")) {
+		return PersonKind::CoverArtist;
+	}
+	if (str == QStringLiteral("Editor")) {
+		return PersonKind::Editor;
+	}
+	if (str == QStringLiteral("Translator")) {
+		return PersonKind::Translator;
+	}
+	
+	return PersonKind::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const PersonKind &source, convertType<PersonKind>) {
+	switch(source) {
+	case PersonKind::Unknown:
+		return QStringLiteral("Unknown");
+	case PersonKind::Actor:
+		return QStringLiteral("Actor");
+	case PersonKind::Director:
+		return QStringLiteral("Director");
+	case PersonKind::Composer:
+		return QStringLiteral("Composer");
+	case PersonKind::Writer:
+		return QStringLiteral("Writer");
+	case PersonKind::GuestStar:
+		return QStringLiteral("GuestStar");
+	case PersonKind::Producer:
+		return QStringLiteral("Producer");
+	case PersonKind::Conductor:
+		return QStringLiteral("Conductor");
+	case PersonKind::Lyricist:
+		return QStringLiteral("Lyricist");
+	case PersonKind::Arranger:
+		return QStringLiteral("Arranger");
+	case PersonKind::Engineer:
+		return QStringLiteral("Engineer");
+	case PersonKind::Mixer:
+		return QStringLiteral("Mixer");
+	case PersonKind::Remixer:
+		return QStringLiteral("Remixer");
+	case PersonKind::Creator:
+		return QStringLiteral("Creator");
+	case PersonKind::Artist:
+		return QStringLiteral("Artist");
+	case PersonKind::AlbumArtist:
+		return QStringLiteral("AlbumArtist");
+	case PersonKind::Author:
+		return QStringLiteral("Author");
+	case PersonKind::Illustrator:
+		return QStringLiteral("Illustrator");
+	case PersonKind::Penciller:
+		return QStringLiteral("Penciller");
+	case PersonKind::Inker:
+		return QStringLiteral("Inker");
+	case PersonKind::Colorist:
+		return QStringLiteral("Colorist");
+	case PersonKind::Letterer:
+		return QStringLiteral("Letterer");
+	case PersonKind::CoverArtist:
+		return QStringLiteral("CoverArtist");
+	case PersonKind::Editor:
+		return QStringLiteral("Editor");
+	case PersonKind::Translator:
+		return QStringLiteral("Translator");
+
+	case PersonKind::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/personlookupinfo.cpp b/core/src/dto/personlookupinfo.cpp
index d2be25c..b56bde4 100644
--- a/core/src/dto/personlookupinfo.cpp
+++ b/core/src/dto/personlookupinfo.cpp
@@ -43,6 +43,7 @@ PersonLookupInfo::PersonLookupInfo (
 PersonLookupInfo::PersonLookupInfo(const PersonLookupInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -56,6 +57,7 @@ PersonLookupInfo::PersonLookupInfo(const PersonLookupInfo &other) :
 
 void PersonLookupInfo::replaceData(PersonLookupInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -76,6 +78,7 @@ PersonLookupInfo PersonLookupInfo::fromJson(QJsonObject source) {
 
 void PersonLookupInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -97,6 +100,11 @@ QJsonObject PersonLookupInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -152,6 +160,19 @@ bool PersonLookupInfo::nameNull() const {
 void PersonLookupInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString PersonLookupInfo::originalTitle() const { return m_originalTitle; }
+
+void PersonLookupInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool PersonLookupInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void PersonLookupInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString PersonLookupInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/pinredeemresult.cpp b/core/src/dto/pinredeemresult.cpp
index 094d810..57b4654 100644
--- a/core/src/dto/pinredeemresult.cpp
+++ b/core/src/dto/pinredeemresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 PinRedeemResult::PinRedeemResult() {}
 PinRedeemResult::PinRedeemResult (
-		bool success 
+		bool success, 
+		QStringList usersReset 
 		) :
-	m_success(success) { }
+	m_success(success),
+	m_usersReset(usersReset) { }
 
 
 
@@ -68,11 +70,7 @@ QJsonObject PinRedeemResult::toJson() const {
 	QJsonObject result;
 	
 	result["Success"] = Jellyfin::Support::toJsonValue<bool>(m_success);		
-	
-	if (!(m_usersReset.size() == 0)) {
-		result["UsersReset"] = Jellyfin::Support::toJsonValue<QStringList>(m_usersReset);
-	}
-		
+	result["UsersReset"] = Jellyfin::Support::toJsonValue<QStringList>(m_usersReset);	
 	return result;
 }
 
@@ -87,14 +85,7 @@ QStringList PinRedeemResult::usersReset() const { return m_usersReset; }
 void PinRedeemResult::setUsersReset(QStringList newUsersReset) {
 	m_usersReset = newUsersReset;
 }
-bool PinRedeemResult::usersResetNull() const {
-	return m_usersReset.size() == 0;
-}
 
-void PinRedeemResult::setUsersResetNull() {
-	m_usersReset.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/playbackinfodto.cpp b/core/src/dto/playbackinfodto.cpp
index 3eb6268..67ad93f 100644
--- a/core/src/dto/playbackinfodto.cpp
+++ b/core/src/dto/playbackinfodto.cpp
@@ -56,7 +56,8 @@ PlaybackInfoDto::PlaybackInfoDto(const PlaybackInfoDto &other) :
 	m_enableTranscoding(other.m_enableTranscoding),
 	m_allowVideoStreamCopy(other.m_allowVideoStreamCopy),
 	m_allowAudioStreamCopy(other.m_allowAudioStreamCopy),
-	m_autoOpenLiveStream(other.m_autoOpenLiveStream){}
+	m_autoOpenLiveStream(other.m_autoOpenLiveStream),
+	m_alwaysBurnInSubtitleWhenTranscoding(other.m_alwaysBurnInSubtitleWhenTranscoding){}
 
 
 void PlaybackInfoDto::replaceData(PlaybackInfoDto &other) {
@@ -75,6 +76,7 @@ void PlaybackInfoDto::replaceData(PlaybackInfoDto &other) {
 	m_allowVideoStreamCopy = other.m_allowVideoStreamCopy;
 	m_allowAudioStreamCopy = other.m_allowAudioStreamCopy;
 	m_autoOpenLiveStream = other.m_autoOpenLiveStream;
+	m_alwaysBurnInSubtitleWhenTranscoding = other.m_alwaysBurnInSubtitleWhenTranscoding;
 }
 
 PlaybackInfoDto PlaybackInfoDto::fromJson(QJsonObject source) {
@@ -100,6 +102,7 @@ void PlaybackInfoDto::setFromJson(QJsonObject source) {
 	m_allowVideoStreamCopy = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AllowVideoStreamCopy"]);
 	m_allowAudioStreamCopy = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AllowAudioStreamCopy"]);
 	m_autoOpenLiveStream = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AutoOpenLiveStream"]);
+	m_alwaysBurnInSubtitleWhenTranscoding = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AlwaysBurnInSubtitleWhenTranscoding"]);
 
 }
 	
@@ -176,6 +179,11 @@ QJsonObject PlaybackInfoDto::toJson() const {
 	if (!(!m_autoOpenLiveStream.has_value())) {
 		result["AutoOpenLiveStream"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_autoOpenLiveStream);
 	}
+			
+	
+	if (!(!m_alwaysBurnInSubtitleWhenTranscoding.has_value())) {
+		result["AlwaysBurnInSubtitleWhenTranscoding"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_alwaysBurnInSubtitleWhenTranscoding);
+	}
 		
 	return result;
 }
@@ -367,6 +375,19 @@ bool PlaybackInfoDto::autoOpenLiveStreamNull() const {
 void PlaybackInfoDto::setAutoOpenLiveStreamNull() {
 	m_autoOpenLiveStream = std::nullopt;
 
+}
+std::optional<bool> PlaybackInfoDto::alwaysBurnInSubtitleWhenTranscoding() const { return m_alwaysBurnInSubtitleWhenTranscoding; }
+
+void PlaybackInfoDto::setAlwaysBurnInSubtitleWhenTranscoding(std::optional<bool> newAlwaysBurnInSubtitleWhenTranscoding) {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+bool PlaybackInfoDto::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void PlaybackInfoDto::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+
 }
 
 } // NS DTO
diff --git a/core/src/dto/playbackinforesponse.cpp b/core/src/dto/playbackinforesponse.cpp
index e091734..d1af984 100644
--- a/core/src/dto/playbackinforesponse.cpp
+++ b/core/src/dto/playbackinforesponse.cpp
@@ -34,8 +34,10 @@ namespace DTO {
 
 PlaybackInfoResponse::PlaybackInfoResponse() {}
 PlaybackInfoResponse::PlaybackInfoResponse (
+		QList<MediaSourceInfo> mediaSources, 
 		PlaybackErrorCode errorCode 
 		) :
+	m_mediaSources(mediaSources),
 	m_errorCode(errorCode) { }
 
 
@@ -70,11 +72,7 @@ void PlaybackInfoResponse::setFromJson(QJsonObject source) {
 QJsonObject PlaybackInfoResponse::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_mediaSources.size() == 0)) {
-		result["MediaSources"] = Jellyfin::Support::toJsonValue<QList<MediaSourceInfo>>(m_mediaSources);
-	}
-			
+	result["MediaSources"] = Jellyfin::Support::toJsonValue<QList<MediaSourceInfo>>(m_mediaSources);		
 	
 	if (!(m_playSessionId.isNull())) {
 		result["PlaySessionId"] = Jellyfin::Support::toJsonValue<QString>(m_playSessionId);
@@ -89,14 +87,7 @@ QList<MediaSourceInfo> PlaybackInfoResponse::mediaSources() const { return m_med
 void PlaybackInfoResponse::setMediaSources(QList<MediaSourceInfo> newMediaSources) {
 	m_mediaSources = newMediaSources;
 }
-bool PlaybackInfoResponse::mediaSourcesNull() const {
-	return m_mediaSources.size() == 0;
-}
 
-void PlaybackInfoResponse::setMediaSourcesNull() {
-	m_mediaSources.clear();
-
-}
 QString PlaybackInfoResponse::playSessionId() const { return m_playSessionId; }
 
 void PlaybackInfoResponse::setPlaySessionId(QString newPlaySessionId) {
diff --git a/core/src/dto/playbackorder.cpp b/core/src/dto/playbackorder.cpp
new file mode 100644
index 0000000..5b628b2
--- /dev/null
+++ b/core/src/dto/playbackorder.cpp
@@ -0,0 +1,73 @@
+/*
+ * 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/dto/playbackorder.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlaybackOrderClass::PlaybackOrderClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using PlaybackOrder = Jellyfin::DTO::PlaybackOrder;
+
+template <>
+PlaybackOrder fromJsonValue(const QJsonValue &source, convertType<PlaybackOrder>) {
+	if (!source.isString()) return PlaybackOrder::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Default")) {
+		return PlaybackOrder::Default;
+	}
+	if (str == QStringLiteral("Shuffle")) {
+		return PlaybackOrder::Shuffle;
+	}
+	
+	return PlaybackOrder::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const PlaybackOrder &source, convertType<PlaybackOrder>) {
+	switch(source) {
+	case PlaybackOrder::Default:
+		return QStringLiteral("Default");
+	case PlaybackOrder::Shuffle:
+		return QStringLiteral("Shuffle");
+
+	case PlaybackOrder::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playbackprogressinfo.cpp b/core/src/dto/playbackprogressinfo.cpp
index 5c70cc1..9b06f3e 100644
--- a/core/src/dto/playbackprogressinfo.cpp
+++ b/core/src/dto/playbackprogressinfo.cpp
@@ -40,7 +40,8 @@ PlaybackProgressInfo::PlaybackProgressInfo (
 		bool isPaused, 
 		bool isMuted, 
 		PlayMethod playMethod, 
-		RepeatMode repeatMode 
+		RepeatMode repeatMode, 
+		PlaybackOrder playbackOrder 
 		) :
 	m_canSeek(canSeek),
 	m_item(item),
@@ -48,7 +49,8 @@ PlaybackProgressInfo::PlaybackProgressInfo (
 	m_isPaused(isPaused),
 	m_isMuted(isMuted),
 	m_playMethod(playMethod),
-	m_repeatMode(repeatMode) { }
+	m_repeatMode(repeatMode),
+	m_playbackOrder(playbackOrder) { }
 
 
 
@@ -72,6 +74,7 @@ PlaybackProgressInfo::PlaybackProgressInfo(const PlaybackProgressInfo &other) :
 	m_liveStreamId(other.m_liveStreamId),
 	m_playSessionId(other.m_playSessionId),
 	m_repeatMode(other.m_repeatMode),
+	m_playbackOrder(other.m_playbackOrder),
 	m_nowPlayingQueue(other.m_nowPlayingQueue),
 	m_playlistItemId(other.m_playlistItemId){}
 
@@ -95,6 +98,7 @@ void PlaybackProgressInfo::replaceData(PlaybackProgressInfo &other) {
 	m_liveStreamId = other.m_liveStreamId;
 	m_playSessionId = other.m_playSessionId;
 	m_repeatMode = other.m_repeatMode;
+	m_playbackOrder = other.m_playbackOrder;
 	m_nowPlayingQueue = other.m_nowPlayingQueue;
 	m_playlistItemId = other.m_playlistItemId;
 }
@@ -125,6 +129,7 @@ void PlaybackProgressInfo::setFromJson(QJsonObject source) {
 	m_liveStreamId = Jellyfin::Support::fromJsonValue<QString>(source["LiveStreamId"]);
 	m_playSessionId = Jellyfin::Support::fromJsonValue<QString>(source["PlaySessionId"]);
 	m_repeatMode = Jellyfin::Support::fromJsonValue<RepeatMode>(source["RepeatMode"]);
+	m_playbackOrder = Jellyfin::Support::fromJsonValue<PlaybackOrder>(source["PlaybackOrder"]);
 	m_nowPlayingQueue = Jellyfin::Support::fromJsonValue<QList<QueueItem>>(source["NowPlayingQueue"]);
 	m_playlistItemId = Jellyfin::Support::fromJsonValue<QString>(source["PlaylistItemId"]);
 
@@ -195,6 +200,7 @@ QJsonObject PlaybackProgressInfo::toJson() const {
 	}
 			
 	result["RepeatMode"] = Jellyfin::Support::toJsonValue<RepeatMode>(m_repeatMode);		
+	result["PlaybackOrder"] = Jellyfin::Support::toJsonValue<PlaybackOrder>(m_playbackOrder);		
 	
 	if (!(m_nowPlayingQueue.size() == 0)) {
 		result["NowPlayingQueue"] = Jellyfin::Support::toJsonValue<QList<QueueItem>>(m_nowPlayingQueue);
@@ -393,6 +399,12 @@ void PlaybackProgressInfo::setRepeatMode(RepeatMode newRepeatMode) {
 	m_repeatMode = newRepeatMode;
 }
 
+PlaybackOrder PlaybackProgressInfo::playbackOrder() const { return m_playbackOrder; }
+
+void PlaybackProgressInfo::setPlaybackOrder(PlaybackOrder newPlaybackOrder) {
+	m_playbackOrder = newPlaybackOrder;
+}
+
 QList<QueueItem> PlaybackProgressInfo::nowPlayingQueue() const { return m_nowPlayingQueue; }
 
 void PlaybackProgressInfo::setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue) {
diff --git a/core/src/dto/playbackrequesttype.cpp b/core/src/dto/playbackrequesttype.cpp
new file mode 100644
index 0000000..b733ae1
--- /dev/null
+++ b/core/src/dto/playbackrequesttype.cpp
@@ -0,0 +1,148 @@
+/*
+ * 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/dto/playbackrequesttype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlaybackRequestTypeClass::PlaybackRequestTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using PlaybackRequestType = Jellyfin::DTO::PlaybackRequestType;
+
+template <>
+PlaybackRequestType fromJsonValue(const QJsonValue &source, convertType<PlaybackRequestType>) {
+	if (!source.isString()) return PlaybackRequestType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Play")) {
+		return PlaybackRequestType::Play;
+	}
+	if (str == QStringLiteral("SetPlaylistItem")) {
+		return PlaybackRequestType::SetPlaylistItem;
+	}
+	if (str == QStringLiteral("RemoveFromPlaylist")) {
+		return PlaybackRequestType::RemoveFromPlaylist;
+	}
+	if (str == QStringLiteral("MovePlaylistItem")) {
+		return PlaybackRequestType::MovePlaylistItem;
+	}
+	if (str == QStringLiteral("Queue")) {
+		return PlaybackRequestType::Queue;
+	}
+	if (str == QStringLiteral("Unpause")) {
+		return PlaybackRequestType::Unpause;
+	}
+	if (str == QStringLiteral("Pause")) {
+		return PlaybackRequestType::Pause;
+	}
+	if (str == QStringLiteral("Stop")) {
+		return PlaybackRequestType::Stop;
+	}
+	if (str == QStringLiteral("Seek")) {
+		return PlaybackRequestType::Seek;
+	}
+	if (str == QStringLiteral("Buffer")) {
+		return PlaybackRequestType::Buffer;
+	}
+	if (str == QStringLiteral("Ready")) {
+		return PlaybackRequestType::Ready;
+	}
+	if (str == QStringLiteral("NextItem")) {
+		return PlaybackRequestType::NextItem;
+	}
+	if (str == QStringLiteral("PreviousItem")) {
+		return PlaybackRequestType::PreviousItem;
+	}
+	if (str == QStringLiteral("SetRepeatMode")) {
+		return PlaybackRequestType::SetRepeatMode;
+	}
+	if (str == QStringLiteral("SetShuffleMode")) {
+		return PlaybackRequestType::SetShuffleMode;
+	}
+	if (str == QStringLiteral("Ping")) {
+		return PlaybackRequestType::Ping;
+	}
+	if (str == QStringLiteral("IgnoreWait")) {
+		return PlaybackRequestType::IgnoreWait;
+	}
+	
+	return PlaybackRequestType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const PlaybackRequestType &source, convertType<PlaybackRequestType>) {
+	switch(source) {
+	case PlaybackRequestType::Play:
+		return QStringLiteral("Play");
+	case PlaybackRequestType::SetPlaylistItem:
+		return QStringLiteral("SetPlaylistItem");
+	case PlaybackRequestType::RemoveFromPlaylist:
+		return QStringLiteral("RemoveFromPlaylist");
+	case PlaybackRequestType::MovePlaylistItem:
+		return QStringLiteral("MovePlaylistItem");
+	case PlaybackRequestType::Queue:
+		return QStringLiteral("Queue");
+	case PlaybackRequestType::Unpause:
+		return QStringLiteral("Unpause");
+	case PlaybackRequestType::Pause:
+		return QStringLiteral("Pause");
+	case PlaybackRequestType::Stop:
+		return QStringLiteral("Stop");
+	case PlaybackRequestType::Seek:
+		return QStringLiteral("Seek");
+	case PlaybackRequestType::Buffer:
+		return QStringLiteral("Buffer");
+	case PlaybackRequestType::Ready:
+		return QStringLiteral("Ready");
+	case PlaybackRequestType::NextItem:
+		return QStringLiteral("NextItem");
+	case PlaybackRequestType::PreviousItem:
+		return QStringLiteral("PreviousItem");
+	case PlaybackRequestType::SetRepeatMode:
+		return QStringLiteral("SetRepeatMode");
+	case PlaybackRequestType::SetShuffleMode:
+		return QStringLiteral("SetShuffleMode");
+	case PlaybackRequestType::Ping:
+		return QStringLiteral("Ping");
+	case PlaybackRequestType::IgnoreWait:
+		return QStringLiteral("IgnoreWait");
+
+	case PlaybackRequestType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playbackstartinfo.cpp b/core/src/dto/playbackstartinfo.cpp
index 313c12f..5f92164 100644
--- a/core/src/dto/playbackstartinfo.cpp
+++ b/core/src/dto/playbackstartinfo.cpp
@@ -40,7 +40,8 @@ PlaybackStartInfo::PlaybackStartInfo (
 		bool isPaused, 
 		bool isMuted, 
 		PlayMethod playMethod, 
-		RepeatMode repeatMode 
+		RepeatMode repeatMode, 
+		PlaybackOrder playbackOrder 
 		) :
 	m_canSeek(canSeek),
 	m_item(item),
@@ -48,7 +49,8 @@ PlaybackStartInfo::PlaybackStartInfo (
 	m_isPaused(isPaused),
 	m_isMuted(isMuted),
 	m_playMethod(playMethod),
-	m_repeatMode(repeatMode) { }
+	m_repeatMode(repeatMode),
+	m_playbackOrder(playbackOrder) { }
 
 
 
@@ -72,6 +74,7 @@ PlaybackStartInfo::PlaybackStartInfo(const PlaybackStartInfo &other) :
 	m_liveStreamId(other.m_liveStreamId),
 	m_playSessionId(other.m_playSessionId),
 	m_repeatMode(other.m_repeatMode),
+	m_playbackOrder(other.m_playbackOrder),
 	m_nowPlayingQueue(other.m_nowPlayingQueue),
 	m_playlistItemId(other.m_playlistItemId){}
 
@@ -95,6 +98,7 @@ void PlaybackStartInfo::replaceData(PlaybackStartInfo &other) {
 	m_liveStreamId = other.m_liveStreamId;
 	m_playSessionId = other.m_playSessionId;
 	m_repeatMode = other.m_repeatMode;
+	m_playbackOrder = other.m_playbackOrder;
 	m_nowPlayingQueue = other.m_nowPlayingQueue;
 	m_playlistItemId = other.m_playlistItemId;
 }
@@ -125,6 +129,7 @@ void PlaybackStartInfo::setFromJson(QJsonObject source) {
 	m_liveStreamId = Jellyfin::Support::fromJsonValue<QString>(source["LiveStreamId"]);
 	m_playSessionId = Jellyfin::Support::fromJsonValue<QString>(source["PlaySessionId"]);
 	m_repeatMode = Jellyfin::Support::fromJsonValue<RepeatMode>(source["RepeatMode"]);
+	m_playbackOrder = Jellyfin::Support::fromJsonValue<PlaybackOrder>(source["PlaybackOrder"]);
 	m_nowPlayingQueue = Jellyfin::Support::fromJsonValue<QList<QueueItem>>(source["NowPlayingQueue"]);
 	m_playlistItemId = Jellyfin::Support::fromJsonValue<QString>(source["PlaylistItemId"]);
 
@@ -195,6 +200,7 @@ QJsonObject PlaybackStartInfo::toJson() const {
 	}
 			
 	result["RepeatMode"] = Jellyfin::Support::toJsonValue<RepeatMode>(m_repeatMode);		
+	result["PlaybackOrder"] = Jellyfin::Support::toJsonValue<PlaybackOrder>(m_playbackOrder);		
 	
 	if (!(m_nowPlayingQueue.size() == 0)) {
 		result["NowPlayingQueue"] = Jellyfin::Support::toJsonValue<QList<QueueItem>>(m_nowPlayingQueue);
@@ -393,6 +399,12 @@ void PlaybackStartInfo::setRepeatMode(RepeatMode newRepeatMode) {
 	m_repeatMode = newRepeatMode;
 }
 
+PlaybackOrder PlaybackStartInfo::playbackOrder() const { return m_playbackOrder; }
+
+void PlaybackStartInfo::setPlaybackOrder(PlaybackOrder newPlaybackOrder) {
+	m_playbackOrder = newPlaybackOrder;
+}
+
 QList<QueueItem> PlaybackStartInfo::nowPlayingQueue() const { return m_nowPlayingQueue; }
 
 void PlaybackStartInfo::setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue) {
diff --git a/core/src/dto/playerstateinfo.cpp b/core/src/dto/playerstateinfo.cpp
index 25ad5d7..ce19343 100644
--- a/core/src/dto/playerstateinfo.cpp
+++ b/core/src/dto/playerstateinfo.cpp
@@ -38,13 +38,15 @@ PlayerStateInfo::PlayerStateInfo (
 		bool isPaused, 
 		bool isMuted, 
 		PlayMethod playMethod, 
-		RepeatMode repeatMode 
+		RepeatMode repeatMode, 
+		PlaybackOrder playbackOrder 
 		) :
 	m_canSeek(canSeek),
 	m_isPaused(isPaused),
 	m_isMuted(isMuted),
 	m_playMethod(playMethod),
-	m_repeatMode(repeatMode) { }
+	m_repeatMode(repeatMode),
+	m_playbackOrder(playbackOrder) { }
 
 
 
@@ -59,7 +61,9 @@ PlayerStateInfo::PlayerStateInfo(const PlayerStateInfo &other) :
 	m_subtitleStreamIndex(other.m_subtitleStreamIndex),
 	m_mediaSourceId(other.m_mediaSourceId),
 	m_playMethod(other.m_playMethod),
-	m_repeatMode(other.m_repeatMode){}
+	m_repeatMode(other.m_repeatMode),
+	m_playbackOrder(other.m_playbackOrder),
+	m_liveStreamId(other.m_liveStreamId){}
 
 
 void PlayerStateInfo::replaceData(PlayerStateInfo &other) {
@@ -73,6 +77,8 @@ void PlayerStateInfo::replaceData(PlayerStateInfo &other) {
 	m_mediaSourceId = other.m_mediaSourceId;
 	m_playMethod = other.m_playMethod;
 	m_repeatMode = other.m_repeatMode;
+	m_playbackOrder = other.m_playbackOrder;
+	m_liveStreamId = other.m_liveStreamId;
 }
 
 PlayerStateInfo PlayerStateInfo::fromJson(QJsonObject source) {
@@ -93,6 +99,8 @@ void PlayerStateInfo::setFromJson(QJsonObject source) {
 	m_mediaSourceId = Jellyfin::Support::fromJsonValue<QString>(source["MediaSourceId"]);
 	m_playMethod = Jellyfin::Support::fromJsonValue<PlayMethod>(source["PlayMethod"]);
 	m_repeatMode = Jellyfin::Support::fromJsonValue<RepeatMode>(source["RepeatMode"]);
+	m_playbackOrder = Jellyfin::Support::fromJsonValue<PlaybackOrder>(source["PlaybackOrder"]);
+	m_liveStreamId = Jellyfin::Support::fromJsonValue<QString>(source["LiveStreamId"]);
 
 }
 	
@@ -128,7 +136,13 @@ QJsonObject PlayerStateInfo::toJson() const {
 	}
 			
 	result["PlayMethod"] = Jellyfin::Support::toJsonValue<PlayMethod>(m_playMethod);		
-	result["RepeatMode"] = Jellyfin::Support::toJsonValue<RepeatMode>(m_repeatMode);	
+	result["RepeatMode"] = Jellyfin::Support::toJsonValue<RepeatMode>(m_repeatMode);		
+	result["PlaybackOrder"] = Jellyfin::Support::toJsonValue<PlaybackOrder>(m_playbackOrder);		
+	
+	if (!(m_liveStreamId.isNull())) {
+		result["LiveStreamId"] = Jellyfin::Support::toJsonValue<QString>(m_liveStreamId);
+	}
+		
 	return result;
 }
 
@@ -227,6 +241,25 @@ void PlayerStateInfo::setRepeatMode(RepeatMode newRepeatMode) {
 	m_repeatMode = newRepeatMode;
 }
 
+PlaybackOrder PlayerStateInfo::playbackOrder() const { return m_playbackOrder; }
+
+void PlayerStateInfo::setPlaybackOrder(PlaybackOrder newPlaybackOrder) {
+	m_playbackOrder = newPlaybackOrder;
+}
+
+QString PlayerStateInfo::liveStreamId() const { return m_liveStreamId; }
+
+void PlayerStateInfo::setLiveStreamId(QString newLiveStreamId) {
+	m_liveStreamId = newLiveStreamId;
+}
+bool PlayerStateInfo::liveStreamIdNull() const {
+	return m_liveStreamId.isNull();
+}
+
+void PlayerStateInfo::setLiveStreamIdNull() {
+	m_liveStreamId.clear();
+
+}
 
 } // NS DTO
 
diff --git a/core/src/dto/playlistcreationresult.cpp b/core/src/dto/playlistcreationresult.cpp
index bc7d1d8..0a4bafe 100644
--- a/core/src/dto/playlistcreationresult.cpp
+++ b/core/src/dto/playlistcreationresult.cpp
@@ -33,6 +33,12 @@ namespace Jellyfin {
 namespace DTO {
 
 PlaylistCreationResult::PlaylistCreationResult() {}
+PlaylistCreationResult::PlaylistCreationResult (
+		QString jellyfinId 
+		) :
+	m_jellyfinId(jellyfinId) { }
+
+
 
 PlaylistCreationResult::PlaylistCreationResult(const PlaylistCreationResult &other) :
 
@@ -58,11 +64,7 @@ void PlaylistCreationResult::setFromJson(QJsonObject source) {
 QJsonObject PlaylistCreationResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-		
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);	
 	return result;
 }
 
@@ -71,14 +73,7 @@ QString PlaylistCreationResult::jellyfinId() const { return m_jellyfinId; }
 void PlaylistCreationResult::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool PlaylistCreationResult::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
 
-void PlaylistCreationResult::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/playlistdto.cpp b/core/src/dto/playlistdto.cpp
new file mode 100644
index 0000000..4c76e0d
--- /dev/null
+++ b/core/src/dto/playlistdto.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/playlistdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlaylistDto::PlaylistDto() {}
+PlaylistDto::PlaylistDto (
+		bool openAccess, 
+		QList<PlaylistUserPermissions> shares, 
+		QStringList itemIds 
+		) :
+	m_openAccess(openAccess),
+	m_shares(shares),
+	m_itemIds(itemIds) { }
+
+
+
+PlaylistDto::PlaylistDto(const PlaylistDto &other) :
+
+	m_openAccess(other.m_openAccess),
+	m_shares(other.m_shares),
+	m_itemIds(other.m_itemIds){}
+
+
+void PlaylistDto::replaceData(PlaylistDto &other) {
+	m_openAccess = other.m_openAccess;
+	m_shares = other.m_shares;
+	m_itemIds = other.m_itemIds;
+}
+
+PlaylistDto PlaylistDto::fromJson(QJsonObject source) {
+	PlaylistDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlaylistDto::setFromJson(QJsonObject source) {
+	m_openAccess = Jellyfin::Support::fromJsonValue<bool>(source["OpenAccess"]);
+	m_shares = Jellyfin::Support::fromJsonValue<QList<PlaylistUserPermissions>>(source["Shares"]);
+	m_itemIds = Jellyfin::Support::fromJsonValue<QStringList>(source["ItemIds"]);
+
+}
+	
+QJsonObject PlaylistDto::toJson() const {
+	QJsonObject result;
+	
+	result["OpenAccess"] = Jellyfin::Support::toJsonValue<bool>(m_openAccess);		
+	result["Shares"] = Jellyfin::Support::toJsonValue<QList<PlaylistUserPermissions>>(m_shares);		
+	result["ItemIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemIds);	
+	return result;
+}
+
+bool PlaylistDto::openAccess() const { return m_openAccess; }
+
+void PlaylistDto::setOpenAccess(bool newOpenAccess) {
+	m_openAccess = newOpenAccess;
+}
+
+QList<PlaylistUserPermissions> PlaylistDto::shares() const { return m_shares; }
+
+void PlaylistDto::setShares(QList<PlaylistUserPermissions> newShares) {
+	m_shares = newShares;
+}
+
+QStringList PlaylistDto::itemIds() const { return m_itemIds; }
+
+void PlaylistDto::setItemIds(QStringList newItemIds) {
+	m_itemIds = newItemIds;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlaylistDto = Jellyfin::DTO::PlaylistDto;
+
+template <>
+PlaylistDto fromJsonValue(const QJsonValue &source, convertType<PlaylistDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlaylistDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlaylistDto &source, convertType<PlaylistDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playlistuserpermissions.cpp b/core/src/dto/playlistuserpermissions.cpp
new file mode 100644
index 0000000..9cc9af5
--- /dev/null
+++ b/core/src/dto/playlistuserpermissions.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/playlistuserpermissions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlaylistUserPermissions::PlaylistUserPermissions() {}
+PlaylistUserPermissions::PlaylistUserPermissions (
+		QString userId, 
+		bool canEdit 
+		) :
+	m_userId(userId),
+	m_canEdit(canEdit) { }
+
+
+
+PlaylistUserPermissions::PlaylistUserPermissions(const PlaylistUserPermissions &other) :
+
+	m_userId(other.m_userId),
+	m_canEdit(other.m_canEdit){}
+
+
+void PlaylistUserPermissions::replaceData(PlaylistUserPermissions &other) {
+	m_userId = other.m_userId;
+	m_canEdit = other.m_canEdit;
+}
+
+PlaylistUserPermissions PlaylistUserPermissions::fromJson(QJsonObject source) {
+	PlaylistUserPermissions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlaylistUserPermissions::setFromJson(QJsonObject source) {
+	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
+	m_canEdit = Jellyfin::Support::fromJsonValue<bool>(source["CanEdit"]);
+
+}
+	
+QJsonObject PlaylistUserPermissions::toJson() const {
+	QJsonObject result;
+	
+	result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);		
+	result["CanEdit"] = Jellyfin::Support::toJsonValue<bool>(m_canEdit);	
+	return result;
+}
+
+QString PlaylistUserPermissions::userId() const { return m_userId; }
+
+void PlaylistUserPermissions::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+
+bool PlaylistUserPermissions::canEdit() const { return m_canEdit; }
+
+void PlaylistUserPermissions::setCanEdit(bool newCanEdit) {
+	m_canEdit = newCanEdit;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlaylistUserPermissions = Jellyfin::DTO::PlaylistUserPermissions;
+
+template <>
+PlaylistUserPermissions fromJsonValue(const QJsonValue &source, convertType<PlaylistUserPermissions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlaylistUserPermissions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlaylistUserPermissions &source, convertType<PlaylistUserPermissions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playmessage.cpp b/core/src/dto/playmessage.cpp
new file mode 100644
index 0000000..f00b577
--- /dev/null
+++ b/core/src/dto/playmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/playmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlayMessage::PlayMessage() {}
+PlayMessage::PlayMessage (
+		QSharedPointer<PlayRequest> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PlayMessage::PlayMessage(const PlayMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PlayMessage::replaceData(PlayMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PlayMessage PlayMessage::fromJson(QJsonObject source) {
+	PlayMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlayMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<PlayRequest>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PlayMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<PlayRequest>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<PlayRequest> PlayMessage::data() const { return m_data; }
+
+void PlayMessage::setData(QSharedPointer<PlayRequest> newData) {
+	m_data = newData;
+}
+
+QString PlayMessage::messageId() const { return m_messageId; }
+
+void PlayMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PlayMessage::messageType() const { return m_messageType; }
+
+void PlayMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayMessage = Jellyfin::DTO::PlayMessage;
+
+template <>
+PlayMessage fromJsonValue(const QJsonValue &source, convertType<PlayMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlayMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlayMessage &source, convertType<PlayMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playqueueupdate.cpp b/core/src/dto/playqueueupdate.cpp
new file mode 100644
index 0000000..1d49e3c
--- /dev/null
+++ b/core/src/dto/playqueueupdate.cpp
@@ -0,0 +1,180 @@
+/*
+ * 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/dto/playqueueupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlayQueueUpdate::PlayQueueUpdate() {}
+PlayQueueUpdate::PlayQueueUpdate (
+		PlayQueueUpdateReason reason, 
+		QDateTime lastUpdate, 
+		QList<SyncPlayQueueItem> playlist, 
+		qint32 playingItemIndex, 
+		qint64 startPositionTicks, 
+		bool isPlaying, 
+		GroupShuffleMode shuffleMode, 
+		GroupRepeatMode repeatMode 
+		) :
+	m_reason(reason),
+	m_lastUpdate(lastUpdate),
+	m_playlist(playlist),
+	m_playingItemIndex(playingItemIndex),
+	m_startPositionTicks(startPositionTicks),
+	m_isPlaying(isPlaying),
+	m_shuffleMode(shuffleMode),
+	m_repeatMode(repeatMode) { }
+
+
+
+PlayQueueUpdate::PlayQueueUpdate(const PlayQueueUpdate &other) :
+
+	m_reason(other.m_reason),
+	m_lastUpdate(other.m_lastUpdate),
+	m_playlist(other.m_playlist),
+	m_playingItemIndex(other.m_playingItemIndex),
+	m_startPositionTicks(other.m_startPositionTicks),
+	m_isPlaying(other.m_isPlaying),
+	m_shuffleMode(other.m_shuffleMode),
+	m_repeatMode(other.m_repeatMode){}
+
+
+void PlayQueueUpdate::replaceData(PlayQueueUpdate &other) {
+	m_reason = other.m_reason;
+	m_lastUpdate = other.m_lastUpdate;
+	m_playlist = other.m_playlist;
+	m_playingItemIndex = other.m_playingItemIndex;
+	m_startPositionTicks = other.m_startPositionTicks;
+	m_isPlaying = other.m_isPlaying;
+	m_shuffleMode = other.m_shuffleMode;
+	m_repeatMode = other.m_repeatMode;
+}
+
+PlayQueueUpdate PlayQueueUpdate::fromJson(QJsonObject source) {
+	PlayQueueUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlayQueueUpdate::setFromJson(QJsonObject source) {
+	m_reason = Jellyfin::Support::fromJsonValue<PlayQueueUpdateReason>(source["Reason"]);
+	m_lastUpdate = Jellyfin::Support::fromJsonValue<QDateTime>(source["LastUpdate"]);
+	m_playlist = Jellyfin::Support::fromJsonValue<QList<SyncPlayQueueItem>>(source["Playlist"]);
+	m_playingItemIndex = Jellyfin::Support::fromJsonValue<qint32>(source["PlayingItemIndex"]);
+	m_startPositionTicks = Jellyfin::Support::fromJsonValue<qint64>(source["StartPositionTicks"]);
+	m_isPlaying = Jellyfin::Support::fromJsonValue<bool>(source["IsPlaying"]);
+	m_shuffleMode = Jellyfin::Support::fromJsonValue<GroupShuffleMode>(source["ShuffleMode"]);
+	m_repeatMode = Jellyfin::Support::fromJsonValue<GroupRepeatMode>(source["RepeatMode"]);
+
+}
+	
+QJsonObject PlayQueueUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["Reason"] = Jellyfin::Support::toJsonValue<PlayQueueUpdateReason>(m_reason);		
+	result["LastUpdate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastUpdate);		
+	result["Playlist"] = Jellyfin::Support::toJsonValue<QList<SyncPlayQueueItem>>(m_playlist);		
+	result["PlayingItemIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_playingItemIndex);		
+	result["StartPositionTicks"] = Jellyfin::Support::toJsonValue<qint64>(m_startPositionTicks);		
+	result["IsPlaying"] = Jellyfin::Support::toJsonValue<bool>(m_isPlaying);		
+	result["ShuffleMode"] = Jellyfin::Support::toJsonValue<GroupShuffleMode>(m_shuffleMode);		
+	result["RepeatMode"] = Jellyfin::Support::toJsonValue<GroupRepeatMode>(m_repeatMode);	
+	return result;
+}
+
+PlayQueueUpdateReason PlayQueueUpdate::reason() const { return m_reason; }
+
+void PlayQueueUpdate::setReason(PlayQueueUpdateReason newReason) {
+	m_reason = newReason;
+}
+
+QDateTime PlayQueueUpdate::lastUpdate() const { return m_lastUpdate; }
+
+void PlayQueueUpdate::setLastUpdate(QDateTime newLastUpdate) {
+	m_lastUpdate = newLastUpdate;
+}
+
+QList<SyncPlayQueueItem> PlayQueueUpdate::playlist() const { return m_playlist; }
+
+void PlayQueueUpdate::setPlaylist(QList<SyncPlayQueueItem> newPlaylist) {
+	m_playlist = newPlaylist;
+}
+
+qint32 PlayQueueUpdate::playingItemIndex() const { return m_playingItemIndex; }
+
+void PlayQueueUpdate::setPlayingItemIndex(qint32 newPlayingItemIndex) {
+	m_playingItemIndex = newPlayingItemIndex;
+}
+
+qint64 PlayQueueUpdate::startPositionTicks() const { return m_startPositionTicks; }
+
+void PlayQueueUpdate::setStartPositionTicks(qint64 newStartPositionTicks) {
+	m_startPositionTicks = newStartPositionTicks;
+}
+
+bool PlayQueueUpdate::isPlaying() const { return m_isPlaying; }
+
+void PlayQueueUpdate::setIsPlaying(bool newIsPlaying) {
+	m_isPlaying = newIsPlaying;
+}
+
+GroupShuffleMode PlayQueueUpdate::shuffleMode() const { return m_shuffleMode; }
+
+void PlayQueueUpdate::setShuffleMode(GroupShuffleMode newShuffleMode) {
+	m_shuffleMode = newShuffleMode;
+}
+
+GroupRepeatMode PlayQueueUpdate::repeatMode() const { return m_repeatMode; }
+
+void PlayQueueUpdate::setRepeatMode(GroupRepeatMode newRepeatMode) {
+	m_repeatMode = newRepeatMode;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdate = Jellyfin::DTO::PlayQueueUpdate;
+
+template <>
+PlayQueueUpdate fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlayQueueUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlayQueueUpdate &source, convertType<PlayQueueUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playqueueupdategroupupdate.cpp b/core/src/dto/playqueueupdategroupupdate.cpp
new file mode 100644
index 0000000..ff4ca0e
--- /dev/null
+++ b/core/src/dto/playqueueupdategroupupdate.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/playqueueupdategroupupdate.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlayQueueUpdateGroupUpdate::PlayQueueUpdateGroupUpdate() {}
+PlayQueueUpdateGroupUpdate::PlayQueueUpdateGroupUpdate (
+		QString groupId, 
+		GroupUpdateType type, 
+		QSharedPointer<PlayQueueUpdate> data 
+		) :
+	m_groupId(groupId),
+	m_type(type),
+	m_data(data) { }
+
+
+
+PlayQueueUpdateGroupUpdate::PlayQueueUpdateGroupUpdate(const PlayQueueUpdateGroupUpdate &other) :
+
+	m_groupId(other.m_groupId),
+	m_type(other.m_type),
+	m_data(other.m_data){}
+
+
+void PlayQueueUpdateGroupUpdate::replaceData(PlayQueueUpdateGroupUpdate &other) {
+	m_groupId = other.m_groupId;
+	m_type = other.m_type;
+	m_data = other.m_data;
+}
+
+PlayQueueUpdateGroupUpdate PlayQueueUpdateGroupUpdate::fromJson(QJsonObject source) {
+	PlayQueueUpdateGroupUpdate instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlayQueueUpdateGroupUpdate::setFromJson(QJsonObject source) {
+	m_groupId = Jellyfin::Support::fromJsonValue<QString>(source["GroupId"]);
+	m_type = Jellyfin::Support::fromJsonValue<GroupUpdateType>(source["Type"]);
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<PlayQueueUpdate>>(source["Data"]);
+
+}
+	
+QJsonObject PlayQueueUpdateGroupUpdate::toJson() const {
+	QJsonObject result;
+	
+	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
+	result["Type"] = Jellyfin::Support::toJsonValue<GroupUpdateType>(m_type);		
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<PlayQueueUpdate>>(m_data);	
+	return result;
+}
+
+QString PlayQueueUpdateGroupUpdate::groupId() const { return m_groupId; }
+
+void PlayQueueUpdateGroupUpdate::setGroupId(QString newGroupId) {
+	m_groupId = newGroupId;
+}
+
+GroupUpdateType PlayQueueUpdateGroupUpdate::type() const { return m_type; }
+
+void PlayQueueUpdateGroupUpdate::setType(GroupUpdateType newType) {
+	m_type = newType;
+}
+
+QSharedPointer<PlayQueueUpdate> PlayQueueUpdateGroupUpdate::data() const { return m_data; }
+
+void PlayQueueUpdateGroupUpdate::setData(QSharedPointer<PlayQueueUpdate> newData) {
+	m_data = newData;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdateGroupUpdate = Jellyfin::DTO::PlayQueueUpdateGroupUpdate;
+
+template <>
+PlayQueueUpdateGroupUpdate fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdateGroupUpdate>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlayQueueUpdateGroupUpdate::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlayQueueUpdateGroupUpdate &source, convertType<PlayQueueUpdateGroupUpdate>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playqueueupdatereason.cpp b/core/src/dto/playqueueupdatereason.cpp
new file mode 100644
index 0000000..f4fd498
--- /dev/null
+++ b/core/src/dto/playqueueupdatereason.cpp
@@ -0,0 +1,113 @@
+/*
+ * 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/dto/playqueueupdatereason.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlayQueueUpdateReasonClass::PlayQueueUpdateReasonClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using PlayQueueUpdateReason = Jellyfin::DTO::PlayQueueUpdateReason;
+
+template <>
+PlayQueueUpdateReason fromJsonValue(const QJsonValue &source, convertType<PlayQueueUpdateReason>) {
+	if (!source.isString()) return PlayQueueUpdateReason::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("NewPlaylist")) {
+		return PlayQueueUpdateReason::NewPlaylist;
+	}
+	if (str == QStringLiteral("SetCurrentItem")) {
+		return PlayQueueUpdateReason::SetCurrentItem;
+	}
+	if (str == QStringLiteral("RemoveItems")) {
+		return PlayQueueUpdateReason::RemoveItems;
+	}
+	if (str == QStringLiteral("MoveItem")) {
+		return PlayQueueUpdateReason::MoveItem;
+	}
+	if (str == QStringLiteral("Queue")) {
+		return PlayQueueUpdateReason::Queue;
+	}
+	if (str == QStringLiteral("QueueNext")) {
+		return PlayQueueUpdateReason::QueueNext;
+	}
+	if (str == QStringLiteral("NextItem")) {
+		return PlayQueueUpdateReason::NextItem;
+	}
+	if (str == QStringLiteral("PreviousItem")) {
+		return PlayQueueUpdateReason::PreviousItem;
+	}
+	if (str == QStringLiteral("RepeatMode")) {
+		return PlayQueueUpdateReason::RepeatMode;
+	}
+	if (str == QStringLiteral("ShuffleMode")) {
+		return PlayQueueUpdateReason::ShuffleMode;
+	}
+	
+	return PlayQueueUpdateReason::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const PlayQueueUpdateReason &source, convertType<PlayQueueUpdateReason>) {
+	switch(source) {
+	case PlayQueueUpdateReason::NewPlaylist:
+		return QStringLiteral("NewPlaylist");
+	case PlayQueueUpdateReason::SetCurrentItem:
+		return QStringLiteral("SetCurrentItem");
+	case PlayQueueUpdateReason::RemoveItems:
+		return QStringLiteral("RemoveItems");
+	case PlayQueueUpdateReason::MoveItem:
+		return QStringLiteral("MoveItem");
+	case PlayQueueUpdateReason::Queue:
+		return QStringLiteral("Queue");
+	case PlayQueueUpdateReason::QueueNext:
+		return QStringLiteral("QueueNext");
+	case PlayQueueUpdateReason::NextItem:
+		return QStringLiteral("NextItem");
+	case PlayQueueUpdateReason::PreviousItem:
+		return QStringLiteral("PreviousItem");
+	case PlayQueueUpdateReason::RepeatMode:
+		return QStringLiteral("RepeatMode");
+	case PlayQueueUpdateReason::ShuffleMode:
+		return QStringLiteral("ShuffleMode");
+
+	case PlayQueueUpdateReason::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/playrequestdto.cpp b/core/src/dto/playrequestdto.cpp
index 7965bbd..d04ca76 100644
--- a/core/src/dto/playrequestdto.cpp
+++ b/core/src/dto/playrequestdto.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 PlayRequestDto::PlayRequestDto() {}
 PlayRequestDto::PlayRequestDto (
+		QStringList playingQueue, 
 		qint32 playingItemPosition, 
 		qint64 startPositionTicks 
 		) :
+	m_playingQueue(playingQueue),
 	m_playingItemPosition(playingItemPosition),
 	m_startPositionTicks(startPositionTicks) { }
 
@@ -72,11 +74,7 @@ void PlayRequestDto::setFromJson(QJsonObject source) {
 QJsonObject PlayRequestDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_playingQueue.size() == 0)) {
-		result["PlayingQueue"] = Jellyfin::Support::toJsonValue<QStringList>(m_playingQueue);
-	}
-			
+	result["PlayingQueue"] = Jellyfin::Support::toJsonValue<QStringList>(m_playingQueue);		
 	result["PlayingItemPosition"] = Jellyfin::Support::toJsonValue<qint32>(m_playingItemPosition);		
 	result["StartPositionTicks"] = Jellyfin::Support::toJsonValue<qint64>(m_startPositionTicks);	
 	return result;
@@ -87,14 +85,7 @@ QStringList PlayRequestDto::playingQueue() const { return m_playingQueue; }
 void PlayRequestDto::setPlayingQueue(QStringList newPlayingQueue) {
 	m_playingQueue = newPlayingQueue;
 }
-bool PlayRequestDto::playingQueueNull() const {
-	return m_playingQueue.size() == 0;
-}
 
-void PlayRequestDto::setPlayingQueueNull() {
-	m_playingQueue.clear();
-
-}
 qint32 PlayRequestDto::playingItemPosition() const { return m_playingItemPosition; }
 
 void PlayRequestDto::setPlayingItemPosition(qint32 newPlayingItemPosition) {
diff --git a/core/src/dto/playstatemessage.cpp b/core/src/dto/playstatemessage.cpp
new file mode 100644
index 0000000..653586b
--- /dev/null
+++ b/core/src/dto/playstatemessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/playstatemessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PlaystateMessage::PlaystateMessage() {}
+PlaystateMessage::PlaystateMessage (
+		QSharedPointer<PlaystateRequest> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PlaystateMessage::PlaystateMessage(const PlaystateMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PlaystateMessage::replaceData(PlaystateMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PlaystateMessage PlaystateMessage::fromJson(QJsonObject source) {
+	PlaystateMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PlaystateMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<PlaystateRequest>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PlaystateMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<PlaystateRequest>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<PlaystateRequest> PlaystateMessage::data() const { return m_data; }
+
+void PlaystateMessage::setData(QSharedPointer<PlaystateRequest> newData) {
+	m_data = newData;
+}
+
+QString PlaystateMessage::messageId() const { return m_messageId; }
+
+void PlaystateMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PlaystateMessage::messageType() const { return m_messageType; }
+
+void PlaystateMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PlaystateMessage = Jellyfin::DTO::PlaystateMessage;
+
+template <>
+PlaystateMessage fromJsonValue(const QJsonValue &source, convertType<PlaystateMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PlaystateMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PlaystateMessage &source, convertType<PlaystateMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/plugininfo.cpp b/core/src/dto/plugininfo.cpp
index 152db34..ca4f05f 100644
--- a/core/src/dto/plugininfo.cpp
+++ b/core/src/dto/plugininfo.cpp
@@ -34,13 +34,17 @@ namespace DTO {
 
 PluginInfo::PluginInfo() {}
 PluginInfo::PluginInfo (
-		QSharedPointer<Version> version, 
+		QString name, 
+		QString version, 
+		QString description, 
 		QString jellyfinId, 
 		bool canUninstall, 
 		bool hasImage, 
 		PluginStatus status 
 		) :
+	m_name(name),
 	m_version(version),
+	m_description(description),
 	m_jellyfinId(jellyfinId),
 	m_canUninstall(canUninstall),
 	m_hasImage(hasImage),
@@ -80,7 +84,7 @@ PluginInfo PluginInfo::fromJson(QJsonObject source) {
 
 void PluginInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
-	m_version = Jellyfin::Support::fromJsonValue<QSharedPointer<Version>>(source["Version"]);
+	m_version = Jellyfin::Support::fromJsonValue<QString>(source["Version"]);
 	m_configurationFileName = Jellyfin::Support::fromJsonValue<QString>(source["ConfigurationFileName"]);
 	m_description = Jellyfin::Support::fromJsonValue<QString>(source["Description"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
@@ -93,22 +97,14 @@ void PluginInfo::setFromJson(QJsonObject source) {
 QJsonObject PluginInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
-	result["Version"] = Jellyfin::Support::toJsonValue<QSharedPointer<Version>>(m_version);		
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["Version"] = Jellyfin::Support::toJsonValue<QString>(m_version);		
 	
 	if (!(m_configurationFileName.isNull())) {
 		result["ConfigurationFileName"] = Jellyfin::Support::toJsonValue<QString>(m_configurationFileName);
 	}
 			
-	
-	if (!(m_description.isNull())) {
-		result["Description"] = Jellyfin::Support::toJsonValue<QString>(m_description);
-	}
-			
+	result["Description"] = Jellyfin::Support::toJsonValue<QString>(m_description);		
 	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
 	result["CanUninstall"] = Jellyfin::Support::toJsonValue<bool>(m_canUninstall);		
 	result["HasImage"] = Jellyfin::Support::toJsonValue<bool>(m_hasImage);		
@@ -121,17 +117,10 @@ QString PluginInfo::name() const { return m_name; }
 void PluginInfo::setName(QString newName) {
 	m_name = newName;
 }
-bool PluginInfo::nameNull() const {
-	return m_name.isNull();
-}
 
-void PluginInfo::setNameNull() {
-	m_name.clear();
+QString PluginInfo::version() const { return m_version; }
 
-}
-QSharedPointer<Version> PluginInfo::version() const { return m_version; }
-
-void PluginInfo::setVersion(QSharedPointer<Version> newVersion) {
+void PluginInfo::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
 
@@ -153,14 +142,7 @@ QString PluginInfo::description() const { return m_description; }
 void PluginInfo::setDescription(QString newDescription) {
 	m_description = newDescription;
 }
-bool PluginInfo::descriptionNull() const {
-	return m_description.isNull();
-}
 
-void PluginInfo::setDescriptionNull() {
-	m_description.clear();
-
-}
 QString PluginInfo::jellyfinId() const { return m_jellyfinId; }
 
 void PluginInfo::setJellyfinId(QString newJellyfinId) {
diff --git a/core/src/dto/plugininstallationcancelledmessage.cpp b/core/src/dto/plugininstallationcancelledmessage.cpp
new file mode 100644
index 0000000..33fa864
--- /dev/null
+++ b/core/src/dto/plugininstallationcancelledmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/plugininstallationcancelledmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PluginInstallationCancelledMessage::PluginInstallationCancelledMessage() {}
+PluginInstallationCancelledMessage::PluginInstallationCancelledMessage (
+		QSharedPointer<InstallationInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PluginInstallationCancelledMessage::PluginInstallationCancelledMessage(const PluginInstallationCancelledMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PluginInstallationCancelledMessage::replaceData(PluginInstallationCancelledMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PluginInstallationCancelledMessage PluginInstallationCancelledMessage::fromJson(QJsonObject source) {
+	PluginInstallationCancelledMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PluginInstallationCancelledMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<InstallationInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PluginInstallationCancelledMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<InstallationInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<InstallationInfo> PluginInstallationCancelledMessage::data() const { return m_data; }
+
+void PluginInstallationCancelledMessage::setData(QSharedPointer<InstallationInfo> newData) {
+	m_data = newData;
+}
+
+QString PluginInstallationCancelledMessage::messageId() const { return m_messageId; }
+
+void PluginInstallationCancelledMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PluginInstallationCancelledMessage::messageType() const { return m_messageType; }
+
+void PluginInstallationCancelledMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationCancelledMessage = Jellyfin::DTO::PluginInstallationCancelledMessage;
+
+template <>
+PluginInstallationCancelledMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationCancelledMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PluginInstallationCancelledMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationCancelledMessage &source, convertType<PluginInstallationCancelledMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/plugininstallationcompletedmessage.cpp b/core/src/dto/plugininstallationcompletedmessage.cpp
new file mode 100644
index 0000000..af2d1a7
--- /dev/null
+++ b/core/src/dto/plugininstallationcompletedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/plugininstallationcompletedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PluginInstallationCompletedMessage::PluginInstallationCompletedMessage() {}
+PluginInstallationCompletedMessage::PluginInstallationCompletedMessage (
+		QSharedPointer<InstallationInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PluginInstallationCompletedMessage::PluginInstallationCompletedMessage(const PluginInstallationCompletedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PluginInstallationCompletedMessage::replaceData(PluginInstallationCompletedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PluginInstallationCompletedMessage PluginInstallationCompletedMessage::fromJson(QJsonObject source) {
+	PluginInstallationCompletedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PluginInstallationCompletedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<InstallationInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PluginInstallationCompletedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<InstallationInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<InstallationInfo> PluginInstallationCompletedMessage::data() const { return m_data; }
+
+void PluginInstallationCompletedMessage::setData(QSharedPointer<InstallationInfo> newData) {
+	m_data = newData;
+}
+
+QString PluginInstallationCompletedMessage::messageId() const { return m_messageId; }
+
+void PluginInstallationCompletedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PluginInstallationCompletedMessage::messageType() const { return m_messageType; }
+
+void PluginInstallationCompletedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationCompletedMessage = Jellyfin::DTO::PluginInstallationCompletedMessage;
+
+template <>
+PluginInstallationCompletedMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationCompletedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PluginInstallationCompletedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationCompletedMessage &source, convertType<PluginInstallationCompletedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/plugininstallationfailedmessage.cpp b/core/src/dto/plugininstallationfailedmessage.cpp
new file mode 100644
index 0000000..bda0a84
--- /dev/null
+++ b/core/src/dto/plugininstallationfailedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/plugininstallationfailedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PluginInstallationFailedMessage::PluginInstallationFailedMessage() {}
+PluginInstallationFailedMessage::PluginInstallationFailedMessage (
+		QSharedPointer<InstallationInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PluginInstallationFailedMessage::PluginInstallationFailedMessage(const PluginInstallationFailedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PluginInstallationFailedMessage::replaceData(PluginInstallationFailedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PluginInstallationFailedMessage PluginInstallationFailedMessage::fromJson(QJsonObject source) {
+	PluginInstallationFailedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PluginInstallationFailedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<InstallationInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PluginInstallationFailedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<InstallationInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<InstallationInfo> PluginInstallationFailedMessage::data() const { return m_data; }
+
+void PluginInstallationFailedMessage::setData(QSharedPointer<InstallationInfo> newData) {
+	m_data = newData;
+}
+
+QString PluginInstallationFailedMessage::messageId() const { return m_messageId; }
+
+void PluginInstallationFailedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PluginInstallationFailedMessage::messageType() const { return m_messageType; }
+
+void PluginInstallationFailedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallationFailedMessage = Jellyfin::DTO::PluginInstallationFailedMessage;
+
+template <>
+PluginInstallationFailedMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallationFailedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PluginInstallationFailedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PluginInstallationFailedMessage &source, convertType<PluginInstallationFailedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/plugininstallingmessage.cpp b/core/src/dto/plugininstallingmessage.cpp
new file mode 100644
index 0000000..6061085
--- /dev/null
+++ b/core/src/dto/plugininstallingmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/plugininstallingmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PluginInstallingMessage::PluginInstallingMessage() {}
+PluginInstallingMessage::PluginInstallingMessage (
+		QSharedPointer<InstallationInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PluginInstallingMessage::PluginInstallingMessage(const PluginInstallingMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PluginInstallingMessage::replaceData(PluginInstallingMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PluginInstallingMessage PluginInstallingMessage::fromJson(QJsonObject source) {
+	PluginInstallingMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PluginInstallingMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<InstallationInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PluginInstallingMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<InstallationInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<InstallationInfo> PluginInstallingMessage::data() const { return m_data; }
+
+void PluginInstallingMessage::setData(QSharedPointer<InstallationInfo> newData) {
+	m_data = newData;
+}
+
+QString PluginInstallingMessage::messageId() const { return m_messageId; }
+
+void PluginInstallingMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PluginInstallingMessage::messageType() const { return m_messageType; }
+
+void PluginInstallingMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginInstallingMessage = Jellyfin::DTO::PluginInstallingMessage;
+
+template <>
+PluginInstallingMessage fromJsonValue(const QJsonValue &source, convertType<PluginInstallingMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PluginInstallingMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PluginInstallingMessage &source, convertType<PluginInstallingMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/pluginsecurityinfo.cpp b/core/src/dto/pluginsecurityinfo.cpp
deleted file mode 100644
index c2b066f..0000000
--- a/core/src/dto/pluginsecurityinfo.cpp
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * 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/dto/pluginsecurityinfo.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-PluginSecurityInfo::PluginSecurityInfo() {}
-PluginSecurityInfo::PluginSecurityInfo (
-		bool isMbSupporter 
-		) :
-	m_isMbSupporter(isMbSupporter) { }
-
-
-
-PluginSecurityInfo::PluginSecurityInfo(const PluginSecurityInfo &other) :
-
-	m_supporterKey(other.m_supporterKey),
-	m_isMbSupporter(other.m_isMbSupporter){}
-
-
-void PluginSecurityInfo::replaceData(PluginSecurityInfo &other) {
-	m_supporterKey = other.m_supporterKey;
-	m_isMbSupporter = other.m_isMbSupporter;
-}
-
-PluginSecurityInfo PluginSecurityInfo::fromJson(QJsonObject source) {
-	PluginSecurityInfo instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void PluginSecurityInfo::setFromJson(QJsonObject source) {
-	m_supporterKey = Jellyfin::Support::fromJsonValue<QString>(source["SupporterKey"]);
-	m_isMbSupporter = Jellyfin::Support::fromJsonValue<bool>(source["IsMbSupporter"]);
-
-}
-	
-QJsonObject PluginSecurityInfo::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_supporterKey.isNull())) {
-		result["SupporterKey"] = Jellyfin::Support::toJsonValue<QString>(m_supporterKey);
-	}
-			
-	result["IsMbSupporter"] = Jellyfin::Support::toJsonValue<bool>(m_isMbSupporter);	
-	return result;
-}
-
-QString PluginSecurityInfo::supporterKey() const { return m_supporterKey; }
-
-void PluginSecurityInfo::setSupporterKey(QString newSupporterKey) {
-	m_supporterKey = newSupporterKey;
-}
-bool PluginSecurityInfo::supporterKeyNull() const {
-	return m_supporterKey.isNull();
-}
-
-void PluginSecurityInfo::setSupporterKeyNull() {
-	m_supporterKey.clear();
-
-}
-bool PluginSecurityInfo::isMbSupporter() const { return m_isMbSupporter; }
-
-void PluginSecurityInfo::setIsMbSupporter(bool newIsMbSupporter) {
-	m_isMbSupporter = newIsMbSupporter;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using PluginSecurityInfo = Jellyfin::DTO::PluginSecurityInfo;
-
-template <>
-PluginSecurityInfo fromJsonValue(const QJsonValue &source, convertType<PluginSecurityInfo>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return PluginSecurityInfo::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const PluginSecurityInfo &source, convertType<PluginSecurityInfo>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/pluginuninstalledmessage.cpp b/core/src/dto/pluginuninstalledmessage.cpp
new file mode 100644
index 0000000..dea4ca8
--- /dev/null
+++ b/core/src/dto/pluginuninstalledmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/pluginuninstalledmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+PluginUninstalledMessage::PluginUninstalledMessage() {}
+PluginUninstalledMessage::PluginUninstalledMessage (
+		QSharedPointer<PluginInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+PluginUninstalledMessage::PluginUninstalledMessage(const PluginUninstalledMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void PluginUninstalledMessage::replaceData(PluginUninstalledMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+PluginUninstalledMessage PluginUninstalledMessage::fromJson(QJsonObject source) {
+	PluginUninstalledMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void PluginUninstalledMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<PluginInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject PluginUninstalledMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<PluginInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<PluginInfo> PluginUninstalledMessage::data() const { return m_data; }
+
+void PluginUninstalledMessage::setData(QSharedPointer<PluginInfo> newData) {
+	m_data = newData;
+}
+
+QString PluginUninstalledMessage::messageId() const { return m_messageId; }
+
+void PluginUninstalledMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType PluginUninstalledMessage::messageType() const { return m_messageType; }
+
+void PluginUninstalledMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using PluginUninstalledMessage = Jellyfin::DTO::PluginUninstalledMessage;
+
+template <>
+PluginUninstalledMessage fromJsonValue(const QJsonValue &source, convertType<PluginUninstalledMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return PluginUninstalledMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const PluginUninstalledMessage &source, convertType<PluginUninstalledMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/processpriorityclass.cpp b/core/src/dto/processpriorityclass.cpp
new file mode 100644
index 0000000..a609128
--- /dev/null
+++ b/core/src/dto/processpriorityclass.cpp
@@ -0,0 +1,93 @@
+/*
+ * 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/dto/processpriorityclass.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ProcessPriorityClassClass::ProcessPriorityClassClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using ProcessPriorityClass = Jellyfin::DTO::ProcessPriorityClass;
+
+template <>
+ProcessPriorityClass fromJsonValue(const QJsonValue &source, convertType<ProcessPriorityClass>) {
+	if (!source.isString()) return ProcessPriorityClass::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Normal")) {
+		return ProcessPriorityClass::Normal;
+	}
+	if (str == QStringLiteral("Idle")) {
+		return ProcessPriorityClass::Idle;
+	}
+	if (str == QStringLiteral("High")) {
+		return ProcessPriorityClass::High;
+	}
+	if (str == QStringLiteral("RealTime")) {
+		return ProcessPriorityClass::RealTime;
+	}
+	if (str == QStringLiteral("BelowNormal")) {
+		return ProcessPriorityClass::BelowNormal;
+	}
+	if (str == QStringLiteral("AboveNormal")) {
+		return ProcessPriorityClass::AboveNormal;
+	}
+	
+	return ProcessPriorityClass::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const ProcessPriorityClass &source, convertType<ProcessPriorityClass>) {
+	switch(source) {
+	case ProcessPriorityClass::Normal:
+		return QStringLiteral("Normal");
+	case ProcessPriorityClass::Idle:
+		return QStringLiteral("Idle");
+	case ProcessPriorityClass::High:
+		return QStringLiteral("High");
+	case ProcessPriorityClass::RealTime:
+		return QStringLiteral("RealTime");
+	case ProcessPriorityClass::BelowNormal:
+		return QStringLiteral("BelowNormal");
+	case ProcessPriorityClass::AboveNormal:
+		return QStringLiteral("AboveNormal");
+
+	case ProcessPriorityClass::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/profileconditionvalue.cpp b/core/src/dto/profileconditionvalue.cpp
index d0366ec..0d0e1fb 100644
--- a/core/src/dto/profileconditionvalue.cpp
+++ b/core/src/dto/profileconditionvalue.cpp
@@ -114,6 +114,9 @@ ProfileConditionValue fromJsonValue(const QJsonValue &source, convertType<Profil
 	if (str == QStringLiteral("AudioBitDepth")) {
 		return ProfileConditionValue::AudioBitDepth;
 	}
+	if (str == QStringLiteral("VideoRangeType")) {
+		return ProfileConditionValue::VideoRangeType;
+	}
 	
 	return ProfileConditionValue::EnumNotSet;
 }
@@ -167,6 +170,8 @@ QJsonValue toJsonValue(const ProfileConditionValue &source, convertType<ProfileC
 		return QStringLiteral("AudioSampleRate");
 	case ProfileConditionValue::AudioBitDepth:
 		return QStringLiteral("AudioBitDepth");
+	case ProfileConditionValue::VideoRangeType:
+		return QStringLiteral("VideoRangeType");
 
 	case ProfileConditionValue::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/queuerequestdto.cpp b/core/src/dto/queuerequestdto.cpp
index a934aec..5f10415 100644
--- a/core/src/dto/queuerequestdto.cpp
+++ b/core/src/dto/queuerequestdto.cpp
@@ -34,8 +34,10 @@ namespace DTO {
 
 QueueRequestDto::QueueRequestDto() {}
 QueueRequestDto::QueueRequestDto (
+		QStringList itemIds, 
 		GroupQueueMode mode 
 		) :
+	m_itemIds(itemIds),
 	m_mode(mode) { }
 
 
@@ -67,11 +69,7 @@ void QueueRequestDto::setFromJson(QJsonObject source) {
 QJsonObject QueueRequestDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_itemIds.size() == 0)) {
-		result["ItemIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemIds);
-	}
-			
+	result["ItemIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_itemIds);		
 	result["Mode"] = Jellyfin::Support::toJsonValue<GroupQueueMode>(m_mode);	
 	return result;
 }
@@ -81,14 +79,7 @@ QStringList QueueRequestDto::itemIds() const { return m_itemIds; }
 void QueueRequestDto::setItemIds(QStringList newItemIds) {
 	m_itemIds = newItemIds;
 }
-bool QueueRequestDto::itemIdsNull() const {
-	return m_itemIds.size() == 0;
-}
 
-void QueueRequestDto::setItemIdsNull() {
-	m_itemIds.clear();
-
-}
 GroupQueueMode QueueRequestDto::mode() const { return m_mode; }
 
 void QueueRequestDto::setMode(GroupQueueMode newMode) {
diff --git a/core/src/dto/quickconnectdto.cpp b/core/src/dto/quickconnectdto.cpp
index 31ea72f..08c8c2c 100644
--- a/core/src/dto/quickconnectdto.cpp
+++ b/core/src/dto/quickconnectdto.cpp
@@ -34,19 +34,19 @@ namespace DTO {
 
 QuickConnectDto::QuickConnectDto() {}
 QuickConnectDto::QuickConnectDto (
-		QString token 
+		QString secret 
 		) :
-	m_token(token) { }
+	m_secret(secret) { }
 
 
 
 QuickConnectDto::QuickConnectDto(const QuickConnectDto &other) :
 
-	m_token(other.m_token){}
+	m_secret(other.m_secret){}
 
 
 void QuickConnectDto::replaceData(QuickConnectDto &other) {
-	m_token = other.m_token;
+	m_secret = other.m_secret;
 }
 
 QuickConnectDto QuickConnectDto::fromJson(QJsonObject source) {
@@ -57,21 +57,21 @@ QuickConnectDto QuickConnectDto::fromJson(QJsonObject source) {
 
 
 void QuickConnectDto::setFromJson(QJsonObject source) {
-	m_token = Jellyfin::Support::fromJsonValue<QString>(source["Token"]);
+	m_secret = Jellyfin::Support::fromJsonValue<QString>(source["Secret"]);
 
 }
 	
 QJsonObject QuickConnectDto::toJson() const {
 	QJsonObject result;
 	
-	result["Token"] = Jellyfin::Support::toJsonValue<QString>(m_token);	
+	result["Secret"] = Jellyfin::Support::toJsonValue<QString>(m_secret);	
 	return result;
 }
 
-QString QuickConnectDto::token() const { return m_token; }
+QString QuickConnectDto::secret() const { return m_secret; }
 
-void QuickConnectDto::setToken(QString newToken) {
-	m_token = newToken;
+void QuickConnectDto::setSecret(QString newSecret) {
+	m_secret = newSecret;
 }
 
 
diff --git a/core/src/dto/quickconnectresult.cpp b/core/src/dto/quickconnectresult.cpp
index e7c1474..5cdd7c1 100644
--- a/core/src/dto/quickconnectresult.cpp
+++ b/core/src/dto/quickconnectresult.cpp
@@ -34,9 +34,23 @@ namespace DTO {
 
 QuickConnectResult::QuickConnectResult() {}
 QuickConnectResult::QuickConnectResult (
-		bool authenticated 
+		bool authenticated, 
+		QString secret, 
+		QString code, 
+		QString deviceId, 
+		QString deviceName, 
+		QString appName, 
+		QString appVersion, 
+		QDateTime dateAdded 
 		) :
-	m_authenticated(authenticated) { }
+	m_authenticated(authenticated),
+	m_secret(secret),
+	m_code(code),
+	m_deviceId(deviceId),
+	m_deviceName(deviceName),
+	m_appName(appName),
+	m_appVersion(appVersion),
+	m_dateAdded(dateAdded) { }
 
 
 
@@ -45,8 +59,10 @@ QuickConnectResult::QuickConnectResult(const QuickConnectResult &other) :
 	m_authenticated(other.m_authenticated),
 	m_secret(other.m_secret),
 	m_code(other.m_code),
-	m_authentication(other.m_authentication),
-	m_error(other.m_error),
+	m_deviceId(other.m_deviceId),
+	m_deviceName(other.m_deviceName),
+	m_appName(other.m_appName),
+	m_appVersion(other.m_appVersion),
 	m_dateAdded(other.m_dateAdded){}
 
 
@@ -54,8 +70,10 @@ void QuickConnectResult::replaceData(QuickConnectResult &other) {
 	m_authenticated = other.m_authenticated;
 	m_secret = other.m_secret;
 	m_code = other.m_code;
-	m_authentication = other.m_authentication;
-	m_error = other.m_error;
+	m_deviceId = other.m_deviceId;
+	m_deviceName = other.m_deviceName;
+	m_appName = other.m_appName;
+	m_appVersion = other.m_appVersion;
 	m_dateAdded = other.m_dateAdded;
 }
 
@@ -70,8 +88,10 @@ void QuickConnectResult::setFromJson(QJsonObject source) {
 	m_authenticated = Jellyfin::Support::fromJsonValue<bool>(source["Authenticated"]);
 	m_secret = Jellyfin::Support::fromJsonValue<QString>(source["Secret"]);
 	m_code = Jellyfin::Support::fromJsonValue<QString>(source["Code"]);
-	m_authentication = Jellyfin::Support::fromJsonValue<QString>(source["Authentication"]);
-	m_error = Jellyfin::Support::fromJsonValue<QString>(source["Error"]);
+	m_deviceId = Jellyfin::Support::fromJsonValue<QString>(source["DeviceId"]);
+	m_deviceName = Jellyfin::Support::fromJsonValue<QString>(source["DeviceName"]);
+	m_appName = Jellyfin::Support::fromJsonValue<QString>(source["AppName"]);
+	m_appVersion = Jellyfin::Support::fromJsonValue<QString>(source["AppVersion"]);
 	m_dateAdded = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateAdded"]);
 
 }
@@ -80,31 +100,13 @@ QJsonObject QuickConnectResult::toJson() const {
 	QJsonObject result;
 	
 	result["Authenticated"] = Jellyfin::Support::toJsonValue<bool>(m_authenticated);		
-	
-	if (!(m_secret.isNull())) {
-		result["Secret"] = Jellyfin::Support::toJsonValue<QString>(m_secret);
-	}
-			
-	
-	if (!(m_code.isNull())) {
-		result["Code"] = Jellyfin::Support::toJsonValue<QString>(m_code);
-	}
-			
-	
-	if (!(m_authentication.isNull())) {
-		result["Authentication"] = Jellyfin::Support::toJsonValue<QString>(m_authentication);
-	}
-			
-	
-	if (!(m_error.isNull())) {
-		result["Error"] = Jellyfin::Support::toJsonValue<QString>(m_error);
-	}
-			
-	
-	if (!(m_dateAdded.isNull())) {
-		result["DateAdded"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateAdded);
-	}
-		
+	result["Secret"] = Jellyfin::Support::toJsonValue<QString>(m_secret);		
+	result["Code"] = Jellyfin::Support::toJsonValue<QString>(m_code);		
+	result["DeviceId"] = Jellyfin::Support::toJsonValue<QString>(m_deviceId);		
+	result["DeviceName"] = Jellyfin::Support::toJsonValue<QString>(m_deviceName);		
+	result["AppName"] = Jellyfin::Support::toJsonValue<QString>(m_appName);		
+	result["AppVersion"] = Jellyfin::Support::toJsonValue<QString>(m_appVersion);		
+	result["DateAdded"] = Jellyfin::Support::toJsonValue<QDateTime>(m_dateAdded);	
 	return result;
 }
 
@@ -119,66 +121,43 @@ QString QuickConnectResult::secret() const { return m_secret; }
 void QuickConnectResult::setSecret(QString newSecret) {
 	m_secret = newSecret;
 }
-bool QuickConnectResult::secretNull() const {
-	return m_secret.isNull();
-}
 
-void QuickConnectResult::setSecretNull() {
-	m_secret.clear();
-
-}
 QString QuickConnectResult::code() const { return m_code; }
 
 void QuickConnectResult::setCode(QString newCode) {
 	m_code = newCode;
 }
-bool QuickConnectResult::codeNull() const {
-	return m_code.isNull();
+
+QString QuickConnectResult::deviceId() const { return m_deviceId; }
+
+void QuickConnectResult::setDeviceId(QString newDeviceId) {
+	m_deviceId = newDeviceId;
 }
 
-void QuickConnectResult::setCodeNull() {
-	m_code.clear();
+QString QuickConnectResult::deviceName() const { return m_deviceName; }
 
-}
-QString QuickConnectResult::authentication() const { return m_authentication; }
-
-void QuickConnectResult::setAuthentication(QString newAuthentication) {
-	m_authentication = newAuthentication;
-}
-bool QuickConnectResult::authenticationNull() const {
-	return m_authentication.isNull();
+void QuickConnectResult::setDeviceName(QString newDeviceName) {
+	m_deviceName = newDeviceName;
 }
 
-void QuickConnectResult::setAuthenticationNull() {
-	m_authentication.clear();
+QString QuickConnectResult::appName() const { return m_appName; }
 
-}
-QString QuickConnectResult::error() const { return m_error; }
-
-void QuickConnectResult::setError(QString newError) {
-	m_error = newError;
-}
-bool QuickConnectResult::errorNull() const {
-	return m_error.isNull();
+void QuickConnectResult::setAppName(QString newAppName) {
+	m_appName = newAppName;
 }
 
-void QuickConnectResult::setErrorNull() {
-	m_error.clear();
+QString QuickConnectResult::appVersion() const { return m_appVersion; }
 
+void QuickConnectResult::setAppVersion(QString newAppVersion) {
+	m_appVersion = newAppVersion;
 }
+
 QDateTime QuickConnectResult::dateAdded() const { return m_dateAdded; }
 
 void QuickConnectResult::setDateAdded(QDateTime newDateAdded) {
 	m_dateAdded = newDateAdded;
 }
-bool QuickConnectResult::dateAddedNull() const {
-	return m_dateAdded.isNull();
-}
 
-void QuickConnectResult::setDateAddedNull() {
-	m_dateAdded= QDateTime();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/refreshprogressmessage.cpp b/core/src/dto/refreshprogressmessage.cpp
new file mode 100644
index 0000000..f3e4a9f
--- /dev/null
+++ b/core/src/dto/refreshprogressmessage.cpp
@@ -0,0 +1,129 @@
+/*
+ * 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/dto/refreshprogressmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+RefreshProgressMessage::RefreshProgressMessage() {}
+RefreshProgressMessage::RefreshProgressMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+RefreshProgressMessage::RefreshProgressMessage(const RefreshProgressMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void RefreshProgressMessage::replaceData(RefreshProgressMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+RefreshProgressMessage RefreshProgressMessage::fromJson(QJsonObject source) {
+	RefreshProgressMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void RefreshProgressMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QJsonObject>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject RefreshProgressMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.isEmpty())) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QJsonObject>(m_data);
+	}
+			
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QJsonObject RefreshProgressMessage::data() const { return m_data; }
+
+void RefreshProgressMessage::setData(QJsonObject newData) {
+	m_data = newData;
+}
+bool RefreshProgressMessage::dataNull() const {
+	return m_data.isEmpty();
+}
+
+void RefreshProgressMessage::setDataNull() {
+	m_data= QJsonObject();
+
+}
+QString RefreshProgressMessage::messageId() const { return m_messageId; }
+
+void RefreshProgressMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType RefreshProgressMessage::messageType() const { return m_messageType; }
+
+void RefreshProgressMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using RefreshProgressMessage = Jellyfin::DTO::RefreshProgressMessage;
+
+template <>
+RefreshProgressMessage fromJsonValue(const QJsonValue &source, convertType<RefreshProgressMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return RefreshProgressMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const RefreshProgressMessage &source, convertType<RefreshProgressMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/remotelyricinfodto.cpp b/core/src/dto/remotelyricinfodto.cpp
new file mode 100644
index 0000000..7647886
--- /dev/null
+++ b/core/src/dto/remotelyricinfodto.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/remotelyricinfodto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+RemoteLyricInfoDto::RemoteLyricInfoDto() {}
+RemoteLyricInfoDto::RemoteLyricInfoDto (
+		QString jellyfinId, 
+		QString providerName, 
+		QSharedPointer<LyricDto> lyrics 
+		) :
+	m_jellyfinId(jellyfinId),
+	m_providerName(providerName),
+	m_lyrics(lyrics) { }
+
+
+
+RemoteLyricInfoDto::RemoteLyricInfoDto(const RemoteLyricInfoDto &other) :
+
+	m_jellyfinId(other.m_jellyfinId),
+	m_providerName(other.m_providerName),
+	m_lyrics(other.m_lyrics){}
+
+
+void RemoteLyricInfoDto::replaceData(RemoteLyricInfoDto &other) {
+	m_jellyfinId = other.m_jellyfinId;
+	m_providerName = other.m_providerName;
+	m_lyrics = other.m_lyrics;
+}
+
+RemoteLyricInfoDto RemoteLyricInfoDto::fromJson(QJsonObject source) {
+	RemoteLyricInfoDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void RemoteLyricInfoDto::setFromJson(QJsonObject source) {
+	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
+	m_providerName = Jellyfin::Support::fromJsonValue<QString>(source["ProviderName"]);
+	m_lyrics = Jellyfin::Support::fromJsonValue<QSharedPointer<LyricDto>>(source["Lyrics"]);
+
+}
+	
+QJsonObject RemoteLyricInfoDto::toJson() const {
+	QJsonObject result;
+	
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
+	result["ProviderName"] = Jellyfin::Support::toJsonValue<QString>(m_providerName);		
+	result["Lyrics"] = Jellyfin::Support::toJsonValue<QSharedPointer<LyricDto>>(m_lyrics);	
+	return result;
+}
+
+QString RemoteLyricInfoDto::jellyfinId() const { return m_jellyfinId; }
+
+void RemoteLyricInfoDto::setJellyfinId(QString newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
+}
+
+QString RemoteLyricInfoDto::providerName() const { return m_providerName; }
+
+void RemoteLyricInfoDto::setProviderName(QString newProviderName) {
+	m_providerName = newProviderName;
+}
+
+QSharedPointer<LyricDto> RemoteLyricInfoDto::lyrics() const { return m_lyrics; }
+
+void RemoteLyricInfoDto::setLyrics(QSharedPointer<LyricDto> newLyrics) {
+	m_lyrics = newLyrics;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using RemoteLyricInfoDto = Jellyfin::DTO::RemoteLyricInfoDto;
+
+template <>
+RemoteLyricInfoDto fromJsonValue(const QJsonValue &source, convertType<RemoteLyricInfoDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return RemoteLyricInfoDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const RemoteLyricInfoDto &source, convertType<RemoteLyricInfoDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/remotesubtitleinfo.cpp b/core/src/dto/remotesubtitleinfo.cpp
index e9be16d..4f5c59a 100644
--- a/core/src/dto/remotesubtitleinfo.cpp
+++ b/core/src/dto/remotesubtitleinfo.cpp
@@ -45,8 +45,13 @@ RemoteSubtitleInfo::RemoteSubtitleInfo(const RemoteSubtitleInfo &other) :
 	m_comment(other.m_comment),
 	m_dateCreated(other.m_dateCreated),
 	m_communityRating(other.m_communityRating),
+	m_frameRate(other.m_frameRate),
 	m_downloadCount(other.m_downloadCount),
-	m_isHashMatch(other.m_isHashMatch){}
+	m_isHashMatch(other.m_isHashMatch),
+	m_aiTranslated(other.m_aiTranslated),
+	m_machineTranslated(other.m_machineTranslated),
+	m_forced(other.m_forced),
+	m_hearingImpaired(other.m_hearingImpaired){}
 
 
 void RemoteSubtitleInfo::replaceData(RemoteSubtitleInfo &other) {
@@ -59,8 +64,13 @@ void RemoteSubtitleInfo::replaceData(RemoteSubtitleInfo &other) {
 	m_comment = other.m_comment;
 	m_dateCreated = other.m_dateCreated;
 	m_communityRating = other.m_communityRating;
+	m_frameRate = other.m_frameRate;
 	m_downloadCount = other.m_downloadCount;
 	m_isHashMatch = other.m_isHashMatch;
+	m_aiTranslated = other.m_aiTranslated;
+	m_machineTranslated = other.m_machineTranslated;
+	m_forced = other.m_forced;
+	m_hearingImpaired = other.m_hearingImpaired;
 }
 
 RemoteSubtitleInfo RemoteSubtitleInfo::fromJson(QJsonObject source) {
@@ -80,8 +90,13 @@ void RemoteSubtitleInfo::setFromJson(QJsonObject source) {
 	m_comment = Jellyfin::Support::fromJsonValue<QString>(source["Comment"]);
 	m_dateCreated = Jellyfin::Support::fromJsonValue<QDateTime>(source["DateCreated"]);
 	m_communityRating = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["CommunityRating"]);
+	m_frameRate = Jellyfin::Support::fromJsonValue<std::optional<float>>(source["FrameRate"]);
 	m_downloadCount = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["DownloadCount"]);
 	m_isHashMatch = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsHashMatch"]);
+	m_aiTranslated = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["AiTranslated"]);
+	m_machineTranslated = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["MachineTranslated"]);
+	m_forced = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["Forced"]);
+	m_hearingImpaired = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["HearingImpaired"]);
 
 }
 	
@@ -134,6 +149,11 @@ QJsonObject RemoteSubtitleInfo::toJson() const {
 	}
 			
 	
+	if (!(!m_frameRate.has_value())) {
+		result["FrameRate"] = Jellyfin::Support::toJsonValue<std::optional<float>>(m_frameRate);
+	}
+			
+	
 	if (!(!m_downloadCount.has_value())) {
 		result["DownloadCount"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_downloadCount);
 	}
@@ -142,6 +162,26 @@ QJsonObject RemoteSubtitleInfo::toJson() const {
 	if (!(!m_isHashMatch.has_value())) {
 		result["IsHashMatch"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_isHashMatch);
 	}
+			
+	
+	if (!(!m_aiTranslated.has_value())) {
+		result["AiTranslated"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_aiTranslated);
+	}
+			
+	
+	if (!(!m_machineTranslated.has_value())) {
+		result["MachineTranslated"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_machineTranslated);
+	}
+			
+	
+	if (!(!m_forced.has_value())) {
+		result["Forced"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_forced);
+	}
+			
+	
+	if (!(!m_hearingImpaired.has_value())) {
+		result["HearingImpaired"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_hearingImpaired);
+	}
 		
 	return result;
 }
@@ -262,6 +302,19 @@ bool RemoteSubtitleInfo::communityRatingNull() const {
 void RemoteSubtitleInfo::setCommunityRatingNull() {
 	m_communityRating = std::nullopt;
 
+}
+std::optional<float> RemoteSubtitleInfo::frameRate() const { return m_frameRate; }
+
+void RemoteSubtitleInfo::setFrameRate(std::optional<float> newFrameRate) {
+	m_frameRate = newFrameRate;
+}
+bool RemoteSubtitleInfo::frameRateNull() const {
+	return !m_frameRate.has_value();
+}
+
+void RemoteSubtitleInfo::setFrameRateNull() {
+	m_frameRate = std::nullopt;
+
 }
 std::optional<qint32> RemoteSubtitleInfo::downloadCount() const { return m_downloadCount; }
 
@@ -288,6 +341,58 @@ bool RemoteSubtitleInfo::isHashMatchNull() const {
 void RemoteSubtitleInfo::setIsHashMatchNull() {
 	m_isHashMatch = std::nullopt;
 
+}
+std::optional<bool> RemoteSubtitleInfo::aiTranslated() const { return m_aiTranslated; }
+
+void RemoteSubtitleInfo::setAiTranslated(std::optional<bool> newAiTranslated) {
+	m_aiTranslated = newAiTranslated;
+}
+bool RemoteSubtitleInfo::aiTranslatedNull() const {
+	return !m_aiTranslated.has_value();
+}
+
+void RemoteSubtitleInfo::setAiTranslatedNull() {
+	m_aiTranslated = std::nullopt;
+
+}
+std::optional<bool> RemoteSubtitleInfo::machineTranslated() const { return m_machineTranslated; }
+
+void RemoteSubtitleInfo::setMachineTranslated(std::optional<bool> newMachineTranslated) {
+	m_machineTranslated = newMachineTranslated;
+}
+bool RemoteSubtitleInfo::machineTranslatedNull() const {
+	return !m_machineTranslated.has_value();
+}
+
+void RemoteSubtitleInfo::setMachineTranslatedNull() {
+	m_machineTranslated = std::nullopt;
+
+}
+std::optional<bool> RemoteSubtitleInfo::forced() const { return m_forced; }
+
+void RemoteSubtitleInfo::setForced(std::optional<bool> newForced) {
+	m_forced = newForced;
+}
+bool RemoteSubtitleInfo::forcedNull() const {
+	return !m_forced.has_value();
+}
+
+void RemoteSubtitleInfo::setForcedNull() {
+	m_forced = std::nullopt;
+
+}
+std::optional<bool> RemoteSubtitleInfo::hearingImpaired() const { return m_hearingImpaired; }
+
+void RemoteSubtitleInfo::setHearingImpaired(std::optional<bool> newHearingImpaired) {
+	m_hearingImpaired = newHearingImpaired;
+}
+bool RemoteSubtitleInfo::hearingImpairedNull() const {
+	return !m_hearingImpaired.has_value();
+}
+
+void RemoteSubtitleInfo::setHearingImpairedNull() {
+	m_hearingImpaired = std::nullopt;
+
 }
 
 } // NS DTO
diff --git a/core/src/dto/removefromplaylistrequestdto.cpp b/core/src/dto/removefromplaylistrequestdto.cpp
index a4108bd..9b4bd14 100644
--- a/core/src/dto/removefromplaylistrequestdto.cpp
+++ b/core/src/dto/removefromplaylistrequestdto.cpp
@@ -33,14 +33,28 @@ namespace Jellyfin {
 namespace DTO {
 
 RemoveFromPlaylistRequestDto::RemoveFromPlaylistRequestDto() {}
+RemoveFromPlaylistRequestDto::RemoveFromPlaylistRequestDto (
+		QStringList playlistItemIds, 
+		bool clearPlaylist, 
+		bool clearPlayingItem 
+		) :
+	m_playlistItemIds(playlistItemIds),
+	m_clearPlaylist(clearPlaylist),
+	m_clearPlayingItem(clearPlayingItem) { }
+
+
 
 RemoveFromPlaylistRequestDto::RemoveFromPlaylistRequestDto(const RemoveFromPlaylistRequestDto &other) :
 
-	m_playlistItemIds(other.m_playlistItemIds){}
+	m_playlistItemIds(other.m_playlistItemIds),
+	m_clearPlaylist(other.m_clearPlaylist),
+	m_clearPlayingItem(other.m_clearPlayingItem){}
 
 
 void RemoveFromPlaylistRequestDto::replaceData(RemoveFromPlaylistRequestDto &other) {
 	m_playlistItemIds = other.m_playlistItemIds;
+	m_clearPlaylist = other.m_clearPlaylist;
+	m_clearPlayingItem = other.m_clearPlayingItem;
 }
 
 RemoveFromPlaylistRequestDto RemoveFromPlaylistRequestDto::fromJson(QJsonObject source) {
@@ -52,17 +66,17 @@ RemoveFromPlaylistRequestDto RemoveFromPlaylistRequestDto::fromJson(QJsonObject
 
 void RemoveFromPlaylistRequestDto::setFromJson(QJsonObject source) {
 	m_playlistItemIds = Jellyfin::Support::fromJsonValue<QStringList>(source["PlaylistItemIds"]);
+	m_clearPlaylist = Jellyfin::Support::fromJsonValue<bool>(source["ClearPlaylist"]);
+	m_clearPlayingItem = Jellyfin::Support::fromJsonValue<bool>(source["ClearPlayingItem"]);
 
 }
 	
 QJsonObject RemoveFromPlaylistRequestDto::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_playlistItemIds.size() == 0)) {
-		result["PlaylistItemIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_playlistItemIds);
-	}
-		
+	result["PlaylistItemIds"] = Jellyfin::Support::toJsonValue<QStringList>(m_playlistItemIds);		
+	result["ClearPlaylist"] = Jellyfin::Support::toJsonValue<bool>(m_clearPlaylist);		
+	result["ClearPlayingItem"] = Jellyfin::Support::toJsonValue<bool>(m_clearPlayingItem);	
 	return result;
 }
 
@@ -71,15 +85,20 @@ QStringList RemoveFromPlaylistRequestDto::playlistItemIds() const { return m_pla
 void RemoveFromPlaylistRequestDto::setPlaylistItemIds(QStringList newPlaylistItemIds) {
 	m_playlistItemIds = newPlaylistItemIds;
 }
-bool RemoveFromPlaylistRequestDto::playlistItemIdsNull() const {
-	return m_playlistItemIds.size() == 0;
+
+bool RemoveFromPlaylistRequestDto::clearPlaylist() const { return m_clearPlaylist; }
+
+void RemoveFromPlaylistRequestDto::setClearPlaylist(bool newClearPlaylist) {
+	m_clearPlaylist = newClearPlaylist;
 }
 
-void RemoveFromPlaylistRequestDto::setPlaylistItemIdsNull() {
-	m_playlistItemIds.clear();
+bool RemoveFromPlaylistRequestDto::clearPlayingItem() const { return m_clearPlayingItem; }
 
+void RemoveFromPlaylistRequestDto::setClearPlayingItem(bool newClearPlayingItem) {
+	m_clearPlayingItem = newClearPlayingItem;
 }
 
+
 } // NS DTO
 
 namespace Support {
diff --git a/core/src/dto/responseprofile.cpp b/core/src/dto/responseprofile.cpp
deleted file mode 100644
index 2110607..0000000
--- a/core/src/dto/responseprofile.cpp
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * 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/dto/responseprofile.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-ResponseProfile::ResponseProfile() {}
-ResponseProfile::ResponseProfile (
-		DlnaProfileType type 
-		) :
-	m_type(type) { }
-
-
-
-ResponseProfile::ResponseProfile(const ResponseProfile &other) :
-
-	m_container(other.m_container),
-	m_audioCodec(other.m_audioCodec),
-	m_videoCodec(other.m_videoCodec),
-	m_type(other.m_type),
-	m_orgPn(other.m_orgPn),
-	m_mimeType(other.m_mimeType),
-	m_conditions(other.m_conditions){}
-
-
-void ResponseProfile::replaceData(ResponseProfile &other) {
-	m_container = other.m_container;
-	m_audioCodec = other.m_audioCodec;
-	m_videoCodec = other.m_videoCodec;
-	m_type = other.m_type;
-	m_orgPn = other.m_orgPn;
-	m_mimeType = other.m_mimeType;
-	m_conditions = other.m_conditions;
-}
-
-ResponseProfile ResponseProfile::fromJson(QJsonObject source) {
-	ResponseProfile instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void ResponseProfile::setFromJson(QJsonObject source) {
-	m_container = Jellyfin::Support::fromJsonValue<QString>(source["Container"]);
-	m_audioCodec = Jellyfin::Support::fromJsonValue<QString>(source["AudioCodec"]);
-	m_videoCodec = Jellyfin::Support::fromJsonValue<QString>(source["VideoCodec"]);
-	m_type = Jellyfin::Support::fromJsonValue<DlnaProfileType>(source["Type"]);
-	m_orgPn = Jellyfin::Support::fromJsonValue<QString>(source["OrgPn"]);
-	m_mimeType = Jellyfin::Support::fromJsonValue<QString>(source["MimeType"]);
-	m_conditions = Jellyfin::Support::fromJsonValue<QList<ProfileCondition>>(source["Conditions"]);
-
-}
-	
-QJsonObject ResponseProfile::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_container.isNull())) {
-		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
-	}
-			
-	
-	if (!(m_audioCodec.isNull())) {
-		result["AudioCodec"] = Jellyfin::Support::toJsonValue<QString>(m_audioCodec);
-	}
-			
-	
-	if (!(m_videoCodec.isNull())) {
-		result["VideoCodec"] = Jellyfin::Support::toJsonValue<QString>(m_videoCodec);
-	}
-			
-	result["Type"] = Jellyfin::Support::toJsonValue<DlnaProfileType>(m_type);		
-	
-	if (!(m_orgPn.isNull())) {
-		result["OrgPn"] = Jellyfin::Support::toJsonValue<QString>(m_orgPn);
-	}
-			
-	
-	if (!(m_mimeType.isNull())) {
-		result["MimeType"] = Jellyfin::Support::toJsonValue<QString>(m_mimeType);
-	}
-			
-	
-	if (!(m_conditions.size() == 0)) {
-		result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);
-	}
-		
-	return result;
-}
-
-QString ResponseProfile::container() const { return m_container; }
-
-void ResponseProfile::setContainer(QString newContainer) {
-	m_container = newContainer;
-}
-bool ResponseProfile::containerNull() const {
-	return m_container.isNull();
-}
-
-void ResponseProfile::setContainerNull() {
-	m_container.clear();
-
-}
-QString ResponseProfile::audioCodec() const { return m_audioCodec; }
-
-void ResponseProfile::setAudioCodec(QString newAudioCodec) {
-	m_audioCodec = newAudioCodec;
-}
-bool ResponseProfile::audioCodecNull() const {
-	return m_audioCodec.isNull();
-}
-
-void ResponseProfile::setAudioCodecNull() {
-	m_audioCodec.clear();
-
-}
-QString ResponseProfile::videoCodec() const { return m_videoCodec; }
-
-void ResponseProfile::setVideoCodec(QString newVideoCodec) {
-	m_videoCodec = newVideoCodec;
-}
-bool ResponseProfile::videoCodecNull() const {
-	return m_videoCodec.isNull();
-}
-
-void ResponseProfile::setVideoCodecNull() {
-	m_videoCodec.clear();
-
-}
-DlnaProfileType ResponseProfile::type() const { return m_type; }
-
-void ResponseProfile::setType(DlnaProfileType newType) {
-	m_type = newType;
-}
-
-QString ResponseProfile::orgPn() const { return m_orgPn; }
-
-void ResponseProfile::setOrgPn(QString newOrgPn) {
-	m_orgPn = newOrgPn;
-}
-bool ResponseProfile::orgPnNull() const {
-	return m_orgPn.isNull();
-}
-
-void ResponseProfile::setOrgPnNull() {
-	m_orgPn.clear();
-
-}
-QString ResponseProfile::mimeType() const { return m_mimeType; }
-
-void ResponseProfile::setMimeType(QString newMimeType) {
-	m_mimeType = newMimeType;
-}
-bool ResponseProfile::mimeTypeNull() const {
-	return m_mimeType.isNull();
-}
-
-void ResponseProfile::setMimeTypeNull() {
-	m_mimeType.clear();
-
-}
-QList<ProfileCondition> ResponseProfile::conditions() const { return m_conditions; }
-
-void ResponseProfile::setConditions(QList<ProfileCondition> newConditions) {
-	m_conditions = newConditions;
-}
-bool ResponseProfile::conditionsNull() const {
-	return m_conditions.size() == 0;
-}
-
-void ResponseProfile::setConditionsNull() {
-	m_conditions.clear();
-
-}
-
-} // NS DTO
-
-namespace Support {
-
-using ResponseProfile = Jellyfin::DTO::ResponseProfile;
-
-template <>
-ResponseProfile fromJsonValue(const QJsonValue &source, convertType<ResponseProfile>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return ResponseProfile::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const ResponseProfile &source, convertType<ResponseProfile>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/restartrequiredmessage.cpp b/core/src/dto/restartrequiredmessage.cpp
new file mode 100644
index 0000000..287d973
--- /dev/null
+++ b/core/src/dto/restartrequiredmessage.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/restartrequiredmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+RestartRequiredMessage::RestartRequiredMessage() {}
+RestartRequiredMessage::RestartRequiredMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+RestartRequiredMessage::RestartRequiredMessage(const RestartRequiredMessage &other) :
+
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void RestartRequiredMessage::replaceData(RestartRequiredMessage &other) {
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+RestartRequiredMessage RestartRequiredMessage::fromJson(QJsonObject source) {
+	RestartRequiredMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void RestartRequiredMessage::setFromJson(QJsonObject source) {
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject RestartRequiredMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString RestartRequiredMessage::messageId() const { return m_messageId; }
+
+void RestartRequiredMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType RestartRequiredMessage::messageType() const { return m_messageType; }
+
+void RestartRequiredMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using RestartRequiredMessage = Jellyfin::DTO::RestartRequiredMessage;
+
+template <>
+RestartRequiredMessage fromJsonValue(const QJsonValue &source, convertType<RestartRequiredMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return RestartRequiredMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const RestartRequiredMessage &source, convertType<RestartRequiredMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/scheduledtaskendedmessage.cpp b/core/src/dto/scheduledtaskendedmessage.cpp
new file mode 100644
index 0000000..ec3dbd9
--- /dev/null
+++ b/core/src/dto/scheduledtaskendedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/scheduledtaskendedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ScheduledTaskEndedMessage::ScheduledTaskEndedMessage() {}
+ScheduledTaskEndedMessage::ScheduledTaskEndedMessage (
+		QSharedPointer<TaskResult> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ScheduledTaskEndedMessage::ScheduledTaskEndedMessage(const ScheduledTaskEndedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ScheduledTaskEndedMessage::replaceData(ScheduledTaskEndedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ScheduledTaskEndedMessage ScheduledTaskEndedMessage::fromJson(QJsonObject source) {
+	ScheduledTaskEndedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ScheduledTaskEndedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<TaskResult>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ScheduledTaskEndedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<TaskResult>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<TaskResult> ScheduledTaskEndedMessage::data() const { return m_data; }
+
+void ScheduledTaskEndedMessage::setData(QSharedPointer<TaskResult> newData) {
+	m_data = newData;
+}
+
+QString ScheduledTaskEndedMessage::messageId() const { return m_messageId; }
+
+void ScheduledTaskEndedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ScheduledTaskEndedMessage::messageType() const { return m_messageType; }
+
+void ScheduledTaskEndedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTaskEndedMessage = Jellyfin::DTO::ScheduledTaskEndedMessage;
+
+template <>
+ScheduledTaskEndedMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTaskEndedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ScheduledTaskEndedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ScheduledTaskEndedMessage &source, convertType<ScheduledTaskEndedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/scheduledtasksinfomessage.cpp b/core/src/dto/scheduledtasksinfomessage.cpp
new file mode 100644
index 0000000..76d2a4e
--- /dev/null
+++ b/core/src/dto/scheduledtasksinfomessage.cpp
@@ -0,0 +1,129 @@
+/*
+ * 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/dto/scheduledtasksinfomessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ScheduledTasksInfoMessage::ScheduledTasksInfoMessage() {}
+ScheduledTasksInfoMessage::ScheduledTasksInfoMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ScheduledTasksInfoMessage::ScheduledTasksInfoMessage(const ScheduledTasksInfoMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ScheduledTasksInfoMessage::replaceData(ScheduledTasksInfoMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ScheduledTasksInfoMessage ScheduledTasksInfoMessage::fromJson(QJsonObject source) {
+	ScheduledTasksInfoMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ScheduledTasksInfoMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QList<TaskInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ScheduledTasksInfoMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.size() == 0)) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QList<TaskInfo>>(m_data);
+	}
+			
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QList<TaskInfo> ScheduledTasksInfoMessage::data() const { return m_data; }
+
+void ScheduledTasksInfoMessage::setData(QList<TaskInfo> newData) {
+	m_data = newData;
+}
+bool ScheduledTasksInfoMessage::dataNull() const {
+	return m_data.size() == 0;
+}
+
+void ScheduledTasksInfoMessage::setDataNull() {
+	m_data.clear();
+
+}
+QString ScheduledTasksInfoMessage::messageId() const { return m_messageId; }
+
+void ScheduledTasksInfoMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ScheduledTasksInfoMessage::messageType() const { return m_messageType; }
+
+void ScheduledTasksInfoMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoMessage = Jellyfin::DTO::ScheduledTasksInfoMessage;
+
+template <>
+ScheduledTasksInfoMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ScheduledTasksInfoMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoMessage &source, convertType<ScheduledTasksInfoMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/scheduledtasksinfostartmessage.cpp b/core/src/dto/scheduledtasksinfostartmessage.cpp
new file mode 100644
index 0000000..c04af73
--- /dev/null
+++ b/core/src/dto/scheduledtasksinfostartmessage.cpp
@@ -0,0 +1,117 @@
+/*
+ * 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/dto/scheduledtasksinfostartmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ScheduledTasksInfoStartMessage::ScheduledTasksInfoStartMessage() {}
+ScheduledTasksInfoStartMessage::ScheduledTasksInfoStartMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+ScheduledTasksInfoStartMessage::ScheduledTasksInfoStartMessage(const ScheduledTasksInfoStartMessage &other) :
+
+	m_data(other.m_data),
+	m_messageType(other.m_messageType){}
+
+
+void ScheduledTasksInfoStartMessage::replaceData(ScheduledTasksInfoStartMessage &other) {
+	m_data = other.m_data;
+	m_messageType = other.m_messageType;
+}
+
+ScheduledTasksInfoStartMessage ScheduledTasksInfoStartMessage::fromJson(QJsonObject source) {
+	ScheduledTasksInfoStartMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ScheduledTasksInfoStartMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ScheduledTasksInfoStartMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.isNull())) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);
+	}
+			
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString ScheduledTasksInfoStartMessage::data() const { return m_data; }
+
+void ScheduledTasksInfoStartMessage::setData(QString newData) {
+	m_data = newData;
+}
+bool ScheduledTasksInfoStartMessage::dataNull() const {
+	return m_data.isNull();
+}
+
+void ScheduledTasksInfoStartMessage::setDataNull() {
+	m_data.clear();
+
+}
+SessionMessageType ScheduledTasksInfoStartMessage::messageType() const { return m_messageType; }
+
+void ScheduledTasksInfoStartMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoStartMessage = Jellyfin::DTO::ScheduledTasksInfoStartMessage;
+
+template <>
+ScheduledTasksInfoStartMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoStartMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ScheduledTasksInfoStartMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoStartMessage &source, convertType<ScheduledTasksInfoStartMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/scheduledtasksinfostopmessage.cpp b/core/src/dto/scheduledtasksinfostopmessage.cpp
new file mode 100644
index 0000000..57b9c5b
--- /dev/null
+++ b/core/src/dto/scheduledtasksinfostopmessage.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/scheduledtasksinfostopmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ScheduledTasksInfoStopMessage::ScheduledTasksInfoStopMessage() {}
+ScheduledTasksInfoStopMessage::ScheduledTasksInfoStopMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+ScheduledTasksInfoStopMessage::ScheduledTasksInfoStopMessage(const ScheduledTasksInfoStopMessage &other) :
+
+	m_messageType(other.m_messageType){}
+
+
+void ScheduledTasksInfoStopMessage::replaceData(ScheduledTasksInfoStopMessage &other) {
+	m_messageType = other.m_messageType;
+}
+
+ScheduledTasksInfoStopMessage ScheduledTasksInfoStopMessage::fromJson(QJsonObject source) {
+	ScheduledTasksInfoStopMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ScheduledTasksInfoStopMessage::setFromJson(QJsonObject source) {
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ScheduledTasksInfoStopMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+SessionMessageType ScheduledTasksInfoStopMessage::messageType() const { return m_messageType; }
+
+void ScheduledTasksInfoStopMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ScheduledTasksInfoStopMessage = Jellyfin::DTO::ScheduledTasksInfoStopMessage;
+
+template <>
+ScheduledTasksInfoStopMessage fromJsonValue(const QJsonValue &source, convertType<ScheduledTasksInfoStopMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ScheduledTasksInfoStopMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ScheduledTasksInfoStopMessage &source, convertType<ScheduledTasksInfoStopMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/searchhint.cpp b/core/src/dto/searchhint.cpp
index 712545f..ebaa8f4 100644
--- a/core/src/dto/searchhint.cpp
+++ b/core/src/dto/searchhint.cpp
@@ -36,13 +36,17 @@ SearchHint::SearchHint() {}
 SearchHint::SearchHint (
 		QString itemId, 
 		QString jellyfinId, 
-		QString albumId, 
-		QString channelId 
+		QString name, 
+		BaseItemKind type, 
+		MediaType mediaType, 
+		QStringList artists 
 		) :
 	m_itemId(itemId),
 	m_jellyfinId(jellyfinId),
-	m_albumId(albumId),
-	m_channelId(channelId) { }
+	m_name(name),
+	m_type(type),
+	m_mediaType(mediaType),
+	m_artists(artists) { }
 
 
 
@@ -131,10 +135,10 @@ void SearchHint::setFromJson(QJsonObject source) {
 	m_thumbImageItemId = Jellyfin::Support::fromJsonValue<QString>(source["ThumbImageItemId"]);
 	m_backdropImageTag = Jellyfin::Support::fromJsonValue<QString>(source["BackdropImageTag"]);
 	m_backdropImageItemId = Jellyfin::Support::fromJsonValue<QString>(source["BackdropImageItemId"]);
-	m_type = Jellyfin::Support::fromJsonValue<QString>(source["Type"]);
+	m_type = Jellyfin::Support::fromJsonValue<BaseItemKind>(source["Type"]);
 	m_isFolder = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsFolder"]);
 	m_runTimeTicks = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["RunTimeTicks"]);
-	m_mediaType = Jellyfin::Support::fromJsonValue<QString>(source["MediaType"]);
+	m_mediaType = Jellyfin::Support::fromJsonValue<MediaType>(source["MediaType"]);
 	m_startDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["StartDate"]);
 	m_endDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["EndDate"]);
 	m_series = Jellyfin::Support::fromJsonValue<QString>(source["Series"]);
@@ -156,11 +160,7 @@ QJsonObject SearchHint::toJson() const {
 	
 	result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);		
 	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
-	
-	if (!(m_name.isNull())) {
-		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
-	}
-			
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
 	
 	if (!(m_matchedTerm.isNull())) {
 		result["MatchedTerm"] = Jellyfin::Support::toJsonValue<QString>(m_matchedTerm);
@@ -206,11 +206,7 @@ QJsonObject SearchHint::toJson() const {
 		result["BackdropImageItemId"] = Jellyfin::Support::toJsonValue<QString>(m_backdropImageItemId);
 	}
 			
-	
-	if (!(m_type.isNull())) {
-		result["Type"] = Jellyfin::Support::toJsonValue<QString>(m_type);
-	}
-			
+	result["Type"] = Jellyfin::Support::toJsonValue<BaseItemKind>(m_type);		
 	
 	if (!(!m_isFolder.has_value())) {
 		result["IsFolder"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_isFolder);
@@ -221,11 +217,7 @@ QJsonObject SearchHint::toJson() const {
 		result["RunTimeTicks"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_runTimeTicks);
 	}
 			
-	
-	if (!(m_mediaType.isNull())) {
-		result["MediaType"] = Jellyfin::Support::toJsonValue<QString>(m_mediaType);
-	}
-			
+	result["MediaType"] = Jellyfin::Support::toJsonValue<MediaType>(m_mediaType);		
 	
 	if (!(m_startDate.isNull())) {
 		result["StartDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_startDate);
@@ -251,17 +243,17 @@ QJsonObject SearchHint::toJson() const {
 		result["Album"] = Jellyfin::Support::toJsonValue<QString>(m_album);
 	}
 			
-	result["AlbumId"] = Jellyfin::Support::toJsonValue<QString>(m_albumId);		
+	
+	if (!(m_albumId.isNull())) {
+		result["AlbumId"] = Jellyfin::Support::toJsonValue<QString>(m_albumId);
+	}
+			
 	
 	if (!(m_albumArtist.isNull())) {
 		result["AlbumArtist"] = Jellyfin::Support::toJsonValue<QString>(m_albumArtist);
 	}
 			
-	
-	if (!(m_artists.size() == 0)) {
-		result["Artists"] = Jellyfin::Support::toJsonValue<QStringList>(m_artists);
-	}
-			
+	result["Artists"] = Jellyfin::Support::toJsonValue<QStringList>(m_artists);		
 	
 	if (!(!m_songCount.has_value())) {
 		result["SongCount"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_songCount);
@@ -272,7 +264,11 @@ QJsonObject SearchHint::toJson() const {
 		result["EpisodeCount"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_episodeCount);
 	}
 			
-	result["ChannelId"] = Jellyfin::Support::toJsonValue<QString>(m_channelId);		
+	
+	if (!(m_channelId.isNull())) {
+		result["ChannelId"] = Jellyfin::Support::toJsonValue<QString>(m_channelId);
+	}
+			
 	
 	if (!(m_channelName.isNull())) {
 		result["ChannelName"] = Jellyfin::Support::toJsonValue<QString>(m_channelName);
@@ -303,14 +299,7 @@ QString SearchHint::name() const { return m_name; }
 void SearchHint::setName(QString newName) {
 	m_name = newName;
 }
-bool SearchHint::nameNull() const {
-	return m_name.isNull();
-}
 
-void SearchHint::setNameNull() {
-	m_name.clear();
-
-}
 QString SearchHint::matchedTerm() const { return m_matchedTerm; }
 
 void SearchHint::setMatchedTerm(QString newMatchedTerm) {
@@ -428,19 +417,12 @@ void SearchHint::setBackdropImageItemIdNull() {
 	m_backdropImageItemId.clear();
 
 }
-QString SearchHint::type() const { return m_type; }
+BaseItemKind SearchHint::type() const { return m_type; }
 
-void SearchHint::setType(QString newType) {
+void SearchHint::setType(BaseItemKind newType) {
 	m_type = newType;
 }
-bool SearchHint::typeNull() const {
-	return m_type.isNull();
-}
 
-void SearchHint::setTypeNull() {
-	m_type.clear();
-
-}
 std::optional<bool> SearchHint::isFolder() const { return m_isFolder; }
 
 void SearchHint::setIsFolder(std::optional<bool> newIsFolder) {
@@ -467,19 +449,12 @@ void SearchHint::setRunTimeTicksNull() {
 	m_runTimeTicks = std::nullopt;
 
 }
-QString SearchHint::mediaType() const { return m_mediaType; }
+MediaType SearchHint::mediaType() const { return m_mediaType; }
 
-void SearchHint::setMediaType(QString newMediaType) {
+void SearchHint::setMediaType(MediaType newMediaType) {
 	m_mediaType = newMediaType;
 }
-bool SearchHint::mediaTypeNull() const {
-	return m_mediaType.isNull();
-}
 
-void SearchHint::setMediaTypeNull() {
-	m_mediaType.clear();
-
-}
 QDateTime SearchHint::startDate() const { return m_startDate; }
 
 void SearchHint::setStartDate(QDateTime newStartDate) {
@@ -550,7 +525,14 @@ QString SearchHint::albumId() const { return m_albumId; }
 void SearchHint::setAlbumId(QString newAlbumId) {
 	m_albumId = newAlbumId;
 }
+bool SearchHint::albumIdNull() const {
+	return m_albumId.isNull();
+}
 
+void SearchHint::setAlbumIdNull() {
+	m_albumId.clear();
+
+}
 QString SearchHint::albumArtist() const { return m_albumArtist; }
 
 void SearchHint::setAlbumArtist(QString newAlbumArtist) {
@@ -569,14 +551,7 @@ QStringList SearchHint::artists() const { return m_artists; }
 void SearchHint::setArtists(QStringList newArtists) {
 	m_artists = newArtists;
 }
-bool SearchHint::artistsNull() const {
-	return m_artists.size() == 0;
-}
 
-void SearchHint::setArtistsNull() {
-	m_artists.clear();
-
-}
 std::optional<qint32> SearchHint::songCount() const { return m_songCount; }
 
 void SearchHint::setSongCount(std::optional<qint32> newSongCount) {
@@ -608,7 +583,14 @@ QString SearchHint::channelId() const { return m_channelId; }
 void SearchHint::setChannelId(QString newChannelId) {
 	m_channelId = newChannelId;
 }
+bool SearchHint::channelIdNull() const {
+	return m_channelId.isNull();
+}
 
+void SearchHint::setChannelIdNull() {
+	m_channelId.clear();
+
+}
 QString SearchHint::channelName() const { return m_channelName; }
 
 void SearchHint::setChannelName(QString newChannelName) {
diff --git a/core/src/dto/searchhintresult.cpp b/core/src/dto/searchhintresult.cpp
index a5ce234..5218dc9 100644
--- a/core/src/dto/searchhintresult.cpp
+++ b/core/src/dto/searchhintresult.cpp
@@ -34,8 +34,10 @@ namespace DTO {
 
 SearchHintResult::SearchHintResult() {}
 SearchHintResult::SearchHintResult (
+		QList<SearchHint> searchHints, 
 		qint32 totalRecordCount 
 		) :
+	m_searchHints(searchHints),
 	m_totalRecordCount(totalRecordCount) { }
 
 
@@ -67,11 +69,7 @@ void SearchHintResult::setFromJson(QJsonObject source) {
 QJsonObject SearchHintResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_searchHints.size() == 0)) {
-		result["SearchHints"] = Jellyfin::Support::toJsonValue<QList<SearchHint>>(m_searchHints);
-	}
-			
+	result["SearchHints"] = Jellyfin::Support::toJsonValue<QList<SearchHint>>(m_searchHints);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);	
 	return result;
 }
@@ -81,14 +79,7 @@ QList<SearchHint> SearchHintResult::searchHints() const { return m_searchHints;
 void SearchHintResult::setSearchHints(QList<SearchHint> newSearchHints) {
 	m_searchHints = newSearchHints;
 }
-bool SearchHintResult::searchHintsNull() const {
-	return m_searchHints.size() == 0;
-}
 
-void SearchHintResult::setSearchHintsNull() {
-	m_searchHints.clear();
-
-}
 qint32 SearchHintResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void SearchHintResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/seriesinfo.cpp b/core/src/dto/seriesinfo.cpp
index fbe0a29..57da08b 100644
--- a/core/src/dto/seriesinfo.cpp
+++ b/core/src/dto/seriesinfo.cpp
@@ -43,6 +43,7 @@ SeriesInfo::SeriesInfo (
 SeriesInfo::SeriesInfo(const SeriesInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -56,6 +57,7 @@ SeriesInfo::SeriesInfo(const SeriesInfo &other) :
 
 void SeriesInfo::replaceData(SeriesInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -76,6 +78,7 @@ SeriesInfo SeriesInfo::fromJson(QJsonObject source) {
 
 void SeriesInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -97,6 +100,11 @@ QJsonObject SeriesInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -152,6 +160,19 @@ bool SeriesInfo::nameNull() const {
 void SeriesInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString SeriesInfo::originalTitle() const { return m_originalTitle; }
+
+void SeriesInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool SeriesInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void SeriesInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString SeriesInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/seriesstatus.cpp b/core/src/dto/seriesstatus.cpp
index 69e7e9a..303b450 100644
--- a/core/src/dto/seriesstatus.cpp
+++ b/core/src/dto/seriesstatus.cpp
@@ -51,6 +51,9 @@ SeriesStatus fromJsonValue(const QJsonValue &source, convertType<SeriesStatus>)
 	if (str == QStringLiteral("Ended")) {
 		return SeriesStatus::Ended;
 	}
+	if (str == QStringLiteral("Unreleased")) {
+		return SeriesStatus::Unreleased;
+	}
 	
 	return SeriesStatus::EnumNotSet;
 }
@@ -62,6 +65,8 @@ QJsonValue toJsonValue(const SeriesStatus &source, convertType<SeriesStatus>) {
 		return QStringLiteral("Continuing");
 	case SeriesStatus::Ended:
 		return QStringLiteral("Ended");
+	case SeriesStatus::Unreleased:
+		return QStringLiteral("Unreleased");
 
 	case SeriesStatus::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/seriestimercancelledmessage.cpp b/core/src/dto/seriestimercancelledmessage.cpp
new file mode 100644
index 0000000..54d6702
--- /dev/null
+++ b/core/src/dto/seriestimercancelledmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/seriestimercancelledmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SeriesTimerCancelledMessage::SeriesTimerCancelledMessage() {}
+SeriesTimerCancelledMessage::SeriesTimerCancelledMessage (
+		QSharedPointer<TimerEventInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+SeriesTimerCancelledMessage::SeriesTimerCancelledMessage(const SeriesTimerCancelledMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void SeriesTimerCancelledMessage::replaceData(SeriesTimerCancelledMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+SeriesTimerCancelledMessage SeriesTimerCancelledMessage::fromJson(QJsonObject source) {
+	SeriesTimerCancelledMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SeriesTimerCancelledMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<TimerEventInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SeriesTimerCancelledMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<TimerEventInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<TimerEventInfo> SeriesTimerCancelledMessage::data() const { return m_data; }
+
+void SeriesTimerCancelledMessage::setData(QSharedPointer<TimerEventInfo> newData) {
+	m_data = newData;
+}
+
+QString SeriesTimerCancelledMessage::messageId() const { return m_messageId; }
+
+void SeriesTimerCancelledMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType SeriesTimerCancelledMessage::messageType() const { return m_messageType; }
+
+void SeriesTimerCancelledMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SeriesTimerCancelledMessage = Jellyfin::DTO::SeriesTimerCancelledMessage;
+
+template <>
+SeriesTimerCancelledMessage fromJsonValue(const QJsonValue &source, convertType<SeriesTimerCancelledMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SeriesTimerCancelledMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SeriesTimerCancelledMessage &source, convertType<SeriesTimerCancelledMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/seriestimercreatedmessage.cpp b/core/src/dto/seriestimercreatedmessage.cpp
new file mode 100644
index 0000000..f43c0ba
--- /dev/null
+++ b/core/src/dto/seriestimercreatedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/seriestimercreatedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SeriesTimerCreatedMessage::SeriesTimerCreatedMessage() {}
+SeriesTimerCreatedMessage::SeriesTimerCreatedMessage (
+		QSharedPointer<TimerEventInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+SeriesTimerCreatedMessage::SeriesTimerCreatedMessage(const SeriesTimerCreatedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void SeriesTimerCreatedMessage::replaceData(SeriesTimerCreatedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+SeriesTimerCreatedMessage SeriesTimerCreatedMessage::fromJson(QJsonObject source) {
+	SeriesTimerCreatedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SeriesTimerCreatedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<TimerEventInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SeriesTimerCreatedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<TimerEventInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<TimerEventInfo> SeriesTimerCreatedMessage::data() const { return m_data; }
+
+void SeriesTimerCreatedMessage::setData(QSharedPointer<TimerEventInfo> newData) {
+	m_data = newData;
+}
+
+QString SeriesTimerCreatedMessage::messageId() const { return m_messageId; }
+
+void SeriesTimerCreatedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType SeriesTimerCreatedMessage::messageType() const { return m_messageType; }
+
+void SeriesTimerCreatedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SeriesTimerCreatedMessage = Jellyfin::DTO::SeriesTimerCreatedMessage;
+
+template <>
+SeriesTimerCreatedMessage fromJsonValue(const QJsonValue &source, convertType<SeriesTimerCreatedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SeriesTimerCreatedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SeriesTimerCreatedMessage &source, convertType<SeriesTimerCreatedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/seriestimerinfodtoqueryresult.cpp b/core/src/dto/seriestimerinfodtoqueryresult.cpp
index 60b3292..0723f13 100644
--- a/core/src/dto/seriestimerinfodtoqueryresult.cpp
+++ b/core/src/dto/seriestimerinfodtoqueryresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 SeriesTimerInfoDtoQueryResult::SeriesTimerInfoDtoQueryResult() {}
 SeriesTimerInfoDtoQueryResult::SeriesTimerInfoDtoQueryResult (
+		QList<SeriesTimerInfoDto> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
@@ -72,11 +74,7 @@ void SeriesTimerInfoDtoQueryResult::setFromJson(QJsonObject source) {
 QJsonObject SeriesTimerInfoDtoQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<SeriesTimerInfoDto>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<SeriesTimerInfoDto>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
@@ -87,14 +85,7 @@ QList<SeriesTimerInfoDto> SeriesTimerInfoDtoQueryResult::items() const { return
 void SeriesTimerInfoDtoQueryResult::setItems(QList<SeriesTimerInfoDto> newItems) {
 	m_items = newItems;
 }
-bool SeriesTimerInfoDtoQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void SeriesTimerInfoDtoQueryResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 SeriesTimerInfoDtoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void SeriesTimerInfoDtoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/serverconfiguration.cpp b/core/src/dto/serverconfiguration.cpp
index 63ea73f..abc471b 100644
--- a/core/src/dto/serverconfiguration.cpp
+++ b/core/src/dto/serverconfiguration.cpp
@@ -36,113 +36,105 @@ ServerConfiguration::ServerConfiguration() {}
 ServerConfiguration::ServerConfiguration (
 		qint32 logFileRetentionDays, 
 		bool isStartupWizardCompleted, 
-		QSharedPointer<Version> previousVersion, 
-		bool enableUPnP, 
 		bool enableMetrics, 
-		qint32 publicPort, 
-		bool uPnPCreateHttpPortMap, 
-		bool enableIPV6, 
-		bool enableIPV4, 
-		bool enableSSDPTracing, 
-		qint32 uDPSendCount, 
-		qint32 uDPSendDelay, 
-		bool ignoreVirtualInterfaces, 
-		qint32 gatewayMonitorPeriod, 
-		bool enableMultiSocketBinding, 
-		bool trustAllIP6Interfaces, 
-		bool autoDiscoveryTracing, 
-		bool autoDiscovery, 
-		qint32 publicHttpsPort, 
-		qint32 httpServerPortNumber, 
-		qint32 httpsPortNumber, 
-		bool enableHttps, 
 		bool enableNormalizedItemByNameIds, 
 		bool isPortAuthorized, 
 		bool quickConnectAvailable, 
-		bool enableRemoteAccess, 
 		bool enableCaseSensitiveItemIds, 
 		bool disableLiveTvChannelUserDataName, 
+		QString metadataPath, 
+		QString preferredMetadataLanguage, 
+		QString metadataCountryCode, 
+		QStringList sortReplaceCharacters, 
+		QStringList sortRemoveCharacters, 
+		QStringList sortRemoveWords, 
 		qint32 minResumePct, 
 		qint32 maxResumePct, 
 		qint32 minResumeDurationSeconds, 
 		qint32 minAudiobookResume, 
 		qint32 maxAudiobookResume, 
+		qint32 inactiveSessionThreshold, 
 		qint32 libraryMonitorDelay, 
-		bool enableDashboardResponseCaching, 
+		qint32 libraryUpdateDuration, 
 		ImageSavingConvention imageSavingConvention, 
+		QList<MetadataOptions> metadataOptions, 
 		bool skipDeserializationForBasicTypes, 
+		QString serverName, 
+		QString uICulture, 
 		bool saveMetadataHidden, 
+		QList<NameValuePair> contentTypes, 
 		qint32 remoteClientBitrateLimit, 
 		bool enableFolderView, 
 		bool enableGroupingIntoCollections, 
 		bool displaySpecialsWithinSeasons, 
+		QStringList codecsUsed, 
+		QList<RepositoryInfo> pluginRepositories, 
 		bool enableExternalContentInSuggestions, 
-		bool requireHttps, 
-		bool enableNewOmdbSupport, 
-		bool isRemoteIPFilterBlacklist, 
 		qint32 imageExtractionTimeoutMs, 
-		bool enableSimpleArtistDetection, 
+		QList<PathSubstitution> pathSubstitutions, 
 		bool enableSlowResponseWarning, 
 		qint64 slowResponseThresholdMs, 
+		QStringList corsHosts, 
 		qint32 libraryScanFanoutConcurrency, 
 		qint32 libraryMetadataRefreshConcurrency, 
 		bool removeOldPlugins, 
-		bool disablePluginImages 
+		bool allowClientLogUpload, 
+		qint32 dummyChapterDuration, 
+		ImageResolution chapterImageResolution, 
+		qint32 parallelImageEncodingLimit, 
+		QList<CastReceiverApplication> castReceiverApplications, 
+		QSharedPointer<TrickplayOptions> trickplayOptions 
 		) :
 	m_logFileRetentionDays(logFileRetentionDays),
 	m_isStartupWizardCompleted(isStartupWizardCompleted),
-	m_previousVersion(previousVersion),
-	m_enableUPnP(enableUPnP),
 	m_enableMetrics(enableMetrics),
-	m_publicPort(publicPort),
-	m_uPnPCreateHttpPortMap(uPnPCreateHttpPortMap),
-	m_enableIPV6(enableIPV6),
-	m_enableIPV4(enableIPV4),
-	m_enableSSDPTracing(enableSSDPTracing),
-	m_uDPSendCount(uDPSendCount),
-	m_uDPSendDelay(uDPSendDelay),
-	m_ignoreVirtualInterfaces(ignoreVirtualInterfaces),
-	m_gatewayMonitorPeriod(gatewayMonitorPeriod),
-	m_enableMultiSocketBinding(enableMultiSocketBinding),
-	m_trustAllIP6Interfaces(trustAllIP6Interfaces),
-	m_autoDiscoveryTracing(autoDiscoveryTracing),
-	m_autoDiscovery(autoDiscovery),
-	m_publicHttpsPort(publicHttpsPort),
-	m_httpServerPortNumber(httpServerPortNumber),
-	m_httpsPortNumber(httpsPortNumber),
-	m_enableHttps(enableHttps),
 	m_enableNormalizedItemByNameIds(enableNormalizedItemByNameIds),
 	m_isPortAuthorized(isPortAuthorized),
 	m_quickConnectAvailable(quickConnectAvailable),
-	m_enableRemoteAccess(enableRemoteAccess),
 	m_enableCaseSensitiveItemIds(enableCaseSensitiveItemIds),
 	m_disableLiveTvChannelUserDataName(disableLiveTvChannelUserDataName),
+	m_metadataPath(metadataPath),
+	m_preferredMetadataLanguage(preferredMetadataLanguage),
+	m_metadataCountryCode(metadataCountryCode),
+	m_sortReplaceCharacters(sortReplaceCharacters),
+	m_sortRemoveCharacters(sortRemoveCharacters),
+	m_sortRemoveWords(sortRemoveWords),
 	m_minResumePct(minResumePct),
 	m_maxResumePct(maxResumePct),
 	m_minResumeDurationSeconds(minResumeDurationSeconds),
 	m_minAudiobookResume(minAudiobookResume),
 	m_maxAudiobookResume(maxAudiobookResume),
+	m_inactiveSessionThreshold(inactiveSessionThreshold),
 	m_libraryMonitorDelay(libraryMonitorDelay),
-	m_enableDashboardResponseCaching(enableDashboardResponseCaching),
+	m_libraryUpdateDuration(libraryUpdateDuration),
 	m_imageSavingConvention(imageSavingConvention),
+	m_metadataOptions(metadataOptions),
 	m_skipDeserializationForBasicTypes(skipDeserializationForBasicTypes),
+	m_serverName(serverName),
+	m_uICulture(uICulture),
 	m_saveMetadataHidden(saveMetadataHidden),
+	m_contentTypes(contentTypes),
 	m_remoteClientBitrateLimit(remoteClientBitrateLimit),
 	m_enableFolderView(enableFolderView),
 	m_enableGroupingIntoCollections(enableGroupingIntoCollections),
 	m_displaySpecialsWithinSeasons(displaySpecialsWithinSeasons),
+	m_codecsUsed(codecsUsed),
+	m_pluginRepositories(pluginRepositories),
 	m_enableExternalContentInSuggestions(enableExternalContentInSuggestions),
-	m_requireHttps(requireHttps),
-	m_enableNewOmdbSupport(enableNewOmdbSupport),
-	m_isRemoteIPFilterBlacklist(isRemoteIPFilterBlacklist),
 	m_imageExtractionTimeoutMs(imageExtractionTimeoutMs),
-	m_enableSimpleArtistDetection(enableSimpleArtistDetection),
+	m_pathSubstitutions(pathSubstitutions),
 	m_enableSlowResponseWarning(enableSlowResponseWarning),
 	m_slowResponseThresholdMs(slowResponseThresholdMs),
+	m_corsHosts(corsHosts),
 	m_libraryScanFanoutConcurrency(libraryScanFanoutConcurrency),
 	m_libraryMetadataRefreshConcurrency(libraryMetadataRefreshConcurrency),
 	m_removeOldPlugins(removeOldPlugins),
-	m_disablePluginImages(disablePluginImages) { }
+	m_allowClientLogUpload(allowClientLogUpload),
+	m_dummyChapterDuration(dummyChapterDuration),
+	m_chapterImageResolution(chapterImageResolution),
+	m_parallelImageEncodingLimit(parallelImageEncodingLimit),
+	m_castReceiverApplications(castReceiverApplications),
+	m_trickplayOptions(trickplayOptions) { }
 
 
 
@@ -153,40 +145,13 @@ ServerConfiguration::ServerConfiguration(const ServerConfiguration &other) :
 	m_cachePath(other.m_cachePath),
 	m_previousVersion(other.m_previousVersion),
 	m_previousVersionStr(other.m_previousVersionStr),
-	m_enableUPnP(other.m_enableUPnP),
 	m_enableMetrics(other.m_enableMetrics),
-	m_publicPort(other.m_publicPort),
-	m_uPnPCreateHttpPortMap(other.m_uPnPCreateHttpPortMap),
-	m_uDPPortRange(other.m_uDPPortRange),
-	m_enableIPV6(other.m_enableIPV6),
-	m_enableIPV4(other.m_enableIPV4),
-	m_enableSSDPTracing(other.m_enableSSDPTracing),
-	m_sSDPTracingFilter(other.m_sSDPTracingFilter),
-	m_uDPSendCount(other.m_uDPSendCount),
-	m_uDPSendDelay(other.m_uDPSendDelay),
-	m_ignoreVirtualInterfaces(other.m_ignoreVirtualInterfaces),
-	m_virtualInterfaceNames(other.m_virtualInterfaceNames),
-	m_gatewayMonitorPeriod(other.m_gatewayMonitorPeriod),
-	m_enableMultiSocketBinding(other.m_enableMultiSocketBinding),
-	m_trustAllIP6Interfaces(other.m_trustAllIP6Interfaces),
-	m_hDHomerunPortRange(other.m_hDHomerunPortRange),
-	m_publishedServerUriBySubnet(other.m_publishedServerUriBySubnet),
-	m_autoDiscoveryTracing(other.m_autoDiscoveryTracing),
-	m_autoDiscovery(other.m_autoDiscovery),
-	m_publicHttpsPort(other.m_publicHttpsPort),
-	m_httpServerPortNumber(other.m_httpServerPortNumber),
-	m_httpsPortNumber(other.m_httpsPortNumber),
-	m_enableHttps(other.m_enableHttps),
 	m_enableNormalizedItemByNameIds(other.m_enableNormalizedItemByNameIds),
-	m_certificatePath(other.m_certificatePath),
-	m_certificatePassword(other.m_certificatePassword),
 	m_isPortAuthorized(other.m_isPortAuthorized),
 	m_quickConnectAvailable(other.m_quickConnectAvailable),
-	m_enableRemoteAccess(other.m_enableRemoteAccess),
 	m_enableCaseSensitiveItemIds(other.m_enableCaseSensitiveItemIds),
 	m_disableLiveTvChannelUserDataName(other.m_disableLiveTvChannelUserDataName),
 	m_metadataPath(other.m_metadataPath),
-	m_metadataNetworkPath(other.m_metadataNetworkPath),
 	m_preferredMetadataLanguage(other.m_preferredMetadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
 	m_sortReplaceCharacters(other.m_sortReplaceCharacters),
@@ -197,13 +162,13 @@ ServerConfiguration::ServerConfiguration(const ServerConfiguration &other) :
 	m_minResumeDurationSeconds(other.m_minResumeDurationSeconds),
 	m_minAudiobookResume(other.m_minAudiobookResume),
 	m_maxAudiobookResume(other.m_maxAudiobookResume),
+	m_inactiveSessionThreshold(other.m_inactiveSessionThreshold),
 	m_libraryMonitorDelay(other.m_libraryMonitorDelay),
-	m_enableDashboardResponseCaching(other.m_enableDashboardResponseCaching),
+	m_libraryUpdateDuration(other.m_libraryUpdateDuration),
 	m_imageSavingConvention(other.m_imageSavingConvention),
 	m_metadataOptions(other.m_metadataOptions),
 	m_skipDeserializationForBasicTypes(other.m_skipDeserializationForBasicTypes),
 	m_serverName(other.m_serverName),
-	m_baseUrl(other.m_baseUrl),
 	m_uICulture(other.m_uICulture),
 	m_saveMetadataHidden(other.m_saveMetadataHidden),
 	m_contentTypes(other.m_contentTypes),
@@ -211,28 +176,24 @@ ServerConfiguration::ServerConfiguration(const ServerConfiguration &other) :
 	m_enableFolderView(other.m_enableFolderView),
 	m_enableGroupingIntoCollections(other.m_enableGroupingIntoCollections),
 	m_displaySpecialsWithinSeasons(other.m_displaySpecialsWithinSeasons),
-	m_localNetworkSubnets(other.m_localNetworkSubnets),
-	m_localNetworkAddresses(other.m_localNetworkAddresses),
 	m_codecsUsed(other.m_codecsUsed),
 	m_pluginRepositories(other.m_pluginRepositories),
 	m_enableExternalContentInSuggestions(other.m_enableExternalContentInSuggestions),
-	m_requireHttps(other.m_requireHttps),
-	m_enableNewOmdbSupport(other.m_enableNewOmdbSupport),
-	m_remoteIPFilter(other.m_remoteIPFilter),
-	m_isRemoteIPFilterBlacklist(other.m_isRemoteIPFilterBlacklist),
 	m_imageExtractionTimeoutMs(other.m_imageExtractionTimeoutMs),
 	m_pathSubstitutions(other.m_pathSubstitutions),
-	m_enableSimpleArtistDetection(other.m_enableSimpleArtistDetection),
-	m_uninstalledPlugins(other.m_uninstalledPlugins),
 	m_enableSlowResponseWarning(other.m_enableSlowResponseWarning),
 	m_slowResponseThresholdMs(other.m_slowResponseThresholdMs),
 	m_corsHosts(other.m_corsHosts),
-	m_knownProxies(other.m_knownProxies),
 	m_activityLogRetentionDays(other.m_activityLogRetentionDays),
 	m_libraryScanFanoutConcurrency(other.m_libraryScanFanoutConcurrency),
 	m_libraryMetadataRefreshConcurrency(other.m_libraryMetadataRefreshConcurrency),
 	m_removeOldPlugins(other.m_removeOldPlugins),
-	m_disablePluginImages(other.m_disablePluginImages){}
+	m_allowClientLogUpload(other.m_allowClientLogUpload),
+	m_dummyChapterDuration(other.m_dummyChapterDuration),
+	m_chapterImageResolution(other.m_chapterImageResolution),
+	m_parallelImageEncodingLimit(other.m_parallelImageEncodingLimit),
+	m_castReceiverApplications(other.m_castReceiverApplications),
+	m_trickplayOptions(other.m_trickplayOptions){}
 
 
 void ServerConfiguration::replaceData(ServerConfiguration &other) {
@@ -241,40 +202,13 @@ void ServerConfiguration::replaceData(ServerConfiguration &other) {
 	m_cachePath = other.m_cachePath;
 	m_previousVersion = other.m_previousVersion;
 	m_previousVersionStr = other.m_previousVersionStr;
-	m_enableUPnP = other.m_enableUPnP;
 	m_enableMetrics = other.m_enableMetrics;
-	m_publicPort = other.m_publicPort;
-	m_uPnPCreateHttpPortMap = other.m_uPnPCreateHttpPortMap;
-	m_uDPPortRange = other.m_uDPPortRange;
-	m_enableIPV6 = other.m_enableIPV6;
-	m_enableIPV4 = other.m_enableIPV4;
-	m_enableSSDPTracing = other.m_enableSSDPTracing;
-	m_sSDPTracingFilter = other.m_sSDPTracingFilter;
-	m_uDPSendCount = other.m_uDPSendCount;
-	m_uDPSendDelay = other.m_uDPSendDelay;
-	m_ignoreVirtualInterfaces = other.m_ignoreVirtualInterfaces;
-	m_virtualInterfaceNames = other.m_virtualInterfaceNames;
-	m_gatewayMonitorPeriod = other.m_gatewayMonitorPeriod;
-	m_enableMultiSocketBinding = other.m_enableMultiSocketBinding;
-	m_trustAllIP6Interfaces = other.m_trustAllIP6Interfaces;
-	m_hDHomerunPortRange = other.m_hDHomerunPortRange;
-	m_publishedServerUriBySubnet = other.m_publishedServerUriBySubnet;
-	m_autoDiscoveryTracing = other.m_autoDiscoveryTracing;
-	m_autoDiscovery = other.m_autoDiscovery;
-	m_publicHttpsPort = other.m_publicHttpsPort;
-	m_httpServerPortNumber = other.m_httpServerPortNumber;
-	m_httpsPortNumber = other.m_httpsPortNumber;
-	m_enableHttps = other.m_enableHttps;
 	m_enableNormalizedItemByNameIds = other.m_enableNormalizedItemByNameIds;
-	m_certificatePath = other.m_certificatePath;
-	m_certificatePassword = other.m_certificatePassword;
 	m_isPortAuthorized = other.m_isPortAuthorized;
 	m_quickConnectAvailable = other.m_quickConnectAvailable;
-	m_enableRemoteAccess = other.m_enableRemoteAccess;
 	m_enableCaseSensitiveItemIds = other.m_enableCaseSensitiveItemIds;
 	m_disableLiveTvChannelUserDataName = other.m_disableLiveTvChannelUserDataName;
 	m_metadataPath = other.m_metadataPath;
-	m_metadataNetworkPath = other.m_metadataNetworkPath;
 	m_preferredMetadataLanguage = other.m_preferredMetadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
 	m_sortReplaceCharacters = other.m_sortReplaceCharacters;
@@ -285,13 +219,13 @@ void ServerConfiguration::replaceData(ServerConfiguration &other) {
 	m_minResumeDurationSeconds = other.m_minResumeDurationSeconds;
 	m_minAudiobookResume = other.m_minAudiobookResume;
 	m_maxAudiobookResume = other.m_maxAudiobookResume;
+	m_inactiveSessionThreshold = other.m_inactiveSessionThreshold;
 	m_libraryMonitorDelay = other.m_libraryMonitorDelay;
-	m_enableDashboardResponseCaching = other.m_enableDashboardResponseCaching;
+	m_libraryUpdateDuration = other.m_libraryUpdateDuration;
 	m_imageSavingConvention = other.m_imageSavingConvention;
 	m_metadataOptions = other.m_metadataOptions;
 	m_skipDeserializationForBasicTypes = other.m_skipDeserializationForBasicTypes;
 	m_serverName = other.m_serverName;
-	m_baseUrl = other.m_baseUrl;
 	m_uICulture = other.m_uICulture;
 	m_saveMetadataHidden = other.m_saveMetadataHidden;
 	m_contentTypes = other.m_contentTypes;
@@ -299,28 +233,24 @@ void ServerConfiguration::replaceData(ServerConfiguration &other) {
 	m_enableFolderView = other.m_enableFolderView;
 	m_enableGroupingIntoCollections = other.m_enableGroupingIntoCollections;
 	m_displaySpecialsWithinSeasons = other.m_displaySpecialsWithinSeasons;
-	m_localNetworkSubnets = other.m_localNetworkSubnets;
-	m_localNetworkAddresses = other.m_localNetworkAddresses;
 	m_codecsUsed = other.m_codecsUsed;
 	m_pluginRepositories = other.m_pluginRepositories;
 	m_enableExternalContentInSuggestions = other.m_enableExternalContentInSuggestions;
-	m_requireHttps = other.m_requireHttps;
-	m_enableNewOmdbSupport = other.m_enableNewOmdbSupport;
-	m_remoteIPFilter = other.m_remoteIPFilter;
-	m_isRemoteIPFilterBlacklist = other.m_isRemoteIPFilterBlacklist;
 	m_imageExtractionTimeoutMs = other.m_imageExtractionTimeoutMs;
 	m_pathSubstitutions = other.m_pathSubstitutions;
-	m_enableSimpleArtistDetection = other.m_enableSimpleArtistDetection;
-	m_uninstalledPlugins = other.m_uninstalledPlugins;
 	m_enableSlowResponseWarning = other.m_enableSlowResponseWarning;
 	m_slowResponseThresholdMs = other.m_slowResponseThresholdMs;
 	m_corsHosts = other.m_corsHosts;
-	m_knownProxies = other.m_knownProxies;
 	m_activityLogRetentionDays = other.m_activityLogRetentionDays;
 	m_libraryScanFanoutConcurrency = other.m_libraryScanFanoutConcurrency;
 	m_libraryMetadataRefreshConcurrency = other.m_libraryMetadataRefreshConcurrency;
 	m_removeOldPlugins = other.m_removeOldPlugins;
-	m_disablePluginImages = other.m_disablePluginImages;
+	m_allowClientLogUpload = other.m_allowClientLogUpload;
+	m_dummyChapterDuration = other.m_dummyChapterDuration;
+	m_chapterImageResolution = other.m_chapterImageResolution;
+	m_parallelImageEncodingLimit = other.m_parallelImageEncodingLimit;
+	m_castReceiverApplications = other.m_castReceiverApplications;
+	m_trickplayOptions = other.m_trickplayOptions;
 }
 
 ServerConfiguration ServerConfiguration::fromJson(QJsonObject source) {
@@ -334,42 +264,15 @@ void ServerConfiguration::setFromJson(QJsonObject source) {
 	m_logFileRetentionDays = Jellyfin::Support::fromJsonValue<qint32>(source["LogFileRetentionDays"]);
 	m_isStartupWizardCompleted = Jellyfin::Support::fromJsonValue<bool>(source["IsStartupWizardCompleted"]);
 	m_cachePath = Jellyfin::Support::fromJsonValue<QString>(source["CachePath"]);
-	m_previousVersion = Jellyfin::Support::fromJsonValue<QSharedPointer<Version>>(source["PreviousVersion"]);
+	m_previousVersion = Jellyfin::Support::fromJsonValue<QString>(source["PreviousVersion"]);
 	m_previousVersionStr = Jellyfin::Support::fromJsonValue<QString>(source["PreviousVersionStr"]);
-	m_enableUPnP = Jellyfin::Support::fromJsonValue<bool>(source["EnableUPnP"]);
 	m_enableMetrics = Jellyfin::Support::fromJsonValue<bool>(source["EnableMetrics"]);
-	m_publicPort = Jellyfin::Support::fromJsonValue<qint32>(source["PublicPort"]);
-	m_uPnPCreateHttpPortMap = Jellyfin::Support::fromJsonValue<bool>(source["UPnPCreateHttpPortMap"]);
-	m_uDPPortRange = Jellyfin::Support::fromJsonValue<QString>(source["UDPPortRange"]);
-	m_enableIPV6 = Jellyfin::Support::fromJsonValue<bool>(source["EnableIPV6"]);
-	m_enableIPV4 = Jellyfin::Support::fromJsonValue<bool>(source["EnableIPV4"]);
-	m_enableSSDPTracing = Jellyfin::Support::fromJsonValue<bool>(source["EnableSSDPTracing"]);
-	m_sSDPTracingFilter = Jellyfin::Support::fromJsonValue<QString>(source["SSDPTracingFilter"]);
-	m_uDPSendCount = Jellyfin::Support::fromJsonValue<qint32>(source["UDPSendCount"]);
-	m_uDPSendDelay = Jellyfin::Support::fromJsonValue<qint32>(source["UDPSendDelay"]);
-	m_ignoreVirtualInterfaces = Jellyfin::Support::fromJsonValue<bool>(source["IgnoreVirtualInterfaces"]);
-	m_virtualInterfaceNames = Jellyfin::Support::fromJsonValue<QString>(source["VirtualInterfaceNames"]);
-	m_gatewayMonitorPeriod = Jellyfin::Support::fromJsonValue<qint32>(source["GatewayMonitorPeriod"]);
-	m_enableMultiSocketBinding = Jellyfin::Support::fromJsonValue<bool>(source["EnableMultiSocketBinding"]);
-	m_trustAllIP6Interfaces = Jellyfin::Support::fromJsonValue<bool>(source["TrustAllIP6Interfaces"]);
-	m_hDHomerunPortRange = Jellyfin::Support::fromJsonValue<QString>(source["HDHomerunPortRange"]);
-	m_publishedServerUriBySubnet = Jellyfin::Support::fromJsonValue<QStringList>(source["PublishedServerUriBySubnet"]);
-	m_autoDiscoveryTracing = Jellyfin::Support::fromJsonValue<bool>(source["AutoDiscoveryTracing"]);
-	m_autoDiscovery = Jellyfin::Support::fromJsonValue<bool>(source["AutoDiscovery"]);
-	m_publicHttpsPort = Jellyfin::Support::fromJsonValue<qint32>(source["PublicHttpsPort"]);
-	m_httpServerPortNumber = Jellyfin::Support::fromJsonValue<qint32>(source["HttpServerPortNumber"]);
-	m_httpsPortNumber = Jellyfin::Support::fromJsonValue<qint32>(source["HttpsPortNumber"]);
-	m_enableHttps = Jellyfin::Support::fromJsonValue<bool>(source["EnableHttps"]);
 	m_enableNormalizedItemByNameIds = Jellyfin::Support::fromJsonValue<bool>(source["EnableNormalizedItemByNameIds"]);
-	m_certificatePath = Jellyfin::Support::fromJsonValue<QString>(source["CertificatePath"]);
-	m_certificatePassword = Jellyfin::Support::fromJsonValue<QString>(source["CertificatePassword"]);
 	m_isPortAuthorized = Jellyfin::Support::fromJsonValue<bool>(source["IsPortAuthorized"]);
 	m_quickConnectAvailable = Jellyfin::Support::fromJsonValue<bool>(source["QuickConnectAvailable"]);
-	m_enableRemoteAccess = Jellyfin::Support::fromJsonValue<bool>(source["EnableRemoteAccess"]);
 	m_enableCaseSensitiveItemIds = Jellyfin::Support::fromJsonValue<bool>(source["EnableCaseSensitiveItemIds"]);
 	m_disableLiveTvChannelUserDataName = Jellyfin::Support::fromJsonValue<bool>(source["DisableLiveTvChannelUserDataName"]);
 	m_metadataPath = Jellyfin::Support::fromJsonValue<QString>(source["MetadataPath"]);
-	m_metadataNetworkPath = Jellyfin::Support::fromJsonValue<QString>(source["MetadataNetworkPath"]);
 	m_preferredMetadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["PreferredMetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
 	m_sortReplaceCharacters = Jellyfin::Support::fromJsonValue<QStringList>(source["SortReplaceCharacters"]);
@@ -380,13 +283,13 @@ void ServerConfiguration::setFromJson(QJsonObject source) {
 	m_minResumeDurationSeconds = Jellyfin::Support::fromJsonValue<qint32>(source["MinResumeDurationSeconds"]);
 	m_minAudiobookResume = Jellyfin::Support::fromJsonValue<qint32>(source["MinAudiobookResume"]);
 	m_maxAudiobookResume = Jellyfin::Support::fromJsonValue<qint32>(source["MaxAudiobookResume"]);
+	m_inactiveSessionThreshold = Jellyfin::Support::fromJsonValue<qint32>(source["InactiveSessionThreshold"]);
 	m_libraryMonitorDelay = Jellyfin::Support::fromJsonValue<qint32>(source["LibraryMonitorDelay"]);
-	m_enableDashboardResponseCaching = Jellyfin::Support::fromJsonValue<bool>(source["EnableDashboardResponseCaching"]);
+	m_libraryUpdateDuration = Jellyfin::Support::fromJsonValue<qint32>(source["LibraryUpdateDuration"]);
 	m_imageSavingConvention = Jellyfin::Support::fromJsonValue<ImageSavingConvention>(source["ImageSavingConvention"]);
 	m_metadataOptions = Jellyfin::Support::fromJsonValue<QList<MetadataOptions>>(source["MetadataOptions"]);
 	m_skipDeserializationForBasicTypes = Jellyfin::Support::fromJsonValue<bool>(source["SkipDeserializationForBasicTypes"]);
 	m_serverName = Jellyfin::Support::fromJsonValue<QString>(source["ServerName"]);
-	m_baseUrl = Jellyfin::Support::fromJsonValue<QString>(source["BaseUrl"]);
 	m_uICulture = Jellyfin::Support::fromJsonValue<QString>(source["UICulture"]);
 	m_saveMetadataHidden = Jellyfin::Support::fromJsonValue<bool>(source["SaveMetadataHidden"]);
 	m_contentTypes = Jellyfin::Support::fromJsonValue<QList<NameValuePair>>(source["ContentTypes"]);
@@ -394,28 +297,24 @@ void ServerConfiguration::setFromJson(QJsonObject source) {
 	m_enableFolderView = Jellyfin::Support::fromJsonValue<bool>(source["EnableFolderView"]);
 	m_enableGroupingIntoCollections = Jellyfin::Support::fromJsonValue<bool>(source["EnableGroupingIntoCollections"]);
 	m_displaySpecialsWithinSeasons = Jellyfin::Support::fromJsonValue<bool>(source["DisplaySpecialsWithinSeasons"]);
-	m_localNetworkSubnets = Jellyfin::Support::fromJsonValue<QStringList>(source["LocalNetworkSubnets"]);
-	m_localNetworkAddresses = Jellyfin::Support::fromJsonValue<QStringList>(source["LocalNetworkAddresses"]);
 	m_codecsUsed = Jellyfin::Support::fromJsonValue<QStringList>(source["CodecsUsed"]);
 	m_pluginRepositories = Jellyfin::Support::fromJsonValue<QList<RepositoryInfo>>(source["PluginRepositories"]);
 	m_enableExternalContentInSuggestions = Jellyfin::Support::fromJsonValue<bool>(source["EnableExternalContentInSuggestions"]);
-	m_requireHttps = Jellyfin::Support::fromJsonValue<bool>(source["RequireHttps"]);
-	m_enableNewOmdbSupport = Jellyfin::Support::fromJsonValue<bool>(source["EnableNewOmdbSupport"]);
-	m_remoteIPFilter = Jellyfin::Support::fromJsonValue<QStringList>(source["RemoteIPFilter"]);
-	m_isRemoteIPFilterBlacklist = Jellyfin::Support::fromJsonValue<bool>(source["IsRemoteIPFilterBlacklist"]);
 	m_imageExtractionTimeoutMs = Jellyfin::Support::fromJsonValue<qint32>(source["ImageExtractionTimeoutMs"]);
 	m_pathSubstitutions = Jellyfin::Support::fromJsonValue<QList<PathSubstitution>>(source["PathSubstitutions"]);
-	m_enableSimpleArtistDetection = Jellyfin::Support::fromJsonValue<bool>(source["EnableSimpleArtistDetection"]);
-	m_uninstalledPlugins = Jellyfin::Support::fromJsonValue<QStringList>(source["UninstalledPlugins"]);
 	m_enableSlowResponseWarning = Jellyfin::Support::fromJsonValue<bool>(source["EnableSlowResponseWarning"]);
 	m_slowResponseThresholdMs = Jellyfin::Support::fromJsonValue<qint64>(source["SlowResponseThresholdMs"]);
 	m_corsHosts = Jellyfin::Support::fromJsonValue<QStringList>(source["CorsHosts"]);
-	m_knownProxies = Jellyfin::Support::fromJsonValue<QStringList>(source["KnownProxies"]);
 	m_activityLogRetentionDays = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["ActivityLogRetentionDays"]);
 	m_libraryScanFanoutConcurrency = Jellyfin::Support::fromJsonValue<qint32>(source["LibraryScanFanoutConcurrency"]);
 	m_libraryMetadataRefreshConcurrency = Jellyfin::Support::fromJsonValue<qint32>(source["LibraryMetadataRefreshConcurrency"]);
 	m_removeOldPlugins = Jellyfin::Support::fromJsonValue<bool>(source["RemoveOldPlugins"]);
-	m_disablePluginImages = Jellyfin::Support::fromJsonValue<bool>(source["DisablePluginImages"]);
+	m_allowClientLogUpload = Jellyfin::Support::fromJsonValue<bool>(source["AllowClientLogUpload"]);
+	m_dummyChapterDuration = Jellyfin::Support::fromJsonValue<qint32>(source["DummyChapterDuration"]);
+	m_chapterImageResolution = Jellyfin::Support::fromJsonValue<ImageResolution>(source["ChapterImageResolution"]);
+	m_parallelImageEncodingLimit = Jellyfin::Support::fromJsonValue<qint32>(source["ParallelImageEncodingLimit"]);
+	m_castReceiverApplications = Jellyfin::Support::fromJsonValue<QList<CastReceiverApplication>>(source["CastReceiverApplications"]);
+	m_trickplayOptions = Jellyfin::Support::fromJsonValue<QSharedPointer<TrickplayOptions>>(source["TrickplayOptions"]);
 
 }
 	
@@ -429,199 +328,55 @@ QJsonObject ServerConfiguration::toJson() const {
 		result["CachePath"] = Jellyfin::Support::toJsonValue<QString>(m_cachePath);
 	}
 			
-	result["PreviousVersion"] = Jellyfin::Support::toJsonValue<QSharedPointer<Version>>(m_previousVersion);		
+	
+	if (!(m_previousVersion.isNull())) {
+		result["PreviousVersion"] = Jellyfin::Support::toJsonValue<QString>(m_previousVersion);
+	}
+			
 	
 	if (!(m_previousVersionStr.isNull())) {
 		result["PreviousVersionStr"] = Jellyfin::Support::toJsonValue<QString>(m_previousVersionStr);
 	}
 			
-	result["EnableUPnP"] = Jellyfin::Support::toJsonValue<bool>(m_enableUPnP);		
 	result["EnableMetrics"] = Jellyfin::Support::toJsonValue<bool>(m_enableMetrics);		
-	result["PublicPort"] = Jellyfin::Support::toJsonValue<qint32>(m_publicPort);		
-	result["UPnPCreateHttpPortMap"] = Jellyfin::Support::toJsonValue<bool>(m_uPnPCreateHttpPortMap);		
-	
-	if (!(m_uDPPortRange.isNull())) {
-		result["UDPPortRange"] = Jellyfin::Support::toJsonValue<QString>(m_uDPPortRange);
-	}
-			
-	result["EnableIPV6"] = Jellyfin::Support::toJsonValue<bool>(m_enableIPV6);		
-	result["EnableIPV4"] = Jellyfin::Support::toJsonValue<bool>(m_enableIPV4);		
-	result["EnableSSDPTracing"] = Jellyfin::Support::toJsonValue<bool>(m_enableSSDPTracing);		
-	
-	if (!(m_sSDPTracingFilter.isNull())) {
-		result["SSDPTracingFilter"] = Jellyfin::Support::toJsonValue<QString>(m_sSDPTracingFilter);
-	}
-			
-	result["UDPSendCount"] = Jellyfin::Support::toJsonValue<qint32>(m_uDPSendCount);		
-	result["UDPSendDelay"] = Jellyfin::Support::toJsonValue<qint32>(m_uDPSendDelay);		
-	result["IgnoreVirtualInterfaces"] = Jellyfin::Support::toJsonValue<bool>(m_ignoreVirtualInterfaces);		
-	
-	if (!(m_virtualInterfaceNames.isNull())) {
-		result["VirtualInterfaceNames"] = Jellyfin::Support::toJsonValue<QString>(m_virtualInterfaceNames);
-	}
-			
-	result["GatewayMonitorPeriod"] = Jellyfin::Support::toJsonValue<qint32>(m_gatewayMonitorPeriod);		
-	result["EnableMultiSocketBinding"] = Jellyfin::Support::toJsonValue<bool>(m_enableMultiSocketBinding);		
-	result["TrustAllIP6Interfaces"] = Jellyfin::Support::toJsonValue<bool>(m_trustAllIP6Interfaces);		
-	
-	if (!(m_hDHomerunPortRange.isNull())) {
-		result["HDHomerunPortRange"] = Jellyfin::Support::toJsonValue<QString>(m_hDHomerunPortRange);
-	}
-			
-	
-	if (!(m_publishedServerUriBySubnet.size() == 0)) {
-		result["PublishedServerUriBySubnet"] = Jellyfin::Support::toJsonValue<QStringList>(m_publishedServerUriBySubnet);
-	}
-			
-	result["AutoDiscoveryTracing"] = Jellyfin::Support::toJsonValue<bool>(m_autoDiscoveryTracing);		
-	result["AutoDiscovery"] = Jellyfin::Support::toJsonValue<bool>(m_autoDiscovery);		
-	result["PublicHttpsPort"] = Jellyfin::Support::toJsonValue<qint32>(m_publicHttpsPort);		
-	result["HttpServerPortNumber"] = Jellyfin::Support::toJsonValue<qint32>(m_httpServerPortNumber);		
-	result["HttpsPortNumber"] = Jellyfin::Support::toJsonValue<qint32>(m_httpsPortNumber);		
-	result["EnableHttps"] = Jellyfin::Support::toJsonValue<bool>(m_enableHttps);		
 	result["EnableNormalizedItemByNameIds"] = Jellyfin::Support::toJsonValue<bool>(m_enableNormalizedItemByNameIds);		
-	
-	if (!(m_certificatePath.isNull())) {
-		result["CertificatePath"] = Jellyfin::Support::toJsonValue<QString>(m_certificatePath);
-	}
-			
-	
-	if (!(m_certificatePassword.isNull())) {
-		result["CertificatePassword"] = Jellyfin::Support::toJsonValue<QString>(m_certificatePassword);
-	}
-			
 	result["IsPortAuthorized"] = Jellyfin::Support::toJsonValue<bool>(m_isPortAuthorized);		
 	result["QuickConnectAvailable"] = Jellyfin::Support::toJsonValue<bool>(m_quickConnectAvailable);		
-	result["EnableRemoteAccess"] = Jellyfin::Support::toJsonValue<bool>(m_enableRemoteAccess);		
 	result["EnableCaseSensitiveItemIds"] = Jellyfin::Support::toJsonValue<bool>(m_enableCaseSensitiveItemIds);		
 	result["DisableLiveTvChannelUserDataName"] = Jellyfin::Support::toJsonValue<bool>(m_disableLiveTvChannelUserDataName);		
-	
-	if (!(m_metadataPath.isNull())) {
-		result["MetadataPath"] = Jellyfin::Support::toJsonValue<QString>(m_metadataPath);
-	}
-			
-	
-	if (!(m_metadataNetworkPath.isNull())) {
-		result["MetadataNetworkPath"] = Jellyfin::Support::toJsonValue<QString>(m_metadataNetworkPath);
-	}
-			
-	
-	if (!(m_preferredMetadataLanguage.isNull())) {
-		result["PreferredMetadataLanguage"] = Jellyfin::Support::toJsonValue<QString>(m_preferredMetadataLanguage);
-	}
-			
-	
-	if (!(m_metadataCountryCode.isNull())) {
-		result["MetadataCountryCode"] = Jellyfin::Support::toJsonValue<QString>(m_metadataCountryCode);
-	}
-			
-	
-	if (!(m_sortReplaceCharacters.size() == 0)) {
-		result["SortReplaceCharacters"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortReplaceCharacters);
-	}
-			
-	
-	if (!(m_sortRemoveCharacters.size() == 0)) {
-		result["SortRemoveCharacters"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortRemoveCharacters);
-	}
-			
-	
-	if (!(m_sortRemoveWords.size() == 0)) {
-		result["SortRemoveWords"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortRemoveWords);
-	}
-			
+	result["MetadataPath"] = Jellyfin::Support::toJsonValue<QString>(m_metadataPath);		
+	result["PreferredMetadataLanguage"] = Jellyfin::Support::toJsonValue<QString>(m_preferredMetadataLanguage);		
+	result["MetadataCountryCode"] = Jellyfin::Support::toJsonValue<QString>(m_metadataCountryCode);		
+	result["SortReplaceCharacters"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortReplaceCharacters);		
+	result["SortRemoveCharacters"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortRemoveCharacters);		
+	result["SortRemoveWords"] = Jellyfin::Support::toJsonValue<QStringList>(m_sortRemoveWords);		
 	result["MinResumePct"] = Jellyfin::Support::toJsonValue<qint32>(m_minResumePct);		
 	result["MaxResumePct"] = Jellyfin::Support::toJsonValue<qint32>(m_maxResumePct);		
 	result["MinResumeDurationSeconds"] = Jellyfin::Support::toJsonValue<qint32>(m_minResumeDurationSeconds);		
 	result["MinAudiobookResume"] = Jellyfin::Support::toJsonValue<qint32>(m_minAudiobookResume);		
 	result["MaxAudiobookResume"] = Jellyfin::Support::toJsonValue<qint32>(m_maxAudiobookResume);		
+	result["InactiveSessionThreshold"] = Jellyfin::Support::toJsonValue<qint32>(m_inactiveSessionThreshold);		
 	result["LibraryMonitorDelay"] = Jellyfin::Support::toJsonValue<qint32>(m_libraryMonitorDelay);		
-	result["EnableDashboardResponseCaching"] = Jellyfin::Support::toJsonValue<bool>(m_enableDashboardResponseCaching);		
+	result["LibraryUpdateDuration"] = Jellyfin::Support::toJsonValue<qint32>(m_libraryUpdateDuration);		
 	result["ImageSavingConvention"] = Jellyfin::Support::toJsonValue<ImageSavingConvention>(m_imageSavingConvention);		
-	
-	if (!(m_metadataOptions.size() == 0)) {
-		result["MetadataOptions"] = Jellyfin::Support::toJsonValue<QList<MetadataOptions>>(m_metadataOptions);
-	}
-			
+	result["MetadataOptions"] = Jellyfin::Support::toJsonValue<QList<MetadataOptions>>(m_metadataOptions);		
 	result["SkipDeserializationForBasicTypes"] = Jellyfin::Support::toJsonValue<bool>(m_skipDeserializationForBasicTypes);		
-	
-	if (!(m_serverName.isNull())) {
-		result["ServerName"] = Jellyfin::Support::toJsonValue<QString>(m_serverName);
-	}
-			
-	
-	if (!(m_baseUrl.isNull())) {
-		result["BaseUrl"] = Jellyfin::Support::toJsonValue<QString>(m_baseUrl);
-	}
-			
-	
-	if (!(m_uICulture.isNull())) {
-		result["UICulture"] = Jellyfin::Support::toJsonValue<QString>(m_uICulture);
-	}
-			
+	result["ServerName"] = Jellyfin::Support::toJsonValue<QString>(m_serverName);		
+	result["UICulture"] = Jellyfin::Support::toJsonValue<QString>(m_uICulture);		
 	result["SaveMetadataHidden"] = Jellyfin::Support::toJsonValue<bool>(m_saveMetadataHidden);		
-	
-	if (!(m_contentTypes.size() == 0)) {
-		result["ContentTypes"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_contentTypes);
-	}
-			
+	result["ContentTypes"] = Jellyfin::Support::toJsonValue<QList<NameValuePair>>(m_contentTypes);		
 	result["RemoteClientBitrateLimit"] = Jellyfin::Support::toJsonValue<qint32>(m_remoteClientBitrateLimit);		
 	result["EnableFolderView"] = Jellyfin::Support::toJsonValue<bool>(m_enableFolderView);		
 	result["EnableGroupingIntoCollections"] = Jellyfin::Support::toJsonValue<bool>(m_enableGroupingIntoCollections);		
 	result["DisplaySpecialsWithinSeasons"] = Jellyfin::Support::toJsonValue<bool>(m_displaySpecialsWithinSeasons);		
-	
-	if (!(m_localNetworkSubnets.size() == 0)) {
-		result["LocalNetworkSubnets"] = Jellyfin::Support::toJsonValue<QStringList>(m_localNetworkSubnets);
-	}
-			
-	
-	if (!(m_localNetworkAddresses.size() == 0)) {
-		result["LocalNetworkAddresses"] = Jellyfin::Support::toJsonValue<QStringList>(m_localNetworkAddresses);
-	}
-			
-	
-	if (!(m_codecsUsed.size() == 0)) {
-		result["CodecsUsed"] = Jellyfin::Support::toJsonValue<QStringList>(m_codecsUsed);
-	}
-			
-	
-	if (!(m_pluginRepositories.size() == 0)) {
-		result["PluginRepositories"] = Jellyfin::Support::toJsonValue<QList<RepositoryInfo>>(m_pluginRepositories);
-	}
-			
+	result["CodecsUsed"] = Jellyfin::Support::toJsonValue<QStringList>(m_codecsUsed);		
+	result["PluginRepositories"] = Jellyfin::Support::toJsonValue<QList<RepositoryInfo>>(m_pluginRepositories);		
 	result["EnableExternalContentInSuggestions"] = Jellyfin::Support::toJsonValue<bool>(m_enableExternalContentInSuggestions);		
-	result["RequireHttps"] = Jellyfin::Support::toJsonValue<bool>(m_requireHttps);		
-	result["EnableNewOmdbSupport"] = Jellyfin::Support::toJsonValue<bool>(m_enableNewOmdbSupport);		
-	
-	if (!(m_remoteIPFilter.size() == 0)) {
-		result["RemoteIPFilter"] = Jellyfin::Support::toJsonValue<QStringList>(m_remoteIPFilter);
-	}
-			
-	result["IsRemoteIPFilterBlacklist"] = Jellyfin::Support::toJsonValue<bool>(m_isRemoteIPFilterBlacklist);		
 	result["ImageExtractionTimeoutMs"] = Jellyfin::Support::toJsonValue<qint32>(m_imageExtractionTimeoutMs);		
-	
-	if (!(m_pathSubstitutions.size() == 0)) {
-		result["PathSubstitutions"] = Jellyfin::Support::toJsonValue<QList<PathSubstitution>>(m_pathSubstitutions);
-	}
-			
-	result["EnableSimpleArtistDetection"] = Jellyfin::Support::toJsonValue<bool>(m_enableSimpleArtistDetection);		
-	
-	if (!(m_uninstalledPlugins.size() == 0)) {
-		result["UninstalledPlugins"] = Jellyfin::Support::toJsonValue<QStringList>(m_uninstalledPlugins);
-	}
-			
+	result["PathSubstitutions"] = Jellyfin::Support::toJsonValue<QList<PathSubstitution>>(m_pathSubstitutions);		
 	result["EnableSlowResponseWarning"] = Jellyfin::Support::toJsonValue<bool>(m_enableSlowResponseWarning);		
 	result["SlowResponseThresholdMs"] = Jellyfin::Support::toJsonValue<qint64>(m_slowResponseThresholdMs);		
-	
-	if (!(m_corsHosts.size() == 0)) {
-		result["CorsHosts"] = Jellyfin::Support::toJsonValue<QStringList>(m_corsHosts);
-	}
-			
-	
-	if (!(m_knownProxies.size() == 0)) {
-		result["KnownProxies"] = Jellyfin::Support::toJsonValue<QStringList>(m_knownProxies);
-	}
-			
+	result["CorsHosts"] = Jellyfin::Support::toJsonValue<QStringList>(m_corsHosts);		
 	
 	if (!(!m_activityLogRetentionDays.has_value())) {
 		result["ActivityLogRetentionDays"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_activityLogRetentionDays);
@@ -630,7 +385,12 @@ QJsonObject ServerConfiguration::toJson() const {
 	result["LibraryScanFanoutConcurrency"] = Jellyfin::Support::toJsonValue<qint32>(m_libraryScanFanoutConcurrency);		
 	result["LibraryMetadataRefreshConcurrency"] = Jellyfin::Support::toJsonValue<qint32>(m_libraryMetadataRefreshConcurrency);		
 	result["RemoveOldPlugins"] = Jellyfin::Support::toJsonValue<bool>(m_removeOldPlugins);		
-	result["DisablePluginImages"] = Jellyfin::Support::toJsonValue<bool>(m_disablePluginImages);	
+	result["AllowClientLogUpload"] = Jellyfin::Support::toJsonValue<bool>(m_allowClientLogUpload);		
+	result["DummyChapterDuration"] = Jellyfin::Support::toJsonValue<qint32>(m_dummyChapterDuration);		
+	result["ChapterImageResolution"] = Jellyfin::Support::toJsonValue<ImageResolution>(m_chapterImageResolution);		
+	result["ParallelImageEncodingLimit"] = Jellyfin::Support::toJsonValue<qint32>(m_parallelImageEncodingLimit);		
+	result["CastReceiverApplications"] = Jellyfin::Support::toJsonValue<QList<CastReceiverApplication>>(m_castReceiverApplications);		
+	result["TrickplayOptions"] = Jellyfin::Support::toJsonValue<QSharedPointer<TrickplayOptions>>(m_trickplayOptions);	
 	return result;
 }
 
@@ -659,12 +419,19 @@ void ServerConfiguration::setCachePathNull() {
 	m_cachePath.clear();
 
 }
-QSharedPointer<Version> ServerConfiguration::previousVersion() const { return m_previousVersion; }
+QString ServerConfiguration::previousVersion() const { return m_previousVersion; }
 
-void ServerConfiguration::setPreviousVersion(QSharedPointer<Version> newPreviousVersion) {
+void ServerConfiguration::setPreviousVersion(QString newPreviousVersion) {
 	m_previousVersion = newPreviousVersion;
 }
+bool ServerConfiguration::previousVersionNull() const {
+	return m_previousVersion.isNull();
+}
 
+void ServerConfiguration::setPreviousVersionNull() {
+	m_previousVersion.clear();
+
+}
 QString ServerConfiguration::previousVersionStr() const { return m_previousVersionStr; }
 
 void ServerConfiguration::setPreviousVersionStr(QString newPreviousVersionStr) {
@@ -678,217 +445,18 @@ void ServerConfiguration::setPreviousVersionStrNull() {
 	m_previousVersionStr.clear();
 
 }
-bool ServerConfiguration::enableUPnP() const { return m_enableUPnP; }
-
-void ServerConfiguration::setEnableUPnP(bool newEnableUPnP) {
-	m_enableUPnP = newEnableUPnP;
-}
-
 bool ServerConfiguration::enableMetrics() const { return m_enableMetrics; }
 
 void ServerConfiguration::setEnableMetrics(bool newEnableMetrics) {
 	m_enableMetrics = newEnableMetrics;
 }
 
-qint32 ServerConfiguration::publicPort() const { return m_publicPort; }
-
-void ServerConfiguration::setPublicPort(qint32 newPublicPort) {
-	m_publicPort = newPublicPort;
-}
-
-bool ServerConfiguration::uPnPCreateHttpPortMap() const { return m_uPnPCreateHttpPortMap; }
-
-void ServerConfiguration::setUPnPCreateHttpPortMap(bool newUPnPCreateHttpPortMap) {
-	m_uPnPCreateHttpPortMap = newUPnPCreateHttpPortMap;
-}
-
-QString ServerConfiguration::uDPPortRange() const { return m_uDPPortRange; }
-
-void ServerConfiguration::setUDPPortRange(QString newUDPPortRange) {
-	m_uDPPortRange = newUDPPortRange;
-}
-bool ServerConfiguration::uDPPortRangeNull() const {
-	return m_uDPPortRange.isNull();
-}
-
-void ServerConfiguration::setUDPPortRangeNull() {
-	m_uDPPortRange.clear();
-
-}
-bool ServerConfiguration::enableIPV6() const { return m_enableIPV6; }
-
-void ServerConfiguration::setEnableIPV6(bool newEnableIPV6) {
-	m_enableIPV6 = newEnableIPV6;
-}
-
-bool ServerConfiguration::enableIPV4() const { return m_enableIPV4; }
-
-void ServerConfiguration::setEnableIPV4(bool newEnableIPV4) {
-	m_enableIPV4 = newEnableIPV4;
-}
-
-bool ServerConfiguration::enableSSDPTracing() const { return m_enableSSDPTracing; }
-
-void ServerConfiguration::setEnableSSDPTracing(bool newEnableSSDPTracing) {
-	m_enableSSDPTracing = newEnableSSDPTracing;
-}
-
-QString ServerConfiguration::sSDPTracingFilter() const { return m_sSDPTracingFilter; }
-
-void ServerConfiguration::setSSDPTracingFilter(QString newSSDPTracingFilter) {
-	m_sSDPTracingFilter = newSSDPTracingFilter;
-}
-bool ServerConfiguration::sSDPTracingFilterNull() const {
-	return m_sSDPTracingFilter.isNull();
-}
-
-void ServerConfiguration::setSSDPTracingFilterNull() {
-	m_sSDPTracingFilter.clear();
-
-}
-qint32 ServerConfiguration::uDPSendCount() const { return m_uDPSendCount; }
-
-void ServerConfiguration::setUDPSendCount(qint32 newUDPSendCount) {
-	m_uDPSendCount = newUDPSendCount;
-}
-
-qint32 ServerConfiguration::uDPSendDelay() const { return m_uDPSendDelay; }
-
-void ServerConfiguration::setUDPSendDelay(qint32 newUDPSendDelay) {
-	m_uDPSendDelay = newUDPSendDelay;
-}
-
-bool ServerConfiguration::ignoreVirtualInterfaces() const { return m_ignoreVirtualInterfaces; }
-
-void ServerConfiguration::setIgnoreVirtualInterfaces(bool newIgnoreVirtualInterfaces) {
-	m_ignoreVirtualInterfaces = newIgnoreVirtualInterfaces;
-}
-
-QString ServerConfiguration::virtualInterfaceNames() const { return m_virtualInterfaceNames; }
-
-void ServerConfiguration::setVirtualInterfaceNames(QString newVirtualInterfaceNames) {
-	m_virtualInterfaceNames = newVirtualInterfaceNames;
-}
-bool ServerConfiguration::virtualInterfaceNamesNull() const {
-	return m_virtualInterfaceNames.isNull();
-}
-
-void ServerConfiguration::setVirtualInterfaceNamesNull() {
-	m_virtualInterfaceNames.clear();
-
-}
-qint32 ServerConfiguration::gatewayMonitorPeriod() const { return m_gatewayMonitorPeriod; }
-
-void ServerConfiguration::setGatewayMonitorPeriod(qint32 newGatewayMonitorPeriod) {
-	m_gatewayMonitorPeriod = newGatewayMonitorPeriod;
-}
-
-bool ServerConfiguration::enableMultiSocketBinding() const { return m_enableMultiSocketBinding; }
-
-void ServerConfiguration::setEnableMultiSocketBinding(bool newEnableMultiSocketBinding) {
-	m_enableMultiSocketBinding = newEnableMultiSocketBinding;
-}
-
-bool ServerConfiguration::trustAllIP6Interfaces() const { return m_trustAllIP6Interfaces; }
-
-void ServerConfiguration::setTrustAllIP6Interfaces(bool newTrustAllIP6Interfaces) {
-	m_trustAllIP6Interfaces = newTrustAllIP6Interfaces;
-}
-
-QString ServerConfiguration::hDHomerunPortRange() const { return m_hDHomerunPortRange; }
-
-void ServerConfiguration::setHDHomerunPortRange(QString newHDHomerunPortRange) {
-	m_hDHomerunPortRange = newHDHomerunPortRange;
-}
-bool ServerConfiguration::hDHomerunPortRangeNull() const {
-	return m_hDHomerunPortRange.isNull();
-}
-
-void ServerConfiguration::setHDHomerunPortRangeNull() {
-	m_hDHomerunPortRange.clear();
-
-}
-QStringList ServerConfiguration::publishedServerUriBySubnet() const { return m_publishedServerUriBySubnet; }
-
-void ServerConfiguration::setPublishedServerUriBySubnet(QStringList newPublishedServerUriBySubnet) {
-	m_publishedServerUriBySubnet = newPublishedServerUriBySubnet;
-}
-bool ServerConfiguration::publishedServerUriBySubnetNull() const {
-	return m_publishedServerUriBySubnet.size() == 0;
-}
-
-void ServerConfiguration::setPublishedServerUriBySubnetNull() {
-	m_publishedServerUriBySubnet.clear();
-
-}
-bool ServerConfiguration::autoDiscoveryTracing() const { return m_autoDiscoveryTracing; }
-
-void ServerConfiguration::setAutoDiscoveryTracing(bool newAutoDiscoveryTracing) {
-	m_autoDiscoveryTracing = newAutoDiscoveryTracing;
-}
-
-bool ServerConfiguration::autoDiscovery() const { return m_autoDiscovery; }
-
-void ServerConfiguration::setAutoDiscovery(bool newAutoDiscovery) {
-	m_autoDiscovery = newAutoDiscovery;
-}
-
-qint32 ServerConfiguration::publicHttpsPort() const { return m_publicHttpsPort; }
-
-void ServerConfiguration::setPublicHttpsPort(qint32 newPublicHttpsPort) {
-	m_publicHttpsPort = newPublicHttpsPort;
-}
-
-qint32 ServerConfiguration::httpServerPortNumber() const { return m_httpServerPortNumber; }
-
-void ServerConfiguration::setHttpServerPortNumber(qint32 newHttpServerPortNumber) {
-	m_httpServerPortNumber = newHttpServerPortNumber;
-}
-
-qint32 ServerConfiguration::httpsPortNumber() const { return m_httpsPortNumber; }
-
-void ServerConfiguration::setHttpsPortNumber(qint32 newHttpsPortNumber) {
-	m_httpsPortNumber = newHttpsPortNumber;
-}
-
-bool ServerConfiguration::enableHttps() const { return m_enableHttps; }
-
-void ServerConfiguration::setEnableHttps(bool newEnableHttps) {
-	m_enableHttps = newEnableHttps;
-}
-
 bool ServerConfiguration::enableNormalizedItemByNameIds() const { return m_enableNormalizedItemByNameIds; }
 
 void ServerConfiguration::setEnableNormalizedItemByNameIds(bool newEnableNormalizedItemByNameIds) {
 	m_enableNormalizedItemByNameIds = newEnableNormalizedItemByNameIds;
 }
 
-QString ServerConfiguration::certificatePath() const { return m_certificatePath; }
-
-void ServerConfiguration::setCertificatePath(QString newCertificatePath) {
-	m_certificatePath = newCertificatePath;
-}
-bool ServerConfiguration::certificatePathNull() const {
-	return m_certificatePath.isNull();
-}
-
-void ServerConfiguration::setCertificatePathNull() {
-	m_certificatePath.clear();
-
-}
-QString ServerConfiguration::certificatePassword() const { return m_certificatePassword; }
-
-void ServerConfiguration::setCertificatePassword(QString newCertificatePassword) {
-	m_certificatePassword = newCertificatePassword;
-}
-bool ServerConfiguration::certificatePasswordNull() const {
-	return m_certificatePassword.isNull();
-}
-
-void ServerConfiguration::setCertificatePasswordNull() {
-	m_certificatePassword.clear();
-
-}
 bool ServerConfiguration::isPortAuthorized() const { return m_isPortAuthorized; }
 
 void ServerConfiguration::setIsPortAuthorized(bool newIsPortAuthorized) {
@@ -901,12 +469,6 @@ void ServerConfiguration::setQuickConnectAvailable(bool newQuickConnectAvailable
 	m_quickConnectAvailable = newQuickConnectAvailable;
 }
 
-bool ServerConfiguration::enableRemoteAccess() const { return m_enableRemoteAccess; }
-
-void ServerConfiguration::setEnableRemoteAccess(bool newEnableRemoteAccess) {
-	m_enableRemoteAccess = newEnableRemoteAccess;
-}
-
 bool ServerConfiguration::enableCaseSensitiveItemIds() const { return m_enableCaseSensitiveItemIds; }
 
 void ServerConfiguration::setEnableCaseSensitiveItemIds(bool newEnableCaseSensitiveItemIds) {
@@ -924,92 +486,37 @@ QString ServerConfiguration::metadataPath() const { return m_metadataPath; }
 void ServerConfiguration::setMetadataPath(QString newMetadataPath) {
 	m_metadataPath = newMetadataPath;
 }
-bool ServerConfiguration::metadataPathNull() const {
-	return m_metadataPath.isNull();
-}
 
-void ServerConfiguration::setMetadataPathNull() {
-	m_metadataPath.clear();
-
-}
-QString ServerConfiguration::metadataNetworkPath() const { return m_metadataNetworkPath; }
-
-void ServerConfiguration::setMetadataNetworkPath(QString newMetadataNetworkPath) {
-	m_metadataNetworkPath = newMetadataNetworkPath;
-}
-bool ServerConfiguration::metadataNetworkPathNull() const {
-	return m_metadataNetworkPath.isNull();
-}
-
-void ServerConfiguration::setMetadataNetworkPathNull() {
-	m_metadataNetworkPath.clear();
-
-}
 QString ServerConfiguration::preferredMetadataLanguage() const { return m_preferredMetadataLanguage; }
 
 void ServerConfiguration::setPreferredMetadataLanguage(QString newPreferredMetadataLanguage) {
 	m_preferredMetadataLanguage = newPreferredMetadataLanguage;
 }
-bool ServerConfiguration::preferredMetadataLanguageNull() const {
-	return m_preferredMetadataLanguage.isNull();
-}
 
-void ServerConfiguration::setPreferredMetadataLanguageNull() {
-	m_preferredMetadataLanguage.clear();
-
-}
 QString ServerConfiguration::metadataCountryCode() const { return m_metadataCountryCode; }
 
 void ServerConfiguration::setMetadataCountryCode(QString newMetadataCountryCode) {
 	m_metadataCountryCode = newMetadataCountryCode;
 }
-bool ServerConfiguration::metadataCountryCodeNull() const {
-	return m_metadataCountryCode.isNull();
-}
 
-void ServerConfiguration::setMetadataCountryCodeNull() {
-	m_metadataCountryCode.clear();
-
-}
 QStringList ServerConfiguration::sortReplaceCharacters() const { return m_sortReplaceCharacters; }
 
 void ServerConfiguration::setSortReplaceCharacters(QStringList newSortReplaceCharacters) {
 	m_sortReplaceCharacters = newSortReplaceCharacters;
 }
-bool ServerConfiguration::sortReplaceCharactersNull() const {
-	return m_sortReplaceCharacters.size() == 0;
-}
 
-void ServerConfiguration::setSortReplaceCharactersNull() {
-	m_sortReplaceCharacters.clear();
-
-}
 QStringList ServerConfiguration::sortRemoveCharacters() const { return m_sortRemoveCharacters; }
 
 void ServerConfiguration::setSortRemoveCharacters(QStringList newSortRemoveCharacters) {
 	m_sortRemoveCharacters = newSortRemoveCharacters;
 }
-bool ServerConfiguration::sortRemoveCharactersNull() const {
-	return m_sortRemoveCharacters.size() == 0;
-}
 
-void ServerConfiguration::setSortRemoveCharactersNull() {
-	m_sortRemoveCharacters.clear();
-
-}
 QStringList ServerConfiguration::sortRemoveWords() const { return m_sortRemoveWords; }
 
 void ServerConfiguration::setSortRemoveWords(QStringList newSortRemoveWords) {
 	m_sortRemoveWords = newSortRemoveWords;
 }
-bool ServerConfiguration::sortRemoveWordsNull() const {
-	return m_sortRemoveWords.size() == 0;
-}
 
-void ServerConfiguration::setSortRemoveWordsNull() {
-	m_sortRemoveWords.clear();
-
-}
 qint32 ServerConfiguration::minResumePct() const { return m_minResumePct; }
 
 void ServerConfiguration::setMinResumePct(qint32 newMinResumePct) {
@@ -1040,16 +547,22 @@ void ServerConfiguration::setMaxAudiobookResume(qint32 newMaxAudiobookResume) {
 	m_maxAudiobookResume = newMaxAudiobookResume;
 }
 
+qint32 ServerConfiguration::inactiveSessionThreshold() const { return m_inactiveSessionThreshold; }
+
+void ServerConfiguration::setInactiveSessionThreshold(qint32 newInactiveSessionThreshold) {
+	m_inactiveSessionThreshold = newInactiveSessionThreshold;
+}
+
 qint32 ServerConfiguration::libraryMonitorDelay() const { return m_libraryMonitorDelay; }
 
 void ServerConfiguration::setLibraryMonitorDelay(qint32 newLibraryMonitorDelay) {
 	m_libraryMonitorDelay = newLibraryMonitorDelay;
 }
 
-bool ServerConfiguration::enableDashboardResponseCaching() const { return m_enableDashboardResponseCaching; }
+qint32 ServerConfiguration::libraryUpdateDuration() const { return m_libraryUpdateDuration; }
 
-void ServerConfiguration::setEnableDashboardResponseCaching(bool newEnableDashboardResponseCaching) {
-	m_enableDashboardResponseCaching = newEnableDashboardResponseCaching;
+void ServerConfiguration::setLibraryUpdateDuration(qint32 newLibraryUpdateDuration) {
+	m_libraryUpdateDuration = newLibraryUpdateDuration;
 }
 
 ImageSavingConvention ServerConfiguration::imageSavingConvention() const { return m_imageSavingConvention; }
@@ -1063,14 +576,7 @@ QList<MetadataOptions> ServerConfiguration::metadataOptions() const { return m_m
 void ServerConfiguration::setMetadataOptions(QList<MetadataOptions> newMetadataOptions) {
 	m_metadataOptions = newMetadataOptions;
 }
-bool ServerConfiguration::metadataOptionsNull() const {
-	return m_metadataOptions.size() == 0;
-}
 
-void ServerConfiguration::setMetadataOptionsNull() {
-	m_metadataOptions.clear();
-
-}
 bool ServerConfiguration::skipDeserializationForBasicTypes() const { return m_skipDeserializationForBasicTypes; }
 
 void ServerConfiguration::setSkipDeserializationForBasicTypes(bool newSkipDeserializationForBasicTypes) {
@@ -1082,40 +588,13 @@ QString ServerConfiguration::serverName() const { return m_serverName; }
 void ServerConfiguration::setServerName(QString newServerName) {
 	m_serverName = newServerName;
 }
-bool ServerConfiguration::serverNameNull() const {
-	return m_serverName.isNull();
-}
 
-void ServerConfiguration::setServerNameNull() {
-	m_serverName.clear();
-
-}
-QString ServerConfiguration::baseUrl() const { return m_baseUrl; }
-
-void ServerConfiguration::setBaseUrl(QString newBaseUrl) {
-	m_baseUrl = newBaseUrl;
-}
-bool ServerConfiguration::baseUrlNull() const {
-	return m_baseUrl.isNull();
-}
-
-void ServerConfiguration::setBaseUrlNull() {
-	m_baseUrl.clear();
-
-}
 QString ServerConfiguration::uICulture() const { return m_uICulture; }
 
 void ServerConfiguration::setUICulture(QString newUICulture) {
 	m_uICulture = newUICulture;
 }
-bool ServerConfiguration::uICultureNull() const {
-	return m_uICulture.isNull();
-}
 
-void ServerConfiguration::setUICultureNull() {
-	m_uICulture.clear();
-
-}
 bool ServerConfiguration::saveMetadataHidden() const { return m_saveMetadataHidden; }
 
 void ServerConfiguration::setSaveMetadataHidden(bool newSaveMetadataHidden) {
@@ -1127,14 +606,7 @@ QList<NameValuePair> ServerConfiguration::contentTypes() const { return m_conten
 void ServerConfiguration::setContentTypes(QList<NameValuePair> newContentTypes) {
 	m_contentTypes = newContentTypes;
 }
-bool ServerConfiguration::contentTypesNull() const {
-	return m_contentTypes.size() == 0;
-}
 
-void ServerConfiguration::setContentTypesNull() {
-	m_contentTypes.clear();
-
-}
 qint32 ServerConfiguration::remoteClientBitrateLimit() const { return m_remoteClientBitrateLimit; }
 
 void ServerConfiguration::setRemoteClientBitrateLimit(qint32 newRemoteClientBitrateLimit) {
@@ -1159,95 +631,24 @@ void ServerConfiguration::setDisplaySpecialsWithinSeasons(bool newDisplaySpecial
 	m_displaySpecialsWithinSeasons = newDisplaySpecialsWithinSeasons;
 }
 
-QStringList ServerConfiguration::localNetworkSubnets() const { return m_localNetworkSubnets; }
-
-void ServerConfiguration::setLocalNetworkSubnets(QStringList newLocalNetworkSubnets) {
-	m_localNetworkSubnets = newLocalNetworkSubnets;
-}
-bool ServerConfiguration::localNetworkSubnetsNull() const {
-	return m_localNetworkSubnets.size() == 0;
-}
-
-void ServerConfiguration::setLocalNetworkSubnetsNull() {
-	m_localNetworkSubnets.clear();
-
-}
-QStringList ServerConfiguration::localNetworkAddresses() const { return m_localNetworkAddresses; }
-
-void ServerConfiguration::setLocalNetworkAddresses(QStringList newLocalNetworkAddresses) {
-	m_localNetworkAddresses = newLocalNetworkAddresses;
-}
-bool ServerConfiguration::localNetworkAddressesNull() const {
-	return m_localNetworkAddresses.size() == 0;
-}
-
-void ServerConfiguration::setLocalNetworkAddressesNull() {
-	m_localNetworkAddresses.clear();
-
-}
 QStringList ServerConfiguration::codecsUsed() const { return m_codecsUsed; }
 
 void ServerConfiguration::setCodecsUsed(QStringList newCodecsUsed) {
 	m_codecsUsed = newCodecsUsed;
 }
-bool ServerConfiguration::codecsUsedNull() const {
-	return m_codecsUsed.size() == 0;
-}
 
-void ServerConfiguration::setCodecsUsedNull() {
-	m_codecsUsed.clear();
-
-}
 QList<RepositoryInfo> ServerConfiguration::pluginRepositories() const { return m_pluginRepositories; }
 
 void ServerConfiguration::setPluginRepositories(QList<RepositoryInfo> newPluginRepositories) {
 	m_pluginRepositories = newPluginRepositories;
 }
-bool ServerConfiguration::pluginRepositoriesNull() const {
-	return m_pluginRepositories.size() == 0;
-}
 
-void ServerConfiguration::setPluginRepositoriesNull() {
-	m_pluginRepositories.clear();
-
-}
 bool ServerConfiguration::enableExternalContentInSuggestions() const { return m_enableExternalContentInSuggestions; }
 
 void ServerConfiguration::setEnableExternalContentInSuggestions(bool newEnableExternalContentInSuggestions) {
 	m_enableExternalContentInSuggestions = newEnableExternalContentInSuggestions;
 }
 
-bool ServerConfiguration::requireHttps() const { return m_requireHttps; }
-
-void ServerConfiguration::setRequireHttps(bool newRequireHttps) {
-	m_requireHttps = newRequireHttps;
-}
-
-bool ServerConfiguration::enableNewOmdbSupport() const { return m_enableNewOmdbSupport; }
-
-void ServerConfiguration::setEnableNewOmdbSupport(bool newEnableNewOmdbSupport) {
-	m_enableNewOmdbSupport = newEnableNewOmdbSupport;
-}
-
-QStringList ServerConfiguration::remoteIPFilter() const { return m_remoteIPFilter; }
-
-void ServerConfiguration::setRemoteIPFilter(QStringList newRemoteIPFilter) {
-	m_remoteIPFilter = newRemoteIPFilter;
-}
-bool ServerConfiguration::remoteIPFilterNull() const {
-	return m_remoteIPFilter.size() == 0;
-}
-
-void ServerConfiguration::setRemoteIPFilterNull() {
-	m_remoteIPFilter.clear();
-
-}
-bool ServerConfiguration::isRemoteIPFilterBlacklist() const { return m_isRemoteIPFilterBlacklist; }
-
-void ServerConfiguration::setIsRemoteIPFilterBlacklist(bool newIsRemoteIPFilterBlacklist) {
-	m_isRemoteIPFilterBlacklist = newIsRemoteIPFilterBlacklist;
-}
-
 qint32 ServerConfiguration::imageExtractionTimeoutMs() const { return m_imageExtractionTimeoutMs; }
 
 void ServerConfiguration::setImageExtractionTimeoutMs(qint32 newImageExtractionTimeoutMs) {
@@ -1259,33 +660,7 @@ QList<PathSubstitution> ServerConfiguration::pathSubstitutions() const { return
 void ServerConfiguration::setPathSubstitutions(QList<PathSubstitution> newPathSubstitutions) {
 	m_pathSubstitutions = newPathSubstitutions;
 }
-bool ServerConfiguration::pathSubstitutionsNull() const {
-	return m_pathSubstitutions.size() == 0;
-}
 
-void ServerConfiguration::setPathSubstitutionsNull() {
-	m_pathSubstitutions.clear();
-
-}
-bool ServerConfiguration::enableSimpleArtistDetection() const { return m_enableSimpleArtistDetection; }
-
-void ServerConfiguration::setEnableSimpleArtistDetection(bool newEnableSimpleArtistDetection) {
-	m_enableSimpleArtistDetection = newEnableSimpleArtistDetection;
-}
-
-QStringList ServerConfiguration::uninstalledPlugins() const { return m_uninstalledPlugins; }
-
-void ServerConfiguration::setUninstalledPlugins(QStringList newUninstalledPlugins) {
-	m_uninstalledPlugins = newUninstalledPlugins;
-}
-bool ServerConfiguration::uninstalledPluginsNull() const {
-	return m_uninstalledPlugins.size() == 0;
-}
-
-void ServerConfiguration::setUninstalledPluginsNull() {
-	m_uninstalledPlugins.clear();
-
-}
 bool ServerConfiguration::enableSlowResponseWarning() const { return m_enableSlowResponseWarning; }
 
 void ServerConfiguration::setEnableSlowResponseWarning(bool newEnableSlowResponseWarning) {
@@ -1303,27 +678,7 @@ QStringList ServerConfiguration::corsHosts() const { return m_corsHosts; }
 void ServerConfiguration::setCorsHosts(QStringList newCorsHosts) {
 	m_corsHosts = newCorsHosts;
 }
-bool ServerConfiguration::corsHostsNull() const {
-	return m_corsHosts.size() == 0;
-}
 
-void ServerConfiguration::setCorsHostsNull() {
-	m_corsHosts.clear();
-
-}
-QStringList ServerConfiguration::knownProxies() const { return m_knownProxies; }
-
-void ServerConfiguration::setKnownProxies(QStringList newKnownProxies) {
-	m_knownProxies = newKnownProxies;
-}
-bool ServerConfiguration::knownProxiesNull() const {
-	return m_knownProxies.size() == 0;
-}
-
-void ServerConfiguration::setKnownProxiesNull() {
-	m_knownProxies.clear();
-
-}
 std::optional<qint32> ServerConfiguration::activityLogRetentionDays() const { return m_activityLogRetentionDays; }
 
 void ServerConfiguration::setActivityLogRetentionDays(std::optional<qint32> newActivityLogRetentionDays) {
@@ -1355,10 +710,40 @@ void ServerConfiguration::setRemoveOldPlugins(bool newRemoveOldPlugins) {
 	m_removeOldPlugins = newRemoveOldPlugins;
 }
 
-bool ServerConfiguration::disablePluginImages() const { return m_disablePluginImages; }
+bool ServerConfiguration::allowClientLogUpload() const { return m_allowClientLogUpload; }
 
-void ServerConfiguration::setDisablePluginImages(bool newDisablePluginImages) {
-	m_disablePluginImages = newDisablePluginImages;
+void ServerConfiguration::setAllowClientLogUpload(bool newAllowClientLogUpload) {
+	m_allowClientLogUpload = newAllowClientLogUpload;
+}
+
+qint32 ServerConfiguration::dummyChapterDuration() const { return m_dummyChapterDuration; }
+
+void ServerConfiguration::setDummyChapterDuration(qint32 newDummyChapterDuration) {
+	m_dummyChapterDuration = newDummyChapterDuration;
+}
+
+ImageResolution ServerConfiguration::chapterImageResolution() const { return m_chapterImageResolution; }
+
+void ServerConfiguration::setChapterImageResolution(ImageResolution newChapterImageResolution) {
+	m_chapterImageResolution = newChapterImageResolution;
+}
+
+qint32 ServerConfiguration::parallelImageEncodingLimit() const { return m_parallelImageEncodingLimit; }
+
+void ServerConfiguration::setParallelImageEncodingLimit(qint32 newParallelImageEncodingLimit) {
+	m_parallelImageEncodingLimit = newParallelImageEncodingLimit;
+}
+
+QList<CastReceiverApplication> ServerConfiguration::castReceiverApplications() const { return m_castReceiverApplications; }
+
+void ServerConfiguration::setCastReceiverApplications(QList<CastReceiverApplication> newCastReceiverApplications) {
+	m_castReceiverApplications = newCastReceiverApplications;
+}
+
+QSharedPointer<TrickplayOptions> ServerConfiguration::trickplayOptions() const { return m_trickplayOptions; }
+
+void ServerConfiguration::setTrickplayOptions(QSharedPointer<TrickplayOptions> newTrickplayOptions) {
+	m_trickplayOptions = newTrickplayOptions;
 }
 
 
diff --git a/core/src/dto/serverdiscoveryinfo.cpp b/core/src/dto/serverdiscoveryinfo.cpp
new file mode 100644
index 0000000..5652460
--- /dev/null
+++ b/core/src/dto/serverdiscoveryinfo.cpp
@@ -0,0 +1,141 @@
+/*
+ * 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/dto/serverdiscoveryinfo.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ServerDiscoveryInfo::ServerDiscoveryInfo() {}
+ServerDiscoveryInfo::ServerDiscoveryInfo (
+		QString address, 
+		QString jellyfinId, 
+		QString name 
+		) :
+	m_address(address),
+	m_jellyfinId(jellyfinId),
+	m_name(name) { }
+
+
+
+ServerDiscoveryInfo::ServerDiscoveryInfo(const ServerDiscoveryInfo &other) :
+
+	m_address(other.m_address),
+	m_jellyfinId(other.m_jellyfinId),
+	m_name(other.m_name),
+	m_endpointAddress(other.m_endpointAddress){}
+
+
+void ServerDiscoveryInfo::replaceData(ServerDiscoveryInfo &other) {
+	m_address = other.m_address;
+	m_jellyfinId = other.m_jellyfinId;
+	m_name = other.m_name;
+	m_endpointAddress = other.m_endpointAddress;
+}
+
+ServerDiscoveryInfo ServerDiscoveryInfo::fromJson(QJsonObject source) {
+	ServerDiscoveryInfo instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ServerDiscoveryInfo::setFromJson(QJsonObject source) {
+	m_address = Jellyfin::Support::fromJsonValue<QString>(source["Address"]);
+	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
+	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_endpointAddress = Jellyfin::Support::fromJsonValue<QString>(source["EndpointAddress"]);
+
+}
+	
+QJsonObject ServerDiscoveryInfo::toJson() const {
+	QJsonObject result;
+	
+	result["Address"] = Jellyfin::Support::toJsonValue<QString>(m_address);		
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	
+	if (!(m_endpointAddress.isNull())) {
+		result["EndpointAddress"] = Jellyfin::Support::toJsonValue<QString>(m_endpointAddress);
+	}
+		
+	return result;
+}
+
+QString ServerDiscoveryInfo::address() const { return m_address; }
+
+void ServerDiscoveryInfo::setAddress(QString newAddress) {
+	m_address = newAddress;
+}
+
+QString ServerDiscoveryInfo::jellyfinId() const { return m_jellyfinId; }
+
+void ServerDiscoveryInfo::setJellyfinId(QString newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
+}
+
+QString ServerDiscoveryInfo::name() const { return m_name; }
+
+void ServerDiscoveryInfo::setName(QString newName) {
+	m_name = newName;
+}
+
+QString ServerDiscoveryInfo::endpointAddress() const { return m_endpointAddress; }
+
+void ServerDiscoveryInfo::setEndpointAddress(QString newEndpointAddress) {
+	m_endpointAddress = newEndpointAddress;
+}
+bool ServerDiscoveryInfo::endpointAddressNull() const {
+	return m_endpointAddress.isNull();
+}
+
+void ServerDiscoveryInfo::setEndpointAddressNull() {
+	m_endpointAddress.clear();
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using ServerDiscoveryInfo = Jellyfin::DTO::ServerDiscoveryInfo;
+
+template <>
+ServerDiscoveryInfo fromJsonValue(const QJsonValue &source, convertType<ServerDiscoveryInfo>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ServerDiscoveryInfo::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ServerDiscoveryInfo &source, convertType<ServerDiscoveryInfo>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/serverrestartingmessage.cpp b/core/src/dto/serverrestartingmessage.cpp
new file mode 100644
index 0000000..7dc4a9b
--- /dev/null
+++ b/core/src/dto/serverrestartingmessage.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/serverrestartingmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ServerRestartingMessage::ServerRestartingMessage() {}
+ServerRestartingMessage::ServerRestartingMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ServerRestartingMessage::ServerRestartingMessage(const ServerRestartingMessage &other) :
+
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ServerRestartingMessage::replaceData(ServerRestartingMessage &other) {
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ServerRestartingMessage ServerRestartingMessage::fromJson(QJsonObject source) {
+	ServerRestartingMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ServerRestartingMessage::setFromJson(QJsonObject source) {
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ServerRestartingMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString ServerRestartingMessage::messageId() const { return m_messageId; }
+
+void ServerRestartingMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ServerRestartingMessage::messageType() const { return m_messageType; }
+
+void ServerRestartingMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ServerRestartingMessage = Jellyfin::DTO::ServerRestartingMessage;
+
+template <>
+ServerRestartingMessage fromJsonValue(const QJsonValue &source, convertType<ServerRestartingMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ServerRestartingMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ServerRestartingMessage &source, convertType<ServerRestartingMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/servershuttingdownmessage.cpp b/core/src/dto/servershuttingdownmessage.cpp
new file mode 100644
index 0000000..ba9bfd2
--- /dev/null
+++ b/core/src/dto/servershuttingdownmessage.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/servershuttingdownmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+ServerShuttingDownMessage::ServerShuttingDownMessage() {}
+ServerShuttingDownMessage::ServerShuttingDownMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+ServerShuttingDownMessage::ServerShuttingDownMessage(const ServerShuttingDownMessage &other) :
+
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void ServerShuttingDownMessage::replaceData(ServerShuttingDownMessage &other) {
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+ServerShuttingDownMessage ServerShuttingDownMessage::fromJson(QJsonObject source) {
+	ServerShuttingDownMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void ServerShuttingDownMessage::setFromJson(QJsonObject source) {
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject ServerShuttingDownMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString ServerShuttingDownMessage::messageId() const { return m_messageId; }
+
+void ServerShuttingDownMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType ServerShuttingDownMessage::messageType() const { return m_messageType; }
+
+void ServerShuttingDownMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using ServerShuttingDownMessage = Jellyfin::DTO::ServerShuttingDownMessage;
+
+template <>
+ServerShuttingDownMessage fromJsonValue(const QJsonValue &source, convertType<ServerShuttingDownMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return ServerShuttingDownMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const ServerShuttingDownMessage &source, convertType<ServerShuttingDownMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/sessioninfo.cpp b/core/src/dto/sessioninfodto.cpp
similarity index 58%
rename from core/src/dto/sessioninfo.cpp
rename to core/src/dto/sessioninfodto.cpp
index b16ab20..70ac08b 100644
--- a/core/src/dto/sessioninfo.cpp
+++ b/core/src/dto/sessioninfodto.cpp
@@ -27,44 +27,46 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/sessioninfo.h>
+#include <JellyfinQt/dto/sessioninfodto.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-SessionInfo::SessionInfo() {}
-SessionInfo::SessionInfo (
+SessionInfoDto::SessionInfoDto() {}
+SessionInfoDto::SessionInfoDto (
 		QSharedPointer<PlayerStateInfo> playState, 
-		QSharedPointer<ClientCapabilities> capabilities, 
+		QSharedPointer<ClientCapabilitiesDto> capabilities, 
+		QList<MediaType> playableMediaTypes, 
 		QString userId, 
 		QDateTime lastActivityDate, 
 		QDateTime lastPlaybackCheckIn, 
 		QSharedPointer<BaseItemDto> nowPlayingItem, 
-		QSharedPointer<BaseItem> fullNowPlayingItem, 
 		QSharedPointer<BaseItemDto> nowViewingItem, 
 		QSharedPointer<TranscodingInfo> transcodingInfo, 
 		bool isActive, 
 		bool supportsMediaControl, 
 		bool supportsRemoteControl, 
-		bool hasCustomDeviceName 
+		bool hasCustomDeviceName, 
+		QList<GeneralCommandType> supportedCommands 
 		) :
 	m_playState(playState),
 	m_capabilities(capabilities),
+	m_playableMediaTypes(playableMediaTypes),
 	m_userId(userId),
 	m_lastActivityDate(lastActivityDate),
 	m_lastPlaybackCheckIn(lastPlaybackCheckIn),
 	m_nowPlayingItem(nowPlayingItem),
-	m_fullNowPlayingItem(fullNowPlayingItem),
 	m_nowViewingItem(nowViewingItem),
 	m_transcodingInfo(transcodingInfo),
 	m_isActive(isActive),
 	m_supportsMediaControl(supportsMediaControl),
 	m_supportsRemoteControl(supportsRemoteControl),
-	m_hasCustomDeviceName(hasCustomDeviceName) { }
+	m_hasCustomDeviceName(hasCustomDeviceName),
+	m_supportedCommands(supportedCommands) { }
 
 
 
-SessionInfo::SessionInfo(const SessionInfo &other) :
+SessionInfoDto::SessionInfoDto(const SessionInfoDto &other) :
 
 	m_playState(other.m_playState),
 	m_additionalUsers(other.m_additionalUsers),
@@ -77,10 +79,10 @@ SessionInfo::SessionInfo(const SessionInfo &other) :
 	m_client(other.m_client),
 	m_lastActivityDate(other.m_lastActivityDate),
 	m_lastPlaybackCheckIn(other.m_lastPlaybackCheckIn),
+	m_lastPausedDate(other.m_lastPausedDate),
 	m_deviceName(other.m_deviceName),
 	m_deviceType(other.m_deviceType),
 	m_nowPlayingItem(other.m_nowPlayingItem),
-	m_fullNowPlayingItem(other.m_fullNowPlayingItem),
 	m_nowViewingItem(other.m_nowViewingItem),
 	m_deviceId(other.m_deviceId),
 	m_applicationVersion(other.m_applicationVersion),
@@ -89,6 +91,7 @@ SessionInfo::SessionInfo(const SessionInfo &other) :
 	m_supportsMediaControl(other.m_supportsMediaControl),
 	m_supportsRemoteControl(other.m_supportsRemoteControl),
 	m_nowPlayingQueue(other.m_nowPlayingQueue),
+	m_nowPlayingQueueFullItems(other.m_nowPlayingQueueFullItems),
 	m_hasCustomDeviceName(other.m_hasCustomDeviceName),
 	m_playlistItemId(other.m_playlistItemId),
 	m_serverId(other.m_serverId),
@@ -96,7 +99,7 @@ SessionInfo::SessionInfo(const SessionInfo &other) :
 	m_supportedCommands(other.m_supportedCommands){}
 
 
-void SessionInfo::replaceData(SessionInfo &other) {
+void SessionInfoDto::replaceData(SessionInfoDto &other) {
 	m_playState = other.m_playState;
 	m_additionalUsers = other.m_additionalUsers;
 	m_capabilities = other.m_capabilities;
@@ -108,10 +111,10 @@ void SessionInfo::replaceData(SessionInfo &other) {
 	m_client = other.m_client;
 	m_lastActivityDate = other.m_lastActivityDate;
 	m_lastPlaybackCheckIn = other.m_lastPlaybackCheckIn;
+	m_lastPausedDate = other.m_lastPausedDate;
 	m_deviceName = other.m_deviceName;
 	m_deviceType = other.m_deviceType;
 	m_nowPlayingItem = other.m_nowPlayingItem;
-	m_fullNowPlayingItem = other.m_fullNowPlayingItem;
 	m_nowViewingItem = other.m_nowViewingItem;
 	m_deviceId = other.m_deviceId;
 	m_applicationVersion = other.m_applicationVersion;
@@ -120,6 +123,7 @@ void SessionInfo::replaceData(SessionInfo &other) {
 	m_supportsMediaControl = other.m_supportsMediaControl;
 	m_supportsRemoteControl = other.m_supportsRemoteControl;
 	m_nowPlayingQueue = other.m_nowPlayingQueue;
+	m_nowPlayingQueueFullItems = other.m_nowPlayingQueueFullItems;
 	m_hasCustomDeviceName = other.m_hasCustomDeviceName;
 	m_playlistItemId = other.m_playlistItemId;
 	m_serverId = other.m_serverId;
@@ -127,29 +131,29 @@ void SessionInfo::replaceData(SessionInfo &other) {
 	m_supportedCommands = other.m_supportedCommands;
 }
 
-SessionInfo SessionInfo::fromJson(QJsonObject source) {
-	SessionInfo instance;
+SessionInfoDto SessionInfoDto::fromJson(QJsonObject source) {
+	SessionInfoDto instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void SessionInfo::setFromJson(QJsonObject source) {
+void SessionInfoDto::setFromJson(QJsonObject source) {
 	m_playState = Jellyfin::Support::fromJsonValue<QSharedPointer<PlayerStateInfo>>(source["PlayState"]);
 	m_additionalUsers = Jellyfin::Support::fromJsonValue<QList<SessionUserInfo>>(source["AdditionalUsers"]);
-	m_capabilities = Jellyfin::Support::fromJsonValue<QSharedPointer<ClientCapabilities>>(source["Capabilities"]);
+	m_capabilities = Jellyfin::Support::fromJsonValue<QSharedPointer<ClientCapabilitiesDto>>(source["Capabilities"]);
 	m_remoteEndPoint = Jellyfin::Support::fromJsonValue<QString>(source["RemoteEndPoint"]);
-	m_playableMediaTypes = Jellyfin::Support::fromJsonValue<QStringList>(source["PlayableMediaTypes"]);
+	m_playableMediaTypes = Jellyfin::Support::fromJsonValue<QList<MediaType>>(source["PlayableMediaTypes"]);
 	m_jellyfinId = Jellyfin::Support::fromJsonValue<QString>(source["Id"]);
 	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
 	m_userName = Jellyfin::Support::fromJsonValue<QString>(source["UserName"]);
 	m_client = Jellyfin::Support::fromJsonValue<QString>(source["Client"]);
 	m_lastActivityDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["LastActivityDate"]);
 	m_lastPlaybackCheckIn = Jellyfin::Support::fromJsonValue<QDateTime>(source["LastPlaybackCheckIn"]);
+	m_lastPausedDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["LastPausedDate"]);
 	m_deviceName = Jellyfin::Support::fromJsonValue<QString>(source["DeviceName"]);
 	m_deviceType = Jellyfin::Support::fromJsonValue<QString>(source["DeviceType"]);
 	m_nowPlayingItem = Jellyfin::Support::fromJsonValue<QSharedPointer<BaseItemDto>>(source["NowPlayingItem"]);
-	m_fullNowPlayingItem = Jellyfin::Support::fromJsonValue<QSharedPointer<BaseItem>>(source["FullNowPlayingItem"]);
 	m_nowViewingItem = Jellyfin::Support::fromJsonValue<QSharedPointer<BaseItemDto>>(source["NowViewingItem"]);
 	m_deviceId = Jellyfin::Support::fromJsonValue<QString>(source["DeviceId"]);
 	m_applicationVersion = Jellyfin::Support::fromJsonValue<QString>(source["ApplicationVersion"]);
@@ -158,6 +162,7 @@ void SessionInfo::setFromJson(QJsonObject source) {
 	m_supportsMediaControl = Jellyfin::Support::fromJsonValue<bool>(source["SupportsMediaControl"]);
 	m_supportsRemoteControl = Jellyfin::Support::fromJsonValue<bool>(source["SupportsRemoteControl"]);
 	m_nowPlayingQueue = Jellyfin::Support::fromJsonValue<QList<QueueItem>>(source["NowPlayingQueue"]);
+	m_nowPlayingQueueFullItems = Jellyfin::Support::fromJsonValue<QList<BaseItemDto>>(source["NowPlayingQueueFullItems"]);
 	m_hasCustomDeviceName = Jellyfin::Support::fromJsonValue<bool>(source["HasCustomDeviceName"]);
 	m_playlistItemId = Jellyfin::Support::fromJsonValue<QString>(source["PlaylistItemId"]);
 	m_serverId = Jellyfin::Support::fromJsonValue<QString>(source["ServerId"]);
@@ -166,7 +171,7 @@ void SessionInfo::setFromJson(QJsonObject source) {
 
 }
 	
-QJsonObject SessionInfo::toJson() const {
+QJsonObject SessionInfoDto::toJson() const {
 	QJsonObject result;
 	
 	result["PlayState"] = Jellyfin::Support::toJsonValue<QSharedPointer<PlayerStateInfo>>(m_playState);		
@@ -175,17 +180,13 @@ QJsonObject SessionInfo::toJson() const {
 		result["AdditionalUsers"] = Jellyfin::Support::toJsonValue<QList<SessionUserInfo>>(m_additionalUsers);
 	}
 			
-	result["Capabilities"] = Jellyfin::Support::toJsonValue<QSharedPointer<ClientCapabilities>>(m_capabilities);		
+	result["Capabilities"] = Jellyfin::Support::toJsonValue<QSharedPointer<ClientCapabilitiesDto>>(m_capabilities);		
 	
 	if (!(m_remoteEndPoint.isNull())) {
 		result["RemoteEndPoint"] = Jellyfin::Support::toJsonValue<QString>(m_remoteEndPoint);
 	}
 			
-	
-	if (!(m_playableMediaTypes.size() == 0)) {
-		result["PlayableMediaTypes"] = Jellyfin::Support::toJsonValue<QStringList>(m_playableMediaTypes);
-	}
-			
+	result["PlayableMediaTypes"] = Jellyfin::Support::toJsonValue<QList<MediaType>>(m_playableMediaTypes);		
 	
 	if (!(m_jellyfinId.isNull())) {
 		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
@@ -205,6 +206,11 @@ QJsonObject SessionInfo::toJson() const {
 	result["LastActivityDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastActivityDate);		
 	result["LastPlaybackCheckIn"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastPlaybackCheckIn);		
 	
+	if (!(m_lastPausedDate.isNull())) {
+		result["LastPausedDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastPausedDate);
+	}
+			
+	
 	if (!(m_deviceName.isNull())) {
 		result["DeviceName"] = Jellyfin::Support::toJsonValue<QString>(m_deviceName);
 	}
@@ -215,7 +221,6 @@ QJsonObject SessionInfo::toJson() const {
 	}
 			
 	result["NowPlayingItem"] = Jellyfin::Support::toJsonValue<QSharedPointer<BaseItemDto>>(m_nowPlayingItem);		
-	result["FullNowPlayingItem"] = Jellyfin::Support::toJsonValue<QSharedPointer<BaseItem>>(m_fullNowPlayingItem);		
 	result["NowViewingItem"] = Jellyfin::Support::toJsonValue<QSharedPointer<BaseItemDto>>(m_nowViewingItem);		
 	
 	if (!(m_deviceId.isNull())) {
@@ -236,6 +241,11 @@ QJsonObject SessionInfo::toJson() const {
 		result["NowPlayingQueue"] = Jellyfin::Support::toJsonValue<QList<QueueItem>>(m_nowPlayingQueue);
 	}
 			
+	
+	if (!(m_nowPlayingQueueFullItems.size() == 0)) {
+		result["NowPlayingQueueFullItems"] = Jellyfin::Support::toJsonValue<QList<BaseItemDto>>(m_nowPlayingQueueFullItems);
+	}
+			
 	result["HasCustomDeviceName"] = Jellyfin::Support::toJsonValue<bool>(m_hasCustomDeviceName);		
 	
 	if (!(m_playlistItemId.isNull())) {
@@ -252,302 +262,304 @@ QJsonObject SessionInfo::toJson() const {
 		result["UserPrimaryImageTag"] = Jellyfin::Support::toJsonValue<QString>(m_userPrimaryImageTag);
 	}
 			
-	
-	if (!(m_supportedCommands.size() == 0)) {
-		result["SupportedCommands"] = Jellyfin::Support::toJsonValue<QList<GeneralCommandType>>(m_supportedCommands);
-	}
-		
+	result["SupportedCommands"] = Jellyfin::Support::toJsonValue<QList<GeneralCommandType>>(m_supportedCommands);	
 	return result;
 }
 
-QSharedPointer<PlayerStateInfo> SessionInfo::playState() const { return m_playState; }
+QSharedPointer<PlayerStateInfo> SessionInfoDto::playState() const { return m_playState; }
 
-void SessionInfo::setPlayState(QSharedPointer<PlayerStateInfo> newPlayState) {
+void SessionInfoDto::setPlayState(QSharedPointer<PlayerStateInfo> newPlayState) {
 	m_playState = newPlayState;
 }
 
-QList<SessionUserInfo> SessionInfo::additionalUsers() const { return m_additionalUsers; }
+QList<SessionUserInfo> SessionInfoDto::additionalUsers() const { return m_additionalUsers; }
 
-void SessionInfo::setAdditionalUsers(QList<SessionUserInfo> newAdditionalUsers) {
+void SessionInfoDto::setAdditionalUsers(QList<SessionUserInfo> newAdditionalUsers) {
 	m_additionalUsers = newAdditionalUsers;
 }
-bool SessionInfo::additionalUsersNull() const {
+bool SessionInfoDto::additionalUsersNull() const {
 	return m_additionalUsers.size() == 0;
 }
 
-void SessionInfo::setAdditionalUsersNull() {
+void SessionInfoDto::setAdditionalUsersNull() {
 	m_additionalUsers.clear();
 
 }
-QSharedPointer<ClientCapabilities> SessionInfo::capabilities() const { return m_capabilities; }
+QSharedPointer<ClientCapabilitiesDto> SessionInfoDto::capabilities() const { return m_capabilities; }
 
-void SessionInfo::setCapabilities(QSharedPointer<ClientCapabilities> newCapabilities) {
+void SessionInfoDto::setCapabilities(QSharedPointer<ClientCapabilitiesDto> newCapabilities) {
 	m_capabilities = newCapabilities;
 }
 
-QString SessionInfo::remoteEndPoint() const { return m_remoteEndPoint; }
+QString SessionInfoDto::remoteEndPoint() const { return m_remoteEndPoint; }
 
-void SessionInfo::setRemoteEndPoint(QString newRemoteEndPoint) {
+void SessionInfoDto::setRemoteEndPoint(QString newRemoteEndPoint) {
 	m_remoteEndPoint = newRemoteEndPoint;
 }
-bool SessionInfo::remoteEndPointNull() const {
+bool SessionInfoDto::remoteEndPointNull() const {
 	return m_remoteEndPoint.isNull();
 }
 
-void SessionInfo::setRemoteEndPointNull() {
+void SessionInfoDto::setRemoteEndPointNull() {
 	m_remoteEndPoint.clear();
 
 }
-QStringList SessionInfo::playableMediaTypes() const { return m_playableMediaTypes; }
+QList<MediaType> SessionInfoDto::playableMediaTypes() const { return m_playableMediaTypes; }
 
-void SessionInfo::setPlayableMediaTypes(QStringList newPlayableMediaTypes) {
+void SessionInfoDto::setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes) {
 	m_playableMediaTypes = newPlayableMediaTypes;
 }
-bool SessionInfo::playableMediaTypesNull() const {
-	return m_playableMediaTypes.size() == 0;
-}
 
-void SessionInfo::setPlayableMediaTypesNull() {
-	m_playableMediaTypes.clear();
+QString SessionInfoDto::jellyfinId() const { return m_jellyfinId; }
 
-}
-QString SessionInfo::jellyfinId() const { return m_jellyfinId; }
-
-void SessionInfo::setJellyfinId(QString newJellyfinId) {
+void SessionInfoDto::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool SessionInfo::jellyfinIdNull() const {
+bool SessionInfoDto::jellyfinIdNull() const {
 	return m_jellyfinId.isNull();
 }
 
-void SessionInfo::setJellyfinIdNull() {
+void SessionInfoDto::setJellyfinIdNull() {
 	m_jellyfinId.clear();
 
 }
-QString SessionInfo::userId() const { return m_userId; }
+QString SessionInfoDto::userId() const { return m_userId; }
 
-void SessionInfo::setUserId(QString newUserId) {
+void SessionInfoDto::setUserId(QString newUserId) {
 	m_userId = newUserId;
 }
 
-QString SessionInfo::userName() const { return m_userName; }
+QString SessionInfoDto::userName() const { return m_userName; }
 
-void SessionInfo::setUserName(QString newUserName) {
+void SessionInfoDto::setUserName(QString newUserName) {
 	m_userName = newUserName;
 }
-bool SessionInfo::userNameNull() const {
+bool SessionInfoDto::userNameNull() const {
 	return m_userName.isNull();
 }
 
-void SessionInfo::setUserNameNull() {
+void SessionInfoDto::setUserNameNull() {
 	m_userName.clear();
 
 }
-QString SessionInfo::client() const { return m_client; }
+QString SessionInfoDto::client() const { return m_client; }
 
-void SessionInfo::setClient(QString newClient) {
+void SessionInfoDto::setClient(QString newClient) {
 	m_client = newClient;
 }
-bool SessionInfo::clientNull() const {
+bool SessionInfoDto::clientNull() const {
 	return m_client.isNull();
 }
 
-void SessionInfo::setClientNull() {
+void SessionInfoDto::setClientNull() {
 	m_client.clear();
 
 }
-QDateTime SessionInfo::lastActivityDate() const { return m_lastActivityDate; }
+QDateTime SessionInfoDto::lastActivityDate() const { return m_lastActivityDate; }
 
-void SessionInfo::setLastActivityDate(QDateTime newLastActivityDate) {
+void SessionInfoDto::setLastActivityDate(QDateTime newLastActivityDate) {
 	m_lastActivityDate = newLastActivityDate;
 }
 
-QDateTime SessionInfo::lastPlaybackCheckIn() const { return m_lastPlaybackCheckIn; }
+QDateTime SessionInfoDto::lastPlaybackCheckIn() const { return m_lastPlaybackCheckIn; }
 
-void SessionInfo::setLastPlaybackCheckIn(QDateTime newLastPlaybackCheckIn) {
+void SessionInfoDto::setLastPlaybackCheckIn(QDateTime newLastPlaybackCheckIn) {
 	m_lastPlaybackCheckIn = newLastPlaybackCheckIn;
 }
 
-QString SessionInfo::deviceName() const { return m_deviceName; }
+QDateTime SessionInfoDto::lastPausedDate() const { return m_lastPausedDate; }
 
-void SessionInfo::setDeviceName(QString newDeviceName) {
+void SessionInfoDto::setLastPausedDate(QDateTime newLastPausedDate) {
+	m_lastPausedDate = newLastPausedDate;
+}
+bool SessionInfoDto::lastPausedDateNull() const {
+	return m_lastPausedDate.isNull();
+}
+
+void SessionInfoDto::setLastPausedDateNull() {
+	m_lastPausedDate= QDateTime();
+
+}
+QString SessionInfoDto::deviceName() const { return m_deviceName; }
+
+void SessionInfoDto::setDeviceName(QString newDeviceName) {
 	m_deviceName = newDeviceName;
 }
-bool SessionInfo::deviceNameNull() const {
+bool SessionInfoDto::deviceNameNull() const {
 	return m_deviceName.isNull();
 }
 
-void SessionInfo::setDeviceNameNull() {
+void SessionInfoDto::setDeviceNameNull() {
 	m_deviceName.clear();
 
 }
-QString SessionInfo::deviceType() const { return m_deviceType; }
+QString SessionInfoDto::deviceType() const { return m_deviceType; }
 
-void SessionInfo::setDeviceType(QString newDeviceType) {
+void SessionInfoDto::setDeviceType(QString newDeviceType) {
 	m_deviceType = newDeviceType;
 }
-bool SessionInfo::deviceTypeNull() const {
+bool SessionInfoDto::deviceTypeNull() const {
 	return m_deviceType.isNull();
 }
 
-void SessionInfo::setDeviceTypeNull() {
+void SessionInfoDto::setDeviceTypeNull() {
 	m_deviceType.clear();
 
 }
-QSharedPointer<BaseItemDto> SessionInfo::nowPlayingItem() const { return m_nowPlayingItem; }
+QSharedPointer<BaseItemDto> SessionInfoDto::nowPlayingItem() const { return m_nowPlayingItem; }
 
-void SessionInfo::setNowPlayingItem(QSharedPointer<BaseItemDto> newNowPlayingItem) {
+void SessionInfoDto::setNowPlayingItem(QSharedPointer<BaseItemDto> newNowPlayingItem) {
 	m_nowPlayingItem = newNowPlayingItem;
 }
 
-QSharedPointer<BaseItem> SessionInfo::fullNowPlayingItem() const { return m_fullNowPlayingItem; }
+QSharedPointer<BaseItemDto> SessionInfoDto::nowViewingItem() const { return m_nowViewingItem; }
 
-void SessionInfo::setFullNowPlayingItem(QSharedPointer<BaseItem> newFullNowPlayingItem) {
-	m_fullNowPlayingItem = newFullNowPlayingItem;
-}
-
-QSharedPointer<BaseItemDto> SessionInfo::nowViewingItem() const { return m_nowViewingItem; }
-
-void SessionInfo::setNowViewingItem(QSharedPointer<BaseItemDto> newNowViewingItem) {
+void SessionInfoDto::setNowViewingItem(QSharedPointer<BaseItemDto> newNowViewingItem) {
 	m_nowViewingItem = newNowViewingItem;
 }
 
-QString SessionInfo::deviceId() const { return m_deviceId; }
+QString SessionInfoDto::deviceId() const { return m_deviceId; }
 
-void SessionInfo::setDeviceId(QString newDeviceId) {
+void SessionInfoDto::setDeviceId(QString newDeviceId) {
 	m_deviceId = newDeviceId;
 }
-bool SessionInfo::deviceIdNull() const {
+bool SessionInfoDto::deviceIdNull() const {
 	return m_deviceId.isNull();
 }
 
-void SessionInfo::setDeviceIdNull() {
+void SessionInfoDto::setDeviceIdNull() {
 	m_deviceId.clear();
 
 }
-QString SessionInfo::applicationVersion() const { return m_applicationVersion; }
+QString SessionInfoDto::applicationVersion() const { return m_applicationVersion; }
 
-void SessionInfo::setApplicationVersion(QString newApplicationVersion) {
+void SessionInfoDto::setApplicationVersion(QString newApplicationVersion) {
 	m_applicationVersion = newApplicationVersion;
 }
-bool SessionInfo::applicationVersionNull() const {
+bool SessionInfoDto::applicationVersionNull() const {
 	return m_applicationVersion.isNull();
 }
 
-void SessionInfo::setApplicationVersionNull() {
+void SessionInfoDto::setApplicationVersionNull() {
 	m_applicationVersion.clear();
 
 }
-QSharedPointer<TranscodingInfo> SessionInfo::transcodingInfo() const { return m_transcodingInfo; }
+QSharedPointer<TranscodingInfo> SessionInfoDto::transcodingInfo() const { return m_transcodingInfo; }
 
-void SessionInfo::setTranscodingInfo(QSharedPointer<TranscodingInfo> newTranscodingInfo) {
+void SessionInfoDto::setTranscodingInfo(QSharedPointer<TranscodingInfo> newTranscodingInfo) {
 	m_transcodingInfo = newTranscodingInfo;
 }
 
-bool SessionInfo::isActive() const { return m_isActive; }
+bool SessionInfoDto::isActive() const { return m_isActive; }
 
-void SessionInfo::setIsActive(bool newIsActive) {
+void SessionInfoDto::setIsActive(bool newIsActive) {
 	m_isActive = newIsActive;
 }
 
-bool SessionInfo::supportsMediaControl() const { return m_supportsMediaControl; }
+bool SessionInfoDto::supportsMediaControl() const { return m_supportsMediaControl; }
 
-void SessionInfo::setSupportsMediaControl(bool newSupportsMediaControl) {
+void SessionInfoDto::setSupportsMediaControl(bool newSupportsMediaControl) {
 	m_supportsMediaControl = newSupportsMediaControl;
 }
 
-bool SessionInfo::supportsRemoteControl() const { return m_supportsRemoteControl; }
+bool SessionInfoDto::supportsRemoteControl() const { return m_supportsRemoteControl; }
 
-void SessionInfo::setSupportsRemoteControl(bool newSupportsRemoteControl) {
+void SessionInfoDto::setSupportsRemoteControl(bool newSupportsRemoteControl) {
 	m_supportsRemoteControl = newSupportsRemoteControl;
 }
 
-QList<QueueItem> SessionInfo::nowPlayingQueue() const { return m_nowPlayingQueue; }
+QList<QueueItem> SessionInfoDto::nowPlayingQueue() const { return m_nowPlayingQueue; }
 
-void SessionInfo::setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue) {
+void SessionInfoDto::setNowPlayingQueue(QList<QueueItem> newNowPlayingQueue) {
 	m_nowPlayingQueue = newNowPlayingQueue;
 }
-bool SessionInfo::nowPlayingQueueNull() const {
+bool SessionInfoDto::nowPlayingQueueNull() const {
 	return m_nowPlayingQueue.size() == 0;
 }
 
-void SessionInfo::setNowPlayingQueueNull() {
+void SessionInfoDto::setNowPlayingQueueNull() {
 	m_nowPlayingQueue.clear();
 
 }
-bool SessionInfo::hasCustomDeviceName() const { return m_hasCustomDeviceName; }
+QList<BaseItemDto> SessionInfoDto::nowPlayingQueueFullItems() const { return m_nowPlayingQueueFullItems; }
 
-void SessionInfo::setHasCustomDeviceName(bool newHasCustomDeviceName) {
+void SessionInfoDto::setNowPlayingQueueFullItems(QList<BaseItemDto> newNowPlayingQueueFullItems) {
+	m_nowPlayingQueueFullItems = newNowPlayingQueueFullItems;
+}
+bool SessionInfoDto::nowPlayingQueueFullItemsNull() const {
+	return m_nowPlayingQueueFullItems.size() == 0;
+}
+
+void SessionInfoDto::setNowPlayingQueueFullItemsNull() {
+	m_nowPlayingQueueFullItems.clear();
+
+}
+bool SessionInfoDto::hasCustomDeviceName() const { return m_hasCustomDeviceName; }
+
+void SessionInfoDto::setHasCustomDeviceName(bool newHasCustomDeviceName) {
 	m_hasCustomDeviceName = newHasCustomDeviceName;
 }
 
-QString SessionInfo::playlistItemId() const { return m_playlistItemId; }
+QString SessionInfoDto::playlistItemId() const { return m_playlistItemId; }
 
-void SessionInfo::setPlaylistItemId(QString newPlaylistItemId) {
+void SessionInfoDto::setPlaylistItemId(QString newPlaylistItemId) {
 	m_playlistItemId = newPlaylistItemId;
 }
-bool SessionInfo::playlistItemIdNull() const {
+bool SessionInfoDto::playlistItemIdNull() const {
 	return m_playlistItemId.isNull();
 }
 
-void SessionInfo::setPlaylistItemIdNull() {
+void SessionInfoDto::setPlaylistItemIdNull() {
 	m_playlistItemId.clear();
 
 }
-QString SessionInfo::serverId() const { return m_serverId; }
+QString SessionInfoDto::serverId() const { return m_serverId; }
 
-void SessionInfo::setServerId(QString newServerId) {
+void SessionInfoDto::setServerId(QString newServerId) {
 	m_serverId = newServerId;
 }
-bool SessionInfo::serverIdNull() const {
+bool SessionInfoDto::serverIdNull() const {
 	return m_serverId.isNull();
 }
 
-void SessionInfo::setServerIdNull() {
+void SessionInfoDto::setServerIdNull() {
 	m_serverId.clear();
 
 }
-QString SessionInfo::userPrimaryImageTag() const { return m_userPrimaryImageTag; }
+QString SessionInfoDto::userPrimaryImageTag() const { return m_userPrimaryImageTag; }
 
-void SessionInfo::setUserPrimaryImageTag(QString newUserPrimaryImageTag) {
+void SessionInfoDto::setUserPrimaryImageTag(QString newUserPrimaryImageTag) {
 	m_userPrimaryImageTag = newUserPrimaryImageTag;
 }
-bool SessionInfo::userPrimaryImageTagNull() const {
+bool SessionInfoDto::userPrimaryImageTagNull() const {
 	return m_userPrimaryImageTag.isNull();
 }
 
-void SessionInfo::setUserPrimaryImageTagNull() {
+void SessionInfoDto::setUserPrimaryImageTagNull() {
 	m_userPrimaryImageTag.clear();
 
 }
-QList<GeneralCommandType> SessionInfo::supportedCommands() const { return m_supportedCommands; }
+QList<GeneralCommandType> SessionInfoDto::supportedCommands() const { return m_supportedCommands; }
 
-void SessionInfo::setSupportedCommands(QList<GeneralCommandType> newSupportedCommands) {
+void SessionInfoDto::setSupportedCommands(QList<GeneralCommandType> newSupportedCommands) {
 	m_supportedCommands = newSupportedCommands;
 }
-bool SessionInfo::supportedCommandsNull() const {
-	return m_supportedCommands.size() == 0;
-}
 
-void SessionInfo::setSupportedCommandsNull() {
-	m_supportedCommands.clear();
-
-}
 
 } // NS DTO
 
 namespace Support {
 
-using SessionInfo = Jellyfin::DTO::SessionInfo;
+using SessionInfoDto = Jellyfin::DTO::SessionInfoDto;
 
 template <>
-SessionInfo fromJsonValue(const QJsonValue &source, convertType<SessionInfo>) {
+SessionInfoDto fromJsonValue(const QJsonValue &source, convertType<SessionInfoDto>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return SessionInfo::fromJson(source.toObject());
+	return SessionInfoDto::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const SessionInfo &source, convertType<SessionInfo>) {
+QJsonValue toJsonValue(const SessionInfoDto &source, convertType<SessionInfoDto>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/sessionmessagetype.cpp b/core/src/dto/sessionmessagetype.cpp
new file mode 100644
index 0000000..9751f7c
--- /dev/null
+++ b/core/src/dto/sessionmessagetype.cpp
@@ -0,0 +1,233 @@
+/*
+ * 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/dto/sessionmessagetype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SessionMessageTypeClass::SessionMessageTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using SessionMessageType = Jellyfin::DTO::SessionMessageType;
+
+template <>
+SessionMessageType fromJsonValue(const QJsonValue &source, convertType<SessionMessageType>) {
+	if (!source.isString()) return SessionMessageType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("ForceKeepAlive")) {
+		return SessionMessageType::ForceKeepAlive;
+	}
+	if (str == QStringLiteral("GeneralCommand")) {
+		return SessionMessageType::GeneralCommand;
+	}
+	if (str == QStringLiteral("UserDataChanged")) {
+		return SessionMessageType::UserDataChanged;
+	}
+	if (str == QStringLiteral("Sessions")) {
+		return SessionMessageType::Sessions;
+	}
+	if (str == QStringLiteral("Play")) {
+		return SessionMessageType::Play;
+	}
+	if (str == QStringLiteral("SyncPlayCommand")) {
+		return SessionMessageType::SyncPlayCommand;
+	}
+	if (str == QStringLiteral("SyncPlayGroupUpdate")) {
+		return SessionMessageType::SyncPlayGroupUpdate;
+	}
+	if (str == QStringLiteral("Playstate")) {
+		return SessionMessageType::Playstate;
+	}
+	if (str == QStringLiteral("RestartRequired")) {
+		return SessionMessageType::RestartRequired;
+	}
+	if (str == QStringLiteral("ServerShuttingDown")) {
+		return SessionMessageType::ServerShuttingDown;
+	}
+	if (str == QStringLiteral("ServerRestarting")) {
+		return SessionMessageType::ServerRestarting;
+	}
+	if (str == QStringLiteral("LibraryChanged")) {
+		return SessionMessageType::LibraryChanged;
+	}
+	if (str == QStringLiteral("UserDeleted")) {
+		return SessionMessageType::UserDeleted;
+	}
+	if (str == QStringLiteral("UserUpdated")) {
+		return SessionMessageType::UserUpdated;
+	}
+	if (str == QStringLiteral("SeriesTimerCreated")) {
+		return SessionMessageType::SeriesTimerCreated;
+	}
+	if (str == QStringLiteral("TimerCreated")) {
+		return SessionMessageType::TimerCreated;
+	}
+	if (str == QStringLiteral("SeriesTimerCancelled")) {
+		return SessionMessageType::SeriesTimerCancelled;
+	}
+	if (str == QStringLiteral("TimerCancelled")) {
+		return SessionMessageType::TimerCancelled;
+	}
+	if (str == QStringLiteral("RefreshProgress")) {
+		return SessionMessageType::RefreshProgress;
+	}
+	if (str == QStringLiteral("ScheduledTaskEnded")) {
+		return SessionMessageType::ScheduledTaskEnded;
+	}
+	if (str == QStringLiteral("PackageInstallationCancelled")) {
+		return SessionMessageType::PackageInstallationCancelled;
+	}
+	if (str == QStringLiteral("PackageInstallationFailed")) {
+		return SessionMessageType::PackageInstallationFailed;
+	}
+	if (str == QStringLiteral("PackageInstallationCompleted")) {
+		return SessionMessageType::PackageInstallationCompleted;
+	}
+	if (str == QStringLiteral("PackageInstalling")) {
+		return SessionMessageType::PackageInstalling;
+	}
+	if (str == QStringLiteral("PackageUninstalled")) {
+		return SessionMessageType::PackageUninstalled;
+	}
+	if (str == QStringLiteral("ActivityLogEntry")) {
+		return SessionMessageType::ActivityLogEntry;
+	}
+	if (str == QStringLiteral("ScheduledTasksInfo")) {
+		return SessionMessageType::ScheduledTasksInfo;
+	}
+	if (str == QStringLiteral("ActivityLogEntryStart")) {
+		return SessionMessageType::ActivityLogEntryStart;
+	}
+	if (str == QStringLiteral("ActivityLogEntryStop")) {
+		return SessionMessageType::ActivityLogEntryStop;
+	}
+	if (str == QStringLiteral("SessionsStart")) {
+		return SessionMessageType::SessionsStart;
+	}
+	if (str == QStringLiteral("SessionsStop")) {
+		return SessionMessageType::SessionsStop;
+	}
+	if (str == QStringLiteral("ScheduledTasksInfoStart")) {
+		return SessionMessageType::ScheduledTasksInfoStart;
+	}
+	if (str == QStringLiteral("ScheduledTasksInfoStop")) {
+		return SessionMessageType::ScheduledTasksInfoStop;
+	}
+	if (str == QStringLiteral("KeepAlive")) {
+		return SessionMessageType::KeepAlive;
+	}
+	
+	return SessionMessageType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const SessionMessageType &source, convertType<SessionMessageType>) {
+	switch(source) {
+	case SessionMessageType::ForceKeepAlive:
+		return QStringLiteral("ForceKeepAlive");
+	case SessionMessageType::GeneralCommand:
+		return QStringLiteral("GeneralCommand");
+	case SessionMessageType::UserDataChanged:
+		return QStringLiteral("UserDataChanged");
+	case SessionMessageType::Sessions:
+		return QStringLiteral("Sessions");
+	case SessionMessageType::Play:
+		return QStringLiteral("Play");
+	case SessionMessageType::SyncPlayCommand:
+		return QStringLiteral("SyncPlayCommand");
+	case SessionMessageType::SyncPlayGroupUpdate:
+		return QStringLiteral("SyncPlayGroupUpdate");
+	case SessionMessageType::Playstate:
+		return QStringLiteral("Playstate");
+	case SessionMessageType::RestartRequired:
+		return QStringLiteral("RestartRequired");
+	case SessionMessageType::ServerShuttingDown:
+		return QStringLiteral("ServerShuttingDown");
+	case SessionMessageType::ServerRestarting:
+		return QStringLiteral("ServerRestarting");
+	case SessionMessageType::LibraryChanged:
+		return QStringLiteral("LibraryChanged");
+	case SessionMessageType::UserDeleted:
+		return QStringLiteral("UserDeleted");
+	case SessionMessageType::UserUpdated:
+		return QStringLiteral("UserUpdated");
+	case SessionMessageType::SeriesTimerCreated:
+		return QStringLiteral("SeriesTimerCreated");
+	case SessionMessageType::TimerCreated:
+		return QStringLiteral("TimerCreated");
+	case SessionMessageType::SeriesTimerCancelled:
+		return QStringLiteral("SeriesTimerCancelled");
+	case SessionMessageType::TimerCancelled:
+		return QStringLiteral("TimerCancelled");
+	case SessionMessageType::RefreshProgress:
+		return QStringLiteral("RefreshProgress");
+	case SessionMessageType::ScheduledTaskEnded:
+		return QStringLiteral("ScheduledTaskEnded");
+	case SessionMessageType::PackageInstallationCancelled:
+		return QStringLiteral("PackageInstallationCancelled");
+	case SessionMessageType::PackageInstallationFailed:
+		return QStringLiteral("PackageInstallationFailed");
+	case SessionMessageType::PackageInstallationCompleted:
+		return QStringLiteral("PackageInstallationCompleted");
+	case SessionMessageType::PackageInstalling:
+		return QStringLiteral("PackageInstalling");
+	case SessionMessageType::PackageUninstalled:
+		return QStringLiteral("PackageUninstalled");
+	case SessionMessageType::ActivityLogEntry:
+		return QStringLiteral("ActivityLogEntry");
+	case SessionMessageType::ScheduledTasksInfo:
+		return QStringLiteral("ScheduledTasksInfo");
+	case SessionMessageType::ActivityLogEntryStart:
+		return QStringLiteral("ActivityLogEntryStart");
+	case SessionMessageType::ActivityLogEntryStop:
+		return QStringLiteral("ActivityLogEntryStop");
+	case SessionMessageType::SessionsStart:
+		return QStringLiteral("SessionsStart");
+	case SessionMessageType::SessionsStop:
+		return QStringLiteral("SessionsStop");
+	case SessionMessageType::ScheduledTasksInfoStart:
+		return QStringLiteral("ScheduledTasksInfoStart");
+	case SessionMessageType::ScheduledTasksInfoStop:
+		return QStringLiteral("ScheduledTasksInfoStop");
+	case SessionMessageType::KeepAlive:
+		return QStringLiteral("KeepAlive");
+
+	case SessionMessageType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/sessionsmessage.cpp b/core/src/dto/sessionsmessage.cpp
new file mode 100644
index 0000000..56b4581
--- /dev/null
+++ b/core/src/dto/sessionsmessage.cpp
@@ -0,0 +1,129 @@
+/*
+ * 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/dto/sessionsmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SessionsMessage::SessionsMessage() {}
+SessionsMessage::SessionsMessage (
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+SessionsMessage::SessionsMessage(const SessionsMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void SessionsMessage::replaceData(SessionsMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+SessionsMessage SessionsMessage::fromJson(QJsonObject source) {
+	SessionsMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SessionsMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QList<SessionInfoDto>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SessionsMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.size() == 0)) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QList<SessionInfoDto>>(m_data);
+	}
+			
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QList<SessionInfoDto> SessionsMessage::data() const { return m_data; }
+
+void SessionsMessage::setData(QList<SessionInfoDto> newData) {
+	m_data = newData;
+}
+bool SessionsMessage::dataNull() const {
+	return m_data.size() == 0;
+}
+
+void SessionsMessage::setDataNull() {
+	m_data.clear();
+
+}
+QString SessionsMessage::messageId() const { return m_messageId; }
+
+void SessionsMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType SessionsMessage::messageType() const { return m_messageType; }
+
+void SessionsMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SessionsMessage = Jellyfin::DTO::SessionsMessage;
+
+template <>
+SessionsMessage fromJsonValue(const QJsonValue &source, convertType<SessionsMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SessionsMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SessionsMessage &source, convertType<SessionsMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/sessionsstartmessage.cpp b/core/src/dto/sessionsstartmessage.cpp
new file mode 100644
index 0000000..a82e708
--- /dev/null
+++ b/core/src/dto/sessionsstartmessage.cpp
@@ -0,0 +1,117 @@
+/*
+ * 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/dto/sessionsstartmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SessionsStartMessage::SessionsStartMessage() {}
+SessionsStartMessage::SessionsStartMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+SessionsStartMessage::SessionsStartMessage(const SessionsStartMessage &other) :
+
+	m_data(other.m_data),
+	m_messageType(other.m_messageType){}
+
+
+void SessionsStartMessage::replaceData(SessionsStartMessage &other) {
+	m_data = other.m_data;
+	m_messageType = other.m_messageType;
+}
+
+SessionsStartMessage SessionsStartMessage::fromJson(QJsonObject source) {
+	SessionsStartMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SessionsStartMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SessionsStartMessage::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_data.isNull())) {
+		result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);
+	}
+			
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString SessionsStartMessage::data() const { return m_data; }
+
+void SessionsStartMessage::setData(QString newData) {
+	m_data = newData;
+}
+bool SessionsStartMessage::dataNull() const {
+	return m_data.isNull();
+}
+
+void SessionsStartMessage::setDataNull() {
+	m_data.clear();
+
+}
+SessionMessageType SessionsStartMessage::messageType() const { return m_messageType; }
+
+void SessionsStartMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SessionsStartMessage = Jellyfin::DTO::SessionsStartMessage;
+
+template <>
+SessionsStartMessage fromJsonValue(const QJsonValue &source, convertType<SessionsStartMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SessionsStartMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SessionsStartMessage &source, convertType<SessionsStartMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/sessionsstopmessage.cpp b/core/src/dto/sessionsstopmessage.cpp
new file mode 100644
index 0000000..75868eb
--- /dev/null
+++ b/core/src/dto/sessionsstopmessage.cpp
@@ -0,0 +1,96 @@
+/*
+ * 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/dto/sessionsstopmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SessionsStopMessage::SessionsStopMessage() {}
+SessionsStopMessage::SessionsStopMessage (
+		SessionMessageType messageType 
+		) :
+	m_messageType(messageType) { }
+
+
+
+SessionsStopMessage::SessionsStopMessage(const SessionsStopMessage &other) :
+
+	m_messageType(other.m_messageType){}
+
+
+void SessionsStopMessage::replaceData(SessionsStopMessage &other) {
+	m_messageType = other.m_messageType;
+}
+
+SessionsStopMessage SessionsStopMessage::fromJson(QJsonObject source) {
+	SessionsStopMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SessionsStopMessage::setFromJson(QJsonObject source) {
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SessionsStopMessage::toJson() const {
+	QJsonObject result;
+	
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+SessionMessageType SessionsStopMessage::messageType() const { return m_messageType; }
+
+void SessionsStopMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SessionsStopMessage = Jellyfin::DTO::SessionsStopMessage;
+
+template <>
+SessionsStopMessage fromJsonValue(const QJsonValue &source, convertType<SessionsStopMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SessionsStopMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SessionsStopMessage &source, convertType<SessionsStopMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/songinfo.cpp b/core/src/dto/songinfo.cpp
index 82e8709..43b413a 100644
--- a/core/src/dto/songinfo.cpp
+++ b/core/src/dto/songinfo.cpp
@@ -43,6 +43,7 @@ SongInfo::SongInfo (
 SongInfo::SongInfo(const SongInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -59,6 +60,7 @@ SongInfo::SongInfo(const SongInfo &other) :
 
 void SongInfo::replaceData(SongInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -82,6 +84,7 @@ SongInfo SongInfo::fromJson(QJsonObject source) {
 
 void SongInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -106,6 +109,11 @@ QJsonObject SongInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -176,6 +184,19 @@ bool SongInfo::nameNull() const {
 void SongInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString SongInfo::originalTitle() const { return m_originalTitle; }
+
+void SongInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool SongInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void SongInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString SongInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/objectgroupupdate.cpp b/core/src/dto/stringgroupupdate.cpp
similarity index 65%
rename from core/src/dto/objectgroupupdate.cpp
rename to core/src/dto/stringgroupupdate.cpp
index 8d36d97..9f5ac80 100644
--- a/core/src/dto/objectgroupupdate.cpp
+++ b/core/src/dto/stringgroupupdate.cpp
@@ -27,16 +27,16 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/objectgroupupdate.h>
+#include <JellyfinQt/dto/stringgroupupdate.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-ObjectGroupUpdate::ObjectGroupUpdate() {}
-ObjectGroupUpdate::ObjectGroupUpdate (
+StringGroupUpdate::StringGroupUpdate() {}
+StringGroupUpdate::StringGroupUpdate (
 		QString groupId, 
 		GroupUpdateType type, 
-		QVariant data 
+		QString data 
 		) :
 	m_groupId(groupId),
 	m_type(type),
@@ -44,57 +44,57 @@ ObjectGroupUpdate::ObjectGroupUpdate (
 
 
 
-ObjectGroupUpdate::ObjectGroupUpdate(const ObjectGroupUpdate &other) :
+StringGroupUpdate::StringGroupUpdate(const StringGroupUpdate &other) :
 
 	m_groupId(other.m_groupId),
 	m_type(other.m_type),
 	m_data(other.m_data){}
 
 
-void ObjectGroupUpdate::replaceData(ObjectGroupUpdate &other) {
+void StringGroupUpdate::replaceData(StringGroupUpdate &other) {
 	m_groupId = other.m_groupId;
 	m_type = other.m_type;
 	m_data = other.m_data;
 }
 
-ObjectGroupUpdate ObjectGroupUpdate::fromJson(QJsonObject source) {
-	ObjectGroupUpdate instance;
+StringGroupUpdate StringGroupUpdate::fromJson(QJsonObject source) {
+	StringGroupUpdate instance;
 	instance.setFromJson(source);
 	return instance;
 }
 
 
-void ObjectGroupUpdate::setFromJson(QJsonObject source) {
+void StringGroupUpdate::setFromJson(QJsonObject source) {
 	m_groupId = Jellyfin::Support::fromJsonValue<QString>(source["GroupId"]);
 	m_type = Jellyfin::Support::fromJsonValue<GroupUpdateType>(source["Type"]);
-	m_data = Jellyfin::Support::fromJsonValue<QVariant>(source["Data"]);
+	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
 
 }
 	
-QJsonObject ObjectGroupUpdate::toJson() const {
+QJsonObject StringGroupUpdate::toJson() const {
 	QJsonObject result;
 	
 	result["GroupId"] = Jellyfin::Support::toJsonValue<QString>(m_groupId);		
 	result["Type"] = Jellyfin::Support::toJsonValue<GroupUpdateType>(m_type);		
-	result["Data"] = Jellyfin::Support::toJsonValue<QVariant>(m_data);	
+	result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);	
 	return result;
 }
 
-QString ObjectGroupUpdate::groupId() const { return m_groupId; }
+QString StringGroupUpdate::groupId() const { return m_groupId; }
 
-void ObjectGroupUpdate::setGroupId(QString newGroupId) {
+void StringGroupUpdate::setGroupId(QString newGroupId) {
 	m_groupId = newGroupId;
 }
 
-GroupUpdateType ObjectGroupUpdate::type() const { return m_type; }
+GroupUpdateType StringGroupUpdate::type() const { return m_type; }
 
-void ObjectGroupUpdate::setType(GroupUpdateType newType) {
+void StringGroupUpdate::setType(GroupUpdateType newType) {
 	m_type = newType;
 }
 
-QVariant ObjectGroupUpdate::data() const { return m_data; }
+QString StringGroupUpdate::data() const { return m_data; }
 
-void ObjectGroupUpdate::setData(QVariant newData) {
+void StringGroupUpdate::setData(QString newData) {
 	m_data = newData;
 }
 
@@ -103,16 +103,16 @@ void ObjectGroupUpdate::setData(QVariant newData) {
 
 namespace Support {
 
-using ObjectGroupUpdate = Jellyfin::DTO::ObjectGroupUpdate;
+using StringGroupUpdate = Jellyfin::DTO::StringGroupUpdate;
 
 template <>
-ObjectGroupUpdate fromJsonValue(const QJsonValue &source, convertType<ObjectGroupUpdate>) {
+StringGroupUpdate fromJsonValue(const QJsonValue &source, convertType<StringGroupUpdate>) {
 	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return ObjectGroupUpdate::fromJson(source.toObject());
+	return StringGroupUpdate::fromJson(source.toObject());
 }
 
 template<>
-QJsonValue toJsonValue(const ObjectGroupUpdate &source, convertType<ObjectGroupUpdate>) {
+QJsonValue toJsonValue(const StringGroupUpdate &source, convertType<StringGroupUpdate>) {
 	return source.toJson();
 }
 
diff --git a/core/src/dto/subtitledeliverymethod.cpp b/core/src/dto/subtitledeliverymethod.cpp
index b30f845..f5c8f78 100644
--- a/core/src/dto/subtitledeliverymethod.cpp
+++ b/core/src/dto/subtitledeliverymethod.cpp
@@ -57,6 +57,9 @@ SubtitleDeliveryMethod fromJsonValue(const QJsonValue &source, convertType<Subti
 	if (str == QStringLiteral("Hls")) {
 		return SubtitleDeliveryMethod::Hls;
 	}
+	if (str == QStringLiteral("Drop")) {
+		return SubtitleDeliveryMethod::Drop;
+	}
 	
 	return SubtitleDeliveryMethod::EnumNotSet;
 }
@@ -72,6 +75,8 @@ QJsonValue toJsonValue(const SubtitleDeliveryMethod &source, convertType<Subtitl
 		return QStringLiteral("External");
 	case SubtitleDeliveryMethod::Hls:
 		return QStringLiteral("Hls");
+	case SubtitleDeliveryMethod::Drop:
+		return QStringLiteral("Drop");
 
 	case SubtitleDeliveryMethod::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/subtitleoptions.cpp b/core/src/dto/subtitleoptions.cpp
new file mode 100644
index 0000000..f8860c0
--- /dev/null
+++ b/core/src/dto/subtitleoptions.cpp
@@ -0,0 +1,219 @@
+/*
+ * 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/dto/subtitleoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SubtitleOptions::SubtitleOptions() {}
+SubtitleOptions::SubtitleOptions (
+		bool skipIfEmbeddedSubtitlesPresent, 
+		bool skipIfAudioTrackMatches, 
+		bool downloadMovieSubtitles, 
+		bool downloadEpisodeSubtitles, 
+		bool isOpenSubtitleVipAccount, 
+		bool requirePerfectMatch 
+		) :
+	m_skipIfEmbeddedSubtitlesPresent(skipIfEmbeddedSubtitlesPresent),
+	m_skipIfAudioTrackMatches(skipIfAudioTrackMatches),
+	m_downloadMovieSubtitles(downloadMovieSubtitles),
+	m_downloadEpisodeSubtitles(downloadEpisodeSubtitles),
+	m_isOpenSubtitleVipAccount(isOpenSubtitleVipAccount),
+	m_requirePerfectMatch(requirePerfectMatch) { }
+
+
+
+SubtitleOptions::SubtitleOptions(const SubtitleOptions &other) :
+
+	m_skipIfEmbeddedSubtitlesPresent(other.m_skipIfEmbeddedSubtitlesPresent),
+	m_skipIfAudioTrackMatches(other.m_skipIfAudioTrackMatches),
+	m_downloadLanguages(other.m_downloadLanguages),
+	m_downloadMovieSubtitles(other.m_downloadMovieSubtitles),
+	m_downloadEpisodeSubtitles(other.m_downloadEpisodeSubtitles),
+	m_openSubtitlesUsername(other.m_openSubtitlesUsername),
+	m_openSubtitlesPasswordHash(other.m_openSubtitlesPasswordHash),
+	m_isOpenSubtitleVipAccount(other.m_isOpenSubtitleVipAccount),
+	m_requirePerfectMatch(other.m_requirePerfectMatch){}
+
+
+void SubtitleOptions::replaceData(SubtitleOptions &other) {
+	m_skipIfEmbeddedSubtitlesPresent = other.m_skipIfEmbeddedSubtitlesPresent;
+	m_skipIfAudioTrackMatches = other.m_skipIfAudioTrackMatches;
+	m_downloadLanguages = other.m_downloadLanguages;
+	m_downloadMovieSubtitles = other.m_downloadMovieSubtitles;
+	m_downloadEpisodeSubtitles = other.m_downloadEpisodeSubtitles;
+	m_openSubtitlesUsername = other.m_openSubtitlesUsername;
+	m_openSubtitlesPasswordHash = other.m_openSubtitlesPasswordHash;
+	m_isOpenSubtitleVipAccount = other.m_isOpenSubtitleVipAccount;
+	m_requirePerfectMatch = other.m_requirePerfectMatch;
+}
+
+SubtitleOptions SubtitleOptions::fromJson(QJsonObject source) {
+	SubtitleOptions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SubtitleOptions::setFromJson(QJsonObject source) {
+	m_skipIfEmbeddedSubtitlesPresent = Jellyfin::Support::fromJsonValue<bool>(source["SkipIfEmbeddedSubtitlesPresent"]);
+	m_skipIfAudioTrackMatches = Jellyfin::Support::fromJsonValue<bool>(source["SkipIfAudioTrackMatches"]);
+	m_downloadLanguages = Jellyfin::Support::fromJsonValue<QStringList>(source["DownloadLanguages"]);
+	m_downloadMovieSubtitles = Jellyfin::Support::fromJsonValue<bool>(source["DownloadMovieSubtitles"]);
+	m_downloadEpisodeSubtitles = Jellyfin::Support::fromJsonValue<bool>(source["DownloadEpisodeSubtitles"]);
+	m_openSubtitlesUsername = Jellyfin::Support::fromJsonValue<QString>(source["OpenSubtitlesUsername"]);
+	m_openSubtitlesPasswordHash = Jellyfin::Support::fromJsonValue<QString>(source["OpenSubtitlesPasswordHash"]);
+	m_isOpenSubtitleVipAccount = Jellyfin::Support::fromJsonValue<bool>(source["IsOpenSubtitleVipAccount"]);
+	m_requirePerfectMatch = Jellyfin::Support::fromJsonValue<bool>(source["RequirePerfectMatch"]);
+
+}
+	
+QJsonObject SubtitleOptions::toJson() const {
+	QJsonObject result;
+	
+	result["SkipIfEmbeddedSubtitlesPresent"] = Jellyfin::Support::toJsonValue<bool>(m_skipIfEmbeddedSubtitlesPresent);		
+	result["SkipIfAudioTrackMatches"] = Jellyfin::Support::toJsonValue<bool>(m_skipIfAudioTrackMatches);		
+	
+	if (!(m_downloadLanguages.size() == 0)) {
+		result["DownloadLanguages"] = Jellyfin::Support::toJsonValue<QStringList>(m_downloadLanguages);
+	}
+			
+	result["DownloadMovieSubtitles"] = Jellyfin::Support::toJsonValue<bool>(m_downloadMovieSubtitles);		
+	result["DownloadEpisodeSubtitles"] = Jellyfin::Support::toJsonValue<bool>(m_downloadEpisodeSubtitles);		
+	
+	if (!(m_openSubtitlesUsername.isNull())) {
+		result["OpenSubtitlesUsername"] = Jellyfin::Support::toJsonValue<QString>(m_openSubtitlesUsername);
+	}
+			
+	
+	if (!(m_openSubtitlesPasswordHash.isNull())) {
+		result["OpenSubtitlesPasswordHash"] = Jellyfin::Support::toJsonValue<QString>(m_openSubtitlesPasswordHash);
+	}
+			
+	result["IsOpenSubtitleVipAccount"] = Jellyfin::Support::toJsonValue<bool>(m_isOpenSubtitleVipAccount);		
+	result["RequirePerfectMatch"] = Jellyfin::Support::toJsonValue<bool>(m_requirePerfectMatch);	
+	return result;
+}
+
+bool SubtitleOptions::skipIfEmbeddedSubtitlesPresent() const { return m_skipIfEmbeddedSubtitlesPresent; }
+
+void SubtitleOptions::setSkipIfEmbeddedSubtitlesPresent(bool newSkipIfEmbeddedSubtitlesPresent) {
+	m_skipIfEmbeddedSubtitlesPresent = newSkipIfEmbeddedSubtitlesPresent;
+}
+
+bool SubtitleOptions::skipIfAudioTrackMatches() const { return m_skipIfAudioTrackMatches; }
+
+void SubtitleOptions::setSkipIfAudioTrackMatches(bool newSkipIfAudioTrackMatches) {
+	m_skipIfAudioTrackMatches = newSkipIfAudioTrackMatches;
+}
+
+QStringList SubtitleOptions::downloadLanguages() const { return m_downloadLanguages; }
+
+void SubtitleOptions::setDownloadLanguages(QStringList newDownloadLanguages) {
+	m_downloadLanguages = newDownloadLanguages;
+}
+bool SubtitleOptions::downloadLanguagesNull() const {
+	return m_downloadLanguages.size() == 0;
+}
+
+void SubtitleOptions::setDownloadLanguagesNull() {
+	m_downloadLanguages.clear();
+
+}
+bool SubtitleOptions::downloadMovieSubtitles() const { return m_downloadMovieSubtitles; }
+
+void SubtitleOptions::setDownloadMovieSubtitles(bool newDownloadMovieSubtitles) {
+	m_downloadMovieSubtitles = newDownloadMovieSubtitles;
+}
+
+bool SubtitleOptions::downloadEpisodeSubtitles() const { return m_downloadEpisodeSubtitles; }
+
+void SubtitleOptions::setDownloadEpisodeSubtitles(bool newDownloadEpisodeSubtitles) {
+	m_downloadEpisodeSubtitles = newDownloadEpisodeSubtitles;
+}
+
+QString SubtitleOptions::openSubtitlesUsername() const { return m_openSubtitlesUsername; }
+
+void SubtitleOptions::setOpenSubtitlesUsername(QString newOpenSubtitlesUsername) {
+	m_openSubtitlesUsername = newOpenSubtitlesUsername;
+}
+bool SubtitleOptions::openSubtitlesUsernameNull() const {
+	return m_openSubtitlesUsername.isNull();
+}
+
+void SubtitleOptions::setOpenSubtitlesUsernameNull() {
+	m_openSubtitlesUsername.clear();
+
+}
+QString SubtitleOptions::openSubtitlesPasswordHash() const { return m_openSubtitlesPasswordHash; }
+
+void SubtitleOptions::setOpenSubtitlesPasswordHash(QString newOpenSubtitlesPasswordHash) {
+	m_openSubtitlesPasswordHash = newOpenSubtitlesPasswordHash;
+}
+bool SubtitleOptions::openSubtitlesPasswordHashNull() const {
+	return m_openSubtitlesPasswordHash.isNull();
+}
+
+void SubtitleOptions::setOpenSubtitlesPasswordHashNull() {
+	m_openSubtitlesPasswordHash.clear();
+
+}
+bool SubtitleOptions::isOpenSubtitleVipAccount() const { return m_isOpenSubtitleVipAccount; }
+
+void SubtitleOptions::setIsOpenSubtitleVipAccount(bool newIsOpenSubtitleVipAccount) {
+	m_isOpenSubtitleVipAccount = newIsOpenSubtitleVipAccount;
+}
+
+bool SubtitleOptions::requirePerfectMatch() const { return m_requirePerfectMatch; }
+
+void SubtitleOptions::setRequirePerfectMatch(bool newRequirePerfectMatch) {
+	m_requirePerfectMatch = newRequirePerfectMatch;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SubtitleOptions = Jellyfin::DTO::SubtitleOptions;
+
+template <>
+SubtitleOptions fromJsonValue(const QJsonValue &source, convertType<SubtitleOptions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SubtitleOptions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SubtitleOptions &source, convertType<SubtitleOptions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/syncplaycommandmessage.cpp b/core/src/dto/syncplaycommandmessage.cpp
new file mode 100644
index 0000000..4b3b674
--- /dev/null
+++ b/core/src/dto/syncplaycommandmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/syncplaycommandmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SyncPlayCommandMessage::SyncPlayCommandMessage() {}
+SyncPlayCommandMessage::SyncPlayCommandMessage (
+		QSharedPointer<SendCommand> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+SyncPlayCommandMessage::SyncPlayCommandMessage(const SyncPlayCommandMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void SyncPlayCommandMessage::replaceData(SyncPlayCommandMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+SyncPlayCommandMessage SyncPlayCommandMessage::fromJson(QJsonObject source) {
+	SyncPlayCommandMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SyncPlayCommandMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<SendCommand>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SyncPlayCommandMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<SendCommand>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<SendCommand> SyncPlayCommandMessage::data() const { return m_data; }
+
+void SyncPlayCommandMessage::setData(QSharedPointer<SendCommand> newData) {
+	m_data = newData;
+}
+
+QString SyncPlayCommandMessage::messageId() const { return m_messageId; }
+
+void SyncPlayCommandMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType SyncPlayCommandMessage::messageType() const { return m_messageType; }
+
+void SyncPlayCommandMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayCommandMessage = Jellyfin::DTO::SyncPlayCommandMessage;
+
+template <>
+SyncPlayCommandMessage fromJsonValue(const QJsonValue &source, convertType<SyncPlayCommandMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SyncPlayCommandMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SyncPlayCommandMessage &source, convertType<SyncPlayCommandMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/syncplaygroupupdatecommandmessage.cpp b/core/src/dto/syncplaygroupupdatecommandmessage.cpp
new file mode 100644
index 0000000..ad383e3
--- /dev/null
+++ b/core/src/dto/syncplaygroupupdatecommandmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/syncplaygroupupdatecommandmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SyncPlayGroupUpdateCommandMessage::SyncPlayGroupUpdateCommandMessage() {}
+SyncPlayGroupUpdateCommandMessage::SyncPlayGroupUpdateCommandMessage (
+		QSharedPointer<GroupUpdate> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+SyncPlayGroupUpdateCommandMessage::SyncPlayGroupUpdateCommandMessage(const SyncPlayGroupUpdateCommandMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void SyncPlayGroupUpdateCommandMessage::replaceData(SyncPlayGroupUpdateCommandMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+SyncPlayGroupUpdateCommandMessage SyncPlayGroupUpdateCommandMessage::fromJson(QJsonObject source) {
+	SyncPlayGroupUpdateCommandMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SyncPlayGroupUpdateCommandMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<GroupUpdate>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject SyncPlayGroupUpdateCommandMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<GroupUpdate>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<GroupUpdate> SyncPlayGroupUpdateCommandMessage::data() const { return m_data; }
+
+void SyncPlayGroupUpdateCommandMessage::setData(QSharedPointer<GroupUpdate> newData) {
+	m_data = newData;
+}
+
+QString SyncPlayGroupUpdateCommandMessage::messageId() const { return m_messageId; }
+
+void SyncPlayGroupUpdateCommandMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType SyncPlayGroupUpdateCommandMessage::messageType() const { return m_messageType; }
+
+void SyncPlayGroupUpdateCommandMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayGroupUpdateCommandMessage = Jellyfin::DTO::SyncPlayGroupUpdateCommandMessage;
+
+template <>
+SyncPlayGroupUpdateCommandMessage fromJsonValue(const QJsonValue &source, convertType<SyncPlayGroupUpdateCommandMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SyncPlayGroupUpdateCommandMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SyncPlayGroupUpdateCommandMessage &source, convertType<SyncPlayGroupUpdateCommandMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/syncplayqueueitem.cpp b/core/src/dto/syncplayqueueitem.cpp
new file mode 100644
index 0000000..ceaddd7
--- /dev/null
+++ b/core/src/dto/syncplayqueueitem.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/syncplayqueueitem.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+SyncPlayQueueItem::SyncPlayQueueItem() {}
+SyncPlayQueueItem::SyncPlayQueueItem (
+		QString itemId, 
+		QString playlistItemId 
+		) :
+	m_itemId(itemId),
+	m_playlistItemId(playlistItemId) { }
+
+
+
+SyncPlayQueueItem::SyncPlayQueueItem(const SyncPlayQueueItem &other) :
+
+	m_itemId(other.m_itemId),
+	m_playlistItemId(other.m_playlistItemId){}
+
+
+void SyncPlayQueueItem::replaceData(SyncPlayQueueItem &other) {
+	m_itemId = other.m_itemId;
+	m_playlistItemId = other.m_playlistItemId;
+}
+
+SyncPlayQueueItem SyncPlayQueueItem::fromJson(QJsonObject source) {
+	SyncPlayQueueItem instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void SyncPlayQueueItem::setFromJson(QJsonObject source) {
+	m_itemId = Jellyfin::Support::fromJsonValue<QString>(source["ItemId"]);
+	m_playlistItemId = Jellyfin::Support::fromJsonValue<QString>(source["PlaylistItemId"]);
+
+}
+	
+QJsonObject SyncPlayQueueItem::toJson() const {
+	QJsonObject result;
+	
+	result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);		
+	result["PlaylistItemId"] = Jellyfin::Support::toJsonValue<QString>(m_playlistItemId);	
+	return result;
+}
+
+QString SyncPlayQueueItem::itemId() const { return m_itemId; }
+
+void SyncPlayQueueItem::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+QString SyncPlayQueueItem::playlistItemId() const { return m_playlistItemId; }
+
+void SyncPlayQueueItem::setPlaylistItemId(QString newPlaylistItemId) {
+	m_playlistItemId = newPlaylistItemId;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using SyncPlayQueueItem = Jellyfin::DTO::SyncPlayQueueItem;
+
+template <>
+SyncPlayQueueItem fromJsonValue(const QJsonValue &source, convertType<SyncPlayQueueItem>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return SyncPlayQueueItem::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const SyncPlayQueueItem &source, convertType<SyncPlayQueueItem>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/systeminfo.cpp b/core/src/dto/systeminfo.cpp
index 4aff8ce..c018513 100644
--- a/core/src/dto/systeminfo.cpp
+++ b/core/src/dto/systeminfo.cpp
@@ -38,11 +38,9 @@ SystemInfo::SystemInfo (
 		bool isShuttingDown, 
 		bool supportsLibraryMonitor, 
 		qint32 webSocketPortNumber, 
-		bool canSelfRestart, 
-		bool canLaunchWebBrowser, 
-		bool hasUpdateAvailable, 
-		FFmpegLocation encoderLocation, 
-		Architecture systemArchitecture 
+		std::optional<bool> canSelfRestart, 
+		std::optional<bool> canLaunchWebBrowser, 
+		std::optional<bool> hasUpdateAvailable 
 		) :
 	m_hasPendingRestart(hasPendingRestart),
 	m_isShuttingDown(isShuttingDown),
@@ -50,9 +48,7 @@ SystemInfo::SystemInfo (
 	m_webSocketPortNumber(webSocketPortNumber),
 	m_canSelfRestart(canSelfRestart),
 	m_canLaunchWebBrowser(canLaunchWebBrowser),
-	m_hasUpdateAvailable(hasUpdateAvailable),
-	m_encoderLocation(encoderLocation),
-	m_systemArchitecture(systemArchitecture) { }
+	m_hasUpdateAvailable(hasUpdateAvailable) { }
 
 
 
@@ -81,6 +77,7 @@ SystemInfo::SystemInfo(const SystemInfo &other) :
 	m_logPath(other.m_logPath),
 	m_internalMetadataPath(other.m_internalMetadataPath),
 	m_transcodingTempPath(other.m_transcodingTempPath),
+	m_castReceiverApplications(other.m_castReceiverApplications),
 	m_hasUpdateAvailable(other.m_hasUpdateAvailable),
 	m_encoderLocation(other.m_encoderLocation),
 	m_systemArchitecture(other.m_systemArchitecture){}
@@ -110,6 +107,7 @@ void SystemInfo::replaceData(SystemInfo &other) {
 	m_logPath = other.m_logPath;
 	m_internalMetadataPath = other.m_internalMetadataPath;
 	m_transcodingTempPath = other.m_transcodingTempPath;
+	m_castReceiverApplications = other.m_castReceiverApplications;
 	m_hasUpdateAvailable = other.m_hasUpdateAvailable;
 	m_encoderLocation = other.m_encoderLocation;
 	m_systemArchitecture = other.m_systemArchitecture;
@@ -137,8 +135,8 @@ void SystemInfo::setFromJson(QJsonObject source) {
 	m_supportsLibraryMonitor = Jellyfin::Support::fromJsonValue<bool>(source["SupportsLibraryMonitor"]);
 	m_webSocketPortNumber = Jellyfin::Support::fromJsonValue<qint32>(source["WebSocketPortNumber"]);
 	m_completedInstallations = Jellyfin::Support::fromJsonValue<QList<InstallationInfo>>(source["CompletedInstallations"]);
-	m_canSelfRestart = Jellyfin::Support::fromJsonValue<bool>(source["CanSelfRestart"]);
-	m_canLaunchWebBrowser = Jellyfin::Support::fromJsonValue<bool>(source["CanLaunchWebBrowser"]);
+	m_canSelfRestart = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CanSelfRestart"]);
+	m_canLaunchWebBrowser = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CanLaunchWebBrowser"]);
 	m_programDataPath = Jellyfin::Support::fromJsonValue<QString>(source["ProgramDataPath"]);
 	m_webPath = Jellyfin::Support::fromJsonValue<QString>(source["WebPath"]);
 	m_itemsByNamePath = Jellyfin::Support::fromJsonValue<QString>(source["ItemsByNamePath"]);
@@ -146,9 +144,10 @@ void SystemInfo::setFromJson(QJsonObject source) {
 	m_logPath = Jellyfin::Support::fromJsonValue<QString>(source["LogPath"]);
 	m_internalMetadataPath = Jellyfin::Support::fromJsonValue<QString>(source["InternalMetadataPath"]);
 	m_transcodingTempPath = Jellyfin::Support::fromJsonValue<QString>(source["TranscodingTempPath"]);
-	m_hasUpdateAvailable = Jellyfin::Support::fromJsonValue<bool>(source["HasUpdateAvailable"]);
-	m_encoderLocation = Jellyfin::Support::fromJsonValue<FFmpegLocation>(source["EncoderLocation"]);
-	m_systemArchitecture = Jellyfin::Support::fromJsonValue<Architecture>(source["SystemArchitecture"]);
+	m_castReceiverApplications = Jellyfin::Support::fromJsonValue<QList<CastReceiverApplication>>(source["CastReceiverApplications"]);
+	m_hasUpdateAvailable = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["HasUpdateAvailable"]);
+	m_encoderLocation = Jellyfin::Support::fromJsonValue<QString>(source["EncoderLocation"]);
+	m_systemArchitecture = Jellyfin::Support::fromJsonValue<QString>(source["SystemArchitecture"]);
 
 }
 	
@@ -209,8 +208,8 @@ QJsonObject SystemInfo::toJson() const {
 		result["CompletedInstallations"] = Jellyfin::Support::toJsonValue<QList<InstallationInfo>>(m_completedInstallations);
 	}
 			
-	result["CanSelfRestart"] = Jellyfin::Support::toJsonValue<bool>(m_canSelfRestart);		
-	result["CanLaunchWebBrowser"] = Jellyfin::Support::toJsonValue<bool>(m_canLaunchWebBrowser);		
+	result["CanSelfRestart"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_canSelfRestart);		
+	result["CanLaunchWebBrowser"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_canLaunchWebBrowser);		
 	
 	if (!(m_programDataPath.isNull())) {
 		result["ProgramDataPath"] = Jellyfin::Support::toJsonValue<QString>(m_programDataPath);
@@ -246,9 +245,22 @@ QJsonObject SystemInfo::toJson() const {
 		result["TranscodingTempPath"] = Jellyfin::Support::toJsonValue<QString>(m_transcodingTempPath);
 	}
 			
-	result["HasUpdateAvailable"] = Jellyfin::Support::toJsonValue<bool>(m_hasUpdateAvailable);		
-	result["EncoderLocation"] = Jellyfin::Support::toJsonValue<FFmpegLocation>(m_encoderLocation);		
-	result["SystemArchitecture"] = Jellyfin::Support::toJsonValue<Architecture>(m_systemArchitecture);	
+	
+	if (!(m_castReceiverApplications.size() == 0)) {
+		result["CastReceiverApplications"] = Jellyfin::Support::toJsonValue<QList<CastReceiverApplication>>(m_castReceiverApplications);
+	}
+			
+	result["HasUpdateAvailable"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_hasUpdateAvailable);		
+	
+	if (!(m_encoderLocation.isNull())) {
+		result["EncoderLocation"] = Jellyfin::Support::toJsonValue<QString>(m_encoderLocation);
+	}
+			
+	
+	if (!(m_systemArchitecture.isNull())) {
+		result["SystemArchitecture"] = Jellyfin::Support::toJsonValue<QString>(m_systemArchitecture);
+	}
+		
 	return result;
 }
 
@@ -406,15 +418,15 @@ void SystemInfo::setCompletedInstallationsNull() {
 	m_completedInstallations.clear();
 
 }
-bool SystemInfo::canSelfRestart() const { return m_canSelfRestart; }
+std::optional<bool> SystemInfo::canSelfRestart() const { return m_canSelfRestart; }
 
-void SystemInfo::setCanSelfRestart(bool newCanSelfRestart) {
+void SystemInfo::setCanSelfRestart(std::optional<bool> newCanSelfRestart) {
 	m_canSelfRestart = newCanSelfRestart;
 }
 
-bool SystemInfo::canLaunchWebBrowser() const { return m_canLaunchWebBrowser; }
+std::optional<bool> SystemInfo::canLaunchWebBrowser() const { return m_canLaunchWebBrowser; }
 
-void SystemInfo::setCanLaunchWebBrowser(bool newCanLaunchWebBrowser) {
+void SystemInfo::setCanLaunchWebBrowser(std::optional<bool> newCanLaunchWebBrowser) {
 	m_canLaunchWebBrowser = newCanLaunchWebBrowser;
 }
 
@@ -509,24 +521,51 @@ void SystemInfo::setTranscodingTempPathNull() {
 	m_transcodingTempPath.clear();
 
 }
-bool SystemInfo::hasUpdateAvailable() const { return m_hasUpdateAvailable; }
+QList<CastReceiverApplication> SystemInfo::castReceiverApplications() const { return m_castReceiverApplications; }
 
-void SystemInfo::setHasUpdateAvailable(bool newHasUpdateAvailable) {
+void SystemInfo::setCastReceiverApplications(QList<CastReceiverApplication> newCastReceiverApplications) {
+	m_castReceiverApplications = newCastReceiverApplications;
+}
+bool SystemInfo::castReceiverApplicationsNull() const {
+	return m_castReceiverApplications.size() == 0;
+}
+
+void SystemInfo::setCastReceiverApplicationsNull() {
+	m_castReceiverApplications.clear();
+
+}
+std::optional<bool> SystemInfo::hasUpdateAvailable() const { return m_hasUpdateAvailable; }
+
+void SystemInfo::setHasUpdateAvailable(std::optional<bool> newHasUpdateAvailable) {
 	m_hasUpdateAvailable = newHasUpdateAvailable;
 }
 
-FFmpegLocation SystemInfo::encoderLocation() const { return m_encoderLocation; }
+QString SystemInfo::encoderLocation() const { return m_encoderLocation; }
 
-void SystemInfo::setEncoderLocation(FFmpegLocation newEncoderLocation) {
+void SystemInfo::setEncoderLocation(QString newEncoderLocation) {
 	m_encoderLocation = newEncoderLocation;
 }
-
-Architecture SystemInfo::systemArchitecture() const { return m_systemArchitecture; }
-
-void SystemInfo::setSystemArchitecture(Architecture newSystemArchitecture) {
-	m_systemArchitecture = newSystemArchitecture;
+bool SystemInfo::encoderLocationNull() const {
+	return m_encoderLocation.isNull();
 }
 
+void SystemInfo::setEncoderLocationNull() {
+	m_encoderLocation.clear();
+
+}
+QString SystemInfo::systemArchitecture() const { return m_systemArchitecture; }
+
+void SystemInfo::setSystemArchitecture(QString newSystemArchitecture) {
+	m_systemArchitecture = newSystemArchitecture;
+}
+bool SystemInfo::systemArchitectureNull() const {
+	return m_systemArchitecture.isNull();
+}
+
+void SystemInfo::setSystemArchitectureNull() {
+	m_systemArchitecture.clear();
+
+}
 
 } // NS DTO
 
diff --git a/core/src/dto/thememediaresult.cpp b/core/src/dto/thememediaresult.cpp
index cf675b3..5a33b9f 100644
--- a/core/src/dto/thememediaresult.cpp
+++ b/core/src/dto/thememediaresult.cpp
@@ -34,10 +34,12 @@ namespace DTO {
 
 ThemeMediaResult::ThemeMediaResult() {}
 ThemeMediaResult::ThemeMediaResult (
+		QList<BaseItemDto> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex, 
 		QString ownerId 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex),
 	m_ownerId(ownerId) { }
@@ -77,11 +79,7 @@ void ThemeMediaResult::setFromJson(QJsonObject source) {
 QJsonObject ThemeMediaResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<BaseItemDto>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<BaseItemDto>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);		
 	result["OwnerId"] = Jellyfin::Support::toJsonValue<QString>(m_ownerId);	
@@ -93,14 +91,7 @@ QList<BaseItemDto> ThemeMediaResult::items() const { return m_items; }
 void ThemeMediaResult::setItems(QList<BaseItemDto> newItems) {
 	m_items = newItems;
 }
-bool ThemeMediaResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void ThemeMediaResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 ThemeMediaResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void ThemeMediaResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/timercancelledmessage.cpp b/core/src/dto/timercancelledmessage.cpp
new file mode 100644
index 0000000..eb792c7
--- /dev/null
+++ b/core/src/dto/timercancelledmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/timercancelledmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TimerCancelledMessage::TimerCancelledMessage() {}
+TimerCancelledMessage::TimerCancelledMessage (
+		QSharedPointer<TimerEventInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+TimerCancelledMessage::TimerCancelledMessage(const TimerCancelledMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void TimerCancelledMessage::replaceData(TimerCancelledMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+TimerCancelledMessage TimerCancelledMessage::fromJson(QJsonObject source) {
+	TimerCancelledMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void TimerCancelledMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<TimerEventInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject TimerCancelledMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<TimerEventInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<TimerEventInfo> TimerCancelledMessage::data() const { return m_data; }
+
+void TimerCancelledMessage::setData(QSharedPointer<TimerEventInfo> newData) {
+	m_data = newData;
+}
+
+QString TimerCancelledMessage::messageId() const { return m_messageId; }
+
+void TimerCancelledMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType TimerCancelledMessage::messageType() const { return m_messageType; }
+
+void TimerCancelledMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using TimerCancelledMessage = Jellyfin::DTO::TimerCancelledMessage;
+
+template <>
+TimerCancelledMessage fromJsonValue(const QJsonValue &source, convertType<TimerCancelledMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return TimerCancelledMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const TimerCancelledMessage &source, convertType<TimerCancelledMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/timercreatedmessage.cpp b/core/src/dto/timercreatedmessage.cpp
new file mode 100644
index 0000000..6b815c4
--- /dev/null
+++ b/core/src/dto/timercreatedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/timercreatedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TimerCreatedMessage::TimerCreatedMessage() {}
+TimerCreatedMessage::TimerCreatedMessage (
+		QSharedPointer<TimerEventInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+TimerCreatedMessage::TimerCreatedMessage(const TimerCreatedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void TimerCreatedMessage::replaceData(TimerCreatedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+TimerCreatedMessage TimerCreatedMessage::fromJson(QJsonObject source) {
+	TimerCreatedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void TimerCreatedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<TimerEventInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject TimerCreatedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<TimerEventInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<TimerEventInfo> TimerCreatedMessage::data() const { return m_data; }
+
+void TimerCreatedMessage::setData(QSharedPointer<TimerEventInfo> newData) {
+	m_data = newData;
+}
+
+QString TimerCreatedMessage::messageId() const { return m_messageId; }
+
+void TimerCreatedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType TimerCreatedMessage::messageType() const { return m_messageType; }
+
+void TimerCreatedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using TimerCreatedMessage = Jellyfin::DTO::TimerCreatedMessage;
+
+template <>
+TimerCreatedMessage fromJsonValue(const QJsonValue &source, convertType<TimerCreatedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return TimerCreatedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const TimerCreatedMessage &source, convertType<TimerCreatedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/timereventinfo.cpp b/core/src/dto/timereventinfo.cpp
index 64bb1e1..afca1c6 100644
--- a/core/src/dto/timereventinfo.cpp
+++ b/core/src/dto/timereventinfo.cpp
@@ -33,6 +33,12 @@ namespace Jellyfin {
 namespace DTO {
 
 TimerEventInfo::TimerEventInfo() {}
+TimerEventInfo::TimerEventInfo (
+		QString jellyfinId 
+		) :
+	m_jellyfinId(jellyfinId) { }
+
+
 
 TimerEventInfo::TimerEventInfo(const TimerEventInfo &other) :
 
@@ -61,11 +67,7 @@ void TimerEventInfo::setFromJson(QJsonObject source) {
 QJsonObject TimerEventInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_jellyfinId.isNull())) {
-		result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);
-	}
-			
+	result["Id"] = Jellyfin::Support::toJsonValue<QString>(m_jellyfinId);		
 	
 	if (!(m_programId.isNull())) {
 		result["ProgramId"] = Jellyfin::Support::toJsonValue<QString>(m_programId);
@@ -79,14 +81,7 @@ QString TimerEventInfo::jellyfinId() const { return m_jellyfinId; }
 void TimerEventInfo::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
-bool TimerEventInfo::jellyfinIdNull() const {
-	return m_jellyfinId.isNull();
-}
 
-void TimerEventInfo::setJellyfinIdNull() {
-	m_jellyfinId.clear();
-
-}
 QString TimerEventInfo::programId() const { return m_programId; }
 
 void TimerEventInfo::setProgramId(QString newProgramId) {
diff --git a/core/src/dto/timerinfodtoqueryresult.cpp b/core/src/dto/timerinfodtoqueryresult.cpp
index 6b3b710..ced1cbc 100644
--- a/core/src/dto/timerinfodtoqueryresult.cpp
+++ b/core/src/dto/timerinfodtoqueryresult.cpp
@@ -34,9 +34,11 @@ namespace DTO {
 
 TimerInfoDtoQueryResult::TimerInfoDtoQueryResult() {}
 TimerInfoDtoQueryResult::TimerInfoDtoQueryResult (
+		QList<TimerInfoDto> items, 
 		qint32 totalRecordCount, 
 		qint32 startIndex 
 		) :
+	m_items(items),
 	m_totalRecordCount(totalRecordCount),
 	m_startIndex(startIndex) { }
 
@@ -72,11 +74,7 @@ void TimerInfoDtoQueryResult::setFromJson(QJsonObject source) {
 QJsonObject TimerInfoDtoQueryResult::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_items.size() == 0)) {
-		result["Items"] = Jellyfin::Support::toJsonValue<QList<TimerInfoDto>>(m_items);
-	}
-			
+	result["Items"] = Jellyfin::Support::toJsonValue<QList<TimerInfoDto>>(m_items);		
 	result["TotalRecordCount"] = Jellyfin::Support::toJsonValue<qint32>(m_totalRecordCount);		
 	result["StartIndex"] = Jellyfin::Support::toJsonValue<qint32>(m_startIndex);	
 	return result;
@@ -87,14 +85,7 @@ QList<TimerInfoDto> TimerInfoDtoQueryResult::items() const { return m_items; }
 void TimerInfoDtoQueryResult::setItems(QList<TimerInfoDto> newItems) {
 	m_items = newItems;
 }
-bool TimerInfoDtoQueryResult::itemsNull() const {
-	return m_items.size() == 0;
-}
 
-void TimerInfoDtoQueryResult::setItemsNull() {
-	m_items.clear();
-
-}
 qint32 TimerInfoDtoQueryResult::totalRecordCount() const { return m_totalRecordCount; }
 
 void TimerInfoDtoQueryResult::setTotalRecordCount(qint32 newTotalRecordCount) {
diff --git a/core/src/dto/tonemappingalgorithm.cpp b/core/src/dto/tonemappingalgorithm.cpp
new file mode 100644
index 0000000..fd8b395
--- /dev/null
+++ b/core/src/dto/tonemappingalgorithm.cpp
@@ -0,0 +1,103 @@
+/*
+ * 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/dto/tonemappingalgorithm.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TonemappingAlgorithmClass::TonemappingAlgorithmClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using TonemappingAlgorithm = Jellyfin::DTO::TonemappingAlgorithm;
+
+template <>
+TonemappingAlgorithm fromJsonValue(const QJsonValue &source, convertType<TonemappingAlgorithm>) {
+	if (!source.isString()) return TonemappingAlgorithm::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("none")) {
+		return TonemappingAlgorithm::None;
+	}
+	if (str == QStringLiteral("clip")) {
+		return TonemappingAlgorithm::Clip;
+	}
+	if (str == QStringLiteral("linear")) {
+		return TonemappingAlgorithm::Linear;
+	}
+	if (str == QStringLiteral("gamma")) {
+		return TonemappingAlgorithm::Gamma;
+	}
+	if (str == QStringLiteral("reinhard")) {
+		return TonemappingAlgorithm::Reinhard;
+	}
+	if (str == QStringLiteral("hable")) {
+		return TonemappingAlgorithm::Hable;
+	}
+	if (str == QStringLiteral("mobius")) {
+		return TonemappingAlgorithm::Mobius;
+	}
+	if (str == QStringLiteral("bt2390")) {
+		return TonemappingAlgorithm::Bt2390;
+	}
+	
+	return TonemappingAlgorithm::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const TonemappingAlgorithm &source, convertType<TonemappingAlgorithm>) {
+	switch(source) {
+	case TonemappingAlgorithm::None:
+		return QStringLiteral("none");
+	case TonemappingAlgorithm::Clip:
+		return QStringLiteral("clip");
+	case TonemappingAlgorithm::Linear:
+		return QStringLiteral("linear");
+	case TonemappingAlgorithm::Gamma:
+		return QStringLiteral("gamma");
+	case TonemappingAlgorithm::Reinhard:
+		return QStringLiteral("reinhard");
+	case TonemappingAlgorithm::Hable:
+		return QStringLiteral("hable");
+	case TonemappingAlgorithm::Mobius:
+		return QStringLiteral("mobius");
+	case TonemappingAlgorithm::Bt2390:
+		return QStringLiteral("bt2390");
+
+	case TonemappingAlgorithm::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/architecture.cpp b/core/src/dto/tonemappingmode.cpp
similarity index 58%
rename from core/src/dto/architecture.cpp
rename to core/src/dto/tonemappingmode.cpp
index 7e9db87..ccb08f9 100644
--- a/core/src/dto/architecture.cpp
+++ b/core/src/dto/tonemappingmode.cpp
@@ -27,58 +27,58 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/architecture.h>
+#include <JellyfinQt/dto/tonemappingmode.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-ArchitectureClass::ArchitectureClass() {}
+TonemappingModeClass::TonemappingModeClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using Architecture = Jellyfin::DTO::Architecture;
+using TonemappingMode = Jellyfin::DTO::TonemappingMode;
 
 template <>
-Architecture fromJsonValue(const QJsonValue &source, convertType<Architecture>) {
-	if (!source.isString()) return Architecture::EnumNotSet;
+TonemappingMode fromJsonValue(const QJsonValue &source, convertType<TonemappingMode>) {
+	if (!source.isString()) return TonemappingMode::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("X86")) {
-		return Architecture::X86;
+	if (str == QStringLiteral("auto")) {
+		return TonemappingMode::Automatic;
 	}
-	if (str == QStringLiteral("X64")) {
-		return Architecture::X64;
+	if (str == QStringLiteral("max")) {
+		return TonemappingMode::Max;
 	}
-	if (str == QStringLiteral("Arm")) {
-		return Architecture::Arm;
+	if (str == QStringLiteral("rgb")) {
+		return TonemappingMode::Rgb;
 	}
-	if (str == QStringLiteral("Arm64")) {
-		return Architecture::Arm64;
+	if (str == QStringLiteral("lum")) {
+		return TonemappingMode::Lum;
 	}
-	if (str == QStringLiteral("Wasm")) {
-		return Architecture::Wasm;
+	if (str == QStringLiteral("itp")) {
+		return TonemappingMode::Itp;
 	}
 	
-	return Architecture::EnumNotSet;
+	return TonemappingMode::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const Architecture &source, convertType<Architecture>) {
+QJsonValue toJsonValue(const TonemappingMode &source, convertType<TonemappingMode>) {
 	switch(source) {
-	case Architecture::X86:
-		return QStringLiteral("X86");
-	case Architecture::X64:
-		return QStringLiteral("X64");
-	case Architecture::Arm:
-		return QStringLiteral("Arm");
-	case Architecture::Arm64:
-		return QStringLiteral("Arm64");
-	case Architecture::Wasm:
-		return QStringLiteral("Wasm");
+	case TonemappingMode::Automatic:
+		return QStringLiteral("auto");
+	case TonemappingMode::Max:
+		return QStringLiteral("max");
+	case TonemappingMode::Rgb:
+		return QStringLiteral("rgb");
+	case TonemappingMode::Lum:
+		return QStringLiteral("lum");
+	case TonemappingMode::Itp:
+		return QStringLiteral("itp");
 
-	case Architecture::EnumNotSet: // Fallthrough
+	case TonemappingMode::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/headermatchtype.cpp b/core/src/dto/tonemappingrange.cpp
similarity index 63%
rename from core/src/dto/headermatchtype.cpp
rename to core/src/dto/tonemappingrange.cpp
index 9cd299b..50cf7f3 100644
--- a/core/src/dto/headermatchtype.cpp
+++ b/core/src/dto/tonemappingrange.cpp
@@ -27,48 +27,48 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/headermatchtype.h>
+#include <JellyfinQt/dto/tonemappingrange.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-HeaderMatchTypeClass::HeaderMatchTypeClass() {}
+TonemappingRangeClass::TonemappingRangeClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using HeaderMatchType = Jellyfin::DTO::HeaderMatchType;
+using TonemappingRange = Jellyfin::DTO::TonemappingRange;
 
 template <>
-HeaderMatchType fromJsonValue(const QJsonValue &source, convertType<HeaderMatchType>) {
-	if (!source.isString()) return HeaderMatchType::EnumNotSet;
+TonemappingRange fromJsonValue(const QJsonValue &source, convertType<TonemappingRange>) {
+	if (!source.isString()) return TonemappingRange::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("Equals")) {
-		return HeaderMatchType::Equals;
+	if (str == QStringLiteral("auto")) {
+		return TonemappingRange::Automatic;
 	}
-	if (str == QStringLiteral("Regex")) {
-		return HeaderMatchType::Regex;
+	if (str == QStringLiteral("tv")) {
+		return TonemappingRange::Tv;
 	}
-	if (str == QStringLiteral("Substring")) {
-		return HeaderMatchType::Substring;
+	if (str == QStringLiteral("pc")) {
+		return TonemappingRange::Pc;
 	}
 	
-	return HeaderMatchType::EnumNotSet;
+	return TonemappingRange::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const HeaderMatchType &source, convertType<HeaderMatchType>) {
+QJsonValue toJsonValue(const TonemappingRange &source, convertType<TonemappingRange>) {
 	switch(source) {
-	case HeaderMatchType::Equals:
-		return QStringLiteral("Equals");
-	case HeaderMatchType::Regex:
-		return QStringLiteral("Regex");
-	case HeaderMatchType::Substring:
-		return QStringLiteral("Substring");
+	case TonemappingRange::Automatic:
+		return QStringLiteral("auto");
+	case TonemappingRange::Tv:
+		return QStringLiteral("tv");
+	case TonemappingRange::Pc:
+		return QStringLiteral("pc");
 
-	case HeaderMatchType::EnumNotSet: // Fallthrough
+	case TonemappingRange::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/trailerinfo.cpp b/core/src/dto/trailerinfo.cpp
index fc555e8..54ac3af 100644
--- a/core/src/dto/trailerinfo.cpp
+++ b/core/src/dto/trailerinfo.cpp
@@ -43,6 +43,7 @@ TrailerInfo::TrailerInfo (
 TrailerInfo::TrailerInfo(const TrailerInfo &other) :
 
 	m_name(other.m_name),
+	m_originalTitle(other.m_originalTitle),
 	m_path(other.m_path),
 	m_metadataLanguage(other.m_metadataLanguage),
 	m_metadataCountryCode(other.m_metadataCountryCode),
@@ -56,6 +57,7 @@ TrailerInfo::TrailerInfo(const TrailerInfo &other) :
 
 void TrailerInfo::replaceData(TrailerInfo &other) {
 	m_name = other.m_name;
+	m_originalTitle = other.m_originalTitle;
 	m_path = other.m_path;
 	m_metadataLanguage = other.m_metadataLanguage;
 	m_metadataCountryCode = other.m_metadataCountryCode;
@@ -76,6 +78,7 @@ TrailerInfo TrailerInfo::fromJson(QJsonObject source) {
 
 void TrailerInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_originalTitle = Jellyfin::Support::fromJsonValue<QString>(source["OriginalTitle"]);
 	m_path = Jellyfin::Support::fromJsonValue<QString>(source["Path"]);
 	m_metadataLanguage = Jellyfin::Support::fromJsonValue<QString>(source["MetadataLanguage"]);
 	m_metadataCountryCode = Jellyfin::Support::fromJsonValue<QString>(source["MetadataCountryCode"]);
@@ -97,6 +100,11 @@ QJsonObject TrailerInfo::toJson() const {
 	}
 			
 	
+	if (!(m_originalTitle.isNull())) {
+		result["OriginalTitle"] = Jellyfin::Support::toJsonValue<QString>(m_originalTitle);
+	}
+			
+	
 	if (!(m_path.isNull())) {
 		result["Path"] = Jellyfin::Support::toJsonValue<QString>(m_path);
 	}
@@ -152,6 +160,19 @@ bool TrailerInfo::nameNull() const {
 void TrailerInfo::setNameNull() {
 	m_name.clear();
 
+}
+QString TrailerInfo::originalTitle() const { return m_originalTitle; }
+
+void TrailerInfo::setOriginalTitle(QString newOriginalTitle) {
+	m_originalTitle = newOriginalTitle;
+}
+bool TrailerInfo::originalTitleNull() const {
+	return m_originalTitle.isNull();
+}
+
+void TrailerInfo::setOriginalTitleNull() {
+	m_originalTitle.clear();
+
 }
 QString TrailerInfo::path() const { return m_path; }
 
diff --git a/core/src/dto/transcodereason.cpp b/core/src/dto/transcodereason.cpp
index d96f29b..1ab079e 100644
--- a/core/src/dto/transcodereason.cpp
+++ b/core/src/dto/transcodereason.cpp
@@ -54,29 +54,32 @@ TranscodeReason fromJsonValue(const QJsonValue &source, convertType<TranscodeRea
 	if (str == QStringLiteral("AudioCodecNotSupported")) {
 		return TranscodeReason::AudioCodecNotSupported;
 	}
-	if (str == QStringLiteral("ContainerBitrateExceedsLimit")) {
-		return TranscodeReason::ContainerBitrateExceedsLimit;
+	if (str == QStringLiteral("SubtitleCodecNotSupported")) {
+		return TranscodeReason::SubtitleCodecNotSupported;
 	}
-	if (str == QStringLiteral("AudioBitrateNotSupported")) {
-		return TranscodeReason::AudioBitrateNotSupported;
+	if (str == QStringLiteral("AudioIsExternal")) {
+		return TranscodeReason::AudioIsExternal;
 	}
-	if (str == QStringLiteral("AudioChannelsNotSupported")) {
-		return TranscodeReason::AudioChannelsNotSupported;
+	if (str == QStringLiteral("SecondaryAudioNotSupported")) {
+		return TranscodeReason::SecondaryAudioNotSupported;
+	}
+	if (str == QStringLiteral("VideoProfileNotSupported")) {
+		return TranscodeReason::VideoProfileNotSupported;
+	}
+	if (str == QStringLiteral("VideoLevelNotSupported")) {
+		return TranscodeReason::VideoLevelNotSupported;
 	}
 	if (str == QStringLiteral("VideoResolutionNotSupported")) {
 		return TranscodeReason::VideoResolutionNotSupported;
 	}
-	if (str == QStringLiteral("UnknownVideoStreamInfo")) {
-		return TranscodeReason::UnknownVideoStreamInfo;
+	if (str == QStringLiteral("VideoBitDepthNotSupported")) {
+		return TranscodeReason::VideoBitDepthNotSupported;
 	}
-	if (str == QStringLiteral("UnknownAudioStreamInfo")) {
-		return TranscodeReason::UnknownAudioStreamInfo;
+	if (str == QStringLiteral("VideoFramerateNotSupported")) {
+		return TranscodeReason::VideoFramerateNotSupported;
 	}
-	if (str == QStringLiteral("AudioProfileNotSupported")) {
-		return TranscodeReason::AudioProfileNotSupported;
-	}
-	if (str == QStringLiteral("AudioSampleRateNotSupported")) {
-		return TranscodeReason::AudioSampleRateNotSupported;
+	if (str == QStringLiteral("RefFramesNotSupported")) {
+		return TranscodeReason::RefFramesNotSupported;
 	}
 	if (str == QStringLiteral("AnamorphicVideoNotSupported")) {
 		return TranscodeReason::AnamorphicVideoNotSupported;
@@ -84,36 +87,42 @@ TranscodeReason fromJsonValue(const QJsonValue &source, convertType<TranscodeRea
 	if (str == QStringLiteral("InterlacedVideoNotSupported")) {
 		return TranscodeReason::InterlacedVideoNotSupported;
 	}
-	if (str == QStringLiteral("SecondaryAudioNotSupported")) {
-		return TranscodeReason::SecondaryAudioNotSupported;
+	if (str == QStringLiteral("AudioChannelsNotSupported")) {
+		return TranscodeReason::AudioChannelsNotSupported;
 	}
-	if (str == QStringLiteral("RefFramesNotSupported")) {
-		return TranscodeReason::RefFramesNotSupported;
+	if (str == QStringLiteral("AudioProfileNotSupported")) {
+		return TranscodeReason::AudioProfileNotSupported;
 	}
-	if (str == QStringLiteral("VideoBitDepthNotSupported")) {
-		return TranscodeReason::VideoBitDepthNotSupported;
-	}
-	if (str == QStringLiteral("VideoBitrateNotSupported")) {
-		return TranscodeReason::VideoBitrateNotSupported;
-	}
-	if (str == QStringLiteral("VideoFramerateNotSupported")) {
-		return TranscodeReason::VideoFramerateNotSupported;
-	}
-	if (str == QStringLiteral("VideoLevelNotSupported")) {
-		return TranscodeReason::VideoLevelNotSupported;
-	}
-	if (str == QStringLiteral("VideoProfileNotSupported")) {
-		return TranscodeReason::VideoProfileNotSupported;
+	if (str == QStringLiteral("AudioSampleRateNotSupported")) {
+		return TranscodeReason::AudioSampleRateNotSupported;
 	}
 	if (str == QStringLiteral("AudioBitDepthNotSupported")) {
 		return TranscodeReason::AudioBitDepthNotSupported;
 	}
-	if (str == QStringLiteral("SubtitleCodecNotSupported")) {
-		return TranscodeReason::SubtitleCodecNotSupported;
+	if (str == QStringLiteral("ContainerBitrateExceedsLimit")) {
+		return TranscodeReason::ContainerBitrateExceedsLimit;
+	}
+	if (str == QStringLiteral("VideoBitrateNotSupported")) {
+		return TranscodeReason::VideoBitrateNotSupported;
+	}
+	if (str == QStringLiteral("AudioBitrateNotSupported")) {
+		return TranscodeReason::AudioBitrateNotSupported;
+	}
+	if (str == QStringLiteral("UnknownVideoStreamInfo")) {
+		return TranscodeReason::UnknownVideoStreamInfo;
+	}
+	if (str == QStringLiteral("UnknownAudioStreamInfo")) {
+		return TranscodeReason::UnknownAudioStreamInfo;
 	}
 	if (str == QStringLiteral("DirectPlayError")) {
 		return TranscodeReason::DirectPlayError;
 	}
+	if (str == QStringLiteral("VideoRangeTypeNotSupported")) {
+		return TranscodeReason::VideoRangeTypeNotSupported;
+	}
+	if (str == QStringLiteral("VideoCodecTagNotSupported")) {
+		return TranscodeReason::VideoCodecTagNotSupported;
+	}
 	
 	return TranscodeReason::EnumNotSet;
 }
@@ -127,46 +136,52 @@ QJsonValue toJsonValue(const TranscodeReason &source, convertType<TranscodeReaso
 		return QStringLiteral("VideoCodecNotSupported");
 	case TranscodeReason::AudioCodecNotSupported:
 		return QStringLiteral("AudioCodecNotSupported");
-	case TranscodeReason::ContainerBitrateExceedsLimit:
-		return QStringLiteral("ContainerBitrateExceedsLimit");
-	case TranscodeReason::AudioBitrateNotSupported:
-		return QStringLiteral("AudioBitrateNotSupported");
-	case TranscodeReason::AudioChannelsNotSupported:
-		return QStringLiteral("AudioChannelsNotSupported");
+	case TranscodeReason::SubtitleCodecNotSupported:
+		return QStringLiteral("SubtitleCodecNotSupported");
+	case TranscodeReason::AudioIsExternal:
+		return QStringLiteral("AudioIsExternal");
+	case TranscodeReason::SecondaryAudioNotSupported:
+		return QStringLiteral("SecondaryAudioNotSupported");
+	case TranscodeReason::VideoProfileNotSupported:
+		return QStringLiteral("VideoProfileNotSupported");
+	case TranscodeReason::VideoLevelNotSupported:
+		return QStringLiteral("VideoLevelNotSupported");
 	case TranscodeReason::VideoResolutionNotSupported:
 		return QStringLiteral("VideoResolutionNotSupported");
-	case TranscodeReason::UnknownVideoStreamInfo:
-		return QStringLiteral("UnknownVideoStreamInfo");
-	case TranscodeReason::UnknownAudioStreamInfo:
-		return QStringLiteral("UnknownAudioStreamInfo");
-	case TranscodeReason::AudioProfileNotSupported:
-		return QStringLiteral("AudioProfileNotSupported");
-	case TranscodeReason::AudioSampleRateNotSupported:
-		return QStringLiteral("AudioSampleRateNotSupported");
+	case TranscodeReason::VideoBitDepthNotSupported:
+		return QStringLiteral("VideoBitDepthNotSupported");
+	case TranscodeReason::VideoFramerateNotSupported:
+		return QStringLiteral("VideoFramerateNotSupported");
+	case TranscodeReason::RefFramesNotSupported:
+		return QStringLiteral("RefFramesNotSupported");
 	case TranscodeReason::AnamorphicVideoNotSupported:
 		return QStringLiteral("AnamorphicVideoNotSupported");
 	case TranscodeReason::InterlacedVideoNotSupported:
 		return QStringLiteral("InterlacedVideoNotSupported");
-	case TranscodeReason::SecondaryAudioNotSupported:
-		return QStringLiteral("SecondaryAudioNotSupported");
-	case TranscodeReason::RefFramesNotSupported:
-		return QStringLiteral("RefFramesNotSupported");
-	case TranscodeReason::VideoBitDepthNotSupported:
-		return QStringLiteral("VideoBitDepthNotSupported");
-	case TranscodeReason::VideoBitrateNotSupported:
-		return QStringLiteral("VideoBitrateNotSupported");
-	case TranscodeReason::VideoFramerateNotSupported:
-		return QStringLiteral("VideoFramerateNotSupported");
-	case TranscodeReason::VideoLevelNotSupported:
-		return QStringLiteral("VideoLevelNotSupported");
-	case TranscodeReason::VideoProfileNotSupported:
-		return QStringLiteral("VideoProfileNotSupported");
+	case TranscodeReason::AudioChannelsNotSupported:
+		return QStringLiteral("AudioChannelsNotSupported");
+	case TranscodeReason::AudioProfileNotSupported:
+		return QStringLiteral("AudioProfileNotSupported");
+	case TranscodeReason::AudioSampleRateNotSupported:
+		return QStringLiteral("AudioSampleRateNotSupported");
 	case TranscodeReason::AudioBitDepthNotSupported:
 		return QStringLiteral("AudioBitDepthNotSupported");
-	case TranscodeReason::SubtitleCodecNotSupported:
-		return QStringLiteral("SubtitleCodecNotSupported");
+	case TranscodeReason::ContainerBitrateExceedsLimit:
+		return QStringLiteral("ContainerBitrateExceedsLimit");
+	case TranscodeReason::VideoBitrateNotSupported:
+		return QStringLiteral("VideoBitrateNotSupported");
+	case TranscodeReason::AudioBitrateNotSupported:
+		return QStringLiteral("AudioBitrateNotSupported");
+	case TranscodeReason::UnknownVideoStreamInfo:
+		return QStringLiteral("UnknownVideoStreamInfo");
+	case TranscodeReason::UnknownAudioStreamInfo:
+		return QStringLiteral("UnknownAudioStreamInfo");
 	case TranscodeReason::DirectPlayError:
 		return QStringLiteral("DirectPlayError");
+	case TranscodeReason::VideoRangeTypeNotSupported:
+		return QStringLiteral("VideoRangeTypeNotSupported");
+	case TranscodeReason::VideoCodecTagNotSupported:
+		return QStringLiteral("VideoCodecTagNotSupported");
 
 	case TranscodeReason::EnumNotSet: // Fallthrough
 	default:
diff --git a/core/src/dto/transcodinginfo.cpp b/core/src/dto/transcodinginfo.cpp
index d2689dd..4a29a9e 100644
--- a/core/src/dto/transcodinginfo.cpp
+++ b/core/src/dto/transcodinginfo.cpp
@@ -35,10 +35,14 @@ namespace DTO {
 TranscodingInfo::TranscodingInfo() {}
 TranscodingInfo::TranscodingInfo (
 		bool isVideoDirect, 
-		bool isAudioDirect 
+		bool isAudioDirect, 
+		HardwareAccelerationType hardwareAccelerationType, 
+		QList<TranscodeReason> transcodeReasons 
 		) :
 	m_isVideoDirect(isVideoDirect),
-	m_isAudioDirect(isAudioDirect) { }
+	m_isAudioDirect(isAudioDirect),
+	m_hardwareAccelerationType(hardwareAccelerationType),
+	m_transcodeReasons(transcodeReasons) { }
 
 
 
@@ -55,6 +59,7 @@ TranscodingInfo::TranscodingInfo(const TranscodingInfo &other) :
 	m_width(other.m_width),
 	m_height(other.m_height),
 	m_audioChannels(other.m_audioChannels),
+	m_hardwareAccelerationType(other.m_hardwareAccelerationType),
 	m_transcodeReasons(other.m_transcodeReasons){}
 
 
@@ -70,6 +75,7 @@ void TranscodingInfo::replaceData(TranscodingInfo &other) {
 	m_width = other.m_width;
 	m_height = other.m_height;
 	m_audioChannels = other.m_audioChannels;
+	m_hardwareAccelerationType = other.m_hardwareAccelerationType;
 	m_transcodeReasons = other.m_transcodeReasons;
 }
 
@@ -92,6 +98,7 @@ void TranscodingInfo::setFromJson(QJsonObject source) {
 	m_width = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Width"]);
 	m_height = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["Height"]);
 	m_audioChannels = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["AudioChannels"]);
+	m_hardwareAccelerationType = Jellyfin::Support::fromJsonValue<HardwareAccelerationType>(source["HardwareAccelerationType"]);
 	m_transcodeReasons = Jellyfin::Support::fromJsonValue<QList<TranscodeReason>>(source["TranscodeReasons"]);
 
 }
@@ -146,11 +153,8 @@ QJsonObject TranscodingInfo::toJson() const {
 		result["AudioChannels"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_audioChannels);
 	}
 			
-	
-	if (!(m_transcodeReasons.size() == 0)) {
-		result["TranscodeReasons"] = Jellyfin::Support::toJsonValue<QList<TranscodeReason>>(m_transcodeReasons);
-	}
-		
+	result["HardwareAccelerationType"] = Jellyfin::Support::toJsonValue<HardwareAccelerationType>(m_hardwareAccelerationType);		
+	result["TranscodeReasons"] = Jellyfin::Support::toJsonValue<QList<TranscodeReason>>(m_transcodeReasons);	
 	return result;
 }
 
@@ -283,19 +287,18 @@ void TranscodingInfo::setAudioChannelsNull() {
 	m_audioChannels = std::nullopt;
 
 }
+HardwareAccelerationType TranscodingInfo::hardwareAccelerationType() const { return m_hardwareAccelerationType; }
+
+void TranscodingInfo::setHardwareAccelerationType(HardwareAccelerationType newHardwareAccelerationType) {
+	m_hardwareAccelerationType = newHardwareAccelerationType;
+}
+
 QList<TranscodeReason> TranscodingInfo::transcodeReasons() const { return m_transcodeReasons; }
 
 void TranscodingInfo::setTranscodeReasons(QList<TranscodeReason> newTranscodeReasons) {
 	m_transcodeReasons = newTranscodeReasons;
 }
-bool TranscodingInfo::transcodeReasonsNull() const {
-	return m_transcodeReasons.size() == 0;
-}
 
-void TranscodingInfo::setTranscodeReasonsNull() {
-	m_transcodeReasons.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/transcodingprofile.cpp b/core/src/dto/transcodingprofile.cpp
index 373ceb8..5292ae7 100644
--- a/core/src/dto/transcodingprofile.cpp
+++ b/core/src/dto/transcodingprofile.cpp
@@ -34,18 +34,28 @@ namespace DTO {
 
 TranscodingProfile::TranscodingProfile() {}
 TranscodingProfile::TranscodingProfile (
+		QString container, 
 		DlnaProfileType type, 
-		bool estimateContentLength, 
-		bool enableMpegtsM2TsMode, 
+		QString videoCodec, 
+		QString audioCodec, 
+		MediaStreamProtocol protocol, 
+		std::optional<bool> estimateContentLength, 
+		std::optional<bool> enableMpegtsM2TsMode, 
 		TranscodeSeekInfo transcodeSeekInfo, 
-		bool copyTimestamps, 
+		std::optional<bool> copyTimestamps, 
 		EncodingContext context, 
-		bool enableSubtitlesInManifest, 
-		qint32 minSegments, 
-		qint32 segmentLength, 
-		bool breakOnNonKeyFrames 
+		std::optional<bool> enableSubtitlesInManifest, 
+		std::optional<qint32> minSegments, 
+		std::optional<qint32> segmentLength, 
+		std::optional<bool> breakOnNonKeyFrames, 
+		QList<ProfileCondition> conditions, 
+		std::optional<bool> enableAudioVbrEncoding 
 		) :
+	m_container(container),
 	m_type(type),
+	m_videoCodec(videoCodec),
+	m_audioCodec(audioCodec),
+	m_protocol(protocol),
 	m_estimateContentLength(estimateContentLength),
 	m_enableMpegtsM2TsMode(enableMpegtsM2TsMode),
 	m_transcodeSeekInfo(transcodeSeekInfo),
@@ -54,7 +64,9 @@ TranscodingProfile::TranscodingProfile (
 	m_enableSubtitlesInManifest(enableSubtitlesInManifest),
 	m_minSegments(minSegments),
 	m_segmentLength(segmentLength),
-	m_breakOnNonKeyFrames(breakOnNonKeyFrames) { }
+	m_breakOnNonKeyFrames(breakOnNonKeyFrames),
+	m_conditions(conditions),
+	m_enableAudioVbrEncoding(enableAudioVbrEncoding) { }
 
 
 
@@ -74,7 +86,9 @@ TranscodingProfile::TranscodingProfile(const TranscodingProfile &other) :
 	m_maxAudioChannels(other.m_maxAudioChannels),
 	m_minSegments(other.m_minSegments),
 	m_segmentLength(other.m_segmentLength),
-	m_breakOnNonKeyFrames(other.m_breakOnNonKeyFrames){}
+	m_breakOnNonKeyFrames(other.m_breakOnNonKeyFrames),
+	m_conditions(other.m_conditions),
+	m_enableAudioVbrEncoding(other.m_enableAudioVbrEncoding){}
 
 
 void TranscodingProfile::replaceData(TranscodingProfile &other) {
@@ -93,6 +107,8 @@ void TranscodingProfile::replaceData(TranscodingProfile &other) {
 	m_minSegments = other.m_minSegments;
 	m_segmentLength = other.m_segmentLength;
 	m_breakOnNonKeyFrames = other.m_breakOnNonKeyFrames;
+	m_conditions = other.m_conditions;
+	m_enableAudioVbrEncoding = other.m_enableAudioVbrEncoding;
 }
 
 TranscodingProfile TranscodingProfile::fromJson(QJsonObject source) {
@@ -107,58 +123,46 @@ void TranscodingProfile::setFromJson(QJsonObject source) {
 	m_type = Jellyfin::Support::fromJsonValue<DlnaProfileType>(source["Type"]);
 	m_videoCodec = Jellyfin::Support::fromJsonValue<QString>(source["VideoCodec"]);
 	m_audioCodec = Jellyfin::Support::fromJsonValue<QString>(source["AudioCodec"]);
-	m_protocol = Jellyfin::Support::fromJsonValue<QString>(source["Protocol"]);
-	m_estimateContentLength = Jellyfin::Support::fromJsonValue<bool>(source["EstimateContentLength"]);
-	m_enableMpegtsM2TsMode = Jellyfin::Support::fromJsonValue<bool>(source["EnableMpegtsM2TsMode"]);
+	m_protocol = Jellyfin::Support::fromJsonValue<MediaStreamProtocol>(source["Protocol"]);
+	m_estimateContentLength = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EstimateContentLength"]);
+	m_enableMpegtsM2TsMode = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableMpegtsM2TsMode"]);
 	m_transcodeSeekInfo = Jellyfin::Support::fromJsonValue<TranscodeSeekInfo>(source["TranscodeSeekInfo"]);
-	m_copyTimestamps = Jellyfin::Support::fromJsonValue<bool>(source["CopyTimestamps"]);
+	m_copyTimestamps = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CopyTimestamps"]);
 	m_context = Jellyfin::Support::fromJsonValue<EncodingContext>(source["Context"]);
-	m_enableSubtitlesInManifest = Jellyfin::Support::fromJsonValue<bool>(source["EnableSubtitlesInManifest"]);
+	m_enableSubtitlesInManifest = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableSubtitlesInManifest"]);
 	m_maxAudioChannels = Jellyfin::Support::fromJsonValue<QString>(source["MaxAudioChannels"]);
-	m_minSegments = Jellyfin::Support::fromJsonValue<qint32>(source["MinSegments"]);
-	m_segmentLength = Jellyfin::Support::fromJsonValue<qint32>(source["SegmentLength"]);
-	m_breakOnNonKeyFrames = Jellyfin::Support::fromJsonValue<bool>(source["BreakOnNonKeyFrames"]);
+	m_minSegments = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MinSegments"]);
+	m_segmentLength = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["SegmentLength"]);
+	m_breakOnNonKeyFrames = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["BreakOnNonKeyFrames"]);
+	m_conditions = Jellyfin::Support::fromJsonValue<QList<ProfileCondition>>(source["Conditions"]);
+	m_enableAudioVbrEncoding = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableAudioVbrEncoding"]);
 
 }
 	
 QJsonObject TranscodingProfile::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_container.isNull())) {
-		result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);
-	}
-			
+	result["Container"] = Jellyfin::Support::toJsonValue<QString>(m_container);		
 	result["Type"] = Jellyfin::Support::toJsonValue<DlnaProfileType>(m_type);		
-	
-	if (!(m_videoCodec.isNull())) {
-		result["VideoCodec"] = Jellyfin::Support::toJsonValue<QString>(m_videoCodec);
-	}
-			
-	
-	if (!(m_audioCodec.isNull())) {
-		result["AudioCodec"] = Jellyfin::Support::toJsonValue<QString>(m_audioCodec);
-	}
-			
-	
-	if (!(m_protocol.isNull())) {
-		result["Protocol"] = Jellyfin::Support::toJsonValue<QString>(m_protocol);
-	}
-			
-	result["EstimateContentLength"] = Jellyfin::Support::toJsonValue<bool>(m_estimateContentLength);		
-	result["EnableMpegtsM2TsMode"] = Jellyfin::Support::toJsonValue<bool>(m_enableMpegtsM2TsMode);		
+	result["VideoCodec"] = Jellyfin::Support::toJsonValue<QString>(m_videoCodec);		
+	result["AudioCodec"] = Jellyfin::Support::toJsonValue<QString>(m_audioCodec);		
+	result["Protocol"] = Jellyfin::Support::toJsonValue<MediaStreamProtocol>(m_protocol);		
+	result["EstimateContentLength"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_estimateContentLength);		
+	result["EnableMpegtsM2TsMode"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableMpegtsM2TsMode);		
 	result["TranscodeSeekInfo"] = Jellyfin::Support::toJsonValue<TranscodeSeekInfo>(m_transcodeSeekInfo);		
-	result["CopyTimestamps"] = Jellyfin::Support::toJsonValue<bool>(m_copyTimestamps);		
+	result["CopyTimestamps"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_copyTimestamps);		
 	result["Context"] = Jellyfin::Support::toJsonValue<EncodingContext>(m_context);		
-	result["EnableSubtitlesInManifest"] = Jellyfin::Support::toJsonValue<bool>(m_enableSubtitlesInManifest);		
+	result["EnableSubtitlesInManifest"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableSubtitlesInManifest);		
 	
 	if (!(m_maxAudioChannels.isNull())) {
 		result["MaxAudioChannels"] = Jellyfin::Support::toJsonValue<QString>(m_maxAudioChannels);
 	}
 			
-	result["MinSegments"] = Jellyfin::Support::toJsonValue<qint32>(m_minSegments);		
-	result["SegmentLength"] = Jellyfin::Support::toJsonValue<qint32>(m_segmentLength);		
-	result["BreakOnNonKeyFrames"] = Jellyfin::Support::toJsonValue<bool>(m_breakOnNonKeyFrames);	
+	result["MinSegments"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_minSegments);		
+	result["SegmentLength"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_segmentLength);		
+	result["BreakOnNonKeyFrames"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_breakOnNonKeyFrames);		
+	result["Conditions"] = Jellyfin::Support::toJsonValue<QList<ProfileCondition>>(m_conditions);		
+	result["EnableAudioVbrEncoding"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableAudioVbrEncoding);	
 	return result;
 }
 
@@ -167,14 +171,7 @@ QString TranscodingProfile::container() const { return m_container; }
 void TranscodingProfile::setContainer(QString newContainer) {
 	m_container = newContainer;
 }
-bool TranscodingProfile::containerNull() const {
-	return m_container.isNull();
-}
 
-void TranscodingProfile::setContainerNull() {
-	m_container.clear();
-
-}
 DlnaProfileType TranscodingProfile::type() const { return m_type; }
 
 void TranscodingProfile::setType(DlnaProfileType newType) {
@@ -186,49 +183,28 @@ QString TranscodingProfile::videoCodec() const { return m_videoCodec; }
 void TranscodingProfile::setVideoCodec(QString newVideoCodec) {
 	m_videoCodec = newVideoCodec;
 }
-bool TranscodingProfile::videoCodecNull() const {
-	return m_videoCodec.isNull();
-}
 
-void TranscodingProfile::setVideoCodecNull() {
-	m_videoCodec.clear();
-
-}
 QString TranscodingProfile::audioCodec() const { return m_audioCodec; }
 
 void TranscodingProfile::setAudioCodec(QString newAudioCodec) {
 	m_audioCodec = newAudioCodec;
 }
-bool TranscodingProfile::audioCodecNull() const {
-	return m_audioCodec.isNull();
-}
 
-void TranscodingProfile::setAudioCodecNull() {
-	m_audioCodec.clear();
+MediaStreamProtocol TranscodingProfile::protocol() const { return m_protocol; }
 
-}
-QString TranscodingProfile::protocol() const { return m_protocol; }
-
-void TranscodingProfile::setProtocol(QString newProtocol) {
+void TranscodingProfile::setProtocol(MediaStreamProtocol newProtocol) {
 	m_protocol = newProtocol;
 }
-bool TranscodingProfile::protocolNull() const {
-	return m_protocol.isNull();
-}
 
-void TranscodingProfile::setProtocolNull() {
-	m_protocol.clear();
+std::optional<bool> TranscodingProfile::estimateContentLength() const { return m_estimateContentLength; }
 
-}
-bool TranscodingProfile::estimateContentLength() const { return m_estimateContentLength; }
-
-void TranscodingProfile::setEstimateContentLength(bool newEstimateContentLength) {
+void TranscodingProfile::setEstimateContentLength(std::optional<bool> newEstimateContentLength) {
 	m_estimateContentLength = newEstimateContentLength;
 }
 
-bool TranscodingProfile::enableMpegtsM2TsMode() const { return m_enableMpegtsM2TsMode; }
+std::optional<bool> TranscodingProfile::enableMpegtsM2TsMode() const { return m_enableMpegtsM2TsMode; }
 
-void TranscodingProfile::setEnableMpegtsM2TsMode(bool newEnableMpegtsM2TsMode) {
+void TranscodingProfile::setEnableMpegtsM2TsMode(std::optional<bool> newEnableMpegtsM2TsMode) {
 	m_enableMpegtsM2TsMode = newEnableMpegtsM2TsMode;
 }
 
@@ -238,9 +214,9 @@ void TranscodingProfile::setTranscodeSeekInfo(TranscodeSeekInfo newTranscodeSeek
 	m_transcodeSeekInfo = newTranscodeSeekInfo;
 }
 
-bool TranscodingProfile::copyTimestamps() const { return m_copyTimestamps; }
+std::optional<bool> TranscodingProfile::copyTimestamps() const { return m_copyTimestamps; }
 
-void TranscodingProfile::setCopyTimestamps(bool newCopyTimestamps) {
+void TranscodingProfile::setCopyTimestamps(std::optional<bool> newCopyTimestamps) {
 	m_copyTimestamps = newCopyTimestamps;
 }
 
@@ -250,9 +226,9 @@ void TranscodingProfile::setContext(EncodingContext newContext) {
 	m_context = newContext;
 }
 
-bool TranscodingProfile::enableSubtitlesInManifest() const { return m_enableSubtitlesInManifest; }
+std::optional<bool> TranscodingProfile::enableSubtitlesInManifest() const { return m_enableSubtitlesInManifest; }
 
-void TranscodingProfile::setEnableSubtitlesInManifest(bool newEnableSubtitlesInManifest) {
+void TranscodingProfile::setEnableSubtitlesInManifest(std::optional<bool> newEnableSubtitlesInManifest) {
 	m_enableSubtitlesInManifest = newEnableSubtitlesInManifest;
 }
 
@@ -269,24 +245,36 @@ void TranscodingProfile::setMaxAudioChannelsNull() {
 	m_maxAudioChannels.clear();
 
 }
-qint32 TranscodingProfile::minSegments() const { return m_minSegments; }
+std::optional<qint32> TranscodingProfile::minSegments() const { return m_minSegments; }
 
-void TranscodingProfile::setMinSegments(qint32 newMinSegments) {
+void TranscodingProfile::setMinSegments(std::optional<qint32> newMinSegments) {
 	m_minSegments = newMinSegments;
 }
 
-qint32 TranscodingProfile::segmentLength() const { return m_segmentLength; }
+std::optional<qint32> TranscodingProfile::segmentLength() const { return m_segmentLength; }
 
-void TranscodingProfile::setSegmentLength(qint32 newSegmentLength) {
+void TranscodingProfile::setSegmentLength(std::optional<qint32> newSegmentLength) {
 	m_segmentLength = newSegmentLength;
 }
 
-bool TranscodingProfile::breakOnNonKeyFrames() const { return m_breakOnNonKeyFrames; }
+std::optional<bool> TranscodingProfile::breakOnNonKeyFrames() const { return m_breakOnNonKeyFrames; }
 
-void TranscodingProfile::setBreakOnNonKeyFrames(bool newBreakOnNonKeyFrames) {
+void TranscodingProfile::setBreakOnNonKeyFrames(std::optional<bool> newBreakOnNonKeyFrames) {
 	m_breakOnNonKeyFrames = newBreakOnNonKeyFrames;
 }
 
+QList<ProfileCondition> TranscodingProfile::conditions() const { return m_conditions; }
+
+void TranscodingProfile::setConditions(QList<ProfileCondition> newConditions) {
+	m_conditions = newConditions;
+}
+
+std::optional<bool> TranscodingProfile::enableAudioVbrEncoding() const { return m_enableAudioVbrEncoding; }
+
+void TranscodingProfile::setEnableAudioVbrEncoding(std::optional<bool> newEnableAudioVbrEncoding) {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
 
 } // NS DTO
 
diff --git a/core/src/dto/trickplayinfo.cpp b/core/src/dto/trickplayinfo.cpp
new file mode 100644
index 0000000..293df2c
--- /dev/null
+++ b/core/src/dto/trickplayinfo.cpp
@@ -0,0 +1,168 @@
+/*
+ * 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/dto/trickplayinfo.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TrickplayInfo::TrickplayInfo() {}
+TrickplayInfo::TrickplayInfo (
+		qint32 width, 
+		qint32 height, 
+		qint32 tileWidth, 
+		qint32 tileHeight, 
+		qint32 thumbnailCount, 
+		qint32 interval, 
+		qint32 bandwidth 
+		) :
+	m_width(width),
+	m_height(height),
+	m_tileWidth(tileWidth),
+	m_tileHeight(tileHeight),
+	m_thumbnailCount(thumbnailCount),
+	m_interval(interval),
+	m_bandwidth(bandwidth) { }
+
+
+
+TrickplayInfo::TrickplayInfo(const TrickplayInfo &other) :
+
+	m_width(other.m_width),
+	m_height(other.m_height),
+	m_tileWidth(other.m_tileWidth),
+	m_tileHeight(other.m_tileHeight),
+	m_thumbnailCount(other.m_thumbnailCount),
+	m_interval(other.m_interval),
+	m_bandwidth(other.m_bandwidth){}
+
+
+void TrickplayInfo::replaceData(TrickplayInfo &other) {
+	m_width = other.m_width;
+	m_height = other.m_height;
+	m_tileWidth = other.m_tileWidth;
+	m_tileHeight = other.m_tileHeight;
+	m_thumbnailCount = other.m_thumbnailCount;
+	m_interval = other.m_interval;
+	m_bandwidth = other.m_bandwidth;
+}
+
+TrickplayInfo TrickplayInfo::fromJson(QJsonObject source) {
+	TrickplayInfo instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void TrickplayInfo::setFromJson(QJsonObject source) {
+	m_width = Jellyfin::Support::fromJsonValue<qint32>(source["Width"]);
+	m_height = Jellyfin::Support::fromJsonValue<qint32>(source["Height"]);
+	m_tileWidth = Jellyfin::Support::fromJsonValue<qint32>(source["TileWidth"]);
+	m_tileHeight = Jellyfin::Support::fromJsonValue<qint32>(source["TileHeight"]);
+	m_thumbnailCount = Jellyfin::Support::fromJsonValue<qint32>(source["ThumbnailCount"]);
+	m_interval = Jellyfin::Support::fromJsonValue<qint32>(source["Interval"]);
+	m_bandwidth = Jellyfin::Support::fromJsonValue<qint32>(source["Bandwidth"]);
+
+}
+	
+QJsonObject TrickplayInfo::toJson() const {
+	QJsonObject result;
+	
+	result["Width"] = Jellyfin::Support::toJsonValue<qint32>(m_width);		
+	result["Height"] = Jellyfin::Support::toJsonValue<qint32>(m_height);		
+	result["TileWidth"] = Jellyfin::Support::toJsonValue<qint32>(m_tileWidth);		
+	result["TileHeight"] = Jellyfin::Support::toJsonValue<qint32>(m_tileHeight);		
+	result["ThumbnailCount"] = Jellyfin::Support::toJsonValue<qint32>(m_thumbnailCount);		
+	result["Interval"] = Jellyfin::Support::toJsonValue<qint32>(m_interval);		
+	result["Bandwidth"] = Jellyfin::Support::toJsonValue<qint32>(m_bandwidth);	
+	return result;
+}
+
+qint32 TrickplayInfo::width() const { return m_width; }
+
+void TrickplayInfo::setWidth(qint32 newWidth) {
+	m_width = newWidth;
+}
+
+qint32 TrickplayInfo::height() const { return m_height; }
+
+void TrickplayInfo::setHeight(qint32 newHeight) {
+	m_height = newHeight;
+}
+
+qint32 TrickplayInfo::tileWidth() const { return m_tileWidth; }
+
+void TrickplayInfo::setTileWidth(qint32 newTileWidth) {
+	m_tileWidth = newTileWidth;
+}
+
+qint32 TrickplayInfo::tileHeight() const { return m_tileHeight; }
+
+void TrickplayInfo::setTileHeight(qint32 newTileHeight) {
+	m_tileHeight = newTileHeight;
+}
+
+qint32 TrickplayInfo::thumbnailCount() const { return m_thumbnailCount; }
+
+void TrickplayInfo::setThumbnailCount(qint32 newThumbnailCount) {
+	m_thumbnailCount = newThumbnailCount;
+}
+
+qint32 TrickplayInfo::interval() const { return m_interval; }
+
+void TrickplayInfo::setInterval(qint32 newInterval) {
+	m_interval = newInterval;
+}
+
+qint32 TrickplayInfo::bandwidth() const { return m_bandwidth; }
+
+void TrickplayInfo::setBandwidth(qint32 newBandwidth) {
+	m_bandwidth = newBandwidth;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayInfo = Jellyfin::DTO::TrickplayInfo;
+
+template <>
+TrickplayInfo fromJsonValue(const QJsonValue &source, convertType<TrickplayInfo>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return TrickplayInfo::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const TrickplayInfo &source, convertType<TrickplayInfo>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/trickplayoptions.cpp b/core/src/dto/trickplayoptions.cpp
new file mode 100644
index 0000000..9ed024e
--- /dev/null
+++ b/core/src/dto/trickplayoptions.cpp
@@ -0,0 +1,228 @@
+/*
+ * 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/dto/trickplayoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TrickplayOptions::TrickplayOptions() {}
+TrickplayOptions::TrickplayOptions (
+		bool enableHwAcceleration, 
+		bool enableHwEncoding, 
+		bool enableKeyFrameOnlyExtraction, 
+		TrickplayScanBehavior scanBehavior, 
+		ProcessPriorityClass processPriority, 
+		qint32 interval, 
+		QList<qint32> widthResolutions, 
+		qint32 tileWidth, 
+		qint32 tileHeight, 
+		qint32 qscale, 
+		qint32 jpegQuality, 
+		qint32 processThreads 
+		) :
+	m_enableHwAcceleration(enableHwAcceleration),
+	m_enableHwEncoding(enableHwEncoding),
+	m_enableKeyFrameOnlyExtraction(enableKeyFrameOnlyExtraction),
+	m_scanBehavior(scanBehavior),
+	m_processPriority(processPriority),
+	m_interval(interval),
+	m_widthResolutions(widthResolutions),
+	m_tileWidth(tileWidth),
+	m_tileHeight(tileHeight),
+	m_qscale(qscale),
+	m_jpegQuality(jpegQuality),
+	m_processThreads(processThreads) { }
+
+
+
+TrickplayOptions::TrickplayOptions(const TrickplayOptions &other) :
+
+	m_enableHwAcceleration(other.m_enableHwAcceleration),
+	m_enableHwEncoding(other.m_enableHwEncoding),
+	m_enableKeyFrameOnlyExtraction(other.m_enableKeyFrameOnlyExtraction),
+	m_scanBehavior(other.m_scanBehavior),
+	m_processPriority(other.m_processPriority),
+	m_interval(other.m_interval),
+	m_widthResolutions(other.m_widthResolutions),
+	m_tileWidth(other.m_tileWidth),
+	m_tileHeight(other.m_tileHeight),
+	m_qscale(other.m_qscale),
+	m_jpegQuality(other.m_jpegQuality),
+	m_processThreads(other.m_processThreads){}
+
+
+void TrickplayOptions::replaceData(TrickplayOptions &other) {
+	m_enableHwAcceleration = other.m_enableHwAcceleration;
+	m_enableHwEncoding = other.m_enableHwEncoding;
+	m_enableKeyFrameOnlyExtraction = other.m_enableKeyFrameOnlyExtraction;
+	m_scanBehavior = other.m_scanBehavior;
+	m_processPriority = other.m_processPriority;
+	m_interval = other.m_interval;
+	m_widthResolutions = other.m_widthResolutions;
+	m_tileWidth = other.m_tileWidth;
+	m_tileHeight = other.m_tileHeight;
+	m_qscale = other.m_qscale;
+	m_jpegQuality = other.m_jpegQuality;
+	m_processThreads = other.m_processThreads;
+}
+
+TrickplayOptions TrickplayOptions::fromJson(QJsonObject source) {
+	TrickplayOptions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void TrickplayOptions::setFromJson(QJsonObject source) {
+	m_enableHwAcceleration = Jellyfin::Support::fromJsonValue<bool>(source["EnableHwAcceleration"]);
+	m_enableHwEncoding = Jellyfin::Support::fromJsonValue<bool>(source["EnableHwEncoding"]);
+	m_enableKeyFrameOnlyExtraction = Jellyfin::Support::fromJsonValue<bool>(source["EnableKeyFrameOnlyExtraction"]);
+	m_scanBehavior = Jellyfin::Support::fromJsonValue<TrickplayScanBehavior>(source["ScanBehavior"]);
+	m_processPriority = Jellyfin::Support::fromJsonValue<ProcessPriorityClass>(source["ProcessPriority"]);
+	m_interval = Jellyfin::Support::fromJsonValue<qint32>(source["Interval"]);
+	m_widthResolutions = Jellyfin::Support::fromJsonValue<QList<qint32>>(source["WidthResolutions"]);
+	m_tileWidth = Jellyfin::Support::fromJsonValue<qint32>(source["TileWidth"]);
+	m_tileHeight = Jellyfin::Support::fromJsonValue<qint32>(source["TileHeight"]);
+	m_qscale = Jellyfin::Support::fromJsonValue<qint32>(source["Qscale"]);
+	m_jpegQuality = Jellyfin::Support::fromJsonValue<qint32>(source["JpegQuality"]);
+	m_processThreads = Jellyfin::Support::fromJsonValue<qint32>(source["ProcessThreads"]);
+
+}
+	
+QJsonObject TrickplayOptions::toJson() const {
+	QJsonObject result;
+	
+	result["EnableHwAcceleration"] = Jellyfin::Support::toJsonValue<bool>(m_enableHwAcceleration);		
+	result["EnableHwEncoding"] = Jellyfin::Support::toJsonValue<bool>(m_enableHwEncoding);		
+	result["EnableKeyFrameOnlyExtraction"] = Jellyfin::Support::toJsonValue<bool>(m_enableKeyFrameOnlyExtraction);		
+	result["ScanBehavior"] = Jellyfin::Support::toJsonValue<TrickplayScanBehavior>(m_scanBehavior);		
+	result["ProcessPriority"] = Jellyfin::Support::toJsonValue<ProcessPriorityClass>(m_processPriority);		
+	result["Interval"] = Jellyfin::Support::toJsonValue<qint32>(m_interval);		
+	result["WidthResolutions"] = Jellyfin::Support::toJsonValue<QList<qint32>>(m_widthResolutions);		
+	result["TileWidth"] = Jellyfin::Support::toJsonValue<qint32>(m_tileWidth);		
+	result["TileHeight"] = Jellyfin::Support::toJsonValue<qint32>(m_tileHeight);		
+	result["Qscale"] = Jellyfin::Support::toJsonValue<qint32>(m_qscale);		
+	result["JpegQuality"] = Jellyfin::Support::toJsonValue<qint32>(m_jpegQuality);		
+	result["ProcessThreads"] = Jellyfin::Support::toJsonValue<qint32>(m_processThreads);	
+	return result;
+}
+
+bool TrickplayOptions::enableHwAcceleration() const { return m_enableHwAcceleration; }
+
+void TrickplayOptions::setEnableHwAcceleration(bool newEnableHwAcceleration) {
+	m_enableHwAcceleration = newEnableHwAcceleration;
+}
+
+bool TrickplayOptions::enableHwEncoding() const { return m_enableHwEncoding; }
+
+void TrickplayOptions::setEnableHwEncoding(bool newEnableHwEncoding) {
+	m_enableHwEncoding = newEnableHwEncoding;
+}
+
+bool TrickplayOptions::enableKeyFrameOnlyExtraction() const { return m_enableKeyFrameOnlyExtraction; }
+
+void TrickplayOptions::setEnableKeyFrameOnlyExtraction(bool newEnableKeyFrameOnlyExtraction) {
+	m_enableKeyFrameOnlyExtraction = newEnableKeyFrameOnlyExtraction;
+}
+
+TrickplayScanBehavior TrickplayOptions::scanBehavior() const { return m_scanBehavior; }
+
+void TrickplayOptions::setScanBehavior(TrickplayScanBehavior newScanBehavior) {
+	m_scanBehavior = newScanBehavior;
+}
+
+ProcessPriorityClass TrickplayOptions::processPriority() const { return m_processPriority; }
+
+void TrickplayOptions::setProcessPriority(ProcessPriorityClass newProcessPriority) {
+	m_processPriority = newProcessPriority;
+}
+
+qint32 TrickplayOptions::interval() const { return m_interval; }
+
+void TrickplayOptions::setInterval(qint32 newInterval) {
+	m_interval = newInterval;
+}
+
+QList<qint32> TrickplayOptions::widthResolutions() const { return m_widthResolutions; }
+
+void TrickplayOptions::setWidthResolutions(QList<qint32> newWidthResolutions) {
+	m_widthResolutions = newWidthResolutions;
+}
+
+qint32 TrickplayOptions::tileWidth() const { return m_tileWidth; }
+
+void TrickplayOptions::setTileWidth(qint32 newTileWidth) {
+	m_tileWidth = newTileWidth;
+}
+
+qint32 TrickplayOptions::tileHeight() const { return m_tileHeight; }
+
+void TrickplayOptions::setTileHeight(qint32 newTileHeight) {
+	m_tileHeight = newTileHeight;
+}
+
+qint32 TrickplayOptions::qscale() const { return m_qscale; }
+
+void TrickplayOptions::setQscale(qint32 newQscale) {
+	m_qscale = newQscale;
+}
+
+qint32 TrickplayOptions::jpegQuality() const { return m_jpegQuality; }
+
+void TrickplayOptions::setJpegQuality(qint32 newJpegQuality) {
+	m_jpegQuality = newJpegQuality;
+}
+
+qint32 TrickplayOptions::processThreads() const { return m_processThreads; }
+
+void TrickplayOptions::setProcessThreads(qint32 newProcessThreads) {
+	m_processThreads = newProcessThreads;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayOptions = Jellyfin::DTO::TrickplayOptions;
+
+template <>
+TrickplayOptions fromJsonValue(const QJsonValue &source, convertType<TrickplayOptions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return TrickplayOptions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const TrickplayOptions &source, convertType<TrickplayOptions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/trickplayscanbehavior.cpp b/core/src/dto/trickplayscanbehavior.cpp
new file mode 100644
index 0000000..c292feb
--- /dev/null
+++ b/core/src/dto/trickplayscanbehavior.cpp
@@ -0,0 +1,73 @@
+/*
+ * 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/dto/trickplayscanbehavior.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+TrickplayScanBehaviorClass::TrickplayScanBehaviorClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using TrickplayScanBehavior = Jellyfin::DTO::TrickplayScanBehavior;
+
+template <>
+TrickplayScanBehavior fromJsonValue(const QJsonValue &source, convertType<TrickplayScanBehavior>) {
+	if (!source.isString()) return TrickplayScanBehavior::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Blocking")) {
+		return TrickplayScanBehavior::Blocking;
+	}
+	if (str == QStringLiteral("NonBlocking")) {
+		return TrickplayScanBehavior::NonBlocking;
+	}
+	
+	return TrickplayScanBehavior::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const TrickplayScanBehavior &source, convertType<TrickplayScanBehavior>) {
+	switch(source) {
+	case TrickplayScanBehavior::Blocking:
+		return QStringLiteral("Blocking");
+	case TrickplayScanBehavior::NonBlocking:
+		return QStringLiteral("NonBlocking");
+
+	case TrickplayScanBehavior::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/tunerhostinfo.cpp b/core/src/dto/tunerhostinfo.cpp
index f9f17af..a99c5ae 100644
--- a/core/src/dto/tunerhostinfo.cpp
+++ b/core/src/dto/tunerhostinfo.cpp
@@ -36,13 +36,21 @@ TunerHostInfo::TunerHostInfo() {}
 TunerHostInfo::TunerHostInfo (
 		bool importFavoritesOnly, 
 		bool allowHWTranscoding, 
+		bool allowFmp4TranscodingContainer, 
+		bool allowStreamSharing, 
+		qint32 fallbackMaxStreamingBitrate, 
 		bool enableStreamLooping, 
-		qint32 tunerCount 
+		qint32 tunerCount, 
+		bool ignoreDts 
 		) :
 	m_importFavoritesOnly(importFavoritesOnly),
 	m_allowHWTranscoding(allowHWTranscoding),
+	m_allowFmp4TranscodingContainer(allowFmp4TranscodingContainer),
+	m_allowStreamSharing(allowStreamSharing),
+	m_fallbackMaxStreamingBitrate(fallbackMaxStreamingBitrate),
 	m_enableStreamLooping(enableStreamLooping),
-	m_tunerCount(tunerCount) { }
+	m_tunerCount(tunerCount),
+	m_ignoreDts(ignoreDts) { }
 
 
 
@@ -55,10 +63,14 @@ TunerHostInfo::TunerHostInfo(const TunerHostInfo &other) :
 	m_friendlyName(other.m_friendlyName),
 	m_importFavoritesOnly(other.m_importFavoritesOnly),
 	m_allowHWTranscoding(other.m_allowHWTranscoding),
+	m_allowFmp4TranscodingContainer(other.m_allowFmp4TranscodingContainer),
+	m_allowStreamSharing(other.m_allowStreamSharing),
+	m_fallbackMaxStreamingBitrate(other.m_fallbackMaxStreamingBitrate),
 	m_enableStreamLooping(other.m_enableStreamLooping),
 	m_source(other.m_source),
 	m_tunerCount(other.m_tunerCount),
-	m_userAgent(other.m_userAgent){}
+	m_userAgent(other.m_userAgent),
+	m_ignoreDts(other.m_ignoreDts){}
 
 
 void TunerHostInfo::replaceData(TunerHostInfo &other) {
@@ -69,10 +81,14 @@ void TunerHostInfo::replaceData(TunerHostInfo &other) {
 	m_friendlyName = other.m_friendlyName;
 	m_importFavoritesOnly = other.m_importFavoritesOnly;
 	m_allowHWTranscoding = other.m_allowHWTranscoding;
+	m_allowFmp4TranscodingContainer = other.m_allowFmp4TranscodingContainer;
+	m_allowStreamSharing = other.m_allowStreamSharing;
+	m_fallbackMaxStreamingBitrate = other.m_fallbackMaxStreamingBitrate;
 	m_enableStreamLooping = other.m_enableStreamLooping;
 	m_source = other.m_source;
 	m_tunerCount = other.m_tunerCount;
 	m_userAgent = other.m_userAgent;
+	m_ignoreDts = other.m_ignoreDts;
 }
 
 TunerHostInfo TunerHostInfo::fromJson(QJsonObject source) {
@@ -90,10 +106,14 @@ void TunerHostInfo::setFromJson(QJsonObject source) {
 	m_friendlyName = Jellyfin::Support::fromJsonValue<QString>(source["FriendlyName"]);
 	m_importFavoritesOnly = Jellyfin::Support::fromJsonValue<bool>(source["ImportFavoritesOnly"]);
 	m_allowHWTranscoding = Jellyfin::Support::fromJsonValue<bool>(source["AllowHWTranscoding"]);
+	m_allowFmp4TranscodingContainer = Jellyfin::Support::fromJsonValue<bool>(source["AllowFmp4TranscodingContainer"]);
+	m_allowStreamSharing = Jellyfin::Support::fromJsonValue<bool>(source["AllowStreamSharing"]);
+	m_fallbackMaxStreamingBitrate = Jellyfin::Support::fromJsonValue<qint32>(source["FallbackMaxStreamingBitrate"]);
 	m_enableStreamLooping = Jellyfin::Support::fromJsonValue<bool>(source["EnableStreamLooping"]);
 	m_source = Jellyfin::Support::fromJsonValue<QString>(source["Source"]);
 	m_tunerCount = Jellyfin::Support::fromJsonValue<qint32>(source["TunerCount"]);
 	m_userAgent = Jellyfin::Support::fromJsonValue<QString>(source["UserAgent"]);
+	m_ignoreDts = Jellyfin::Support::fromJsonValue<bool>(source["IgnoreDts"]);
 
 }
 	
@@ -127,6 +147,9 @@ QJsonObject TunerHostInfo::toJson() const {
 			
 	result["ImportFavoritesOnly"] = Jellyfin::Support::toJsonValue<bool>(m_importFavoritesOnly);		
 	result["AllowHWTranscoding"] = Jellyfin::Support::toJsonValue<bool>(m_allowHWTranscoding);		
+	result["AllowFmp4TranscodingContainer"] = Jellyfin::Support::toJsonValue<bool>(m_allowFmp4TranscodingContainer);		
+	result["AllowStreamSharing"] = Jellyfin::Support::toJsonValue<bool>(m_allowStreamSharing);		
+	result["FallbackMaxStreamingBitrate"] = Jellyfin::Support::toJsonValue<qint32>(m_fallbackMaxStreamingBitrate);		
 	result["EnableStreamLooping"] = Jellyfin::Support::toJsonValue<bool>(m_enableStreamLooping);		
 	
 	if (!(m_source.isNull())) {
@@ -138,7 +161,8 @@ QJsonObject TunerHostInfo::toJson() const {
 	if (!(m_userAgent.isNull())) {
 		result["UserAgent"] = Jellyfin::Support::toJsonValue<QString>(m_userAgent);
 	}
-		
+			
+	result["IgnoreDts"] = Jellyfin::Support::toJsonValue<bool>(m_ignoreDts);	
 	return result;
 }
 
@@ -219,6 +243,24 @@ void TunerHostInfo::setAllowHWTranscoding(bool newAllowHWTranscoding) {
 	m_allowHWTranscoding = newAllowHWTranscoding;
 }
 
+bool TunerHostInfo::allowFmp4TranscodingContainer() const { return m_allowFmp4TranscodingContainer; }
+
+void TunerHostInfo::setAllowFmp4TranscodingContainer(bool newAllowFmp4TranscodingContainer) {
+	m_allowFmp4TranscodingContainer = newAllowFmp4TranscodingContainer;
+}
+
+bool TunerHostInfo::allowStreamSharing() const { return m_allowStreamSharing; }
+
+void TunerHostInfo::setAllowStreamSharing(bool newAllowStreamSharing) {
+	m_allowStreamSharing = newAllowStreamSharing;
+}
+
+qint32 TunerHostInfo::fallbackMaxStreamingBitrate() const { return m_fallbackMaxStreamingBitrate; }
+
+void TunerHostInfo::setFallbackMaxStreamingBitrate(qint32 newFallbackMaxStreamingBitrate) {
+	m_fallbackMaxStreamingBitrate = newFallbackMaxStreamingBitrate;
+}
+
 bool TunerHostInfo::enableStreamLooping() const { return m_enableStreamLooping; }
 
 void TunerHostInfo::setEnableStreamLooping(bool newEnableStreamLooping) {
@@ -257,6 +299,12 @@ void TunerHostInfo::setUserAgentNull() {
 	m_userAgent.clear();
 
 }
+bool TunerHostInfo::ignoreDts() const { return m_ignoreDts; }
+
+void TunerHostInfo::setIgnoreDts(bool newIgnoreDts) {
+	m_ignoreDts = newIgnoreDts;
+}
+
 
 } // NS DTO
 
diff --git a/core/src/dto/updatemediapathrequestdto.cpp b/core/src/dto/updatemediapathrequestdto.cpp
new file mode 100644
index 0000000..2adb37b
--- /dev/null
+++ b/core/src/dto/updatemediapathrequestdto.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/updatemediapathrequestdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UpdateMediaPathRequestDto::UpdateMediaPathRequestDto() {}
+UpdateMediaPathRequestDto::UpdateMediaPathRequestDto (
+		QString name, 
+		QSharedPointer<MediaPathInfo> pathInfo 
+		) :
+	m_name(name),
+	m_pathInfo(pathInfo) { }
+
+
+
+UpdateMediaPathRequestDto::UpdateMediaPathRequestDto(const UpdateMediaPathRequestDto &other) :
+
+	m_name(other.m_name),
+	m_pathInfo(other.m_pathInfo){}
+
+
+void UpdateMediaPathRequestDto::replaceData(UpdateMediaPathRequestDto &other) {
+	m_name = other.m_name;
+	m_pathInfo = other.m_pathInfo;
+}
+
+UpdateMediaPathRequestDto UpdateMediaPathRequestDto::fromJson(QJsonObject source) {
+	UpdateMediaPathRequestDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UpdateMediaPathRequestDto::setFromJson(QJsonObject source) {
+	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_pathInfo = Jellyfin::Support::fromJsonValue<QSharedPointer<MediaPathInfo>>(source["PathInfo"]);
+
+}
+	
+QJsonObject UpdateMediaPathRequestDto::toJson() const {
+	QJsonObject result;
+	
+	result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);		
+	result["PathInfo"] = Jellyfin::Support::toJsonValue<QSharedPointer<MediaPathInfo>>(m_pathInfo);	
+	return result;
+}
+
+QString UpdateMediaPathRequestDto::name() const { return m_name; }
+
+void UpdateMediaPathRequestDto::setName(QString newName) {
+	m_name = newName;
+}
+
+QSharedPointer<MediaPathInfo> UpdateMediaPathRequestDto::pathInfo() const { return m_pathInfo; }
+
+void UpdateMediaPathRequestDto::setPathInfo(QSharedPointer<MediaPathInfo> newPathInfo) {
+	m_pathInfo = newPathInfo;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using UpdateMediaPathRequestDto = Jellyfin::DTO::UpdateMediaPathRequestDto;
+
+template <>
+UpdateMediaPathRequestDto fromJsonValue(const QJsonValue &source, convertType<UpdateMediaPathRequestDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UpdateMediaPathRequestDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UpdateMediaPathRequestDto &source, convertType<UpdateMediaPathRequestDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/updateplaylistdto.cpp b/core/src/dto/updateplaylistdto.cpp
new file mode 100644
index 0000000..5a8bc7e
--- /dev/null
+++ b/core/src/dto/updateplaylistdto.cpp
@@ -0,0 +1,164 @@
+/*
+ * 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/dto/updateplaylistdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UpdatePlaylistDto::UpdatePlaylistDto() {}
+
+UpdatePlaylistDto::UpdatePlaylistDto(const UpdatePlaylistDto &other) :
+
+	m_name(other.m_name),
+	m_ids(other.m_ids),
+	m_users(other.m_users),
+	m_isPublic(other.m_isPublic){}
+
+
+void UpdatePlaylistDto::replaceData(UpdatePlaylistDto &other) {
+	m_name = other.m_name;
+	m_ids = other.m_ids;
+	m_users = other.m_users;
+	m_isPublic = other.m_isPublic;
+}
+
+UpdatePlaylistDto UpdatePlaylistDto::fromJson(QJsonObject source) {
+	UpdatePlaylistDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UpdatePlaylistDto::setFromJson(QJsonObject source) {
+	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
+	m_ids = Jellyfin::Support::fromJsonValue<QStringList>(source["Ids"]);
+	m_users = Jellyfin::Support::fromJsonValue<QList<PlaylistUserPermissions>>(source["Users"]);
+	m_isPublic = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsPublic"]);
+
+}
+	
+QJsonObject UpdatePlaylistDto::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_name.isNull())) {
+		result["Name"] = Jellyfin::Support::toJsonValue<QString>(m_name);
+	}
+			
+	
+	if (!(m_ids.size() == 0)) {
+		result["Ids"] = Jellyfin::Support::toJsonValue<QStringList>(m_ids);
+	}
+			
+	
+	if (!(m_users.size() == 0)) {
+		result["Users"] = Jellyfin::Support::toJsonValue<QList<PlaylistUserPermissions>>(m_users);
+	}
+			
+	
+	if (!(!m_isPublic.has_value())) {
+		result["IsPublic"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_isPublic);
+	}
+		
+	return result;
+}
+
+QString UpdatePlaylistDto::name() const { return m_name; }
+
+void UpdatePlaylistDto::setName(QString newName) {
+	m_name = newName;
+}
+bool UpdatePlaylistDto::nameNull() const {
+	return m_name.isNull();
+}
+
+void UpdatePlaylistDto::setNameNull() {
+	m_name.clear();
+
+}
+QStringList UpdatePlaylistDto::ids() const { return m_ids; }
+
+void UpdatePlaylistDto::setIds(QStringList newIds) {
+	m_ids = newIds;
+}
+bool UpdatePlaylistDto::idsNull() const {
+	return m_ids.size() == 0;
+}
+
+void UpdatePlaylistDto::setIdsNull() {
+	m_ids.clear();
+
+}
+QList<PlaylistUserPermissions> UpdatePlaylistDto::users() const { return m_users; }
+
+void UpdatePlaylistDto::setUsers(QList<PlaylistUserPermissions> newUsers) {
+	m_users = newUsers;
+}
+bool UpdatePlaylistDto::usersNull() const {
+	return m_users.size() == 0;
+}
+
+void UpdatePlaylistDto::setUsersNull() {
+	m_users.clear();
+
+}
+std::optional<bool> UpdatePlaylistDto::isPublic() const { return m_isPublic; }
+
+void UpdatePlaylistDto::setIsPublic(std::optional<bool> newIsPublic) {
+	m_isPublic = newIsPublic;
+}
+bool UpdatePlaylistDto::isPublicNull() const {
+	return !m_isPublic.has_value();
+}
+
+void UpdatePlaylistDto::setIsPublicNull() {
+	m_isPublic = std::nullopt;
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using UpdatePlaylistDto = Jellyfin::DTO::UpdatePlaylistDto;
+
+template <>
+UpdatePlaylistDto fromJsonValue(const QJsonValue &source, convertType<UpdatePlaylistDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UpdatePlaylistDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UpdatePlaylistDto &source, convertType<UpdatePlaylistDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/updateplaylistuserdto.cpp b/core/src/dto/updateplaylistuserdto.cpp
new file mode 100644
index 0000000..eeecca0
--- /dev/null
+++ b/core/src/dto/updateplaylistuserdto.cpp
@@ -0,0 +1,101 @@
+/*
+ * 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/dto/updateplaylistuserdto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UpdatePlaylistUserDto::UpdatePlaylistUserDto() {}
+
+UpdatePlaylistUserDto::UpdatePlaylistUserDto(const UpdatePlaylistUserDto &other) :
+
+	m_canEdit(other.m_canEdit){}
+
+
+void UpdatePlaylistUserDto::replaceData(UpdatePlaylistUserDto &other) {
+	m_canEdit = other.m_canEdit;
+}
+
+UpdatePlaylistUserDto UpdatePlaylistUserDto::fromJson(QJsonObject source) {
+	UpdatePlaylistUserDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UpdatePlaylistUserDto::setFromJson(QJsonObject source) {
+	m_canEdit = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["CanEdit"]);
+
+}
+	
+QJsonObject UpdatePlaylistUserDto::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(!m_canEdit.has_value())) {
+		result["CanEdit"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_canEdit);
+	}
+		
+	return result;
+}
+
+std::optional<bool> UpdatePlaylistUserDto::canEdit() const { return m_canEdit; }
+
+void UpdatePlaylistUserDto::setCanEdit(std::optional<bool> newCanEdit) {
+	m_canEdit = newCanEdit;
+}
+bool UpdatePlaylistUserDto::canEditNull() const {
+	return !m_canEdit.has_value();
+}
+
+void UpdatePlaylistUserDto::setCanEditNull() {
+	m_canEdit = std::nullopt;
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using UpdatePlaylistUserDto = Jellyfin::DTO::UpdatePlaylistUserDto;
+
+template <>
+UpdatePlaylistUserDto fromJsonValue(const QJsonValue &source, convertType<UpdatePlaylistUserDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UpdatePlaylistUserDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UpdatePlaylistUserDto &source, convertType<UpdatePlaylistUserDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/updateusereasypassword.cpp b/core/src/dto/updateusereasypassword.cpp
deleted file mode 100644
index 6b0ca03..0000000
--- a/core/src/dto/updateusereasypassword.cpp
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * 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/dto/updateusereasypassword.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-UpdateUserEasyPassword::UpdateUserEasyPassword() {}
-UpdateUserEasyPassword::UpdateUserEasyPassword (
-		bool resetPassword 
-		) :
-	m_resetPassword(resetPassword) { }
-
-
-
-UpdateUserEasyPassword::UpdateUserEasyPassword(const UpdateUserEasyPassword &other) :
-
-	m_newPassword(other.m_newPassword),
-	m_newPw(other.m_newPw),
-	m_resetPassword(other.m_resetPassword){}
-
-
-void UpdateUserEasyPassword::replaceData(UpdateUserEasyPassword &other) {
-	m_newPassword = other.m_newPassword;
-	m_newPw = other.m_newPw;
-	m_resetPassword = other.m_resetPassword;
-}
-
-UpdateUserEasyPassword UpdateUserEasyPassword::fromJson(QJsonObject source) {
-	UpdateUserEasyPassword instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void UpdateUserEasyPassword::setFromJson(QJsonObject source) {
-	m_newPassword = Jellyfin::Support::fromJsonValue<QString>(source["NewPassword"]);
-	m_newPw = Jellyfin::Support::fromJsonValue<QString>(source["NewPw"]);
-	m_resetPassword = Jellyfin::Support::fromJsonValue<bool>(source["ResetPassword"]);
-
-}
-	
-QJsonObject UpdateUserEasyPassword::toJson() const {
-	QJsonObject result;
-	
-	
-	if (!(m_newPassword.isNull())) {
-		result["NewPassword"] = Jellyfin::Support::toJsonValue<QString>(m_newPassword);
-	}
-			
-	
-	if (!(m_newPw.isNull())) {
-		result["NewPw"] = Jellyfin::Support::toJsonValue<QString>(m_newPw);
-	}
-			
-	result["ResetPassword"] = Jellyfin::Support::toJsonValue<bool>(m_resetPassword);	
-	return result;
-}
-
-QString UpdateUserEasyPassword::newPassword() const { return m_newPassword; }
-
-void UpdateUserEasyPassword::setNewPassword(QString newNewPassword) {
-	m_newPassword = newNewPassword;
-}
-bool UpdateUserEasyPassword::newPasswordNull() const {
-	return m_newPassword.isNull();
-}
-
-void UpdateUserEasyPassword::setNewPasswordNull() {
-	m_newPassword.clear();
-
-}
-QString UpdateUserEasyPassword::newPw() const { return m_newPw; }
-
-void UpdateUserEasyPassword::setNewPw(QString newNewPw) {
-	m_newPw = newNewPw;
-}
-bool UpdateUserEasyPassword::newPwNull() const {
-	return m_newPw.isNull();
-}
-
-void UpdateUserEasyPassword::setNewPwNull() {
-	m_newPw.clear();
-
-}
-bool UpdateUserEasyPassword::resetPassword() const { return m_resetPassword; }
-
-void UpdateUserEasyPassword::setResetPassword(bool newResetPassword) {
-	m_resetPassword = newResetPassword;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using UpdateUserEasyPassword = Jellyfin::DTO::UpdateUserEasyPassword;
-
-template <>
-UpdateUserEasyPassword fromJsonValue(const QJsonValue &source, convertType<UpdateUserEasyPassword>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return UpdateUserEasyPassword::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const UpdateUserEasyPassword &source, convertType<UpdateUserEasyPassword>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/updateuseritemdatadto.cpp b/core/src/dto/updateuseritemdatadto.cpp
new file mode 100644
index 0000000..08feb14
--- /dev/null
+++ b/core/src/dto/updateuseritemdatadto.cpp
@@ -0,0 +1,311 @@
+/*
+ * 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/dto/updateuseritemdatadto.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UpdateUserItemDataDto::UpdateUserItemDataDto() {}
+
+UpdateUserItemDataDto::UpdateUserItemDataDto(const UpdateUserItemDataDto &other) :
+
+	m_rating(other.m_rating),
+	m_playedPercentage(other.m_playedPercentage),
+	m_unplayedItemCount(other.m_unplayedItemCount),
+	m_playbackPositionTicks(other.m_playbackPositionTicks),
+	m_playCount(other.m_playCount),
+	m_isFavorite(other.m_isFavorite),
+	m_likes(other.m_likes),
+	m_lastPlayedDate(other.m_lastPlayedDate),
+	m_played(other.m_played),
+	m_key(other.m_key),
+	m_itemId(other.m_itemId){}
+
+
+void UpdateUserItemDataDto::replaceData(UpdateUserItemDataDto &other) {
+	m_rating = other.m_rating;
+	m_playedPercentage = other.m_playedPercentage;
+	m_unplayedItemCount = other.m_unplayedItemCount;
+	m_playbackPositionTicks = other.m_playbackPositionTicks;
+	m_playCount = other.m_playCount;
+	m_isFavorite = other.m_isFavorite;
+	m_likes = other.m_likes;
+	m_lastPlayedDate = other.m_lastPlayedDate;
+	m_played = other.m_played;
+	m_key = other.m_key;
+	m_itemId = other.m_itemId;
+}
+
+UpdateUserItemDataDto UpdateUserItemDataDto::fromJson(QJsonObject source) {
+	UpdateUserItemDataDto instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UpdateUserItemDataDto::setFromJson(QJsonObject source) {
+	m_rating = Jellyfin::Support::fromJsonValue<std::optional<double>>(source["Rating"]);
+	m_playedPercentage = Jellyfin::Support::fromJsonValue<std::optional<double>>(source["PlayedPercentage"]);
+	m_unplayedItemCount = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["UnplayedItemCount"]);
+	m_playbackPositionTicks = Jellyfin::Support::fromJsonValue<std::optional<qint64>>(source["PlaybackPositionTicks"]);
+	m_playCount = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["PlayCount"]);
+	m_isFavorite = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["IsFavorite"]);
+	m_likes = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["Likes"]);
+	m_lastPlayedDate = Jellyfin::Support::fromJsonValue<QDateTime>(source["LastPlayedDate"]);
+	m_played = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["Played"]);
+	m_key = Jellyfin::Support::fromJsonValue<QString>(source["Key"]);
+	m_itemId = Jellyfin::Support::fromJsonValue<QString>(source["ItemId"]);
+
+}
+	
+QJsonObject UpdateUserItemDataDto::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(!m_rating.has_value())) {
+		result["Rating"] = Jellyfin::Support::toJsonValue<std::optional<double>>(m_rating);
+	}
+			
+	
+	if (!(!m_playedPercentage.has_value())) {
+		result["PlayedPercentage"] = Jellyfin::Support::toJsonValue<std::optional<double>>(m_playedPercentage);
+	}
+			
+	
+	if (!(!m_unplayedItemCount.has_value())) {
+		result["UnplayedItemCount"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_unplayedItemCount);
+	}
+			
+	
+	if (!(!m_playbackPositionTicks.has_value())) {
+		result["PlaybackPositionTicks"] = Jellyfin::Support::toJsonValue<std::optional<qint64>>(m_playbackPositionTicks);
+	}
+			
+	
+	if (!(!m_playCount.has_value())) {
+		result["PlayCount"] = Jellyfin::Support::toJsonValue<std::optional<qint32>>(m_playCount);
+	}
+			
+	
+	if (!(!m_isFavorite.has_value())) {
+		result["IsFavorite"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_isFavorite);
+	}
+			
+	
+	if (!(!m_likes.has_value())) {
+		result["Likes"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_likes);
+	}
+			
+	
+	if (!(m_lastPlayedDate.isNull())) {
+		result["LastPlayedDate"] = Jellyfin::Support::toJsonValue<QDateTime>(m_lastPlayedDate);
+	}
+			
+	
+	if (!(!m_played.has_value())) {
+		result["Played"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_played);
+	}
+			
+	
+	if (!(m_key.isNull())) {
+		result["Key"] = Jellyfin::Support::toJsonValue<QString>(m_key);
+	}
+			
+	
+	if (!(m_itemId.isNull())) {
+		result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);
+	}
+		
+	return result;
+}
+
+std::optional<double> UpdateUserItemDataDto::rating() const { return m_rating; }
+
+void UpdateUserItemDataDto::setRating(std::optional<double> newRating) {
+	m_rating = newRating;
+}
+bool UpdateUserItemDataDto::ratingNull() const {
+	return !m_rating.has_value();
+}
+
+void UpdateUserItemDataDto::setRatingNull() {
+	m_rating = std::nullopt;
+
+}
+std::optional<double> UpdateUserItemDataDto::playedPercentage() const { return m_playedPercentage; }
+
+void UpdateUserItemDataDto::setPlayedPercentage(std::optional<double> newPlayedPercentage) {
+	m_playedPercentage = newPlayedPercentage;
+}
+bool UpdateUserItemDataDto::playedPercentageNull() const {
+	return !m_playedPercentage.has_value();
+}
+
+void UpdateUserItemDataDto::setPlayedPercentageNull() {
+	m_playedPercentage = std::nullopt;
+
+}
+std::optional<qint32> UpdateUserItemDataDto::unplayedItemCount() const { return m_unplayedItemCount; }
+
+void UpdateUserItemDataDto::setUnplayedItemCount(std::optional<qint32> newUnplayedItemCount) {
+	m_unplayedItemCount = newUnplayedItemCount;
+}
+bool UpdateUserItemDataDto::unplayedItemCountNull() const {
+	return !m_unplayedItemCount.has_value();
+}
+
+void UpdateUserItemDataDto::setUnplayedItemCountNull() {
+	m_unplayedItemCount = std::nullopt;
+
+}
+std::optional<qint64> UpdateUserItemDataDto::playbackPositionTicks() const { return m_playbackPositionTicks; }
+
+void UpdateUserItemDataDto::setPlaybackPositionTicks(std::optional<qint64> newPlaybackPositionTicks) {
+	m_playbackPositionTicks = newPlaybackPositionTicks;
+}
+bool UpdateUserItemDataDto::playbackPositionTicksNull() const {
+	return !m_playbackPositionTicks.has_value();
+}
+
+void UpdateUserItemDataDto::setPlaybackPositionTicksNull() {
+	m_playbackPositionTicks = std::nullopt;
+
+}
+std::optional<qint32> UpdateUserItemDataDto::playCount() const { return m_playCount; }
+
+void UpdateUserItemDataDto::setPlayCount(std::optional<qint32> newPlayCount) {
+	m_playCount = newPlayCount;
+}
+bool UpdateUserItemDataDto::playCountNull() const {
+	return !m_playCount.has_value();
+}
+
+void UpdateUserItemDataDto::setPlayCountNull() {
+	m_playCount = std::nullopt;
+
+}
+std::optional<bool> UpdateUserItemDataDto::isFavorite() const { return m_isFavorite; }
+
+void UpdateUserItemDataDto::setIsFavorite(std::optional<bool> newIsFavorite) {
+	m_isFavorite = newIsFavorite;
+}
+bool UpdateUserItemDataDto::isFavoriteNull() const {
+	return !m_isFavorite.has_value();
+}
+
+void UpdateUserItemDataDto::setIsFavoriteNull() {
+	m_isFavorite = std::nullopt;
+
+}
+std::optional<bool> UpdateUserItemDataDto::likes() const { return m_likes; }
+
+void UpdateUserItemDataDto::setLikes(std::optional<bool> newLikes) {
+	m_likes = newLikes;
+}
+bool UpdateUserItemDataDto::likesNull() const {
+	return !m_likes.has_value();
+}
+
+void UpdateUserItemDataDto::setLikesNull() {
+	m_likes = std::nullopt;
+
+}
+QDateTime UpdateUserItemDataDto::lastPlayedDate() const { return m_lastPlayedDate; }
+
+void UpdateUserItemDataDto::setLastPlayedDate(QDateTime newLastPlayedDate) {
+	m_lastPlayedDate = newLastPlayedDate;
+}
+bool UpdateUserItemDataDto::lastPlayedDateNull() const {
+	return m_lastPlayedDate.isNull();
+}
+
+void UpdateUserItemDataDto::setLastPlayedDateNull() {
+	m_lastPlayedDate= QDateTime();
+
+}
+std::optional<bool> UpdateUserItemDataDto::played() const { return m_played; }
+
+void UpdateUserItemDataDto::setPlayed(std::optional<bool> newPlayed) {
+	m_played = newPlayed;
+}
+bool UpdateUserItemDataDto::playedNull() const {
+	return !m_played.has_value();
+}
+
+void UpdateUserItemDataDto::setPlayedNull() {
+	m_played = std::nullopt;
+
+}
+QString UpdateUserItemDataDto::key() const { return m_key; }
+
+void UpdateUserItemDataDto::setKey(QString newKey) {
+	m_key = newKey;
+}
+bool UpdateUserItemDataDto::keyNull() const {
+	return m_key.isNull();
+}
+
+void UpdateUserItemDataDto::setKeyNull() {
+	m_key.clear();
+
+}
+QString UpdateUserItemDataDto::itemId() const { return m_itemId; }
+
+void UpdateUserItemDataDto::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+bool UpdateUserItemDataDto::itemIdNull() const {
+	return m_itemId.isNull();
+}
+
+void UpdateUserItemDataDto::setItemIdNull() {
+	m_itemId.clear();
+
+}
+
+} // NS DTO
+
+namespace Support {
+
+using UpdateUserItemDataDto = Jellyfin::DTO::UpdateUserItemDataDto;
+
+template <>
+UpdateUserItemDataDto fromJsonValue(const QJsonValue &source, convertType<UpdateUserItemDataDto>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UpdateUserItemDataDto::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UpdateUserItemDataDto &source, convertType<UpdateUserItemDataDto>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/uploadsubtitledto.cpp b/core/src/dto/uploadsubtitledto.cpp
index ea04cbf..817acd5 100644
--- a/core/src/dto/uploadsubtitledto.cpp
+++ b/core/src/dto/uploadsubtitledto.cpp
@@ -37,11 +37,13 @@ UploadSubtitleDto::UploadSubtitleDto (
 		QString language, 
 		QString format, 
 		bool isForced, 
+		bool isHearingImpaired, 
 		QString data 
 		) :
 	m_language(language),
 	m_format(format),
 	m_isForced(isForced),
+	m_isHearingImpaired(isHearingImpaired),
 	m_data(data) { }
 
 
@@ -51,6 +53,7 @@ UploadSubtitleDto::UploadSubtitleDto(const UploadSubtitleDto &other) :
 	m_language(other.m_language),
 	m_format(other.m_format),
 	m_isForced(other.m_isForced),
+	m_isHearingImpaired(other.m_isHearingImpaired),
 	m_data(other.m_data){}
 
 
@@ -58,6 +61,7 @@ void UploadSubtitleDto::replaceData(UploadSubtitleDto &other) {
 	m_language = other.m_language;
 	m_format = other.m_format;
 	m_isForced = other.m_isForced;
+	m_isHearingImpaired = other.m_isHearingImpaired;
 	m_data = other.m_data;
 }
 
@@ -72,6 +76,7 @@ void UploadSubtitleDto::setFromJson(QJsonObject source) {
 	m_language = Jellyfin::Support::fromJsonValue<QString>(source["Language"]);
 	m_format = Jellyfin::Support::fromJsonValue<QString>(source["Format"]);
 	m_isForced = Jellyfin::Support::fromJsonValue<bool>(source["IsForced"]);
+	m_isHearingImpaired = Jellyfin::Support::fromJsonValue<bool>(source["IsHearingImpaired"]);
 	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
 
 }
@@ -82,6 +87,7 @@ QJsonObject UploadSubtitleDto::toJson() const {
 	result["Language"] = Jellyfin::Support::toJsonValue<QString>(m_language);		
 	result["Format"] = Jellyfin::Support::toJsonValue<QString>(m_format);		
 	result["IsForced"] = Jellyfin::Support::toJsonValue<bool>(m_isForced);		
+	result["IsHearingImpaired"] = Jellyfin::Support::toJsonValue<bool>(m_isHearingImpaired);		
 	result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);	
 	return result;
 }
@@ -104,6 +110,12 @@ void UploadSubtitleDto::setIsForced(bool newIsForced) {
 	m_isForced = newIsForced;
 }
 
+bool UploadSubtitleDto::isHearingImpaired() const { return m_isHearingImpaired; }
+
+void UploadSubtitleDto::setIsHearingImpaired(bool newIsHearingImpaired) {
+	m_isHearingImpaired = newIsHearingImpaired;
+}
+
 QString UploadSubtitleDto::data() const { return m_data; }
 
 void UploadSubtitleDto::setData(QString newData) {
diff --git a/core/src/dto/userconfiguration.cpp b/core/src/dto/userconfiguration.cpp
index 94b76a6..ad474c8 100644
--- a/core/src/dto/userconfiguration.cpp
+++ b/core/src/dto/userconfiguration.cpp
@@ -36,9 +36,13 @@ UserConfiguration::UserConfiguration() {}
 UserConfiguration::UserConfiguration (
 		bool playDefaultAudioTrack, 
 		bool displayMissingEpisodes, 
+		QStringList groupedFolders, 
 		SubtitlePlaybackMode subtitleMode, 
 		bool displayCollectionsView, 
 		bool enableLocalPassword, 
+		QStringList orderedViews, 
+		QStringList latestItemsExcludes, 
+		QStringList myMediaExcludes, 
 		bool hidePlayedInLatest, 
 		bool rememberAudioSelections, 
 		bool rememberSubtitleSelections, 
@@ -46,9 +50,13 @@ UserConfiguration::UserConfiguration (
 		) :
 	m_playDefaultAudioTrack(playDefaultAudioTrack),
 	m_displayMissingEpisodes(displayMissingEpisodes),
+	m_groupedFolders(groupedFolders),
 	m_subtitleMode(subtitleMode),
 	m_displayCollectionsView(displayCollectionsView),
 	m_enableLocalPassword(enableLocalPassword),
+	m_orderedViews(orderedViews),
+	m_latestItemsExcludes(latestItemsExcludes),
+	m_myMediaExcludes(myMediaExcludes),
 	m_hidePlayedInLatest(hidePlayedInLatest),
 	m_rememberAudioSelections(rememberAudioSelections),
 	m_rememberSubtitleSelections(rememberSubtitleSelections),
@@ -72,7 +80,8 @@ UserConfiguration::UserConfiguration(const UserConfiguration &other) :
 	m_hidePlayedInLatest(other.m_hidePlayedInLatest),
 	m_rememberAudioSelections(other.m_rememberAudioSelections),
 	m_rememberSubtitleSelections(other.m_rememberSubtitleSelections),
-	m_enableNextEpisodeAutoPlay(other.m_enableNextEpisodeAutoPlay){}
+	m_enableNextEpisodeAutoPlay(other.m_enableNextEpisodeAutoPlay),
+	m_castReceiverId(other.m_castReceiverId){}
 
 
 void UserConfiguration::replaceData(UserConfiguration &other) {
@@ -91,6 +100,7 @@ void UserConfiguration::replaceData(UserConfiguration &other) {
 	m_rememberAudioSelections = other.m_rememberAudioSelections;
 	m_rememberSubtitleSelections = other.m_rememberSubtitleSelections;
 	m_enableNextEpisodeAutoPlay = other.m_enableNextEpisodeAutoPlay;
+	m_castReceiverId = other.m_castReceiverId;
 }
 
 UserConfiguration UserConfiguration::fromJson(QJsonObject source) {
@@ -116,6 +126,7 @@ void UserConfiguration::setFromJson(QJsonObject source) {
 	m_rememberAudioSelections = Jellyfin::Support::fromJsonValue<bool>(source["RememberAudioSelections"]);
 	m_rememberSubtitleSelections = Jellyfin::Support::fromJsonValue<bool>(source["RememberSubtitleSelections"]);
 	m_enableNextEpisodeAutoPlay = Jellyfin::Support::fromJsonValue<bool>(source["EnableNextEpisodeAutoPlay"]);
+	m_castReceiverId = Jellyfin::Support::fromJsonValue<QString>(source["CastReceiverId"]);
 
 }
 	
@@ -134,33 +145,22 @@ QJsonObject UserConfiguration::toJson() const {
 	}
 			
 	result["DisplayMissingEpisodes"] = Jellyfin::Support::toJsonValue<bool>(m_displayMissingEpisodes);		
-	
-	if (!(m_groupedFolders.size() == 0)) {
-		result["GroupedFolders"] = Jellyfin::Support::toJsonValue<QStringList>(m_groupedFolders);
-	}
-			
+	result["GroupedFolders"] = Jellyfin::Support::toJsonValue<QStringList>(m_groupedFolders);		
 	result["SubtitleMode"] = Jellyfin::Support::toJsonValue<SubtitlePlaybackMode>(m_subtitleMode);		
 	result["DisplayCollectionsView"] = Jellyfin::Support::toJsonValue<bool>(m_displayCollectionsView);		
 	result["EnableLocalPassword"] = Jellyfin::Support::toJsonValue<bool>(m_enableLocalPassword);		
-	
-	if (!(m_orderedViews.size() == 0)) {
-		result["OrderedViews"] = Jellyfin::Support::toJsonValue<QStringList>(m_orderedViews);
-	}
-			
-	
-	if (!(m_latestItemsExcludes.size() == 0)) {
-		result["LatestItemsExcludes"] = Jellyfin::Support::toJsonValue<QStringList>(m_latestItemsExcludes);
-	}
-			
-	
-	if (!(m_myMediaExcludes.size() == 0)) {
-		result["MyMediaExcludes"] = Jellyfin::Support::toJsonValue<QStringList>(m_myMediaExcludes);
-	}
-			
+	result["OrderedViews"] = Jellyfin::Support::toJsonValue<QStringList>(m_orderedViews);		
+	result["LatestItemsExcludes"] = Jellyfin::Support::toJsonValue<QStringList>(m_latestItemsExcludes);		
+	result["MyMediaExcludes"] = Jellyfin::Support::toJsonValue<QStringList>(m_myMediaExcludes);		
 	result["HidePlayedInLatest"] = Jellyfin::Support::toJsonValue<bool>(m_hidePlayedInLatest);		
 	result["RememberAudioSelections"] = Jellyfin::Support::toJsonValue<bool>(m_rememberAudioSelections);		
 	result["RememberSubtitleSelections"] = Jellyfin::Support::toJsonValue<bool>(m_rememberSubtitleSelections);		
-	result["EnableNextEpisodeAutoPlay"] = Jellyfin::Support::toJsonValue<bool>(m_enableNextEpisodeAutoPlay);	
+	result["EnableNextEpisodeAutoPlay"] = Jellyfin::Support::toJsonValue<bool>(m_enableNextEpisodeAutoPlay);		
+	
+	if (!(m_castReceiverId.isNull())) {
+		result["CastReceiverId"] = Jellyfin::Support::toJsonValue<QString>(m_castReceiverId);
+	}
+		
 	return result;
 }
 
@@ -207,14 +207,7 @@ QStringList UserConfiguration::groupedFolders() const { return m_groupedFolders;
 void UserConfiguration::setGroupedFolders(QStringList newGroupedFolders) {
 	m_groupedFolders = newGroupedFolders;
 }
-bool UserConfiguration::groupedFoldersNull() const {
-	return m_groupedFolders.size() == 0;
-}
 
-void UserConfiguration::setGroupedFoldersNull() {
-	m_groupedFolders.clear();
-
-}
 SubtitlePlaybackMode UserConfiguration::subtitleMode() const { return m_subtitleMode; }
 
 void UserConfiguration::setSubtitleMode(SubtitlePlaybackMode newSubtitleMode) {
@@ -238,40 +231,19 @@ QStringList UserConfiguration::orderedViews() const { return m_orderedViews; }
 void UserConfiguration::setOrderedViews(QStringList newOrderedViews) {
 	m_orderedViews = newOrderedViews;
 }
-bool UserConfiguration::orderedViewsNull() const {
-	return m_orderedViews.size() == 0;
-}
 
-void UserConfiguration::setOrderedViewsNull() {
-	m_orderedViews.clear();
-
-}
 QStringList UserConfiguration::latestItemsExcludes() const { return m_latestItemsExcludes; }
 
 void UserConfiguration::setLatestItemsExcludes(QStringList newLatestItemsExcludes) {
 	m_latestItemsExcludes = newLatestItemsExcludes;
 }
-bool UserConfiguration::latestItemsExcludesNull() const {
-	return m_latestItemsExcludes.size() == 0;
-}
 
-void UserConfiguration::setLatestItemsExcludesNull() {
-	m_latestItemsExcludes.clear();
-
-}
 QStringList UserConfiguration::myMediaExcludes() const { return m_myMediaExcludes; }
 
 void UserConfiguration::setMyMediaExcludes(QStringList newMyMediaExcludes) {
 	m_myMediaExcludes = newMyMediaExcludes;
 }
-bool UserConfiguration::myMediaExcludesNull() const {
-	return m_myMediaExcludes.size() == 0;
-}
 
-void UserConfiguration::setMyMediaExcludesNull() {
-	m_myMediaExcludes.clear();
-
-}
 bool UserConfiguration::hidePlayedInLatest() const { return m_hidePlayedInLatest; }
 
 void UserConfiguration::setHidePlayedInLatest(bool newHidePlayedInLatest) {
@@ -296,6 +268,19 @@ void UserConfiguration::setEnableNextEpisodeAutoPlay(bool newEnableNextEpisodeAu
 	m_enableNextEpisodeAutoPlay = newEnableNextEpisodeAutoPlay;
 }
 
+QString UserConfiguration::castReceiverId() const { return m_castReceiverId; }
+
+void UserConfiguration::setCastReceiverId(QString newCastReceiverId) {
+	m_castReceiverId = newCastReceiverId;
+}
+bool UserConfiguration::castReceiverIdNull() const {
+	return m_castReceiverId.isNull();
+}
+
+void UserConfiguration::setCastReceiverIdNull() {
+	m_castReceiverId.clear();
+
+}
 
 } // NS DTO
 
diff --git a/core/src/dto/userdatachangedmessage.cpp b/core/src/dto/userdatachangedmessage.cpp
new file mode 100644
index 0000000..b6046b5
--- /dev/null
+++ b/core/src/dto/userdatachangedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/userdatachangedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UserDataChangedMessage::UserDataChangedMessage() {}
+UserDataChangedMessage::UserDataChangedMessage (
+		QSharedPointer<UserDataChangeInfo> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+UserDataChangedMessage::UserDataChangedMessage(const UserDataChangedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void UserDataChangedMessage::replaceData(UserDataChangedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+UserDataChangedMessage UserDataChangedMessage::fromJson(QJsonObject source) {
+	UserDataChangedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UserDataChangedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<UserDataChangeInfo>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject UserDataChangedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<UserDataChangeInfo>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<UserDataChangeInfo> UserDataChangedMessage::data() const { return m_data; }
+
+void UserDataChangedMessage::setData(QSharedPointer<UserDataChangeInfo> newData) {
+	m_data = newData;
+}
+
+QString UserDataChangedMessage::messageId() const { return m_messageId; }
+
+void UserDataChangedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType UserDataChangedMessage::messageType() const { return m_messageType; }
+
+void UserDataChangedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDataChangedMessage = Jellyfin::DTO::UserDataChangedMessage;
+
+template <>
+UserDataChangedMessage fromJsonValue(const QJsonValue &source, convertType<UserDataChangedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UserDataChangedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UserDataChangedMessage &source, convertType<UserDataChangedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/userdatachangeinfo.cpp b/core/src/dto/userdatachangeinfo.cpp
new file mode 100644
index 0000000..ecdc73e
--- /dev/null
+++ b/core/src/dto/userdatachangeinfo.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/userdatachangeinfo.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UserDataChangeInfo::UserDataChangeInfo() {}
+UserDataChangeInfo::UserDataChangeInfo (
+		QString userId, 
+		QList<UserItemDataDto> userDataList 
+		) :
+	m_userId(userId),
+	m_userDataList(userDataList) { }
+
+
+
+UserDataChangeInfo::UserDataChangeInfo(const UserDataChangeInfo &other) :
+
+	m_userId(other.m_userId),
+	m_userDataList(other.m_userDataList){}
+
+
+void UserDataChangeInfo::replaceData(UserDataChangeInfo &other) {
+	m_userId = other.m_userId;
+	m_userDataList = other.m_userDataList;
+}
+
+UserDataChangeInfo UserDataChangeInfo::fromJson(QJsonObject source) {
+	UserDataChangeInfo instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UserDataChangeInfo::setFromJson(QJsonObject source) {
+	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
+	m_userDataList = Jellyfin::Support::fromJsonValue<QList<UserItemDataDto>>(source["UserDataList"]);
+
+}
+	
+QJsonObject UserDataChangeInfo::toJson() const {
+	QJsonObject result;
+	
+	result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);		
+	result["UserDataList"] = Jellyfin::Support::toJsonValue<QList<UserItemDataDto>>(m_userDataList);	
+	return result;
+}
+
+QString UserDataChangeInfo::userId() const { return m_userId; }
+
+void UserDataChangeInfo::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+
+QList<UserItemDataDto> UserDataChangeInfo::userDataList() const { return m_userDataList; }
+
+void UserDataChangeInfo::setUserDataList(QList<UserItemDataDto> newUserDataList) {
+	m_userDataList = newUserDataList;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDataChangeInfo = Jellyfin::DTO::UserDataChangeInfo;
+
+template <>
+UserDataChangeInfo fromJsonValue(const QJsonValue &source, convertType<UserDataChangeInfo>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UserDataChangeInfo::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UserDataChangeInfo &source, convertType<UserDataChangeInfo>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/userdeletedmessage.cpp b/core/src/dto/userdeletedmessage.cpp
new file mode 100644
index 0000000..4d3f017
--- /dev/null
+++ b/core/src/dto/userdeletedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/userdeletedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UserDeletedMessage::UserDeletedMessage() {}
+UserDeletedMessage::UserDeletedMessage (
+		QString data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+UserDeletedMessage::UserDeletedMessage(const UserDeletedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void UserDeletedMessage::replaceData(UserDeletedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+UserDeletedMessage UserDeletedMessage::fromJson(QJsonObject source) {
+	UserDeletedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UserDeletedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QString>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject UserDeletedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QString>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QString UserDeletedMessage::data() const { return m_data; }
+
+void UserDeletedMessage::setData(QString newData) {
+	m_data = newData;
+}
+
+QString UserDeletedMessage::messageId() const { return m_messageId; }
+
+void UserDeletedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType UserDeletedMessage::messageType() const { return m_messageType; }
+
+void UserDeletedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserDeletedMessage = Jellyfin::DTO::UserDeletedMessage;
+
+template <>
+UserDeletedMessage fromJsonValue(const QJsonValue &source, convertType<UserDeletedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UserDeletedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UserDeletedMessage &source, convertType<UserDeletedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/useritemdatadto.cpp b/core/src/dto/useritemdatadto.cpp
index bdf4cd1..965f03c 100644
--- a/core/src/dto/useritemdatadto.cpp
+++ b/core/src/dto/useritemdatadto.cpp
@@ -37,12 +37,16 @@ UserItemDataDto::UserItemDataDto (
 		qint64 playbackPositionTicks, 
 		qint32 playCount, 
 		bool isFavorite, 
-		bool played 
+		bool played, 
+		QString key, 
+		QString itemId 
 		) :
 	m_playbackPositionTicks(playbackPositionTicks),
 	m_playCount(playCount),
 	m_isFavorite(isFavorite),
-	m_played(played) { }
+	m_played(played),
+	m_key(key),
+	m_itemId(itemId) { }
 
 
 
@@ -129,16 +133,8 @@ QJsonObject UserItemDataDto::toJson() const {
 	}
 			
 	result["Played"] = Jellyfin::Support::toJsonValue<bool>(m_played);		
-	
-	if (!(m_key.isNull())) {
-		result["Key"] = Jellyfin::Support::toJsonValue<QString>(m_key);
-	}
-			
-	
-	if (!(m_itemId.isNull())) {
-		result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);
-	}
-		
+	result["Key"] = Jellyfin::Support::toJsonValue<QString>(m_key);		
+	result["ItemId"] = Jellyfin::Support::toJsonValue<QString>(m_itemId);	
 	return result;
 }
 
@@ -236,27 +232,13 @@ QString UserItemDataDto::key() const { return m_key; }
 void UserItemDataDto::setKey(QString newKey) {
 	m_key = newKey;
 }
-bool UserItemDataDto::keyNull() const {
-	return m_key.isNull();
-}
 
-void UserItemDataDto::setKeyNull() {
-	m_key.clear();
-
-}
 QString UserItemDataDto::itemId() const { return m_itemId; }
 
 void UserItemDataDto::setItemId(QString newItemId) {
 	m_itemId = newItemId;
 }
-bool UserItemDataDto::itemIdNull() const {
-	return m_itemId.isNull();
-}
 
-void UserItemDataDto::setItemIdNull() {
-	m_itemId.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/userpolicy.cpp b/core/src/dto/userpolicy.cpp
index d303ba5..d8636d8 100644
--- a/core/src/dto/userpolicy.cpp
+++ b/core/src/dto/userpolicy.cpp
@@ -36,6 +36,9 @@ UserPolicy::UserPolicy() {}
 UserPolicy::UserPolicy (
 		bool isAdministrator, 
 		bool isHidden, 
+		std::optional<bool> enableCollectionManagement, 
+		std::optional<bool> enableSubtitleManagement, 
+		std::optional<bool> enableLyricManagement, 
 		bool isDisabled, 
 		bool enableUserPreferenceAccess, 
 		bool enableRemoteControlOfOtherUsers, 
@@ -60,10 +63,15 @@ UserPolicy::UserPolicy (
 		qint32 maxActiveSessions, 
 		bool enablePublicSharing, 
 		qint32 remoteClientBitrateLimit, 
+		QString authenticationProviderId, 
+		QString passwordResetProviderId, 
 		SyncPlayUserAccessType syncPlayAccess 
 		) :
 	m_isAdministrator(isAdministrator),
 	m_isHidden(isHidden),
+	m_enableCollectionManagement(enableCollectionManagement),
+	m_enableSubtitleManagement(enableSubtitleManagement),
+	m_enableLyricManagement(enableLyricManagement),
 	m_isDisabled(isDisabled),
 	m_enableUserPreferenceAccess(enableUserPreferenceAccess),
 	m_enableRemoteControlOfOtherUsers(enableRemoteControlOfOtherUsers),
@@ -88,6 +96,8 @@ UserPolicy::UserPolicy (
 	m_maxActiveSessions(maxActiveSessions),
 	m_enablePublicSharing(enablePublicSharing),
 	m_remoteClientBitrateLimit(remoteClientBitrateLimit),
+	m_authenticationProviderId(authenticationProviderId),
+	m_passwordResetProviderId(passwordResetProviderId),
 	m_syncPlayAccess(syncPlayAccess) { }
 
 
@@ -96,9 +106,13 @@ UserPolicy::UserPolicy(const UserPolicy &other) :
 
 	m_isAdministrator(other.m_isAdministrator),
 	m_isHidden(other.m_isHidden),
+	m_enableCollectionManagement(other.m_enableCollectionManagement),
+	m_enableSubtitleManagement(other.m_enableSubtitleManagement),
+	m_enableLyricManagement(other.m_enableLyricManagement),
 	m_isDisabled(other.m_isDisabled),
 	m_maxParentalRating(other.m_maxParentalRating),
 	m_blockedTags(other.m_blockedTags),
+	m_allowedTags(other.m_allowedTags),
 	m_enableUserPreferenceAccess(other.m_enableUserPreferenceAccess),
 	m_accessSchedules(other.m_accessSchedules),
 	m_blockUnratedItems(other.m_blockUnratedItems),
@@ -138,9 +152,13 @@ UserPolicy::UserPolicy(const UserPolicy &other) :
 void UserPolicy::replaceData(UserPolicy &other) {
 	m_isAdministrator = other.m_isAdministrator;
 	m_isHidden = other.m_isHidden;
+	m_enableCollectionManagement = other.m_enableCollectionManagement;
+	m_enableSubtitleManagement = other.m_enableSubtitleManagement;
+	m_enableLyricManagement = other.m_enableLyricManagement;
 	m_isDisabled = other.m_isDisabled;
 	m_maxParentalRating = other.m_maxParentalRating;
 	m_blockedTags = other.m_blockedTags;
+	m_allowedTags = other.m_allowedTags;
 	m_enableUserPreferenceAccess = other.m_enableUserPreferenceAccess;
 	m_accessSchedules = other.m_accessSchedules;
 	m_blockUnratedItems = other.m_blockUnratedItems;
@@ -187,9 +205,13 @@ UserPolicy UserPolicy::fromJson(QJsonObject source) {
 void UserPolicy::setFromJson(QJsonObject source) {
 	m_isAdministrator = Jellyfin::Support::fromJsonValue<bool>(source["IsAdministrator"]);
 	m_isHidden = Jellyfin::Support::fromJsonValue<bool>(source["IsHidden"]);
+	m_enableCollectionManagement = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableCollectionManagement"]);
+	m_enableSubtitleManagement = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableSubtitleManagement"]);
+	m_enableLyricManagement = Jellyfin::Support::fromJsonValue<std::optional<bool>>(source["EnableLyricManagement"]);
 	m_isDisabled = Jellyfin::Support::fromJsonValue<bool>(source["IsDisabled"]);
 	m_maxParentalRating = Jellyfin::Support::fromJsonValue<std::optional<qint32>>(source["MaxParentalRating"]);
 	m_blockedTags = Jellyfin::Support::fromJsonValue<QStringList>(source["BlockedTags"]);
+	m_allowedTags = Jellyfin::Support::fromJsonValue<QStringList>(source["AllowedTags"]);
 	m_enableUserPreferenceAccess = Jellyfin::Support::fromJsonValue<bool>(source["EnableUserPreferenceAccess"]);
 	m_accessSchedules = Jellyfin::Support::fromJsonValue<QList<AccessSchedule>>(source["AccessSchedules"]);
 	m_blockUnratedItems = Jellyfin::Support::fromJsonValue<QList<UnratedItem>>(source["BlockUnratedItems"]);
@@ -232,6 +254,9 @@ QJsonObject UserPolicy::toJson() const {
 	
 	result["IsAdministrator"] = Jellyfin::Support::toJsonValue<bool>(m_isAdministrator);		
 	result["IsHidden"] = Jellyfin::Support::toJsonValue<bool>(m_isHidden);		
+	result["EnableCollectionManagement"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableCollectionManagement);		
+	result["EnableSubtitleManagement"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableSubtitleManagement);		
+	result["EnableLyricManagement"] = Jellyfin::Support::toJsonValue<std::optional<bool>>(m_enableLyricManagement);		
 	result["IsDisabled"] = Jellyfin::Support::toJsonValue<bool>(m_isDisabled);		
 	
 	if (!(!m_maxParentalRating.has_value())) {
@@ -243,6 +268,11 @@ QJsonObject UserPolicy::toJson() const {
 		result["BlockedTags"] = Jellyfin::Support::toJsonValue<QStringList>(m_blockedTags);
 	}
 			
+	
+	if (!(m_allowedTags.size() == 0)) {
+		result["AllowedTags"] = Jellyfin::Support::toJsonValue<QStringList>(m_allowedTags);
+	}
+			
 	result["EnableUserPreferenceAccess"] = Jellyfin::Support::toJsonValue<bool>(m_enableUserPreferenceAccess);		
 	
 	if (!(m_accessSchedules.size() == 0)) {
@@ -306,16 +336,8 @@ QJsonObject UserPolicy::toJson() const {
 	}
 			
 	result["RemoteClientBitrateLimit"] = Jellyfin::Support::toJsonValue<qint32>(m_remoteClientBitrateLimit);		
-	
-	if (!(m_authenticationProviderId.isNull())) {
-		result["AuthenticationProviderId"] = Jellyfin::Support::toJsonValue<QString>(m_authenticationProviderId);
-	}
-			
-	
-	if (!(m_passwordResetProviderId.isNull())) {
-		result["PasswordResetProviderId"] = Jellyfin::Support::toJsonValue<QString>(m_passwordResetProviderId);
-	}
-			
+	result["AuthenticationProviderId"] = Jellyfin::Support::toJsonValue<QString>(m_authenticationProviderId);		
+	result["PasswordResetProviderId"] = Jellyfin::Support::toJsonValue<QString>(m_passwordResetProviderId);		
 	result["SyncPlayAccess"] = Jellyfin::Support::toJsonValue<SyncPlayUserAccessType>(m_syncPlayAccess);	
 	return result;
 }
@@ -332,6 +354,24 @@ void UserPolicy::setIsHidden(bool newIsHidden) {
 	m_isHidden = newIsHidden;
 }
 
+std::optional<bool> UserPolicy::enableCollectionManagement() const { return m_enableCollectionManagement; }
+
+void UserPolicy::setEnableCollectionManagement(std::optional<bool> newEnableCollectionManagement) {
+	m_enableCollectionManagement = newEnableCollectionManagement;
+}
+
+std::optional<bool> UserPolicy::enableSubtitleManagement() const { return m_enableSubtitleManagement; }
+
+void UserPolicy::setEnableSubtitleManagement(std::optional<bool> newEnableSubtitleManagement) {
+	m_enableSubtitleManagement = newEnableSubtitleManagement;
+}
+
+std::optional<bool> UserPolicy::enableLyricManagement() const { return m_enableLyricManagement; }
+
+void UserPolicy::setEnableLyricManagement(std::optional<bool> newEnableLyricManagement) {
+	m_enableLyricManagement = newEnableLyricManagement;
+}
+
 bool UserPolicy::isDisabled() const { return m_isDisabled; }
 
 void UserPolicy::setIsDisabled(bool newIsDisabled) {
@@ -363,6 +403,19 @@ bool UserPolicy::blockedTagsNull() const {
 void UserPolicy::setBlockedTagsNull() {
 	m_blockedTags.clear();
 
+}
+QStringList UserPolicy::allowedTags() const { return m_allowedTags; }
+
+void UserPolicy::setAllowedTags(QStringList newAllowedTags) {
+	m_allowedTags = newAllowedTags;
+}
+bool UserPolicy::allowedTagsNull() const {
+	return m_allowedTags.size() == 0;
+}
+
+void UserPolicy::setAllowedTagsNull() {
+	m_allowedTags.clear();
+
 }
 bool UserPolicy::enableUserPreferenceAccess() const { return m_enableUserPreferenceAccess; }
 
@@ -611,27 +664,13 @@ QString UserPolicy::authenticationProviderId() const { return m_authenticationPr
 void UserPolicy::setAuthenticationProviderId(QString newAuthenticationProviderId) {
 	m_authenticationProviderId = newAuthenticationProviderId;
 }
-bool UserPolicy::authenticationProviderIdNull() const {
-	return m_authenticationProviderId.isNull();
-}
 
-void UserPolicy::setAuthenticationProviderIdNull() {
-	m_authenticationProviderId.clear();
-
-}
 QString UserPolicy::passwordResetProviderId() const { return m_passwordResetProviderId; }
 
 void UserPolicy::setPasswordResetProviderId(QString newPasswordResetProviderId) {
 	m_passwordResetProviderId = newPasswordResetProviderId;
 }
-bool UserPolicy::passwordResetProviderIdNull() const {
-	return m_passwordResetProviderId.isNull();
-}
 
-void UserPolicy::setPasswordResetProviderIdNull() {
-	m_passwordResetProviderId.clear();
-
-}
 SyncPlayUserAccessType UserPolicy::syncPlayAccess() const { return m_syncPlayAccess; }
 
 void UserPolicy::setSyncPlayAccess(SyncPlayUserAccessType newSyncPlayAccess) {
diff --git a/core/src/dto/userupdatedmessage.cpp b/core/src/dto/userupdatedmessage.cpp
new file mode 100644
index 0000000..869dc08
--- /dev/null
+++ b/core/src/dto/userupdatedmessage.cpp
@@ -0,0 +1,120 @@
+/*
+ * 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/dto/userupdatedmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+UserUpdatedMessage::UserUpdatedMessage() {}
+UserUpdatedMessage::UserUpdatedMessage (
+		QSharedPointer<UserDto> data, 
+		QString messageId, 
+		SessionMessageType messageType 
+		) :
+	m_data(data),
+	m_messageId(messageId),
+	m_messageType(messageType) { }
+
+
+
+UserUpdatedMessage::UserUpdatedMessage(const UserUpdatedMessage &other) :
+
+	m_data(other.m_data),
+	m_messageId(other.m_messageId),
+	m_messageType(other.m_messageType){}
+
+
+void UserUpdatedMessage::replaceData(UserUpdatedMessage &other) {
+	m_data = other.m_data;
+	m_messageId = other.m_messageId;
+	m_messageType = other.m_messageType;
+}
+
+UserUpdatedMessage UserUpdatedMessage::fromJson(QJsonObject source) {
+	UserUpdatedMessage instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void UserUpdatedMessage::setFromJson(QJsonObject source) {
+	m_data = Jellyfin::Support::fromJsonValue<QSharedPointer<UserDto>>(source["Data"]);
+	m_messageId = Jellyfin::Support::fromJsonValue<QString>(source["MessageId"]);
+	m_messageType = Jellyfin::Support::fromJsonValue<SessionMessageType>(source["MessageType"]);
+
+}
+	
+QJsonObject UserUpdatedMessage::toJson() const {
+	QJsonObject result;
+	
+	result["Data"] = Jellyfin::Support::toJsonValue<QSharedPointer<UserDto>>(m_data);		
+	result["MessageId"] = Jellyfin::Support::toJsonValue<QString>(m_messageId);		
+	result["MessageType"] = Jellyfin::Support::toJsonValue<SessionMessageType>(m_messageType);	
+	return result;
+}
+
+QSharedPointer<UserDto> UserUpdatedMessage::data() const { return m_data; }
+
+void UserUpdatedMessage::setData(QSharedPointer<UserDto> newData) {
+	m_data = newData;
+}
+
+QString UserUpdatedMessage::messageId() const { return m_messageId; }
+
+void UserUpdatedMessage::setMessageId(QString newMessageId) {
+	m_messageId = newMessageId;
+}
+
+SessionMessageType UserUpdatedMessage::messageType() const { return m_messageType; }
+
+void UserUpdatedMessage::setMessageType(SessionMessageType newMessageType) {
+	m_messageType = newMessageType;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using UserUpdatedMessage = Jellyfin::DTO::UserUpdatedMessage;
+
+template <>
+UserUpdatedMessage fromJsonValue(const QJsonValue &source, convertType<UserUpdatedMessage>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return UserUpdatedMessage::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const UserUpdatedMessage &source, convertType<UserUpdatedMessage>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/version.cpp b/core/src/dto/version.cpp
deleted file mode 100644
index fc98883..0000000
--- a/core/src/dto/version.cpp
+++ /dev/null
@@ -1,156 +0,0 @@
-/*
- * 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/dto/version.h>
-
-namespace Jellyfin {
-namespace DTO {
-
-Version::Version() {}
-Version::Version (
-		qint32 major, 
-		qint32 minor, 
-		qint32 build, 
-		qint32 revision, 
-		qint32 majorRevision, 
-		qint32 minorRevision 
-		) :
-	m_major(major),
-	m_minor(minor),
-	m_build(build),
-	m_revision(revision),
-	m_majorRevision(majorRevision),
-	m_minorRevision(minorRevision) { }
-
-
-
-Version::Version(const Version &other) :
-
-	m_major(other.m_major),
-	m_minor(other.m_minor),
-	m_build(other.m_build),
-	m_revision(other.m_revision),
-	m_majorRevision(other.m_majorRevision),
-	m_minorRevision(other.m_minorRevision){}
-
-
-void Version::replaceData(Version &other) {
-	m_major = other.m_major;
-	m_minor = other.m_minor;
-	m_build = other.m_build;
-	m_revision = other.m_revision;
-	m_majorRevision = other.m_majorRevision;
-	m_minorRevision = other.m_minorRevision;
-}
-
-Version Version::fromJson(QJsonObject source) {
-	Version instance;
-	instance.setFromJson(source);
-	return instance;
-}
-
-
-void Version::setFromJson(QJsonObject source) {
-	m_major = Jellyfin::Support::fromJsonValue<qint32>(source["Major"]);
-	m_minor = Jellyfin::Support::fromJsonValue<qint32>(source["Minor"]);
-	m_build = Jellyfin::Support::fromJsonValue<qint32>(source["Build"]);
-	m_revision = Jellyfin::Support::fromJsonValue<qint32>(source["Revision"]);
-	m_majorRevision = Jellyfin::Support::fromJsonValue<qint32>(source["MajorRevision"]);
-	m_minorRevision = Jellyfin::Support::fromJsonValue<qint32>(source["MinorRevision"]);
-
-}
-	
-QJsonObject Version::toJson() const {
-	QJsonObject result;
-	
-	result["Major"] = Jellyfin::Support::toJsonValue<qint32>(m_major);		
-	result["Minor"] = Jellyfin::Support::toJsonValue<qint32>(m_minor);		
-	result["Build"] = Jellyfin::Support::toJsonValue<qint32>(m_build);		
-	result["Revision"] = Jellyfin::Support::toJsonValue<qint32>(m_revision);		
-	result["MajorRevision"] = Jellyfin::Support::toJsonValue<qint32>(m_majorRevision);		
-	result["MinorRevision"] = Jellyfin::Support::toJsonValue<qint32>(m_minorRevision);	
-	return result;
-}
-
-qint32 Version::major() const { return m_major; }
-
-void Version::setMajor(qint32 newMajor) {
-	m_major = newMajor;
-}
-
-qint32 Version::minor() const { return m_minor; }
-
-void Version::setMinor(qint32 newMinor) {
-	m_minor = newMinor;
-}
-
-qint32 Version::build() const { return m_build; }
-
-void Version::setBuild(qint32 newBuild) {
-	m_build = newBuild;
-}
-
-qint32 Version::revision() const { return m_revision; }
-
-void Version::setRevision(qint32 newRevision) {
-	m_revision = newRevision;
-}
-
-qint32 Version::majorRevision() const { return m_majorRevision; }
-
-void Version::setMajorRevision(qint32 newMajorRevision) {
-	m_majorRevision = newMajorRevision;
-}
-
-qint32 Version::minorRevision() const { return m_minorRevision; }
-
-void Version::setMinorRevision(qint32 newMinorRevision) {
-	m_minorRevision = newMinorRevision;
-}
-
-
-} // NS DTO
-
-namespace Support {
-
-using Version = Jellyfin::DTO::Version;
-
-template <>
-Version fromJsonValue(const QJsonValue &source, convertType<Version>) {
-	if (!source.isObject()) throw ParseException("Expected JSON Object");
-	return Version::fromJson(source.toObject());
-}
-
-template<>
-QJsonValue toJsonValue(const Version &source, convertType<Version>) {
-	return source.toJson();
-}
-
-} // NS DTO
-} // NS Jellyfin
diff --git a/core/src/dto/versioninfo.cpp b/core/src/dto/versioninfo.cpp
index 7131750..9c9f4fe 100644
--- a/core/src/dto/versioninfo.cpp
+++ b/core/src/dto/versioninfo.cpp
@@ -34,9 +34,15 @@ namespace DTO {
 
 VersionInfo::VersionInfo() {}
 VersionInfo::VersionInfo (
-		QSharedPointer<Version> versionNumber 
+		QString version, 
+		QString versionNumber, 
+		QString repositoryName, 
+		QString repositoryUrl 
 		) :
-	m_versionNumber(versionNumber) { }
+	m_version(version),
+	m_versionNumber(versionNumber),
+	m_repositoryName(repositoryName),
+	m_repositoryUrl(repositoryUrl) { }
 
 
 
@@ -74,7 +80,7 @@ VersionInfo VersionInfo::fromJson(QJsonObject source) {
 
 void VersionInfo::setFromJson(QJsonObject source) {
 	m_version = Jellyfin::Support::fromJsonValue<QString>(source["version"]);
-	m_versionNumber = Jellyfin::Support::fromJsonValue<QSharedPointer<Version>>(source["VersionNumber"]);
+	m_versionNumber = Jellyfin::Support::fromJsonValue<QString>(source["VersionNumber"]);
 	m_changelog = Jellyfin::Support::fromJsonValue<QString>(source["changelog"]);
 	m_targetAbi = Jellyfin::Support::fromJsonValue<QString>(source["targetAbi"]);
 	m_sourceUrl = Jellyfin::Support::fromJsonValue<QString>(source["sourceUrl"]);
@@ -88,12 +94,8 @@ void VersionInfo::setFromJson(QJsonObject source) {
 QJsonObject VersionInfo::toJson() const {
 	QJsonObject result;
 	
-	
-	if (!(m_version.isNull())) {
-		result["version"] = Jellyfin::Support::toJsonValue<QString>(m_version);
-	}
-			
-	result["VersionNumber"] = Jellyfin::Support::toJsonValue<QSharedPointer<Version>>(m_versionNumber);		
+	result["version"] = Jellyfin::Support::toJsonValue<QString>(m_version);		
+	result["VersionNumber"] = Jellyfin::Support::toJsonValue<QString>(m_versionNumber);		
 	
 	if (!(m_changelog.isNull())) {
 		result["changelog"] = Jellyfin::Support::toJsonValue<QString>(m_changelog);
@@ -119,16 +121,8 @@ QJsonObject VersionInfo::toJson() const {
 		result["timestamp"] = Jellyfin::Support::toJsonValue<QString>(m_timestamp);
 	}
 			
-	
-	if (!(m_repositoryName.isNull())) {
-		result["repositoryName"] = Jellyfin::Support::toJsonValue<QString>(m_repositoryName);
-	}
-			
-	
-	if (!(m_repositoryUrl.isNull())) {
-		result["repositoryUrl"] = Jellyfin::Support::toJsonValue<QString>(m_repositoryUrl);
-	}
-		
+	result["repositoryName"] = Jellyfin::Support::toJsonValue<QString>(m_repositoryName);		
+	result["repositoryUrl"] = Jellyfin::Support::toJsonValue<QString>(m_repositoryUrl);	
 	return result;
 }
 
@@ -137,17 +131,10 @@ QString VersionInfo::version() const { return m_version; }
 void VersionInfo::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
-bool VersionInfo::versionNull() const {
-	return m_version.isNull();
-}
 
-void VersionInfo::setVersionNull() {
-	m_version.clear();
+QString VersionInfo::versionNumber() const { return m_versionNumber; }
 
-}
-QSharedPointer<Version> VersionInfo::versionNumber() const { return m_versionNumber; }
-
-void VersionInfo::setVersionNumber(QSharedPointer<Version> newVersionNumber) {
+void VersionInfo::setVersionNumber(QString newVersionNumber) {
 	m_versionNumber = newVersionNumber;
 }
 
@@ -221,27 +208,13 @@ QString VersionInfo::repositoryName() const { return m_repositoryName; }
 void VersionInfo::setRepositoryName(QString newRepositoryName) {
 	m_repositoryName = newRepositoryName;
 }
-bool VersionInfo::repositoryNameNull() const {
-	return m_repositoryName.isNull();
-}
 
-void VersionInfo::setRepositoryNameNull() {
-	m_repositoryName.clear();
-
-}
 QString VersionInfo::repositoryUrl() const { return m_repositoryUrl; }
 
 void VersionInfo::setRepositoryUrl(QString newRepositoryUrl) {
 	m_repositoryUrl = newRepositoryUrl;
 }
-bool VersionInfo::repositoryUrlNull() const {
-	return m_repositoryUrl.isNull();
-}
 
-void VersionInfo::setRepositoryUrlNull() {
-	m_repositoryUrl.clear();
-
-}
 
 } // NS DTO
 
diff --git a/core/src/dto/notificationlevel.cpp b/core/src/dto/videorange.cpp
similarity index 62%
rename from core/src/dto/notificationlevel.cpp
rename to core/src/dto/videorange.cpp
index a53c67d..7dba3c6 100644
--- a/core/src/dto/notificationlevel.cpp
+++ b/core/src/dto/videorange.cpp
@@ -27,48 +27,48 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/dto/notificationlevel.h>
+#include <JellyfinQt/dto/videorange.h>
 
 namespace Jellyfin {
 namespace DTO {
 
-NotificationLevelClass::NotificationLevelClass() {}
+VideoRangeClass::VideoRangeClass() {}
 
 } // NS DTO
 
 namespace Support {
 
-using NotificationLevel = Jellyfin::DTO::NotificationLevel;
+using VideoRange = Jellyfin::DTO::VideoRange;
 
 template <>
-NotificationLevel fromJsonValue(const QJsonValue &source, convertType<NotificationLevel>) {
-	if (!source.isString()) return NotificationLevel::EnumNotSet;
+VideoRange fromJsonValue(const QJsonValue &source, convertType<VideoRange>) {
+	if (!source.isString()) return VideoRange::EnumNotSet;
 
 	QString str = source.toString();
-	if (str == QStringLiteral("Normal")) {
-		return NotificationLevel::Normal;
+	if (str == QStringLiteral("Unknown")) {
+		return VideoRange::Unknown;
 	}
-	if (str == QStringLiteral("Warning")) {
-		return NotificationLevel::Warning;
+	if (str == QStringLiteral("SDR")) {
+		return VideoRange::SDR;
 	}
-	if (str == QStringLiteral("Error")) {
-		return NotificationLevel::Error;
+	if (str == QStringLiteral("HDR")) {
+		return VideoRange::HDR;
 	}
 	
-	return NotificationLevel::EnumNotSet;
+	return VideoRange::EnumNotSet;
 }
 
 template <>
-QJsonValue toJsonValue(const NotificationLevel &source, convertType<NotificationLevel>) {
+QJsonValue toJsonValue(const VideoRange &source, convertType<VideoRange>) {
 	switch(source) {
-	case NotificationLevel::Normal:
-		return QStringLiteral("Normal");
-	case NotificationLevel::Warning:
-		return QStringLiteral("Warning");
-	case NotificationLevel::Error:
-		return QStringLiteral("Error");
+	case VideoRange::Unknown:
+		return QStringLiteral("Unknown");
+	case VideoRange::SDR:
+		return QStringLiteral("SDR");
+	case VideoRange::HDR:
+		return QStringLiteral("HDR");
 
-	case NotificationLevel::EnumNotSet: // Fallthrough
+	case VideoRange::EnumNotSet: // Fallthrough
 	default:
 		return QJsonValue();
 	}
diff --git a/core/src/dto/videorangetype.cpp b/core/src/dto/videorangetype.cpp
new file mode 100644
index 0000000..a1e3beb
--- /dev/null
+++ b/core/src/dto/videorangetype.cpp
@@ -0,0 +1,108 @@
+/*
+ * 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/dto/videorangetype.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+VideoRangeTypeClass::VideoRangeTypeClass() {}
+
+} // NS DTO
+
+namespace Support {
+
+using VideoRangeType = Jellyfin::DTO::VideoRangeType;
+
+template <>
+VideoRangeType fromJsonValue(const QJsonValue &source, convertType<VideoRangeType>) {
+	if (!source.isString()) return VideoRangeType::EnumNotSet;
+
+	QString str = source.toString();
+	if (str == QStringLiteral("Unknown")) {
+		return VideoRangeType::Unknown;
+	}
+	if (str == QStringLiteral("SDR")) {
+		return VideoRangeType::SDR;
+	}
+	if (str == QStringLiteral("HDR10")) {
+		return VideoRangeType::HDR10;
+	}
+	if (str == QStringLiteral("HLG")) {
+		return VideoRangeType::HLG;
+	}
+	if (str == QStringLiteral("DOVI")) {
+		return VideoRangeType::DOVI;
+	}
+	if (str == QStringLiteral("DOVIWithHDR10")) {
+		return VideoRangeType::DOVIWithHDR10;
+	}
+	if (str == QStringLiteral("DOVIWithHLG")) {
+		return VideoRangeType::DOVIWithHLG;
+	}
+	if (str == QStringLiteral("DOVIWithSDR")) {
+		return VideoRangeType::DOVIWithSDR;
+	}
+	if (str == QStringLiteral("HDR10Plus")) {
+		return VideoRangeType::HDR10Plus;
+	}
+	
+	return VideoRangeType::EnumNotSet;
+}
+
+template <>
+QJsonValue toJsonValue(const VideoRangeType &source, convertType<VideoRangeType>) {
+	switch(source) {
+	case VideoRangeType::Unknown:
+		return QStringLiteral("Unknown");
+	case VideoRangeType::SDR:
+		return QStringLiteral("SDR");
+	case VideoRangeType::HDR10:
+		return QStringLiteral("HDR10");
+	case VideoRangeType::HLG:
+		return QStringLiteral("HLG");
+	case VideoRangeType::DOVI:
+		return QStringLiteral("DOVI");
+	case VideoRangeType::DOVIWithHDR10:
+		return QStringLiteral("DOVIWithHDR10");
+	case VideoRangeType::DOVIWithHLG:
+		return QStringLiteral("DOVIWithHLG");
+	case VideoRangeType::DOVIWithSDR:
+		return QStringLiteral("DOVIWithSDR");
+	case VideoRangeType::HDR10Plus:
+		return QStringLiteral("HDR10Plus");
+
+	case VideoRangeType::EnumNotSet: // Fallthrough
+	default:
+		return QJsonValue();
+	}
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/virtualfolderinfo.cpp b/core/src/dto/virtualfolderinfo.cpp
index 10640b9..e8b112e 100644
--- a/core/src/dto/virtualfolderinfo.cpp
+++ b/core/src/dto/virtualfolderinfo.cpp
@@ -34,8 +34,10 @@ namespace DTO {
 
 VirtualFolderInfo::VirtualFolderInfo() {}
 VirtualFolderInfo::VirtualFolderInfo (
+		CollectionTypeOptions collectionType, 
 		QSharedPointer<LibraryOptions> libraryOptions 
 		) :
+	m_collectionType(collectionType),
 	m_libraryOptions(libraryOptions) { }
 
 
@@ -73,7 +75,7 @@ VirtualFolderInfo VirtualFolderInfo::fromJson(QJsonObject source) {
 void VirtualFolderInfo::setFromJson(QJsonObject source) {
 	m_name = Jellyfin::Support::fromJsonValue<QString>(source["Name"]);
 	m_locations = Jellyfin::Support::fromJsonValue<QStringList>(source["Locations"]);
-	m_collectionType = Jellyfin::Support::fromJsonValue<QString>(source["CollectionType"]);
+	m_collectionType = Jellyfin::Support::fromJsonValue<CollectionTypeOptions>(source["CollectionType"]);
 	m_libraryOptions = Jellyfin::Support::fromJsonValue<QSharedPointer<LibraryOptions>>(source["LibraryOptions"]);
 	m_itemId = Jellyfin::Support::fromJsonValue<QString>(source["ItemId"]);
 	m_primaryImageItemId = Jellyfin::Support::fromJsonValue<QString>(source["PrimaryImageItemId"]);
@@ -95,11 +97,7 @@ QJsonObject VirtualFolderInfo::toJson() const {
 		result["Locations"] = Jellyfin::Support::toJsonValue<QStringList>(m_locations);
 	}
 			
-	
-	if (!(m_collectionType.isNull())) {
-		result["CollectionType"] = Jellyfin::Support::toJsonValue<QString>(m_collectionType);
-	}
-			
+	result["CollectionType"] = Jellyfin::Support::toJsonValue<CollectionTypeOptions>(m_collectionType);		
 	result["LibraryOptions"] = Jellyfin::Support::toJsonValue<QSharedPointer<LibraryOptions>>(m_libraryOptions);		
 	
 	if (!(m_itemId.isNull())) {
@@ -150,19 +148,12 @@ void VirtualFolderInfo::setLocationsNull() {
 	m_locations.clear();
 
 }
-QString VirtualFolderInfo::collectionType() const { return m_collectionType; }
+CollectionTypeOptions VirtualFolderInfo::collectionType() const { return m_collectionType; }
 
-void VirtualFolderInfo::setCollectionType(QString newCollectionType) {
+void VirtualFolderInfo::setCollectionType(CollectionTypeOptions newCollectionType) {
 	m_collectionType = newCollectionType;
 }
-bool VirtualFolderInfo::collectionTypeNull() const {
-	return m_collectionType.isNull();
-}
 
-void VirtualFolderInfo::setCollectionTypeNull() {
-	m_collectionType.clear();
-
-}
 QSharedPointer<LibraryOptions> VirtualFolderInfo::libraryOptions() const { return m_libraryOptions; }
 
 void VirtualFolderInfo::setLibraryOptions(QSharedPointer<LibraryOptions> newLibraryOptions) {
diff --git a/core/src/dto/websocketmessage.cpp b/core/src/dto/websocketmessage.cpp
new file mode 100644
index 0000000..c76ab9f
--- /dev/null
+++ b/core/src/dto/websocketmessage.cpp
@@ -0,0 +1,37 @@
+/*
+ * 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/dto/websocketmessage.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/dto/xbmcmetadataoptions.cpp b/core/src/dto/xbmcmetadataoptions.cpp
new file mode 100644
index 0000000..d157dbc
--- /dev/null
+++ b/core/src/dto/xbmcmetadataoptions.cpp
@@ -0,0 +1,153 @@
+/*
+ * 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/dto/xbmcmetadataoptions.h>
+
+namespace Jellyfin {
+namespace DTO {
+
+XbmcMetadataOptions::XbmcMetadataOptions() {}
+XbmcMetadataOptions::XbmcMetadataOptions (
+		QString releaseDateFormat, 
+		bool saveImagePathsInNfo, 
+		bool enablePathSubstitution, 
+		bool enableExtraThumbsDuplication 
+		) :
+	m_releaseDateFormat(releaseDateFormat),
+	m_saveImagePathsInNfo(saveImagePathsInNfo),
+	m_enablePathSubstitution(enablePathSubstitution),
+	m_enableExtraThumbsDuplication(enableExtraThumbsDuplication) { }
+
+
+
+XbmcMetadataOptions::XbmcMetadataOptions(const XbmcMetadataOptions &other) :
+
+	m_userId(other.m_userId),
+	m_releaseDateFormat(other.m_releaseDateFormat),
+	m_saveImagePathsInNfo(other.m_saveImagePathsInNfo),
+	m_enablePathSubstitution(other.m_enablePathSubstitution),
+	m_enableExtraThumbsDuplication(other.m_enableExtraThumbsDuplication){}
+
+
+void XbmcMetadataOptions::replaceData(XbmcMetadataOptions &other) {
+	m_userId = other.m_userId;
+	m_releaseDateFormat = other.m_releaseDateFormat;
+	m_saveImagePathsInNfo = other.m_saveImagePathsInNfo;
+	m_enablePathSubstitution = other.m_enablePathSubstitution;
+	m_enableExtraThumbsDuplication = other.m_enableExtraThumbsDuplication;
+}
+
+XbmcMetadataOptions XbmcMetadataOptions::fromJson(QJsonObject source) {
+	XbmcMetadataOptions instance;
+	instance.setFromJson(source);
+	return instance;
+}
+
+
+void XbmcMetadataOptions::setFromJson(QJsonObject source) {
+	m_userId = Jellyfin::Support::fromJsonValue<QString>(source["UserId"]);
+	m_releaseDateFormat = Jellyfin::Support::fromJsonValue<QString>(source["ReleaseDateFormat"]);
+	m_saveImagePathsInNfo = Jellyfin::Support::fromJsonValue<bool>(source["SaveImagePathsInNfo"]);
+	m_enablePathSubstitution = Jellyfin::Support::fromJsonValue<bool>(source["EnablePathSubstitution"]);
+	m_enableExtraThumbsDuplication = Jellyfin::Support::fromJsonValue<bool>(source["EnableExtraThumbsDuplication"]);
+
+}
+	
+QJsonObject XbmcMetadataOptions::toJson() const {
+	QJsonObject result;
+	
+	
+	if (!(m_userId.isNull())) {
+		result["UserId"] = Jellyfin::Support::toJsonValue<QString>(m_userId);
+	}
+			
+	result["ReleaseDateFormat"] = Jellyfin::Support::toJsonValue<QString>(m_releaseDateFormat);		
+	result["SaveImagePathsInNfo"] = Jellyfin::Support::toJsonValue<bool>(m_saveImagePathsInNfo);		
+	result["EnablePathSubstitution"] = Jellyfin::Support::toJsonValue<bool>(m_enablePathSubstitution);		
+	result["EnableExtraThumbsDuplication"] = Jellyfin::Support::toJsonValue<bool>(m_enableExtraThumbsDuplication);	
+	return result;
+}
+
+QString XbmcMetadataOptions::userId() const { return m_userId; }
+
+void XbmcMetadataOptions::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+bool XbmcMetadataOptions::userIdNull() const {
+	return m_userId.isNull();
+}
+
+void XbmcMetadataOptions::setUserIdNull() {
+	m_userId.clear();
+
+}
+QString XbmcMetadataOptions::releaseDateFormat() const { return m_releaseDateFormat; }
+
+void XbmcMetadataOptions::setReleaseDateFormat(QString newReleaseDateFormat) {
+	m_releaseDateFormat = newReleaseDateFormat;
+}
+
+bool XbmcMetadataOptions::saveImagePathsInNfo() const { return m_saveImagePathsInNfo; }
+
+void XbmcMetadataOptions::setSaveImagePathsInNfo(bool newSaveImagePathsInNfo) {
+	m_saveImagePathsInNfo = newSaveImagePathsInNfo;
+}
+
+bool XbmcMetadataOptions::enablePathSubstitution() const { return m_enablePathSubstitution; }
+
+void XbmcMetadataOptions::setEnablePathSubstitution(bool newEnablePathSubstitution) {
+	m_enablePathSubstitution = newEnablePathSubstitution;
+}
+
+bool XbmcMetadataOptions::enableExtraThumbsDuplication() const { return m_enableExtraThumbsDuplication; }
+
+void XbmcMetadataOptions::setEnableExtraThumbsDuplication(bool newEnableExtraThumbsDuplication) {
+	m_enableExtraThumbsDuplication = newEnableExtraThumbsDuplication;
+}
+
+
+} // NS DTO
+
+namespace Support {
+
+using XbmcMetadataOptions = Jellyfin::DTO::XbmcMetadataOptions;
+
+template <>
+XbmcMetadataOptions fromJsonValue(const QJsonValue &source, convertType<XbmcMetadataOptions>) {
+	if (!source.isObject()) throw ParseException("Expected JSON Object");
+	return XbmcMetadataOptions::fromJson(source.toObject());
+}
+
+template<>
+QJsonValue toJsonValue(const XbmcMetadataOptions &source, convertType<XbmcMetadataOptions>) {
+	return source.toJson();
+}
+
+} // NS DTO
+} // NS Jellyfin
diff --git a/core/src/loader/http/artists.cpp b/core/src/loader/http/artists.cpp
index 319860d..3e87e17 100644
--- a/core/src/loader/http/artists.cpp
+++ b/core/src/loader/http/artists.cpp
@@ -69,10 +69,10 @@ QUrlQuery GetArtistsLoader::query(const GetArtistsParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.filtersNull()) {
 		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
@@ -81,7 +81,7 @@ QUrlQuery GetArtistsLoader::query(const GetArtistsParams &params) const {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.genresNull()) {
 		result.addQueryItem("genres", Support::toString<QStringList>(params.genres()));
@@ -134,6 +134,12 @@ QUrlQuery GetArtistsLoader::query(const GetArtistsParams &params) const {
 	if (!params.nameLessThanNull()) {
 		result.addQueryItem("nameLessThan", Support::toString<QString>(params.nameLessThan()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	if (!params.enableImagesNull()) {
 		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
@@ -220,10 +226,10 @@ QUrlQuery GetAlbumArtistsLoader::query(const GetAlbumArtistsParams &params) cons
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.filtersNull()) {
 		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
@@ -232,7 +238,7 @@ QUrlQuery GetAlbumArtistsLoader::query(const GetAlbumArtistsParams &params) cons
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.genresNull()) {
 		result.addQueryItem("genres", Support::toString<QStringList>(params.genres()));
@@ -285,6 +291,12 @@ QUrlQuery GetAlbumArtistsLoader::query(const GetAlbumArtistsParams &params) cons
 	if (!params.nameLessThanNull()) {
 		result.addQueryItem("nameLessThan", Support::toString<QString>(params.nameLessThan()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	if (!params.enableImagesNull()) {
 		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
diff --git a/core/src/loader/http/channels.cpp b/core/src/loader/http/channels.cpp
index ff29925..5cc9eb8 100644
--- a/core/src/loader/http/channels.cpp
+++ b/core/src/loader/http/channels.cpp
@@ -139,13 +139,13 @@ QUrlQuery GetChannelItemsLoader::query(const GetChannelItemsParams &params) cons
 		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
 	}
 	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
 	}
 	if (!params.filtersNull()) {
 		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.fieldsNull()) {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
diff --git a/core/src/loader/http/clientlog.cpp b/core/src/loader/http/clientlog.cpp
new file mode 100644
index 0000000..1052c6a
--- /dev/null
+++ b/core/src/loader/http/clientlog.cpp
@@ -0,0 +1,70 @@
+/*
+ * 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/clientlog.h>
+
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+LogFileLoader::LogFileLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<ClientLogDocumentResponseDto, LogFileParams>(apiClient) {}
+
+QString LogFileLoader::path(const LogFileParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/ClientLog/Document");
+}
+
+QUrlQuery LogFileLoader::query(const LogFileParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray LogFileLoader::body(const LogFileParams &params) const {
+	return Support::toString<QByteArray>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation LogFileLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
diff --git a/core/src/loader/http/configuration.cpp b/core/src/loader/http/configuration.cpp
index 77dadc3..55c4eed 100644
--- a/core/src/loader/http/configuration.cpp
+++ b/core/src/loader/http/configuration.cpp
@@ -142,7 +142,7 @@ QUrlQuery UpdateNamedConfigurationLoader::query(const UpdateNamedConfigurationPa
 }
 
 QByteArray UpdateNamedConfigurationLoader::body(const UpdateNamedConfigurationParams &params) const {
-	return QByteArray();
+	return Support::toString<QVariant>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation UpdateNamedConfigurationLoader::operation() const {
@@ -180,35 +180,6 @@ QNetworkAccessManager::Operation GetDefaultMetadataOptionsLoader::operation() co
 
 }
 
-UpdateMediaEncoderPathLoader::UpdateMediaEncoderPathLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateMediaEncoderPathParams>(apiClient) {}
-
-QString UpdateMediaEncoderPathLoader::path(const UpdateMediaEncoderPathParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/System/MediaEncoder/Path");
-}
-
-QUrlQuery UpdateMediaEncoderPathLoader::query(const UpdateMediaEncoderPathParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateMediaEncoderPathLoader::body(const UpdateMediaEncoderPathParams &params) const {
-	return Support::toString<QSharedPointer<MediaEncoderPathDto>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateMediaEncoderPathLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/dashboard.cpp b/core/src/loader/http/dashboard.cpp
index 2c0e124..823d2e6 100644
--- a/core/src/loader/http/dashboard.cpp
+++ b/core/src/loader/http/dashboard.cpp
@@ -53,9 +53,6 @@ QUrlQuery GetConfigurationPagesLoader::query(const GetConfigurationPagesParams &
 	if (!params.enableInMainMenuNull()) {
 		result.addQueryItem("enableInMainMenu", Support::toString<std::optional<bool>>(params.enableInMainMenu()));
 	}
-	if (!params.pageTypeNull()) {
-		result.addQueryItem("pageType", Support::toString<ConfigurationPageType>(params.pageType()));
-	}
 	
 	return result;
 }
diff --git a/core/src/loader/http/devices.cpp b/core/src/loader/http/devices.cpp
index 9941836..13c7d7d 100644
--- a/core/src/loader/http/devices.cpp
+++ b/core/src/loader/http/devices.cpp
@@ -36,7 +36,7 @@ namespace HTTP {
 using namespace Jellyfin::DTO;
 
 GetDevicesLoader::GetDevicesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<DeviceInfoQueryResult, GetDevicesParams>(apiClient) {}
+	: Jellyfin::Support::HttpLoader<DeviceInfoDtoQueryResult, GetDevicesParams>(apiClient) {}
 
 QString GetDevicesLoader::path(const GetDevicesParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
@@ -50,9 +50,6 @@ QUrlQuery GetDevicesLoader::query(const GetDevicesParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
-	if (!params.supportsSyncNull()) {
-		result.addQueryItem("supportsSync", Support::toString<std::optional<bool>>(params.supportsSync()));
-	}
 	if (!params.userIdNull()) {
 		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
@@ -101,7 +98,7 @@ QNetworkAccessManager::Operation DeleteDeviceLoader::operation() const {
 }
 
 GetDeviceInfoLoader::GetDeviceInfoLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<DeviceInfo, GetDeviceInfoParams>(apiClient) {}
+	: Jellyfin::Support::HttpLoader<DeviceInfoDto, GetDeviceInfoParams>(apiClient) {}
 
 QString GetDeviceInfoLoader::path(const GetDeviceInfoParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
@@ -131,7 +128,7 @@ QNetworkAccessManager::Operation GetDeviceInfoLoader::operation() const {
 }
 
 GetDeviceOptionsLoader::GetDeviceOptionsLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<DeviceOptions, GetDeviceOptionsParams>(apiClient) {}
+	: Jellyfin::Support::HttpLoader<DeviceOptionsDto, GetDeviceOptionsParams>(apiClient) {}
 
 QString GetDeviceOptionsLoader::path(const GetDeviceOptionsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
@@ -181,7 +178,7 @@ QUrlQuery UpdateDeviceOptionsLoader::query(const UpdateDeviceOptionsParams &para
 }
 
 QByteArray UpdateDeviceOptionsLoader::body(const UpdateDeviceOptionsParams &params) const {
-	return Support::toString<QSharedPointer<DeviceOptions>>(params.body()).toUtf8();
+	return Support::toString<QSharedPointer<DeviceOptionsDto>>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation UpdateDeviceOptionsLoader::operation() const {
diff --git a/core/src/loader/http/displaypreferences.cpp b/core/src/loader/http/displaypreferences.cpp
index 73bb14f..0e82c87 100644
--- a/core/src/loader/http/displaypreferences.cpp
+++ b/core/src/loader/http/displaypreferences.cpp
@@ -48,10 +48,12 @@ QUrlQuery GetDisplayPreferencesLoader::query(const GetDisplayPreferencesParams &
 	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()));
 	result.addQueryItem("client", Support::toString<QString>(params.client()));
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -79,10 +81,12 @@ QUrlQuery UpdateDisplayPreferencesLoader::query(const UpdateDisplayPreferencesPa
 	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()));
 	result.addQueryItem("client", Support::toString<QString>(params.client()));
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
diff --git a/core/src/loader/http/dlna.cpp b/core/src/loader/http/dlna.cpp
deleted file mode 100644
index 76add46..0000000
--- a/core/src/loader/http/dlna.cpp
+++ /dev/null
@@ -1,215 +0,0 @@
-/*
- * 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/dlna.h>
-
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-GetProfileInfosLoader::GetProfileInfosLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<DeviceProfileInfo>, GetProfileInfosParams>(apiClient) {}
-
-QString GetProfileInfosLoader::path(const GetProfileInfosParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/ProfileInfos");
-}
-
-QUrlQuery GetProfileInfosLoader::query(const GetProfileInfosParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetProfileInfosLoader::body(const GetProfileInfosParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetProfileInfosLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-CreateProfileLoader::CreateProfileLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, CreateProfileParams>(apiClient) {}
-
-QString CreateProfileLoader::path(const CreateProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/Profiles");
-}
-
-QUrlQuery CreateProfileLoader::query(const CreateProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray CreateProfileLoader::body(const CreateProfileParams &params) const {
-	return Support::toString<QSharedPointer<DeviceProfile>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation CreateProfileLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-GetProfileLoader::GetProfileLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<DeviceProfile, GetProfileParams>(apiClient) {}
-
-QString GetProfileLoader::path(const GetProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/Profiles/") + Support::toString< QString>(params.profileId()) ;
-}
-
-QUrlQuery GetProfileLoader::query(const GetProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetProfileLoader::body(const GetProfileParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetProfileLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-DeleteProfileLoader::DeleteProfileLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, DeleteProfileParams>(apiClient) {}
-
-QString DeleteProfileLoader::path(const DeleteProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/Profiles/") + Support::toString< QString>(params.profileId()) ;
-}
-
-QUrlQuery DeleteProfileLoader::query(const DeleteProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray DeleteProfileLoader::body(const DeleteProfileParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation DeleteProfileLoader::operation() const {
-	// HTTP method Delete
-	return QNetworkAccessManager::DeleteOperation;
-
-}
-
-UpdateProfileLoader::UpdateProfileLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateProfileParams>(apiClient) {}
-
-QString UpdateProfileLoader::path(const UpdateProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/Profiles/") + Support::toString< QString>(params.profileId()) ;
-}
-
-QUrlQuery UpdateProfileLoader::query(const UpdateProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateProfileLoader::body(const UpdateProfileParams &params) const {
-	return Support::toString<QSharedPointer<DeviceProfile>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateProfileLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-GetDefaultProfileLoader::GetDefaultProfileLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<DeviceProfile, GetDefaultProfileParams>(apiClient) {}
-
-QString GetDefaultProfileLoader::path(const GetDefaultProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Dlna/Profiles/Default");
-}
-
-QUrlQuery GetDefaultProfileLoader::query(const GetDefaultProfileParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetDefaultProfileLoader::body(const GetDefaultProfileParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetDefaultProfileLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
diff --git a/core/src/loader/http/filter.cpp b/core/src/loader/http/filter.cpp
index f156566..86d3cdc 100644
--- a/core/src/loader/http/filter.cpp
+++ b/core/src/loader/http/filter.cpp
@@ -57,10 +57,10 @@ QUrlQuery GetQueryFiltersLegacyLoader::query(const GetQueryFiltersLegacyParams &
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	
 	return result;
@@ -98,7 +98,7 @@ QUrlQuery GetQueryFiltersLoader::query(const GetQueryFiltersParams &params) cons
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.isAiringNull()) {
 		result.addQueryItem("isAiring", Support::toString<std::optional<bool>>(params.isAiring()));
diff --git a/core/src/loader/http/genres.cpp b/core/src/loader/http/genres.cpp
index fe2e301..dc490c6 100644
--- a/core/src/loader/http/genres.cpp
+++ b/core/src/loader/http/genres.cpp
@@ -66,10 +66,10 @@ QUrlQuery GetGenresLoader::query(const GetGenresParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.isFavoriteNull()) {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
@@ -92,6 +92,12 @@ QUrlQuery GetGenresLoader::query(const GetGenresParams &params) const {
 	if (!params.nameLessThanNull()) {
 		result.addQueryItem("nameLessThan", Support::toString<QString>(params.nameLessThan()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	if (!params.enableImagesNull()) {
 		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
diff --git a/core/src/loader/http/hlssegment.cpp b/core/src/loader/http/hlssegment.cpp
index cb0354f..3d03377 100644
--- a/core/src/loader/http/hlssegment.cpp
+++ b/core/src/loader/http/hlssegment.cpp
@@ -48,14 +48,10 @@ QUrlQuery StopEncodingProcessLoader::query(const StopEncodingProcessParams &para
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
+	result.addQueryItem("deviceId", Support::toString<QString>(params.deviceId()));
+	result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
 
 	// Optional parameters
-	if (!params.deviceIdNull()) {
-		result.addQueryItem("deviceId", Support::toString<QString>(params.deviceId()));
-	}
-	if (!params.playSessionIdNull()) {
-		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
-	}
 	
 	return result;
 }
diff --git a/core/src/loader/http/image.cpp b/core/src/loader/http/image.cpp
index e17ac3d..6a97ef8 100644
--- a/core/src/loader/http/image.cpp
+++ b/core/src/loader/http/image.cpp
@@ -35,6 +35,64 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
+UploadCustomSplashscreenLoader::UploadCustomSplashscreenLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UploadCustomSplashscreenParams>(apiClient) {}
+
+QString UploadCustomSplashscreenLoader::path(const UploadCustomSplashscreenParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Branding/Splashscreen");
+}
+
+QUrlQuery UploadCustomSplashscreenLoader::query(const UploadCustomSplashscreenParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray UploadCustomSplashscreenLoader::body(const UploadCustomSplashscreenParams &params) const {
+	return Support::toString<QByteArray>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UploadCustomSplashscreenLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+DeleteCustomSplashscreenLoader::DeleteCustomSplashscreenLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, DeleteCustomSplashscreenParams>(apiClient) {}
+
+QString DeleteCustomSplashscreenLoader::path(const DeleteCustomSplashscreenParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Branding/Splashscreen");
+}
+
+QUrlQuery DeleteCustomSplashscreenLoader::query(const DeleteCustomSplashscreenParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray DeleteCustomSplashscreenLoader::body(const DeleteCustomSplashscreenParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation DeleteCustomSplashscreenLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
 GetItemImageInfosLoader::GetItemImageInfosLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<QList<ImageInfo>, GetItemImageInfosParams>(apiClient) {}
 
@@ -116,7 +174,7 @@ QUrlQuery SetItemImageLoader::query(const SetItemImageParams &params) const {
 }
 
 QByteArray SetItemImageLoader::body(const SetItemImageParams &params) const {
-	return QByteArray();
+	return Support::toString<QByteArray>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation SetItemImageLoader::operation() const {
@@ -174,7 +232,7 @@ QUrlQuery SetItemImageByIndexLoader::query(const SetItemImageByIndexParams &para
 }
 
 QByteArray SetItemImageByIndexLoader::body(const SetItemImageByIndexParams &params) const {
-	return QByteArray();
+	return Support::toString<QByteArray>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation SetItemImageByIndexLoader::operation() const {
@@ -196,11 +254,9 @@ QUrlQuery UpdateItemImageIndexLoader::query(const UpdateItemImageIndexParams &pa
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
+	result.addQueryItem("newIndex", Support::toString<qint32>(params.newIndex()));
 
 	// Optional parameters
-	if (!params.newIndexNull()) {
-		result.addQueryItem("newIndex", Support::toString<std::optional<qint32>>(params.newIndex()));
-	}
 	
 	return result;
 }
@@ -221,7 +277,7 @@ PostUserImageLoader::PostUserImageLoader(ApiClient *apiClient)
 QString PostUserImageLoader::path(const PostUserImageParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Images/") + Support::toString< ImageType>(params.imageType()) ;
+	return QStringLiteral("/UserImage");
 }
 
 QUrlQuery PostUserImageLoader::query(const PostUserImageParams &params) const {
@@ -230,15 +286,15 @@ QUrlQuery PostUserImageLoader::query(const PostUserImageParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
-	if (!params.indexNull()) {
-		result.addQueryItem("index", Support::toString<std::optional<qint32>>(params.index()));
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	
 	return result;
 }
 
 QByteArray PostUserImageLoader::body(const PostUserImageParams &params) const {
-	return QByteArray();
+	return Support::toString<QByteArray>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation PostUserImageLoader::operation() const {
@@ -253,7 +309,7 @@ DeleteUserImageLoader::DeleteUserImageLoader(ApiClient *apiClient)
 QString DeleteUserImageLoader::path(const DeleteUserImageParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Images/") + Support::toString< ImageType>(params.imageType()) ;
+	return QStringLiteral("/UserImage");
 }
 
 QUrlQuery DeleteUserImageLoader::query(const DeleteUserImageParams &params) const {
@@ -262,8 +318,8 @@ QUrlQuery DeleteUserImageLoader::query(const DeleteUserImageParams &params) cons
 	QUrlQuery result;
 
 	// Optional parameters
-	if (!params.indexNull()) {
-		result.addQueryItem("index", Support::toString<std::optional<qint32>>(params.index()));
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	
 	return result;
@@ -279,64 +335,6 @@ QNetworkAccessManager::Operation DeleteUserImageLoader::operation() const {
 
 }
 
-PostUserImageByIndexLoader::PostUserImageByIndexLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, PostUserImageByIndexParams>(apiClient) {}
-
-QString PostUserImageByIndexLoader::path(const PostUserImageByIndexParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Images/") + Support::toString< ImageType>(params.imageType()) + QStringLiteral("/") + Support::toString< qint32>(params.index()) ;
-}
-
-QUrlQuery PostUserImageByIndexLoader::query(const PostUserImageByIndexParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray PostUserImageByIndexLoader::body(const PostUserImageByIndexParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation PostUserImageByIndexLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-DeleteUserImageByIndexLoader::DeleteUserImageByIndexLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, DeleteUserImageByIndexParams>(apiClient) {}
-
-QString DeleteUserImageByIndexLoader::path(const DeleteUserImageByIndexParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Images/") + Support::toString< ImageType>(params.imageType()) + QStringLiteral("/") + Support::toString< qint32>(params.index()) ;
-}
-
-QUrlQuery DeleteUserImageByIndexLoader::query(const DeleteUserImageByIndexParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray DeleteUserImageByIndexLoader::body(const DeleteUserImageByIndexParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation DeleteUserImageByIndexLoader::operation() const {
-	// HTTP method Delete
-	return QNetworkAccessManager::DeleteOperation;
-
-}
-
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/imagebyname.cpp b/core/src/loader/http/imagebyname.cpp
deleted file mode 100644
index fa78f49..0000000
--- a/core/src/loader/http/imagebyname.cpp
+++ /dev/null
@@ -1,128 +0,0 @@
-/*
- * 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/imagebyname.h>
-
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-GetGeneralImagesLoader::GetGeneralImagesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetGeneralImagesParams>(apiClient) {}
-
-QString GetGeneralImagesLoader::path(const GetGeneralImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Images/General");
-}
-
-QUrlQuery GetGeneralImagesLoader::query(const GetGeneralImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetGeneralImagesLoader::body(const GetGeneralImagesParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetGeneralImagesLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-GetMediaInfoImagesLoader::GetMediaInfoImagesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetMediaInfoImagesParams>(apiClient) {}
-
-QString GetMediaInfoImagesLoader::path(const GetMediaInfoImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Images/MediaInfo");
-}
-
-QUrlQuery GetMediaInfoImagesLoader::query(const GetMediaInfoImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetMediaInfoImagesLoader::body(const GetMediaInfoImagesParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetMediaInfoImagesLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-GetRatingImagesLoader::GetRatingImagesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<ImageByNameInfo>, GetRatingImagesParams>(apiClient) {}
-
-QString GetRatingImagesLoader::path(const GetRatingImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Images/Ratings");
-}
-
-QUrlQuery GetRatingImagesLoader::query(const GetRatingImagesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetRatingImagesLoader::body(const GetRatingImagesParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetRatingImagesLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
diff --git a/core/src/loader/http/instantmix.cpp b/core/src/loader/http/instantmix.cpp
index a39d065..3291dd5 100644
--- a/core/src/loader/http/instantmix.cpp
+++ b/core/src/loader/http/instantmix.cpp
@@ -41,7 +41,7 @@ GetInstantMixFromAlbumLoader::GetInstantMixFromAlbumLoader(ApiClient *apiClient)
 QString GetInstantMixFromAlbumLoader::path(const GetInstantMixFromAlbumParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Albums/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
+	return QStringLiteral("/Albums/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/InstantMix");
 }
 
 QUrlQuery GetInstantMixFromAlbumLoader::query(const GetInstantMixFromAlbumParams &params) const {
@@ -91,7 +91,7 @@ GetInstantMixFromArtistsLoader::GetInstantMixFromArtistsLoader(ApiClient *apiCli
 QString GetInstantMixFromArtistsLoader::path(const GetInstantMixFromArtistsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Artists/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
+	return QStringLiteral("/Artists/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/InstantMix");
 }
 
 QUrlQuery GetInstantMixFromArtistsLoader::query(const GetInstantMixFromArtistsParams &params) const {
@@ -135,13 +135,64 @@ QNetworkAccessManager::Operation GetInstantMixFromArtistsLoader::operation() con
 
 }
 
+GetInstantMixFromArtists2Loader::GetInstantMixFromArtists2Loader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromArtists2Params>(apiClient) {}
+
+QString GetInstantMixFromArtists2Loader::path(const GetInstantMixFromArtists2Params &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Artists/InstantMix");
+}
+
+QUrlQuery GetInstantMixFromArtists2Loader::query(const GetInstantMixFromArtists2Params &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+	result.addQueryItem("id", Support::toString<QString>(params.jellyfinId()));
+
+	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
+	if (!params.limitNull()) {
+		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
+	}
+	if (!params.fieldsNull()) {
+		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
+	}
+	if (!params.enableImagesNull()) {
+		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
+	}
+	if (!params.enableUserDataNull()) {
+		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
+	}
+	if (!params.imageTypeLimitNull()) {
+		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
+	}
+	if (!params.enableImageTypesNull()) {
+		result.addQueryItem("enableImageTypes", Support::toString<QList<ImageType>>(params.enableImageTypes()));
+	}
+	
+	return result;
+}
+
+QByteArray GetInstantMixFromArtists2Loader::body(const GetInstantMixFromArtists2Params &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetInstantMixFromArtists2Loader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
 GetInstantMixFromItemLoader::GetInstantMixFromItemLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromItemParams>(apiClient) {}
 
 QString GetInstantMixFromItemLoader::path(const GetInstantMixFromItemParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Items/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
+	return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/InstantMix");
 }
 
 QUrlQuery GetInstantMixFromItemLoader::query(const GetInstantMixFromItemParams &params) const {
@@ -185,66 +236,16 @@ QNetworkAccessManager::Operation GetInstantMixFromItemLoader::operation() const
 
 }
 
-GetInstantMixFromMusicGenresLoader::GetInstantMixFromMusicGenresLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenresParams>(apiClient) {}
+GetInstantMixFromMusicGenreByNameLoader::GetInstantMixFromMusicGenreByNameLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreByNameParams>(apiClient) {}
 
-QString GetInstantMixFromMusicGenresLoader::path(const GetInstantMixFromMusicGenresParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/MusicGenres/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
-}
-
-QUrlQuery GetInstantMixFromMusicGenresLoader::query(const GetInstantMixFromMusicGenresParams &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.limitNull()) {
-		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
-	}
-	if (!params.fieldsNull()) {
-		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
-	}
-	if (!params.enableImagesNull()) {
-		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
-	}
-	if (!params.enableUserDataNull()) {
-		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
-	}
-	if (!params.imageTypeLimitNull()) {
-		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
-	}
-	if (!params.enableImageTypesNull()) {
-		result.addQueryItem("enableImageTypes", Support::toString<QList<ImageType>>(params.enableImageTypes()));
-	}
-	
-	return result;
-}
-
-QByteArray GetInstantMixFromMusicGenresLoader::body(const GetInstantMixFromMusicGenresParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetInstantMixFromMusicGenresLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-GetInstantMixFromMusicGenreLoader::GetInstantMixFromMusicGenreLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreParams>(apiClient) {}
-
-QString GetInstantMixFromMusicGenreLoader::path(const GetInstantMixFromMusicGenreParams &params) const {
+QString GetInstantMixFromMusicGenreByNameLoader::path(const GetInstantMixFromMusicGenreByNameParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/MusicGenres/") + Support::toString< QString>(params.name()) + QStringLiteral("/InstantMix");
 }
 
-QUrlQuery GetInstantMixFromMusicGenreLoader::query(const GetInstantMixFromMusicGenreParams &params) const {
+QUrlQuery GetInstantMixFromMusicGenreByNameLoader::query(const GetInstantMixFromMusicGenreByNameParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -275,11 +276,62 @@ QUrlQuery GetInstantMixFromMusicGenreLoader::query(const GetInstantMixFromMusicG
 	return result;
 }
 
-QByteArray GetInstantMixFromMusicGenreLoader::body(const GetInstantMixFromMusicGenreParams &params) const {
+QByteArray GetInstantMixFromMusicGenreByNameLoader::body(const GetInstantMixFromMusicGenreByNameParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation GetInstantMixFromMusicGenreLoader::operation() const {
+QNetworkAccessManager::Operation GetInstantMixFromMusicGenreByNameLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+GetInstantMixFromMusicGenreByIdLoader::GetInstantMixFromMusicGenreByIdLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetInstantMixFromMusicGenreByIdParams>(apiClient) {}
+
+QString GetInstantMixFromMusicGenreByIdLoader::path(const GetInstantMixFromMusicGenreByIdParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/MusicGenres/InstantMix");
+}
+
+QUrlQuery GetInstantMixFromMusicGenreByIdLoader::query(const GetInstantMixFromMusicGenreByIdParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+	result.addQueryItem("id", Support::toString<QString>(params.jellyfinId()));
+
+	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
+	if (!params.limitNull()) {
+		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
+	}
+	if (!params.fieldsNull()) {
+		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
+	}
+	if (!params.enableImagesNull()) {
+		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
+	}
+	if (!params.enableUserDataNull()) {
+		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
+	}
+	if (!params.imageTypeLimitNull()) {
+		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
+	}
+	if (!params.enableImageTypesNull()) {
+		result.addQueryItem("enableImageTypes", Support::toString<QList<ImageType>>(params.enableImageTypes()));
+	}
+	
+	return result;
+}
+
+QByteArray GetInstantMixFromMusicGenreByIdLoader::body(const GetInstantMixFromMusicGenreByIdParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetInstantMixFromMusicGenreByIdLoader::operation() const {
 	// HTTP method Get
 	return QNetworkAccessManager::GetOperation;
 
@@ -291,7 +343,7 @@ GetInstantMixFromPlaylistLoader::GetInstantMixFromPlaylistLoader(ApiClient *apiC
 QString GetInstantMixFromPlaylistLoader::path(const GetInstantMixFromPlaylistParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/InstantMix");
 }
 
 QUrlQuery GetInstantMixFromPlaylistLoader::query(const GetInstantMixFromPlaylistParams &params) const {
@@ -341,7 +393,7 @@ GetInstantMixFromSongLoader::GetInstantMixFromSongLoader(ApiClient *apiClient)
 QString GetInstantMixFromSongLoader::path(const GetInstantMixFromSongParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Songs/") + Support::toString< QString>(params.jellyfinId()) + QStringLiteral("/InstantMix");
+	return QStringLiteral("/Songs/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/InstantMix");
 }
 
 QUrlQuery GetInstantMixFromSongLoader::query(const GetInstantMixFromSongParams &params) const {
diff --git a/core/src/loader/http/itemrefresh.cpp b/core/src/loader/http/itemrefresh.cpp
index 5be3700..b6f8139 100644
--- a/core/src/loader/http/itemrefresh.cpp
+++ b/core/src/loader/http/itemrefresh.cpp
@@ -35,16 +35,16 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-PostLoader::PostLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, PostParams>(apiClient) {}
+RefreshItemLoader::RefreshItemLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, RefreshItemParams>(apiClient) {}
 
-QString PostLoader::path(const PostParams &params) const {
+QString RefreshItemLoader::path(const RefreshItemParams &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("/Refresh");
 }
 
-QUrlQuery PostLoader::query(const PostParams &params) const {
+QUrlQuery RefreshItemLoader::query(const RefreshItemParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -62,15 +62,18 @@ QUrlQuery PostLoader::query(const PostParams &params) const {
 	if (!params.replaceAllImagesNull()) {
 		result.addQueryItem("replaceAllImages", Support::toString<std::optional<bool>>(params.replaceAllImages()));
 	}
+	if (!params.regenerateTrickplayNull()) {
+		result.addQueryItem("regenerateTrickplay", Support::toString<std::optional<bool>>(params.regenerateTrickplay()));
+	}
 	
 	return result;
 }
 
-QByteArray PostLoader::body(const PostParams &params) const {
+QByteArray RefreshItemLoader::body(const RefreshItemParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation PostLoader::operation() const {
+QNetworkAccessManager::Operation RefreshItemLoader::operation() const {
 	// HTTP method Post
 	return QNetworkAccessManager::PostOperation;
 
diff --git a/core/src/loader/http/items.cpp b/core/src/loader/http/items.cpp
index 4aba1a5..36306cb 100644
--- a/core/src/loader/http/items.cpp
+++ b/core/src/loader/http/items.cpp
@@ -74,6 +74,9 @@ QUrlQuery GetItemsLoader::query(const GetItemsParams &params) const {
 	if (!params.adjacentToNull()) {
 		result.addQueryItem("adjacentTo", Support::toString<QString>(params.adjacentTo()));
 	}
+	if (!params.indexNumberNull()) {
+		result.addQueryItem("indexNumber", Support::toString<std::optional<qint32>>(params.indexNumber()));
+	}
 	if (!params.parentIndexNumberNull()) {
 		result.addQueryItem("parentIndexNumber", Support::toString<std::optional<qint32>>(params.parentIndexNumber()));
 	}
@@ -128,6 +131,21 @@ QUrlQuery GetItemsLoader::query(const GetItemsParams &params) const {
 	if (!params.hasTvdbIdNull()) {
 		result.addQueryItem("hasTvdbId", Support::toString<std::optional<bool>>(params.hasTvdbId()));
 	}
+	if (!params.isMovieNull()) {
+		result.addQueryItem("isMovie", Support::toString<std::optional<bool>>(params.isMovie()));
+	}
+	if (!params.isSeriesNull()) {
+		result.addQueryItem("isSeries", Support::toString<std::optional<bool>>(params.isSeries()));
+	}
+	if (!params.isNewsNull()) {
+		result.addQueryItem("isNews", Support::toString<std::optional<bool>>(params.isNews()));
+	}
+	if (!params.isKidsNull()) {
+		result.addQueryItem("isKids", Support::toString<std::optional<bool>>(params.isKids()));
+	}
+	if (!params.isSportsNull()) {
+		result.addQueryItem("isSports", Support::toString<std::optional<bool>>(params.isSports()));
+	}
 	if (!params.excludeItemIdsNull()) {
 		result.addQueryItem("excludeItemIds", Support::toString<QStringList>(params.excludeItemIds()));
 	}
@@ -144,7 +162,7 @@ QUrlQuery GetItemsLoader::query(const GetItemsParams &params) const {
 		result.addQueryItem("searchTerm", Support::toString<QString>(params.searchTerm()));
 	}
 	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
 	}
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
@@ -153,10 +171,10 @@ QUrlQuery GetItemsLoader::query(const GetItemsParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.filtersNull()) {
 		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
@@ -165,13 +183,13 @@ QUrlQuery GetItemsLoader::query(const GetItemsParams &params) const {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.imageTypesNull()) {
 		result.addQueryItem("imageTypes", Support::toString<QList<ImageType>>(params.imageTypes()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.isPlayedNull()) {
 		result.addQueryItem("isPlayed", Support::toString<std::optional<bool>>(params.isPlayed()));
@@ -304,279 +322,77 @@ QNetworkAccessManager::Operation GetItemsLoader::operation() const {
 
 }
 
-GetItemsByUserIdLoader::GetItemsByUserIdLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetItemsByUserIdParams>(apiClient) {}
+GetItemUserDataLoader::GetItemUserDataLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, GetItemUserDataParams>(apiClient) {}
 
-QString GetItemsByUserIdLoader::path(const GetItemsByUserIdParams &params) const {
+QString GetItemUserDataLoader::path(const GetItemUserDataParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items");
+	return QStringLiteral("/UserItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/UserData");
 }
 
-QUrlQuery GetItemsByUserIdLoader::query(const GetItemsByUserIdParams &params) const {
+QUrlQuery GetItemUserDataLoader::query(const GetItemUserDataParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
 
 	// Optional parameters
-	if (!params.maxOfficialRatingNull()) {
-		result.addQueryItem("maxOfficialRating", Support::toString<QString>(params.maxOfficialRating()));
-	}
-	if (!params.hasThemeSongNull()) {
-		result.addQueryItem("hasThemeSong", Support::toString<std::optional<bool>>(params.hasThemeSong()));
-	}
-	if (!params.hasThemeVideoNull()) {
-		result.addQueryItem("hasThemeVideo", Support::toString<std::optional<bool>>(params.hasThemeVideo()));
-	}
-	if (!params.hasSubtitlesNull()) {
-		result.addQueryItem("hasSubtitles", Support::toString<std::optional<bool>>(params.hasSubtitles()));
-	}
-	if (!params.hasSpecialFeatureNull()) {
-		result.addQueryItem("hasSpecialFeature", Support::toString<std::optional<bool>>(params.hasSpecialFeature()));
-	}
-	if (!params.hasTrailerNull()) {
-		result.addQueryItem("hasTrailer", Support::toString<std::optional<bool>>(params.hasTrailer()));
-	}
-	if (!params.adjacentToNull()) {
-		result.addQueryItem("adjacentTo", Support::toString<QString>(params.adjacentTo()));
-	}
-	if (!params.parentIndexNumberNull()) {
-		result.addQueryItem("parentIndexNumber", Support::toString<std::optional<qint32>>(params.parentIndexNumber()));
-	}
-	if (!params.hasParentalRatingNull()) {
-		result.addQueryItem("hasParentalRating", Support::toString<std::optional<bool>>(params.hasParentalRating()));
-	}
-	if (!params.isHdNull()) {
-		result.addQueryItem("isHd", Support::toString<std::optional<bool>>(params.isHd()));
-	}
-	if (!params.is4KNull()) {
-		result.addQueryItem("is4K", Support::toString<std::optional<bool>>(params.is4K()));
-	}
-	if (!params.locationTypesNull()) {
-		result.addQueryItem("locationTypes", Support::toString<QList<LocationType>>(params.locationTypes()));
-	}
-	if (!params.excludeLocationTypesNull()) {
-		result.addQueryItem("excludeLocationTypes", Support::toString<QList<LocationType>>(params.excludeLocationTypes()));
-	}
-	if (!params.isMissingNull()) {
-		result.addQueryItem("isMissing", Support::toString<std::optional<bool>>(params.isMissing()));
-	}
-	if (!params.isUnairedNull()) {
-		result.addQueryItem("isUnaired", Support::toString<std::optional<bool>>(params.isUnaired()));
-	}
-	if (!params.minCommunityRatingNull()) {
-		result.addQueryItem("minCommunityRating", Support::toString<std::optional<double>>(params.minCommunityRating()));
-	}
-	if (!params.minCriticRatingNull()) {
-		result.addQueryItem("minCriticRating", Support::toString<std::optional<double>>(params.minCriticRating()));
-	}
-	if (!params.minPremiereDateNull()) {
-		result.addQueryItem("minPremiereDate", Support::toString<QDateTime>(params.minPremiereDate()));
-	}
-	if (!params.minDateLastSavedNull()) {
-		result.addQueryItem("minDateLastSaved", Support::toString<QDateTime>(params.minDateLastSaved()));
-	}
-	if (!params.minDateLastSavedForUserNull()) {
-		result.addQueryItem("minDateLastSavedForUser", Support::toString<QDateTime>(params.minDateLastSavedForUser()));
-	}
-	if (!params.maxPremiereDateNull()) {
-		result.addQueryItem("maxPremiereDate", Support::toString<QDateTime>(params.maxPremiereDate()));
-	}
-	if (!params.hasOverviewNull()) {
-		result.addQueryItem("hasOverview", Support::toString<std::optional<bool>>(params.hasOverview()));
-	}
-	if (!params.hasImdbIdNull()) {
-		result.addQueryItem("hasImdbId", Support::toString<std::optional<bool>>(params.hasImdbId()));
-	}
-	if (!params.hasTmdbIdNull()) {
-		result.addQueryItem("hasTmdbId", Support::toString<std::optional<bool>>(params.hasTmdbId()));
-	}
-	if (!params.hasTvdbIdNull()) {
-		result.addQueryItem("hasTvdbId", Support::toString<std::optional<bool>>(params.hasTvdbId()));
-	}
-	if (!params.excludeItemIdsNull()) {
-		result.addQueryItem("excludeItemIds", Support::toString<QStringList>(params.excludeItemIds()));
-	}
-	if (!params.startIndexNull()) {
-		result.addQueryItem("startIndex", Support::toString<std::optional<qint32>>(params.startIndex()));
-	}
-	if (!params.limitNull()) {
-		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
-	}
-	if (!params.recursiveNull()) {
-		result.addQueryItem("recursive", Support::toString<std::optional<bool>>(params.recursive()));
-	}
-	if (!params.searchTermNull()) {
-		result.addQueryItem("searchTerm", Support::toString<QString>(params.searchTerm()));
-	}
-	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
-	}
-	if (!params.parentIdNull()) {
-		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
-	}
-	if (!params.fieldsNull()) {
-		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
-	}
-	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
-	}
-	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
-	}
-	if (!params.filtersNull()) {
-		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
-	}
-	if (!params.isFavoriteNull()) {
-		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
-	}
-	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
-	}
-	if (!params.imageTypesNull()) {
-		result.addQueryItem("imageTypes", Support::toString<QList<ImageType>>(params.imageTypes()));
-	}
-	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
-	}
-	if (!params.isPlayedNull()) {
-		result.addQueryItem("isPlayed", Support::toString<std::optional<bool>>(params.isPlayed()));
-	}
-	if (!params.genresNull()) {
-		result.addQueryItem("genres", Support::toString<QStringList>(params.genres()));
-	}
-	if (!params.officialRatingsNull()) {
-		result.addQueryItem("officialRatings", Support::toString<QStringList>(params.officialRatings()));
-	}
-	if (!params.tagsNull()) {
-		result.addQueryItem("tags", Support::toString<QStringList>(params.tags()));
-	}
-	if (!params.yearsNull()) {
-		result.addQueryItem("years", Support::toString<QList<qint32>>(params.years()));
-	}
-	if (!params.enableUserDataNull()) {
-		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
-	}
-	if (!params.imageTypeLimitNull()) {
-		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
-	}
-	if (!params.enableImageTypesNull()) {
-		result.addQueryItem("enableImageTypes", Support::toString<QList<ImageType>>(params.enableImageTypes()));
-	}
-	if (!params.personNull()) {
-		result.addQueryItem("person", Support::toString<QString>(params.person()));
-	}
-	if (!params.personIdsNull()) {
-		result.addQueryItem("personIds", Support::toString<QStringList>(params.personIds()));
-	}
-	if (!params.personTypesNull()) {
-		result.addQueryItem("personTypes", Support::toString<QStringList>(params.personTypes()));
-	}
-	if (!params.studiosNull()) {
-		result.addQueryItem("studios", Support::toString<QStringList>(params.studios()));
-	}
-	if (!params.artistsNull()) {
-		result.addQueryItem("artists", Support::toString<QStringList>(params.artists()));
-	}
-	if (!params.excludeArtistIdsNull()) {
-		result.addQueryItem("excludeArtistIds", Support::toString<QStringList>(params.excludeArtistIds()));
-	}
-	if (!params.artistIdsNull()) {
-		result.addQueryItem("artistIds", Support::toString<QStringList>(params.artistIds()));
-	}
-	if (!params.albumArtistIdsNull()) {
-		result.addQueryItem("albumArtistIds", Support::toString<QStringList>(params.albumArtistIds()));
-	}
-	if (!params.contributingArtistIdsNull()) {
-		result.addQueryItem("contributingArtistIds", Support::toString<QStringList>(params.contributingArtistIds()));
-	}
-	if (!params.albumsNull()) {
-		result.addQueryItem("albums", Support::toString<QStringList>(params.albums()));
-	}
-	if (!params.albumIdsNull()) {
-		result.addQueryItem("albumIds", Support::toString<QStringList>(params.albumIds()));
-	}
-	if (!params.idsNull()) {
-		result.addQueryItem("ids", Support::toString<QStringList>(params.ids()));
-	}
-	if (!params.videoTypesNull()) {
-		result.addQueryItem("videoTypes", Support::toString<QList<VideoType>>(params.videoTypes()));
-	}
-	if (!params.minOfficialRatingNull()) {
-		result.addQueryItem("minOfficialRating", Support::toString<QString>(params.minOfficialRating()));
-	}
-	if (!params.isLockedNull()) {
-		result.addQueryItem("isLocked", Support::toString<std::optional<bool>>(params.isLocked()));
-	}
-	if (!params.isPlaceHolderNull()) {
-		result.addQueryItem("isPlaceHolder", Support::toString<std::optional<bool>>(params.isPlaceHolder()));
-	}
-	if (!params.hasOfficialRatingNull()) {
-		result.addQueryItem("hasOfficialRating", Support::toString<std::optional<bool>>(params.hasOfficialRating()));
-	}
-	if (!params.collapseBoxSetItemsNull()) {
-		result.addQueryItem("collapseBoxSetItems", Support::toString<std::optional<bool>>(params.collapseBoxSetItems()));
-	}
-	if (!params.minWidthNull()) {
-		result.addQueryItem("minWidth", Support::toString<std::optional<qint32>>(params.minWidth()));
-	}
-	if (!params.minHeightNull()) {
-		result.addQueryItem("minHeight", Support::toString<std::optional<qint32>>(params.minHeight()));
-	}
-	if (!params.maxWidthNull()) {
-		result.addQueryItem("maxWidth", Support::toString<std::optional<qint32>>(params.maxWidth()));
-	}
-	if (!params.maxHeightNull()) {
-		result.addQueryItem("maxHeight", Support::toString<std::optional<qint32>>(params.maxHeight()));
-	}
-	if (!params.is3DNull()) {
-		result.addQueryItem("is3D", Support::toString<std::optional<bool>>(params.is3D()));
-	}
-	if (!params.seriesStatusNull()) {
-		result.addQueryItem("seriesStatus", Support::toString<QList<SeriesStatus>>(params.seriesStatus()));
-	}
-	if (!params.nameStartsWithOrGreaterNull()) {
-		result.addQueryItem("nameStartsWithOrGreater", Support::toString<QString>(params.nameStartsWithOrGreater()));
-	}
-	if (!params.nameStartsWithNull()) {
-		result.addQueryItem("nameStartsWith", Support::toString<QString>(params.nameStartsWith()));
-	}
-	if (!params.nameLessThanNull()) {
-		result.addQueryItem("nameLessThan", Support::toString<QString>(params.nameLessThan()));
-	}
-	if (!params.studioIdsNull()) {
-		result.addQueryItem("studioIds", Support::toString<QStringList>(params.studioIds()));
-	}
-	if (!params.genreIdsNull()) {
-		result.addQueryItem("genreIds", Support::toString<QStringList>(params.genreIds()));
-	}
-	if (!params.enableTotalRecordCountNull()) {
-		result.addQueryItem("enableTotalRecordCount", Support::toString<std::optional<bool>>(params.enableTotalRecordCount()));
-	}
-	if (!params.enableImagesNull()) {
-		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	
 	return result;
 }
 
-QByteArray GetItemsByUserIdLoader::body(const GetItemsByUserIdParams &params) const {
+QByteArray GetItemUserDataLoader::body(const GetItemUserDataParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation GetItemsByUserIdLoader::operation() const {
+QNetworkAccessManager::Operation GetItemUserDataLoader::operation() const {
 	// HTTP method Get
 	return QNetworkAccessManager::GetOperation;
 
 }
 
+UpdateItemUserDataLoader::UpdateItemUserDataLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateItemUserDataParams>(apiClient) {}
+
+QString UpdateItemUserDataLoader::path(const UpdateItemUserDataParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/UserData");
+}
+
+QUrlQuery UpdateItemUserDataLoader::query(const UpdateItemUserDataParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray UpdateItemUserDataLoader::body(const UpdateItemUserDataParams &params) const {
+	return Support::toString<QSharedPointer<UpdateUserItemDataDto>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdateItemUserDataLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 GetResumeItemsLoader::GetResumeItemsLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetResumeItemsParams>(apiClient) {}
 
 QString GetResumeItemsLoader::path(const GetResumeItemsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/Resume");
+	return QStringLiteral("/UserItems/Resume");
 }
 
 QUrlQuery GetResumeItemsLoader::query(const GetResumeItemsParams &params) const {
@@ -585,6 +401,9 @@ QUrlQuery GetResumeItemsLoader::query(const GetResumeItemsParams &params) const
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.startIndexNull()) {
 		result.addQueryItem("startIndex", Support::toString<std::optional<qint32>>(params.startIndex()));
 	}
@@ -601,7 +420,7 @@ QUrlQuery GetResumeItemsLoader::query(const GetResumeItemsParams &params) const
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.enableUserDataNull()) {
 		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
@@ -613,10 +432,10 @@ QUrlQuery GetResumeItemsLoader::query(const GetResumeItemsParams &params) const
 		result.addQueryItem("enableImageTypes", Support::toString<QList<ImageType>>(params.enableImageTypes()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.enableTotalRecordCountNull()) {
 		result.addQueryItem("enableTotalRecordCount", Support::toString<std::optional<bool>>(params.enableTotalRecordCount()));
@@ -624,6 +443,9 @@ QUrlQuery GetResumeItemsLoader::query(const GetResumeItemsParams &params) const
 	if (!params.enableImagesNull()) {
 		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
+	if (!params.excludeActiveSessionsNull()) {
+		result.addQueryItem("excludeActiveSessions", Support::toString<std::optional<bool>>(params.excludeActiveSessions()));
+	}
 	
 	return result;
 }
diff --git a/core/src/loader/http/library.cpp b/core/src/loader/http/library.cpp
index c53dbe8..3a4e333 100644
--- a/core/src/loader/http/library.cpp
+++ b/core/src/loader/http/library.cpp
@@ -301,6 +301,12 @@ QUrlQuery GetThemeMediaLoader::query(const GetThemeMediaParams &params) const {
 	if (!params.inheritFromParentNull()) {
 		result.addQueryItem("inheritFromParent", Support::toString<std::optional<bool>>(params.inheritFromParent()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	
 	return result;
 }
@@ -336,6 +342,12 @@ QUrlQuery GetThemeSongsLoader::query(const GetThemeSongsParams &params) const {
 	if (!params.inheritFromParentNull()) {
 		result.addQueryItem("inheritFromParent", Support::toString<std::optional<bool>>(params.inheritFromParent()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	
 	return result;
 }
@@ -371,6 +383,12 @@ QUrlQuery GetThemeVideosLoader::query(const GetThemeVideosParams &params) const
 	if (!params.inheritFromParentNull()) {
 		result.addQueryItem("inheritFromParent", Support::toString<std::optional<bool>>(params.inheritFromParent()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	
 	return result;
 }
@@ -436,7 +454,7 @@ QUrlQuery GetLibraryOptionsInfoLoader::query(const GetLibraryOptionsInfoParams &
 
 	// Optional parameters
 	if (!params.libraryContentTypeNull()) {
-		result.addQueryItem("libraryContentType", Support::toString<QString>(params.libraryContentType()));
+		result.addQueryItem("libraryContentType", Support::toString<CollectionType>(params.libraryContentType()));
 	}
 	if (!params.isNewLibraryNull()) {
 		result.addQueryItem("isNewLibrary", Support::toString<std::optional<bool>>(params.isNewLibrary()));
@@ -475,7 +493,7 @@ QUrlQuery PostUpdatedMediaLoader::query(const PostUpdatedMediaParams &params) co
 }
 
 QByteArray PostUpdatedMediaLoader::body(const PostUpdatedMediaParams &params) const {
-	return Support::toString<QList<MediaUpdateInfoDto>>(params.body()).toUtf8();
+	return Support::toString<QSharedPointer<MediaUpdateInfoDto>>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation PostUpdatedMediaLoader::operation() const {
@@ -639,8 +657,8 @@ QByteArray RefreshLibraryLoader::body(const RefreshLibraryParams &params) const
 }
 
 QNetworkAccessManager::Operation RefreshLibraryLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
 
 }
 
diff --git a/core/src/loader/http/librarystructure.cpp b/core/src/loader/http/librarystructure.cpp
index 17898b7..6117feb 100644
--- a/core/src/loader/http/librarystructure.cpp
+++ b/core/src/loader/http/librarystructure.cpp
@@ -83,7 +83,7 @@ QUrlQuery AddVirtualFolderLoader::query(const AddVirtualFolderParams &params) co
 		result.addQueryItem("name", Support::toString<QString>(params.name()));
 	}
 	if (!params.collectionTypeNull()) {
-		result.addQueryItem("collectionType", Support::toString<QString>(params.collectionType()));
+		result.addQueryItem("collectionType", Support::toString<CollectionTypeOptions>(params.collectionType()));
 	}
 	if (!params.pathsNull()) {
 		result.addQueryItem("paths", Support::toString<QStringList>(params.paths()));
@@ -292,15 +292,12 @@ QUrlQuery UpdateMediaPathLoader::query(const UpdateMediaPathParams &params) cons
 	QUrlQuery result;
 
 	// Optional parameters
-	if (!params.nameNull()) {
-		result.addQueryItem("name", Support::toString<QString>(params.name()));
-	}
 	
 	return result;
 }
 
 QByteArray UpdateMediaPathLoader::body(const UpdateMediaPathParams &params) const {
-	return Support::toString<QSharedPointer<MediaPathInfo>>(params.body()).toUtf8();
+	return Support::toString<QSharedPointer<UpdateMediaPathRequestDto>>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation UpdateMediaPathLoader::operation() const {
diff --git a/core/src/loader/http/livetv.cpp b/core/src/loader/http/livetv.cpp
index dfce054..29c0ed1 100644
--- a/core/src/loader/http/livetv.cpp
+++ b/core/src/loader/http/livetv.cpp
@@ -163,7 +163,7 @@ QUrlQuery GetLiveTvChannelsLoader::query(const GetLiveTvChannelsParams &params)
 		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QStringList>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.sortOrderNull()) {
 		result.addQueryItem("sortOrder", Support::toString<SortOrder>(params.sortOrder()));
@@ -508,10 +508,10 @@ QUrlQuery GetLiveTvProgramsLoader::query(const GetLiveTvProgramsParams &params)
 		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
 	}
 	if (!params.genresNull()) {
 		result.addQueryItem("genres", Support::toString<QStringList>(params.genres()));
diff --git a/core/src/loader/http/lyrics.cpp b/core/src/loader/http/lyrics.cpp
new file mode 100644
index 0000000..b5b3c84
--- /dev/null
+++ b/core/src/loader/http/lyrics.cpp
@@ -0,0 +1,216 @@
+/*
+ * 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/lyrics.h>
+
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+GetLyricsLoader::GetLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<LyricDto, GetLyricsParams>(apiClient) {}
+
+QString GetLyricsLoader::path(const GetLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Audio/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Lyrics");
+}
+
+QUrlQuery GetLyricsLoader::query(const GetLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray GetLyricsLoader::body(const GetLyricsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetLyricsLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+UploadLyricsLoader::UploadLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<LyricDto, UploadLyricsParams>(apiClient) {}
+
+QString UploadLyricsLoader::path(const UploadLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Audio/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Lyrics");
+}
+
+QUrlQuery UploadLyricsLoader::query(const UploadLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+	result.addQueryItem("fileName", Support::toString<QString>(params.fileName()));
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray UploadLyricsLoader::body(const UploadLyricsParams &params) const {
+	return Support::toString<QByteArray>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UploadLyricsLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+DeleteLyricsLoader::DeleteLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, DeleteLyricsParams>(apiClient) {}
+
+QString DeleteLyricsLoader::path(const DeleteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Audio/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Lyrics");
+}
+
+QUrlQuery DeleteLyricsLoader::query(const DeleteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray DeleteLyricsLoader::body(const DeleteLyricsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation DeleteLyricsLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
+SearchRemoteLyricsLoader::SearchRemoteLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<QList<RemoteLyricInfoDto>, SearchRemoteLyricsParams>(apiClient) {}
+
+QString SearchRemoteLyricsLoader::path(const SearchRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Audio/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/RemoteSearch/Lyrics");
+}
+
+QUrlQuery SearchRemoteLyricsLoader::query(const SearchRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray SearchRemoteLyricsLoader::body(const SearchRemoteLyricsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation SearchRemoteLyricsLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+DownloadRemoteLyricsLoader::DownloadRemoteLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<LyricDto, DownloadRemoteLyricsParams>(apiClient) {}
+
+QString DownloadRemoteLyricsLoader::path(const DownloadRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Audio/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/RemoteSearch/Lyrics/") + Support::toString< QString>(params.lyricId()) ;
+}
+
+QUrlQuery DownloadRemoteLyricsLoader::query(const DownloadRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray DownloadRemoteLyricsLoader::body(const DownloadRemoteLyricsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation DownloadRemoteLyricsLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+GetRemoteLyricsLoader::GetRemoteLyricsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<LyricDto, GetRemoteLyricsParams>(apiClient) {}
+
+QString GetRemoteLyricsLoader::path(const GetRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Providers/Lyrics/") + Support::toString< QString>(params.lyricId()) ;
+}
+
+QUrlQuery GetRemoteLyricsLoader::query(const GetRemoteLyricsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray GetRemoteLyricsLoader::body(const GetRemoteLyricsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetRemoteLyricsLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
diff --git a/core/src/loader/http/mediainfo.cpp b/core/src/loader/http/mediainfo.cpp
index c2aaf46..3c85c10 100644
--- a/core/src/loader/http/mediainfo.cpp
+++ b/core/src/loader/http/mediainfo.cpp
@@ -48,9 +48,11 @@ QUrlQuery GetPlaybackInfoLoader::query(const GetPlaybackInfoParams &params) cons
 	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
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -214,6 +216,9 @@ QUrlQuery OpenLiveStreamLoader::query(const OpenLiveStreamParams &params) const
 	if (!params.enableDirectStreamNull()) {
 		result.addQueryItem("enableDirectStream", Support::toString<std::optional<bool>>(params.enableDirectStream()));
 	}
+	if (!params.alwaysBurnInSubtitleWhenTranscodingNull()) {
+		result.addQueryItem("alwaysBurnInSubtitleWhenTranscoding", Support::toString<std::optional<bool>>(params.alwaysBurnInSubtitleWhenTranscoding()));
+	}
 	
 	return result;
 }
diff --git a/core/src/loader/http/mediasegments.cpp b/core/src/loader/http/mediasegments.cpp
new file mode 100644
index 0000000..88fcb0a
--- /dev/null
+++ b/core/src/loader/http/mediasegments.cpp
@@ -0,0 +1,73 @@
+/*
+ * 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/mediasegments.h>
+
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+GetItemSegmentsLoader::GetItemSegmentsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<MediaSegmentDtoQueryResult, GetItemSegmentsParams>(apiClient) {}
+
+QString GetItemSegmentsLoader::path(const GetItemSegmentsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/MediaSegments/") + Support::toString< QString>(params.itemId()) ;
+}
+
+QUrlQuery GetItemSegmentsLoader::query(const GetItemSegmentsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	if (!params.includeSegmentTypesNull()) {
+		result.addQueryItem("includeSegmentTypes", Support::toString<QList<MediaSegmentType>>(params.includeSegmentTypes()));
+	}
+	
+	return result;
+}
+
+QByteArray GetItemSegmentsLoader::body(const GetItemSegmentsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetItemSegmentsLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
diff --git a/core/src/loader/http/musicgenres.cpp b/core/src/loader/http/musicgenres.cpp
index 4fd2e3f..f6a604f 100644
--- a/core/src/loader/http/musicgenres.cpp
+++ b/core/src/loader/http/musicgenres.cpp
@@ -66,10 +66,10 @@ QUrlQuery GetMusicGenresLoader::query(const GetMusicGenresParams &params) const
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.isFavoriteNull()) {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
@@ -92,6 +92,12 @@ QUrlQuery GetMusicGenresLoader::query(const GetMusicGenresParams &params) const
 	if (!params.nameLessThanNull()) {
 		result.addQueryItem("nameLessThan", Support::toString<QString>(params.nameLessThan()));
 	}
+	if (!params.sortByNull()) {
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
+	}
+	if (!params.sortOrderNull()) {
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
+	}
 	if (!params.enableImagesNull()) {
 		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
diff --git a/core/src/loader/http/notifications.cpp b/core/src/loader/http/notifications.cpp
deleted file mode 100644
index 5041bce..0000000
--- a/core/src/loader/http/notifications.cpp
+++ /dev/null
@@ -1,256 +0,0 @@
-/*
- * 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/notifications.h>
-
-namespace Jellyfin {
-namespace Loader {
-namespace HTTP {
-
-using namespace Jellyfin::DTO;
-
-GetNotificationsLoader::GetNotificationsLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<NotificationResultDto, GetNotificationsParams>(apiClient) {}
-
-QString GetNotificationsLoader::path(const GetNotificationsParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/") + Support::toString< QString>(params.userId()) ;
-}
-
-QUrlQuery GetNotificationsLoader::query(const GetNotificationsParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetNotificationsLoader::body(const GetNotificationsParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetNotificationsLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-SetReadLoader::SetReadLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, SetReadParams>(apiClient) {}
-
-QString SetReadLoader::path(const SetReadParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Read");
-}
-
-QUrlQuery SetReadLoader::query(const SetReadParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray SetReadLoader::body(const SetReadParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation SetReadLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-GetNotificationsSummaryLoader::GetNotificationsSummaryLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<NotificationsSummaryDto, GetNotificationsSummaryParams>(apiClient) {}
-
-QString GetNotificationsSummaryLoader::path(const GetNotificationsSummaryParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Summary");
-}
-
-QUrlQuery GetNotificationsSummaryLoader::query(const GetNotificationsSummaryParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetNotificationsSummaryLoader::body(const GetNotificationsSummaryParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetNotificationsSummaryLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-SetUnreadLoader::SetUnreadLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, SetUnreadParams>(apiClient) {}
-
-QString SetUnreadLoader::path(const SetUnreadParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Unread");
-}
-
-QUrlQuery SetUnreadLoader::query(const SetUnreadParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray SetUnreadLoader::body(const SetUnreadParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation SetUnreadLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-CreateAdminNotificationLoader::CreateAdminNotificationLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, CreateAdminNotificationParams>(apiClient) {}
-
-QString CreateAdminNotificationLoader::path(const CreateAdminNotificationParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/Admin");
-}
-
-QUrlQuery CreateAdminNotificationLoader::query(const CreateAdminNotificationParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.urlNull()) {
-		result.addQueryItem("url", Support::toString<QString>(params.url()));
-	}
-	if (!params.levelNull()) {
-		result.addQueryItem("level", Support::toString<NotificationLevel>(params.level()));
-	}
-	if (!params.nameNull()) {
-		result.addQueryItem("name", Support::toString<QString>(params.name()));
-	}
-	if (!params.descriptionNull()) {
-		result.addQueryItem("description", Support::toString<QString>(params.description()));
-	}
-	
-	return result;
-}
-
-QByteArray CreateAdminNotificationLoader::body(const CreateAdminNotificationParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation CreateAdminNotificationLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-GetNotificationServicesLoader::GetNotificationServicesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<NameIdPair>, GetNotificationServicesParams>(apiClient) {}
-
-QString GetNotificationServicesLoader::path(const GetNotificationServicesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/Services");
-}
-
-QUrlQuery GetNotificationServicesLoader::query(const GetNotificationServicesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetNotificationServicesLoader::body(const GetNotificationServicesParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetNotificationServicesLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-GetNotificationTypesLoader::GetNotificationTypesLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<NotificationTypeInfo>, GetNotificationTypesParams>(apiClient) {}
-
-QString GetNotificationTypesLoader::path(const GetNotificationTypesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Notifications/Types");
-}
-
-QUrlQuery GetNotificationTypesLoader::query(const GetNotificationTypesParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetNotificationTypesLoader::body(const GetNotificationTypesParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetNotificationTypesLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-
-} // NS HTTP
-} // NS Loader
-} // NS Jellyfin
diff --git a/core/src/loader/http/playlists.cpp b/core/src/loader/http/playlists.cpp
index dc7f2db..3823114 100644
--- a/core/src/loader/http/playlists.cpp
+++ b/core/src/loader/http/playlists.cpp
@@ -60,7 +60,7 @@ QUrlQuery CreatePlaylistLoader::query(const CreatePlaylistParams &params) const
 		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	if (!params.mediaTypeNull()) {
-		result.addQueryItem("mediaType", Support::toString<QString>(params.mediaType()));
+		result.addQueryItem("mediaType", Support::toString<MediaType>(params.mediaType()));
 	}
 	
 	return result;
@@ -76,16 +76,74 @@ QNetworkAccessManager::Operation CreatePlaylistLoader::operation() const {
 
 }
 
-AddToPlaylistLoader::AddToPlaylistLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, AddToPlaylistParams>(apiClient) {}
+UpdatePlaylistLoader::UpdatePlaylistLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UpdatePlaylistParams>(apiClient) {}
 
-QString AddToPlaylistLoader::path(const AddToPlaylistParams &params) const {
+QString UpdatePlaylistLoader::path(const UpdatePlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) ;
+}
+
+QUrlQuery UpdatePlaylistLoader::query(const UpdatePlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray UpdatePlaylistLoader::body(const UpdatePlaylistParams &params) const {
+	return Support::toString<QSharedPointer<UpdatePlaylistDto>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdatePlaylistLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+GetPlaylistLoader::GetPlaylistLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<PlaylistDto, GetPlaylistParams>(apiClient) {}
+
+QString GetPlaylistLoader::path(const GetPlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) ;
+}
+
+QUrlQuery GetPlaylistLoader::query(const GetPlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray GetPlaylistLoader::body(const GetPlaylistParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetPlaylistLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+AddItemToPlaylistLoader::AddItemToPlaylistLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, AddItemToPlaylistParams>(apiClient) {}
+
+QString AddItemToPlaylistLoader::path(const AddItemToPlaylistParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Items");
 }
 
-QUrlQuery AddToPlaylistLoader::query(const AddToPlaylistParams &params) const {
+QUrlQuery AddItemToPlaylistLoader::query(const AddItemToPlaylistParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -101,26 +159,26 @@ QUrlQuery AddToPlaylistLoader::query(const AddToPlaylistParams &params) const {
 	return result;
 }
 
-QByteArray AddToPlaylistLoader::body(const AddToPlaylistParams &params) const {
+QByteArray AddItemToPlaylistLoader::body(const AddItemToPlaylistParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation AddToPlaylistLoader::operation() const {
+QNetworkAccessManager::Operation AddItemToPlaylistLoader::operation() const {
 	// HTTP method Post
 	return QNetworkAccessManager::PostOperation;
 
 }
 
-RemoveFromPlaylistLoader::RemoveFromPlaylistLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, RemoveFromPlaylistParams>(apiClient) {}
+RemoveItemFromPlaylistLoader::RemoveItemFromPlaylistLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, RemoveItemFromPlaylistParams>(apiClient) {}
 
-QString RemoveFromPlaylistLoader::path(const RemoveFromPlaylistParams &params) const {
+QString RemoveItemFromPlaylistLoader::path(const RemoveItemFromPlaylistParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Items");
 }
 
-QUrlQuery RemoveFromPlaylistLoader::query(const RemoveFromPlaylistParams &params) const {
+QUrlQuery RemoveItemFromPlaylistLoader::query(const RemoveItemFromPlaylistParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -133,11 +191,11 @@ QUrlQuery RemoveFromPlaylistLoader::query(const RemoveFromPlaylistParams &params
 	return result;
 }
 
-QByteArray RemoveFromPlaylistLoader::body(const RemoveFromPlaylistParams &params) const {
+QByteArray RemoveItemFromPlaylistLoader::body(const RemoveItemFromPlaylistParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation RemoveFromPlaylistLoader::operation() const {
+QNetworkAccessManager::Operation RemoveItemFromPlaylistLoader::operation() const {
 	// HTTP method Delete
 	return QNetworkAccessManager::DeleteOperation;
 
@@ -156,9 +214,11 @@ QUrlQuery GetPlaylistItemsLoader::query(const GetPlaylistItemsParams &params) co
 	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
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.startIndexNull()) {
 		result.addQueryItem("startIndex", Support::toString<std::optional<qint32>>(params.startIndex()));
 	}
@@ -223,6 +283,122 @@ QNetworkAccessManager::Operation MoveItemLoader::operation() const {
 
 }
 
+GetPlaylistUsersLoader::GetPlaylistUsersLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<QList<PlaylistUserPermissions>, GetPlaylistUsersParams>(apiClient) {}
+
+QString GetPlaylistUsersLoader::path(const GetPlaylistUsersParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Users");
+}
+
+QUrlQuery GetPlaylistUsersLoader::query(const GetPlaylistUsersParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray GetPlaylistUsersLoader::body(const GetPlaylistUsersParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetPlaylistUsersLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+GetPlaylistUserLoader::GetPlaylistUserLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<PlaylistUserPermissions, GetPlaylistUserParams>(apiClient) {}
+
+QString GetPlaylistUserLoader::path(const GetPlaylistUserParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) ;
+}
+
+QUrlQuery GetPlaylistUserLoader::query(const GetPlaylistUserParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray GetPlaylistUserLoader::body(const GetPlaylistUserParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetPlaylistUserLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+UpdatePlaylistUserLoader::UpdatePlaylistUserLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UpdatePlaylistUserParams>(apiClient) {}
+
+QString UpdatePlaylistUserLoader::path(const UpdatePlaylistUserParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) ;
+}
+
+QUrlQuery UpdatePlaylistUserLoader::query(const UpdatePlaylistUserParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray UpdatePlaylistUserLoader::body(const UpdatePlaylistUserParams &params) const {
+	return Support::toString<QSharedPointer<UpdatePlaylistUserDto>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdatePlaylistUserLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+RemoveUserFromPlaylistLoader::RemoveUserFromPlaylistLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, RemoveUserFromPlaylistParams>(apiClient) {}
+
+QString RemoveUserFromPlaylistLoader::path(const RemoveUserFromPlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Playlists/") + Support::toString< QString>(params.playlistId()) + QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) ;
+}
+
+QUrlQuery RemoveUserFromPlaylistLoader::query(const RemoveUserFromPlaylistParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray RemoveUserFromPlaylistLoader::body(const RemoveUserFromPlaylistParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation RemoveUserFromPlaylistLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/playstate.cpp b/core/src/loader/http/playstate.cpp
index abd37d1..d41b2d7 100644
--- a/core/src/loader/http/playstate.cpp
+++ b/core/src/loader/http/playstate.cpp
@@ -35,6 +35,162 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
+OnPlaybackStartLoader::OnPlaybackStartLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, OnPlaybackStartParams>(apiClient) {}
+
+QString OnPlaybackStartLoader::path(const OnPlaybackStartParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) ;
+}
+
+QUrlQuery OnPlaybackStartLoader::query(const OnPlaybackStartParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	if (!params.mediaSourceIdNull()) {
+		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
+	}
+	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.playMethodNull()) {
+		result.addQueryItem("playMethod", Support::toString<PlayMethod>(params.playMethod()));
+	}
+	if (!params.liveStreamIdNull()) {
+		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
+	}
+	if (!params.playSessionIdNull()) {
+		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
+	}
+	if (!params.canSeekNull()) {
+		result.addQueryItem("canSeek", Support::toString<std::optional<bool>>(params.canSeek()));
+	}
+	
+	return result;
+}
+
+QByteArray OnPlaybackStartLoader::body(const OnPlaybackStartParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation OnPlaybackStartLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+OnPlaybackStoppedLoader::OnPlaybackStoppedLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, OnPlaybackStoppedParams>(apiClient) {}
+
+QString OnPlaybackStoppedLoader::path(const OnPlaybackStoppedParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) ;
+}
+
+QUrlQuery OnPlaybackStoppedLoader::query(const OnPlaybackStoppedParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	if (!params.mediaSourceIdNull()) {
+		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
+	}
+	if (!params.nextMediaTypeNull()) {
+		result.addQueryItem("nextMediaType", Support::toString<QString>(params.nextMediaType()));
+	}
+	if (!params.positionTicksNull()) {
+		result.addQueryItem("positionTicks", Support::toString<std::optional<qint64>>(params.positionTicks()));
+	}
+	if (!params.liveStreamIdNull()) {
+		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
+	}
+	if (!params.playSessionIdNull()) {
+		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
+	}
+	
+	return result;
+}
+
+QByteArray OnPlaybackStoppedLoader::body(const OnPlaybackStoppedParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation OnPlaybackStoppedLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
+OnPlaybackProgressLoader::OnPlaybackProgressLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, OnPlaybackProgressParams>(apiClient) {}
+
+QString OnPlaybackProgressLoader::path(const OnPlaybackProgressParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Progress");
+}
+
+QUrlQuery OnPlaybackProgressLoader::query(const OnPlaybackProgressParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	if (!params.mediaSourceIdNull()) {
+		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
+	}
+	if (!params.positionTicksNull()) {
+		result.addQueryItem("positionTicks", Support::toString<std::optional<qint64>>(params.positionTicks()));
+	}
+	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.volumeLevelNull()) {
+		result.addQueryItem("volumeLevel", Support::toString<std::optional<qint32>>(params.volumeLevel()));
+	}
+	if (!params.playMethodNull()) {
+		result.addQueryItem("playMethod", Support::toString<PlayMethod>(params.playMethod()));
+	}
+	if (!params.liveStreamIdNull()) {
+		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
+	}
+	if (!params.playSessionIdNull()) {
+		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
+	}
+	if (!params.repeatModeNull()) {
+		result.addQueryItem("repeatMode", Support::toString<RepeatMode>(params.repeatMode()));
+	}
+	if (!params.isPausedNull()) {
+		result.addQueryItem("isPaused", Support::toString<std::optional<bool>>(params.isPaused()));
+	}
+	if (!params.isMutedNull()) {
+		result.addQueryItem("isMuted", Support::toString<std::optional<bool>>(params.isMuted()));
+	}
+	
+	return result;
+}
+
+QByteArray OnPlaybackProgressLoader::body(const OnPlaybackProgressParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation OnPlaybackProgressLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 ReportPlaybackStartLoader::ReportPlaybackStartLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<void, ReportPlaybackStartParams>(apiClient) {}
 
@@ -77,11 +233,9 @@ QUrlQuery PingPlaybackSessionLoader::query(const PingPlaybackSessionParams &para
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
+	result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
 
 	// Optional parameters
-	if (!params.playSessionIdNull()) {
-		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
-	}
 	
 	return result;
 }
@@ -160,7 +314,7 @@ MarkPlayedItemLoader::MarkPlayedItemLoader(ApiClient *apiClient)
 QString MarkPlayedItemLoader::path(const MarkPlayedItemParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/PlayedItems/") + Support::toString< QString>(params.itemId()) ;
+	return QStringLiteral("/UserPlayedItems/") + Support::toString< QString>(params.itemId()) ;
 }
 
 QUrlQuery MarkPlayedItemLoader::query(const MarkPlayedItemParams &params) const {
@@ -169,6 +323,9 @@ QUrlQuery MarkPlayedItemLoader::query(const MarkPlayedItemParams &params) const
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.datePlayedNull()) {
 		result.addQueryItem("datePlayed", Support::toString<QDateTime>(params.datePlayed()));
 	}
@@ -192,7 +349,7 @@ MarkUnplayedItemLoader::MarkUnplayedItemLoader(ApiClient *apiClient)
 QString MarkUnplayedItemLoader::path(const MarkUnplayedItemParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/PlayedItems/") + Support::toString< QString>(params.itemId()) ;
+	return QStringLiteral("/UserPlayedItems/") + Support::toString< QString>(params.itemId()) ;
 }
 
 QUrlQuery MarkUnplayedItemLoader::query(const MarkUnplayedItemParams &params) const {
@@ -201,6 +358,9 @@ QUrlQuery MarkUnplayedItemLoader::query(const MarkUnplayedItemParams &params) co
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -215,162 +375,6 @@ QNetworkAccessManager::Operation MarkUnplayedItemLoader::operation() const {
 
 }
 
-OnPlaybackStartLoader::OnPlaybackStartLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, OnPlaybackStartParams>(apiClient) {}
-
-QString OnPlaybackStartLoader::path(const OnPlaybackStartParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) ;
-}
-
-QUrlQuery OnPlaybackStartLoader::query(const OnPlaybackStartParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.mediaSourceIdNull()) {
-		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
-	}
-	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.playMethodNull()) {
-		result.addQueryItem("playMethod", Support::toString<PlayMethod>(params.playMethod()));
-	}
-	if (!params.liveStreamIdNull()) {
-		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
-	}
-	if (!params.playSessionIdNull()) {
-		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
-	}
-	if (!params.canSeekNull()) {
-		result.addQueryItem("canSeek", Support::toString<std::optional<bool>>(params.canSeek()));
-	}
-	
-	return result;
-}
-
-QByteArray OnPlaybackStartLoader::body(const OnPlaybackStartParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation OnPlaybackStartLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-OnPlaybackStoppedLoader::OnPlaybackStoppedLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, OnPlaybackStoppedParams>(apiClient) {}
-
-QString OnPlaybackStoppedLoader::path(const OnPlaybackStoppedParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) ;
-}
-
-QUrlQuery OnPlaybackStoppedLoader::query(const OnPlaybackStoppedParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.mediaSourceIdNull()) {
-		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
-	}
-	if (!params.nextMediaTypeNull()) {
-		result.addQueryItem("nextMediaType", Support::toString<QString>(params.nextMediaType()));
-	}
-	if (!params.positionTicksNull()) {
-		result.addQueryItem("positionTicks", Support::toString<std::optional<qint64>>(params.positionTicks()));
-	}
-	if (!params.liveStreamIdNull()) {
-		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
-	}
-	if (!params.playSessionIdNull()) {
-		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
-	}
-	
-	return result;
-}
-
-QByteArray OnPlaybackStoppedLoader::body(const OnPlaybackStoppedParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation OnPlaybackStoppedLoader::operation() const {
-	// HTTP method Delete
-	return QNetworkAccessManager::DeleteOperation;
-
-}
-
-OnPlaybackProgressLoader::OnPlaybackProgressLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, OnPlaybackProgressParams>(apiClient) {}
-
-QString OnPlaybackProgressLoader::path(const OnPlaybackProgressParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/PlayingItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Progress");
-}
-
-QUrlQuery OnPlaybackProgressLoader::query(const OnPlaybackProgressParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.mediaSourceIdNull()) {
-		result.addQueryItem("mediaSourceId", Support::toString<QString>(params.mediaSourceId()));
-	}
-	if (!params.positionTicksNull()) {
-		result.addQueryItem("positionTicks", Support::toString<std::optional<qint64>>(params.positionTicks()));
-	}
-	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.volumeLevelNull()) {
-		result.addQueryItem("volumeLevel", Support::toString<std::optional<qint32>>(params.volumeLevel()));
-	}
-	if (!params.playMethodNull()) {
-		result.addQueryItem("playMethod", Support::toString<PlayMethod>(params.playMethod()));
-	}
-	if (!params.liveStreamIdNull()) {
-		result.addQueryItem("liveStreamId", Support::toString<QString>(params.liveStreamId()));
-	}
-	if (!params.playSessionIdNull()) {
-		result.addQueryItem("playSessionId", Support::toString<QString>(params.playSessionId()));
-	}
-	if (!params.repeatModeNull()) {
-		result.addQueryItem("repeatMode", Support::toString<RepeatMode>(params.repeatMode()));
-	}
-	if (!params.isPausedNull()) {
-		result.addQueryItem("isPaused", Support::toString<std::optional<bool>>(params.isPaused()));
-	}
-	if (!params.isMutedNull()) {
-		result.addQueryItem("isMuted", Support::toString<std::optional<bool>>(params.isMuted()));
-	}
-	
-	return result;
-}
-
-QByteArray OnPlaybackProgressLoader::body(const OnPlaybackProgressParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation OnPlaybackProgressLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/plugins.cpp b/core/src/loader/http/plugins.cpp
index 6a813b7..b610789 100644
--- a/core/src/loader/http/plugins.cpp
+++ b/core/src/loader/http/plugins.cpp
@@ -99,7 +99,7 @@ UninstallPluginByVersionLoader::UninstallPluginByVersionLoader(ApiClient *apiCli
 QString UninstallPluginByVersionLoader::path(const UninstallPluginByVersionParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QSharedPointer<Version>>(params.version()) ;
+	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QString>(params.version()) ;
 }
 
 QUrlQuery UninstallPluginByVersionLoader::query(const UninstallPluginByVersionParams &params) const {
@@ -128,7 +128,7 @@ DisablePluginLoader::DisablePluginLoader(ApiClient *apiClient)
 QString DisablePluginLoader::path(const DisablePluginParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QSharedPointer<Version>>(params.version()) + QStringLiteral("/Disable");
+	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QString>(params.version()) + QStringLiteral("/Disable");
 }
 
 QUrlQuery DisablePluginLoader::query(const DisablePluginParams &params) const {
@@ -157,7 +157,7 @@ EnablePluginLoader::EnablePluginLoader(ApiClient *apiClient)
 QString EnablePluginLoader::path(const EnablePluginParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QSharedPointer<Version>>(params.version()) + QStringLiteral("/Enable");
+	return QStringLiteral("/Plugins/") + Support::toString< QString>(params.pluginId()) + QStringLiteral("/") + Support::toString< QString>(params.version()) + QStringLiteral("/Enable");
 }
 
 QUrlQuery EnablePluginLoader::query(const EnablePluginParams &params) const {
@@ -267,35 +267,6 @@ QNetworkAccessManager::Operation GetPluginManifestLoader::operation() const {
 
 }
 
-UpdatePluginSecurityInfoLoader::UpdatePluginSecurityInfoLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdatePluginSecurityInfoParams>(apiClient) {}
-
-QString UpdatePluginSecurityInfoLoader::path(const UpdatePluginSecurityInfoParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Plugins/SecurityInfo");
-}
-
-QUrlQuery UpdatePluginSecurityInfoLoader::query(const UpdatePluginSecurityInfoParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdatePluginSecurityInfoLoader::body(const UpdatePluginSecurityInfoParams &params) const {
-	return Support::toString<QSharedPointer<PluginSecurityInfo>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdatePluginSecurityInfoLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/quickconnect.cpp b/core/src/loader/http/quickconnect.cpp
index 48c98b8..b9c073d 100644
--- a/core/src/loader/http/quickconnect.cpp
+++ b/core/src/loader/http/quickconnect.cpp
@@ -35,107 +35,49 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-ActivateLoader::ActivateLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, ActivateParams>(apiClient) {}
+AuthorizeQuickConnectLoader::AuthorizeQuickConnectLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<bool, AuthorizeQuickConnectParams>(apiClient) {}
 
-QString ActivateLoader::path(const ActivateParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/QuickConnect/Activate");
-}
-
-QUrlQuery ActivateLoader::query(const ActivateParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray ActivateLoader::body(const ActivateParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation ActivateLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-AuthorizeLoader::AuthorizeLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<bool, AuthorizeParams>(apiClient) {}
-
-QString AuthorizeLoader::path(const AuthorizeParams &params) const {
+QString AuthorizeQuickConnectLoader::path(const AuthorizeQuickConnectParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/QuickConnect/Authorize");
 }
 
-QUrlQuery AuthorizeLoader::query(const AuthorizeParams &params) const {
+QUrlQuery AuthorizeQuickConnectLoader::query(const AuthorizeQuickConnectParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
 	result.addQueryItem("code", Support::toString<QString>(params.code()));
 
 	// Optional parameters
-	
-	return result;
-}
-
-QByteArray AuthorizeLoader::body(const AuthorizeParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation AuthorizeLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-AvailableLoader::AvailableLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, AvailableParams>(apiClient) {}
-
-QString AvailableLoader::path(const AvailableParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/QuickConnect/Available");
-}
-
-QUrlQuery AvailableLoader::query(const AvailableParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.statusNull()) {
-		result.addQueryItem("status", Support::toString<QuickConnectState>(params.status()));
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	
 	return result;
 }
 
-QByteArray AvailableLoader::body(const AvailableParams &params) const {
+QByteArray AuthorizeQuickConnectLoader::body(const AuthorizeQuickConnectParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation AvailableLoader::operation() const {
+QNetworkAccessManager::Operation AuthorizeQuickConnectLoader::operation() const {
 	// HTTP method Post
 	return QNetworkAccessManager::PostOperation;
 
 }
 
-ConnectLoader::ConnectLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QuickConnectResult, ConnectParams>(apiClient) {}
+GetQuickConnectStateLoader::GetQuickConnectStateLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<QuickConnectResult, GetQuickConnectStateParams>(apiClient) {}
 
-QString ConnectLoader::path(const ConnectParams &params) const {
+QString GetQuickConnectStateLoader::path(const GetQuickConnectStateParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/QuickConnect/Connect");
 }
 
-QUrlQuery ConnectLoader::query(const ConnectParams &params) const {
+QUrlQuery GetQuickConnectStateLoader::query(const GetQuickConnectStateParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -146,26 +88,26 @@ QUrlQuery ConnectLoader::query(const ConnectParams &params) const {
 	return result;
 }
 
-QByteArray ConnectLoader::body(const ConnectParams &params) const {
+QByteArray GetQuickConnectStateLoader::body(const GetQuickConnectStateParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation ConnectLoader::operation() const {
+QNetworkAccessManager::Operation GetQuickConnectStateLoader::operation() const {
 	// HTTP method Get
 	return QNetworkAccessManager::GetOperation;
 
 }
 
-DeauthorizeLoader::DeauthorizeLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<qint32, DeauthorizeParams>(apiClient) {}
+GetQuickConnectEnabledLoader::GetQuickConnectEnabledLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<bool, GetQuickConnectEnabledParams>(apiClient) {}
 
-QString DeauthorizeLoader::path(const DeauthorizeParams &params) const {
+QString GetQuickConnectEnabledLoader::path(const GetQuickConnectEnabledParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/QuickConnect/Deauthorize");
+	return QStringLiteral("/QuickConnect/Enabled");
 }
 
-QUrlQuery DeauthorizeLoader::query(const DeauthorizeParams &params) const {
+QUrlQuery GetQuickConnectEnabledLoader::query(const GetQuickConnectEnabledParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -175,26 +117,26 @@ QUrlQuery DeauthorizeLoader::query(const DeauthorizeParams &params) const {
 	return result;
 }
 
-QByteArray DeauthorizeLoader::body(const DeauthorizeParams &params) const {
+QByteArray GetQuickConnectEnabledLoader::body(const GetQuickConnectEnabledParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation DeauthorizeLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
+QNetworkAccessManager::Operation GetQuickConnectEnabledLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
 
 }
 
-InitiateLoader::InitiateLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QuickConnectResult, InitiateParams>(apiClient) {}
+InitiateQuickConnectLoader::InitiateQuickConnectLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<QuickConnectResult, InitiateQuickConnectParams>(apiClient) {}
 
-QString InitiateLoader::path(const InitiateParams &params) const {
+QString InitiateQuickConnectLoader::path(const InitiateQuickConnectParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/QuickConnect/Initiate");
 }
 
-QUrlQuery InitiateLoader::query(const InitiateParams &params) const {
+QUrlQuery InitiateQuickConnectLoader::query(const InitiateQuickConnectParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -204,42 +146,13 @@ QUrlQuery InitiateLoader::query(const InitiateParams &params) const {
 	return result;
 }
 
-QByteArray InitiateLoader::body(const InitiateParams &params) const {
+QByteArray InitiateQuickConnectLoader::body(const InitiateQuickConnectParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation InitiateLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
-GetStatusLoader::GetStatusLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QuickConnectState, GetStatusParams>(apiClient) {}
-
-QString GetStatusLoader::path(const GetStatusParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/QuickConnect/Status");
-}
-
-QUrlQuery GetStatusLoader::query(const GetStatusParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetStatusLoader::body(const GetStatusParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetStatusLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
+QNetworkAccessManager::Operation InitiateQuickConnectLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
 
 }
 
diff --git a/core/src/loader/http/search.cpp b/core/src/loader/http/search.cpp
index 776f5ba..e9e3a06 100644
--- a/core/src/loader/http/search.cpp
+++ b/core/src/loader/http/search.cpp
@@ -35,16 +35,16 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-GetLoader::GetLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<SearchHintResult, GetParams>(apiClient) {}
+GetSearchHintsLoader::GetSearchHintsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<SearchHintResult, GetSearchHintsParams>(apiClient) {}
 
-QString GetLoader::path(const GetParams &params) const {
+QString GetSearchHintsLoader::path(const GetSearchHintsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
 	return QStringLiteral("/Search/Hints");
 }
 
-QUrlQuery GetLoader::query(const GetParams &params) const {
+QUrlQuery GetSearchHintsLoader::query(const GetSearchHintsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
@@ -61,13 +61,13 @@ QUrlQuery GetLoader::query(const GetParams &params) const {
 		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
@@ -106,11 +106,11 @@ QUrlQuery GetLoader::query(const GetParams &params) const {
 	return result;
 }
 
-QByteArray GetLoader::body(const GetParams &params) const {
+QByteArray GetSearchHintsLoader::body(const GetSearchHintsParams &params) const {
 	return QByteArray();
 }
 
-QNetworkAccessManager::Operation GetLoader::operation() const {
+QNetworkAccessManager::Operation GetSearchHintsLoader::operation() const {
 	// HTTP method Get
 	return QNetworkAccessManager::GetOperation;
 
diff --git a/core/src/loader/http/session.cpp b/core/src/loader/http/session.cpp
index 939cfc3..5e8992d 100644
--- a/core/src/loader/http/session.cpp
+++ b/core/src/loader/http/session.cpp
@@ -94,7 +94,7 @@ QNetworkAccessManager::Operation GetAuthProvidersLoader::operation() const {
 }
 
 GetSessionsLoader::GetSessionsLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<SessionInfo>, GetSessionsParams>(apiClient) {}
+	: Jellyfin::Support::HttpLoader<QList<SessionInfoDto>, GetSessionsParams>(apiClient) {}
 
 QString GetSessionsLoader::path(const GetSessionsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
@@ -202,21 +202,14 @@ QUrlQuery SendMessageCommandLoader::query(const SendMessageCommandParams &params
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
-	result.addQueryItem("text", Support::toString<QString>(params.text()));
 
 	// Optional parameters
-	if (!params.headerNull()) {
-		result.addQueryItem("header", Support::toString<QString>(params.header()));
-	}
-	if (!params.timeoutMsNull()) {
-		result.addQueryItem("timeoutMs", Support::toString<std::optional<qint64>>(params.timeoutMs()));
-	}
 	
 	return result;
 }
 
 QByteArray SendMessageCommandLoader::body(const SendMessageCommandParams &params) const {
-	return QByteArray();
+	return Support::toString<QSharedPointer<MessageCommand>>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation SendMessageCommandLoader::operation() const {
@@ -406,7 +399,7 @@ QUrlQuery DisplayContentLoader::query(const DisplayContentParams &params) const
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 
 	QUrlQuery result;
-	result.addQueryItem("itemType", Support::toString<QString>(params.itemType()));
+	result.addQueryItem("itemType", Support::toString<BaseItemKind>(params.itemType()));
 	result.addQueryItem("itemId", Support::toString<QString>(params.itemId()));
 	result.addQueryItem("itemName", Support::toString<QString>(params.itemName()));
 
@@ -444,7 +437,7 @@ QUrlQuery PostCapabilitiesLoader::query(const PostCapabilitiesParams &params) co
 		result.addQueryItem("id", Support::toString<QString>(params.jellyfinId()));
 	}
 	if (!params.playableMediaTypesNull()) {
-		result.addQueryItem("playableMediaTypes", Support::toString<QStringList>(params.playableMediaTypes()));
+		result.addQueryItem("playableMediaTypes", Support::toString<QList<MediaType>>(params.playableMediaTypes()));
 	}
 	if (!params.supportedCommandsNull()) {
 		result.addQueryItem("supportedCommands", Support::toString<QList<GeneralCommandType>>(params.supportedCommands()));
@@ -452,9 +445,6 @@ QUrlQuery PostCapabilitiesLoader::query(const PostCapabilitiesParams &params) co
 	if (!params.supportsMediaControlNull()) {
 		result.addQueryItem("supportsMediaControl", Support::toString<std::optional<bool>>(params.supportsMediaControl()));
 	}
-	if (!params.supportsSyncNull()) {
-		result.addQueryItem("supportsSync", Support::toString<std::optional<bool>>(params.supportsSync()));
-	}
 	if (!params.supportsPersistentIdentifierNull()) {
 		result.addQueryItem("supportsPersistentIdentifier", Support::toString<std::optional<bool>>(params.supportsPersistentIdentifier()));
 	}
diff --git a/core/src/loader/http/studios.cpp b/core/src/loader/http/studios.cpp
index 7986cc2..7804e62 100644
--- a/core/src/loader/http/studios.cpp
+++ b/core/src/loader/http/studios.cpp
@@ -66,10 +66,10 @@ QUrlQuery GetStudiosLoader::query(const GetStudiosParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.isFavoriteNull()) {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
diff --git a/core/src/loader/http/suggestions.cpp b/core/src/loader/http/suggestions.cpp
index 8ddd807..371021c 100644
--- a/core/src/loader/http/suggestions.cpp
+++ b/core/src/loader/http/suggestions.cpp
@@ -41,7 +41,7 @@ GetSuggestionsLoader::GetSuggestionsLoader(ApiClient *apiClient)
 QString GetSuggestionsLoader::path(const GetSuggestionsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Suggestions");
+	return QStringLiteral("/Items/Suggestions");
 }
 
 QUrlQuery GetSuggestionsLoader::query(const GetSuggestionsParams &params) const {
@@ -50,11 +50,14 @@ QUrlQuery GetSuggestionsLoader::query(const GetSuggestionsParams &params) const
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.mediaTypeNull()) {
-		result.addQueryItem("mediaType", Support::toString<QStringList>(params.mediaType()));
+		result.addQueryItem("mediaType", Support::toString<QList<MediaType>>(params.mediaType()));
 	}
 	if (!params.typeNull()) {
-		result.addQueryItem("type", Support::toString<QStringList>(params.type()));
+		result.addQueryItem("type", Support::toString<QList<BaseItemKind>>(params.type()));
 	}
 	if (!params.startIndexNull()) {
 		result.addQueryItem("startIndex", Support::toString<std::optional<qint32>>(params.startIndex()));
diff --git a/core/src/loader/http/tmdb.cpp b/core/src/loader/http/tmdb.cpp
new file mode 100644
index 0000000..a5bfbf7
--- /dev/null
+++ b/core/src/loader/http/tmdb.cpp
@@ -0,0 +1,70 @@
+/*
+ * 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/tmdb.h>
+
+namespace Jellyfin {
+namespace Loader {
+namespace HTTP {
+
+using namespace Jellyfin::DTO;
+
+TmdbClientConfigurationLoader::TmdbClientConfigurationLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<ConfigImageTypes, TmdbClientConfigurationParams>(apiClient) {}
+
+QString TmdbClientConfigurationLoader::path(const TmdbClientConfigurationParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Tmdb/ClientConfiguration");
+}
+
+QUrlQuery TmdbClientConfigurationLoader::query(const TmdbClientConfigurationParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+
+	QUrlQuery result;
+
+	// Optional parameters
+	
+	return result;
+}
+
+QByteArray TmdbClientConfigurationLoader::body(const TmdbClientConfigurationParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation TmdbClientConfigurationLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
+
+} // NS HTTP
+} // NS Loader
+} // NS Jellyfin
diff --git a/core/src/loader/http/trailers.cpp b/core/src/loader/http/trailers.cpp
index e355295..4f6c500 100644
--- a/core/src/loader/http/trailers.cpp
+++ b/core/src/loader/http/trailers.cpp
@@ -128,6 +128,21 @@ QUrlQuery GetTrailersLoader::query(const GetTrailersParams &params) const {
 	if (!params.hasTvdbIdNull()) {
 		result.addQueryItem("hasTvdbId", Support::toString<std::optional<bool>>(params.hasTvdbId()));
 	}
+	if (!params.isMovieNull()) {
+		result.addQueryItem("isMovie", Support::toString<std::optional<bool>>(params.isMovie()));
+	}
+	if (!params.isSeriesNull()) {
+		result.addQueryItem("isSeries", Support::toString<std::optional<bool>>(params.isSeries()));
+	}
+	if (!params.isNewsNull()) {
+		result.addQueryItem("isNews", Support::toString<std::optional<bool>>(params.isNews()));
+	}
+	if (!params.isKidsNull()) {
+		result.addQueryItem("isKids", Support::toString<std::optional<bool>>(params.isKids()));
+	}
+	if (!params.isSportsNull()) {
+		result.addQueryItem("isSports", Support::toString<std::optional<bool>>(params.isSports()));
+	}
 	if (!params.excludeItemIdsNull()) {
 		result.addQueryItem("excludeItemIds", Support::toString<QStringList>(params.excludeItemIds()));
 	}
@@ -144,7 +159,7 @@ QUrlQuery GetTrailersLoader::query(const GetTrailersParams &params) const {
 		result.addQueryItem("searchTerm", Support::toString<QString>(params.searchTerm()));
 	}
 	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
 	}
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
@@ -153,7 +168,7 @@ QUrlQuery GetTrailersLoader::query(const GetTrailersParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.filtersNull()) {
 		result.addQueryItem("filters", Support::toString<QList<ItemFilter>>(params.filters()));
@@ -162,13 +177,13 @@ QUrlQuery GetTrailersLoader::query(const GetTrailersParams &params) const {
 		result.addQueryItem("isFavorite", Support::toString<std::optional<bool>>(params.isFavorite()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.imageTypesNull()) {
 		result.addQueryItem("imageTypes", Support::toString<QList<ImageType>>(params.imageTypes()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.isPlayedNull()) {
 		result.addQueryItem("isPlayed", Support::toString<std::optional<bool>>(params.isPlayed()));
diff --git a/core/src/loader/http/videohls.cpp b/core/src/loader/http/trickplay.cpp
similarity index 96%
rename from core/src/loader/http/videohls.cpp
rename to core/src/loader/http/trickplay.cpp
index eced5c6..6e5a577 100644
--- a/core/src/loader/http/videohls.cpp
+++ b/core/src/loader/http/trickplay.cpp
@@ -27,7 +27,7 @@
  * file with a newer file if needed instead of manually updating the files.
  */
 
-#include <JellyfinQt/loader/http/videohls.h>
+#include <JellyfinQt/loader/http/trickplay.h>
 
 namespace Jellyfin {
 namespace Loader {
diff --git a/core/src/loader/http/tvshows.cpp b/core/src/loader/http/tvshows.cpp
index dea8b1e..059b915 100644
--- a/core/src/loader/http/tvshows.cpp
+++ b/core/src/loader/http/tvshows.cpp
@@ -90,7 +90,7 @@ QUrlQuery GetEpisodesLoader::query(const GetEpisodesParams &params) const {
 		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<ItemSortBy>(params.sortBy()));
 	}
 	
 	return result;
@@ -195,8 +195,8 @@ QUrlQuery GetNextUpLoader::query(const GetNextUpParams &params) const {
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
 	}
-	if (!params.enableImgesNull()) {
-		result.addQueryItem("enableImges", Support::toString<std::optional<bool>>(params.enableImges()));
+	if (!params.enableImagesNull()) {
+		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
 	if (!params.imageTypeLimitNull()) {
 		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
@@ -207,12 +207,21 @@ QUrlQuery GetNextUpLoader::query(const GetNextUpParams &params) const {
 	if (!params.enableUserDataNull()) {
 		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
 	}
+	if (!params.nextUpDateCutoffNull()) {
+		result.addQueryItem("nextUpDateCutoff", Support::toString<QDateTime>(params.nextUpDateCutoff()));
+	}
 	if (!params.enableTotalRecordCountNull()) {
 		result.addQueryItem("enableTotalRecordCount", Support::toString<std::optional<bool>>(params.enableTotalRecordCount()));
 	}
 	if (!params.disableFirstEpisodeNull()) {
 		result.addQueryItem("disableFirstEpisode", Support::toString<std::optional<bool>>(params.disableFirstEpisode()));
 	}
+	if (!params.enableResumableNull()) {
+		result.addQueryItem("enableResumable", Support::toString<std::optional<bool>>(params.enableResumable()));
+	}
+	if (!params.enableRewatchingNull()) {
+		result.addQueryItem("enableRewatching", Support::toString<std::optional<bool>>(params.enableRewatching()));
+	}
 	
 	return result;
 }
@@ -257,8 +266,8 @@ QUrlQuery GetUpcomingEpisodesLoader::query(const GetUpcomingEpisodesParams &para
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
 	}
-	if (!params.enableImgesNull()) {
-		result.addQueryItem("enableImges", Support::toString<std::optional<bool>>(params.enableImges()));
+	if (!params.enableImagesNull()) {
+		result.addQueryItem("enableImages", Support::toString<std::optional<bool>>(params.enableImages()));
 	}
 	if (!params.imageTypeLimitNull()) {
 		result.addQueryItem("imageTypeLimit", Support::toString<std::optional<qint32>>(params.imageTypeLimit()));
diff --git a/core/src/loader/http/user.cpp b/core/src/loader/http/user.cpp
index 1bef710..78ed066 100644
--- a/core/src/loader/http/user.cpp
+++ b/core/src/loader/http/user.cpp
@@ -70,6 +70,38 @@ QNetworkAccessManager::Operation GetUsersLoader::operation() const {
 
 }
 
+UpdateUserLoader::UpdateUserLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UpdateUserParams>(apiClient) {}
+
+QString UpdateUserLoader::path(const UpdateUserParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Users");
+}
+
+QUrlQuery UpdateUserLoader::query(const UpdateUserParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray UpdateUserLoader::body(const UpdateUserParams &params) const {
+	return Support::toString<QSharedPointer<UserDto>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdateUserLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 GetUserByIdLoader::GetUserByIdLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<UserDto, GetUserByIdParams>(apiClient) {}
 
@@ -128,155 +160,6 @@ QNetworkAccessManager::Operation DeleteUserLoader::operation() const {
 
 }
 
-UpdateUserLoader::UpdateUserLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateUserParams>(apiClient) {}
-
-QString UpdateUserLoader::path(const UpdateUserParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) ;
-}
-
-QUrlQuery UpdateUserLoader::query(const UpdateUserParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateUserLoader::body(const UpdateUserParams &params) const {
-	return Support::toString<QSharedPointer<UserDto>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateUserLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-AuthenticateUserLoader::AuthenticateUserLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<AuthenticationResult, AuthenticateUserParams>(apiClient) {}
-
-QString AuthenticateUserLoader::path(const AuthenticateUserParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Authenticate");
-}
-
-QUrlQuery AuthenticateUserLoader::query(const AuthenticateUserParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-	result.addQueryItem("pw", Support::toString<QString>(params.pw()));
-
-	// Optional parameters
-	if (!params.passwordNull()) {
-		result.addQueryItem("password", Support::toString<QString>(params.password()));
-	}
-	
-	return result;
-}
-
-QByteArray AuthenticateUserLoader::body(const AuthenticateUserParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation AuthenticateUserLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-UpdateUserConfigurationLoader::UpdateUserConfigurationLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateUserConfigurationParams>(apiClient) {}
-
-QString UpdateUserConfigurationLoader::path(const UpdateUserConfigurationParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Configuration");
-}
-
-QUrlQuery UpdateUserConfigurationLoader::query(const UpdateUserConfigurationParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateUserConfigurationLoader::body(const UpdateUserConfigurationParams &params) const {
-	return Support::toString<QSharedPointer<UserConfiguration>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateUserConfigurationLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-UpdateUserEasyPasswordLoader::UpdateUserEasyPasswordLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateUserEasyPasswordParams>(apiClient) {}
-
-QString UpdateUserEasyPasswordLoader::path(const UpdateUserEasyPasswordParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/EasyPassword");
-}
-
-QUrlQuery UpdateUserEasyPasswordLoader::query(const UpdateUserEasyPasswordParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateUserEasyPasswordLoader::body(const UpdateUserEasyPasswordParams &params) const {
-	return Support::toString<QSharedPointer<UpdateUserEasyPassword>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateUserEasyPasswordLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-UpdateUserPasswordLoader::UpdateUserPasswordLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<void, UpdateUserPasswordParams>(apiClient) {}
-
-QString UpdateUserPasswordLoader::path(const UpdateUserPasswordParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Password");
-}
-
-QUrlQuery UpdateUserPasswordLoader::query(const UpdateUserPasswordParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UpdateUserPasswordLoader::body(const UpdateUserPasswordParams &params) const {
-	return Support::toString<QSharedPointer<UpdateUserPassword>>(params.body()).toUtf8();
-}
-
-QNetworkAccessManager::Operation UpdateUserPasswordLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
 UpdateUserPolicyLoader::UpdateUserPolicyLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<void, UpdateUserPolicyParams>(apiClient) {}
 
@@ -364,6 +247,38 @@ QNetworkAccessManager::Operation AuthenticateWithQuickConnectLoader::operation()
 
 }
 
+UpdateUserConfigurationLoader::UpdateUserConfigurationLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UpdateUserConfigurationParams>(apiClient) {}
+
+QString UpdateUserConfigurationLoader::path(const UpdateUserConfigurationParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Users/Configuration");
+}
+
+QUrlQuery UpdateUserConfigurationLoader::query(const UpdateUserConfigurationParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray UpdateUserConfigurationLoader::body(const UpdateUserConfigurationParams &params) const {
+	return Support::toString<QSharedPointer<UserConfiguration>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdateUserConfigurationLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 ForgotPasswordLoader::ForgotPasswordLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<ForgotPasswordResult, ForgotPasswordParams>(apiClient) {}
 
@@ -413,7 +328,7 @@ QUrlQuery ForgotPasswordPinLoader::query(const ForgotPasswordPinParams &params)
 }
 
 QByteArray ForgotPasswordPinLoader::body(const ForgotPasswordPinParams &params) const {
-	return Support::toString<QString>(params.body()).toUtf8();
+	return Support::toString<QSharedPointer<ForgotPasswordPinDto>>(params.body()).toUtf8();
 }
 
 QNetworkAccessManager::Operation ForgotPasswordPinLoader::operation() const {
@@ -480,6 +395,38 @@ QNetworkAccessManager::Operation CreateUserByNameLoader::operation() const {
 
 }
 
+UpdateUserPasswordLoader::UpdateUserPasswordLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<void, UpdateUserPasswordParams>(apiClient) {}
+
+QString UpdateUserPasswordLoader::path(const UpdateUserPasswordParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/Users/Password");
+}
+
+QUrlQuery UpdateUserPasswordLoader::query(const UpdateUserPasswordParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray UpdateUserPasswordLoader::body(const UpdateUserPasswordParams &params) const {
+	return Support::toString<QSharedPointer<UpdateUserPassword>>(params.body()).toUtf8();
+}
+
+QNetworkAccessManager::Operation UpdateUserPasswordLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 GetPublicUsersLoader::GetPublicUsersLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<QList<UserDto>, GetPublicUsersParams>(apiClient) {}
 
diff --git a/core/src/loader/http/userlibrary.cpp b/core/src/loader/http/userlibrary.cpp
index 4d59470..27e38df 100644
--- a/core/src/loader/http/userlibrary.cpp
+++ b/core/src/loader/http/userlibrary.cpp
@@ -35,71 +35,13 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-MarkFavoriteItemLoader::MarkFavoriteItemLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<UserItemDataDto, MarkFavoriteItemParams>(apiClient) {}
-
-QString MarkFavoriteItemLoader::path(const MarkFavoriteItemParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/FavoriteItems/") + Support::toString< QString>(params.itemId()) ;
-}
-
-QUrlQuery MarkFavoriteItemLoader::query(const MarkFavoriteItemParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray MarkFavoriteItemLoader::body(const MarkFavoriteItemParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation MarkFavoriteItemLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
-UnmarkFavoriteItemLoader::UnmarkFavoriteItemLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<UserItemDataDto, UnmarkFavoriteItemParams>(apiClient) {}
-
-QString UnmarkFavoriteItemLoader::path(const UnmarkFavoriteItemParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/FavoriteItems/") + Support::toString< QString>(params.itemId()) ;
-}
-
-QUrlQuery UnmarkFavoriteItemLoader::query(const UnmarkFavoriteItemParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray UnmarkFavoriteItemLoader::body(const UnmarkFavoriteItemParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation UnmarkFavoriteItemLoader::operation() const {
-	// HTTP method Delete
-	return QNetworkAccessManager::DeleteOperation;
-
-}
-
 GetItemLoader::GetItemLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<BaseItemDto, GetItemParams>(apiClient) {}
 
 QString GetItemLoader::path(const GetItemParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) ;
+	return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) ;
 }
 
 QUrlQuery GetItemLoader::query(const GetItemParams &params) const {
@@ -108,6 +50,9 @@ QUrlQuery GetItemLoader::query(const GetItemParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -128,7 +73,7 @@ GetIntrosLoader::GetIntrosLoader(ApiClient *apiClient)
 QString GetIntrosLoader::path(const GetIntrosParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Intros");
+	return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Intros");
 }
 
 QUrlQuery GetIntrosLoader::query(const GetIntrosParams &params) const {
@@ -137,6 +82,9 @@ QUrlQuery GetIntrosLoader::query(const GetIntrosParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -157,7 +105,7 @@ GetLocalTrailersLoader::GetLocalTrailersLoader(ApiClient *apiClient)
 QString GetLocalTrailersLoader::path(const GetLocalTrailersParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/LocalTrailers");
+	return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/LocalTrailers");
 }
 
 QUrlQuery GetLocalTrailersLoader::query(const GetLocalTrailersParams &params) const {
@@ -166,6 +114,9 @@ QUrlQuery GetLocalTrailersLoader::query(const GetLocalTrailersParams &params) co
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -180,74 +131,13 @@ QNetworkAccessManager::Operation GetLocalTrailersLoader::operation() const {
 
 }
 
-DeleteUserItemRatingLoader::DeleteUserItemRatingLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<UserItemDataDto, DeleteUserItemRatingParams>(apiClient) {}
-
-QString DeleteUserItemRatingLoader::path(const DeleteUserItemRatingParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Rating");
-}
-
-QUrlQuery DeleteUserItemRatingLoader::query(const DeleteUserItemRatingParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray DeleteUserItemRatingLoader::body(const DeleteUserItemRatingParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation DeleteUserItemRatingLoader::operation() const {
-	// HTTP method Delete
-	return QNetworkAccessManager::DeleteOperation;
-
-}
-
-UpdateUserItemRatingLoader::UpdateUserItemRatingLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateUserItemRatingParams>(apiClient) {}
-
-QString UpdateUserItemRatingLoader::path(const UpdateUserItemRatingParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Rating");
-}
-
-QUrlQuery UpdateUserItemRatingLoader::query(const UpdateUserItemRatingParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	if (!params.likesNull()) {
-		result.addQueryItem("likes", Support::toString<std::optional<bool>>(params.likes()));
-	}
-	
-	return result;
-}
-
-QByteArray UpdateUserItemRatingLoader::body(const UpdateUserItemRatingParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation UpdateUserItemRatingLoader::operation() const {
-	// HTTP method Post
-	return QNetworkAccessManager::PostOperation;
-
-}
-
 GetSpecialFeaturesLoader::GetSpecialFeaturesLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<QList<BaseItemDto>, GetSpecialFeaturesParams>(apiClient) {}
 
 QString GetSpecialFeaturesLoader::path(const GetSpecialFeaturesParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/SpecialFeatures");
+	return QStringLiteral("/Items/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/SpecialFeatures");
 }
 
 QUrlQuery GetSpecialFeaturesLoader::query(const GetSpecialFeaturesParams &params) const {
@@ -256,6 +146,9 @@ QUrlQuery GetSpecialFeaturesLoader::query(const GetSpecialFeaturesParams &params
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -276,7 +169,7 @@ GetLatestMediaLoader::GetLatestMediaLoader(ApiClient *apiClient)
 QString GetLatestMediaLoader::path(const GetLatestMediaParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/Latest");
+	return QStringLiteral("/Items/Latest");
 }
 
 QUrlQuery GetLatestMediaLoader::query(const GetLatestMediaParams &params) const {
@@ -285,6 +178,9 @@ QUrlQuery GetLatestMediaLoader::query(const GetLatestMediaParams &params) const
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
 	}
@@ -292,7 +188,7 @@ QUrlQuery GetLatestMediaLoader::query(const GetLatestMediaParams &params) const
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.isPlayedNull()) {
 		result.addQueryItem("isPlayed", Support::toString<std::optional<bool>>(params.isPlayed()));
@@ -335,7 +231,7 @@ GetRootFolderLoader::GetRootFolderLoader(ApiClient *apiClient)
 QString GetRootFolderLoader::path(const GetRootFolderParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Items/Root");
+	return QStringLiteral("/Items/Root");
 }
 
 QUrlQuery GetRootFolderLoader::query(const GetRootFolderParams &params) const {
@@ -344,6 +240,9 @@ QUrlQuery GetRootFolderLoader::query(const GetRootFolderParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	
 	return result;
 }
@@ -358,6 +257,137 @@ QNetworkAccessManager::Operation GetRootFolderLoader::operation() const {
 
 }
 
+MarkFavoriteItemLoader::MarkFavoriteItemLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, MarkFavoriteItemParams>(apiClient) {}
+
+QString MarkFavoriteItemLoader::path(const MarkFavoriteItemParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserFavoriteItems/") + Support::toString< QString>(params.itemId()) ;
+}
+
+QUrlQuery MarkFavoriteItemLoader::query(const MarkFavoriteItemParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray MarkFavoriteItemLoader::body(const MarkFavoriteItemParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation MarkFavoriteItemLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
+UnmarkFavoriteItemLoader::UnmarkFavoriteItemLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, UnmarkFavoriteItemParams>(apiClient) {}
+
+QString UnmarkFavoriteItemLoader::path(const UnmarkFavoriteItemParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserFavoriteItems/") + Support::toString< QString>(params.itemId()) ;
+}
+
+QUrlQuery UnmarkFavoriteItemLoader::query(const UnmarkFavoriteItemParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray UnmarkFavoriteItemLoader::body(const UnmarkFavoriteItemParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation UnmarkFavoriteItemLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
+DeleteUserItemRatingLoader::DeleteUserItemRatingLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, DeleteUserItemRatingParams>(apiClient) {}
+
+QString DeleteUserItemRatingLoader::path(const DeleteUserItemRatingParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Rating");
+}
+
+QUrlQuery DeleteUserItemRatingLoader::query(const DeleteUserItemRatingParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray DeleteUserItemRatingLoader::body(const DeleteUserItemRatingParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation DeleteUserItemRatingLoader::operation() const {
+	// HTTP method Delete
+	return QNetworkAccessManager::DeleteOperation;
+
+}
+
+UpdateUserItemRatingLoader::UpdateUserItemRatingLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<UserItemDataDto, UpdateUserItemRatingParams>(apiClient) {}
+
+QString UpdateUserItemRatingLoader::path(const UpdateUserItemRatingParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserItems/") + Support::toString< QString>(params.itemId()) + QStringLiteral("/Rating");
+}
+
+QUrlQuery UpdateUserItemRatingLoader::query(const UpdateUserItemRatingParams &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.likesNull()) {
+		result.addQueryItem("likes", Support::toString<std::optional<bool>>(params.likes()));
+	}
+	
+	return result;
+}
+
+QByteArray UpdateUserItemRatingLoader::body(const UpdateUserItemRatingParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation UpdateUserItemRatingLoader::operation() const {
+	// HTTP method Post
+	return QNetworkAccessManager::PostOperation;
+
+}
+
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/userviews.cpp b/core/src/loader/http/userviews.cpp
index 39436bd..3d439a1 100644
--- a/core/src/loader/http/userviews.cpp
+++ b/core/src/loader/http/userviews.cpp
@@ -35,42 +35,13 @@ namespace HTTP {
 
 using namespace Jellyfin::DTO;
 
-GetGroupingOptionsLoader::GetGroupingOptionsLoader(ApiClient *apiClient)
-	: Jellyfin::Support::HttpLoader<QList<SpecialViewOptionDto>, GetGroupingOptionsParams>(apiClient) {}
-
-QString GetGroupingOptionsLoader::path(const GetGroupingOptionsParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/GroupingOptions");
-}
-
-QUrlQuery GetGroupingOptionsLoader::query(const GetGroupingOptionsParams &params) const {
-	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
-
-	QUrlQuery result;
-
-	// Optional parameters
-	
-	return result;
-}
-
-QByteArray GetGroupingOptionsLoader::body(const GetGroupingOptionsParams &params) const {
-	return QByteArray();
-}
-
-QNetworkAccessManager::Operation GetGroupingOptionsLoader::operation() const {
-	// HTTP method Get
-	return QNetworkAccessManager::GetOperation;
-
-}
-
 GetUserViewsLoader::GetUserViewsLoader(ApiClient *apiClient)
 	: Jellyfin::Support::HttpLoader<BaseItemDtoQueryResult, GetUserViewsParams>(apiClient) {}
 
 QString GetUserViewsLoader::path(const GetUserViewsParams &params) const {
 	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
 	
-	return QStringLiteral("/Users/") + Support::toString< QString>(params.userId()) + QStringLiteral("/Views");
+	return QStringLiteral("/UserViews");
 }
 
 QUrlQuery GetUserViewsLoader::query(const GetUserViewsParams &params) const {
@@ -79,11 +50,14 @@ QUrlQuery GetUserViewsLoader::query(const GetUserViewsParams &params) const {
 	QUrlQuery result;
 
 	// Optional parameters
+	if (!params.userIdNull()) {
+		result.addQueryItem("userId", Support::toString<QString>(params.userId()));
+	}
 	if (!params.includeExternalContentNull()) {
 		result.addQueryItem("includeExternalContent", Support::toString<std::optional<bool>>(params.includeExternalContent()));
 	}
 	if (!params.presetViewsNull()) {
-		result.addQueryItem("presetViews", Support::toString<QStringList>(params.presetViews()));
+		result.addQueryItem("presetViews", Support::toString<QList<CollectionType>>(params.presetViews()));
 	}
 	if (!params.includeHiddenNull()) {
 		result.addQueryItem("includeHidden", Support::toString<std::optional<bool>>(params.includeHidden()));
@@ -102,6 +76,38 @@ QNetworkAccessManager::Operation GetUserViewsLoader::operation() const {
 
 }
 
+GetGroupingOptionsLoader::GetGroupingOptionsLoader(ApiClient *apiClient)
+	: Jellyfin::Support::HttpLoader<QList<SpecialViewOptionDto>, GetGroupingOptionsParams>(apiClient) {}
+
+QString GetGroupingOptionsLoader::path(const GetGroupingOptionsParams &params) const {
+	Q_UNUSED(params) // Might be overzealous, but I don't like theses kind of warnings
+	
+	return QStringLiteral("/UserViews/GroupingOptions");
+}
+
+QUrlQuery GetGroupingOptionsLoader::query(const GetGroupingOptionsParams &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()));
+	}
+	
+	return result;
+}
+
+QByteArray GetGroupingOptionsLoader::body(const GetGroupingOptionsParams &params) const {
+	return QByteArray();
+}
+
+QNetworkAccessManager::Operation GetGroupingOptionsLoader::operation() const {
+	// HTTP method Get
+	return QNetworkAccessManager::GetOperation;
+
+}
+
 
 } // NS HTTP
 } // NS Loader
diff --git a/core/src/loader/http/years.cpp b/core/src/loader/http/years.cpp
index 4f6fc5f..785851f 100644
--- a/core/src/loader/http/years.cpp
+++ b/core/src/loader/http/years.cpp
@@ -57,7 +57,7 @@ QUrlQuery GetYearsLoader::query(const GetYearsParams &params) const {
 		result.addQueryItem("limit", Support::toString<std::optional<qint32>>(params.limit()));
 	}
 	if (!params.sortOrderNull()) {
-		result.addQueryItem("sortOrder", Support::toString<QString>(params.sortOrder()));
+		result.addQueryItem("sortOrder", Support::toString<QList<SortOrder>>(params.sortOrder()));
 	}
 	if (!params.parentIdNull()) {
 		result.addQueryItem("parentId", Support::toString<QString>(params.parentId()));
@@ -66,16 +66,16 @@ QUrlQuery GetYearsLoader::query(const GetYearsParams &params) const {
 		result.addQueryItem("fields", Support::toString<QList<ItemFields>>(params.fields()));
 	}
 	if (!params.excludeItemTypesNull()) {
-		result.addQueryItem("excludeItemTypes", Support::toString<QStringList>(params.excludeItemTypes()));
+		result.addQueryItem("excludeItemTypes", Support::toString<QList<BaseItemKind>>(params.excludeItemTypes()));
 	}
 	if (!params.includeItemTypesNull()) {
-		result.addQueryItem("includeItemTypes", Support::toString<QStringList>(params.includeItemTypes()));
+		result.addQueryItem("includeItemTypes", Support::toString<QList<BaseItemKind>>(params.includeItemTypes()));
 	}
 	if (!params.mediaTypesNull()) {
-		result.addQueryItem("mediaTypes", Support::toString<QStringList>(params.mediaTypes()));
+		result.addQueryItem("mediaTypes", Support::toString<QList<MediaType>>(params.mediaTypes()));
 	}
 	if (!params.sortByNull()) {
-		result.addQueryItem("sortBy", Support::toString<QString>(params.sortBy()));
+		result.addQueryItem("sortBy", Support::toString<QList<ItemSortBy>>(params.sortBy()));
 	}
 	if (!params.enableUserDataNull()) {
 		result.addQueryItem("enableUserData", Support::toString<std::optional<bool>>(params.enableUserData()));
diff --git a/core/src/loader/requesttypes.cpp b/core/src/loader/requesttypes.cpp
index 2c4b771..5cb60b7 100644
--- a/core/src/loader/requesttypes.cpp
+++ b/core/src/loader/requesttypes.cpp
@@ -34,7 +34,58 @@ namespace Loader {
 
 using namespace Jellyfin::DTO;
 
-// ActivateParams
+// AddItemToPlaylistParams
+
+const QString &AddItemToPlaylistParams::playlistId() const {
+	return m_playlistId;
+}
+
+void AddItemToPlaylistParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
+const QStringList &AddItemToPlaylistParams::ids() const {
+	return m_ids;
+}
+
+void AddItemToPlaylistParams::setIds(QStringList newIds)  {
+	m_ids = newIds;
+}
+
+bool AddItemToPlaylistParams::idsNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_ids.size() == 0;
+}
+
+void AddItemToPlaylistParams::setIdsNull() {
+	m_ids.clear();
+}
+
+
+const QString &AddItemToPlaylistParams::userId() const {
+	return m_userId;
+}
+
+void AddItemToPlaylistParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool AddItemToPlaylistParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void AddItemToPlaylistParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -170,61 +221,6 @@ void AddToCollectionParams::setIds(QStringList newIds) {
 
 
 
-// AddToPlaylistParams
-
-const QString &AddToPlaylistParams::playlistId() const {
-	return m_playlistId;
-}
-
-void AddToPlaylistParams::setPlaylistId(QString newPlaylistId) {
-	m_playlistId = newPlaylistId;
-}
-
-
-const QStringList &AddToPlaylistParams::ids() const {
-	return m_ids;
-}
-
-void AddToPlaylistParams::setIds(QStringList newIds)  {
-	m_ids = newIds;
-}
-
-bool AddToPlaylistParams::idsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_ids.size() == 0;
-}
-
-void AddToPlaylistParams::setIdsNull() {
-	m_ids.clear();
-}
-
-
-const QString &AddToPlaylistParams::userId() const {
-	return m_userId;
-}
-
-void AddToPlaylistParams::setUserId(QString newUserId)  {
-	m_userId = newUserId;
-}
-
-bool AddToPlaylistParams::userIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_userId.isNull();
-}
-
-void AddToPlaylistParams::setUserIdNull() {
-	m_userId.clear();
-}
-
-
-
-
 // AddTunerHostParams
 
 const QSharedPointer<TunerHostInfo> &AddTunerHostParams::body() const {
@@ -262,11 +258,11 @@ void AddUserToSessionParams::setUserId(QString newUserId) {
 
 // AddVirtualFolderParams
 
-const QString &AddVirtualFolderParams::collectionType() const {
+const CollectionTypeOptions &AddVirtualFolderParams::collectionType() const {
 	return m_collectionType;
 }
 
-void AddVirtualFolderParams::setCollectionType(QString newCollectionType)  {
+void AddVirtualFolderParams::setCollectionType(CollectionTypeOptions newCollectionType)  {
 	m_collectionType = newCollectionType;
 }
 
@@ -275,11 +271,11 @@ bool AddVirtualFolderParams::collectionTypeNull() const {
 	// Type Nullable: true
 	
 
-	return m_collectionType.isNull();
+	return m_collectionType== CollectionTypeOptions::EnumNotSet;
 }
 
 void AddVirtualFolderParams::setCollectionTypeNull() {
-	m_collectionType.clear();
+	m_collectionType= CollectionTypeOptions::EnumNotSet;
 }
 
 
@@ -400,49 +396,6 @@ void ApplySearchCriteriaParams::setBody(QSharedPointer<RemoteSearchResult> newBo
 
 
 
-// AuthenticateUserParams
-
-const QString &AuthenticateUserParams::userId() const {
-	return m_userId;
-}
-
-void AuthenticateUserParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const QString &AuthenticateUserParams::pw() const {
-	return m_pw;
-}
-
-void AuthenticateUserParams::setPw(QString newPw) {
-	m_pw = newPw;
-}
-
-
-const QString &AuthenticateUserParams::password() const {
-	return m_password;
-}
-
-void AuthenticateUserParams::setPassword(QString newPassword)  {
-	m_password = newPassword;
-}
-
-bool AuthenticateUserParams::passwordNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_password.isNull();
-}
-
-void AuthenticateUserParams::setPasswordNull() {
-	m_password.clear();
-}
-
-
-
-
 // AuthenticateUserByNameParams
 
 const QSharedPointer<AuthenticateUserByName> &AuthenticateUserByNameParams::body() const {
@@ -469,39 +422,35 @@ void AuthenticateWithQuickConnectParams::setBody(QSharedPointer<QuickConnectDto>
 
 
 
-// AuthorizeParams
+// AuthorizeQuickConnectParams
 
-const QString &AuthorizeParams::code() const {
+const QString &AuthorizeQuickConnectParams::code() const {
 	return m_code;
 }
 
-void AuthorizeParams::setCode(QString newCode) {
+void AuthorizeQuickConnectParams::setCode(QString newCode) {
 	m_code = newCode;
 }
 
 
-
-
-// AvailableParams
-
-const QuickConnectState &AvailableParams::status() const {
-	return m_status;
+const QString &AuthorizeQuickConnectParams::userId() const {
+	return m_userId;
 }
 
-void AvailableParams::setStatus(QuickConnectState newStatus)  {
-	m_status = newStatus;
+void AuthorizeQuickConnectParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
 }
 
-bool AvailableParams::statusNull() const {
+bool AuthorizeQuickConnectParams::userIdNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
 
-	return m_status== QuickConnectState::EnumNotSet;
+	return m_userId.isNull();
 }
 
-void AvailableParams::setStatusNull() {
-	m_status= QuickConnectState::EnumNotSet;
+void AuthorizeQuickConnectParams::setUserIdNull() {
+	m_userId.clear();
 }
 
 
@@ -563,107 +512,6 @@ void CloseLiveStreamParams::setLiveStreamId(QString newLiveStreamId) {
 
 
 
-// ConnectParams
-
-const QString &ConnectParams::secret() const {
-	return m_secret;
-}
-
-void ConnectParams::setSecret(QString newSecret) {
-	m_secret = newSecret;
-}
-
-
-
-
-// CreateAdminNotificationParams
-
-const QString &CreateAdminNotificationParams::description() const {
-	return m_description;
-}
-
-void CreateAdminNotificationParams::setDescription(QString newDescription)  {
-	m_description = newDescription;
-}
-
-bool CreateAdminNotificationParams::descriptionNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_description.isNull();
-}
-
-void CreateAdminNotificationParams::setDescriptionNull() {
-	m_description.clear();
-}
-
-
-const NotificationLevel &CreateAdminNotificationParams::level() const {
-	return m_level;
-}
-
-void CreateAdminNotificationParams::setLevel(NotificationLevel newLevel)  {
-	m_level = newLevel;
-}
-
-bool CreateAdminNotificationParams::levelNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_level== NotificationLevel::EnumNotSet;
-}
-
-void CreateAdminNotificationParams::setLevelNull() {
-	m_level= NotificationLevel::EnumNotSet;
-}
-
-
-const QString &CreateAdminNotificationParams::name() const {
-	return m_name;
-}
-
-void CreateAdminNotificationParams::setName(QString newName)  {
-	m_name = newName;
-}
-
-bool CreateAdminNotificationParams::nameNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_name.isNull();
-}
-
-void CreateAdminNotificationParams::setNameNull() {
-	m_name.clear();
-}
-
-
-const QString &CreateAdminNotificationParams::url() const {
-	return m_url;
-}
-
-void CreateAdminNotificationParams::setUrl(QString newUrl)  {
-	m_url = newUrl;
-}
-
-bool CreateAdminNotificationParams::urlNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_url.isNull();
-}
-
-void CreateAdminNotificationParams::setUrlNull() {
-	m_url.clear();
-}
-
-
-
-
 // CreateCollectionParams
 
 const QStringList &CreateCollectionParams::ids() const {
@@ -788,11 +636,11 @@ void CreatePlaylistParams::setIdsNull() {
 }
 
 
-const QString &CreatePlaylistParams::mediaType() const {
+const MediaType &CreatePlaylistParams::mediaType() const {
 	return m_mediaType;
 }
 
-void CreatePlaylistParams::setMediaType(QString newMediaType)  {
+void CreatePlaylistParams::setMediaType(MediaType newMediaType)  {
 	m_mediaType = newMediaType;
 }
 
@@ -801,11 +649,11 @@ bool CreatePlaylistParams::mediaTypeNull() const {
 	// Type Nullable: true
 	
 
-	return m_mediaType.isNull();
+	return m_mediaType== MediaType::EnumNotSet;
 }
 
 void CreatePlaylistParams::setMediaTypeNull() {
-	m_mediaType.clear();
+	m_mediaType= MediaType::EnumNotSet;
 }
 
 
@@ -862,19 +710,6 @@ void CreatePlaylistParams::setBody(QSharedPointer<CreatePlaylistDto> newBody) {
 
 
 
-// CreateProfileParams
-
-const QSharedPointer<DeviceProfile> &CreateProfileParams::body() const {
-	return m_body;
-}
-
-void CreateProfileParams::setBody(QSharedPointer<DeviceProfile> newBody) {
-	m_body = newBody;
-}
-
-
-
-
 // CreateSeriesTimerParams
 
 const QSharedPointer<SeriesTimerInfoDto> &CreateSeriesTimerParams::body() const {
@@ -914,10 +749,6 @@ void CreateUserByNameParams::setBody(QSharedPointer<CreateUserByName> newBody) {
 
 
 
-// DeauthorizeParams
-
-
-
 // DeleteAlternateSourcesParams
 
 const QString &DeleteAlternateSourcesParams::itemId() const {
@@ -931,6 +762,10 @@ void DeleteAlternateSourcesParams::setItemId(QString newItemId) {
 
 
 
+// DeleteCustomSplashscreenParams
+
+
+
 // DeleteDeviceParams
 
 const QString &DeleteDeviceParams::jellyfinId() const {
@@ -1081,14 +916,14 @@ void DeleteListingProviderParams::setJellyfinIdNull() {
 
 
 
-// DeleteProfileParams
+// DeleteLyricsParams
 
-const QString &DeleteProfileParams::profileId() const {
-	return m_profileId;
+const QString &DeleteLyricsParams::itemId() const {
+	return m_itemId;
 }
 
-void DeleteProfileParams::setProfileId(QString newProfileId) {
-	m_profileId = newProfileId;
+void DeleteLyricsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
 }
 
 
@@ -1169,73 +1004,24 @@ void DeleteUserParams::setUserId(QString newUserId) {
 
 // DeleteUserImageParams
 
-const ImageType &DeleteUserImageParams::imageType() const {
-	return m_imageType;
-}
-
-void DeleteUserImageParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
 const QString &DeleteUserImageParams::userId() const {
 	return m_userId;
 }
 
-void DeleteUserImageParams::setUserId(QString newUserId) {
+void DeleteUserImageParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
-
-const qint32 &DeleteUserImageParams::index() const {
-	return m_index.value();
-}
-
-void DeleteUserImageParams::setIndex(qint32 newIndex)  {
-	m_index = newIndex;
-}
-
-bool DeleteUserImageParams::indexNull() const {
+bool DeleteUserImageParams::userIdNull() const {
 	// Nullable: true
-	// Type Nullable: false
+	// Type Nullable: true
 	
 
-	return !m_index.has_value();
+	return m_userId.isNull();
 }
 
-void DeleteUserImageParams::setIndexNull() {
-	m_index = std::nullopt;
-}
-
-
-
-
-// DeleteUserImageByIndexParams
-
-const ImageType &DeleteUserImageByIndexParams::imageType() const {
-	return m_imageType;
-}
-
-void DeleteUserImageByIndexParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
-const qint32 &DeleteUserImageByIndexParams::index() const {
-	return m_index;
-}
-
-void DeleteUserImageByIndexParams::setIndex(qint32 newIndex) {
-	m_index = newIndex;
-}
-
-
-const QString &DeleteUserImageByIndexParams::userId() const {
-	return m_userId;
-}
-
-void DeleteUserImageByIndexParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
+void DeleteUserImageParams::setUserIdNull() {
+	m_userId.clear();
 }
 
 
@@ -1256,10 +1042,22 @@ const QString &DeleteUserItemRatingParams::userId() const {
 	return m_userId;
 }
 
-void DeleteUserItemRatingParams::setUserId(QString newUserId) {
+void DeleteUserItemRatingParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool DeleteUserItemRatingParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void DeleteUserItemRatingParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -1274,11 +1072,11 @@ void DisablePluginParams::setPluginId(QString newPluginId) {
 }
 
 
-const QSharedPointer<Version> &DisablePluginParams::version() const {
+const QString &DisablePluginParams::version() const {
 	return m_version;
 }
 
-void DisablePluginParams::setVersion(QSharedPointer<Version> newVersion) {
+void DisablePluginParams::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
 
@@ -1364,11 +1162,11 @@ void DisplayContentParams::setItemName(QString newItemName) {
 }
 
 
-const QString &DisplayContentParams::itemType() const {
+const BaseItemKind &DisplayContentParams::itemType() const {
 	return m_itemType;
 }
 
-void DisplayContentParams::setItemType(QString newItemType) {
+void DisplayContentParams::setItemType(BaseItemKind newItemType) {
 	m_itemType = newItemType;
 }
 
@@ -1418,6 +1216,28 @@ void DownloadRemoteImageParams::setImageUrlNull() {
 
 
 
+// DownloadRemoteLyricsParams
+
+const QString &DownloadRemoteLyricsParams::itemId() const {
+	return m_itemId;
+}
+
+void DownloadRemoteLyricsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const QString &DownloadRemoteLyricsParams::lyricId() const {
+	return m_lyricId;
+}
+
+void DownloadRemoteLyricsParams::setLyricId(QString newLyricId) {
+	m_lyricId = newLyricId;
+}
+
+
+
+
 // DownloadRemoteSubtitlesParams
 
 const QString &DownloadRemoteSubtitlesParams::itemId() const {
@@ -1451,11 +1271,11 @@ void EnablePluginParams::setPluginId(QString newPluginId) {
 }
 
 
-const QSharedPointer<Version> &EnablePluginParams::version() const {
+const QString &EnablePluginParams::version() const {
 	return m_version;
 }
 
-void EnablePluginParams::setVersion(QSharedPointer<Version> newVersion) {
+void EnablePluginParams::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
 
@@ -1477,387 +1297,17 @@ void ForgotPasswordParams::setBody(QSharedPointer<ForgotPasswordDto> newBody) {
 
 // ForgotPasswordPinParams
 
-const QString &ForgotPasswordPinParams::body() const {
+const QSharedPointer<ForgotPasswordPinDto> &ForgotPasswordPinParams::body() const {
 	return m_body;
 }
 
-void ForgotPasswordPinParams::setBody(QString newBody) {
+void ForgotPasswordPinParams::setBody(QSharedPointer<ForgotPasswordPinDto> newBody) {
 	m_body = newBody;
 }
 
 
 
 
-// GetParams
-
-const QString &GetParams::searchTerm() const {
-	return m_searchTerm;
-}
-
-void GetParams::setSearchTerm(QString newSearchTerm) {
-	m_searchTerm = newSearchTerm;
-}
-
-
-const QStringList &GetParams::excludeItemTypes() const {
-	return m_excludeItemTypes;
-}
-
-void GetParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
-	m_excludeItemTypes = newExcludeItemTypes;
-}
-
-bool GetParams::excludeItemTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_excludeItemTypes.size() == 0;
-}
-
-void GetParams::setExcludeItemTypesNull() {
-	m_excludeItemTypes.clear();
-}
-
-
-const bool &GetParams::includeArtists() const {
-	return m_includeArtists.value();
-}
-
-void GetParams::setIncludeArtists(bool newIncludeArtists)  {
-	m_includeArtists = newIncludeArtists;
-}
-
-bool GetParams::includeArtistsNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_includeArtists.has_value();
-}
-
-void GetParams::setIncludeArtistsNull() {
-	m_includeArtists = std::nullopt;
-}
-
-
-const bool &GetParams::includeGenres() const {
-	return m_includeGenres.value();
-}
-
-void GetParams::setIncludeGenres(bool newIncludeGenres)  {
-	m_includeGenres = newIncludeGenres;
-}
-
-bool GetParams::includeGenresNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_includeGenres.has_value();
-}
-
-void GetParams::setIncludeGenresNull() {
-	m_includeGenres = std::nullopt;
-}
-
-
-const QStringList &GetParams::includeItemTypes() const {
-	return m_includeItemTypes;
-}
-
-void GetParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
-	m_includeItemTypes = newIncludeItemTypes;
-}
-
-bool GetParams::includeItemTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_includeItemTypes.size() == 0;
-}
-
-void GetParams::setIncludeItemTypesNull() {
-	m_includeItemTypes.clear();
-}
-
-
-const bool &GetParams::includeMedia() const {
-	return m_includeMedia.value();
-}
-
-void GetParams::setIncludeMedia(bool newIncludeMedia)  {
-	m_includeMedia = newIncludeMedia;
-}
-
-bool GetParams::includeMediaNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_includeMedia.has_value();
-}
-
-void GetParams::setIncludeMediaNull() {
-	m_includeMedia = std::nullopt;
-}
-
-
-const bool &GetParams::includePeople() const {
-	return m_includePeople.value();
-}
-
-void GetParams::setIncludePeople(bool newIncludePeople)  {
-	m_includePeople = newIncludePeople;
-}
-
-bool GetParams::includePeopleNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_includePeople.has_value();
-}
-
-void GetParams::setIncludePeopleNull() {
-	m_includePeople = std::nullopt;
-}
-
-
-const bool &GetParams::includeStudios() const {
-	return m_includeStudios.value();
-}
-
-void GetParams::setIncludeStudios(bool newIncludeStudios)  {
-	m_includeStudios = newIncludeStudios;
-}
-
-bool GetParams::includeStudiosNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_includeStudios.has_value();
-}
-
-void GetParams::setIncludeStudiosNull() {
-	m_includeStudios = std::nullopt;
-}
-
-
-const bool &GetParams::isKids() const {
-	return m_isKids.value();
-}
-
-void GetParams::setIsKids(bool newIsKids)  {
-	m_isKids = newIsKids;
-}
-
-bool GetParams::isKidsNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isKids.has_value();
-}
-
-void GetParams::setIsKidsNull() {
-	m_isKids = std::nullopt;
-}
-
-
-const bool &GetParams::isMovie() const {
-	return m_isMovie.value();
-}
-
-void GetParams::setIsMovie(bool newIsMovie)  {
-	m_isMovie = newIsMovie;
-}
-
-bool GetParams::isMovieNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isMovie.has_value();
-}
-
-void GetParams::setIsMovieNull() {
-	m_isMovie = std::nullopt;
-}
-
-
-const bool &GetParams::isNews() const {
-	return m_isNews.value();
-}
-
-void GetParams::setIsNews(bool newIsNews)  {
-	m_isNews = newIsNews;
-}
-
-bool GetParams::isNewsNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isNews.has_value();
-}
-
-void GetParams::setIsNewsNull() {
-	m_isNews = std::nullopt;
-}
-
-
-const bool &GetParams::isSeries() const {
-	return m_isSeries.value();
-}
-
-void GetParams::setIsSeries(bool newIsSeries)  {
-	m_isSeries = newIsSeries;
-}
-
-bool GetParams::isSeriesNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isSeries.has_value();
-}
-
-void GetParams::setIsSeriesNull() {
-	m_isSeries = std::nullopt;
-}
-
-
-const bool &GetParams::isSports() const {
-	return m_isSports.value();
-}
-
-void GetParams::setIsSports(bool newIsSports)  {
-	m_isSports = newIsSports;
-}
-
-bool GetParams::isSportsNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isSports.has_value();
-}
-
-void GetParams::setIsSportsNull() {
-	m_isSports = std::nullopt;
-}
-
-
-const qint32 &GetParams::limit() const {
-	return m_limit.value();
-}
-
-void GetParams::setLimit(qint32 newLimit)  {
-	m_limit = newLimit;
-}
-
-bool GetParams::limitNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_limit.has_value();
-}
-
-void GetParams::setLimitNull() {
-	m_limit = std::nullopt;
-}
-
-
-const QStringList &GetParams::mediaTypes() const {
-	return m_mediaTypes;
-}
-
-void GetParams::setMediaTypes(QStringList newMediaTypes)  {
-	m_mediaTypes = newMediaTypes;
-}
-
-bool GetParams::mediaTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_mediaTypes.size() == 0;
-}
-
-void GetParams::setMediaTypesNull() {
-	m_mediaTypes.clear();
-}
-
-
-const QString &GetParams::parentId() const {
-	return m_parentId;
-}
-
-void GetParams::setParentId(QString newParentId)  {
-	m_parentId = newParentId;
-}
-
-bool GetParams::parentIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_parentId.isNull();
-}
-
-void GetParams::setParentIdNull() {
-	m_parentId.clear();
-}
-
-
-const qint32 &GetParams::startIndex() const {
-	return m_startIndex.value();
-}
-
-void GetParams::setStartIndex(qint32 newStartIndex)  {
-	m_startIndex = newStartIndex;
-}
-
-bool GetParams::startIndexNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_startIndex.has_value();
-}
-
-void GetParams::setStartIndexNull() {
-	m_startIndex = std::nullopt;
-}
-
-
-const QString &GetParams::userId() const {
-	return m_userId;
-}
-
-void GetParams::setUserId(QString newUserId)  {
-	m_userId = newUserId;
-}
-
-bool GetParams::userIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_userId.isNull();
-}
-
-void GetParams::setUserIdNull() {
-	m_userId.clear();
-}
-
-
-
-
 // GetAdditionalPartParams
 
 const QString &GetAdditionalPartParams::itemId() const {
@@ -1924,7 +1374,7 @@ void GetAlbumArtistsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetAlbumArtistsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -1978,11 +1428,11 @@ void GetAlbumArtistsParams::setEnableUserDataNull() {
 }
 
 
-const QStringList &GetAlbumArtistsParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetAlbumArtistsParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetAlbumArtistsParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetAlbumArtistsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -2104,11 +1554,11 @@ void GetAlbumArtistsParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetAlbumArtistsParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetAlbumArtistsParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetAlbumArtistsParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetAlbumArtistsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -2167,11 +1617,11 @@ void GetAlbumArtistsParams::setLimitNull() {
 }
 
 
-const QStringList &GetAlbumArtistsParams::mediaTypes() const {
+const QList<MediaType> &GetAlbumArtistsParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetAlbumArtistsParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetAlbumArtistsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -2398,6 +1848,48 @@ void GetAlbumArtistsParams::setSearchTermNull() {
 }
 
 
+const QList<ItemSortBy> &GetAlbumArtistsParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetAlbumArtistsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetAlbumArtistsParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetAlbumArtistsParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetAlbumArtistsParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetAlbumArtistsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetAlbumArtistsParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetAlbumArtistsParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const qint32 &GetAlbumArtistsParams::startIndex() const {
 	return m_startIndex.value();
 }
@@ -2627,27 +2119,6 @@ void GetArtistImageParams::setName(QString newName) {
 }
 
 
-const bool &GetArtistImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetArtistImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetArtistImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetArtistImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetArtistImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -2690,24 +2161,45 @@ void GetArtistImageParams::setBlurNull() {
 }
 
 
-const bool &GetArtistImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetArtistImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetArtistImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetArtistImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetArtistImageParams::cropWhitespaceNull() const {
+bool GetArtistImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetArtistImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetArtistImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetArtistImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetArtistImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetArtistImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetArtistImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -2955,7 +2447,7 @@ void GetArtistsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetArtistsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -3009,11 +2501,11 @@ void GetArtistsParams::setEnableUserDataNull() {
 }
 
 
-const QStringList &GetArtistsParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetArtistsParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetArtistsParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetArtistsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -3135,11 +2627,11 @@ void GetArtistsParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetArtistsParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetArtistsParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetArtistsParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetArtistsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -3198,11 +2690,11 @@ void GetArtistsParams::setLimitNull() {
 }
 
 
-const QStringList &GetArtistsParams::mediaTypes() const {
+const QList<MediaType> &GetArtistsParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetArtistsParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetArtistsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -3429,6 +2921,48 @@ void GetArtistsParams::setSearchTermNull() {
 }
 
 
+const QList<ItemSortBy> &GetArtistsParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetArtistsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetArtistsParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetArtistsParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetArtistsParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetArtistsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetArtistsParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetArtistsParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const qint32 &GetArtistsParams::startIndex() const {
 	return m_startIndex.value();
 }
@@ -3914,6 +3448,27 @@ void GetAudioStreamParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetAudioStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetAudioStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetAudioStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetAudioStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetAudioStreamParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -4923,6 +4478,27 @@ void GetAudioStreamByContainerParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetAudioStreamByContainerParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetAudioStreamByContainerParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetAudioStreamByContainerParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetAudioStreamByContainerParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetAudioStreamByContainerParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -5827,11 +5403,11 @@ void GetChannelItemsParams::setLimitNull() {
 }
 
 
-const QString &GetChannelItemsParams::sortBy() const {
+const QList<ItemSortBy> &GetChannelItemsParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetChannelItemsParams::setSortBy(QString newSortBy)  {
+void GetChannelItemsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -5840,7 +5416,7 @@ bool GetChannelItemsParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetChannelItemsParams::setSortByNull() {
@@ -5848,11 +5424,11 @@ void GetChannelItemsParams::setSortByNull() {
 }
 
 
-const QString &GetChannelItemsParams::sortOrder() const {
+const QList<SortOrder> &GetChannelItemsParams::sortOrder() const {
 	return m_sortOrder;
 }
 
-void GetChannelItemsParams::setSortOrder(QString newSortOrder)  {
+void GetChannelItemsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
 	m_sortOrder = newSortOrder;
 }
 
@@ -5861,7 +5437,7 @@ bool GetChannelItemsParams::sortOrderNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetChannelItemsParams::setSortOrderNull() {
@@ -6095,105 +5671,6 @@ void GetConfigurationPagesParams::setEnableInMainMenuNull() {
 }
 
 
-const ConfigurationPageType &GetConfigurationPagesParams::pageType() const {
-	return m_pageType;
-}
-
-void GetConfigurationPagesParams::setPageType(ConfigurationPageType newPageType)  {
-	m_pageType = newPageType;
-}
-
-bool GetConfigurationPagesParams::pageTypeNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_pageType== ConfigurationPageType::EnumNotSet;
-}
-
-void GetConfigurationPagesParams::setPageTypeNull() {
-	m_pageType= ConfigurationPageType::EnumNotSet;
-}
-
-
-
-
-// GetConnectionManagerParams
-
-const QString &GetConnectionManagerParams::serverId() const {
-	return m_serverId;
-}
-
-void GetConnectionManagerParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetConnectionManager_2Params
-
-const QString &GetConnectionManager_2Params::serverId() const {
-	return m_serverId;
-}
-
-void GetConnectionManager_2Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetConnectionManager_3Params
-
-const QString &GetConnectionManager_3Params::serverId() const {
-	return m_serverId;
-}
-
-void GetConnectionManager_3Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetContentDirectoryParams
-
-const QString &GetContentDirectoryParams::serverId() const {
-	return m_serverId;
-}
-
-void GetContentDirectoryParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetContentDirectory_2Params
-
-const QString &GetContentDirectory_2Params::serverId() const {
-	return m_serverId;
-}
-
-void GetContentDirectory_2Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetContentDirectory_3Params
-
-const QString &GetContentDirectory_3Params::serverId() const {
-	return m_serverId;
-}
-
-void GetContentDirectory_3Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
 
 
 // GetCountriesParams
@@ -6258,10 +5735,6 @@ void GetDashboardConfigurationPageParams::setNameNull() {
 
 
 
-// GetDefaultProfileParams
-
-
-
 // GetDefaultTimerParams
 
 const QString &GetDefaultTimerParams::programId() const {
@@ -6287,32 +5760,6 @@ void GetDefaultTimerParams::setProgramIdNull() {
 
 
 
-// GetDescriptionXmlParams
-
-const QString &GetDescriptionXmlParams::serverId() const {
-	return m_serverId;
-}
-
-void GetDescriptionXmlParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetDescriptionXml_2Params
-
-const QString &GetDescriptionXml_2Params::serverId() const {
-	return m_serverId;
-}
-
-void GetDescriptionXml_2Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
 // GetDeviceInfoParams
 
 const QString &GetDeviceInfoParams::jellyfinId() const {
@@ -6341,27 +5788,6 @@ void GetDeviceOptionsParams::setJellyfinId(QString newJellyfinId) {
 
 // GetDevicesParams
 
-const bool &GetDevicesParams::supportsSync() const {
-	return m_supportsSync.value();
-}
-
-void GetDevicesParams::setSupportsSync(bool newSupportsSync)  {
-	m_supportsSync = newSupportsSync;
-}
-
-bool GetDevicesParams::supportsSyncNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_supportsSync.has_value();
-}
-
-void GetDevicesParams::setSupportsSyncNull() {
-	m_supportsSync = std::nullopt;
-}
-
-
 const QString &GetDevicesParams::userId() const {
 	return m_userId;
 }
@@ -6464,10 +5890,22 @@ const QString &GetDisplayPreferencesParams::userId() const {
 	return m_userId;
 }
 
-void GetDisplayPreferencesParams::setUserId(QString newUserId) {
+void GetDisplayPreferencesParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetDisplayPreferencesParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetDisplayPreferencesParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -6713,11 +6151,11 @@ void GetEpisodesParams::setSeasonIdNull() {
 }
 
 
-const QString &GetEpisodesParams::sortBy() const {
+const ItemSortBy &GetEpisodesParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetEpisodesParams::setSortBy(QString newSortBy)  {
+void GetEpisodesParams::setSortBy(ItemSortBy newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -6726,11 +6164,11 @@ bool GetEpisodesParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy== ItemSortBy::EnumNotSet;
 }
 
 void GetEpisodesParams::setSortByNull() {
-	m_sortBy.clear();
+	m_sortBy= ItemSortBy::EnumNotSet;
 }
 
 
@@ -6850,32 +6288,6 @@ void GetFileParams::setItemId(QString newItemId) {
 
 
 
-// GetGeneralImageParams
-
-const QString &GetGeneralImageParams::name() const {
-	return m_name;
-}
-
-void GetGeneralImageParams::setName(QString newName) {
-	m_name = newName;
-}
-
-
-const QString &GetGeneralImageParams::type() const {
-	return m_type;
-}
-
-void GetGeneralImageParams::setType(QString newType) {
-	m_type = newType;
-}
-
-
-
-
-// GetGeneralImagesParams
-
-
-
 // GetGenreParams
 
 const QString &GetGenreParams::genreName() const {
@@ -6930,27 +6342,6 @@ void GetGenreImageParams::setName(QString newName) {
 }
 
 
-const bool &GetGenreImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetGenreImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetGenreImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetGenreImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetGenreImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -6993,24 +6384,45 @@ void GetGenreImageParams::setBlurNull() {
 }
 
 
-const bool &GetGenreImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetGenreImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetGenreImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetGenreImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetGenreImageParams::cropWhitespaceNull() const {
+bool GetGenreImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetGenreImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetGenreImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetGenreImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetGenreImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetGenreImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetGenreImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -7276,27 +6688,6 @@ void GetGenreImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &GetGenreImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetGenreImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetGenreImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetGenreImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetGenreImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -7339,24 +6730,45 @@ void GetGenreImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &GetGenreImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetGenreImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetGenreImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetGenreImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetGenreImageByIndexParams::cropWhitespaceNull() const {
+bool GetGenreImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetGenreImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetGenreImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetGenreImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetGenreImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetGenreImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetGenreImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -7604,7 +7016,7 @@ void GetGenresParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetGenresParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -7637,11 +7049,11 @@ void GetGenresParams::setEnableTotalRecordCountNull() {
 }
 
 
-const QStringList &GetGenresParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetGenresParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetGenresParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetGenresParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -7700,11 +7112,11 @@ void GetGenresParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetGenresParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetGenresParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetGenresParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetGenresParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -7868,6 +7280,48 @@ void GetGenresParams::setSearchTermNull() {
 }
 
 
+const QList<ItemSortBy> &GetGenresParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetGenresParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetGenresParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetGenresParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetGenresParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetGenresParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetGenresParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetGenresParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const qint32 &GetGenresParams::startIndex() const {
 	return m_startIndex.value();
 }
@@ -7918,10 +7372,22 @@ const QString &GetGroupingOptionsParams::userId() const {
 	return m_userId;
 }
 
-void GetGroupingOptionsParams::setUserId(QString newUserId) {
+void GetGroupingOptionsParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetGroupingOptionsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetGroupingOptionsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -7967,6 +7433,24 @@ void GetHlsAudioSegmentParams::setSegmentId(qint32 newSegmentId) {
 }
 
 
+const qint64 &GetHlsAudioSegmentParams::actualSegmentLengthTicks() const {
+	return m_actualSegmentLengthTicks;
+}
+
+void GetHlsAudioSegmentParams::setActualSegmentLengthTicks(qint64 newActualSegmentLengthTicks) {
+	m_actualSegmentLengthTicks = newActualSegmentLengthTicks;
+}
+
+
+const qint64 &GetHlsAudioSegmentParams::runtimeTicks() const {
+	return m_runtimeTicks;
+}
+
+void GetHlsAudioSegmentParams::setRuntimeTicks(qint64 newRuntimeTicks) {
+	m_runtimeTicks = newRuntimeTicks;
+}
+
+
 const bool &GetHlsAudioSegmentParams::allowAudioStreamCopy() const {
 	return m_allowAudioStreamCopy.value();
 }
@@ -8261,6 +7745,27 @@ void GetHlsAudioSegmentParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetHlsAudioSegmentParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetHlsAudioSegmentParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetHlsAudioSegmentParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetHlsAudioSegmentParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetHlsAudioSegmentParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -9081,6 +8586,24 @@ void GetHlsVideoSegmentParams::setSegmentId(qint32 newSegmentId) {
 }
 
 
+const qint64 &GetHlsVideoSegmentParams::actualSegmentLengthTicks() const {
+	return m_actualSegmentLengthTicks;
+}
+
+void GetHlsVideoSegmentParams::setActualSegmentLengthTicks(qint64 newActualSegmentLengthTicks) {
+	m_actualSegmentLengthTicks = newActualSegmentLengthTicks;
+}
+
+
+const qint64 &GetHlsVideoSegmentParams::runtimeTicks() const {
+	return m_runtimeTicks;
+}
+
+void GetHlsVideoSegmentParams::setRuntimeTicks(qint64 newRuntimeTicks) {
+	m_runtimeTicks = newRuntimeTicks;
+}
+
+
 const bool &GetHlsVideoSegmentParams::allowAudioStreamCopy() const {
 	return m_allowAudioStreamCopy.value();
 }
@@ -9123,6 +8646,27 @@ void GetHlsVideoSegmentParams::setAllowVideoStreamCopyNull() {
 }
 
 
+const bool &GetHlsVideoSegmentParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void GetHlsVideoSegmentParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool GetHlsVideoSegmentParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void GetHlsVideoSegmentParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &GetHlsVideoSegmentParams::audioBitRate() const {
 	return m_audioBitRate.value();
 }
@@ -9375,6 +8919,27 @@ void GetHlsVideoSegmentParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetHlsVideoSegmentParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetHlsVideoSegmentParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetHlsVideoSegmentParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetHlsVideoSegmentParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetHlsVideoSegmentParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -9564,6 +9129,27 @@ void GetHlsVideoSegmentParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &GetHlsVideoSegmentParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetHlsVideoSegmentParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetHlsVideoSegmentParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetHlsVideoSegmentParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &GetHlsVideoSegmentParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -9606,6 +9192,27 @@ void GetHlsVideoSegmentParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &GetHlsVideoSegmentParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetHlsVideoSegmentParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetHlsVideoSegmentParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetHlsVideoSegmentParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &GetHlsVideoSegmentParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -10110,49 +9717,14 @@ void GetHlsVideoSegmentLegacyParams::setSegmentId(QString newSegmentId) {
 
 
 
-// GetIconParams
-
-const QString &GetIconParams::fileName() const {
-	return m_fileName;
-}
-
-void GetIconParams::setFileName(QString newFileName) {
-	m_fileName = newFileName;
-}
-
-
-
-
-// GetIconIdParams
-
-const QString &GetIconIdParams::fileName() const {
-	return m_fileName;
-}
-
-void GetIconIdParams::setFileName(QString newFileName) {
-	m_fileName = newFileName;
-}
-
-
-const QString &GetIconIdParams::serverId() const {
-	return m_serverId;
-}
-
-void GetIconIdParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
 // GetInstantMixFromAlbumParams
 
-const QString &GetInstantMixFromAlbumParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetInstantMixFromAlbumParams::itemId() const {
+	return m_itemId;
 }
 
-void GetInstantMixFromAlbumParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetInstantMixFromAlbumParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
 }
 
 
@@ -10307,12 +9879,12 @@ void GetInstantMixFromAlbumParams::setUserIdNull() {
 
 // GetInstantMixFromArtistsParams
 
-const QString &GetInstantMixFromArtistsParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetInstantMixFromArtistsParams::itemId() const {
+	return m_itemId;
 }
 
-void GetInstantMixFromArtistsParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetInstantMixFromArtistsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
 }
 
 
@@ -10465,17 +10037,177 @@ void GetInstantMixFromArtistsParams::setUserIdNull() {
 
 
 
-// GetInstantMixFromItemParams
+// GetInstantMixFromArtists2Params
 
-const QString &GetInstantMixFromItemParams::jellyfinId() const {
+const QString &GetInstantMixFromArtists2Params::jellyfinId() const {
 	return m_jellyfinId;
 }
 
-void GetInstantMixFromItemParams::setJellyfinId(QString newJellyfinId) {
+void GetInstantMixFromArtists2Params::setJellyfinId(QString newJellyfinId) {
 	m_jellyfinId = newJellyfinId;
 }
 
 
+const QList<ImageType> &GetInstantMixFromArtists2Params::enableImageTypes() const {
+	return m_enableImageTypes;
+}
+
+void GetInstantMixFromArtists2Params::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
+	m_enableImageTypes = newEnableImageTypes;
+}
+
+bool GetInstantMixFromArtists2Params::enableImageTypesNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_enableImageTypes.size() == 0;
+}
+
+void GetInstantMixFromArtists2Params::setEnableImageTypesNull() {
+	m_enableImageTypes.clear();
+}
+
+
+const bool &GetInstantMixFromArtists2Params::enableImages() const {
+	return m_enableImages.value();
+}
+
+void GetInstantMixFromArtists2Params::setEnableImages(bool newEnableImages)  {
+	m_enableImages = newEnableImages;
+}
+
+bool GetInstantMixFromArtists2Params::enableImagesNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_enableImages.has_value();
+}
+
+void GetInstantMixFromArtists2Params::setEnableImagesNull() {
+	m_enableImages = std::nullopt;
+}
+
+
+const bool &GetInstantMixFromArtists2Params::enableUserData() const {
+	return m_enableUserData.value();
+}
+
+void GetInstantMixFromArtists2Params::setEnableUserData(bool newEnableUserData)  {
+	m_enableUserData = newEnableUserData;
+}
+
+bool GetInstantMixFromArtists2Params::enableUserDataNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_enableUserData.has_value();
+}
+
+void GetInstantMixFromArtists2Params::setEnableUserDataNull() {
+	m_enableUserData = std::nullopt;
+}
+
+
+const QList<ItemFields> &GetInstantMixFromArtists2Params::fields() const {
+	return m_fields;
+}
+
+void GetInstantMixFromArtists2Params::setFields(QList<ItemFields> newFields)  {
+	m_fields = newFields;
+}
+
+bool GetInstantMixFromArtists2Params::fieldsNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_fields.size() == 0;
+}
+
+void GetInstantMixFromArtists2Params::setFieldsNull() {
+	m_fields.clear();
+}
+
+
+const qint32 &GetInstantMixFromArtists2Params::imageTypeLimit() const {
+	return m_imageTypeLimit.value();
+}
+
+void GetInstantMixFromArtists2Params::setImageTypeLimit(qint32 newImageTypeLimit)  {
+	m_imageTypeLimit = newImageTypeLimit;
+}
+
+bool GetInstantMixFromArtists2Params::imageTypeLimitNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_imageTypeLimit.has_value();
+}
+
+void GetInstantMixFromArtists2Params::setImageTypeLimitNull() {
+	m_imageTypeLimit = std::nullopt;
+}
+
+
+const qint32 &GetInstantMixFromArtists2Params::limit() const {
+	return m_limit.value();
+}
+
+void GetInstantMixFromArtists2Params::setLimit(qint32 newLimit)  {
+	m_limit = newLimit;
+}
+
+bool GetInstantMixFromArtists2Params::limitNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_limit.has_value();
+}
+
+void GetInstantMixFromArtists2Params::setLimitNull() {
+	m_limit = std::nullopt;
+}
+
+
+const QString &GetInstantMixFromArtists2Params::userId() const {
+	return m_userId;
+}
+
+void GetInstantMixFromArtists2Params::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetInstantMixFromArtists2Params::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetInstantMixFromArtists2Params::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
+// GetInstantMixFromItemParams
+
+const QString &GetInstantMixFromItemParams::itemId() const {
+	return m_itemId;
+}
+
+void GetInstantMixFromItemParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
 const QList<ImageType> &GetInstantMixFromItemParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
@@ -10625,26 +10357,26 @@ void GetInstantMixFromItemParams::setUserIdNull() {
 
 
 
-// GetInstantMixFromMusicGenreParams
+// GetInstantMixFromMusicGenreByIdParams
 
-const QString &GetInstantMixFromMusicGenreParams::name() const {
-	return m_name;
+const QString &GetInstantMixFromMusicGenreByIdParams::jellyfinId() const {
+	return m_jellyfinId;
 }
 
-void GetInstantMixFromMusicGenreParams::setName(QString newName) {
-	m_name = newName;
+void GetInstantMixFromMusicGenreByIdParams::setJellyfinId(QString newJellyfinId) {
+	m_jellyfinId = newJellyfinId;
 }
 
 
-const QList<ImageType> &GetInstantMixFromMusicGenreParams::enableImageTypes() const {
+const QList<ImageType> &GetInstantMixFromMusicGenreByIdParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
+void GetInstantMixFromMusicGenreByIdParams::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
 	m_enableImageTypes = newEnableImageTypes;
 }
 
-bool GetInstantMixFromMusicGenreParams::enableImageTypesNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::enableImageTypesNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10652,20 +10384,20 @@ bool GetInstantMixFromMusicGenreParams::enableImageTypesNull() const {
 	return m_enableImageTypes.size() == 0;
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableImageTypesNull() {
+void GetInstantMixFromMusicGenreByIdParams::setEnableImageTypesNull() {
 	m_enableImageTypes.clear();
 }
 
 
-const bool &GetInstantMixFromMusicGenreParams::enableImages() const {
+const bool &GetInstantMixFromMusicGenreByIdParams::enableImages() const {
 	return m_enableImages.value();
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableImages(bool newEnableImages)  {
+void GetInstantMixFromMusicGenreByIdParams::setEnableImages(bool newEnableImages)  {
 	m_enableImages = newEnableImages;
 }
 
-bool GetInstantMixFromMusicGenreParams::enableImagesNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::enableImagesNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10673,20 +10405,20 @@ bool GetInstantMixFromMusicGenreParams::enableImagesNull() const {
 	return !m_enableImages.has_value();
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableImagesNull() {
+void GetInstantMixFromMusicGenreByIdParams::setEnableImagesNull() {
 	m_enableImages = std::nullopt;
 }
 
 
-const bool &GetInstantMixFromMusicGenreParams::enableUserData() const {
+const bool &GetInstantMixFromMusicGenreByIdParams::enableUserData() const {
 	return m_enableUserData.value();
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableUserData(bool newEnableUserData)  {
+void GetInstantMixFromMusicGenreByIdParams::setEnableUserData(bool newEnableUserData)  {
 	m_enableUserData = newEnableUserData;
 }
 
-bool GetInstantMixFromMusicGenreParams::enableUserDataNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::enableUserDataNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10694,20 +10426,20 @@ bool GetInstantMixFromMusicGenreParams::enableUserDataNull() const {
 	return !m_enableUserData.has_value();
 }
 
-void GetInstantMixFromMusicGenreParams::setEnableUserDataNull() {
+void GetInstantMixFromMusicGenreByIdParams::setEnableUserDataNull() {
 	m_enableUserData = std::nullopt;
 }
 
 
-const QList<ItemFields> &GetInstantMixFromMusicGenreParams::fields() const {
+const QList<ItemFields> &GetInstantMixFromMusicGenreByIdParams::fields() const {
 	return m_fields;
 }
 
-void GetInstantMixFromMusicGenreParams::setFields(QList<ItemFields> newFields)  {
+void GetInstantMixFromMusicGenreByIdParams::setFields(QList<ItemFields> newFields)  {
 	m_fields = newFields;
 }
 
-bool GetInstantMixFromMusicGenreParams::fieldsNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::fieldsNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10715,20 +10447,20 @@ bool GetInstantMixFromMusicGenreParams::fieldsNull() const {
 	return m_fields.size() == 0;
 }
 
-void GetInstantMixFromMusicGenreParams::setFieldsNull() {
+void GetInstantMixFromMusicGenreByIdParams::setFieldsNull() {
 	m_fields.clear();
 }
 
 
-const qint32 &GetInstantMixFromMusicGenreParams::imageTypeLimit() const {
+const qint32 &GetInstantMixFromMusicGenreByIdParams::imageTypeLimit() const {
 	return m_imageTypeLimit.value();
 }
 
-void GetInstantMixFromMusicGenreParams::setImageTypeLimit(qint32 newImageTypeLimit)  {
+void GetInstantMixFromMusicGenreByIdParams::setImageTypeLimit(qint32 newImageTypeLimit)  {
 	m_imageTypeLimit = newImageTypeLimit;
 }
 
-bool GetInstantMixFromMusicGenreParams::imageTypeLimitNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::imageTypeLimitNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10736,20 +10468,20 @@ bool GetInstantMixFromMusicGenreParams::imageTypeLimitNull() const {
 	return !m_imageTypeLimit.has_value();
 }
 
-void GetInstantMixFromMusicGenreParams::setImageTypeLimitNull() {
+void GetInstantMixFromMusicGenreByIdParams::setImageTypeLimitNull() {
 	m_imageTypeLimit = std::nullopt;
 }
 
 
-const qint32 &GetInstantMixFromMusicGenreParams::limit() const {
+const qint32 &GetInstantMixFromMusicGenreByIdParams::limit() const {
 	return m_limit.value();
 }
 
-void GetInstantMixFromMusicGenreParams::setLimit(qint32 newLimit)  {
+void GetInstantMixFromMusicGenreByIdParams::setLimit(qint32 newLimit)  {
 	m_limit = newLimit;
 }
 
-bool GetInstantMixFromMusicGenreParams::limitNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::limitNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10757,20 +10489,20 @@ bool GetInstantMixFromMusicGenreParams::limitNull() const {
 	return !m_limit.has_value();
 }
 
-void GetInstantMixFromMusicGenreParams::setLimitNull() {
+void GetInstantMixFromMusicGenreByIdParams::setLimitNull() {
 	m_limit = std::nullopt;
 }
 
 
-const QString &GetInstantMixFromMusicGenreParams::userId() const {
+const QString &GetInstantMixFromMusicGenreByIdParams::userId() const {
 	return m_userId;
 }
 
-void GetInstantMixFromMusicGenreParams::setUserId(QString newUserId)  {
+void GetInstantMixFromMusicGenreByIdParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
-bool GetInstantMixFromMusicGenreParams::userIdNull() const {
+bool GetInstantMixFromMusicGenreByIdParams::userIdNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10778,33 +10510,33 @@ bool GetInstantMixFromMusicGenreParams::userIdNull() const {
 	return m_userId.isNull();
 }
 
-void GetInstantMixFromMusicGenreParams::setUserIdNull() {
+void GetInstantMixFromMusicGenreByIdParams::setUserIdNull() {
 	m_userId.clear();
 }
 
 
 
 
-// GetInstantMixFromMusicGenresParams
+// GetInstantMixFromMusicGenreByNameParams
 
-const QString &GetInstantMixFromMusicGenresParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetInstantMixFromMusicGenreByNameParams::name() const {
+	return m_name;
 }
 
-void GetInstantMixFromMusicGenresParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetInstantMixFromMusicGenreByNameParams::setName(QString newName) {
+	m_name = newName;
 }
 
 
-const QList<ImageType> &GetInstantMixFromMusicGenresParams::enableImageTypes() const {
+const QList<ImageType> &GetInstantMixFromMusicGenreByNameParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
+void GetInstantMixFromMusicGenreByNameParams::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
 	m_enableImageTypes = newEnableImageTypes;
 }
 
-bool GetInstantMixFromMusicGenresParams::enableImageTypesNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::enableImageTypesNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10812,20 +10544,20 @@ bool GetInstantMixFromMusicGenresParams::enableImageTypesNull() const {
 	return m_enableImageTypes.size() == 0;
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableImageTypesNull() {
+void GetInstantMixFromMusicGenreByNameParams::setEnableImageTypesNull() {
 	m_enableImageTypes.clear();
 }
 
 
-const bool &GetInstantMixFromMusicGenresParams::enableImages() const {
+const bool &GetInstantMixFromMusicGenreByNameParams::enableImages() const {
 	return m_enableImages.value();
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableImages(bool newEnableImages)  {
+void GetInstantMixFromMusicGenreByNameParams::setEnableImages(bool newEnableImages)  {
 	m_enableImages = newEnableImages;
 }
 
-bool GetInstantMixFromMusicGenresParams::enableImagesNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::enableImagesNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10833,20 +10565,20 @@ bool GetInstantMixFromMusicGenresParams::enableImagesNull() const {
 	return !m_enableImages.has_value();
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableImagesNull() {
+void GetInstantMixFromMusicGenreByNameParams::setEnableImagesNull() {
 	m_enableImages = std::nullopt;
 }
 
 
-const bool &GetInstantMixFromMusicGenresParams::enableUserData() const {
+const bool &GetInstantMixFromMusicGenreByNameParams::enableUserData() const {
 	return m_enableUserData.value();
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableUserData(bool newEnableUserData)  {
+void GetInstantMixFromMusicGenreByNameParams::setEnableUserData(bool newEnableUserData)  {
 	m_enableUserData = newEnableUserData;
 }
 
-bool GetInstantMixFromMusicGenresParams::enableUserDataNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::enableUserDataNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10854,20 +10586,20 @@ bool GetInstantMixFromMusicGenresParams::enableUserDataNull() const {
 	return !m_enableUserData.has_value();
 }
 
-void GetInstantMixFromMusicGenresParams::setEnableUserDataNull() {
+void GetInstantMixFromMusicGenreByNameParams::setEnableUserDataNull() {
 	m_enableUserData = std::nullopt;
 }
 
 
-const QList<ItemFields> &GetInstantMixFromMusicGenresParams::fields() const {
+const QList<ItemFields> &GetInstantMixFromMusicGenreByNameParams::fields() const {
 	return m_fields;
 }
 
-void GetInstantMixFromMusicGenresParams::setFields(QList<ItemFields> newFields)  {
+void GetInstantMixFromMusicGenreByNameParams::setFields(QList<ItemFields> newFields)  {
 	m_fields = newFields;
 }
 
-bool GetInstantMixFromMusicGenresParams::fieldsNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::fieldsNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10875,20 +10607,20 @@ bool GetInstantMixFromMusicGenresParams::fieldsNull() const {
 	return m_fields.size() == 0;
 }
 
-void GetInstantMixFromMusicGenresParams::setFieldsNull() {
+void GetInstantMixFromMusicGenreByNameParams::setFieldsNull() {
 	m_fields.clear();
 }
 
 
-const qint32 &GetInstantMixFromMusicGenresParams::imageTypeLimit() const {
+const qint32 &GetInstantMixFromMusicGenreByNameParams::imageTypeLimit() const {
 	return m_imageTypeLimit.value();
 }
 
-void GetInstantMixFromMusicGenresParams::setImageTypeLimit(qint32 newImageTypeLimit)  {
+void GetInstantMixFromMusicGenreByNameParams::setImageTypeLimit(qint32 newImageTypeLimit)  {
 	m_imageTypeLimit = newImageTypeLimit;
 }
 
-bool GetInstantMixFromMusicGenresParams::imageTypeLimitNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::imageTypeLimitNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10896,20 +10628,20 @@ bool GetInstantMixFromMusicGenresParams::imageTypeLimitNull() const {
 	return !m_imageTypeLimit.has_value();
 }
 
-void GetInstantMixFromMusicGenresParams::setImageTypeLimitNull() {
+void GetInstantMixFromMusicGenreByNameParams::setImageTypeLimitNull() {
 	m_imageTypeLimit = std::nullopt;
 }
 
 
-const qint32 &GetInstantMixFromMusicGenresParams::limit() const {
+const qint32 &GetInstantMixFromMusicGenreByNameParams::limit() const {
 	return m_limit.value();
 }
 
-void GetInstantMixFromMusicGenresParams::setLimit(qint32 newLimit)  {
+void GetInstantMixFromMusicGenreByNameParams::setLimit(qint32 newLimit)  {
 	m_limit = newLimit;
 }
 
-bool GetInstantMixFromMusicGenresParams::limitNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::limitNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
@@ -10917,20 +10649,20 @@ bool GetInstantMixFromMusicGenresParams::limitNull() const {
 	return !m_limit.has_value();
 }
 
-void GetInstantMixFromMusicGenresParams::setLimitNull() {
+void GetInstantMixFromMusicGenreByNameParams::setLimitNull() {
 	m_limit = std::nullopt;
 }
 
 
-const QString &GetInstantMixFromMusicGenresParams::userId() const {
+const QString &GetInstantMixFromMusicGenreByNameParams::userId() const {
 	return m_userId;
 }
 
-void GetInstantMixFromMusicGenresParams::setUserId(QString newUserId)  {
+void GetInstantMixFromMusicGenreByNameParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
-bool GetInstantMixFromMusicGenresParams::userIdNull() const {
+bool GetInstantMixFromMusicGenreByNameParams::userIdNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -10938,7 +10670,7 @@ bool GetInstantMixFromMusicGenresParams::userIdNull() const {
 	return m_userId.isNull();
 }
 
-void GetInstantMixFromMusicGenresParams::setUserIdNull() {
+void GetInstantMixFromMusicGenreByNameParams::setUserIdNull() {
 	m_userId.clear();
 }
 
@@ -10947,12 +10679,12 @@ void GetInstantMixFromMusicGenresParams::setUserIdNull() {
 
 // GetInstantMixFromPlaylistParams
 
-const QString &GetInstantMixFromPlaylistParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetInstantMixFromPlaylistParams::itemId() const {
+	return m_itemId;
 }
 
-void GetInstantMixFromPlaylistParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetInstantMixFromPlaylistParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
 }
 
 
@@ -11107,12 +10839,12 @@ void GetInstantMixFromPlaylistParams::setUserIdNull() {
 
 // GetInstantMixFromSongParams
 
-const QString &GetInstantMixFromSongParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetInstantMixFromSongParams::itemId() const {
+	return m_itemId;
 }
 
-void GetInstantMixFromSongParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetInstantMixFromSongParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
 }
 
 
@@ -11280,10 +11012,22 @@ const QString &GetIntrosParams::userId() const {
 	return m_userId;
 }
 
-void GetIntrosParams::setUserId(QString newUserId) {
+void GetIntrosParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetIntrosParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetIntrosParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -11302,10 +11046,22 @@ const QString &GetItemParams::userId() const {
 	return m_userId;
 }
 
-void GetItemParams::setUserId(QString newUserId) {
+void GetItemParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetItemParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetItemParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -11375,27 +11131,6 @@ void GetItemImageParams::setItemId(QString newItemId) {
 }
 
 
-const bool &GetItemImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetItemImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetItemImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetItemImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetItemImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -11438,24 +11173,45 @@ void GetItemImageParams::setBlurNull() {
 }
 
 
-const bool &GetItemImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetItemImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetItemImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetItemImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetItemImageParams::cropWhitespaceNull() const {
+bool GetItemImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetItemImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetItemImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetItemImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetItemImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetItemImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetItemImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -11775,27 +11531,6 @@ void GetItemImage2Params::setUnplayedCount(qint32 newUnplayedCount) {
 }
 
 
-const bool &GetItemImage2Params::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetItemImage2Params::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetItemImage2Params::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetItemImage2Params::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetItemImage2Params::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -11838,24 +11573,45 @@ void GetItemImage2Params::setBlurNull() {
 }
 
 
-const bool &GetItemImage2Params::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetItemImage2Params::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetItemImage2Params::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetItemImage2Params::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetItemImage2Params::cropWhitespaceNull() const {
+bool GetItemImage2Params::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetItemImage2Params::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetItemImage2Params::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetItemImage2Params::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetItemImage2Params::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetItemImage2Params::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetItemImage2Params::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -11974,27 +11730,6 @@ void GetItemImageByIndexParams::setItemId(QString newItemId) {
 }
 
 
-const bool &GetItemImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetItemImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetItemImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetItemImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetItemImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -12037,24 +11772,45 @@ void GetItemImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &GetItemImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetItemImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetItemImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetItemImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetItemImageByIndexParams::cropWhitespaceNull() const {
+bool GetItemImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetItemImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetItemImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetItemImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetItemImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetItemImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetItemImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -12283,6 +12039,74 @@ void GetItemImageInfosParams::setItemId(QString newItemId) {
 
 
 
+// GetItemSegmentsParams
+
+const QString &GetItemSegmentsParams::itemId() const {
+	return m_itemId;
+}
+
+void GetItemSegmentsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const QList<MediaSegmentType> &GetItemSegmentsParams::includeSegmentTypes() const {
+	return m_includeSegmentTypes;
+}
+
+void GetItemSegmentsParams::setIncludeSegmentTypes(QList<MediaSegmentType> newIncludeSegmentTypes)  {
+	m_includeSegmentTypes = newIncludeSegmentTypes;
+}
+
+bool GetItemSegmentsParams::includeSegmentTypesNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_includeSegmentTypes.size() == 0;
+}
+
+void GetItemSegmentsParams::setIncludeSegmentTypesNull() {
+	m_includeSegmentTypes.clear();
+}
+
+
+
+
+// GetItemUserDataParams
+
+const QString &GetItemUserDataParams::itemId() const {
+	return m_itemId;
+}
+
+void GetItemUserDataParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const QString &GetItemUserDataParams::userId() const {
+	return m_userId;
+}
+
+void GetItemUserDataParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetItemUserDataParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetItemUserDataParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
 // GetItemsParams
 
 const QString &GetItemsParams::adjacentTo() const {
@@ -12483,7 +12307,7 @@ void GetItemsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetItemsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -12579,11 +12403,11 @@ void GetItemsParams::setExcludeItemIdsNull() {
 }
 
 
-const QStringList &GetItemsParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetItemsParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetItemsParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetItemsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -12999,11 +12823,11 @@ void GetItemsParams::setImageTypesNull() {
 }
 
 
-const QStringList &GetItemsParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetItemsParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetItemsParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetItemsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -13020,6 +12844,27 @@ void GetItemsParams::setIncludeItemTypesNull() {
 }
 
 
+const qint32 &GetItemsParams::indexNumber() const {
+	return m_indexNumber.value();
+}
+
+void GetItemsParams::setIndexNumber(qint32 newIndexNumber)  {
+	m_indexNumber = newIndexNumber;
+}
+
+bool GetItemsParams::indexNumberNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_indexNumber.has_value();
+}
+
+void GetItemsParams::setIndexNumberNull() {
+	m_indexNumber = std::nullopt;
+}
+
+
 const bool &GetItemsParams::is3D() const {
 	return m_is3D.value();
 }
@@ -13104,6 +12949,27 @@ void GetItemsParams::setIsHdNull() {
 }
 
 
+const bool &GetItemsParams::isKids() const {
+	return m_isKids.value();
+}
+
+void GetItemsParams::setIsKids(bool newIsKids)  {
+	m_isKids = newIsKids;
+}
+
+bool GetItemsParams::isKidsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isKids.has_value();
+}
+
+void GetItemsParams::setIsKidsNull() {
+	m_isKids = std::nullopt;
+}
+
+
 const bool &GetItemsParams::isLocked() const {
 	return m_isLocked.value();
 }
@@ -13146,6 +13012,48 @@ void GetItemsParams::setIsMissingNull() {
 }
 
 
+const bool &GetItemsParams::isMovie() const {
+	return m_isMovie.value();
+}
+
+void GetItemsParams::setIsMovie(bool newIsMovie)  {
+	m_isMovie = newIsMovie;
+}
+
+bool GetItemsParams::isMovieNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isMovie.has_value();
+}
+
+void GetItemsParams::setIsMovieNull() {
+	m_isMovie = std::nullopt;
+}
+
+
+const bool &GetItemsParams::isNews() const {
+	return m_isNews.value();
+}
+
+void GetItemsParams::setIsNews(bool newIsNews)  {
+	m_isNews = newIsNews;
+}
+
+bool GetItemsParams::isNewsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isNews.has_value();
+}
+
+void GetItemsParams::setIsNewsNull() {
+	m_isNews = std::nullopt;
+}
+
+
 const bool &GetItemsParams::isPlaceHolder() const {
 	return m_isPlaceHolder.value();
 }
@@ -13188,6 +13096,48 @@ void GetItemsParams::setIsPlayedNull() {
 }
 
 
+const bool &GetItemsParams::isSeries() const {
+	return m_isSeries.value();
+}
+
+void GetItemsParams::setIsSeries(bool newIsSeries)  {
+	m_isSeries = newIsSeries;
+}
+
+bool GetItemsParams::isSeriesNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSeries.has_value();
+}
+
+void GetItemsParams::setIsSeriesNull() {
+	m_isSeries = std::nullopt;
+}
+
+
+const bool &GetItemsParams::isSports() const {
+	return m_isSports.value();
+}
+
+void GetItemsParams::setIsSports(bool newIsSports)  {
+	m_isSports = newIsSports;
+}
+
+bool GetItemsParams::isSportsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSports.has_value();
+}
+
+void GetItemsParams::setIsSportsNull() {
+	m_isSports = std::nullopt;
+}
+
+
 const bool &GetItemsParams::isUnaired() const {
 	return m_isUnaired.value();
 }
@@ -13335,11 +13285,11 @@ void GetItemsParams::setMaxWidthNull() {
 }
 
 
-const QStringList &GetItemsParams::mediaTypes() const {
+const QList<MediaType> &GetItemsParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetItemsParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetItemsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -13776,11 +13726,11 @@ void GetItemsParams::setSeriesStatusNull() {
 }
 
 
-const QString &GetItemsParams::sortBy() const {
+const QList<ItemSortBy> &GetItemsParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetItemsParams::setSortBy(QString newSortBy)  {
+void GetItemsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -13789,7 +13739,7 @@ bool GetItemsParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetItemsParams::setSortByNull() {
@@ -13797,11 +13747,11 @@ void GetItemsParams::setSortByNull() {
 }
 
 
-const QString &GetItemsParams::sortOrder() const {
+const QList<SortOrder> &GetItemsParams::sortOrder() const {
 	return m_sortOrder;
 }
 
-void GetItemsParams::setSortOrder(QString newSortOrder)  {
+void GetItemsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
 	m_sortOrder = newSortOrder;
 }
 
@@ -13810,7 +13760,7 @@ bool GetItemsParams::sortOrderNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetItemsParams::setSortOrderNull() {
@@ -13967,1678 +13917,6 @@ void GetItemsParams::setYearsNull() {
 
 
 
-// GetItemsByUserIdParams
-
-const QString &GetItemsByUserIdParams::userId() const {
-	return m_userId;
-}
-
-void GetItemsByUserIdParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const QString &GetItemsByUserIdParams::adjacentTo() const {
-	return m_adjacentTo;
-}
-
-void GetItemsByUserIdParams::setAdjacentTo(QString newAdjacentTo)  {
-	m_adjacentTo = newAdjacentTo;
-}
-
-bool GetItemsByUserIdParams::adjacentToNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_adjacentTo.isNull();
-}
-
-void GetItemsByUserIdParams::setAdjacentToNull() {
-	m_adjacentTo.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::albumArtistIds() const {
-	return m_albumArtistIds;
-}
-
-void GetItemsByUserIdParams::setAlbumArtistIds(QStringList newAlbumArtistIds)  {
-	m_albumArtistIds = newAlbumArtistIds;
-}
-
-bool GetItemsByUserIdParams::albumArtistIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_albumArtistIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setAlbumArtistIdsNull() {
-	m_albumArtistIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::albumIds() const {
-	return m_albumIds;
-}
-
-void GetItemsByUserIdParams::setAlbumIds(QStringList newAlbumIds)  {
-	m_albumIds = newAlbumIds;
-}
-
-bool GetItemsByUserIdParams::albumIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_albumIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setAlbumIdsNull() {
-	m_albumIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::albums() const {
-	return m_albums;
-}
-
-void GetItemsByUserIdParams::setAlbums(QStringList newAlbums)  {
-	m_albums = newAlbums;
-}
-
-bool GetItemsByUserIdParams::albumsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_albums.size() == 0;
-}
-
-void GetItemsByUserIdParams::setAlbumsNull() {
-	m_albums.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::artistIds() const {
-	return m_artistIds;
-}
-
-void GetItemsByUserIdParams::setArtistIds(QStringList newArtistIds)  {
-	m_artistIds = newArtistIds;
-}
-
-bool GetItemsByUserIdParams::artistIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_artistIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setArtistIdsNull() {
-	m_artistIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::artists() const {
-	return m_artists;
-}
-
-void GetItemsByUserIdParams::setArtists(QStringList newArtists)  {
-	m_artists = newArtists;
-}
-
-bool GetItemsByUserIdParams::artistsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_artists.size() == 0;
-}
-
-void GetItemsByUserIdParams::setArtistsNull() {
-	m_artists.clear();
-}
-
-
-const bool &GetItemsByUserIdParams::collapseBoxSetItems() const {
-	return m_collapseBoxSetItems.value();
-}
-
-void GetItemsByUserIdParams::setCollapseBoxSetItems(bool newCollapseBoxSetItems)  {
-	m_collapseBoxSetItems = newCollapseBoxSetItems;
-}
-
-bool GetItemsByUserIdParams::collapseBoxSetItemsNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_collapseBoxSetItems.has_value();
-}
-
-void GetItemsByUserIdParams::setCollapseBoxSetItemsNull() {
-	m_collapseBoxSetItems = std::nullopt;
-}
-
-
-const QStringList &GetItemsByUserIdParams::contributingArtistIds() const {
-	return m_contributingArtistIds;
-}
-
-void GetItemsByUserIdParams::setContributingArtistIds(QStringList newContributingArtistIds)  {
-	m_contributingArtistIds = newContributingArtistIds;
-}
-
-bool GetItemsByUserIdParams::contributingArtistIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_contributingArtistIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setContributingArtistIdsNull() {
-	m_contributingArtistIds.clear();
-}
-
-
-const QList<ImageType> &GetItemsByUserIdParams::enableImageTypes() const {
-	return m_enableImageTypes;
-}
-
-void GetItemsByUserIdParams::setEnableImageTypes(QList<ImageType> newEnableImageTypes)  {
-	m_enableImageTypes = newEnableImageTypes;
-}
-
-bool GetItemsByUserIdParams::enableImageTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_enableImageTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setEnableImageTypesNull() {
-	m_enableImageTypes.clear();
-}
-
-
-const bool &GetItemsByUserIdParams::enableImages() const {
-	return m_enableImages.value();
-}
-
-void GetItemsByUserIdParams::setEnableImages(bool newEnableImages)  {
-	m_enableImages = newEnableImages;
-}
-
-bool GetItemsByUserIdParams::enableImagesNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_enableImages.has_value();
-}
-
-void GetItemsByUserIdParams::setEnableImagesNull() {
-	m_enableImages = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::enableTotalRecordCount() const {
-	return m_enableTotalRecordCount.value();
-}
-
-void GetItemsByUserIdParams::setEnableTotalRecordCount(bool newEnableTotalRecordCount)  {
-	m_enableTotalRecordCount = newEnableTotalRecordCount;
-}
-
-bool GetItemsByUserIdParams::enableTotalRecordCountNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_enableTotalRecordCount.has_value();
-}
-
-void GetItemsByUserIdParams::setEnableTotalRecordCountNull() {
-	m_enableTotalRecordCount = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::enableUserData() const {
-	return m_enableUserData.value();
-}
-
-void GetItemsByUserIdParams::setEnableUserData(bool newEnableUserData)  {
-	m_enableUserData = newEnableUserData;
-}
-
-bool GetItemsByUserIdParams::enableUserDataNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_enableUserData.has_value();
-}
-
-void GetItemsByUserIdParams::setEnableUserDataNull() {
-	m_enableUserData = std::nullopt;
-}
-
-
-const QStringList &GetItemsByUserIdParams::excludeArtistIds() const {
-	return m_excludeArtistIds;
-}
-
-void GetItemsByUserIdParams::setExcludeArtistIds(QStringList newExcludeArtistIds)  {
-	m_excludeArtistIds = newExcludeArtistIds;
-}
-
-bool GetItemsByUserIdParams::excludeArtistIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_excludeArtistIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setExcludeArtistIdsNull() {
-	m_excludeArtistIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::excludeItemIds() const {
-	return m_excludeItemIds;
-}
-
-void GetItemsByUserIdParams::setExcludeItemIds(QStringList newExcludeItemIds)  {
-	m_excludeItemIds = newExcludeItemIds;
-}
-
-bool GetItemsByUserIdParams::excludeItemIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_excludeItemIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setExcludeItemIdsNull() {
-	m_excludeItemIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::excludeItemTypes() const {
-	return m_excludeItemTypes;
-}
-
-void GetItemsByUserIdParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
-	m_excludeItemTypes = newExcludeItemTypes;
-}
-
-bool GetItemsByUserIdParams::excludeItemTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_excludeItemTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setExcludeItemTypesNull() {
-	m_excludeItemTypes.clear();
-}
-
-
-const QList<LocationType> &GetItemsByUserIdParams::excludeLocationTypes() const {
-	return m_excludeLocationTypes;
-}
-
-void GetItemsByUserIdParams::setExcludeLocationTypes(QList<LocationType> newExcludeLocationTypes)  {
-	m_excludeLocationTypes = newExcludeLocationTypes;
-}
-
-bool GetItemsByUserIdParams::excludeLocationTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_excludeLocationTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setExcludeLocationTypesNull() {
-	m_excludeLocationTypes.clear();
-}
-
-
-const QList<ItemFields> &GetItemsByUserIdParams::fields() const {
-	return m_fields;
-}
-
-void GetItemsByUserIdParams::setFields(QList<ItemFields> newFields)  {
-	m_fields = newFields;
-}
-
-bool GetItemsByUserIdParams::fieldsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_fields.size() == 0;
-}
-
-void GetItemsByUserIdParams::setFieldsNull() {
-	m_fields.clear();
-}
-
-
-const QList<ItemFilter> &GetItemsByUserIdParams::filters() const {
-	return m_filters;
-}
-
-void GetItemsByUserIdParams::setFilters(QList<ItemFilter> newFilters)  {
-	m_filters = newFilters;
-}
-
-bool GetItemsByUserIdParams::filtersNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_filters.size() == 0;
-}
-
-void GetItemsByUserIdParams::setFiltersNull() {
-	m_filters.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::genreIds() const {
-	return m_genreIds;
-}
-
-void GetItemsByUserIdParams::setGenreIds(QStringList newGenreIds)  {
-	m_genreIds = newGenreIds;
-}
-
-bool GetItemsByUserIdParams::genreIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_genreIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setGenreIdsNull() {
-	m_genreIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::genres() const {
-	return m_genres;
-}
-
-void GetItemsByUserIdParams::setGenres(QStringList newGenres)  {
-	m_genres = newGenres;
-}
-
-bool GetItemsByUserIdParams::genresNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_genres.size() == 0;
-}
-
-void GetItemsByUserIdParams::setGenresNull() {
-	m_genres.clear();
-}
-
-
-const bool &GetItemsByUserIdParams::hasImdbId() const {
-	return m_hasImdbId.value();
-}
-
-void GetItemsByUserIdParams::setHasImdbId(bool newHasImdbId)  {
-	m_hasImdbId = newHasImdbId;
-}
-
-bool GetItemsByUserIdParams::hasImdbIdNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasImdbId.has_value();
-}
-
-void GetItemsByUserIdParams::setHasImdbIdNull() {
-	m_hasImdbId = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasOfficialRating() const {
-	return m_hasOfficialRating.value();
-}
-
-void GetItemsByUserIdParams::setHasOfficialRating(bool newHasOfficialRating)  {
-	m_hasOfficialRating = newHasOfficialRating;
-}
-
-bool GetItemsByUserIdParams::hasOfficialRatingNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasOfficialRating.has_value();
-}
-
-void GetItemsByUserIdParams::setHasOfficialRatingNull() {
-	m_hasOfficialRating = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasOverview() const {
-	return m_hasOverview.value();
-}
-
-void GetItemsByUserIdParams::setHasOverview(bool newHasOverview)  {
-	m_hasOverview = newHasOverview;
-}
-
-bool GetItemsByUserIdParams::hasOverviewNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasOverview.has_value();
-}
-
-void GetItemsByUserIdParams::setHasOverviewNull() {
-	m_hasOverview = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasParentalRating() const {
-	return m_hasParentalRating.value();
-}
-
-void GetItemsByUserIdParams::setHasParentalRating(bool newHasParentalRating)  {
-	m_hasParentalRating = newHasParentalRating;
-}
-
-bool GetItemsByUserIdParams::hasParentalRatingNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasParentalRating.has_value();
-}
-
-void GetItemsByUserIdParams::setHasParentalRatingNull() {
-	m_hasParentalRating = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasSpecialFeature() const {
-	return m_hasSpecialFeature.value();
-}
-
-void GetItemsByUserIdParams::setHasSpecialFeature(bool newHasSpecialFeature)  {
-	m_hasSpecialFeature = newHasSpecialFeature;
-}
-
-bool GetItemsByUserIdParams::hasSpecialFeatureNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasSpecialFeature.has_value();
-}
-
-void GetItemsByUserIdParams::setHasSpecialFeatureNull() {
-	m_hasSpecialFeature = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasSubtitles() const {
-	return m_hasSubtitles.value();
-}
-
-void GetItemsByUserIdParams::setHasSubtitles(bool newHasSubtitles)  {
-	m_hasSubtitles = newHasSubtitles;
-}
-
-bool GetItemsByUserIdParams::hasSubtitlesNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasSubtitles.has_value();
-}
-
-void GetItemsByUserIdParams::setHasSubtitlesNull() {
-	m_hasSubtitles = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasThemeSong() const {
-	return m_hasThemeSong.value();
-}
-
-void GetItemsByUserIdParams::setHasThemeSong(bool newHasThemeSong)  {
-	m_hasThemeSong = newHasThemeSong;
-}
-
-bool GetItemsByUserIdParams::hasThemeSongNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasThemeSong.has_value();
-}
-
-void GetItemsByUserIdParams::setHasThemeSongNull() {
-	m_hasThemeSong = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasThemeVideo() const {
-	return m_hasThemeVideo.value();
-}
-
-void GetItemsByUserIdParams::setHasThemeVideo(bool newHasThemeVideo)  {
-	m_hasThemeVideo = newHasThemeVideo;
-}
-
-bool GetItemsByUserIdParams::hasThemeVideoNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasThemeVideo.has_value();
-}
-
-void GetItemsByUserIdParams::setHasThemeVideoNull() {
-	m_hasThemeVideo = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasTmdbId() const {
-	return m_hasTmdbId.value();
-}
-
-void GetItemsByUserIdParams::setHasTmdbId(bool newHasTmdbId)  {
-	m_hasTmdbId = newHasTmdbId;
-}
-
-bool GetItemsByUserIdParams::hasTmdbIdNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasTmdbId.has_value();
-}
-
-void GetItemsByUserIdParams::setHasTmdbIdNull() {
-	m_hasTmdbId = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasTrailer() const {
-	return m_hasTrailer.value();
-}
-
-void GetItemsByUserIdParams::setHasTrailer(bool newHasTrailer)  {
-	m_hasTrailer = newHasTrailer;
-}
-
-bool GetItemsByUserIdParams::hasTrailerNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasTrailer.has_value();
-}
-
-void GetItemsByUserIdParams::setHasTrailerNull() {
-	m_hasTrailer = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::hasTvdbId() const {
-	return m_hasTvdbId.value();
-}
-
-void GetItemsByUserIdParams::setHasTvdbId(bool newHasTvdbId)  {
-	m_hasTvdbId = newHasTvdbId;
-}
-
-bool GetItemsByUserIdParams::hasTvdbIdNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_hasTvdbId.has_value();
-}
-
-void GetItemsByUserIdParams::setHasTvdbIdNull() {
-	m_hasTvdbId = std::nullopt;
-}
-
-
-const QStringList &GetItemsByUserIdParams::ids() const {
-	return m_ids;
-}
-
-void GetItemsByUserIdParams::setIds(QStringList newIds)  {
-	m_ids = newIds;
-}
-
-bool GetItemsByUserIdParams::idsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_ids.size() == 0;
-}
-
-void GetItemsByUserIdParams::setIdsNull() {
-	m_ids.clear();
-}
-
-
-const qint32 &GetItemsByUserIdParams::imageTypeLimit() const {
-	return m_imageTypeLimit.value();
-}
-
-void GetItemsByUserIdParams::setImageTypeLimit(qint32 newImageTypeLimit)  {
-	m_imageTypeLimit = newImageTypeLimit;
-}
-
-bool GetItemsByUserIdParams::imageTypeLimitNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_imageTypeLimit.has_value();
-}
-
-void GetItemsByUserIdParams::setImageTypeLimitNull() {
-	m_imageTypeLimit = std::nullopt;
-}
-
-
-const QList<ImageType> &GetItemsByUserIdParams::imageTypes() const {
-	return m_imageTypes;
-}
-
-void GetItemsByUserIdParams::setImageTypes(QList<ImageType> newImageTypes)  {
-	m_imageTypes = newImageTypes;
-}
-
-bool GetItemsByUserIdParams::imageTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_imageTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setImageTypesNull() {
-	m_imageTypes.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::includeItemTypes() const {
-	return m_includeItemTypes;
-}
-
-void GetItemsByUserIdParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
-	m_includeItemTypes = newIncludeItemTypes;
-}
-
-bool GetItemsByUserIdParams::includeItemTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_includeItemTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setIncludeItemTypesNull() {
-	m_includeItemTypes.clear();
-}
-
-
-const bool &GetItemsByUserIdParams::is3D() const {
-	return m_is3D.value();
-}
-
-void GetItemsByUserIdParams::setIs3D(bool newIs3D)  {
-	m_is3D = newIs3D;
-}
-
-bool GetItemsByUserIdParams::is3DNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_is3D.has_value();
-}
-
-void GetItemsByUserIdParams::setIs3DNull() {
-	m_is3D = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::is4K() const {
-	return m_is4K.value();
-}
-
-void GetItemsByUserIdParams::setIs4K(bool newIs4K)  {
-	m_is4K = newIs4K;
-}
-
-bool GetItemsByUserIdParams::is4KNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_is4K.has_value();
-}
-
-void GetItemsByUserIdParams::setIs4KNull() {
-	m_is4K = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isFavorite() const {
-	return m_isFavorite.value();
-}
-
-void GetItemsByUserIdParams::setIsFavorite(bool newIsFavorite)  {
-	m_isFavorite = newIsFavorite;
-}
-
-bool GetItemsByUserIdParams::isFavoriteNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isFavorite.has_value();
-}
-
-void GetItemsByUserIdParams::setIsFavoriteNull() {
-	m_isFavorite = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isHd() const {
-	return m_isHd.value();
-}
-
-void GetItemsByUserIdParams::setIsHd(bool newIsHd)  {
-	m_isHd = newIsHd;
-}
-
-bool GetItemsByUserIdParams::isHdNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isHd.has_value();
-}
-
-void GetItemsByUserIdParams::setIsHdNull() {
-	m_isHd = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isLocked() const {
-	return m_isLocked.value();
-}
-
-void GetItemsByUserIdParams::setIsLocked(bool newIsLocked)  {
-	m_isLocked = newIsLocked;
-}
-
-bool GetItemsByUserIdParams::isLockedNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isLocked.has_value();
-}
-
-void GetItemsByUserIdParams::setIsLockedNull() {
-	m_isLocked = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isMissing() const {
-	return m_isMissing.value();
-}
-
-void GetItemsByUserIdParams::setIsMissing(bool newIsMissing)  {
-	m_isMissing = newIsMissing;
-}
-
-bool GetItemsByUserIdParams::isMissingNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isMissing.has_value();
-}
-
-void GetItemsByUserIdParams::setIsMissingNull() {
-	m_isMissing = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isPlaceHolder() const {
-	return m_isPlaceHolder.value();
-}
-
-void GetItemsByUserIdParams::setIsPlaceHolder(bool newIsPlaceHolder)  {
-	m_isPlaceHolder = newIsPlaceHolder;
-}
-
-bool GetItemsByUserIdParams::isPlaceHolderNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isPlaceHolder.has_value();
-}
-
-void GetItemsByUserIdParams::setIsPlaceHolderNull() {
-	m_isPlaceHolder = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isPlayed() const {
-	return m_isPlayed.value();
-}
-
-void GetItemsByUserIdParams::setIsPlayed(bool newIsPlayed)  {
-	m_isPlayed = newIsPlayed;
-}
-
-bool GetItemsByUserIdParams::isPlayedNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isPlayed.has_value();
-}
-
-void GetItemsByUserIdParams::setIsPlayedNull() {
-	m_isPlayed = std::nullopt;
-}
-
-
-const bool &GetItemsByUserIdParams::isUnaired() const {
-	return m_isUnaired.value();
-}
-
-void GetItemsByUserIdParams::setIsUnaired(bool newIsUnaired)  {
-	m_isUnaired = newIsUnaired;
-}
-
-bool GetItemsByUserIdParams::isUnairedNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_isUnaired.has_value();
-}
-
-void GetItemsByUserIdParams::setIsUnairedNull() {
-	m_isUnaired = std::nullopt;
-}
-
-
-const qint32 &GetItemsByUserIdParams::limit() const {
-	return m_limit.value();
-}
-
-void GetItemsByUserIdParams::setLimit(qint32 newLimit)  {
-	m_limit = newLimit;
-}
-
-bool GetItemsByUserIdParams::limitNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_limit.has_value();
-}
-
-void GetItemsByUserIdParams::setLimitNull() {
-	m_limit = std::nullopt;
-}
-
-
-const QList<LocationType> &GetItemsByUserIdParams::locationTypes() const {
-	return m_locationTypes;
-}
-
-void GetItemsByUserIdParams::setLocationTypes(QList<LocationType> newLocationTypes)  {
-	m_locationTypes = newLocationTypes;
-}
-
-bool GetItemsByUserIdParams::locationTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_locationTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setLocationTypesNull() {
-	m_locationTypes.clear();
-}
-
-
-const qint32 &GetItemsByUserIdParams::maxHeight() const {
-	return m_maxHeight.value();
-}
-
-void GetItemsByUserIdParams::setMaxHeight(qint32 newMaxHeight)  {
-	m_maxHeight = newMaxHeight;
-}
-
-bool GetItemsByUserIdParams::maxHeightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxHeight.has_value();
-}
-
-void GetItemsByUserIdParams::setMaxHeightNull() {
-	m_maxHeight = std::nullopt;
-}
-
-
-const QString &GetItemsByUserIdParams::maxOfficialRating() const {
-	return m_maxOfficialRating;
-}
-
-void GetItemsByUserIdParams::setMaxOfficialRating(QString newMaxOfficialRating)  {
-	m_maxOfficialRating = newMaxOfficialRating;
-}
-
-bool GetItemsByUserIdParams::maxOfficialRatingNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_maxOfficialRating.isNull();
-}
-
-void GetItemsByUserIdParams::setMaxOfficialRatingNull() {
-	m_maxOfficialRating.clear();
-}
-
-
-const QDateTime &GetItemsByUserIdParams::maxPremiereDate() const {
-	return m_maxPremiereDate;
-}
-
-void GetItemsByUserIdParams::setMaxPremiereDate(QDateTime newMaxPremiereDate)  {
-	m_maxPremiereDate = newMaxPremiereDate;
-}
-
-bool GetItemsByUserIdParams::maxPremiereDateNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_maxPremiereDate.isNull();
-}
-
-void GetItemsByUserIdParams::setMaxPremiereDateNull() {
-	m_maxPremiereDate= QDateTime();
-}
-
-
-const qint32 &GetItemsByUserIdParams::maxWidth() const {
-	return m_maxWidth.value();
-}
-
-void GetItemsByUserIdParams::setMaxWidth(qint32 newMaxWidth)  {
-	m_maxWidth = newMaxWidth;
-}
-
-bool GetItemsByUserIdParams::maxWidthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxWidth.has_value();
-}
-
-void GetItemsByUserIdParams::setMaxWidthNull() {
-	m_maxWidth = std::nullopt;
-}
-
-
-const QStringList &GetItemsByUserIdParams::mediaTypes() const {
-	return m_mediaTypes;
-}
-
-void GetItemsByUserIdParams::setMediaTypes(QStringList newMediaTypes)  {
-	m_mediaTypes = newMediaTypes;
-}
-
-bool GetItemsByUserIdParams::mediaTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_mediaTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setMediaTypesNull() {
-	m_mediaTypes.clear();
-}
-
-
-const double &GetItemsByUserIdParams::minCommunityRating() const {
-	return m_minCommunityRating.value();
-}
-
-void GetItemsByUserIdParams::setMinCommunityRating(double newMinCommunityRating)  {
-	m_minCommunityRating = newMinCommunityRating;
-}
-
-bool GetItemsByUserIdParams::minCommunityRatingNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_minCommunityRating.has_value();
-}
-
-void GetItemsByUserIdParams::setMinCommunityRatingNull() {
-	m_minCommunityRating = std::nullopt;
-}
-
-
-const double &GetItemsByUserIdParams::minCriticRating() const {
-	return m_minCriticRating.value();
-}
-
-void GetItemsByUserIdParams::setMinCriticRating(double newMinCriticRating)  {
-	m_minCriticRating = newMinCriticRating;
-}
-
-bool GetItemsByUserIdParams::minCriticRatingNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_minCriticRating.has_value();
-}
-
-void GetItemsByUserIdParams::setMinCriticRatingNull() {
-	m_minCriticRating = std::nullopt;
-}
-
-
-const QDateTime &GetItemsByUserIdParams::minDateLastSaved() const {
-	return m_minDateLastSaved;
-}
-
-void GetItemsByUserIdParams::setMinDateLastSaved(QDateTime newMinDateLastSaved)  {
-	m_minDateLastSaved = newMinDateLastSaved;
-}
-
-bool GetItemsByUserIdParams::minDateLastSavedNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_minDateLastSaved.isNull();
-}
-
-void GetItemsByUserIdParams::setMinDateLastSavedNull() {
-	m_minDateLastSaved= QDateTime();
-}
-
-
-const QDateTime &GetItemsByUserIdParams::minDateLastSavedForUser() const {
-	return m_minDateLastSavedForUser;
-}
-
-void GetItemsByUserIdParams::setMinDateLastSavedForUser(QDateTime newMinDateLastSavedForUser)  {
-	m_minDateLastSavedForUser = newMinDateLastSavedForUser;
-}
-
-bool GetItemsByUserIdParams::minDateLastSavedForUserNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_minDateLastSavedForUser.isNull();
-}
-
-void GetItemsByUserIdParams::setMinDateLastSavedForUserNull() {
-	m_minDateLastSavedForUser= QDateTime();
-}
-
-
-const qint32 &GetItemsByUserIdParams::minHeight() const {
-	return m_minHeight.value();
-}
-
-void GetItemsByUserIdParams::setMinHeight(qint32 newMinHeight)  {
-	m_minHeight = newMinHeight;
-}
-
-bool GetItemsByUserIdParams::minHeightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_minHeight.has_value();
-}
-
-void GetItemsByUserIdParams::setMinHeightNull() {
-	m_minHeight = std::nullopt;
-}
-
-
-const QString &GetItemsByUserIdParams::minOfficialRating() const {
-	return m_minOfficialRating;
-}
-
-void GetItemsByUserIdParams::setMinOfficialRating(QString newMinOfficialRating)  {
-	m_minOfficialRating = newMinOfficialRating;
-}
-
-bool GetItemsByUserIdParams::minOfficialRatingNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_minOfficialRating.isNull();
-}
-
-void GetItemsByUserIdParams::setMinOfficialRatingNull() {
-	m_minOfficialRating.clear();
-}
-
-
-const QDateTime &GetItemsByUserIdParams::minPremiereDate() const {
-	return m_minPremiereDate;
-}
-
-void GetItemsByUserIdParams::setMinPremiereDate(QDateTime newMinPremiereDate)  {
-	m_minPremiereDate = newMinPremiereDate;
-}
-
-bool GetItemsByUserIdParams::minPremiereDateNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_minPremiereDate.isNull();
-}
-
-void GetItemsByUserIdParams::setMinPremiereDateNull() {
-	m_minPremiereDate= QDateTime();
-}
-
-
-const qint32 &GetItemsByUserIdParams::minWidth() const {
-	return m_minWidth.value();
-}
-
-void GetItemsByUserIdParams::setMinWidth(qint32 newMinWidth)  {
-	m_minWidth = newMinWidth;
-}
-
-bool GetItemsByUserIdParams::minWidthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_minWidth.has_value();
-}
-
-void GetItemsByUserIdParams::setMinWidthNull() {
-	m_minWidth = std::nullopt;
-}
-
-
-const QString &GetItemsByUserIdParams::nameLessThan() const {
-	return m_nameLessThan;
-}
-
-void GetItemsByUserIdParams::setNameLessThan(QString newNameLessThan)  {
-	m_nameLessThan = newNameLessThan;
-}
-
-bool GetItemsByUserIdParams::nameLessThanNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_nameLessThan.isNull();
-}
-
-void GetItemsByUserIdParams::setNameLessThanNull() {
-	m_nameLessThan.clear();
-}
-
-
-const QString &GetItemsByUserIdParams::nameStartsWith() const {
-	return m_nameStartsWith;
-}
-
-void GetItemsByUserIdParams::setNameStartsWith(QString newNameStartsWith)  {
-	m_nameStartsWith = newNameStartsWith;
-}
-
-bool GetItemsByUserIdParams::nameStartsWithNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_nameStartsWith.isNull();
-}
-
-void GetItemsByUserIdParams::setNameStartsWithNull() {
-	m_nameStartsWith.clear();
-}
-
-
-const QString &GetItemsByUserIdParams::nameStartsWithOrGreater() const {
-	return m_nameStartsWithOrGreater;
-}
-
-void GetItemsByUserIdParams::setNameStartsWithOrGreater(QString newNameStartsWithOrGreater)  {
-	m_nameStartsWithOrGreater = newNameStartsWithOrGreater;
-}
-
-bool GetItemsByUserIdParams::nameStartsWithOrGreaterNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_nameStartsWithOrGreater.isNull();
-}
-
-void GetItemsByUserIdParams::setNameStartsWithOrGreaterNull() {
-	m_nameStartsWithOrGreater.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::officialRatings() const {
-	return m_officialRatings;
-}
-
-void GetItemsByUserIdParams::setOfficialRatings(QStringList newOfficialRatings)  {
-	m_officialRatings = newOfficialRatings;
-}
-
-bool GetItemsByUserIdParams::officialRatingsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_officialRatings.size() == 0;
-}
-
-void GetItemsByUserIdParams::setOfficialRatingsNull() {
-	m_officialRatings.clear();
-}
-
-
-const QString &GetItemsByUserIdParams::parentId() const {
-	return m_parentId;
-}
-
-void GetItemsByUserIdParams::setParentId(QString newParentId)  {
-	m_parentId = newParentId;
-}
-
-bool GetItemsByUserIdParams::parentIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_parentId.isNull();
-}
-
-void GetItemsByUserIdParams::setParentIdNull() {
-	m_parentId.clear();
-}
-
-
-const qint32 &GetItemsByUserIdParams::parentIndexNumber() const {
-	return m_parentIndexNumber.value();
-}
-
-void GetItemsByUserIdParams::setParentIndexNumber(qint32 newParentIndexNumber)  {
-	m_parentIndexNumber = newParentIndexNumber;
-}
-
-bool GetItemsByUserIdParams::parentIndexNumberNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_parentIndexNumber.has_value();
-}
-
-void GetItemsByUserIdParams::setParentIndexNumberNull() {
-	m_parentIndexNumber = std::nullopt;
-}
-
-
-const QString &GetItemsByUserIdParams::person() const {
-	return m_person;
-}
-
-void GetItemsByUserIdParams::setPerson(QString newPerson)  {
-	m_person = newPerson;
-}
-
-bool GetItemsByUserIdParams::personNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_person.isNull();
-}
-
-void GetItemsByUserIdParams::setPersonNull() {
-	m_person.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::personIds() const {
-	return m_personIds;
-}
-
-void GetItemsByUserIdParams::setPersonIds(QStringList newPersonIds)  {
-	m_personIds = newPersonIds;
-}
-
-bool GetItemsByUserIdParams::personIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_personIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setPersonIdsNull() {
-	m_personIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::personTypes() const {
-	return m_personTypes;
-}
-
-void GetItemsByUserIdParams::setPersonTypes(QStringList newPersonTypes)  {
-	m_personTypes = newPersonTypes;
-}
-
-bool GetItemsByUserIdParams::personTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_personTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setPersonTypesNull() {
-	m_personTypes.clear();
-}
-
-
-const bool &GetItemsByUserIdParams::recursive() const {
-	return m_recursive.value();
-}
-
-void GetItemsByUserIdParams::setRecursive(bool newRecursive)  {
-	m_recursive = newRecursive;
-}
-
-bool GetItemsByUserIdParams::recursiveNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_recursive.has_value();
-}
-
-void GetItemsByUserIdParams::setRecursiveNull() {
-	m_recursive = std::nullopt;
-}
-
-
-const QString &GetItemsByUserIdParams::searchTerm() const {
-	return m_searchTerm;
-}
-
-void GetItemsByUserIdParams::setSearchTerm(QString newSearchTerm)  {
-	m_searchTerm = newSearchTerm;
-}
-
-bool GetItemsByUserIdParams::searchTermNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_searchTerm.isNull();
-}
-
-void GetItemsByUserIdParams::setSearchTermNull() {
-	m_searchTerm.clear();
-}
-
-
-const QList<SeriesStatus> &GetItemsByUserIdParams::seriesStatus() const {
-	return m_seriesStatus;
-}
-
-void GetItemsByUserIdParams::setSeriesStatus(QList<SeriesStatus> newSeriesStatus)  {
-	m_seriesStatus = newSeriesStatus;
-}
-
-bool GetItemsByUserIdParams::seriesStatusNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_seriesStatus.size() == 0;
-}
-
-void GetItemsByUserIdParams::setSeriesStatusNull() {
-	m_seriesStatus.clear();
-}
-
-
-const QString &GetItemsByUserIdParams::sortBy() const {
-	return m_sortBy;
-}
-
-void GetItemsByUserIdParams::setSortBy(QString newSortBy)  {
-	m_sortBy = newSortBy;
-}
-
-bool GetItemsByUserIdParams::sortByNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_sortBy.isNull();
-}
-
-void GetItemsByUserIdParams::setSortByNull() {
-	m_sortBy.clear();
-}
-
-
-const QString &GetItemsByUserIdParams::sortOrder() const {
-	return m_sortOrder;
-}
-
-void GetItemsByUserIdParams::setSortOrder(QString newSortOrder)  {
-	m_sortOrder = newSortOrder;
-}
-
-bool GetItemsByUserIdParams::sortOrderNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_sortOrder.isNull();
-}
-
-void GetItemsByUserIdParams::setSortOrderNull() {
-	m_sortOrder.clear();
-}
-
-
-const qint32 &GetItemsByUserIdParams::startIndex() const {
-	return m_startIndex.value();
-}
-
-void GetItemsByUserIdParams::setStartIndex(qint32 newStartIndex)  {
-	m_startIndex = newStartIndex;
-}
-
-bool GetItemsByUserIdParams::startIndexNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_startIndex.has_value();
-}
-
-void GetItemsByUserIdParams::setStartIndexNull() {
-	m_startIndex = std::nullopt;
-}
-
-
-const QStringList &GetItemsByUserIdParams::studioIds() const {
-	return m_studioIds;
-}
-
-void GetItemsByUserIdParams::setStudioIds(QStringList newStudioIds)  {
-	m_studioIds = newStudioIds;
-}
-
-bool GetItemsByUserIdParams::studioIdsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_studioIds.size() == 0;
-}
-
-void GetItemsByUserIdParams::setStudioIdsNull() {
-	m_studioIds.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::studios() const {
-	return m_studios;
-}
-
-void GetItemsByUserIdParams::setStudios(QStringList newStudios)  {
-	m_studios = newStudios;
-}
-
-bool GetItemsByUserIdParams::studiosNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_studios.size() == 0;
-}
-
-void GetItemsByUserIdParams::setStudiosNull() {
-	m_studios.clear();
-}
-
-
-const QStringList &GetItemsByUserIdParams::tags() const {
-	return m_tags;
-}
-
-void GetItemsByUserIdParams::setTags(QStringList newTags)  {
-	m_tags = newTags;
-}
-
-bool GetItemsByUserIdParams::tagsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_tags.size() == 0;
-}
-
-void GetItemsByUserIdParams::setTagsNull() {
-	m_tags.clear();
-}
-
-
-const QList<VideoType> &GetItemsByUserIdParams::videoTypes() const {
-	return m_videoTypes;
-}
-
-void GetItemsByUserIdParams::setVideoTypes(QList<VideoType> newVideoTypes)  {
-	m_videoTypes = newVideoTypes;
-}
-
-bool GetItemsByUserIdParams::videoTypesNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_videoTypes.size() == 0;
-}
-
-void GetItemsByUserIdParams::setVideoTypesNull() {
-	m_videoTypes.clear();
-}
-
-
-const QList<qint32> &GetItemsByUserIdParams::years() const {
-	return m_years;
-}
-
-void GetItemsByUserIdParams::setYears(QList<qint32> newYears)  {
-	m_years = newYears;
-}
-
-bool GetItemsByUserIdParams::yearsNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_years.size() == 0;
-}
-
-void GetItemsByUserIdParams::setYearsNull() {
-	m_years.clear();
-}
-
-
-
-
 // GetKeysParams
 
 
@@ -15775,15 +14053,6 @@ void GetLatestChannelItemsParams::setUserIdNull() {
 
 // GetLatestMediaParams
 
-const QString &GetLatestMediaParams::userId() const {
-	return m_userId;
-}
-
-void GetLatestMediaParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const QList<ImageType> &GetLatestMediaParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
@@ -15910,11 +14179,11 @@ void GetLatestMediaParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetLatestMediaParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetLatestMediaParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetLatestMediaParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetLatestMediaParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -15994,6 +14263,27 @@ void GetLatestMediaParams::setParentIdNull() {
 }
 
 
+const QString &GetLatestMediaParams::userId() const {
+	return m_userId;
+}
+
+void GetLatestMediaParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetLatestMediaParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetLatestMediaParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // GetLibraryOptionsInfoParams
@@ -16007,7 +14297,7 @@ void GetLibraryOptionsInfoParams::setIsNewLibrary(bool newIsNewLibrary)  {
 }
 
 bool GetLibraryOptionsInfoParams::isNewLibraryNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -16019,11 +14309,11 @@ void GetLibraryOptionsInfoParams::setIsNewLibraryNull() {
 }
 
 
-const QString &GetLibraryOptionsInfoParams::libraryContentType() const {
+const CollectionType &GetLibraryOptionsInfoParams::libraryContentType() const {
 	return m_libraryContentType;
 }
 
-void GetLibraryOptionsInfoParams::setLibraryContentType(QString newLibraryContentType)  {
+void GetLibraryOptionsInfoParams::setLibraryContentType(CollectionType newLibraryContentType)  {
 	m_libraryContentType = newLibraryContentType;
 }
 
@@ -16032,11 +14322,11 @@ bool GetLibraryOptionsInfoParams::libraryContentTypeNull() const {
 	// Type Nullable: true
 	
 
-	return m_libraryContentType.isNull();
+	return m_libraryContentType== CollectionType::EnumNotSet;
 }
 
 void GetLibraryOptionsInfoParams::setLibraryContentTypeNull() {
-	m_libraryContentType.clear();
+	m_libraryContentType= CollectionType::EnumNotSet;
 }
 
 
@@ -16183,6 +14473,27 @@ void GetLiveHlsStreamParams::setAllowVideoStreamCopyNull() {
 }
 
 
+const bool &GetLiveHlsStreamParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void GetLiveHlsStreamParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool GetLiveHlsStreamParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void GetLiveHlsStreamParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &GetLiveHlsStreamParams::audioBitRate() const {
 	return m_audioBitRate.value();
 }
@@ -16456,6 +14767,27 @@ void GetLiveHlsStreamParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetLiveHlsStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetLiveHlsStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetLiveHlsStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetLiveHlsStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetLiveHlsStreamParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -17587,11 +15919,11 @@ void GetLiveTvChannelsParams::setLimitNull() {
 }
 
 
-const QStringList &GetLiveTvChannelsParams::sortBy() const {
+const QList<ItemSortBy> &GetLiveTvChannelsParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetLiveTvChannelsParams::setSortBy(QStringList newSortBy)  {
+void GetLiveTvChannelsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -18183,11 +16515,11 @@ void GetLiveTvProgramsParams::setSeriesTimerIdNull() {
 }
 
 
-const QString &GetLiveTvProgramsParams::sortBy() const {
+const QList<ItemSortBy> &GetLiveTvProgramsParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetLiveTvProgramsParams::setSortBy(QString newSortBy)  {
+void GetLiveTvProgramsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -18196,7 +16528,7 @@ bool GetLiveTvProgramsParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetLiveTvProgramsParams::setSortByNull() {
@@ -18204,11 +16536,11 @@ void GetLiveTvProgramsParams::setSortByNull() {
 }
 
 
-const QString &GetLiveTvProgramsParams::sortOrder() const {
+const QList<SortOrder> &GetLiveTvProgramsParams::sortOrder() const {
 	return m_sortOrder;
 }
 
-void GetLiveTvProgramsParams::setSortOrder(QString newSortOrder)  {
+void GetLiveTvProgramsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
 	m_sortOrder = newSortOrder;
 }
 
@@ -18217,7 +16549,7 @@ bool GetLiveTvProgramsParams::sortOrderNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetLiveTvProgramsParams::setSortOrderNull() {
@@ -18284,10 +16616,22 @@ const QString &GetLocalTrailersParams::userId() const {
 	return m_userId;
 }
 
-void GetLocalTrailersParams::setUserId(QString newUserId) {
+void GetLocalTrailersParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetLocalTrailersParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetLocalTrailersParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -18396,6 +16740,19 @@ void GetLogFileParams::setName(QString newName) {
 
 
 
+// GetLyricsParams
+
+const QString &GetLyricsParams::itemId() const {
+	return m_itemId;
+}
+
+void GetLyricsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+
+
 // GetMasterHlsAudioPlaylistParams
 
 const QString &GetMasterHlsAudioPlaylistParams::itemId() const {
@@ -18731,6 +17088,27 @@ void GetMasterHlsAudioPlaylistParams::setEnableAdaptiveBitrateStreamingNull() {
 }
 
 
+const bool &GetMasterHlsAudioPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetMasterHlsAudioPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetMasterHlsAudioPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetMasterHlsAudioPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetMasterHlsAudioPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -19488,6 +17866,27 @@ void GetMasterHlsVideoPlaylistParams::setAllowVideoStreamCopyNull() {
 }
 
 
+const bool &GetMasterHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool GetMasterHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &GetMasterHlsVideoPlaylistParams::audioBitRate() const {
 	return m_audioBitRate.value();
 }
@@ -19761,6 +18160,27 @@ void GetMasterHlsVideoPlaylistParams::setEnableAdaptiveBitrateStreamingNull() {
 }
 
 
+const bool &GetMasterHlsVideoPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetMasterHlsVideoPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetMasterHlsVideoPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -19803,6 +18223,27 @@ void GetMasterHlsVideoPlaylistParams::setEnableMpegtsM2TsModeNull() {
 }
 
 
+const bool &GetMasterHlsVideoPlaylistParams::enableTrickplay() const {
+	return m_enableTrickplay.value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setEnableTrickplay(bool newEnableTrickplay)  {
+	m_enableTrickplay = newEnableTrickplay;
+}
+
+bool GetMasterHlsVideoPlaylistParams::enableTrickplayNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableTrickplay.has_value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setEnableTrickplayNull() {
+	m_enableTrickplay = std::nullopt;
+}
+
+
 const float &GetMasterHlsVideoPlaylistParams::framerate() const {
 	return m_framerate.value();
 }
@@ -19950,6 +18391,27 @@ void GetMasterHlsVideoPlaylistParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &GetMasterHlsVideoPlaylistParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetMasterHlsVideoPlaylistParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &GetMasterHlsVideoPlaylistParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -19992,6 +18454,27 @@ void GetMasterHlsVideoPlaylistParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &GetMasterHlsVideoPlaylistParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetMasterHlsVideoPlaylistParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetMasterHlsVideoPlaylistParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const qint32 &GetMasterHlsVideoPlaylistParams::minSegments() const {
 	return m_minSegments.value();
 }
@@ -20460,71 +18943,6 @@ void GetMediaFoldersParams::setIsHiddenNull() {
 
 
 
-// GetMediaInfoImageParams
-
-const QString &GetMediaInfoImageParams::name() const {
-	return m_name;
-}
-
-void GetMediaInfoImageParams::setName(QString newName) {
-	m_name = newName;
-}
-
-
-const QString &GetMediaInfoImageParams::theme() const {
-	return m_theme;
-}
-
-void GetMediaInfoImageParams::setTheme(QString newTheme) {
-	m_theme = newTheme;
-}
-
-
-
-
-// GetMediaInfoImagesParams
-
-
-
-// GetMediaReceiverRegistrarParams
-
-const QString &GetMediaReceiverRegistrarParams::serverId() const {
-	return m_serverId;
-}
-
-void GetMediaReceiverRegistrarParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetMediaReceiverRegistrar_2Params
-
-const QString &GetMediaReceiverRegistrar_2Params::serverId() const {
-	return m_serverId;
-}
-
-void GetMediaReceiverRegistrar_2Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// GetMediaReceiverRegistrar_3Params
-
-const QString &GetMediaReceiverRegistrar_3Params::serverId() const {
-	return m_serverId;
-}
-
-void GetMediaReceiverRegistrar_3Params::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
 // GetMetadataEditorInfoParams
 
 const QString &GetMetadataEditorInfoParams::itemId() const {
@@ -20740,27 +19158,6 @@ void GetMusicGenreImageParams::setName(QString newName) {
 }
 
 
-const bool &GetMusicGenreImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetMusicGenreImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetMusicGenreImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetMusicGenreImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetMusicGenreImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -20803,24 +19200,45 @@ void GetMusicGenreImageParams::setBlurNull() {
 }
 
 
-const bool &GetMusicGenreImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetMusicGenreImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetMusicGenreImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetMusicGenreImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetMusicGenreImageParams::cropWhitespaceNull() const {
+bool GetMusicGenreImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetMusicGenreImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetMusicGenreImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetMusicGenreImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetMusicGenreImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetMusicGenreImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetMusicGenreImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -21086,27 +19504,6 @@ void GetMusicGenreImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &GetMusicGenreImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetMusicGenreImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetMusicGenreImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetMusicGenreImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetMusicGenreImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -21149,24 +19546,45 @@ void GetMusicGenreImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &GetMusicGenreImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetMusicGenreImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetMusicGenreImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetMusicGenreImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetMusicGenreImageByIndexParams::cropWhitespaceNull() const {
+bool GetMusicGenreImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetMusicGenreImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetMusicGenreImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetMusicGenreImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetMusicGenreImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetMusicGenreImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetMusicGenreImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -21414,7 +19832,7 @@ void GetMusicGenresParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetMusicGenresParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -21447,11 +19865,11 @@ void GetMusicGenresParams::setEnableTotalRecordCountNull() {
 }
 
 
-const QStringList &GetMusicGenresParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetMusicGenresParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetMusicGenresParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetMusicGenresParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -21510,11 +19928,11 @@ void GetMusicGenresParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetMusicGenresParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetMusicGenresParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetMusicGenresParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetMusicGenresParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -21678,6 +20096,48 @@ void GetMusicGenresParams::setSearchTermNull() {
 }
 
 
+const QList<ItemSortBy> &GetMusicGenresParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetMusicGenresParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetMusicGenresParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetMusicGenresParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetMusicGenresParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetMusicGenresParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetMusicGenresParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetMusicGenresParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const qint32 &GetMusicGenresParams::startIndex() const {
 	return m_startIndex.value();
 }
@@ -21796,24 +20256,66 @@ void GetNextUpParams::setEnableImageTypesNull() {
 }
 
 
-const bool &GetNextUpParams::enableImges() const {
-	return m_enableImges.value();
+const bool &GetNextUpParams::enableImages() const {
+	return m_enableImages.value();
 }
 
-void GetNextUpParams::setEnableImges(bool newEnableImges)  {
-	m_enableImges = newEnableImges;
+void GetNextUpParams::setEnableImages(bool newEnableImages)  {
+	m_enableImages = newEnableImages;
 }
 
-bool GetNextUpParams::enableImgesNull() const {
+bool GetNextUpParams::enableImagesNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_enableImges.has_value();
+	return !m_enableImages.has_value();
 }
 
-void GetNextUpParams::setEnableImgesNull() {
-	m_enableImges = std::nullopt;
+void GetNextUpParams::setEnableImagesNull() {
+	m_enableImages = std::nullopt;
+}
+
+
+const bool &GetNextUpParams::enableResumable() const {
+	return m_enableResumable.value();
+}
+
+void GetNextUpParams::setEnableResumable(bool newEnableResumable)  {
+	m_enableResumable = newEnableResumable;
+}
+
+bool GetNextUpParams::enableResumableNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableResumable.has_value();
+}
+
+void GetNextUpParams::setEnableResumableNull() {
+	m_enableResumable = std::nullopt;
+}
+
+
+const bool &GetNextUpParams::enableRewatching() const {
+	return m_enableRewatching.value();
+}
+
+void GetNextUpParams::setEnableRewatching(bool newEnableRewatching)  {
+	m_enableRewatching = newEnableRewatching;
+}
+
+bool GetNextUpParams::enableRewatchingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableRewatching.has_value();
+}
+
+void GetNextUpParams::setEnableRewatchingNull() {
+	m_enableRewatching = std::nullopt;
 }
 
 
@@ -21922,6 +20424,27 @@ void GetNextUpParams::setLimitNull() {
 }
 
 
+const QDateTime &GetNextUpParams::nextUpDateCutoff() const {
+	return m_nextUpDateCutoff;
+}
+
+void GetNextUpParams::setNextUpDateCutoff(QDateTime newNextUpDateCutoff)  {
+	m_nextUpDateCutoff = newNextUpDateCutoff;
+}
+
+bool GetNextUpParams::nextUpDateCutoffNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_nextUpDateCutoff.isNull();
+}
+
+void GetNextUpParams::setNextUpDateCutoffNull() {
+	m_nextUpDateCutoff= QDateTime();
+}
+
+
 const QString &GetNextUpParams::parentId() const {
 	return m_parentId;
 }
@@ -22008,40 +20531,6 @@ void GetNextUpParams::setUserIdNull() {
 
 
 
-// GetNotificationServicesParams
-
-
-
-// GetNotificationTypesParams
-
-
-
-// GetNotificationsParams
-
-const QString &GetNotificationsParams::userId() const {
-	return m_userId;
-}
-
-void GetNotificationsParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-
-
-// GetNotificationsSummaryParams
-
-const QString &GetNotificationsSummaryParams::userId() const {
-	return m_userId;
-}
-
-void GetNotificationsSummaryParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-
-
 // GetPackageInfoParams
 
 const QString &GetPackageInfoParams::name() const {
@@ -22155,27 +20644,6 @@ void GetPersonImageParams::setName(QString newName) {
 }
 
 
-const bool &GetPersonImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetPersonImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetPersonImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetPersonImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetPersonImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -22218,24 +20686,45 @@ void GetPersonImageParams::setBlurNull() {
 }
 
 
-const bool &GetPersonImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetPersonImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetPersonImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetPersonImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetPersonImageParams::cropWhitespaceNull() const {
+bool GetPersonImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetPersonImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetPersonImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetPersonImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetPersonImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetPersonImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetPersonImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -22501,27 +20990,6 @@ void GetPersonImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &GetPersonImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetPersonImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetPersonImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetPersonImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetPersonImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -22564,24 +21032,45 @@ void GetPersonImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &GetPersonImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetPersonImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetPersonImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetPersonImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetPersonImageByIndexParams::cropWhitespaceNull() const {
+bool GetPersonImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetPersonImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetPersonImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetPersonImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetPersonImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetPersonImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetPersonImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -22863,7 +21352,7 @@ void GetPersonsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetPersonsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -23110,10 +21599,35 @@ const QString &GetPlaybackInfoParams::userId() const {
 	return m_userId;
 }
 
-void GetPlaybackInfoParams::setUserId(QString newUserId) {
+void GetPlaybackInfoParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetPlaybackInfoParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetPlaybackInfoParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
+// GetPlaylistParams
+
+const QString &GetPlaylistParams::playlistId() const {
+	return m_playlistId;
+}
+
+void GetPlaylistParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
 
 
 
@@ -23128,15 +21642,6 @@ void GetPlaylistItemsParams::setPlaylistId(QString newPlaylistId) {
 }
 
 
-const QString &GetPlaylistItemsParams::userId() const {
-	return m_userId;
-}
-
-void GetPlaylistItemsParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const QList<ImageType> &GetPlaylistItemsParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
@@ -23284,6 +21789,62 @@ void GetPlaylistItemsParams::setStartIndexNull() {
 }
 
 
+const QString &GetPlaylistItemsParams::userId() const {
+	return m_userId;
+}
+
+void GetPlaylistItemsParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetPlaylistItemsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetPlaylistItemsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
+// GetPlaylistUserParams
+
+const QString &GetPlaylistUserParams::playlistId() const {
+	return m_playlistId;
+}
+
+void GetPlaylistUserParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
+const QString &GetPlaylistUserParams::userId() const {
+	return m_userId;
+}
+
+void GetPlaylistUserParams::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+
+
+
+
+// GetPlaylistUsersParams
+
+const QString &GetPlaylistUsersParams::playlistId() const {
+	return m_playlistId;
+}
+
+void GetPlaylistUsersParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
 
 
 // GetPluginConfigurationParams
@@ -23310,11 +21871,11 @@ void GetPluginImageParams::setPluginId(QString newPluginId) {
 }
 
 
-const QSharedPointer<Version> &GetPluginImageParams::version() const {
+const QString &GetPluginImageParams::version() const {
 	return m_version;
 }
 
-void GetPluginImageParams::setVersion(QSharedPointer<Version> newVersion) {
+void GetPluginImageParams::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
 
@@ -23654,23 +22215,6 @@ void GetPostedPlaybackInfoParams::setBody(QSharedPointer<PlaybackInfoDto> newBod
 
 
 
-// GetProfileParams
-
-const QString &GetProfileParams::profileId() const {
-	return m_profileId;
-}
-
-void GetProfileParams::setProfileId(QString newProfileId) {
-	m_profileId = newProfileId;
-}
-
-
-
-
-// GetProfileInfosParams
-
-
-
 // GetProgramParams
 
 const QString &GetProgramParams::programId() const {
@@ -23728,11 +22272,11 @@ void GetProgramsParams::setBody(QSharedPointer<GetProgramsDto> newBody) {
 
 // GetQueryFiltersParams
 
-const QStringList &GetQueryFiltersParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetQueryFiltersParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetQueryFiltersParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetQueryFiltersParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -23942,11 +22486,11 @@ void GetQueryFiltersParams::setUserIdNull() {
 
 // GetQueryFiltersLegacyParams
 
-const QStringList &GetQueryFiltersLegacyParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetQueryFiltersLegacyParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetQueryFiltersLegacyParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetQueryFiltersLegacyParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -23963,11 +22507,11 @@ void GetQueryFiltersLegacyParams::setIncludeItemTypesNull() {
 }
 
 
-const QStringList &GetQueryFiltersLegacyParams::mediaTypes() const {
+const QList<MediaType> &GetQueryFiltersLegacyParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetQueryFiltersLegacyParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetQueryFiltersLegacyParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -24028,30 +22572,21 @@ void GetQueryFiltersLegacyParams::setUserIdNull() {
 
 
 
-// GetRatingImageParams
+// GetQuickConnectEnabledParams
 
-const QString &GetRatingImageParams::name() const {
-	return m_name;
+
+
+// GetQuickConnectStateParams
+
+const QString &GetQuickConnectStateParams::secret() const {
+	return m_secret;
 }
 
-void GetRatingImageParams::setName(QString newName) {
-	m_name = newName;
+void GetQuickConnectStateParams::setSecret(QString newSecret) {
+	m_secret = newSecret;
 }
 
 
-const QString &GetRatingImageParams::theme() const {
-	return m_theme;
-}
-
-void GetRatingImageParams::setTheme(QString newTheme) {
-	m_theme = newTheme;
-}
-
-
-
-
-// GetRatingImagesParams
-
 
 
 // GetRecommendedProgramsParams
@@ -25192,19 +23727,6 @@ void GetRecordingsSeriesParams::setUserIdNull() {
 
 
 
-// GetRemoteImageParams
-
-const QString &GetRemoteImageParams::imageUrl() const {
-	return m_imageUrl;
-}
-
-void GetRemoteImageParams::setImageUrl(QString newImageUrl) {
-	m_imageUrl = newImageUrl;
-}
-
-
-
-
 // GetRemoteImageProvidersParams
 
 const QString &GetRemoteImageProvidersParams::itemId() const {
@@ -25336,23 +23858,14 @@ void GetRemoteImagesParams::setTypeNull() {
 
 
 
-// GetRemoteSearchImageParams
+// GetRemoteLyricsParams
 
-const QString &GetRemoteSearchImageParams::imageUrl() const {
-	return m_imageUrl;
+const QString &GetRemoteLyricsParams::lyricId() const {
+	return m_lyricId;
 }
 
-void GetRemoteSearchImageParams::setImageUrl(QString newImageUrl) {
-	m_imageUrl = newImageUrl;
-}
-
-
-const QString &GetRemoteSearchImageParams::providerName() const {
-	return m_providerName;
-}
-
-void GetRemoteSearchImageParams::setProviderName(QString newProviderName) {
-	m_providerName = newProviderName;
+void GetRemoteLyricsParams::setLyricId(QString newLyricId) {
+	m_lyricId = newLyricId;
 }
 
 
@@ -25360,12 +23873,12 @@ void GetRemoteSearchImageParams::setProviderName(QString newProviderName) {
 
 // GetRemoteSubtitlesParams
 
-const QString &GetRemoteSubtitlesParams::jellyfinId() const {
-	return m_jellyfinId;
+const QString &GetRemoteSubtitlesParams::subtitleId() const {
+	return m_subtitleId;
 }
 
-void GetRemoteSubtitlesParams::setJellyfinId(QString newJellyfinId) {
-	m_jellyfinId = newJellyfinId;
+void GetRemoteSubtitlesParams::setSubtitleId(QString newSubtitleId) {
+	m_subtitleId = newSubtitleId;
 }
 
 
@@ -25377,15 +23890,6 @@ void GetRemoteSubtitlesParams::setJellyfinId(QString newJellyfinId) {
 
 // GetResumeItemsParams
 
-const QString &GetResumeItemsParams::userId() const {
-	return m_userId;
-}
-
-void GetResumeItemsParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const QList<ImageType> &GetResumeItemsParams::enableImageTypes() const {
 	return m_enableImageTypes;
 }
@@ -25416,7 +23920,7 @@ void GetResumeItemsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetResumeItemsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -25470,11 +23974,32 @@ void GetResumeItemsParams::setEnableUserDataNull() {
 }
 
 
-const QStringList &GetResumeItemsParams::excludeItemTypes() const {
+const bool &GetResumeItemsParams::excludeActiveSessions() const {
+	return m_excludeActiveSessions.value();
+}
+
+void GetResumeItemsParams::setExcludeActiveSessions(bool newExcludeActiveSessions)  {
+	m_excludeActiveSessions = newExcludeActiveSessions;
+}
+
+bool GetResumeItemsParams::excludeActiveSessionsNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_excludeActiveSessions.has_value();
+}
+
+void GetResumeItemsParams::setExcludeActiveSessionsNull() {
+	m_excludeActiveSessions = std::nullopt;
+}
+
+
+const QList<BaseItemKind> &GetResumeItemsParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetResumeItemsParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetResumeItemsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -25533,11 +24058,11 @@ void GetResumeItemsParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetResumeItemsParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetResumeItemsParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetResumeItemsParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetResumeItemsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -25575,11 +24100,11 @@ void GetResumeItemsParams::setLimitNull() {
 }
 
 
-const QStringList &GetResumeItemsParams::mediaTypes() const {
+const QList<MediaType> &GetResumeItemsParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetResumeItemsParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetResumeItemsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -25659,6 +24184,27 @@ void GetResumeItemsParams::setStartIndexNull() {
 }
 
 
+const QString &GetResumeItemsParams::userId() const {
+	return m_userId;
+}
+
+void GetResumeItemsParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetResumeItemsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetResumeItemsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // GetRootFolderParams
@@ -25667,10 +24213,22 @@ const QString &GetRootFolderParams::userId() const {
 	return m_userId;
 }
 
-void GetRootFolderParams::setUserId(QString newUserId) {
+void GetRootFolderParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetRootFolderParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetRootFolderParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -25678,6 +24236,376 @@ void GetRootFolderParams::setUserId(QString newUserId) {
 
 
 
+// GetSearchHintsParams
+
+const QString &GetSearchHintsParams::searchTerm() const {
+	return m_searchTerm;
+}
+
+void GetSearchHintsParams::setSearchTerm(QString newSearchTerm) {
+	m_searchTerm = newSearchTerm;
+}
+
+
+const QList<BaseItemKind> &GetSearchHintsParams::excludeItemTypes() const {
+	return m_excludeItemTypes;
+}
+
+void GetSearchHintsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
+	m_excludeItemTypes = newExcludeItemTypes;
+}
+
+bool GetSearchHintsParams::excludeItemTypesNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_excludeItemTypes.size() == 0;
+}
+
+void GetSearchHintsParams::setExcludeItemTypesNull() {
+	m_excludeItemTypes.clear();
+}
+
+
+const bool &GetSearchHintsParams::includeArtists() const {
+	return m_includeArtists.value();
+}
+
+void GetSearchHintsParams::setIncludeArtists(bool newIncludeArtists)  {
+	m_includeArtists = newIncludeArtists;
+}
+
+bool GetSearchHintsParams::includeArtistsNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_includeArtists.has_value();
+}
+
+void GetSearchHintsParams::setIncludeArtistsNull() {
+	m_includeArtists = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::includeGenres() const {
+	return m_includeGenres.value();
+}
+
+void GetSearchHintsParams::setIncludeGenres(bool newIncludeGenres)  {
+	m_includeGenres = newIncludeGenres;
+}
+
+bool GetSearchHintsParams::includeGenresNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_includeGenres.has_value();
+}
+
+void GetSearchHintsParams::setIncludeGenresNull() {
+	m_includeGenres = std::nullopt;
+}
+
+
+const QList<BaseItemKind> &GetSearchHintsParams::includeItemTypes() const {
+	return m_includeItemTypes;
+}
+
+void GetSearchHintsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
+	m_includeItemTypes = newIncludeItemTypes;
+}
+
+bool GetSearchHintsParams::includeItemTypesNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_includeItemTypes.size() == 0;
+}
+
+void GetSearchHintsParams::setIncludeItemTypesNull() {
+	m_includeItemTypes.clear();
+}
+
+
+const bool &GetSearchHintsParams::includeMedia() const {
+	return m_includeMedia.value();
+}
+
+void GetSearchHintsParams::setIncludeMedia(bool newIncludeMedia)  {
+	m_includeMedia = newIncludeMedia;
+}
+
+bool GetSearchHintsParams::includeMediaNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_includeMedia.has_value();
+}
+
+void GetSearchHintsParams::setIncludeMediaNull() {
+	m_includeMedia = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::includePeople() const {
+	return m_includePeople.value();
+}
+
+void GetSearchHintsParams::setIncludePeople(bool newIncludePeople)  {
+	m_includePeople = newIncludePeople;
+}
+
+bool GetSearchHintsParams::includePeopleNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_includePeople.has_value();
+}
+
+void GetSearchHintsParams::setIncludePeopleNull() {
+	m_includePeople = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::includeStudios() const {
+	return m_includeStudios.value();
+}
+
+void GetSearchHintsParams::setIncludeStudios(bool newIncludeStudios)  {
+	m_includeStudios = newIncludeStudios;
+}
+
+bool GetSearchHintsParams::includeStudiosNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_includeStudios.has_value();
+}
+
+void GetSearchHintsParams::setIncludeStudiosNull() {
+	m_includeStudios = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::isKids() const {
+	return m_isKids.value();
+}
+
+void GetSearchHintsParams::setIsKids(bool newIsKids)  {
+	m_isKids = newIsKids;
+}
+
+bool GetSearchHintsParams::isKidsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isKids.has_value();
+}
+
+void GetSearchHintsParams::setIsKidsNull() {
+	m_isKids = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::isMovie() const {
+	return m_isMovie.value();
+}
+
+void GetSearchHintsParams::setIsMovie(bool newIsMovie)  {
+	m_isMovie = newIsMovie;
+}
+
+bool GetSearchHintsParams::isMovieNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isMovie.has_value();
+}
+
+void GetSearchHintsParams::setIsMovieNull() {
+	m_isMovie = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::isNews() const {
+	return m_isNews.value();
+}
+
+void GetSearchHintsParams::setIsNews(bool newIsNews)  {
+	m_isNews = newIsNews;
+}
+
+bool GetSearchHintsParams::isNewsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isNews.has_value();
+}
+
+void GetSearchHintsParams::setIsNewsNull() {
+	m_isNews = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::isSeries() const {
+	return m_isSeries.value();
+}
+
+void GetSearchHintsParams::setIsSeries(bool newIsSeries)  {
+	m_isSeries = newIsSeries;
+}
+
+bool GetSearchHintsParams::isSeriesNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSeries.has_value();
+}
+
+void GetSearchHintsParams::setIsSeriesNull() {
+	m_isSeries = std::nullopt;
+}
+
+
+const bool &GetSearchHintsParams::isSports() const {
+	return m_isSports.value();
+}
+
+void GetSearchHintsParams::setIsSports(bool newIsSports)  {
+	m_isSports = newIsSports;
+}
+
+bool GetSearchHintsParams::isSportsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSports.has_value();
+}
+
+void GetSearchHintsParams::setIsSportsNull() {
+	m_isSports = std::nullopt;
+}
+
+
+const qint32 &GetSearchHintsParams::limit() const {
+	return m_limit.value();
+}
+
+void GetSearchHintsParams::setLimit(qint32 newLimit)  {
+	m_limit = newLimit;
+}
+
+bool GetSearchHintsParams::limitNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_limit.has_value();
+}
+
+void GetSearchHintsParams::setLimitNull() {
+	m_limit = std::nullopt;
+}
+
+
+const QList<MediaType> &GetSearchHintsParams::mediaTypes() const {
+	return m_mediaTypes;
+}
+
+void GetSearchHintsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
+	m_mediaTypes = newMediaTypes;
+}
+
+bool GetSearchHintsParams::mediaTypesNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_mediaTypes.size() == 0;
+}
+
+void GetSearchHintsParams::setMediaTypesNull() {
+	m_mediaTypes.clear();
+}
+
+
+const QString &GetSearchHintsParams::parentId() const {
+	return m_parentId;
+}
+
+void GetSearchHintsParams::setParentId(QString newParentId)  {
+	m_parentId = newParentId;
+}
+
+bool GetSearchHintsParams::parentIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_parentId.isNull();
+}
+
+void GetSearchHintsParams::setParentIdNull() {
+	m_parentId.clear();
+}
+
+
+const qint32 &GetSearchHintsParams::startIndex() const {
+	return m_startIndex.value();
+}
+
+void GetSearchHintsParams::setStartIndex(qint32 newStartIndex)  {
+	m_startIndex = newStartIndex;
+}
+
+bool GetSearchHintsParams::startIndexNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_startIndex.has_value();
+}
+
+void GetSearchHintsParams::setStartIndexNull() {
+	m_startIndex = std::nullopt;
+}
+
+
+const QString &GetSearchHintsParams::userId() const {
+	return m_userId;
+}
+
+void GetSearchHintsParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetSearchHintsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetSearchHintsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
 // GetSeasonsParams
 
 const QString &GetSeasonsParams::seriesId() const {
@@ -26620,10 +25548,278 @@ const QString &GetSpecialFeaturesParams::userId() const {
 	return m_userId;
 }
 
-void GetSpecialFeaturesParams::setUserId(QString newUserId) {
+void GetSpecialFeaturesParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool GetSpecialFeaturesParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetSpecialFeaturesParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+
+
+// GetSplashscreenParams
+
+const QString &GetSplashscreenParams::backgroundColor() const {
+	return m_backgroundColor;
+}
+
+void GetSplashscreenParams::setBackgroundColor(QString newBackgroundColor)  {
+	m_backgroundColor = newBackgroundColor;
+}
+
+bool GetSplashscreenParams::backgroundColorNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_backgroundColor.isNull();
+}
+
+void GetSplashscreenParams::setBackgroundColorNull() {
+	m_backgroundColor.clear();
+}
+
+
+const qint32 &GetSplashscreenParams::blur() const {
+	return m_blur.value();
+}
+
+void GetSplashscreenParams::setBlur(qint32 newBlur)  {
+	m_blur = newBlur;
+}
+
+bool GetSplashscreenParams::blurNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_blur.has_value();
+}
+
+void GetSplashscreenParams::setBlurNull() {
+	m_blur = std::nullopt;
+}
+
+
+const qint32 &GetSplashscreenParams::fillHeight() const {
+	return m_fillHeight.value();
+}
+
+void GetSplashscreenParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
+}
+
+bool GetSplashscreenParams::fillHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillHeight.has_value();
+}
+
+void GetSplashscreenParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetSplashscreenParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetSplashscreenParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetSplashscreenParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetSplashscreenParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
+}
+
+
+const QString &GetSplashscreenParams::foregroundLayer() const {
+	return m_foregroundLayer;
+}
+
+void GetSplashscreenParams::setForegroundLayer(QString newForegroundLayer)  {
+	m_foregroundLayer = newForegroundLayer;
+}
+
+bool GetSplashscreenParams::foregroundLayerNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_foregroundLayer.isNull();
+}
+
+void GetSplashscreenParams::setForegroundLayerNull() {
+	m_foregroundLayer.clear();
+}
+
+
+const ImageFormat &GetSplashscreenParams::format() const {
+	return m_format;
+}
+
+void GetSplashscreenParams::setFormat(ImageFormat newFormat)  {
+	m_format = newFormat;
+}
+
+bool GetSplashscreenParams::formatNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_format== ImageFormat::EnumNotSet;
+}
+
+void GetSplashscreenParams::setFormatNull() {
+	m_format= ImageFormat::EnumNotSet;
+}
+
+
+const qint32 &GetSplashscreenParams::height() const {
+	return m_height.value();
+}
+
+void GetSplashscreenParams::setHeight(qint32 newHeight)  {
+	m_height = newHeight;
+}
+
+bool GetSplashscreenParams::heightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_height.has_value();
+}
+
+void GetSplashscreenParams::setHeightNull() {
+	m_height = std::nullopt;
+}
+
+
+const qint32 &GetSplashscreenParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetSplashscreenParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetSplashscreenParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetSplashscreenParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
+const qint32 &GetSplashscreenParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetSplashscreenParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetSplashscreenParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetSplashscreenParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
+const qint32 &GetSplashscreenParams::quality() const {
+	return m_quality.value();
+}
+
+void GetSplashscreenParams::setQuality(qint32 newQuality)  {
+	m_quality = newQuality;
+}
+
+bool GetSplashscreenParams::qualityNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_quality.has_value();
+}
+
+void GetSplashscreenParams::setQualityNull() {
+	m_quality = std::nullopt;
+}
+
+
+const QString &GetSplashscreenParams::tag() const {
+	return m_tag;
+}
+
+void GetSplashscreenParams::setTag(QString newTag)  {
+	m_tag = newTag;
+}
+
+bool GetSplashscreenParams::tagNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_tag.isNull();
+}
+
+void GetSplashscreenParams::setTagNull() {
+	m_tag.clear();
+}
+
+
+const qint32 &GetSplashscreenParams::width() const {
+	return m_width.value();
+}
+
+void GetSplashscreenParams::setWidth(qint32 newWidth)  {
+	m_width = newWidth;
+}
+
+bool GetSplashscreenParams::widthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_width.has_value();
+}
+
+void GetSplashscreenParams::setWidthNull() {
+	m_width = std::nullopt;
+}
+
 
 
 
@@ -26631,10 +25827,6 @@ void GetSpecialFeaturesParams::setUserId(QString newUserId) {
 
 
 
-// GetStatusParams
-
-
-
 // GetStudioParams
 
 const QString &GetStudioParams::name() const {
@@ -26689,27 +25881,6 @@ void GetStudioImageParams::setName(QString newName) {
 }
 
 
-const bool &GetStudioImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetStudioImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetStudioImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetStudioImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetStudioImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -26752,24 +25923,45 @@ void GetStudioImageParams::setBlurNull() {
 }
 
 
-const bool &GetStudioImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetStudioImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetStudioImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetStudioImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetStudioImageParams::cropWhitespaceNull() const {
+bool GetStudioImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetStudioImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetStudioImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetStudioImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetStudioImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetStudioImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetStudioImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -27035,27 +26227,6 @@ void GetStudioImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &GetStudioImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetStudioImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetStudioImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetStudioImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetStudioImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -27098,24 +26269,45 @@ void GetStudioImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &GetStudioImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetStudioImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetStudioImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetStudioImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetStudioImageByIndexParams::cropWhitespaceNull() const {
+bool GetStudioImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetStudioImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetStudioImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetStudioImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetStudioImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetStudioImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetStudioImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -27363,7 +26555,7 @@ void GetStudiosParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetStudiosParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -27417,11 +26609,11 @@ void GetStudiosParams::setEnableUserDataNull() {
 }
 
 
-const QStringList &GetStudiosParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetStudiosParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetStudiosParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetStudiosParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -27480,11 +26672,11 @@ void GetStudiosParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetStudiosParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetStudiosParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetStudiosParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetStudiosParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -27694,39 +26886,39 @@ void GetStudiosParams::setUserIdNull() {
 
 // GetSubtitleParams
 
-const QString &GetSubtitleParams::format() const {
-	return m_format;
+const QString &GetSubtitleParams::routeFormat() const {
+	return m_routeFormat;
 }
 
-void GetSubtitleParams::setFormat(QString newFormat) {
-	m_format = newFormat;
+void GetSubtitleParams::setRouteFormat(QString newRouteFormat) {
+	m_routeFormat = newRouteFormat;
 }
 
 
-const qint32 &GetSubtitleParams::index() const {
-	return m_index;
+const qint32 &GetSubtitleParams::routeIndex() const {
+	return m_routeIndex;
 }
 
-void GetSubtitleParams::setIndex(qint32 newIndex) {
-	m_index = newIndex;
+void GetSubtitleParams::setRouteIndex(qint32 newRouteIndex) {
+	m_routeIndex = newRouteIndex;
 }
 
 
-const QString &GetSubtitleParams::itemId() const {
-	return m_itemId;
+const QString &GetSubtitleParams::routeItemId() const {
+	return m_routeItemId;
 }
 
-void GetSubtitleParams::setItemId(QString newItemId) {
-	m_itemId = newItemId;
+void GetSubtitleParams::setRouteItemId(QString newRouteItemId) {
+	m_routeItemId = newRouteItemId;
 }
 
 
-const QString &GetSubtitleParams::mediaSourceId() const {
-	return m_mediaSourceId;
+const QString &GetSubtitleParams::routeMediaSourceId() const {
+	return m_routeMediaSourceId;
 }
 
-void GetSubtitleParams::setMediaSourceId(QString newMediaSourceId) {
-	m_mediaSourceId = newMediaSourceId;
+void GetSubtitleParams::setRouteMediaSourceId(QString newRouteMediaSourceId) {
+	m_routeMediaSourceId = newRouteMediaSourceId;
 }
 
 
@@ -27793,6 +26985,90 @@ void GetSubtitleParams::setEndPositionTicksNull() {
 }
 
 
+const QString &GetSubtitleParams::format() const {
+	return m_format;
+}
+
+void GetSubtitleParams::setFormat(QString newFormat)  {
+	m_format = newFormat;
+}
+
+bool GetSubtitleParams::formatNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_format.isNull();
+}
+
+void GetSubtitleParams::setFormatNull() {
+	m_format.clear();
+}
+
+
+const qint32 &GetSubtitleParams::index() const {
+	return m_index.value();
+}
+
+void GetSubtitleParams::setIndex(qint32 newIndex)  {
+	m_index = newIndex;
+}
+
+bool GetSubtitleParams::indexNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_index.has_value();
+}
+
+void GetSubtitleParams::setIndexNull() {
+	m_index = std::nullopt;
+}
+
+
+const QString &GetSubtitleParams::itemId() const {
+	return m_itemId;
+}
+
+void GetSubtitleParams::setItemId(QString newItemId)  {
+	m_itemId = newItemId;
+}
+
+bool GetSubtitleParams::itemIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_itemId.isNull();
+}
+
+void GetSubtitleParams::setItemIdNull() {
+	m_itemId.clear();
+}
+
+
+const QString &GetSubtitleParams::mediaSourceId() const {
+	return m_mediaSourceId;
+}
+
+void GetSubtitleParams::setMediaSourceId(QString newMediaSourceId)  {
+	m_mediaSourceId = newMediaSourceId;
+}
+
+bool GetSubtitleParams::mediaSourceIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_mediaSourceId.isNull();
+}
+
+void GetSubtitleParams::setMediaSourceIdNull() {
+	m_mediaSourceId.clear();
+}
+
+
 const qint64 &GetSubtitleParams::startPositionTicks() const {
 	return m_startPositionTicks.value();
 }
@@ -27858,48 +27134,48 @@ void GetSubtitlePlaylistParams::setSegmentLength(qint32 newSegmentLength) {
 
 // GetSubtitleWithTicksParams
 
-const QString &GetSubtitleWithTicksParams::format() const {
-	return m_format;
+const QString &GetSubtitleWithTicksParams::routeFormat() const {
+	return m_routeFormat;
 }
 
-void GetSubtitleWithTicksParams::setFormat(QString newFormat) {
-	m_format = newFormat;
+void GetSubtitleWithTicksParams::setRouteFormat(QString newRouteFormat) {
+	m_routeFormat = newRouteFormat;
 }
 
 
-const qint32 &GetSubtitleWithTicksParams::index() const {
-	return m_index;
+const qint32 &GetSubtitleWithTicksParams::routeIndex() const {
+	return m_routeIndex;
 }
 
-void GetSubtitleWithTicksParams::setIndex(qint32 newIndex) {
-	m_index = newIndex;
+void GetSubtitleWithTicksParams::setRouteIndex(qint32 newRouteIndex) {
+	m_routeIndex = newRouteIndex;
 }
 
 
-const QString &GetSubtitleWithTicksParams::itemId() const {
-	return m_itemId;
+const QString &GetSubtitleWithTicksParams::routeItemId() const {
+	return m_routeItemId;
 }
 
-void GetSubtitleWithTicksParams::setItemId(QString newItemId) {
-	m_itemId = newItemId;
+void GetSubtitleWithTicksParams::setRouteItemId(QString newRouteItemId) {
+	m_routeItemId = newRouteItemId;
 }
 
 
-const QString &GetSubtitleWithTicksParams::mediaSourceId() const {
-	return m_mediaSourceId;
+const QString &GetSubtitleWithTicksParams::routeMediaSourceId() const {
+	return m_routeMediaSourceId;
 }
 
-void GetSubtitleWithTicksParams::setMediaSourceId(QString newMediaSourceId) {
-	m_mediaSourceId = newMediaSourceId;
+void GetSubtitleWithTicksParams::setRouteMediaSourceId(QString newRouteMediaSourceId) {
+	m_routeMediaSourceId = newRouteMediaSourceId;
 }
 
 
-const qint64 &GetSubtitleWithTicksParams::startPositionTicks() const {
-	return m_startPositionTicks;
+const qint64 &GetSubtitleWithTicksParams::routeStartPositionTicks() const {
+	return m_routeStartPositionTicks;
 }
 
-void GetSubtitleWithTicksParams::setStartPositionTicks(qint64 newStartPositionTicks) {
-	m_startPositionTicks = newStartPositionTicks;
+void GetSubtitleWithTicksParams::setRouteStartPositionTicks(qint64 newRouteStartPositionTicks) {
+	m_routeStartPositionTicks = newRouteStartPositionTicks;
 }
 
 
@@ -27966,19 +27242,115 @@ void GetSubtitleWithTicksParams::setEndPositionTicksNull() {
 }
 
 
+const QString &GetSubtitleWithTicksParams::format() const {
+	return m_format;
+}
+
+void GetSubtitleWithTicksParams::setFormat(QString newFormat)  {
+	m_format = newFormat;
+}
+
+bool GetSubtitleWithTicksParams::formatNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_format.isNull();
+}
+
+void GetSubtitleWithTicksParams::setFormatNull() {
+	m_format.clear();
+}
+
+
+const qint32 &GetSubtitleWithTicksParams::index() const {
+	return m_index.value();
+}
+
+void GetSubtitleWithTicksParams::setIndex(qint32 newIndex)  {
+	m_index = newIndex;
+}
+
+bool GetSubtitleWithTicksParams::indexNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_index.has_value();
+}
+
+void GetSubtitleWithTicksParams::setIndexNull() {
+	m_index = std::nullopt;
+}
+
+
+const QString &GetSubtitleWithTicksParams::itemId() const {
+	return m_itemId;
+}
+
+void GetSubtitleWithTicksParams::setItemId(QString newItemId)  {
+	m_itemId = newItemId;
+}
+
+bool GetSubtitleWithTicksParams::itemIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_itemId.isNull();
+}
+
+void GetSubtitleWithTicksParams::setItemIdNull() {
+	m_itemId.clear();
+}
+
+
+const QString &GetSubtitleWithTicksParams::mediaSourceId() const {
+	return m_mediaSourceId;
+}
+
+void GetSubtitleWithTicksParams::setMediaSourceId(QString newMediaSourceId)  {
+	m_mediaSourceId = newMediaSourceId;
+}
+
+bool GetSubtitleWithTicksParams::mediaSourceIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_mediaSourceId.isNull();
+}
+
+void GetSubtitleWithTicksParams::setMediaSourceIdNull() {
+	m_mediaSourceId.clear();
+}
+
+
+const qint64 &GetSubtitleWithTicksParams::startPositionTicks() const {
+	return m_startPositionTicks.value();
+}
+
+void GetSubtitleWithTicksParams::setStartPositionTicks(qint64 newStartPositionTicks)  {
+	m_startPositionTicks = newStartPositionTicks;
+}
+
+bool GetSubtitleWithTicksParams::startPositionTicksNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_startPositionTicks.has_value();
+}
+
+void GetSubtitleWithTicksParams::setStartPositionTicksNull() {
+	m_startPositionTicks = std::nullopt;
+}
+
+
 
 
 // GetSuggestionsParams
 
-const QString &GetSuggestionsParams::userId() const {
-	return m_userId;
-}
-
-void GetSuggestionsParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const bool &GetSuggestionsParams::enableTotalRecordCount() const {
 	return m_enableTotalRecordCount.value();
 }
@@ -28021,11 +27393,11 @@ void GetSuggestionsParams::setLimitNull() {
 }
 
 
-const QStringList &GetSuggestionsParams::mediaType() const {
+const QList<MediaType> &GetSuggestionsParams::mediaType() const {
 	return m_mediaType;
 }
 
-void GetSuggestionsParams::setMediaType(QStringList newMediaType)  {
+void GetSuggestionsParams::setMediaType(QList<MediaType> newMediaType)  {
 	m_mediaType = newMediaType;
 }
 
@@ -28063,11 +27435,11 @@ void GetSuggestionsParams::setStartIndexNull() {
 }
 
 
-const QStringList &GetSuggestionsParams::type() const {
+const QList<BaseItemKind> &GetSuggestionsParams::type() const {
 	return m_type;
 }
 
-void GetSuggestionsParams::setType(QStringList newType)  {
+void GetSuggestionsParams::setType(QList<BaseItemKind> newType)  {
 	m_type = newType;
 }
 
@@ -28084,6 +27456,27 @@ void GetSuggestionsParams::setTypeNull() {
 }
 
 
+const QString &GetSuggestionsParams::userId() const {
+	return m_userId;
+}
+
+void GetSuggestionsParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetSuggestionsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetSuggestionsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // GetSystemInfoParams
@@ -28181,6 +27574,48 @@ void GetThemeMediaParams::setInheritFromParentNull() {
 }
 
 
+const QList<ItemSortBy> &GetThemeMediaParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetThemeMediaParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetThemeMediaParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetThemeMediaParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetThemeMediaParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetThemeMediaParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetThemeMediaParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetThemeMediaParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const QString &GetThemeMediaParams::userId() const {
 	return m_userId;
 }
@@ -28236,6 +27671,48 @@ void GetThemeSongsParams::setInheritFromParentNull() {
 }
 
 
+const QList<ItemSortBy> &GetThemeSongsParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetThemeSongsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetThemeSongsParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetThemeSongsParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetThemeSongsParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetThemeSongsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetThemeSongsParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetThemeSongsParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const QString &GetThemeSongsParams::userId() const {
 	return m_userId;
 }
@@ -28291,6 +27768,48 @@ void GetThemeVideosParams::setInheritFromParentNull() {
 }
 
 
+const QList<ItemSortBy> &GetThemeVideosParams::sortBy() const {
+	return m_sortBy;
+}
+
+void GetThemeVideosParams::setSortBy(QList<ItemSortBy> newSortBy)  {
+	m_sortBy = newSortBy;
+}
+
+bool GetThemeVideosParams::sortByNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortBy.size() == 0;
+}
+
+void GetThemeVideosParams::setSortByNull() {
+	m_sortBy.clear();
+}
+
+
+const QList<SortOrder> &GetThemeVideosParams::sortOrder() const {
+	return m_sortOrder;
+}
+
+void GetThemeVideosParams::setSortOrder(QList<SortOrder> newSortOrder)  {
+	m_sortOrder = newSortOrder;
+}
+
+bool GetThemeVideosParams::sortOrderNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_sortOrder.size() == 0;
+}
+
+void GetThemeVideosParams::setSortOrderNull() {
+	m_sortOrder.clear();
+}
+
+
 const QString &GetThemeVideosParams::userId() const {
 	return m_userId;
 }
@@ -28628,7 +28147,7 @@ void GetTrailersParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetTrailersParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -28724,11 +28243,11 @@ void GetTrailersParams::setExcludeItemIdsNull() {
 }
 
 
-const QStringList &GetTrailersParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetTrailersParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetTrailersParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetTrailersParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -29228,6 +28747,27 @@ void GetTrailersParams::setIsHdNull() {
 }
 
 
+const bool &GetTrailersParams::isKids() const {
+	return m_isKids.value();
+}
+
+void GetTrailersParams::setIsKids(bool newIsKids)  {
+	m_isKids = newIsKids;
+}
+
+bool GetTrailersParams::isKidsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isKids.has_value();
+}
+
+void GetTrailersParams::setIsKidsNull() {
+	m_isKids = std::nullopt;
+}
+
+
 const bool &GetTrailersParams::isLocked() const {
 	return m_isLocked.value();
 }
@@ -29270,6 +28810,48 @@ void GetTrailersParams::setIsMissingNull() {
 }
 
 
+const bool &GetTrailersParams::isMovie() const {
+	return m_isMovie.value();
+}
+
+void GetTrailersParams::setIsMovie(bool newIsMovie)  {
+	m_isMovie = newIsMovie;
+}
+
+bool GetTrailersParams::isMovieNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isMovie.has_value();
+}
+
+void GetTrailersParams::setIsMovieNull() {
+	m_isMovie = std::nullopt;
+}
+
+
+const bool &GetTrailersParams::isNews() const {
+	return m_isNews.value();
+}
+
+void GetTrailersParams::setIsNews(bool newIsNews)  {
+	m_isNews = newIsNews;
+}
+
+bool GetTrailersParams::isNewsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isNews.has_value();
+}
+
+void GetTrailersParams::setIsNewsNull() {
+	m_isNews = std::nullopt;
+}
+
+
 const bool &GetTrailersParams::isPlaceHolder() const {
 	return m_isPlaceHolder.value();
 }
@@ -29312,6 +28894,48 @@ void GetTrailersParams::setIsPlayedNull() {
 }
 
 
+const bool &GetTrailersParams::isSeries() const {
+	return m_isSeries.value();
+}
+
+void GetTrailersParams::setIsSeries(bool newIsSeries)  {
+	m_isSeries = newIsSeries;
+}
+
+bool GetTrailersParams::isSeriesNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSeries.has_value();
+}
+
+void GetTrailersParams::setIsSeriesNull() {
+	m_isSeries = std::nullopt;
+}
+
+
+const bool &GetTrailersParams::isSports() const {
+	return m_isSports.value();
+}
+
+void GetTrailersParams::setIsSports(bool newIsSports)  {
+	m_isSports = newIsSports;
+}
+
+bool GetTrailersParams::isSportsNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_isSports.has_value();
+}
+
+void GetTrailersParams::setIsSportsNull() {
+	m_isSports = std::nullopt;
+}
+
+
 const bool &GetTrailersParams::isUnaired() const {
 	return m_isUnaired.value();
 }
@@ -29459,11 +29083,11 @@ void GetTrailersParams::setMaxWidthNull() {
 }
 
 
-const QStringList &GetTrailersParams::mediaTypes() const {
+const QList<MediaType> &GetTrailersParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetTrailersParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetTrailersParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -29900,11 +29524,11 @@ void GetTrailersParams::setSeriesStatusNull() {
 }
 
 
-const QString &GetTrailersParams::sortBy() const {
+const QList<ItemSortBy> &GetTrailersParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetTrailersParams::setSortBy(QString newSortBy)  {
+void GetTrailersParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -29913,7 +29537,7 @@ bool GetTrailersParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetTrailersParams::setSortByNull() {
@@ -29921,11 +29545,11 @@ void GetTrailersParams::setSortByNull() {
 }
 
 
-const QString &GetTrailersParams::sortOrder() const {
+const QList<SortOrder> &GetTrailersParams::sortOrder() const {
 	return m_sortOrder;
 }
 
-void GetTrailersParams::setSortOrder(QString newSortOrder)  {
+void GetTrailersParams::setSortOrder(QList<SortOrder> newSortOrder)  {
 	m_sortOrder = newSortOrder;
 }
 
@@ -29934,7 +29558,7 @@ bool GetTrailersParams::sortOrderNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetTrailersParams::setSortOrderNull() {
@@ -30091,6 +29715,101 @@ void GetTrailersParams::setYearsNull() {
 
 
 
+// GetTrickplayHlsPlaylistParams
+
+const QString &GetTrickplayHlsPlaylistParams::itemId() const {
+	return m_itemId;
+}
+
+void GetTrickplayHlsPlaylistParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const qint32 &GetTrickplayHlsPlaylistParams::width() const {
+	return m_width;
+}
+
+void GetTrickplayHlsPlaylistParams::setWidth(qint32 newWidth) {
+	m_width = newWidth;
+}
+
+
+const QString &GetTrickplayHlsPlaylistParams::mediaSourceId() const {
+	return m_mediaSourceId;
+}
+
+void GetTrickplayHlsPlaylistParams::setMediaSourceId(QString newMediaSourceId)  {
+	m_mediaSourceId = newMediaSourceId;
+}
+
+bool GetTrickplayHlsPlaylistParams::mediaSourceIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_mediaSourceId.isNull();
+}
+
+void GetTrickplayHlsPlaylistParams::setMediaSourceIdNull() {
+	m_mediaSourceId.clear();
+}
+
+
+
+
+// GetTrickplayTileImageParams
+
+const qint32 &GetTrickplayTileImageParams::index() const {
+	return m_index;
+}
+
+void GetTrickplayTileImageParams::setIndex(qint32 newIndex) {
+	m_index = newIndex;
+}
+
+
+const QString &GetTrickplayTileImageParams::itemId() const {
+	return m_itemId;
+}
+
+void GetTrickplayTileImageParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const qint32 &GetTrickplayTileImageParams::width() const {
+	return m_width;
+}
+
+void GetTrickplayTileImageParams::setWidth(qint32 newWidth) {
+	m_width = newWidth;
+}
+
+
+const QString &GetTrickplayTileImageParams::mediaSourceId() const {
+	return m_mediaSourceId;
+}
+
+void GetTrickplayTileImageParams::setMediaSourceId(QString newMediaSourceId)  {
+	m_mediaSourceId = newMediaSourceId;
+}
+
+bool GetTrickplayTileImageParams::mediaSourceIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_mediaSourceId.isNull();
+}
+
+void GetTrickplayTileImageParams::setMediaSourceIdNull() {
+	m_mediaSourceId.clear();
+}
+
+
+
+
 // GetTunerHostTypesParams
 
 
@@ -30157,7 +29876,7 @@ void GetUniversalAudioStreamParams::setBreakOnNonKeyFrames(bool newBreakOnNonKey
 }
 
 bool GetUniversalAudioStreamParams::breakOnNonKeyFramesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -30211,6 +29930,27 @@ void GetUniversalAudioStreamParams::setDeviceIdNull() {
 }
 
 
+const bool &GetUniversalAudioStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetUniversalAudioStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetUniversalAudioStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetUniversalAudioStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetUniversalAudioStreamParams::enableRedirection() const {
 	return m_enableRedirection.value();
 }
@@ -30421,11 +30161,11 @@ void GetUniversalAudioStreamParams::setTranscodingContainerNull() {
 }
 
 
-const QString &GetUniversalAudioStreamParams::transcodingProtocol() const {
+const MediaStreamProtocol &GetUniversalAudioStreamParams::transcodingProtocol() const {
 	return m_transcodingProtocol;
 }
 
-void GetUniversalAudioStreamParams::setTranscodingProtocol(QString newTranscodingProtocol)  {
+void GetUniversalAudioStreamParams::setTranscodingProtocol(MediaStreamProtocol newTranscodingProtocol)  {
 	m_transcodingProtocol = newTranscodingProtocol;
 }
 
@@ -30434,11 +30174,11 @@ bool GetUniversalAudioStreamParams::transcodingProtocolNull() const {
 	// Type Nullable: true
 	
 
-	return m_transcodingProtocol.isNull();
+	return m_transcodingProtocol== MediaStreamProtocol::EnumNotSet;
 }
 
 void GetUniversalAudioStreamParams::setTranscodingProtocolNull() {
-	m_transcodingProtocol.clear();
+	m_transcodingProtocol= MediaStreamProtocol::EnumNotSet;
 }
 
 
@@ -30488,24 +30228,24 @@ void GetUpcomingEpisodesParams::setEnableImageTypesNull() {
 }
 
 
-const bool &GetUpcomingEpisodesParams::enableImges() const {
-	return m_enableImges.value();
+const bool &GetUpcomingEpisodesParams::enableImages() const {
+	return m_enableImages.value();
 }
 
-void GetUpcomingEpisodesParams::setEnableImges(bool newEnableImges)  {
-	m_enableImges = newEnableImges;
+void GetUpcomingEpisodesParams::setEnableImages(bool newEnableImages)  {
+	m_enableImages = newEnableImages;
 }
 
-bool GetUpcomingEpisodesParams::enableImgesNull() const {
+bool GetUpcomingEpisodesParams::enableImagesNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_enableImges.has_value();
+	return !m_enableImages.has_value();
 }
 
-void GetUpcomingEpisodesParams::setEnableImgesNull() {
-	m_enableImges = std::nullopt;
+void GetUpcomingEpisodesParams::setEnableImagesNull() {
+	m_enableImages = std::nullopt;
 }
 
 
@@ -30673,45 +30413,6 @@ void GetUserByIdParams::setUserId(QString newUserId) {
 
 // GetUserImageParams
 
-const ImageType &GetUserImageParams::imageType() const {
-	return m_imageType;
-}
-
-void GetUserImageParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
-const QString &GetUserImageParams::userId() const {
-	return m_userId;
-}
-
-void GetUserImageParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const bool &GetUserImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetUserImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetUserImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetUserImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &GetUserImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -30754,24 +30455,45 @@ void GetUserImageParams::setBlurNull() {
 }
 
 
-const bool &GetUserImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &GetUserImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void GetUserImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void GetUserImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool GetUserImageParams::cropWhitespaceNull() const {
+bool GetUserImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void GetUserImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void GetUserImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &GetUserImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void GetUserImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool GetUserImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void GetUserImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -30985,6 +30707,27 @@ void GetUserImageParams::setUnplayedCountNull() {
 }
 
 
+const QString &GetUserImageParams::userId() const {
+	return m_userId;
+}
+
+void GetUserImageParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetUserImageParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetUserImageParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 const qint32 &GetUserImageParams::width() const {
 	return m_width.value();
 }
@@ -31008,342 +30751,8 @@ void GetUserImageParams::setWidthNull() {
 
 
 
-// GetUserImageByIndexParams
-
-const qint32 &GetUserImageByIndexParams::imageIndex() const {
-	return m_imageIndex;
-}
-
-void GetUserImageByIndexParams::setImageIndex(qint32 newImageIndex) {
-	m_imageIndex = newImageIndex;
-}
-
-
-const ImageType &GetUserImageByIndexParams::imageType() const {
-	return m_imageType;
-}
-
-void GetUserImageByIndexParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
-const QString &GetUserImageByIndexParams::userId() const {
-	return m_userId;
-}
-
-void GetUserImageByIndexParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const bool &GetUserImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void GetUserImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool GetUserImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void GetUserImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
-const QString &GetUserImageByIndexParams::backgroundColor() const {
-	return m_backgroundColor;
-}
-
-void GetUserImageByIndexParams::setBackgroundColor(QString newBackgroundColor)  {
-	m_backgroundColor = newBackgroundColor;
-}
-
-bool GetUserImageByIndexParams::backgroundColorNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_backgroundColor.isNull();
-}
-
-void GetUserImageByIndexParams::setBackgroundColorNull() {
-	m_backgroundColor.clear();
-}
-
-
-const qint32 &GetUserImageByIndexParams::blur() const {
-	return m_blur.value();
-}
-
-void GetUserImageByIndexParams::setBlur(qint32 newBlur)  {
-	m_blur = newBlur;
-}
-
-bool GetUserImageByIndexParams::blurNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_blur.has_value();
-}
-
-void GetUserImageByIndexParams::setBlurNull() {
-	m_blur = std::nullopt;
-}
-
-
-const bool &GetUserImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
-}
-
-void GetUserImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
-}
-
-bool GetUserImageByIndexParams::cropWhitespaceNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_cropWhitespace.has_value();
-}
-
-void GetUserImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
-}
-
-
-const QString &GetUserImageByIndexParams::foregroundLayer() const {
-	return m_foregroundLayer;
-}
-
-void GetUserImageByIndexParams::setForegroundLayer(QString newForegroundLayer)  {
-	m_foregroundLayer = newForegroundLayer;
-}
-
-bool GetUserImageByIndexParams::foregroundLayerNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_foregroundLayer.isNull();
-}
-
-void GetUserImageByIndexParams::setForegroundLayerNull() {
-	m_foregroundLayer.clear();
-}
-
-
-const ImageFormat &GetUserImageByIndexParams::format() const {
-	return m_format;
-}
-
-void GetUserImageByIndexParams::setFormat(ImageFormat newFormat)  {
-	m_format = newFormat;
-}
-
-bool GetUserImageByIndexParams::formatNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_format== ImageFormat::EnumNotSet;
-}
-
-void GetUserImageByIndexParams::setFormatNull() {
-	m_format= ImageFormat::EnumNotSet;
-}
-
-
-const qint32 &GetUserImageByIndexParams::height() const {
-	return m_height.value();
-}
-
-void GetUserImageByIndexParams::setHeight(qint32 newHeight)  {
-	m_height = newHeight;
-}
-
-bool GetUserImageByIndexParams::heightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_height.has_value();
-}
-
-void GetUserImageByIndexParams::setHeightNull() {
-	m_height = std::nullopt;
-}
-
-
-const qint32 &GetUserImageByIndexParams::maxHeight() const {
-	return m_maxHeight.value();
-}
-
-void GetUserImageByIndexParams::setMaxHeight(qint32 newMaxHeight)  {
-	m_maxHeight = newMaxHeight;
-}
-
-bool GetUserImageByIndexParams::maxHeightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxHeight.has_value();
-}
-
-void GetUserImageByIndexParams::setMaxHeightNull() {
-	m_maxHeight = std::nullopt;
-}
-
-
-const qint32 &GetUserImageByIndexParams::maxWidth() const {
-	return m_maxWidth.value();
-}
-
-void GetUserImageByIndexParams::setMaxWidth(qint32 newMaxWidth)  {
-	m_maxWidth = newMaxWidth;
-}
-
-bool GetUserImageByIndexParams::maxWidthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxWidth.has_value();
-}
-
-void GetUserImageByIndexParams::setMaxWidthNull() {
-	m_maxWidth = std::nullopt;
-}
-
-
-const double &GetUserImageByIndexParams::percentPlayed() const {
-	return m_percentPlayed.value();
-}
-
-void GetUserImageByIndexParams::setPercentPlayed(double newPercentPlayed)  {
-	m_percentPlayed = newPercentPlayed;
-}
-
-bool GetUserImageByIndexParams::percentPlayedNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_percentPlayed.has_value();
-}
-
-void GetUserImageByIndexParams::setPercentPlayedNull() {
-	m_percentPlayed = std::nullopt;
-}
-
-
-const qint32 &GetUserImageByIndexParams::quality() const {
-	return m_quality.value();
-}
-
-void GetUserImageByIndexParams::setQuality(qint32 newQuality)  {
-	m_quality = newQuality;
-}
-
-bool GetUserImageByIndexParams::qualityNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_quality.has_value();
-}
-
-void GetUserImageByIndexParams::setQualityNull() {
-	m_quality = std::nullopt;
-}
-
-
-const QString &GetUserImageByIndexParams::tag() const {
-	return m_tag;
-}
-
-void GetUserImageByIndexParams::setTag(QString newTag)  {
-	m_tag = newTag;
-}
-
-bool GetUserImageByIndexParams::tagNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_tag.isNull();
-}
-
-void GetUserImageByIndexParams::setTagNull() {
-	m_tag.clear();
-}
-
-
-const qint32 &GetUserImageByIndexParams::unplayedCount() const {
-	return m_unplayedCount.value();
-}
-
-void GetUserImageByIndexParams::setUnplayedCount(qint32 newUnplayedCount)  {
-	m_unplayedCount = newUnplayedCount;
-}
-
-bool GetUserImageByIndexParams::unplayedCountNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_unplayedCount.has_value();
-}
-
-void GetUserImageByIndexParams::setUnplayedCountNull() {
-	m_unplayedCount = std::nullopt;
-}
-
-
-const qint32 &GetUserImageByIndexParams::width() const {
-	return m_width.value();
-}
-
-void GetUserImageByIndexParams::setWidth(qint32 newWidth)  {
-	m_width = newWidth;
-}
-
-bool GetUserImageByIndexParams::widthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_width.has_value();
-}
-
-void GetUserImageByIndexParams::setWidthNull() {
-	m_width = std::nullopt;
-}
-
-
-
-
 // GetUserViewsParams
 
-const QString &GetUserViewsParams::userId() const {
-	return m_userId;
-}
-
-void GetUserViewsParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const bool &GetUserViewsParams::includeExternalContent() const {
 	return m_includeExternalContent.value();
 }
@@ -31386,11 +30795,11 @@ void GetUserViewsParams::setIncludeHiddenNull() {
 }
 
 
-const QStringList &GetUserViewsParams::presetViews() const {
+const QList<CollectionType> &GetUserViewsParams::presetViews() const {
 	return m_presetViews;
 }
 
-void GetUserViewsParams::setPresetViews(QStringList newPresetViews)  {
+void GetUserViewsParams::setPresetViews(QList<CollectionType> newPresetViews)  {
 	m_presetViews = newPresetViews;
 }
 
@@ -31407,6 +30816,27 @@ void GetUserViewsParams::setPresetViewsNull() {
 }
 
 
+const QString &GetUserViewsParams::userId() const {
+	return m_userId;
+}
+
+void GetUserViewsParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool GetUserViewsParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void GetUserViewsParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // GetUsersParams
@@ -31764,6 +31194,27 @@ void GetVariantHlsAudioPlaylistParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetVariantHlsAudioPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetVariantHlsAudioPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetVariantHlsAudioPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetVariantHlsAudioPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetVariantHlsAudioPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -32533,6 +31984,27 @@ void GetVariantHlsVideoPlaylistParams::setAllowVideoStreamCopyNull() {
 }
 
 
+const bool &GetVariantHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool GetVariantHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &GetVariantHlsVideoPlaylistParams::audioBitRate() const {
 	return m_audioBitRate.value();
 }
@@ -32785,6 +32257,27 @@ void GetVariantHlsVideoPlaylistParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetVariantHlsVideoPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetVariantHlsVideoPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetVariantHlsVideoPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -32974,6 +32467,27 @@ void GetVariantHlsVideoPlaylistParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &GetVariantHlsVideoPlaylistParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetVariantHlsVideoPlaylistParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &GetVariantHlsVideoPlaylistParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -33016,6 +32530,27 @@ void GetVariantHlsVideoPlaylistParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &GetVariantHlsVideoPlaylistParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetVariantHlsVideoPlaylistParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetVariantHlsVideoPlaylistParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &GetVariantHlsVideoPlaylistParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -33806,6 +33341,27 @@ void GetVideoStreamParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetVideoStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetVideoStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetVideoStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetVideoStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetVideoStreamParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -33995,6 +33551,27 @@ void GetVideoStreamParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &GetVideoStreamParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetVideoStreamParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetVideoStreamParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetVideoStreamParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &GetVideoStreamParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -34037,6 +33614,27 @@ void GetVideoStreamParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &GetVideoStreamParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetVideoStreamParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetVideoStreamParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetVideoStreamParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &GetVideoStreamParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -34521,15 +34119,6 @@ void GetVideoStreamByContainerParams::setItemId(QString newItemId) {
 }
 
 
-const QString &GetVideoStreamByContainerParams::stream() const {
-	return m_stream;
-}
-
-void GetVideoStreamByContainerParams::setStream(QString newStream) {
-	m_stream = newStream;
-}
-
-
 const bool &GetVideoStreamByContainerParams::allowAudioStreamCopy() const {
 	return m_allowAudioStreamCopy.value();
 }
@@ -34824,6 +34413,27 @@ void GetVideoStreamByContainerParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &GetVideoStreamByContainerParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void GetVideoStreamByContainerParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool GetVideoStreamByContainerParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void GetVideoStreamByContainerParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &GetVideoStreamByContainerParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -35013,6 +34623,27 @@ void GetVideoStreamByContainerParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &GetVideoStreamByContainerParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void GetVideoStreamByContainerParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool GetVideoStreamByContainerParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void GetVideoStreamByContainerParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &GetVideoStreamByContainerParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -35055,6 +34686,27 @@ void GetVideoStreamByContainerParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &GetVideoStreamByContainerParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void GetVideoStreamByContainerParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool GetVideoStreamByContainerParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void GetVideoStreamByContainerParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &GetVideoStreamByContainerParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -35593,7 +35245,7 @@ void GetYearsParams::setEnableImages(bool newEnableImages)  {
 }
 
 bool GetYearsParams::enableImagesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -35626,11 +35278,11 @@ void GetYearsParams::setEnableUserDataNull() {
 }
 
 
-const QStringList &GetYearsParams::excludeItemTypes() const {
+const QList<BaseItemKind> &GetYearsParams::excludeItemTypes() const {
 	return m_excludeItemTypes;
 }
 
-void GetYearsParams::setExcludeItemTypes(QStringList newExcludeItemTypes)  {
+void GetYearsParams::setExcludeItemTypes(QList<BaseItemKind> newExcludeItemTypes)  {
 	m_excludeItemTypes = newExcludeItemTypes;
 }
 
@@ -35689,11 +35341,11 @@ void GetYearsParams::setImageTypeLimitNull() {
 }
 
 
-const QStringList &GetYearsParams::includeItemTypes() const {
+const QList<BaseItemKind> &GetYearsParams::includeItemTypes() const {
 	return m_includeItemTypes;
 }
 
-void GetYearsParams::setIncludeItemTypes(QStringList newIncludeItemTypes)  {
+void GetYearsParams::setIncludeItemTypes(QList<BaseItemKind> newIncludeItemTypes)  {
 	m_includeItemTypes = newIncludeItemTypes;
 }
 
@@ -35731,11 +35383,11 @@ void GetYearsParams::setLimitNull() {
 }
 
 
-const QStringList &GetYearsParams::mediaTypes() const {
+const QList<MediaType> &GetYearsParams::mediaTypes() const {
 	return m_mediaTypes;
 }
 
-void GetYearsParams::setMediaTypes(QStringList newMediaTypes)  {
+void GetYearsParams::setMediaTypes(QList<MediaType> newMediaTypes)  {
 	m_mediaTypes = newMediaTypes;
 }
 
@@ -35794,11 +35446,11 @@ void GetYearsParams::setRecursiveNull() {
 }
 
 
-const QString &GetYearsParams::sortBy() const {
+const QList<ItemSortBy> &GetYearsParams::sortBy() const {
 	return m_sortBy;
 }
 
-void GetYearsParams::setSortBy(QString newSortBy)  {
+void GetYearsParams::setSortBy(QList<ItemSortBy> newSortBy)  {
 	m_sortBy = newSortBy;
 }
 
@@ -35807,7 +35459,7 @@ bool GetYearsParams::sortByNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortBy.isNull();
+	return m_sortBy.size() == 0;
 }
 
 void GetYearsParams::setSortByNull() {
@@ -35815,11 +35467,11 @@ void GetYearsParams::setSortByNull() {
 }
 
 
-const QString &GetYearsParams::sortOrder() const {
+const QList<SortOrder> &GetYearsParams::sortOrder() const {
 	return m_sortOrder;
 }
 
-void GetYearsParams::setSortOrder(QString newSortOrder)  {
+void GetYearsParams::setSortOrder(QList<SortOrder> newSortOrder)  {
 	m_sortOrder = newSortOrder;
 }
 
@@ -35828,7 +35480,7 @@ bool GetYearsParams::sortOrderNull() const {
 	// Type Nullable: true
 	
 
-	return m_sortOrder.isNull();
+	return m_sortOrder.size() == 0;
 }
 
 void GetYearsParams::setSortOrderNull() {
@@ -35909,27 +35561,6 @@ void HeadArtistImageParams::setName(QString newName) {
 }
 
 
-const bool &HeadArtistImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadArtistImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadArtistImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadArtistImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadArtistImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -35972,24 +35603,45 @@ void HeadArtistImageParams::setBlurNull() {
 }
 
 
-const bool &HeadArtistImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadArtistImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadArtistImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadArtistImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadArtistImageParams::cropWhitespaceNull() const {
+bool HeadArtistImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadArtistImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadArtistImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadArtistImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadArtistImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadArtistImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadArtistImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -36531,6 +36183,27 @@ void HeadAudioStreamParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &HeadAudioStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadAudioStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadAudioStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadAudioStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadAudioStreamParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -37540,6 +37213,27 @@ void HeadAudioStreamByContainerParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &HeadAudioStreamByContainerParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadAudioStreamByContainerParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadAudioStreamByContainerParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadAudioStreamByContainerParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadAudioStreamByContainerParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -38255,27 +37949,6 @@ void HeadGenreImageParams::setName(QString newName) {
 }
 
 
-const bool &HeadGenreImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadGenreImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadGenreImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadGenreImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadGenreImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -38318,24 +37991,45 @@ void HeadGenreImageParams::setBlurNull() {
 }
 
 
-const bool &HeadGenreImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadGenreImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadGenreImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadGenreImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadGenreImageParams::cropWhitespaceNull() const {
+bool HeadGenreImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadGenreImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadGenreImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadGenreImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadGenreImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadGenreImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadGenreImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -38601,27 +38295,6 @@ void HeadGenreImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &HeadGenreImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadGenreImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadGenreImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadGenreImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadGenreImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -38664,24 +38337,45 @@ void HeadGenreImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &HeadGenreImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadGenreImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadGenreImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadGenreImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadGenreImageByIndexParams::cropWhitespaceNull() const {
+bool HeadGenreImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadGenreImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadGenreImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadGenreImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadGenreImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadGenreImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadGenreImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -38917,27 +38611,6 @@ void HeadItemImageParams::setItemId(QString newItemId) {
 }
 
 
-const bool &HeadItemImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadItemImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadItemImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadItemImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadItemImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -38980,24 +38653,45 @@ void HeadItemImageParams::setBlurNull() {
 }
 
 
-const bool &HeadItemImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadItemImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadItemImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadItemImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadItemImageParams::cropWhitespaceNull() const {
+bool HeadItemImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadItemImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadItemImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadItemImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadItemImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadItemImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadItemImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -39317,27 +39011,6 @@ void HeadItemImage2Params::setUnplayedCount(qint32 newUnplayedCount) {
 }
 
 
-const bool &HeadItemImage2Params::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadItemImage2Params::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadItemImage2Params::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadItemImage2Params::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadItemImage2Params::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -39380,24 +39053,45 @@ void HeadItemImage2Params::setBlurNull() {
 }
 
 
-const bool &HeadItemImage2Params::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadItemImage2Params::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadItemImage2Params::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadItemImage2Params::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadItemImage2Params::cropWhitespaceNull() const {
+bool HeadItemImage2Params::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadItemImage2Params::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadItemImage2Params::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadItemImage2Params::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadItemImage2Params::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadItemImage2Params::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadItemImage2Params::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -39516,27 +39210,6 @@ void HeadItemImageByIndexParams::setItemId(QString newItemId) {
 }
 
 
-const bool &HeadItemImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadItemImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadItemImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadItemImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadItemImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -39579,24 +39252,45 @@ void HeadItemImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &HeadItemImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadItemImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadItemImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadItemImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadItemImageByIndexParams::cropWhitespaceNull() const {
+bool HeadItemImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadItemImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadItemImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadItemImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadItemImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadItemImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadItemImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -40147,6 +39841,27 @@ void HeadMasterHlsAudioPlaylistParams::setEnableAdaptiveBitrateStreamingNull() {
 }
 
 
+const bool &HeadMasterHlsAudioPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadMasterHlsAudioPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadMasterHlsAudioPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadMasterHlsAudioPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadMasterHlsAudioPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -40904,6 +40619,27 @@ void HeadMasterHlsVideoPlaylistParams::setAllowVideoStreamCopyNull() {
 }
 
 
+const bool &HeadMasterHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool HeadMasterHlsVideoPlaylistParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &HeadMasterHlsVideoPlaylistParams::audioBitRate() const {
 	return m_audioBitRate.value();
 }
@@ -41177,6 +40913,27 @@ void HeadMasterHlsVideoPlaylistParams::setEnableAdaptiveBitrateStreamingNull() {
 }
 
 
+const bool &HeadMasterHlsVideoPlaylistParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadMasterHlsVideoPlaylistParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadMasterHlsVideoPlaylistParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -41219,6 +40976,27 @@ void HeadMasterHlsVideoPlaylistParams::setEnableMpegtsM2TsModeNull() {
 }
 
 
+const bool &HeadMasterHlsVideoPlaylistParams::enableTrickplay() const {
+	return m_enableTrickplay.value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setEnableTrickplay(bool newEnableTrickplay)  {
+	m_enableTrickplay = newEnableTrickplay;
+}
+
+bool HeadMasterHlsVideoPlaylistParams::enableTrickplayNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableTrickplay.has_value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setEnableTrickplayNull() {
+	m_enableTrickplay = std::nullopt;
+}
+
+
 const float &HeadMasterHlsVideoPlaylistParams::framerate() const {
 	return m_framerate.value();
 }
@@ -41366,6 +41144,27 @@ void HeadMasterHlsVideoPlaylistParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &HeadMasterHlsVideoPlaylistParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool HeadMasterHlsVideoPlaylistParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &HeadMasterHlsVideoPlaylistParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -41408,6 +41207,27 @@ void HeadMasterHlsVideoPlaylistParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &HeadMasterHlsVideoPlaylistParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool HeadMasterHlsVideoPlaylistParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void HeadMasterHlsVideoPlaylistParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const qint32 &HeadMasterHlsVideoPlaylistParams::minSegments() const {
 	return m_minSegments.value();
 }
@@ -41871,27 +41691,6 @@ void HeadMusicGenreImageParams::setName(QString newName) {
 }
 
 
-const bool &HeadMusicGenreImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadMusicGenreImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadMusicGenreImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadMusicGenreImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadMusicGenreImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -41934,24 +41733,45 @@ void HeadMusicGenreImageParams::setBlurNull() {
 }
 
 
-const bool &HeadMusicGenreImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadMusicGenreImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadMusicGenreImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadMusicGenreImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadMusicGenreImageParams::cropWhitespaceNull() const {
+bool HeadMusicGenreImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadMusicGenreImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadMusicGenreImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadMusicGenreImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadMusicGenreImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadMusicGenreImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadMusicGenreImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -42217,27 +42037,6 @@ void HeadMusicGenreImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &HeadMusicGenreImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadMusicGenreImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadMusicGenreImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadMusicGenreImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadMusicGenreImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -42280,24 +42079,45 @@ void HeadMusicGenreImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &HeadMusicGenreImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadMusicGenreImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadMusicGenreImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadMusicGenreImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadMusicGenreImageByIndexParams::cropWhitespaceNull() const {
+bool HeadMusicGenreImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadMusicGenreImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadMusicGenreImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadMusicGenreImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadMusicGenreImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadMusicGenreImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadMusicGenreImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -42533,27 +42353,6 @@ void HeadPersonImageParams::setName(QString newName) {
 }
 
 
-const bool &HeadPersonImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadPersonImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadPersonImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadPersonImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadPersonImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -42596,24 +42395,45 @@ void HeadPersonImageParams::setBlurNull() {
 }
 
 
-const bool &HeadPersonImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadPersonImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadPersonImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadPersonImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadPersonImageParams::cropWhitespaceNull() const {
+bool HeadPersonImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadPersonImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadPersonImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadPersonImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadPersonImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadPersonImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadPersonImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -42879,27 +42699,6 @@ void HeadPersonImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &HeadPersonImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadPersonImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadPersonImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadPersonImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadPersonImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -42942,24 +42741,45 @@ void HeadPersonImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &HeadPersonImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadPersonImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadPersonImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadPersonImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadPersonImageByIndexParams::cropWhitespaceNull() const {
+bool HeadPersonImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadPersonImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadPersonImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadPersonImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadPersonImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadPersonImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadPersonImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -43195,27 +43015,6 @@ void HeadStudioImageParams::setName(QString newName) {
 }
 
 
-const bool &HeadStudioImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadStudioImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadStudioImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadStudioImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadStudioImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -43258,24 +43057,45 @@ void HeadStudioImageParams::setBlurNull() {
 }
 
 
-const bool &HeadStudioImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadStudioImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadStudioImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadStudioImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadStudioImageParams::cropWhitespaceNull() const {
+bool HeadStudioImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadStudioImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadStudioImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadStudioImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadStudioImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadStudioImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadStudioImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -43541,27 +43361,6 @@ void HeadStudioImageByIndexParams::setName(QString newName) {
 }
 
 
-const bool &HeadStudioImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadStudioImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadStudioImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadStudioImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadStudioImageByIndexParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -43604,24 +43403,45 @@ void HeadStudioImageByIndexParams::setBlurNull() {
 }
 
 
-const bool &HeadStudioImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadStudioImageByIndexParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadStudioImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadStudioImageByIndexParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadStudioImageByIndexParams::cropWhitespaceNull() const {
+bool HeadStudioImageByIndexParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadStudioImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadStudioImageByIndexParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadStudioImageByIndexParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadStudioImageByIndexParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadStudioImageByIndexParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadStudioImageByIndexParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -43899,7 +43719,7 @@ void HeadUniversalAudioStreamParams::setBreakOnNonKeyFrames(bool newBreakOnNonKe
 }
 
 bool HeadUniversalAudioStreamParams::breakOnNonKeyFramesNull() const {
-	// Nullable: true
+	// Nullable: false
 	// Type Nullable: false
 	
 
@@ -43953,6 +43773,27 @@ void HeadUniversalAudioStreamParams::setDeviceIdNull() {
 }
 
 
+const bool &HeadUniversalAudioStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadUniversalAudioStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadUniversalAudioStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadUniversalAudioStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadUniversalAudioStreamParams::enableRedirection() const {
 	return m_enableRedirection.value();
 }
@@ -44163,11 +44004,11 @@ void HeadUniversalAudioStreamParams::setTranscodingContainerNull() {
 }
 
 
-const QString &HeadUniversalAudioStreamParams::transcodingProtocol() const {
+const MediaStreamProtocol &HeadUniversalAudioStreamParams::transcodingProtocol() const {
 	return m_transcodingProtocol;
 }
 
-void HeadUniversalAudioStreamParams::setTranscodingProtocol(QString newTranscodingProtocol)  {
+void HeadUniversalAudioStreamParams::setTranscodingProtocol(MediaStreamProtocol newTranscodingProtocol)  {
 	m_transcodingProtocol = newTranscodingProtocol;
 }
 
@@ -44176,11 +44017,11 @@ bool HeadUniversalAudioStreamParams::transcodingProtocolNull() const {
 	// Type Nullable: true
 	
 
-	return m_transcodingProtocol.isNull();
+	return m_transcodingProtocol== MediaStreamProtocol::EnumNotSet;
 }
 
 void HeadUniversalAudioStreamParams::setTranscodingProtocolNull() {
-	m_transcodingProtocol.clear();
+	m_transcodingProtocol= MediaStreamProtocol::EnumNotSet;
 }
 
 
@@ -44209,45 +44050,6 @@ void HeadUniversalAudioStreamParams::setUserIdNull() {
 
 // HeadUserImageParams
 
-const ImageType &HeadUserImageParams::imageType() const {
-	return m_imageType;
-}
-
-void HeadUserImageParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
-const QString &HeadUserImageParams::userId() const {
-	return m_userId;
-}
-
-void HeadUserImageParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const bool &HeadUserImageParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadUserImageParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadUserImageParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadUserImageParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
 const QString &HeadUserImageParams::backgroundColor() const {
 	return m_backgroundColor;
 }
@@ -44290,24 +44092,45 @@ void HeadUserImageParams::setBlurNull() {
 }
 
 
-const bool &HeadUserImageParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
+const qint32 &HeadUserImageParams::fillHeight() const {
+	return m_fillHeight.value();
 }
 
-void HeadUserImageParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
+void HeadUserImageParams::setFillHeight(qint32 newFillHeight)  {
+	m_fillHeight = newFillHeight;
 }
 
-bool HeadUserImageParams::cropWhitespaceNull() const {
+bool HeadUserImageParams::fillHeightNull() const {
 	// Nullable: true
 	// Type Nullable: false
 	
 
-	return !m_cropWhitespace.has_value();
+	return !m_fillHeight.has_value();
 }
 
-void HeadUserImageParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
+void HeadUserImageParams::setFillHeightNull() {
+	m_fillHeight = std::nullopt;
+}
+
+
+const qint32 &HeadUserImageParams::fillWidth() const {
+	return m_fillWidth.value();
+}
+
+void HeadUserImageParams::setFillWidth(qint32 newFillWidth)  {
+	m_fillWidth = newFillWidth;
+}
+
+bool HeadUserImageParams::fillWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_fillWidth.has_value();
+}
+
+void HeadUserImageParams::setFillWidthNull() {
+	m_fillWidth = std::nullopt;
 }
 
 
@@ -44521,6 +44344,27 @@ void HeadUserImageParams::setUnplayedCountNull() {
 }
 
 
+const QString &HeadUserImageParams::userId() const {
+	return m_userId;
+}
+
+void HeadUserImageParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool HeadUserImageParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void HeadUserImageParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 const qint32 &HeadUserImageParams::width() const {
 	return m_width.value();
 }
@@ -44544,331 +44388,6 @@ void HeadUserImageParams::setWidthNull() {
 
 
 
-// HeadUserImageByIndexParams
-
-const qint32 &HeadUserImageByIndexParams::imageIndex() const {
-	return m_imageIndex;
-}
-
-void HeadUserImageByIndexParams::setImageIndex(qint32 newImageIndex) {
-	m_imageIndex = newImageIndex;
-}
-
-
-const ImageType &HeadUserImageByIndexParams::imageType() const {
-	return m_imageType;
-}
-
-void HeadUserImageByIndexParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
-const QString &HeadUserImageByIndexParams::userId() const {
-	return m_userId;
-}
-
-void HeadUserImageByIndexParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const bool &HeadUserImageByIndexParams::addPlayedIndicator() const {
-	return m_addPlayedIndicator.value();
-}
-
-void HeadUserImageByIndexParams::setAddPlayedIndicator(bool newAddPlayedIndicator)  {
-	m_addPlayedIndicator = newAddPlayedIndicator;
-}
-
-bool HeadUserImageByIndexParams::addPlayedIndicatorNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_addPlayedIndicator.has_value();
-}
-
-void HeadUserImageByIndexParams::setAddPlayedIndicatorNull() {
-	m_addPlayedIndicator = std::nullopt;
-}
-
-
-const QString &HeadUserImageByIndexParams::backgroundColor() const {
-	return m_backgroundColor;
-}
-
-void HeadUserImageByIndexParams::setBackgroundColor(QString newBackgroundColor)  {
-	m_backgroundColor = newBackgroundColor;
-}
-
-bool HeadUserImageByIndexParams::backgroundColorNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_backgroundColor.isNull();
-}
-
-void HeadUserImageByIndexParams::setBackgroundColorNull() {
-	m_backgroundColor.clear();
-}
-
-
-const qint32 &HeadUserImageByIndexParams::blur() const {
-	return m_blur.value();
-}
-
-void HeadUserImageByIndexParams::setBlur(qint32 newBlur)  {
-	m_blur = newBlur;
-}
-
-bool HeadUserImageByIndexParams::blurNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_blur.has_value();
-}
-
-void HeadUserImageByIndexParams::setBlurNull() {
-	m_blur = std::nullopt;
-}
-
-
-const bool &HeadUserImageByIndexParams::cropWhitespace() const {
-	return m_cropWhitespace.value();
-}
-
-void HeadUserImageByIndexParams::setCropWhitespace(bool newCropWhitespace)  {
-	m_cropWhitespace = newCropWhitespace;
-}
-
-bool HeadUserImageByIndexParams::cropWhitespaceNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_cropWhitespace.has_value();
-}
-
-void HeadUserImageByIndexParams::setCropWhitespaceNull() {
-	m_cropWhitespace = std::nullopt;
-}
-
-
-const QString &HeadUserImageByIndexParams::foregroundLayer() const {
-	return m_foregroundLayer;
-}
-
-void HeadUserImageByIndexParams::setForegroundLayer(QString newForegroundLayer)  {
-	m_foregroundLayer = newForegroundLayer;
-}
-
-bool HeadUserImageByIndexParams::foregroundLayerNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_foregroundLayer.isNull();
-}
-
-void HeadUserImageByIndexParams::setForegroundLayerNull() {
-	m_foregroundLayer.clear();
-}
-
-
-const ImageFormat &HeadUserImageByIndexParams::format() const {
-	return m_format;
-}
-
-void HeadUserImageByIndexParams::setFormat(ImageFormat newFormat)  {
-	m_format = newFormat;
-}
-
-bool HeadUserImageByIndexParams::formatNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_format== ImageFormat::EnumNotSet;
-}
-
-void HeadUserImageByIndexParams::setFormatNull() {
-	m_format= ImageFormat::EnumNotSet;
-}
-
-
-const qint32 &HeadUserImageByIndexParams::height() const {
-	return m_height.value();
-}
-
-void HeadUserImageByIndexParams::setHeight(qint32 newHeight)  {
-	m_height = newHeight;
-}
-
-bool HeadUserImageByIndexParams::heightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_height.has_value();
-}
-
-void HeadUserImageByIndexParams::setHeightNull() {
-	m_height = std::nullopt;
-}
-
-
-const qint32 &HeadUserImageByIndexParams::maxHeight() const {
-	return m_maxHeight.value();
-}
-
-void HeadUserImageByIndexParams::setMaxHeight(qint32 newMaxHeight)  {
-	m_maxHeight = newMaxHeight;
-}
-
-bool HeadUserImageByIndexParams::maxHeightNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxHeight.has_value();
-}
-
-void HeadUserImageByIndexParams::setMaxHeightNull() {
-	m_maxHeight = std::nullopt;
-}
-
-
-const qint32 &HeadUserImageByIndexParams::maxWidth() const {
-	return m_maxWidth.value();
-}
-
-void HeadUserImageByIndexParams::setMaxWidth(qint32 newMaxWidth)  {
-	m_maxWidth = newMaxWidth;
-}
-
-bool HeadUserImageByIndexParams::maxWidthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_maxWidth.has_value();
-}
-
-void HeadUserImageByIndexParams::setMaxWidthNull() {
-	m_maxWidth = std::nullopt;
-}
-
-
-const double &HeadUserImageByIndexParams::percentPlayed() const {
-	return m_percentPlayed.value();
-}
-
-void HeadUserImageByIndexParams::setPercentPlayed(double newPercentPlayed)  {
-	m_percentPlayed = newPercentPlayed;
-}
-
-bool HeadUserImageByIndexParams::percentPlayedNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_percentPlayed.has_value();
-}
-
-void HeadUserImageByIndexParams::setPercentPlayedNull() {
-	m_percentPlayed = std::nullopt;
-}
-
-
-const qint32 &HeadUserImageByIndexParams::quality() const {
-	return m_quality.value();
-}
-
-void HeadUserImageByIndexParams::setQuality(qint32 newQuality)  {
-	m_quality = newQuality;
-}
-
-bool HeadUserImageByIndexParams::qualityNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_quality.has_value();
-}
-
-void HeadUserImageByIndexParams::setQualityNull() {
-	m_quality = std::nullopt;
-}
-
-
-const QString &HeadUserImageByIndexParams::tag() const {
-	return m_tag;
-}
-
-void HeadUserImageByIndexParams::setTag(QString newTag)  {
-	m_tag = newTag;
-}
-
-bool HeadUserImageByIndexParams::tagNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_tag.isNull();
-}
-
-void HeadUserImageByIndexParams::setTagNull() {
-	m_tag.clear();
-}
-
-
-const qint32 &HeadUserImageByIndexParams::unplayedCount() const {
-	return m_unplayedCount.value();
-}
-
-void HeadUserImageByIndexParams::setUnplayedCount(qint32 newUnplayedCount)  {
-	m_unplayedCount = newUnplayedCount;
-}
-
-bool HeadUserImageByIndexParams::unplayedCountNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_unplayedCount.has_value();
-}
-
-void HeadUserImageByIndexParams::setUnplayedCountNull() {
-	m_unplayedCount = std::nullopt;
-}
-
-
-const qint32 &HeadUserImageByIndexParams::width() const {
-	return m_width.value();
-}
-
-void HeadUserImageByIndexParams::setWidth(qint32 newWidth)  {
-	m_width = newWidth;
-}
-
-bool HeadUserImageByIndexParams::widthNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_width.has_value();
-}
-
-void HeadUserImageByIndexParams::setWidthNull() {
-	m_width = std::nullopt;
-}
-
-
-
-
 // HeadVideoStreamParams
 
 const QString &HeadVideoStreamParams::itemId() const {
@@ -45195,6 +44714,27 @@ void HeadVideoStreamParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &HeadVideoStreamParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadVideoStreamParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadVideoStreamParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadVideoStreamParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadVideoStreamParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -45384,6 +44924,27 @@ void HeadVideoStreamParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &HeadVideoStreamParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void HeadVideoStreamParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool HeadVideoStreamParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void HeadVideoStreamParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &HeadVideoStreamParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -45426,6 +44987,27 @@ void HeadVideoStreamParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &HeadVideoStreamParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void HeadVideoStreamParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool HeadVideoStreamParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void HeadVideoStreamParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &HeadVideoStreamParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -45910,15 +45492,6 @@ void HeadVideoStreamByContainerParams::setItemId(QString newItemId) {
 }
 
 
-const QString &HeadVideoStreamByContainerParams::stream() const {
-	return m_stream;
-}
-
-void HeadVideoStreamByContainerParams::setStream(QString newStream) {
-	m_stream = newStream;
-}
-
-
 const bool &HeadVideoStreamByContainerParams::allowAudioStreamCopy() const {
 	return m_allowAudioStreamCopy.value();
 }
@@ -46213,6 +45786,27 @@ void HeadVideoStreamByContainerParams::setDeviceProfileIdNull() {
 }
 
 
+const bool &HeadVideoStreamByContainerParams::enableAudioVbrEncoding() const {
+	return m_enableAudioVbrEncoding.value();
+}
+
+void HeadVideoStreamByContainerParams::setEnableAudioVbrEncoding(bool newEnableAudioVbrEncoding)  {
+	m_enableAudioVbrEncoding = newEnableAudioVbrEncoding;
+}
+
+bool HeadVideoStreamByContainerParams::enableAudioVbrEncodingNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_enableAudioVbrEncoding.has_value();
+}
+
+void HeadVideoStreamByContainerParams::setEnableAudioVbrEncodingNull() {
+	m_enableAudioVbrEncoding = std::nullopt;
+}
+
+
 const bool &HeadVideoStreamByContainerParams::enableAutoStreamCopy() const {
 	return m_enableAutoStreamCopy.value();
 }
@@ -46402,6 +45996,27 @@ void HeadVideoStreamByContainerParams::setMaxFramerateNull() {
 }
 
 
+const qint32 &HeadVideoStreamByContainerParams::maxHeight() const {
+	return m_maxHeight.value();
+}
+
+void HeadVideoStreamByContainerParams::setMaxHeight(qint32 newMaxHeight)  {
+	m_maxHeight = newMaxHeight;
+}
+
+bool HeadVideoStreamByContainerParams::maxHeightNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxHeight.has_value();
+}
+
+void HeadVideoStreamByContainerParams::setMaxHeightNull() {
+	m_maxHeight = std::nullopt;
+}
+
+
 const qint32 &HeadVideoStreamByContainerParams::maxRefFrames() const {
 	return m_maxRefFrames.value();
 }
@@ -46444,6 +46059,27 @@ void HeadVideoStreamByContainerParams::setMaxVideoBitDepthNull() {
 }
 
 
+const qint32 &HeadVideoStreamByContainerParams::maxWidth() const {
+	return m_maxWidth.value();
+}
+
+void HeadVideoStreamByContainerParams::setMaxWidth(qint32 newMaxWidth)  {
+	m_maxWidth = newMaxWidth;
+}
+
+bool HeadVideoStreamByContainerParams::maxWidthNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_maxWidth.has_value();
+}
+
+void HeadVideoStreamByContainerParams::setMaxWidthNull() {
+	m_maxWidth = std::nullopt;
+}
+
+
 const QString &HeadVideoStreamByContainerParams::mediaSourceId() const {
 	return m_mediaSourceId;
 }
@@ -46908,7 +46544,7 @@ void HeadVideoStreamByContainerParams::setWidthNull() {
 
 
 
-// InitiateParams
+// InitiateQuickConnectParams
 
 
 
@@ -46988,6 +46624,19 @@ void InstallPackageParams::setVersionNull() {
 
 
 
+// LogFileParams
+
+const QByteArray &LogFileParams::body() const {
+	return m_body;
+}
+
+void LogFileParams::setBody(QByteArray newBody) {
+	m_body = newBody;
+}
+
+
+
+
 // MarkFavoriteItemParams
 
 const QString &MarkFavoriteItemParams::itemId() const {
@@ -47003,10 +46652,22 @@ const QString &MarkFavoriteItemParams::userId() const {
 	return m_userId;
 }
 
-void MarkFavoriteItemParams::setUserId(QString newUserId) {
+void MarkFavoriteItemParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool MarkFavoriteItemParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void MarkFavoriteItemParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -47021,15 +46682,6 @@ void MarkPlayedItemParams::setItemId(QString newItemId) {
 }
 
 
-const QString &MarkPlayedItemParams::userId() const {
-	return m_userId;
-}
-
-void MarkPlayedItemParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const QDateTime &MarkPlayedItemParams::datePlayed() const {
 	return m_datePlayed;
 }
@@ -47051,6 +46703,27 @@ void MarkPlayedItemParams::setDatePlayedNull() {
 }
 
 
+const QString &MarkPlayedItemParams::userId() const {
+	return m_userId;
+}
+
+void MarkPlayedItemParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool MarkPlayedItemParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void MarkPlayedItemParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // MarkUnplayedItemParams
@@ -47068,10 +46741,22 @@ const QString &MarkUnplayedItemParams::userId() const {
 	return m_userId;
 }
 
-void MarkUnplayedItemParams::setUserId(QString newUserId) {
+void MarkUnplayedItemParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool MarkUnplayedItemParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void MarkUnplayedItemParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -47130,15 +46815,6 @@ void OnPlaybackProgressParams::setItemId(QString newItemId) {
 }
 
 
-const QString &OnPlaybackProgressParams::userId() const {
-	return m_userId;
-}
-
-void OnPlaybackProgressParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const qint32 &OnPlaybackProgressParams::audioStreamIndex() const {
 	return m_audioStreamIndex.value();
 }
@@ -47383,15 +47059,6 @@ void OnPlaybackStartParams::setItemId(QString newItemId) {
 }
 
 
-const QString &OnPlaybackStartParams::userId() const {
-	return m_userId;
-}
-
-void OnPlaybackStartParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const qint32 &OnPlaybackStartParams::audioStreamIndex() const {
 	return m_audioStreamIndex.value();
 }
@@ -47552,15 +47219,6 @@ void OnPlaybackStoppedParams::setItemId(QString newItemId) {
 }
 
 
-const QString &OnPlaybackStoppedParams::userId() const {
-	return m_userId;
-}
-
-void OnPlaybackStoppedParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const QString &OnPlaybackStoppedParams::liveStreamId() const {
 	return m_liveStreamId;
 }
@@ -47670,6 +47328,27 @@ void OnPlaybackStoppedParams::setPositionTicksNull() {
 
 // OpenLiveStreamParams
 
+const bool &OpenLiveStreamParams::alwaysBurnInSubtitleWhenTranscoding() const {
+	return m_alwaysBurnInSubtitleWhenTranscoding.value();
+}
+
+void OpenLiveStreamParams::setAlwaysBurnInSubtitleWhenTranscoding(bool newAlwaysBurnInSubtitleWhenTranscoding)  {
+	m_alwaysBurnInSubtitleWhenTranscoding = newAlwaysBurnInSubtitleWhenTranscoding;
+}
+
+bool OpenLiveStreamParams::alwaysBurnInSubtitleWhenTranscodingNull() const {
+	// Nullable: true
+	// Type Nullable: false
+	
+
+	return !m_alwaysBurnInSubtitleWhenTranscoding.has_value();
+}
+
+void OpenLiveStreamParams::setAlwaysBurnInSubtitleWhenTranscodingNull() {
+	m_alwaysBurnInSubtitleWhenTranscoding = std::nullopt;
+}
+
+
 const qint32 &OpenLiveStreamParams::audioStreamIndex() const {
 	return m_audioStreamIndex.value();
 }
@@ -47918,22 +47597,10 @@ const QString &PingPlaybackSessionParams::playSessionId() const {
 	return m_playSessionId;
 }
 
-void PingPlaybackSessionParams::setPlaySessionId(QString newPlaySessionId)  {
+void PingPlaybackSessionParams::setPlaySessionId(QString newPlaySessionId) {
 	m_playSessionId = newPlaySessionId;
 }
 
-bool PingPlaybackSessionParams::playSessionIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_playSessionId.isNull();
-}
-
-void PingPlaybackSessionParams::setPlaySessionIdNull() {
-	m_playSessionId.clear();
-}
-
 
 
 
@@ -48073,103 +47740,6 @@ void PlayParams::setSubtitleStreamIndexNull() {
 
 
 
-// PostParams
-
-const QString &PostParams::itemId() const {
-	return m_itemId;
-}
-
-void PostParams::setItemId(QString newItemId) {
-	m_itemId = newItemId;
-}
-
-
-const MetadataRefreshMode &PostParams::imageRefreshMode() const {
-	return m_imageRefreshMode;
-}
-
-void PostParams::setImageRefreshMode(MetadataRefreshMode newImageRefreshMode)  {
-	m_imageRefreshMode = newImageRefreshMode;
-}
-
-bool PostParams::imageRefreshModeNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_imageRefreshMode== MetadataRefreshMode::EnumNotSet;
-}
-
-void PostParams::setImageRefreshModeNull() {
-	m_imageRefreshMode= MetadataRefreshMode::EnumNotSet;
-}
-
-
-const MetadataRefreshMode &PostParams::metadataRefreshMode() const {
-	return m_metadataRefreshMode;
-}
-
-void PostParams::setMetadataRefreshMode(MetadataRefreshMode newMetadataRefreshMode)  {
-	m_metadataRefreshMode = newMetadataRefreshMode;
-}
-
-bool PostParams::metadataRefreshModeNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_metadataRefreshMode== MetadataRefreshMode::EnumNotSet;
-}
-
-void PostParams::setMetadataRefreshModeNull() {
-	m_metadataRefreshMode= MetadataRefreshMode::EnumNotSet;
-}
-
-
-const bool &PostParams::replaceAllImages() const {
-	return m_replaceAllImages.value();
-}
-
-void PostParams::setReplaceAllImages(bool newReplaceAllImages)  {
-	m_replaceAllImages = newReplaceAllImages;
-}
-
-bool PostParams::replaceAllImagesNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_replaceAllImages.has_value();
-}
-
-void PostParams::setReplaceAllImagesNull() {
-	m_replaceAllImages = std::nullopt;
-}
-
-
-const bool &PostParams::replaceAllMetadata() const {
-	return m_replaceAllMetadata.value();
-}
-
-void PostParams::setReplaceAllMetadata(bool newReplaceAllMetadata)  {
-	m_replaceAllMetadata = newReplaceAllMetadata;
-}
-
-bool PostParams::replaceAllMetadataNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_replaceAllMetadata.has_value();
-}
-
-void PostParams::setReplaceAllMetadataNull() {
-	m_replaceAllMetadata = std::nullopt;
-}
-
-
-
-
 // PostAddedMoviesParams
 
 const QString &PostAddedMoviesParams::imdbId() const {
@@ -48264,11 +47834,11 @@ void PostCapabilitiesParams::setJellyfinIdNull() {
 }
 
 
-const QStringList &PostCapabilitiesParams::playableMediaTypes() const {
+const QList<MediaType> &PostCapabilitiesParams::playableMediaTypes() const {
 	return m_playableMediaTypes;
 }
 
-void PostCapabilitiesParams::setPlayableMediaTypes(QStringList newPlayableMediaTypes)  {
+void PostCapabilitiesParams::setPlayableMediaTypes(QList<MediaType> newPlayableMediaTypes)  {
 	m_playableMediaTypes = newPlayableMediaTypes;
 }
 
@@ -48348,27 +47918,6 @@ void PostCapabilitiesParams::setSupportsPersistentIdentifierNull() {
 }
 
 
-const bool &PostCapabilitiesParams::supportsSync() const {
-	return m_supportsSync.value();
-}
-
-void PostCapabilitiesParams::setSupportsSync(bool newSupportsSync)  {
-	m_supportsSync = newSupportsSync;
-}
-
-bool PostCapabilitiesParams::supportsSyncNull() const {
-	// Nullable: false
-	// Type Nullable: false
-	
-
-	return !m_supportsSync.has_value();
-}
-
-void PostCapabilitiesParams::setSupportsSyncNull() {
-	m_supportsSync = std::nullopt;
-}
-
-
 
 
 // PostFullCapabilitiesParams
@@ -48411,11 +47960,11 @@ void PostFullCapabilitiesParams::setBody(QSharedPointer<ClientCapabilitiesDto> n
 
 // PostUpdatedMediaParams
 
-const QList<MediaUpdateInfoDto> &PostUpdatedMediaParams::body() const {
+const QSharedPointer<MediaUpdateInfoDto> &PostUpdatedMediaParams::body() const {
 	return m_body;
 }
 
-void PostUpdatedMediaParams::setBody(QList<MediaUpdateInfoDto> newBody) {
+void PostUpdatedMediaParams::setBody(QSharedPointer<MediaUpdateInfoDto> newBody) {
 	m_body = newBody;
 }
 
@@ -48495,112 +48044,151 @@ void PostUpdatedSeriesParams::setTvdbIdNull() {
 
 // PostUserImageParams
 
-const ImageType &PostUserImageParams::imageType() const {
-	return m_imageType;
-}
-
-void PostUserImageParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
-}
-
-
 const QString &PostUserImageParams::userId() const {
 	return m_userId;
 }
 
-void PostUserImageParams::setUserId(QString newUserId) {
+void PostUserImageParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
-
-const qint32 &PostUserImageParams::index() const {
-	return m_index.value();
-}
-
-void PostUserImageParams::setIndex(qint32 newIndex)  {
-	m_index = newIndex;
-}
-
-bool PostUserImageParams::indexNull() const {
+bool PostUserImageParams::userIdNull() const {
 	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void PostUserImageParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+const QByteArray &PostUserImageParams::body() const {
+	return m_body;
+}
+
+void PostUserImageParams::setBody(QByteArray newBody) {
+	m_body = newBody;
+}
+
+
+
+
+// RefreshItemParams
+
+const QString &RefreshItemParams::itemId() const {
+	return m_itemId;
+}
+
+void RefreshItemParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const MetadataRefreshMode &RefreshItemParams::imageRefreshMode() const {
+	return m_imageRefreshMode;
+}
+
+void RefreshItemParams::setImageRefreshMode(MetadataRefreshMode newImageRefreshMode)  {
+	m_imageRefreshMode = newImageRefreshMode;
+}
+
+bool RefreshItemParams::imageRefreshModeNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_imageRefreshMode== MetadataRefreshMode::EnumNotSet;
+}
+
+void RefreshItemParams::setImageRefreshModeNull() {
+	m_imageRefreshMode= MetadataRefreshMode::EnumNotSet;
+}
+
+
+const MetadataRefreshMode &RefreshItemParams::metadataRefreshMode() const {
+	return m_metadataRefreshMode;
+}
+
+void RefreshItemParams::setMetadataRefreshMode(MetadataRefreshMode newMetadataRefreshMode)  {
+	m_metadataRefreshMode = newMetadataRefreshMode;
+}
+
+bool RefreshItemParams::metadataRefreshModeNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_metadataRefreshMode== MetadataRefreshMode::EnumNotSet;
+}
+
+void RefreshItemParams::setMetadataRefreshModeNull() {
+	m_metadataRefreshMode= MetadataRefreshMode::EnumNotSet;
+}
+
+
+const bool &RefreshItemParams::regenerateTrickplay() const {
+	return m_regenerateTrickplay.value();
+}
+
+void RefreshItemParams::setRegenerateTrickplay(bool newRegenerateTrickplay)  {
+	m_regenerateTrickplay = newRegenerateTrickplay;
+}
+
+bool RefreshItemParams::regenerateTrickplayNull() const {
+	// Nullable: false
 	// Type Nullable: false
 	
 
-	return !m_index.has_value();
+	return !m_regenerateTrickplay.has_value();
 }
 
-void PostUserImageParams::setIndexNull() {
-	m_index = std::nullopt;
+void RefreshItemParams::setRegenerateTrickplayNull() {
+	m_regenerateTrickplay = std::nullopt;
 }
 
 
-
-
-// PostUserImageByIndexParams
-
-const ImageType &PostUserImageByIndexParams::imageType() const {
-	return m_imageType;
+const bool &RefreshItemParams::replaceAllImages() const {
+	return m_replaceAllImages.value();
 }
 
-void PostUserImageByIndexParams::setImageType(ImageType newImageType) {
-	m_imageType = newImageType;
+void RefreshItemParams::setReplaceAllImages(bool newReplaceAllImages)  {
+	m_replaceAllImages = newReplaceAllImages;
+}
+
+bool RefreshItemParams::replaceAllImagesNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
+
+	return !m_replaceAllImages.has_value();
+}
+
+void RefreshItemParams::setReplaceAllImagesNull() {
+	m_replaceAllImages = std::nullopt;
 }
 
 
-const qint32 &PostUserImageByIndexParams::index() const {
-	return m_index;
+const bool &RefreshItemParams::replaceAllMetadata() const {
+	return m_replaceAllMetadata.value();
 }
 
-void PostUserImageByIndexParams::setIndex(qint32 newIndex) {
-	m_index = newIndex;
+void RefreshItemParams::setReplaceAllMetadata(bool newReplaceAllMetadata)  {
+	m_replaceAllMetadata = newReplaceAllMetadata;
 }
 
+bool RefreshItemParams::replaceAllMetadataNull() const {
+	// Nullable: false
+	// Type Nullable: false
+	
 
-const QString &PostUserImageByIndexParams::userId() const {
-	return m_userId;
+	return !m_replaceAllMetadata.has_value();
 }
 
-void PostUserImageByIndexParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-
-
-// ProcessConnectionManagerControlRequestParams
-
-const QString &ProcessConnectionManagerControlRequestParams::serverId() const {
-	return m_serverId;
-}
-
-void ProcessConnectionManagerControlRequestParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// ProcessContentDirectoryControlRequestParams
-
-const QString &ProcessContentDirectoryControlRequestParams::serverId() const {
-	return m_serverId;
-}
-
-void ProcessContentDirectoryControlRequestParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
-}
-
-
-
-
-// ProcessMediaReceiverRegistrarControlRequestParams
-
-const QString &ProcessMediaReceiverRegistrarControlRequestParams::serverId() const {
-	return m_serverId;
-}
-
-void ProcessMediaReceiverRegistrarControlRequestParams::setServerId(QString newServerId) {
-	m_serverId = newServerId;
+void RefreshItemParams::setReplaceAllMetadataNull() {
+	m_replaceAllMetadata = std::nullopt;
 }
 
 
@@ -48632,26 +48220,26 @@ void RemoveFromCollectionParams::setIds(QStringList newIds) {
 
 
 
-// RemoveFromPlaylistParams
+// RemoveItemFromPlaylistParams
 
-const QString &RemoveFromPlaylistParams::playlistId() const {
+const QString &RemoveItemFromPlaylistParams::playlistId() const {
 	return m_playlistId;
 }
 
-void RemoveFromPlaylistParams::setPlaylistId(QString newPlaylistId) {
+void RemoveItemFromPlaylistParams::setPlaylistId(QString newPlaylistId) {
 	m_playlistId = newPlaylistId;
 }
 
 
-const QStringList &RemoveFromPlaylistParams::entryIds() const {
+const QStringList &RemoveItemFromPlaylistParams::entryIds() const {
 	return m_entryIds;
 }
 
-void RemoveFromPlaylistParams::setEntryIds(QStringList newEntryIds)  {
+void RemoveItemFromPlaylistParams::setEntryIds(QStringList newEntryIds)  {
 	m_entryIds = newEntryIds;
 }
 
-bool RemoveFromPlaylistParams::entryIdsNull() const {
+bool RemoveItemFromPlaylistParams::entryIdsNull() const {
 	// Nullable: true
 	// Type Nullable: true
 	
@@ -48659,7 +48247,7 @@ bool RemoveFromPlaylistParams::entryIdsNull() const {
 	return m_entryIds.size() == 0;
 }
 
-void RemoveFromPlaylistParams::setEntryIdsNull() {
+void RemoveItemFromPlaylistParams::setEntryIdsNull() {
 	m_entryIds.clear();
 }
 
@@ -48733,6 +48321,28 @@ void RemoveMediaPathParams::setRefreshLibraryNull() {
 
 
 
+// RemoveUserFromPlaylistParams
+
+const QString &RemoveUserFromPlaylistParams::playlistId() const {
+	return m_playlistId;
+}
+
+void RemoveUserFromPlaylistParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
+const QString &RemoveUserFromPlaylistParams::userId() const {
+	return m_userId;
+}
+
+void RemoveUserFromPlaylistParams::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+
+
+
+
 // RemoveUserFromSessionParams
 
 const QString &RemoveUserFromSessionParams::sessionId() const {
@@ -48975,6 +48585,19 @@ void RevokeKeyParams::setKey(QString newKey) {
 
 
 
+// SearchRemoteLyricsParams
+
+const QString &SearchRemoteLyricsParams::itemId() const {
+	return m_itemId;
+}
+
+void SearchRemoteLyricsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+
+
 // SearchRemoteSubtitlesParams
 
 const QString &SearchRemoteSubtitlesParams::itemId() const {
@@ -49073,54 +48696,12 @@ void SendMessageCommandParams::setSessionId(QString newSessionId) {
 }
 
 
-const QString &SendMessageCommandParams::text() const {
-	return m_text;
+const QSharedPointer<MessageCommand> &SendMessageCommandParams::body() const {
+	return m_body;
 }
 
-void SendMessageCommandParams::setText(QString newText) {
-	m_text = newText;
-}
-
-
-const QString &SendMessageCommandParams::header() const {
-	return m_header;
-}
-
-void SendMessageCommandParams::setHeader(QString newHeader)  {
-	m_header = newHeader;
-}
-
-bool SendMessageCommandParams::headerNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_header.isNull();
-}
-
-void SendMessageCommandParams::setHeaderNull() {
-	m_header.clear();
-}
-
-
-const qint64 &SendMessageCommandParams::timeoutMs() const {
-	return m_timeoutMs.value();
-}
-
-void SendMessageCommandParams::setTimeoutMs(qint64 newTimeoutMs)  {
-	m_timeoutMs = newTimeoutMs;
-}
-
-bool SendMessageCommandParams::timeoutMsNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
-
-	return !m_timeoutMs.has_value();
-}
-
-void SendMessageCommandParams::setTimeoutMsNull() {
-	m_timeoutMs = std::nullopt;
+void SendMessageCommandParams::setBody(QSharedPointer<MessageCommand> newBody) {
+	m_body = newBody;
 }
 
 
@@ -49245,6 +48826,15 @@ void SetItemImageParams::setItemId(QString newItemId) {
 }
 
 
+const QByteArray &SetItemImageParams::body() const {
+	return m_body;
+}
+
+void SetItemImageParams::setBody(QByteArray newBody) {
+	m_body = newBody;
+}
+
+
 
 
 // SetItemImageByIndexParams
@@ -49276,16 +48866,12 @@ void SetItemImageByIndexParams::setItemId(QString newItemId) {
 }
 
 
-
-
-// SetReadParams
-
-const QString &SetReadParams::userId() const {
-	return m_userId;
+const QByteArray &SetItemImageByIndexParams::body() const {
+	return m_body;
 }
 
-void SetReadParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
+void SetItemImageByIndexParams::setBody(QByteArray newBody) {
+	m_body = newBody;
 }
 
 
@@ -49317,19 +48903,6 @@ void SetRepositoriesParams::setBody(QList<RepositoryInfo> newBody) {
 
 
 
-// SetUnreadParams
-
-const QString &SetUnreadParams::userId() const {
-	return m_userId;
-}
-
-void SetUnreadParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-
-
 // ShutdownApplicationParams
 
 
@@ -49353,43 +48926,19 @@ const QString &StopEncodingProcessParams::deviceId() const {
 	return m_deviceId;
 }
 
-void StopEncodingProcessParams::setDeviceId(QString newDeviceId)  {
+void StopEncodingProcessParams::setDeviceId(QString newDeviceId) {
 	m_deviceId = newDeviceId;
 }
 
-bool StopEncodingProcessParams::deviceIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_deviceId.isNull();
-}
-
-void StopEncodingProcessParams::setDeviceIdNull() {
-	m_deviceId.clear();
-}
-
 
 const QString &StopEncodingProcessParams::playSessionId() const {
 	return m_playSessionId;
 }
 
-void StopEncodingProcessParams::setPlaySessionId(QString newPlaySessionId)  {
+void StopEncodingProcessParams::setPlaySessionId(QString newPlaySessionId) {
 	m_playSessionId = newPlaySessionId;
 }
 
-bool StopEncodingProcessParams::playSessionIdNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_playSessionId.isNull();
-}
-
-void StopEncodingProcessParams::setPlaySessionIdNull() {
-	m_playSessionId.clear();
-}
-
 
 
 
@@ -49634,6 +49183,10 @@ void SyncPlaySetShuffleModeParams::setBody(QSharedPointer<SetShuffleModeRequestD
 
 
 
+// TmdbClientConfigurationParams
+
+
+
 // UninstallPluginParams
 
 const QString &UninstallPluginParams::pluginId() const {
@@ -49658,11 +49211,11 @@ void UninstallPluginByVersionParams::setPluginId(QString newPluginId) {
 }
 
 
-const QSharedPointer<Version> &UninstallPluginByVersionParams::version() const {
+const QString &UninstallPluginByVersionParams::version() const {
 	return m_version;
 }
 
-void UninstallPluginByVersionParams::setVersion(QSharedPointer<Version> newVersion) {
+void UninstallPluginByVersionParams::setVersion(QString newVersion) {
 	m_version = newVersion;
 }
 
@@ -49684,10 +49237,22 @@ const QString &UnmarkFavoriteItemParams::userId() const {
 	return m_userId;
 }
 
-void UnmarkFavoriteItemParams::setUserId(QString newUserId) {
+void UnmarkFavoriteItemParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool UnmarkFavoriteItemParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UnmarkFavoriteItemParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 
 
@@ -49715,11 +49280,11 @@ void UpdateDeviceOptionsParams::setJellyfinId(QString newJellyfinId) {
 }
 
 
-const QSharedPointer<DeviceOptions> &UpdateDeviceOptionsParams::body() const {
+const QSharedPointer<DeviceOptionsDto> &UpdateDeviceOptionsParams::body() const {
 	return m_body;
 }
 
-void UpdateDeviceOptionsParams::setBody(QSharedPointer<DeviceOptions> newBody) {
+void UpdateDeviceOptionsParams::setBody(QSharedPointer<DeviceOptionsDto> newBody) {
 	m_body = newBody;
 }
 
@@ -49750,10 +49315,22 @@ const QString &UpdateDisplayPreferencesParams::userId() const {
 	return m_userId;
 }
 
-void UpdateDisplayPreferencesParams::setUserId(QString newUserId) {
+void UpdateDisplayPreferencesParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool UpdateDisplayPreferencesParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateDisplayPreferencesParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 const QSharedPointer<DisplayPreferencesDto> &UpdateDisplayPreferencesParams::body() const {
 	return m_body;
@@ -49865,23 +49442,54 @@ void UpdateItemImageIndexParams::setItemId(QString newItemId) {
 
 
 const qint32 &UpdateItemImageIndexParams::newIndex() const {
-	return m_newIndex.value();
+	return m_newIndex;
 }
 
-void UpdateItemImageIndexParams::setNewIndex(qint32 newNewIndex)  {
+void UpdateItemImageIndexParams::setNewIndex(qint32 newNewIndex) {
 	m_newIndex = newNewIndex;
 }
 
-bool UpdateItemImageIndexParams::newIndexNull() const {
-	// Nullable: true
-	// Type Nullable: false
-	
 
-	return !m_newIndex.has_value();
+
+
+// UpdateItemUserDataParams
+
+const QString &UpdateItemUserDataParams::itemId() const {
+	return m_itemId;
 }
 
-void UpdateItemImageIndexParams::setNewIndexNull() {
-	m_newIndex = std::nullopt;
+void UpdateItemUserDataParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const QString &UpdateItemUserDataParams::userId() const {
+	return m_userId;
+}
+
+void UpdateItemUserDataParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool UpdateItemUserDataParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateItemUserDataParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
+const QSharedPointer<UpdateUserItemDataDto> &UpdateItemUserDataParams::body() const {
+	return m_body;
+}
+
+void UpdateItemUserDataParams::setBody(QSharedPointer<UpdateUserItemDataDto> newBody) {
+	m_body = newBody;
 }
 
 
@@ -49900,47 +49508,13 @@ void UpdateLibraryOptionsParams::setBody(QSharedPointer<UpdateLibraryOptionsDto>
 
 
 
-// UpdateMediaEncoderPathParams
-
-const QSharedPointer<MediaEncoderPathDto> &UpdateMediaEncoderPathParams::body() const {
-	return m_body;
-}
-
-void UpdateMediaEncoderPathParams::setBody(QSharedPointer<MediaEncoderPathDto> newBody) {
-	m_body = newBody;
-}
-
-
-
-
 // UpdateMediaPathParams
 
-const QString &UpdateMediaPathParams::name() const {
-	return m_name;
-}
-
-void UpdateMediaPathParams::setName(QString newName)  {
-	m_name = newName;
-}
-
-bool UpdateMediaPathParams::nameNull() const {
-	// Nullable: true
-	// Type Nullable: true
-	
-
-	return m_name.isNull();
-}
-
-void UpdateMediaPathParams::setNameNull() {
-	m_name.clear();
-}
-
-
-const QSharedPointer<MediaPathInfo> &UpdateMediaPathParams::body() const {
+const QSharedPointer<UpdateMediaPathRequestDto> &UpdateMediaPathParams::body() const {
 	return m_body;
 }
 
-void UpdateMediaPathParams::setBody(QSharedPointer<MediaPathInfo> newBody) {
+void UpdateMediaPathParams::setBody(QSharedPointer<UpdateMediaPathRequestDto> newBody) {
 	m_body = newBody;
 }
 
@@ -49958,6 +49532,68 @@ void UpdateNamedConfigurationParams::setKey(QString newKey) {
 }
 
 
+const QVariant &UpdateNamedConfigurationParams::body() const {
+	return m_body;
+}
+
+void UpdateNamedConfigurationParams::setBody(QVariant newBody) {
+	m_body = newBody;
+}
+
+
+
+
+// UpdatePlaylistParams
+
+const QString &UpdatePlaylistParams::playlistId() const {
+	return m_playlistId;
+}
+
+void UpdatePlaylistParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
+const QSharedPointer<UpdatePlaylistDto> &UpdatePlaylistParams::body() const {
+	return m_body;
+}
+
+void UpdatePlaylistParams::setBody(QSharedPointer<UpdatePlaylistDto> newBody) {
+	m_body = newBody;
+}
+
+
+
+
+// UpdatePlaylistUserParams
+
+const QString &UpdatePlaylistUserParams::playlistId() const {
+	return m_playlistId;
+}
+
+void UpdatePlaylistUserParams::setPlaylistId(QString newPlaylistId) {
+	m_playlistId = newPlaylistId;
+}
+
+
+const QString &UpdatePlaylistUserParams::userId() const {
+	return m_userId;
+}
+
+void UpdatePlaylistUserParams::setUserId(QString newUserId) {
+	m_userId = newUserId;
+}
+
+
+const QSharedPointer<UpdatePlaylistUserDto> &UpdatePlaylistUserParams::body() const {
+	return m_body;
+}
+
+void UpdatePlaylistUserParams::setBody(QSharedPointer<UpdatePlaylistUserDto> newBody) {
+	m_body = newBody;
+}
+
+
 
 
 // UpdatePluginConfigurationParams
@@ -49973,41 +49609,6 @@ void UpdatePluginConfigurationParams::setPluginId(QString newPluginId) {
 
 
 
-// UpdatePluginSecurityInfoParams
-
-const QSharedPointer<PluginSecurityInfo> &UpdatePluginSecurityInfoParams::body() const {
-	return m_body;
-}
-
-void UpdatePluginSecurityInfoParams::setBody(QSharedPointer<PluginSecurityInfo> newBody) {
-	m_body = newBody;
-}
-
-
-
-
-// UpdateProfileParams
-
-const QString &UpdateProfileParams::profileId() const {
-	return m_profileId;
-}
-
-void UpdateProfileParams::setProfileId(QString newProfileId) {
-	m_profileId = newProfileId;
-}
-
-
-const QSharedPointer<DeviceProfile> &UpdateProfileParams::body() const {
-	return m_body;
-}
-
-void UpdateProfileParams::setBody(QSharedPointer<DeviceProfile> newBody) {
-	m_body = newBody;
-}
-
-
-
-
 // UpdateSeriesTimerParams
 
 const QString &UpdateSeriesTimerParams::timerId() const {
@@ -50093,10 +49694,22 @@ const QString &UpdateUserParams::userId() const {
 	return m_userId;
 }
 
-void UpdateUserParams::setUserId(QString newUserId) {
+void UpdateUserParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool UpdateUserParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateUserParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 const QSharedPointer<UserDto> &UpdateUserParams::body() const {
 	return m_body;
@@ -50115,10 +49728,22 @@ const QString &UpdateUserConfigurationParams::userId() const {
 	return m_userId;
 }
 
-void UpdateUserConfigurationParams::setUserId(QString newUserId) {
+void UpdateUserConfigurationParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool UpdateUserConfigurationParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateUserConfigurationParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 const QSharedPointer<UserConfiguration> &UpdateUserConfigurationParams::body() const {
 	return m_body;
@@ -50131,28 +49756,6 @@ void UpdateUserConfigurationParams::setBody(QSharedPointer<UserConfiguration> ne
 
 
 
-// UpdateUserEasyPasswordParams
-
-const QString &UpdateUserEasyPasswordParams::userId() const {
-	return m_userId;
-}
-
-void UpdateUserEasyPasswordParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
-const QSharedPointer<UpdateUserEasyPassword> &UpdateUserEasyPasswordParams::body() const {
-	return m_body;
-}
-
-void UpdateUserEasyPasswordParams::setBody(QSharedPointer<UpdateUserEasyPassword> newBody) {
-	m_body = newBody;
-}
-
-
-
-
 // UpdateUserItemRatingParams
 
 const QString &UpdateUserItemRatingParams::itemId() const {
@@ -50164,15 +49767,6 @@ void UpdateUserItemRatingParams::setItemId(QString newItemId) {
 }
 
 
-const QString &UpdateUserItemRatingParams::userId() const {
-	return m_userId;
-}
-
-void UpdateUserItemRatingParams::setUserId(QString newUserId) {
-	m_userId = newUserId;
-}
-
-
 const bool &UpdateUserItemRatingParams::likes() const {
 	return m_likes.value();
 }
@@ -50194,6 +49788,27 @@ void UpdateUserItemRatingParams::setLikesNull() {
 }
 
 
+const QString &UpdateUserItemRatingParams::userId() const {
+	return m_userId;
+}
+
+void UpdateUserItemRatingParams::setUserId(QString newUserId)  {
+	m_userId = newUserId;
+}
+
+bool UpdateUserItemRatingParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateUserItemRatingParams::setUserIdNull() {
+	m_userId.clear();
+}
+
+
 
 
 // UpdateUserPasswordParams
@@ -50202,10 +49817,22 @@ const QString &UpdateUserPasswordParams::userId() const {
 	return m_userId;
 }
 
-void UpdateUserPasswordParams::setUserId(QString newUserId) {
+void UpdateUserPasswordParams::setUserId(QString newUserId)  {
 	m_userId = newUserId;
 }
 
+bool UpdateUserPasswordParams::userIdNull() const {
+	// Nullable: true
+	// Type Nullable: true
+	
+
+	return m_userId.isNull();
+}
+
+void UpdateUserPasswordParams::setUserIdNull() {
+	m_userId.clear();
+}
+
 
 const QSharedPointer<UpdateUserPassword> &UpdateUserPasswordParams::body() const {
 	return m_body;
@@ -50240,6 +49867,50 @@ void UpdateUserPolicyParams::setBody(QSharedPointer<UserPolicy> newBody) {
 
 
 
+// UploadCustomSplashscreenParams
+
+const QByteArray &UploadCustomSplashscreenParams::body() const {
+	return m_body;
+}
+
+void UploadCustomSplashscreenParams::setBody(QByteArray newBody) {
+	m_body = newBody;
+}
+
+
+
+
+// UploadLyricsParams
+
+const QString &UploadLyricsParams::itemId() const {
+	return m_itemId;
+}
+
+void UploadLyricsParams::setItemId(QString newItemId) {
+	m_itemId = newItemId;
+}
+
+
+const QString &UploadLyricsParams::fileName() const {
+	return m_fileName;
+}
+
+void UploadLyricsParams::setFileName(QString newFileName) {
+	m_fileName = newFileName;
+}
+
+
+const QByteArray &UploadLyricsParams::body() const {
+	return m_body;
+}
+
+void UploadLyricsParams::setBody(QByteArray newBody) {
+	m_body = newBody;
+}
+
+
+
+
 // UploadSubtitleParams
 
 const QString &UploadSubtitleParams::itemId() const {