NAME
WWW::Workflowy - Faked up API interface to the workflowy.com collaborative outlining webapp
SYNOPSIS
This module does not use an official Workflowy API! Consult workflowy.com's Terms of Service before deciding if it is okay to access their servers programmatically!
use WWW::Workflowy;
my $wf = WWW::Workflowy->new(
url => 'https://workflowy.com/shared/b141ebc1-4c8d-b31a-e3e8-b9c6c633ca25/',
# or else: guid => 'b141ebc1-4c8d-b31a-e3e8-b9c6c633ca25',
);
$node = $wf->dump;
$node = $wf->find(
sub {
my $node = shift;
my @parent_nodes = @{ shift() };
return 1 if $node->{nm} eq 'The node you are looking for';
return 1 if $node->{id} eq 'Jxn637Zp-uA5O-Anw2-A4kq-4zqKx7WuJNBN';
},
);
$node = $wf->create(
parent_id => 'Jxn637Zp-uA5O-Anw2-A4kq-4zqKx7WuJNBN',
priority => 3, # which position in the list of items under the parent to insert this node
text => "Don't forget to shave the yak",
);
$node = $wf->edit(
save_id => 'Jxn637Zp-uA5O-Anw2-A4kq-4zqKx7WuJNBN',
text => "Think of an idea for a color for the bikeshed",
);
$wf->delete( node_id => $node->{id} );
sleep $wf->polling_interval; $wf->sync;
$wf->fetch;
DESCRIPTION
All methods Carp::confess
on error. Trap errors with Try::Tiny, eval { }
, or similar to attempt to recover from them.
Each node has this structure:
{
'lm' => 1270, # time delta last modified; usually not too interesting
'nm' => 'Test 2.1', # text
'id' => '63c98305-cd96-2016-4c4f-a20f7384ad9c' # id
}
It may also have a 'ch'
containing an arrayref of additional nodes. To make things interesting, the root node does not have a 'ch'
of nodes under it. Use the get_children()
method to avoid dealing with this special case.
The value from the id
field is used as the value for save_id
, node_id
, or parent_id
in other calls.
new
Takes url
resembling https://workflowy.com/shared/b141ebc1-4c8d-b31a-e3e8-b9c6c633ca25/
or a Workflowy guid
such as b141ebc1-4c8d-b31a-e3e8-b9c6c633ca25
.
May also be initialized from a serialized copy of a previous $wf-
outline>. See t/002-concurrent-remote-ops.t
for an example of that.
Returns a coderef.
dump
Produces an ASCII representation of the outline tree.
find
Recurses through the entire outline tree, calling the callback for each item. The callback is passed the node currently being examined and an arrayref of parents, top most parent first.
edit
Changes the text of a node.
create
Created a new node.
delete
Deletes a node.
move
No class method yet. The thing handles move
commands sent down by the Workflowy server (when data was moved by another Workflowy client) but doesn't yet let you send that command to the server.
sync
sync
fetches changes other people have made to the current Workflowy outline and attempts to merge them into the local outline.
create
, edit
, and delete
minipulate data locally but only queue it to later be sent to the Workflowy server. Executing a sync
causes pending operations to be sent.
Check the return value! sync
returns false and does nothing if $wf->polling_interval
seconds have not yet passed since the last request to the Workflowy server. Calling new
generally results in a request to the Workflowy server. To avoid sync
returning false
and doing nothing, use this idiom:
sleep $wf->polling_interval;
$wf->sync;
$wf->last_poll_time
contains a timestamp of the time that the last request was made. The value for $wf->polling_interval
may change in response to a request to the server.
fetch
Fetches the latest copy of the outline from the Workflowy server, blowing away any local changes made to it that haven't yet been pushed up. This happens automatically on new
.
get_children
Takes a node id. Returns an arrayref of a node's children if it has children, or false otherwise.
SEE ALSO
BUGS
Remote changes are not merged with forgiveness. For example, if you delete a node, someone else edits the node concurrently, and then you do a sync
operation, WWW::Workflowy will blow up when it can't find the node to edit. Forgiveness should be optional.
Workflowy versions their protocol. This module targets 10
. The protocol is not a documented API. This module will likely stop working without notice. This module does things like parse out JSON from JavaScript code using regexen.
AUTHOR
Scott Walters, <scott@slowass.net>
COPYRIGHT AND LICENSE
Copyright (C) 2013 by Scott Walters
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.9 or, at your option, any later version of Perl 5 you may have available.