-
Notifications
You must be signed in to change notification settings - Fork 579
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
d23e851
commit a0fc741
Showing
10 changed files
with
94 additions
and
163 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,7 +4,6 @@ dist/ | |
wheelhouse/ | ||
icloudpd.egg-info | ||
tests/fixtures/** | ||
.vscode | ||
__pycache__ | ||
.pytest_cache | ||
.cache | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
{ | ||
"cSpell.words": [ | ||
"icloudpd", | ||
"seealso", | ||
"versionadded", | ||
"versionchanged" | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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. | ||
|
||
|
@@ -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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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. | ||
|
||
|
@@ -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 | ||
|
||
|
@@ -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 | ||
|
||
|
@@ -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` | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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 | ||
|
@@ -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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters