This page offers endpoints that you can hit in order to do something, or get data.
You may also be interested in:
If you're just testing, or building something for yourself... use your personal auth token: (it'll show up here if you're logged in)
Append it to your request like this:
?auth_token=AUTH_TOKEN
If you're wanting to set up an application that others can use, or release your own chrome extension, you may want to create an OAuth2 application.
https://intend.do/oauth/authorize?response_type=code
&client_id=CLIENT_KEY
&client_secret=CLIENT_SECRET
&redirect_uri=http://example.com/REDIRECT_URI/
If you're making a Chrome extension, you'll want to use
chrome.identity.launchWebAuthFlow(
{'url': THE_ABOVE_URL, 'interactive': true},
function callback () {}
);
This will hit your redirectUri with a code as a GET param, like
http://example.com/REDIRECT_URI/?code=23rf87g2v0jij02f
https://intend.do/oauth/token?code=CODE&grant_type=authorization_code
&client_id=CLIENT_KEY&client_secret=CLIENT_SECRET
&redirect_uri=http://example.com/REDIRECT_URI/
You'll want to store this access token somewhere.
If this didn't work, then... google a bit about how to do OAuth2? It should be pretty standard. If you're still stuck, do get in touch.
Now, to access the endpoints below, use this header: Authorization: Bearer YOUR_ACCESS_CODE_GOES_HERE
)
See this javascript file for some documentation of the sorts of objects returned by the API.
Great for testing—returns the user's name and username:
/api/v0/u/me/userinfo.json
Gets the user's list of goals, including each goal's current top priority:
/api/v0/u/me/goals/active.json
The item below returns most of the data used to render the user's today page
/api/v0/u/me/today/full.json
core
... GET /api/v0/u/me/today/core.json
drafts
... GET /api/v0/u/me/today/drafts.json
recent
... GET /api/v0/u/me/today/recent.json
settings
... GET /api/v0/u/me/today/settings.json
timer
... GET /api/v0/u/me/today/timer.json
Add new intention(s)
/api/v0/u/me/intentions
...parameters: {
raw
(string: Intend data in intentions format, one item per line. returns 400 if no valid intentions found)ymd
(string, optional: date in YYYY-MM-DD format. If omitted will use the current date based on user's dayStartTime. If in the past (ie a ymd before the one currently displayed on the today page) will just update the timeline. If tomorrow, will finish today & shift to "set intentions for tomorrow" mode. Does not play nice with dates further in the future—don't bother 😉)makeCurrent
(optional boolean to put the new item(s) above all other not-yet-done items)makeAlmostCurrent
(optional boolean to put the new item(s) immediately below the top not-yet-done item)response
(optional: what to return. options are)
Complete a specific intention
/api/v0/u/me/completeById/zid
(A zid is an id for an intention or outcome—any such item. You can get the zid from newtabpage.json or today/full.json or today/core.json)
Post outcomes
/api/v0/u/me/outcomes
...parameters: {
raw
(string: Intend data in outcomes format, one item per line. returns 400 if no valid data found)ymd
(string, optional: date in YYYY-MM-DD format. if omitted will use the current date based on user's dayStartTime)response
(optional: what to return. options are)
"today"
: the /today/full.json object"count"
: how many completed outcomes for the day (default)Retrieve past entries
/api/v0/u/me/timeline/entries.json
limit
(maximum to pull; default = 21)startymd
(the earliest date to include, in YYYY-MM-DD format)endymd
(the latest date to exclude, in YYYY-MM-DD format)select
(things to select separated by +
. main options: intentions, outcomes, activity, goalCounts. default is all of these except activity)https://intend.do/api/v0/u/me/timeline/entries.json?startymd=2018-05-01&select=outcomes
Retrieve weekly reviews
To mimic the weekly reviews page, you may want to fetch the remarks for week n-1 and the overview for week n.
/api/v0/u/me/:year/week/:weeknum/remarks.json
(the review remarks for a given week)/api/v0/u/me/:year/week/:weeknum/overview.json
(the outcomes for that week, by goal, with most of the goal info as well)Creating new work blocks ('dur', short for duration)
/api/v0/u/me/add_dur
...parameters: {
ty
(string, required. "type" (must be either 'tomato' or 'sand'))min
(number, required. "minutes" of duration. can be decimal)foc
(number, optional. "focusedness". 20% = 0.2, 100% = 1. pomos default to 120% = 1.2)sCp
(number, optional. "stamp completed". unix timestamp in millis. defaults)zidToAssignTo
(string, optional. assigns the dur to the intention with this zid, returns 406 error if not found. returns {intention: ...}
if found)These two old endpoints both return {sparePomos: n, spareDurs: [...]}
/api/v0/u/me/addpomo
/api/v0/u/me/set_spare_pomos
(takes a parameter n
in the request body)The endpoints below control the actual timer itself. IMPORTANT: Note that the timer ticking logic is handled by the frontend on Intend, so while this system can let you start or stop pomodoros with a button, the actual tallying of pomodoros won't occur unless you have your today page or timer page open somewhere! Similarly, being in continuous/automatic mode will only cause the timer to continue if a tab is open.
All of them return the timer object, which looks like (click to view)
{ ticker: { state: 'ticking', mode: 'pomo', endTime: 1522442719000, continuous: true }, extras: { breakCount: 3, spareTomatos: 4, spareDurs: [{ // a list of duration items min: 25, // length in minutes ty: "tomato", // type ("tomato" or "sand") src: "r", // source (t=today page timer, r=room, a=api, m=manual) sCp: 1619231101181, // stamp completed hCp: 19.42 // hour completed (hours since midnight of relevant day) }], lastPomoIncrementStamp: 1522437901064, } }
Get current timer
/api/v0/u/me/today/timer/all
Start pomodoro
/api/v0/u/me/today/timer/startpomodoro
duration
(in minutes; if omitted, uses current setting)
Start break
/api/v0/u/me/today/timer/startbreak
duration
(in minutes; if omitted, uses current setting)
Start hourglass timer
/api/v0/u/me/today/timer/hourglass
duration
(in minutes; if omitted, uses 15 minutes)
Pause timer
/api/v0/u/me/today/timer/pause
Unpause timer
/api/v0/u/me/today/timer/unpause
Cancel timer
/api/v0/u/me/today/timer/cancel
Custom timer update
/api/v0/u/me/today/timer/ticker
...parameters: {
mode
(either "pomo" or "hourglass")state
(one of "inactive", "ticking", "breaking", "paused")endTime
(required if ticking or breaking: numerical unix timestamp in millis)remainingSeconds
(required if paused)
continuous
(boolean; will stay the same if omitted)
Get settings
/api/v0/u/me/apps/beeminder/settings.json
Put settings
/api/v0/u/me/apps/beeminder/settings.json
intentionsBinary
(beeminder goal slug for setting intentions at all)outcomesBinary
outcomesPercentage
roomPresence
weeklyReviewCount
weeklyReviewComplete
monthlyReviewCount
monthlyReviewComplete
quarterlyReviewCount
quarterlyReviewComplete
arbitrary
(array of "beemind arbitrary things" items)beemgoal
(string; beeminder goal slug for this arb match)trackWhat
(string enum: ['exists'
(intended)'d'
(completed)'pd'
(pomodoros completed)'totalMinutes'
'focusedMinutes'
'number'
'sum'
goalid
(Intend goalid, 'misc' if misc-only)textMatch
(string; text or regex match)useRegex
(boolean; true if textMatch is regex)isTextMatchInverse
(boolean; true if counting only non-matches)starred
(boolean; true means match only starred items)staked
(boolean; true means match only items with $ at stake)multiplier
(number; undefined means x1)paused
(boolean; true means this beem arb doesn't fire)Use the question box on the right