jellyflood/Shared/Extensions/JellyfinAPI/DeviceProfile.swift
Joe Kribs 0025422634
[iOS & tvOS] Upgrade SDK to 10.10 (#1463)
* Buildable!

* Update file names.

* Default sort to sort name NOT name.

* SessionInfoDto vs SessionInfo

* Targetting

* Fix many invalid `ItemSortBy` existing. Will need to revisit later to see which can still be used!

* ExtraTypes Patch.

* Move from Binding to OnChange. Tested and Working.

* Update README.md

Update README to use 10.10.6. Bumped up from 10.8.13

* Update to Main on https://github.com/jellyfin/jellyfin-sdk-swift.git

* Now using https://github.com/jellyfin/jellyfin-sdk-swift.git again!

* Paths.getUserViews() userId moved to parameters

* Fix ViewModels where -Dto suffixes were removed by https://github.com/jellyfin/Swiftfin/pull/1465 auto-merge.

* SupportedCaseIterable

* tvOS supportedCases fixes for build issue.

* cleanup

* update API to 0.5.1 and correct VideoRangeTypes.

* Remove deviceProfile.responseProfiles = videoPlayer.responseProfiles

* Second to last adjustment:
Resolved: // TODO: 10.10 - Filter to only valid SortBy's for each BaseItemKind.
Last outstanding item: // TODO: 10.10 - What should authenticationProviderID & passwordResetProviderID be?

* Trailers itemID must precede userID

* Force User Policy to exist.

---------

Co-authored-by: Ethan Pippin <ethanpippin2343@gmail.com>
2025-04-06 23:42:47 -04:00

79 lines
2.9 KiB
Swift

//
// Swiftfin is subject to the terms of the Mozilla Public
// License, v2.0. If a copy of the MPL was not distributed with this
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
//
// Copyright (c) 2025 Jellyfin & Jellyfin Contributors
//
import Defaults
import JellyfinAPI
extension DeviceProfile {
static func build(
for videoPlayer: VideoPlayerType,
compatibilityMode: PlaybackCompatibility,
maxBitrate: Int? = nil
) -> DeviceProfile {
var deviceProfile: DeviceProfile = .init()
// MARK: - Video Player Specific Logic
deviceProfile.codecProfiles = videoPlayer.codecProfiles
deviceProfile.subtitleProfiles = videoPlayer.subtitleProfiles
// MARK: - DirectPlay & Transcoding Profiles
switch compatibilityMode {
case .auto:
deviceProfile.directPlayProfiles = videoPlayer.directPlayProfiles
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
case .mostCompatible:
deviceProfile.directPlayProfiles = PlaybackCompatibility.Video.compatibilityDirectPlayProfile
deviceProfile.transcodingProfiles = PlaybackCompatibility.Video.compatibilityTranscodingProfile
case .directPlay:
deviceProfile.directPlayProfiles = PlaybackCompatibility.Video.forcedDirectPlayProfile
case .custom:
let customProfileMode = Defaults[.VideoPlayer.Playback.customDeviceProfileAction]
let playbackDeviceProfile = StoredValues[.User.customDeviceProfiles]
if customProfileMode == .add {
deviceProfile.directPlayProfiles = videoPlayer.directPlayProfiles
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
} else {
deviceProfile.directPlayProfiles = []
// Only clear the Transcoding Profiles if one of the CustomProfiles is active as a Transcoding Profile
if playbackDeviceProfile.contains(where: { $0.useAsTranscodingProfile == true }) {
deviceProfile.transcodingProfiles = []
} else {
deviceProfile.transcodingProfiles = videoPlayer.transcodingProfiles
}
}
for profile in playbackDeviceProfile where profile.type == .video {
deviceProfile.directPlayProfiles?.append(profile.directPlayProfile)
if profile.useAsTranscodingProfile {
deviceProfile.transcodingProfiles?.append(profile.transcodingProfile)
}
}
}
// MARK: - Assign the Bitrate if provided
if let maxBitrate {
deviceProfile.maxStaticBitrate = maxBitrate
deviceProfile.maxStreamingBitrate = maxBitrate
deviceProfile.musicStreamingTranscodingBitrate = maxBitrate
}
return deviceProfile
}
}