Swift SDK for Jellyfin
Go to file
2023-10-16 12:57:14 -06:00
.github/workflows Create sdk-unstable-branch.yaml (#24) 2023-10-16 12:57:14 -06:00
JellyfinAPI.doccarchive generate with CreateAPI 0.1.0 and doccarchive 2022-08-16 23:32:51 -06:00
Plugins/CreateAPI Update to CreateAPI 0.2.0 (#22) 2023-08-30 16:09:52 -06:00
Sources Update to CreateAPI 0.2.0 (#22) 2023-08-30 16:09:52 -06:00
.gitignore Update .gitignore 2022-08-16 23:39:51 -06:00
.swiftformat update 2022-08-15 20:37:47 -06:00
Package.resolved Update Get (#21) 2023-08-30 13:13:49 -06:00
Package.swift Update to CreateAPI 0.2.0 (#22) 2023-08-30 16:09:52 -06:00
README.md Non-Fixed Width Integers, Hashable, Inline Patching, and 10.8.9 (#18) 2023-04-12 13:10:22 -06:00

Swift SDK Jellyfin

Swift SDK to work with Jellyfin servers.

Generated using CreateAPI

Usage

JellyfinClient uses an underlying Get APIClient to provide basic functionality for interfacing with a Jellyfin server:

  • inject required Authorization header for every request
  • encoding/decoding of expected Date values
  • signIn for generating a session access token
  • signOut for revoking the current access token
// Create client instance
let jellyfinClient = JellyfinClient(configuration: configuration)

// Sign in user with credentials
let response = jellyfinClient.signIn(username: "jelly", password: "fin")

Alternatively, you can use your own network stack with the generated Entities and Paths.

Generation

The mechanism for generating Entities, Extensions, and Paths with CreateAPI is provided as an Xcode command plugin.

  1. Download the latest Jellyfin schema
  2. Move the schema to Sources
  3. Delete the current Entities, Extensions, and Paths directories
  4. Run the following command in the package directory:
# runs the CreateAPI Xcode command plugin
$ swift package --allow-writing-to-package-directory generate-api
  1. New Entities, Extensions, and Paths directories should be available within the package

Alternatively, you can generate your own Swift Jellyfin SDK using CreateAPI or any other OpenAPI generator.