Skip to main content

Migration tool for migrating album and favorites data from photoprism to immich

Project description

[!NOTE] Compatibility:
v0.0.5 → Immich version 1.106.x - latest
v0.0.4 → Immich version 1.105.x
v0.0.2 → Immich version 1.93.x - 1.104.x

PyPI version

Photoprism to Immich migrator

This tool can migrate albums and favorites from Photoprism to Immich. It does not migrate your photo files.

Prerequisites

  1. The tool will only work if you keep the same file structure in immich that you already had in photoprism. This is the case if you take the originals folder from photoprism and use it in immich as external library.
  2. Photoprism and Immich must both be running at the same time, because the tool communicates with both APIs.

How it works

ppim-migrator-diagram

Migrate favorites

  1. The tool fetches all photos with a favorite tag from your photoprism instance
  2. For each photo, it retrieves the original filename and its respective path
  3. It connects to immich, tries to find the photo by filename and validates potential candidates on the immich side by comparing the file path
  4. If a match was found, it marks the photo on immich as favorite

Migrate album

  1. The tool fetches all photos of a certain album from your photoprism instance
  2. For each photo, it retrieves the original filename and its respective path
  3. It connects to immich, tries to find the photo by filename and validates potential candidates on the immich side by comparing the file path
  4. If a match was found, it creates a new album in immich and adds the matched photos

Migrate all albums

  1. The tool fetches all albums from your photoprism instance (1000 albums by default)
  2. For each album found, the migration is launched as described per the previous paragraph.

Installation

pip install ppim-migrator

Configuration

Create a config.yaml file in the working directory where you want to run the command.

photoprism:
  base_url: https://photoprism.example.com
  username:
  password:
immich:
  base_url: https://immich.example.com
  api_key:

Notes:

  • The PhotoPrism account must not have two factor authentication enabled

Usage

Migrate all favorites from photoprism to immich

python -m ppim-migrator migrate-favorites

Migrate a certain album from photoprism to immich

To get an album-id just open the album in photoprism. The id is part of the url. Example:

  • Url, when opening the album: https://photoprism.example.com/library/albums/aqrcixa2uf1q45iq/view The album-id would be aqrcixa2uf1q45iq
python -m ppim-migrator migrate-album <album-id-here>

Migrate all albums from photoprism to immich

python -m ppim-migrator migrate-all-albums

You can overwrite the default 1000 albums cap, by adding a --count= option:

python -m ppim-migrator migrate-all-albums --count=5000

Migrate JPG+RAW stacks from photoprism to immich

Since Immich does not support auto stacking yet, these stacks can be migrated over from photoprism.

python -m ppim-migrator migrate-stacked-raws

You can overwrite the default 100000 photos cap, by adding a --count= option:

python -m ppim-migrator migrate-stacked-raws --count=200000

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ppim_migrator-0.0.9.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ppim_migrator-0.0.9-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

Details for the file ppim_migrator-0.0.9.tar.gz.

File metadata

  • Download URL: ppim_migrator-0.0.9.tar.gz
  • Upload date:
  • Size: 6.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ppim_migrator-0.0.9.tar.gz
Algorithm Hash digest
SHA256 6bec344563e02d2daac558ffa93844c944ae9bf01e0558291d94fe988d837be7
MD5 1ef8d2dcf2d89a394217919655e94839
BLAKE2b-256 cf98025b2a91c7e1f4c68832c2a0cde44a2fde39d8f0bdcbed57e621eab2a3ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for ppim_migrator-0.0.9.tar.gz:

Publisher: pypi.yml on v411e/ppim-migrator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ppim_migrator-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: ppim_migrator-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ppim_migrator-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 aacaa20c2248374381d254d93e71dab7f6be465784599c6b701419e68efab5f9
MD5 5723afbebb1b98e9601311088ca5aae6
BLAKE2b-256 28f1cda8e4055bb2d3575fbab4be600bd5a6aa2863def3cdb8b7f58b228e95d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for ppim_migrator-0.0.9-py3-none-any.whl:

Publisher: pypi.yml on v411e/ppim-migrator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page