Skip to main content

SimpleiCloud is a lightweight iCloud client for Python, currently focused exclusively on managing contacts.

Project description

SimpleICloud

SimpleiCloud is a lightweight iCloud client for Python, currently focused exclusively on managing contacts.

Unlike other libraries — such as the excellent PyiCloud — SimpleiCloud aims to support a broader set of contact-related use cases, including creating, updating, and deleting contacts.

SimpleiCloud is powered by requests HTTP library.

This module is under active development, and we welcome contributions from the community.

Examples

You must use an app-specific password for iCloud (generate it at https://appleid.apple.com/ > Sign-In & Security > App-Specific Passwords)

Package Installation

pip install simple-icloud

Class Instantiation

from simple_icloud import SimpleICloudService

simpleicloudservice = SimpleICloudService(
    username="user@domain.com",
    password="secret_P422sword",
)

Get a contact

contact = simpleicloudservice.get_contact("F4ZZZZ0-EZZ7-4ZZD-8ZZE-C4FZZZZZZACD")

Get all contacts

contacts_list = simpleicloudservice.get_all_contacts()

Delete a contact

contact = simpleicloudservice.delete_contact("F4ZZZZ0-EZZ7-4ZZD-8ZZE-C4FZZZZZZACD")

Create a contact

create the vCard

import uuid
import vobject
v = vobject.vCard()
v.add("fn").value = "Pippo DePippis"
# don't ask me why but iCloud need the following!
# credits to https://github.com/pimutils/vdirsyncer/issues/1145#issuecomment-2464999129
v.add("n").value = vobject.vcard.Name(family="DePippis", given="Pippo")
phone = v.add("tel")
phone.value = phone_
phone.type_param = "CELL"
email = v.add("email")
email.value = "pippo.depippis@xyz.abc"
email.type_param = ["INTERNET", "HOME", "pref"]
uuid_ = str(uuid.uuid4())
v.add("uid").value = uuid_

create the contact in iCloud

simpleicloudservice.create_contact(vcard=v)

Update a contact

edit the contact's feature

email = v.add("email")
email.value = "blabla@aaa.com"
email.type_param = ["INTERNET", "HOME", "pref"]

update the contact in iCloud

simpleicloudservice.update_contact(v)

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

simple_icloud-0.1.5.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

simple_icloud-0.1.5-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file simple_icloud-0.1.5.tar.gz.

File metadata

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

File hashes

Hashes for simple_icloud-0.1.5.tar.gz
Algorithm Hash digest
SHA256 7bedc01632e2ca23f28231f05034bd27d4657dc86cf8973bc514beecd418ece0
MD5 9256387c311b648c50c1c18fe9075ce0
BLAKE2b-256 99e6db97a6d52b07502b203ab8e79edc9402194036ab2573d9ec2117d908d211

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_icloud-0.1.5.tar.gz:

Publisher: publish.yml on luca-ferreri/simple-icloud

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

File details

Details for the file simple_icloud-0.1.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for simple_icloud-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2e2286da293f1555d5a5276b4725ab17e163028a5b53bf9775c1ed3db0cca6b4
MD5 312c95fc3958467828fcb3fd08d69ece
BLAKE2b-256 497a7e00b39da6e28e0214c1a8bcc05867329d2c03c1e786983f7ff3edf6edc9

See more details on using hashes here.

Provenance

The following attestation bundles were made for simple_icloud-0.1.5-py3-none-any.whl:

Publisher: publish.yml on luca-ferreri/simple-icloud

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