Skip to content

Latest commit

 

History

History
126 lines (112 loc) · 3.18 KB

README.md

File metadata and controls

126 lines (112 loc) · 3.18 KB

Immich Screensaver

  • What is it? A utility for creating symbolic links to pictures stored in Immich.
  • Why is it? The intended use case is to create a directory containing links to pictures that can be used for slideshows and screensavers. It might be useful for other uses too!
  • How is it? By default, you can point to Immich's upload directory as a source of screensaver pictures, but that implies displaying ALL pictures. This tool allows you to filter pictures in and out according to the albums that contain them, or the people contained within them, or their archived status.

Usage

Currently, the utility only works on MacOS 13.0+ with a Swift runtime. It also assumes that Immich's upload directory is in an accessible volume by the computer. Usually this means Immich should be running on the same computer, but it may work using network attached storage.

  1. Define your Immich API settings Create a file named immichAPI.pkl as follows:
amends "pkl/ImmichAPI.pkl"

key = "[YOUR IMMICH API KEY]"
endpoint = "http://[YOUR IMMICH URL]/api"

Both values are required. Keep in mind to keep these values private.

  1. Define your search options Create a file named options.pkl with the desired options:
amends "pkl/ImmichScreensaverOptions.pkl"

/*
  Optional.
  Immich albums to be included in the output.
  Joined with `includeFaces` as an OR operation.
*/
includeAlbums = new {
    "My Awesome Trip"
    "Best Doggo"
}
/*
  Optional.
  Immich albums to be excluded in the output.
  If set, these albums will never appear in the output.
  Takes precedence over `includeAlbums`:
    if a picture exists both in an included
    and excluded album, it will not appear.
*/
excludeAlbums = new {
    "Boring things..."
}

/*
  Optional.
  Names of people to be included in the output.
  Joined with `includeAlbums` as an OR operation.
*/
includePeople = new {
    "Steve Jobs"
    "Linus Torvalds"
}
/*
  Optional.
  Names of people to be excluded in the output.
  If set, these people will never appear in the output.
  Takes precedence over `includePeople`:
    if a picture contains both an included
    and excluded person, it will not appear.
*/
excludePeople = new {
    "Bill Gates"
}

/*
   Optional.
   Date from which to start looking for pictures.
*/
startDate = new {
    day = 1
    month = 1
    year = 2000
}

/*
   Optional.
   Date on which to stop looking for pictures.
*/
startDate = new {
    day = 31
    month = 12
    year = 2099
}

/*
   If true, will not display pictures that have been archived.   
*/
excludeArchived = true

/*
   Tell script where to find original photos.
   Also used for output.
*/
uploadLocation = "Same as Immich's UPLOAD_LOCATION environment variable"

Development

./pkl-gen-swift pkl/ImmichAPI.pkl -o Sources/Generated
./pkl-gen-swift pkl/ImmichScreensaverOptions.pkl -o Sources/Generated
swift build -c release
cp .build/release/ImmichScreensaver .

To-do

  • Include Albums
  • Exclude Albums
  • Include People
  • Exclude People
  • Start Date
  • End Date
  • Exclude Archived
  • Immich API 1000 results limitation
  • Option to copy files instead of symbolic links