Some notes on accessing / exporting Apple's Reminders data on macOS.
After some investigation it seems that Tags themselves aren't exposed in the API for the EKReminders class
When you say 'tags', what specifically are you referring to? Do you mean the specific 'hashtags' tags assigned to a reminder? Or are you referring to something else?
The rules for smart lists can have many different aspects, not just tags, so even if they aren't currently accessible, the others may be:
Originally posted by @0xdevalias in keith/reminders-cli#72 (comment)
It looks like the underlying sqlite database backing the Reminders app is stored at:
/Users/devalias/Library/Reminders/Container_v1/Stores/Data-SOME-UUID-TYPE-THING.sqliteWithin that I can see the tags information in the
ZREMCDHASHTAGLABELtable.The
ZREMCDOBJECTtable seems to contain a lot of data, possibly related to the reminders themselves? TheZNAME1column seems to include some of the tags as well.The
ZREMCDREMINDERtable seems to have a lot of the actual reminder data, and seemingly foreign keys to link to some of the other tables.While I wouldn't personally risk writing to this DB for fear of corrupting it or similar; it might be possible to extract some relevant details from it in a 'read only' mode, that could then be used to filter the reminders returned from the official API's 'in app'.
Originally posted by @0xdevalias in keith/reminders-cli#72 (comment)
In
/Users/devalias/Library/Reminders/Container_v1/Stores/Data-SOME-UUID-TYPE-THING.sqlite:
- In the
ZREMCDHASHTAGLABELtable:
Z_ENT: seems to be3for all of the hashtag entriesZNAME/ZCANONICALNAME: seem to contain the text of my hashtags- In the
ZREMCDREMINDERtable:
Z_PK: ?reminder primary key?Z_ENT: seems to be32for all of the reminder entriesZCOMPLETED:1for completed,0for not completedZFLAGGED: ?probably1if flagged, otherwise0?ZPRIORITY: ?reminder priority?ZLIST: ?ID of list the reminder relates to?ZTITLE: Main reminder textZNOTES: Reminder notes- etc
- In the
ZREMCDOBJECTtable, columns such as the following look potentially useful:
ZCKIDENTIFIER: ?some sort of UUID?ZREMINDERIDENTIFIER: ?some sort of UUID?ZREMINDER3: ?might contain the ID of the reminder the row relates to?ZHASHTAGLABEL: seems to contain the PK of the hashtag fromZREMCDHASHTAGLABELZDATECOMPONENTSDATA: ?stuff related to the reminder date?Z_ENT:
30: seems to correlate to the smart lists
Z_FOK_PARENTLIST1: ?Foreign key for the associated parent list?ZBADGEEMBLEM1: Contains data like:{"Emoji" : "🎥"}that I assigned to the smartlistsZNAME3: This seems to contain the name I assigned to the smartlistsZSMARTLISTTYPE: seems to contain things like:
com.apple.reminders.smartlist.todaycom.apple.reminders.smartlist.assignedcom.apple.reminders.smartlist.customcom.apple.reminders.smartlist.flaggedZSORTINGSTYLE1: eg.manualZFILTEREDDATA: json data relating to the smartlist config; eg:
{"hashtags":{"hashtags":["health"]}}{"date":{"relativeRange":["inNext","1","week"]}}{"hashtags":{"hashtags":{"include":["to-watch","youtube-aaa","youtube-bbb","youtube-ccc","youtube-ddd"],"exclude":[],"operation":"or"}},"date":{"any":""},"operation":"and"}26: ???
ZLISTID: seems to contain things like:
com.apple.reminders.smartlist.today- Or sometimes a UUID (eg. in my data:
BA189B19-F050-43FD-A76F-115415ED91A2/5C703F5C-7ED3-4AC3-B064-7F9C1E01AA95)25: seems to correlate to normal lists
ZBADGEEMBLEMseems to be the image I assigned to the normal lists (eg.{"Emoji" : "💲"})ZNAME2seems to be the name of the normal listZSORTINGSTYLE: eg.manual24: seems to (at least partially?) correlate to hashtags for reminders
ZNAME1: seems to contain the text of a hashtag for the reminder22: ???21: ???18: ?URL related?
- Looks like
ZUTI(eg.public.url),ZURL, etc; may be related to this..ZURL: reminder URL field17: ?attachment related?
- Looks like
ZUTI(eg.public.jpeg),ZFILENAME(eg.24B9CB35-CC7F-45F0-B52F-8BED9C2F2769-732-00055908B19E5135.jpeg),ZSHA512SUM, etc; may be related to this..10: ?location related?
- Looks like
ZLATITUDE/ZLONGITUDE/ZADDRESS/ZLOCATIONUID/ZTITLEetc are related to this9: ?reminder date/time related?
- Looks like
ZALARM/ZDATECOMPONENTSDATA/ etc may be related to this7: ???
- Looks like
ZREMINDER/ZTRIGGER/Z8TRIGGER/ etc may be related to this6: ?settings/flags related?
- I only seem to have a single entry for this type, and it seems to correlate with fields like
ZDAALLOWSCALENDARADDDELETEMODIFY/ZDASUPPORTSSHAREDCALENDARS/ etc (seemingly at least 10 fields like this seem to correlate with it), as well asZCKUSERRECORDNAME,ZNAME(iCloud),ZPERSONID(PRIMARY-CLOUDKIT)That seems to be enough basic info to figure out resolving both this issue, and maybe also #72
Would just need to figure out how to match up the ID/data that the API is currently able to provide, with an ID that can be looked up in the sqlite database; and then extract the associated hashtags/etc.
I was thinking that maybe
externalIdfromreminders show Reminders --sort creation-date --sort-order ascending --format jsonmight have worked.. but it only seems to show up inZREMCDOBJECTwithin some fields with LOTS of other IDs in them, so doesn't seem ideal; thoughZREMCDREMINDERseems to have a single row match with the ID being inZCKIDENTIFIER/ZDACALENDARITEMUNIQUEIDENTIFIER, so maybe we can do it that way in like 2 steps..Originally posted by @0xdevalias in keith/reminders-cli#74 (comment)
- Accessing / Exporting Apple's Screen Time Data (0xdevalias' gist)
- Accessing Apple's iCloud Synced Passwords Keychain (0xdevalias' gist)
- Decompile Apple Shortcuts into raw XML 'source code' (0xdevalias' gist)
- AppleScript Automation Snippets (0xdevalias' gist)
- Reverse Engineering on macOS (0xdevalias' gist)