Skip to content

Commit

Permalink
doc updates
Browse files Browse the repository at this point in the history
  • Loading branch information
AndreyNikiforov committed Jul 13, 2024
1 parent d23e851 commit a0fc741
Show file tree
Hide file tree
Showing 10 changed files with 94 additions and 163 deletions.
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ dist/
wheelhouse/
icloudpd.egg-info
tests/fixtures/**
.vscode
__pycache__
.pytest_cache
.cache
Expand Down
8 changes: 8 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"cSpell.words": [
"icloudpd",
"seealso",
"versionadded",
"versionchanged"
]
}
43 changes: 1 addition & 42 deletions EXPERIMENTAL.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,45 +6,4 @@ Anything in this section can change without backward compatibility or even compl

DANGER ZONE: Code may not work as expected.

## CLI format

Goal: reduce user confusion and maintenance burden by restructuring CLI interface for better matching use cases and related options

### New Structure

Ideas:
- Each use case is matched to command
- Customizations are available as options

Use Cases:
- Maintain local copy/backup of iCloud: **COPY** command
- Use iCloud as a transfer medium to local storage (and clean iCloud afterwards): **MOVE** command

Orthogonal Needs:
- Scheduled sync: **WATCH** command
- management of persistent credentials: **AUTH** command
- monitoring/notification/alerting: TBD


### How to Use

Legacy command (compatible with prior versions):

`docker run -it --rm icloudpd:icloudpd icloudpd --help`

`docker run -it --rm icloudpd:icloudpd icloud --help`

`icloudpd-1.22.0-windows-amd64 --help`

Help:

`docker run -it --rm icloudpd:icloudpd`

`icloudpd-ex-1.22.0-windows-amd64 --help`

Example:

`docker run -it --rm icloudpd:icloudpd copy [email protected] /path/to/{album}/{date_created:%Y/%Y-%m}`

`icloudpd-ex-1.22.0-windows-amd64 copy [email protected] /path/to/{album}/{date_created:%Y/%Y-%m}`

(no experiments yet)
81 changes: 0 additions & 81 deletions FAQ.md

This file was deleted.

6 changes: 1 addition & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
- Available as an executable for direct downloading and through package managers/ecosystems ([Docker](https://icloud-photos-downloader.github.io/icloud_photos_downloader/install.html#docker), [PyPI](https://icloud-photos-downloader.github.io/icloud_photos_downloader/install.html#pypi), [AUR](https://icloud-photos-downloader.github.io/icloud_photos_downloader/install.html#aur), [npm](https://icloud-photos-downloader.github.io/icloud_photos_downloader/install.html#npm))
- Developed and maintained by volunteers (we are always looking for [help](CONTRIBUTING.md)).

See [Documentation](https://icloud-photos-downloader.github.io/icloud_photos_downloader/) for more details
See [Documentation](https://icloud-photos-downloader.github.io/icloud_photos_downloader/) for more details. Also, check [Issues](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues)

We aim to release new versions once a week (Friday), if there is something worth delivering.

Expand Down Expand Up @@ -61,10 +61,6 @@ icloudpd --username [email protected] --password my_password --auth-only
> [!TIP]
> This feature can also be used to check and verify that the session is still authenticated.
## FAQ

Nuances of working with the iCloud or a specific operating system are collected in the [FAQ](FAQ.md). Also, check [Issues](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues).

## Contributing

Want to contribute to iCloud Photos Downloader? Awesome! Check out the [contributing guidelines](CONTRIBUTING.md) to get involved.
54 changes: 27 additions & 27 deletions docs/authentication.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

## Multi-Factor Authentication

If your Apple account has two-factor authentication (multifactor authentication, MFA) enabled,
If your Apple account has two-factor authentication (multi-factor authentication, MFA) enabled,
you will be prompted for a code when you run the script. Two-factor authentication will expire after an interval set by Apple,
at which point you will have to re-authenticate. This interval is currently two months. Apple requires MFA for all new accounts.

Expand All @@ -25,6 +25,9 @@ The choice can be made with `--mfa-provider` parameter.

Default: *console*

## Access from Mainland China

Access to iCloud.com is blocked from mainland China. `icloudpd` can be used with `--domain cn` parameter to support downloading iCloud photos from mainland China, however, people reported mixed results with that parameter.

## FIDO

Expand All @@ -36,31 +39,7 @@ Advanced Data Protection (ADP) for iCloud accounts is not supported because `icl

## Occasional Errors

Some authentication errors may be resolved by clearing `.pycloud` subfolder in the user's home directory. [Example](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues/772#issuecomment-1950963522)

## System Keyring

You can store your password in the system keyring using the `icloud` command-line tool:

```
$ icloud --username [email protected]
ICloud Password for [email protected]:
Save password in keyring? (y/N)
```

If you have stored a password in the keyring, you will not be required to provide a password
when running the script.

If you would like to delete a password stored in your system keyring,
you can clear a stored password using the `--delete-from-keyring` command-line option:

``` sh
icloud --username [email protected] --delete-from-keyring
```

```{note}
Use `icloud`, not `icloudpd`
```
Some authentication errors may be resolved by clearing `.pyicloud` subfolder in the user's home directory. [Example](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues/772#issuecomment-1950963522)

## Password Providers

Expand All @@ -83,4 +62,25 @@ Keyring password provider, if specified, saves valid password back into keyring.

Console and Web UI are not compatible with each other. Console or WebUI providers, if specified, must be last in the list of providers because they cannot be skipped.

Default set and order of providers are: *parameter*, *keyring*, *console*
Default set and order of providers are: *parameter*, *keyring*, *console*

### Managing System Keyring

You can store your password in the system keyring or delete it from there using the `icloud` command-line tool:

```
$ icloud --username [email protected]
ICloud Password for [email protected]:
Save password in keyring? (y/N)
```

If you would like to delete a password stored in your system keyring,
you can clear a stored password using the `--delete-from-keyring` command-line option:

``` sh
icloud --username [email protected] --delete-from-keyring
```

```{note}
Use `icloud`, not `icloudpd`
```
28 changes: 27 additions & 1 deletion docs/install.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ There are three ways to run `icloudpd`:
docker run -it --rm --name icloudpd -v $(pwd)/Photos:/data -e TZ=America/Los_Angeles icloudpd/icloudpd:latest icloudpd --directory /data --username [email protected] --watch-with-interval 3600
```

Image asset date will be converted to specified TZ and then used for creating folders (see `--folder-stucture` parameter)
Image asset date will be converted to specified TZ and then used for creating folders ([see `--folder-structure` parameter](#folder_structure))

Synchronization logic can be adjusted with command-line parameters. Run the following to get full list:
``` sh
Expand Down Expand Up @@ -95,3 +95,29 @@ yay -S icloudpd-bin
``` sh
npx --yes icloudpd --directory /data --username [email protected] --watch-with-interval 3600
```

## macOS binary

`icloudpd` is available as Intel 64bit binary for macOS, but works on ARM macs too (M1, M2, M3).

Here are the steps to make it working:
- download binary from GitHub [Releases](https://github.com/icloud-photos-downloader/icloud_photos_downloader/releases) into desired local folder
- add executable flag by running `chmod +x icloudpd-1.22.0-macos-amd64`
- start it from the terminal: `icloudpd-1.22.0-macos-amd64`
- Apple will tell you that it cannot check for malicious software and refuse to run the app; click "Ok"
- Open "System Settings"/"Privacy & Security" and find `icloudpd-1.22.0-macos-amd64` as blocked app; Click "Allow"
- Start `icloudpd-1.22.0-macos-amd64` from the terminal again
- Apple will show another warning; click "Open"
- After that you can run `icloudpd-1.22.0-macos-amd64 --help` or any other supported command/option

## Error on the First Run

When you run the script for the first time, you might see an error message like this:

``` plain
Bad Request (400)
```

This error often happens because your account hasn't used the iCloud API before, so Apple's servers need to prepare some information about your photos. This process can take around 5-10 minutes, so please wait a few minutes and try again.

If you are still seeing this message after 30 minutes, then please [open an issue on GitHub](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues/new) and post the script output.
24 changes: 22 additions & 2 deletions docs/naming.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,36 @@

Assets on iCloud have names. When downloading assets, `icloudpd` can adjust names.

(folder_structure)=
## Folder Structure

```{versionchanged} 1.7.0
Support for `none` value added
```
```{versionchanged} 1.22.0
Support for OS locale added
```

`icloudpd` uses asset metadata (_created date_) to build folder hierarchy, and it can be adjusted with `--folder-stucture` parameter.
`icloudpd` uses asset metadata (_created date_) to build folder hierarchy, and it can be adjusted with `--folder-structure` parameter.

Specifying `--folder-structure none` will put all files into one folder.

### Formatting

`icloudpd` follows [Python string formatting grammar](https://docs.python.org/3/library/string.html#formatstrings) for `--folder-structure` parameter,e.g. `{:%Y}` means the need to take only 4-digit year out of created date. Full list of format codes is [available](https://docs.python.org/3/library/datetime.html#strftime-and-strptime-format-codes).

Default format is: `{:%Y/%m/%d}`

### Language-specific formatting

Some formatting codes, e.g. `%B` for printing full month, are specific to the language. By default `icloudpd` uses English regardless of the locale of the OS. With `--use-os-locale` the behavior can be changed.

Example of running `icloudpd` with specific locale under Linux or MacOS:

```shell
LC_ALL=ru_RU.UTF.8 icloudpd --use-os-locale --version
```

## Duplicates

```{versionchanged} 1.20.0
Expand All @@ -31,7 +51,7 @@ In large iCloud collections it is possible to have name collisions. To avoid col
Live Photo assets have two components: still image and short video. `icloudpd` can download both and allows customizing file name of the video portion with `--live-photo-mov-filename-policy` parameter:

- Use video file name the same as still image with `original` policy; use `--file-match-policy name-id7` to avoid clashes of video file with other videos.
- Use suffix from the still image with `suffix` policy: **"IMG_1234_HEVC.MOV"** for **"IMG_1234.HEIC"** still. This is default and works for HIEC still images only
- Use suffix from the still image with `suffix` policy: **"IMG_1234_HEVC.MOV"** for **"IMG_1234.HEIC"** still. This is default and works for HEIC still images only

## Unicode

Expand Down
10 changes: 7 additions & 3 deletions docs/nas.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ The following are example setups for NAS.

## TrueNAS

Use `Install Custom App` button to set up `icloudpd`:
Use [`Install Custom App` button](https://www.truenas.com/docs/scale/23.10/scaletutorials/apps/usingcustomapp/) to set up `icloudpd`:
| Field | Value | Note |
|-------|-------|------|
Application Name | `icloudpd` |
Expand All @@ -20,8 +20,12 @@ Portal Configuration/Enable Portal Configuration | checked |
Portal Configuration/Portal Name | `icloudpd` |
Portal Configuration/Protocol to Portal | `HTTP Protocol` |
Portal Configuration/Use Node IP for Portal IP/Domain | checked |
Portal Configuration/Port | `9090` |
Portal Configuration/Port | `9090` | Same as "Port Forwarding/Host Port" above

Once the app has started, connect to the [WebUI](webui) to enter password and MFA code one of two ways:
- Using browser from your PC to 9090 port of your NAS
- Clicking on `icloudp` button in Detail/Application Info section of TrueNAS portal
- Clicking on `icloudpd` button in Detail/Application Info section of TrueNAS portal

## Running on Synology NAS

The error `Failed to execv() /tmp/staticx-kJmNbp` has a workaround by (from an SSH terminal in my case) running `sudo mount /tmp -o remount,exec`. [#788](https://github.com/icloud-photos-downloader/icloud_photos_downloader/issues/788)
2 changes: 1 addition & 1 deletion docs/raw.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ One representation will be `original` [size](size) and another `alternative`.
As of June 2024, icloud.com always shows assets with two representations as RAW+JPEG. Photo app on Mac
allows choosing which representation to treat as original, but it is not clear what that setting changes.

`icloudpd` disambiguates behavior with `--align-raw` parameter:
`icloudpd` disambiguates the behavior with `--align-raw` parameter:

- *original* always treat RAW as original [size](size)
- *alternative* always treat RAW as alternative [size](size)
Expand Down

0 comments on commit a0fc741

Please sign in to comment.