immich-go

command module
v0.30.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 16, 2025 License: AGPL-3.0 Imports: 6 Imported by: 0

README ΒΆ

Immich-Go: Upload Your Photos to Your Immich Server

Immich-Go is an open-source tool designed to streamline uploading large photo collections to your self-hosted Immich server.

⚠️ This is an early version, not yet extensively tested
⚠️ Keep a backup copy of your files for safety

🌟 Key Features

  • Simple Installation: No NodeJS or Docker required
  • Multiple Sources: Upload from Google Photos Takeouts, iCloud, local folders, ZIP archives, and other Immich servers
  • Large Collections: Successfully handles 100,000+ photos
  • Smart Management: Duplicate detection, burst photo stacking, RAW+JPEG handling
  • Cross-Platform: Available for Windows, macOS, Linux, and FreeBSD

πŸš€ Quick Start

1. Install Immich-Go

Download the pre-built binary for your system from the GitHub releases page.

2. Basic Usage
# Upload photos from a local folder
immich-go upload from-folder --server=http://your-ip:2283 --api-key=your-api-key /path/to/your/photos

# Upload Google Photos takeout
immich-go upload from-google-photos --server=http://your-ip:2283 --api-key=your-api-key /path/to/takeout-*.zip

# Archive photos from Immich server
immich-go archive from-immich --server=http://your-ip:2283 --api-key=your-api-key --write-to-folder=/path/to/archive
3. Requirements
  • A running Immich server with API access
  • API key with appropriate permissions (see full list)

⚠️ Breaking Change: API keys must now include the asset.copy and asset.delete permissions in addition to previously required permissions. Please update your API keys accordingly.

πŸ“š Documentation

Topic Description
Installation Detailed installation instructions for all platforms
Commands Complete command reference and options
Configuration Configuration options and environment variables
Examples Common use cases and practical examples
Best Practices Tips for optimal performance and reliability
Technical Details File processing, metadata handling, and advanced features
Upload Commands Overview How immich-go processes files from different sources
Release Notes Version history and release notes

✨ How immich-go Works

immich-go offers a versatile set of commands to handle your photo and video uploads. Whether you're uploading from a simple folder, migrating from a Google Photos Takeout, or transferring assets between Immich servers, the tool provides intelligent features to preserve your metadata and organization.

Here's a brief overview of the main upload commands:

  • from-folder: The basic command for uploading from any local folder. It can create albums from your directory structure and read XMP sidecar files.
  • from-google-photos: A powerful command to migrate from a Google Photos Takeout. It intelligently matches photos with their JSON metadata to preserve albums, descriptions, and locations.
  • from-immich: A server-to-server migration tool that allows you to copy assets between two Immich instances with fine-grained filtering.
  • from-picasa: A specialized version of from-folder that automatically reads .picasa.ini files to restore your Picasa album organization.
  • from-icloud: Another specialized command that handles the complexity of an iCloud Photos takeout, correctly identifying creation dates and album structures from the included CSV files.
Leveraging Immich's Features

immich-go is more than just an uploader; it intelligently interacts with the Immich server to preserve your library's structure:

  • Albums and Tags: Automatically creates albums and tags on the server to match your source organization.
  • Stacking: Groups related images, like RAW+JPEG pairs or photo bursts, into stacks.
  • Duplicate Detection: Avoids re-uploading files that already exist on the server.
  • Efficient Uploads: Can pause Immich's background jobs (like thumbnailing) during an upload for better performance.

For a detailed explanation of how each upload command works, please see the Upload Commands Overview.

πŸ’‘ Support the Project

🀝 Contributing

Contributions are welcome! Please see our contributing guidelines for details.

πŸ“„ License

This project is licensed under the terms specified in the LICENSE file.


Need help? Check our documentation or open an issue on GitHub.

Documentation ΒΆ

The Go Gopher

There is no documentation for this package.

Directories ΒΆ

Path Synopsis
app
Package app provides the main application logic for immich-go, including client management for connecting to Immich servers.
Package app provides the main application logic for immich-go, including client management for connecting to Immich servers.
internal
config
Package config provides configuration management for the immich-go application.
Package config provides configuration management for the immich-go application.
gen
tester/cmd command
ui

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL