forked from christopherjwhite/org-toodledo
-
Notifications
You must be signed in to change notification settings - Fork 0
NOTE: Be sure to install the patches to url-http.el if you're seeing any strange problems. 2.9 fixes an issue with syncing child tasks before the parent. 2.8 adds much better error logging and experimental folder support. 2.6 improves support for 3 or more levels of hierarchy, and better handling of duplicate tasks and deleted tasks. 2.4 has an …
jlandahl/org-toodledo
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
;;; Commentary: ;; ;; This package adds the ability to sync org-mode tasks with ;; Toodledo, a powerful web-based todo list manager that welcomes 3rd ;; party integrations. (See http://www.toodledo.com/) ;; ;; This version of `org-toodledo' utilizes version 2.0 of the Toodledo API. ;; ;; SYNCHRONIZING FOR THE FIRST TIME ;; -------------------------------- ;; ;; The first step in using org-toodledo is to initialize a file and ;; synchronize tasks. Simply create a new file, change the mode to ;; `org-mode', then call `org-toodledo-initialize'. This will create ;; a new heading called "TASKS" (by default) and will import all ;; non-deleted tasks from Toodledo as sub-headings beneath "TASKS". ;; ;; If you already have an existing list of tasks in org file, open the ;; org file first. Move the cursor to the headling where you want ;; imported tasks from Toodledo to be inserted into the buffer. Call ;; `org-toodledo-initialize'. This will import all tasks from the ;; server as well as pushing existing tasks in the org file back to ;; the server. ;; ;; Once an org-file has been initialized, the heading selected will ;; be given a few Toodledo specific properties that are used to track ;; the status of synchronization: ;; ;; * TASKS ;; :PROPERTIES: ;; :ToodledoLastSync: 1315343842 ;; :ToodledoLastEdit: 1315337478 ;; :ToodledoLastDelete: 1314972230 ;; :OrgToodledoVersion: 2.3 ;; :END: ;; ;; This is referred to as the 'base Toodledo entry'. ;; ;; SYNCHRONIZING TASKS ;; ------------------- ;; ;; The local org-file can be synchronized with the server at any time ;; by calling `org-toodledo-sync'. When called, the following steps ;; are performed: ;; ;; 1. Tasks added to the server since the last sync are downloaded ;; and inserted as sub-headings to the Toodledo base heading (has ;; the `ToodledoLastSync' property) ;; ;; 2. Tasks modified on the server are compared against the local ;; copy. If the local copy was not modified since the last sync, ;; the local copy is updated. If local copy was modified, the ;; server copy is inserted *after* the local copy as a duplicate. ;; The user must manually merge any changes ;; ;; 3. Tasks deleted on the server are removed entirely from the ;; local org file. ;; ;; 4. Tasks modified locally are pushed to the server as edits. ;; ;; 5. Tasks created and not yet prseent on the server are pushed as ;; new tasks. ;; ;; 6. Tasks marked for deletion are deleted from the server, and ;; then purged from the local file. ;; ;; Changes to tasks are automatically detected by computing a hash of ;; the task fields. This hash is computed and saved as a property of ;; the task on sync. When the next sync occurs, the hash value is ;; compared and if it differs, the task is considered modified. This ;; eliminates the need for the user to mark tasks as modified or ;; remembere which tasks have changed -- it's all automatic! ;; ;; Note that `org-toodledo-sync' scans the entire file for tasks, not ;; just subheadings of the base entry. ;; ;; ADDING NEW TASKS ;; ---------------- ;; ;; To add a new task on the server, just create a new headline ;; anywhere in the org file and give the headline a TODO keyword. ;; When ready, call `org-toodledo-sync' to push new tasks to the ;; server. ;; ;; DELETING TASKS ;; -------------- ;; ;; Tasks cannot simply be killed from the org-file like text if the ;; were already synced with the server since they will just come back ;; the next time `org-toodledo-sync' is called. Instead, they must be ;; marked as deleted by calling `org-toodledo-mark-task-deleted'. Call ;; this function from any point within the task. At the next sync, ;; the task will be deleted from the server and then killed from the ;; local file. ;; ;; Note that it may not be necessary to delete tasks in this way. Instead ;; complete the task and let Toodledo archive completed tasks. ;; ;; TOODLEDO FIELDS ;; --------------- ;; ;; The table lists the possible Toodledo fields and how they are ;; mapped to org-mode style tasks: ;; ;; | Toodledo Field | Org-mode | Comments | ;; | id | Property :ToodledoID: | If present, this task was previoiusly synced | ;; | title | Heading | Heading minus TODO state, priority and tags | ;; | status | TODO state | See `org-toodledo-status-to-org-map' | ;; | startdate | SCHEDULED | startdate/startime are GMT | ;; | starttime | SCHEDULED | | ;; | duedate | DEADLINE | duedate/duetime are GMT | ;; | duetime | DEADLINE | | ;; | completed | CLOSED | Timestamp when the task was marked completed | ;; | repeat | Repeat interval | | ;; | repeatfrom | | | ;; | context | Tag | Context string "Work" becomes a tag :@Work: | ;; | modified | Property :Modified: | Timestamp when last modifed (set by server) | ;; | folder | Property :Folder: | | ;; | goal | Property :Goal: | | ;; | priority | Priority | 3=>A, 2=>B, 1=>C, -1,0 => D | ;; | note | Body | Body of the task minus the properties | ;; | length | Effort | | ;; | parent | | Links tasks parent/child | ;; | tag | Tag | org-mode tags, note context is also a tag | ;; ;; TODO STATES ;; ----------- ;; ;; The TODO states from Toodledo are mapped to org-mode states via the ;; `org-toodledo-status-to-org-map' alist. This can be customized to ;; choose your own TODO states, but all 10 states from Toodledo should ;; be mapped, even if only a subset are used in org-mode. ;; ;; In order to cycle through all the states recognized by Toodledo, ;; put a line like the following somewhere in your org file: ;; ;; #+SEQ_TODO: TODO(t) DELEGATED(g) SOMEDAY(s) WAITING(w) | DONE(d) CANCELLED(c) REFERENCE(r) ;; ;; CONTEXTS ;; -------- ;; ;; Toodledo 'Contexts' allow you to split tasks into contexts such as ;; Work and Home. Contexts are mapped to org tags with the '@' keyword, ;; :@Work: and :@Home:. ;; ;; Currently only contexts already on the server are recognized. Setting ;; the task context of :@Phone: when Phone is not a valid context will ;; loose the context. ;; ;; SUBTASKS ;; -------- ;; ;; Sub-tasks are supported by Toodledo with a Pro account subscription. ;; When enabled, a 2-level task hierarchy is supported: ;; ;; * TODO Write a best-selling novel ;; ** DONE Make an outline ;; ** WAITING Call Susan about the contract ;; ** TODO Finish writing ;; ** TODO Profit ;; ;; The parent/child relationship is tracked dynamically at the time ;; of sync, looking for the next heading up for each task, and if present ;; and a task, link the task to the parent. ;; ;; Bi-directional synchronization is fully supported. ;; ;; If the account is not a Pro account, subtasks will still be synced ;; to the server, but the parent/child relationship is not. This ;; yields a flat list of tasks on the server. Note that the hierarchy ;; in the org file is still maintained even though not on the server. ;; ;; NOTE: A hierarchy of TODO items of more than 2 levels is not supported ;; by the server. If 3 or more levels is present, all children will ;; appear directly beneath the top-most TODO item: ;; ;; org-mode: ;; * TODO Level 1 item ;; ** WAITING Level 1.1 item ;; *** DONE Level 1.1.1 item ;; ** DONE Level 1.2 item ;; *** DONE Level 1.2.1 item ;; ;; server: ;; * TODO Level 1 item ;; ** WAITING Level 1.1 item ;; ** DONE Level 1.1.1 item ;; ** DONE Level 1.2 item ;; ** DONE Level 1.2.1 item ;; ;; Note that the hierarchy is preserved in the org-mode file, it just ;; displays with the children flattened on the server. ;; ;; MISCELLANEOUS NOTES ;; ------------------- ;; ;; - Doesn't do lots of error trapping. Might be a good idea to ;; version-control your Org file. ;; ;; - Verify handling of other tags that are not context ;; ;; - The body of a task is stored as the Toodledo note. May get ;; confused by asterisks, so don't use any starting asterisks in ;; your body text. (or anything that looks like an Org headline). ;; ;; - w3mexcerpt.el inlcudes things needed things from w3m (since w3m ;; requires things which require things which require things which ;; require an executable which is no longer readily ;; available.). (sachac) ;; ;; - By default, save will ask to sync with Toodledo. This can ;; behavior can be changed via `org-toodledo-sync-on-save'. ;; ;; FUTURE WORK ;; ----------- ;; ;; ** TODO Feature Requests: highest priority at top ;; ;; [ ] access to toodledo via proxy would also be good for those ;; inside proxy based firewalls. (stophlong) ;; ;; [ ] Add a 'purge-completed-tasks' function -- once these tasks have ;; been synced to the server, kill them locally (since they are ;; backed up on toodledo). Alternatively, move them to an archive ;; file. (cjwhite) ;; ;; [ ] Option to restrict synchronization to just sync tasks under the ;; the base Toodledo entry. (cjwhite) ;; ;; [ ] Support tasks across all agenda files. (cjwhite) ;; ;;; Change Log: ;; ;; 2011-09-07 (cjwhite) ;; - First release for general distribution based on API 2.0 ;; ;; 2011-09-18 (cjwhite) ;; - (Bug fix) Properly create contexts that are missing on the server. (cjwhite) ;; - (Bug fix) Eliminate hyphens in the tag/properties that are saved (cjwhite) ;; - Implemented sub-tasks -- requires pro account subscription (cjwhite) ;; - Added customization variable `org-toodledo-sync-import-new-tasks' ;; ;; 2011-09-24 (cjwhite) ;; - Use https if pro subscription and patch installed (url-http appears broken ;; for POSTs with data and https, at least on my box). To enable, apply the ;; patch as follows: ;; $ cd $emacs_install_dir/lisp/url ;; $ patch < $path_to_patch/url-http.el.emacs-23.3.patch ;; Then in emacs: ;; M-x byte-compile-file $emacs_install_dir/lisp/url/url-http.el ;; This patch seems to apply cleanly to 23.2 as well, but is not tested there. ;; Search below for "bugreport" for more details and bug references. ;; ;; - Added `org-toodledo-run-tests' to load and run tests in org-toodledo-test.el. ;; This uses the active account, creating/modifying/deleting tasks with the ;; prefix 'ORGTOODLEDOTEST'. All other tasks are ignored, so it *should* operate ;; cleanly on an active toodledo account with multiple tasks. If you run ;; this and it does not pass all tests, please let me know (cjwhite) ;; ;; 2011-09-26 (cjwhite) ;; - Bug fix for checking boundp (myuhe) ;; - Support special chars (verified titles/notes) (myuhe) ;; - Added `org-toodledo-inhibit-https' to disable https ;; ;; 2011-09-29 (cjwhite) ;; - Bug fix: marking a task completed on the server did not update locally ;; ;; 2011-10-16 (cjwhite) ;; - Bug fix: first time sync of tasks with folders failed with org-mode 6.33x ;; ;; 2011-12-05 (cjwhite) ;; - Bug fix: folder / id mapping was reversed ;; - Bug fix: added require for aput / assoc ;; - Properly clear fields that are not set locally, ensuring they get cleared on server ;; ;; 2012-01-29 (cjwhite) - Version 2.2.0 ;; - Added support for starttime / duetime (merged in partical changes for myuhe). Note ;; that the web site does not seem properly handle timezones. The time in org-mode ;; is properly converted to a unix timestamp (adjusting for timezone) and sent to the ;; server, but the displayed time on toodledo.com and in apps (at least iPad app) is ;; the time component in GMT, not the timezone set in the account settings. Waiting ;; for a response from toodledo.com on this. ;; ;; - Added `org-toodledo-flatten-all-tasks' which disables parent/child tasking. ;; Set to true if you have more than 2 levels and wish to sync tasks to the server ;; as a flat list at least for backup. ;; ;; - Improved debug logging, use `org-toodledo-toggle-debug' to turn on debug logging ;; ;; - Updated `org-toodledo-run-tests' to use a test account instead of the users account. ;; ;; 2012-01-30 (cjwhite) - Version 2.3 ;; - Bug fix - major problem found whereby sync / modified times would be off just slightly ;; when syncing local changes up to the server. This would make it look like the local ;; task was still modified even after sending it up to the server. As such, any changes ;; to the task on the server would result in duplicate tasks in org-mode on the next ;; sync, because that's how changes on both sides are handled. As part of this fix ;; I completely eliminated the per task Modified and Sync properities as these are ;; pretty much unneeded because of the detection of changes by the hash code ;; ;; - Bug fix for startdate / duedate. These were probably working ok, but may have ;; misbehaved if the timezone were more than 12h off GMT, which I think can only happen ;; in a very few rare cases. ;; ;; - Fixed up the starttime / duetime. Turns out that toodledo.com treats these times ;; like alarms, so a duetime of "7:00am" is 7am, regardless of what timezone you are ;; in. That means you can change your timezone at will and the duetime is still ;; 7am *local* time. This is stored as an offset from midnight GMT on the due date. ;; ;; - Added a version variable / function `org-toodledo-version'. This is checked on ;; sync and may do some cleanup of things that have changed in various versions. This ;; will make it easier down the road to detect what version someone is running as well. ;; ;; - Added some delays into the devtest -- seems it may have been syncing back and forth ;; too fast (within the same second) such that changes may not be perceived ;; ;; - Added a lot more debug messages to help with timing / sync problems ;; ;; 2012-02-09 (cjwhite) - Version 2.4 ;; - Added new patch for url-http. This should address at least some of the spurious ;; problems that caused an XML parse error. If the XML response from the server ;; was just around 1200 bytes, url-http was not handling it properly and cutting off ;; the last few bytes. See the Installation instructions below for installing the patches ;; ;; 2012-02-09 (cjwhite) - Version 2.5 ;; - Bug fix - requesting a token was still using https even if `org-toodledo-inhibit-https' ;; was set to true. ;; ;; 2012-02-19 (cjwhite) - Version 2.6 ;; - Added `org-toodledo-agenda-mark-task-deleted' function and suggested binding ;; to mark tasks deleted from agenda mode. See Installation for info ;; ;; - When a task is marked for deleted, move the task to a task titled ;; "Deleted Tasks" to get it out of the way ;; ;; - Handle more than 2-levels of hierarchy by flatting all children. The hierarchy ;; will be preserved. See SUBTASKS above for more details. ;; ;; - Realign all tags after sync according to the width of the current window ;; ;; - Better handling of 'duplicate' tasks -- When a task has been ;; modified locally and on the server, the user is prompted to ;; resolve the difference by selecting the local copy, the server ;; copy, or editing and resolving manually ;; ;; 2012-02-19 (cjwhite) - Version 2.6.1 ;; - Fix for use of http vs https ;; ;; 2012-02-20 (cjwhite) - Version 2.7 ;; - Added support for tags, they are added as org-mode tags. ;; ;; - Fixed handling of tasks with an embedded '*' - this would ;; completely mess things up of the '*' was the first char of ;; a line ;; ;; - Added customization `org-toodledo-indent-task-note', set to t ;; by default. This indents the note according to the task level. ;; This has a cleaner look and reduces the chance of errors like ;; the above with '*' as the first char. ;; ;; - Better detection of actual note text, eliminating blank lines ;; ;; - Fixed handling of "Invalid Key" error that indicates the token ;; needs to be refreshed ;; ;; - Fix bug for subtasks if parent is not at top-level ;; ;; 2012-03-13 (cjwhite) - Version 2.8 ;; - Significantly better error handling for adding, editng and deleting ;; tasks during synchronization. If errors occurred, only the offending ;; task should be affected, allowing all other tasks to be synced. The ;; specific error message is logged for better debugging. ;; ;; - Added customization `org-toodledo-folder-support-mode'. Setting this ;; to `heading' will create heading tasks according to the folder name ;; and put all tasks in that folder as child tasks of the heading. ;; No support yet for creating folders in org mode, create the folders ;; on toodledo.com first and put at least one task in the folder. This ;; feature is somewhat experimental. ;; ;; - Improved handling of token expiration / invalid key errors ;; ;; - Added simulation mode for testing without actually hitting the server. ;; Allows simulating error conditions that are potentially hard to ;; reproduce with a real connection to the server. See org-toodledo-sim.el ;; and org-toodledo-test.el where sim calls are used. ;; ;; 2012-07-21 (cjwhite) - Version 2.9 ;; - Added 'length' to the list of fields to ignore if 0 for computing ;; a hash ;; ;; - Removed deprecated/obsolete use of aput/adelete from assoc.el ;; ;; - Hopefully finally fixed spurious issue where syncing resulted in ;; "Failed to find todo entry...". When processing incoming tasks ;; from the server, process parent tasks *then* child tasks. It seems ;; in some cases the child task may show up first before the parent ;; is known. ;;; Installation: ;; ;; 1. Required emacs packages: ;; * `w3m' or `w3mexcerpt' -- see Notes below ;; * `http-post-simple' -- http://www.emacswiki.org/emacs/http-post-simple.el ;; ;; 2. Put this file in your load path, byte compile the file for best ;; performance, see `byte-compile-file'. ;; ;; 3. Put the following in your .emacs: ;; ;; (push "<path-to-this-file>" load-path) ;; (require 'org-toodledo) ;; (setq org-toodledo-userid "<toodledo-userid>") << *NOT* your email! ;; (setq org-toodledo-password "<toodled-password>") ;; ;; ;; Useful key bindings for org-mode ;; (add-hook 'org-mode-hook ;; (lambda () ;; (local-unset-key "\C-o") ;; (local-set-key "\C-od" 'org-toodledo-mark-task-deleted) ;; (local-set-key "\C-os" 'org-toodledo-sync) ;; ) ;; ) ;; (add-hook 'org-agenda-mode-hook ;; (lambda () ;; (local-unset-key "\C-o") ;; (local-set-key "\C-od" 'org-toodledo-agenda-mark-task-deleted) ;; ) ;; ) ;; ;; 4. Install 2 patches for url-http.el (these are written for 23.3, but may ;; work for other versions, if not patch manually, as the diffs are ;; not that complex) ;; ;; url-http.el.emacs-23.3.patch ;; - addresses http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9592, ;; involving attempted connection reuse ;; - addresses http://debbugs.gnu.org/cgi/bugreport.cgi?bug=8931, ;; problem when sending a request with no data ;; ;; url-http.el.emacs-23.3.patch2 ;; - addresses http://debbugs.gnu.org/cgi/bugreport.cgi?bug=10768 ;; fixes a problem with responses that are barely longer than 1 ;; TCP data packet (about 1200 bytes) ;; ;; To install the patches: ;; $ cd $emacs_install_dir/lisp/url ;; $ patch < $path_to_patch/url-http.el.emacs-23.3.patch ;; $ patch < $path_to_patch/url-http.el.emacs-23.3.patch2 ;; ;; Then in emacs: ;; M-x byte-compile-file $emacs_install_dir/lisp/url/url-http.el ;; ;; This patch seems to apply cleanly to 23.2 as well, but is not tested there. ;;
About
NOTE: Be sure to install the patches to url-http.el if you're seeing any strange problems. 2.9 fixes an issue with syncing child tasks before the parent. 2.8 adds much better error logging and experimental folder support. 2.6 improves support for 3 or more levels of hierarchy, and better handling of duplicate tasks and deleted tasks. 2.4 has an …
Resources
Stars
Watchers
Forks
Packages 0
No packages published
Languages
- Emacs Lisp 100.0%