/LetterboxdAPI

Letterboxd API written in Swift

Primary LanguageSwift

LetterboxdAPI

Now with async/await support.

Required

  • Swift 5.3
  • iOS 13
  • tvOS 13
  • watchOS 6
  • macOS 10.15

Installation

Xcode

Project > Swift Packages

git@github.com:gianpispi/LetterboxdAPI.git

Swift Package Manager

You can install it via SPM in your Package.swift:

import PackageDescription

let package = Package(name: "YourPackage",
    dependencies: [
      .Package(url: "https://github.com/gianpispi/LetterboxdAPI", majorVersion: 0),
    ]
)

You must then use import SwiftLocation to use the core features.

Usage

import LetterboxdAPI

// AppDelegate.swift file
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
    // Override point for customization after application launch.
    
    LetterboxdAPI.setUpAPIKeys(publicAPI: "<<API Key>>", privateAPI: "<<API Secret>>")
    
    return true
}

Get the LID (Letterboxd ID) and type for a Letterboxd URL (eg: boxd.it/<> or letterboxd.com/<>)

let url = URL(string: "https://letterboxd.com/film/free-guy/")!
LetterboxdAPI.shared.getLID(for: url) { result in
    switch result {
    case .success(let obj):
        // obj of type LetterboxdObject, which has the object LID and the  object type (LetterboxdType)
        print(obj.lid)
        
    case .failure(let error):
        // error is of type LetterboxdAPIError and is `wrongResponse`
        print(error)
    }
}

async/await

let lObj: LetterboxdObject? = try? await LetterboxdAPI.shared.getLID(for: url)

Get a film providing the film ID

Just provide the film id, and get the response right away.

LetterboxdAPI.shared.getFilm(withId: "id") { result in
    switch result {
    case .success(let film):
        // film is of type Film
        print(film.originalName)
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

let film: Film? = try? await LetterboxdAPI.shared.getFilm(withId: "id")

Get a film providing the film ID

Just provide the film id, and get the response right away.

LetterboxdAPI.shared.getFilmAvailability(withId: "id") { result in
    switch result {
    case .success(let availability):
        // availability is of type FilmAvailabilityResponse
        print(film.items.map({ $0.displayName }))
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

let filmAvailability: FilmAvailabilityResponse? = try? await LetterboxdAPI.shared.getFilmAvailability(withId: "id")

Get a member providing the member's ID

LetterboxdAPI.shared.getMember(withId: "id") { result in
    switch result {
    case .success(let member):
        // member is of type Member
        print(member.username)
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

let member: Member? = try? await LetterboxdAPI.shared.getMember(withId: "id")

Get a member's statistics providing the member's ID

LetterboxdAPI.shared.getMemberStatistics(withId: "id") { result in
    switch result {
    case .success(let statistics):
        // statistics is of type MemberStatistics
        print(statistics.counts.watches)
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

let statistics: MemberStatistics? = try? await LetterboxdAPI.shared.getMemberStatistics(withId: "id")

Get a member's watchlist providing the member's ID

LetterboxdAPI.shared.getMemberWatchlist(withId: "id") { result in
    switch result {
    case .success(let watchlist):
        // watchlist is of type FilmResponse
        print(watchlist.items.map({ $0.name }))
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

let watchlist: FilmResponse? = try? await LetterboxdAPI.shared.getMemberWatchlist(withId: "id")

Run a query for any endpoint

struct List: Decodable {
    var id: String
    var name: String
}

LetterboxdAPI.shared.query(path: "/list/coMSs", parameters: [:]) { (result: Result<List, Error>) in
    switch result {
    case .success(let list):
        // list is of type List, declared a few lines above
        print(list.id)
        
    case .failure(let error):
        // error may be of type LetterboxdAPIError
        print(error)
    }
}

async/await

do {
    let list: List = try await LetterboxdAPI.shared.query(path: "/list/coMSs", parameters: [:])
} catch {
    print(error)
}

Contributing

  • If you need help or you'd like to ask a general question, open an issue.
  • If you found a bug, open an issue.
  • If you have a feature request, open an issue.
  • If you want to contribute, submit a pull request.

API Documentation

Letterboxd API

Author

gianpispi