Loomio API /api/b2

/api/b2 was released in October 2023. It will replace the previous /api/b1

Your API key is:
This user account is a human. You may want to setup a bot account for API requests.

Select a group for example commands

create discussion

example

curl -X POST -H 'Content-Type: application/json' -d '{"group_id": 123, "title":"example thread", "recipient_emails":[""], "api_key": ""}' https://www.loomio.com/api/b2/discussions

params

group_id group where thread will exist
title title of the thread (required)
description context for the thread (optional)
description_format string. either 'md' or 'html' (optional, default: md)
recipient_audience string 'group' or null. if 'group' whole group will be notified about the new thread (optional)
recipient_user_ids array of user ids to notify or invite to the thread (optional)
recipient_emails array of email addresses of people to invite to the thread (optional)
recipient_message string. message to include in the email invitation (optional)

show discussion

Fetch a discussion using the discussion id (an integer) or key (a string) using the following request format

example

curl https://www.loomio.com/api/b2/discussions/abc123?api_key=

create poll

example

curl -X POST -H 'Content-Type: application/json' -d '{"group_id": 123, "title":"example poll", "poll_type": "proposal", "options": ["agree", "disagree"], "closing_at": "2025-01-28T01:00:00Z", "recipient_emails":[""], "api_key": ""}' https://www.loomio.com/api/b2/polls

params

group_id integer. optional. default: null. id of group for poll. If discussion_id is passed, group_id is ignored.
discussion_id integer. optional. default: null. id of discussion thread to add this poll to.
title string. required. title of the poll
poll_type string. required. values: 'proposal', 'poll', 'count', 'score', 'ranked_choice', 'meeting', 'dot_vote'
details string. optional. the body text of the poll
details_format string. optional. default: md. values: 'md' or 'html'.
options array of strings. If poll_type is proposal then valid values are 'agree', 'disagree', 'abstain', 'block'. If poll_type is meeting then a provide iso8601 date or datetime strings '2021-02-01' or '2022-02-15T23:32:39Z'. For all other poll_types, any string is valid.
closing_at iso8601 string or null. default: null. Specify when the poll closes with an iso8601 string such as '2025-01-28T01:00:00Z'. If null then voting is disabled and poll is considered "Work in progress".
specified_voters_only boolean. optional. default: false. true: only specified people can vote, false: everyone in the group will be invited to vote
hide_results string. optional. default: 'off'. values: 'off', 'until_vote', 'until_closed'. allow voters to see the results before the poll has closed
shuffle_options boolean. default false. display options to voters in random order.
anonymous boolean. optional. default: false. true: hide identities of voters.
recipient_audience string 'group' or null. optional. default: null. if 'group' whole group will be notified about the new thread.
notify_on_closing_soon string. optional. default: 'nobody'. values: 'nobody', 'author', 'undecided_voters' or 'voters'. specify the who to send a reminder notification to, 24 hours before the poll closes.
recipient_user_ids array of user ids to notify or invite
recipient_emails array of email addresses of people to invite to vote
recipient_message message to include in the email invitation
notify_recipients boolean. default false. false: add people to a poll without sending notifications. true: everyone invited (in this request) will get a notification email.

show poll

Fetch a poll using the poll id (an integer) or key (a string)

example

curl https://www.loomio.com/api/b2/polls/abc123?api_key=

list memberships

https://www.loomio.com/api/b2/memberships?api_key=&group_id=123
curl https://www.loomio.com/api/b2/memberships?api_key=&group_id=123

manage memberships

send a list of emails. it will invite all the new email addresses to the group.

curl -X POST -H 'Content-Type: application/json' -d '{"group_id": 123, "emails":["[email protected]"], "api_key": ""}' https://www.loomio.com/api/b2/memberships

if you pass remove_absent=1 then any members of the group who were not included in the list will be removed from the group. be careful, you could remove everyone in your group!

curl -X POST -H 'Content-Type: application/json' -d '{"group_id": 123, "emails":["[email protected]"], "remove_absent": 1, "api_key": ""}' https://www.loomio.com/api/b2/memberships

params

emails array of strings. required. email addresses of people to invite into the group
remove_absent boolean. If true, remove anyone from the group who's email is not present in the list

this returns an object with {added_emails: ["[email protected]"], removed_emails: ["[email protected]"]}.