Connect Habitica to Definable AI
Habitica is an open-source task management application that gamifies productivity by turning tasks into role-playing game elements.
About Habitica
Habitica is a productivity tool. Connect it to Definable AI with one-click OAuth2 — no API keys or custom code required.
What you can automate with Habitica
Use Definable AI's agent platform to trigger workflows from Habitica, process results with 50+ AI models, and sync data across 900+ connected apps.
Tools & Actions (82 available)
- Add Push Device: Tool to register a push notification device for the authenticated user. Use when you need to enable push notifications for mobile devices or UnifiedPush clients.
- Add Tag to Task: Tool to add a tag to a task. Use when you need to categorize or label a task with an existing tag.
- Add Task to Challenge: Tool to add a new task to a specified challenge. Use when you need to programmatically create a challenge task after the challenge is set up and you have its ID.
- Cancel Subscription: Attempts to cancel the authenticated user's subscription. Since Habitica's public API does not provide a cancellation endpoint, this action checks the current subscription state and returns: - success=True with a no-op message if there is no active subscription - success=False with guidance to cancel via the website/app if a subscription appears active
- Clone Challenge: Tool to clone an existing challenge. Use when you need to duplicate a challenge to a different group with a new name.
- Create Challenge: Tool to create a new challenge. Use when you need to start a challenge in a specific group with title, summary, and optional tasks.
- Create Habitica Party: Create a new Habitica party for collaborative gameplay. Use this tool to create a party where users can: - Participate in quests together - Chat with party members - Share achievements and progress **Important Notes:** - A user can only be in one party at a time. If already in a party, they must leave first. - Guilds are no longer supported by Habitica (removed August 2023). Only 'party' type works. - The authenticated user automatically becomes the party leader.
- Create Tag: Tool to create a new tag. Use after determining the desired tag name.
- Create Task: Create a new task in Habitica. Supports four task types: - 'habit': Recurring positive/negative actions (use up/down to enable +/- buttons) - 'daily': Scheduled tasks that repeat on a schedule (configure with frequency, repeat, startDate) - 'todo': One-time tasks with optional due date (use date field) - 'reward': Custom rewards that cost gold (set value for the gold cost) Required fields: text (task title), type (habit/daily/todo/reward). Optional: notes, priority (0.1=Trivial, 1=Easy, 1.5=Medium, 2=Hard), tags, checklist.
- Create Webhook: Tool to create a new webhook for taskActivity events. Use when you need real-time notifications of task creation, updates, deletion, or scoring.
- Delete Challenge Task: Permanently deletes a task from a challenge. Only the challenge leader can delete challenge tasks. Use get_challenge_tasks to list tasks and their IDs first. The task cannot be recovered after deletion.
- Delete Group Chat Message: Tool to delete a chat message from a Habitica group (party, guild, or Tavern). Use when you need to remove a specific chat message. Note that only the message author or group moderators can delete messages.
- Delete Habitica Challenge: Permanently delete a Habitica challenge. Only the challenge leader (creator) or an admin can delete a challenge. This action is irreversible - once deleted, the challenge and all associated tasks are permanently removed. Use HABITICA_GET_USER_CHALLENGES to find challenge IDs you own.
- Delete Habitica Tag: Tool to delete a tag for the authenticated user. Use when you need to remove an obsolete tag after confirming it’s no longer applied to any tasks.
- Delete Task: Permanently deletes a user's task (habit, daily, todo, or reward) by its ID. The task cannot be recovered after deletion. Use get_tasks to list tasks and their IDs first.
- Delete Task Checklist Item: Tool to delete a checklist item from a task. Use when you need to remove a specific checklist item from a todo or daily task.
- Delete User Message: Tool to delete a message from the authenticated user's inbox by its ID. Use when you need to remove a specific message from the user's Habitica inbox.
- Delete User Push Device: Tool to remove a push device registration from the authenticated user's account. Use when you need to unregister a device that should no longer receive push notifications.
- Dismiss Bailey Announcement: Tool to dismiss the latest Bailey announcement in Habitica, allowing it to be read later. Use this when the user wants to clear the current news notification without reading it. The announcement will reappear later.
- Equip Item: Tool to equip or unequip gear, pets, mounts, or costume items in Habitica. Use when you need to change the user's equipped items. Equipping an already-equipped item will unequip it.
- Export Challenge to CSV: Tool to export a Habitica challenge to CSV format. Use when you need to download challenge data as a CSV file. The CSV contains all challenge tasks and participant information.
- Export User Data JSON: Exports the authenticated user's complete data in JSON format. Use when you need a full backup or comprehensive snapshot of all user data. Returns the raw internal data structure with all fields and nested objects.
- Get Challenge: Tool to retrieve details of a specific challenge. Use when you have the challenge ID and need its full data.
- Get Challenge Tasks: Tool to get all tasks for a specified challenge. Use when you have a challenge ID and need to list its defined tasks, including challenge metadata per task.
- Get Content: Retrieves all Habitica game content definitions in a single request. Returns ~9MB of static game data including achievements, quests, gear, pets, mounts, eggs, hatching potions, food, backgrounds, spells, and more. Use cases: - Loading full game content to cache for local lookups - Getting all available items, quests, or equipment for reference - Building item pickers or content browsers Note: For specific content types, prefer get_content_by_type to reduce payload size. This endpoint requires no authentication but returns localized English text by default.
- Get Content By Type: Retrieves Habitica game content data filtered by a specific category type. Use this tool to fetch game definitions like quest details, equipment stats, pet/mount info, backgrounds, spells, or other static game content. Useful when you need specific category data without fetching all content at once.
- Get Equipment: Tool to retrieve the authenticated user’s equipped gear and costume. Use when you need to inspect current battle gear and costume slots.
- Get Export History CSV: Tool to export user tasks history in CSV format. Returns CSV data with task completions and updates over time.
- Get Export Inbox HTML: Tool to export inbox data in HTML format from Habitica. Use when you need to retrieve the user's private messages and inbox content as an HTML document.
- Get Group: Retrieves detailed information about a Habitica group (guild or party). Use 'party' as groupId to get the user's current party, or provide a specific group UUID obtained from HABITICA_GET_GROUPS.
- Get Group Challenges: Tool to retrieve challenges available in a specific group (guild, party, or tavern).
- Get Group Members: Retrieve members of a Habitica group (guild or party). Supports pagination via lastId parameter and optional search filtering. Use 'party' as groupId to get members of the current user's party.
- Get Habitica API Status: Tool to check Habitica API server status. Use when you need to verify if the Habitica service is operational before making other API calls.
- Get Habitica Achievements: Retrieves all available Habitica achievements from the game's content catalog. This returns achievement definitions (icons, names, descriptions) - NOT user progress. Use HABITICA_GET_USER_ACHIEVEMENTS to get a specific user's achievement progress.
- Get Habitica Groups: Retrieves Habitica groups based on type. Use 'guilds' to get all guilds the authenticated user belongs to, 'party' to get the user's current party, or 'tavern' to get the global Tavern (the main public chat).
- Get Habitica Tavern Group: Tool to retrieve the Habitica Tavern (habitrpg) group details. The Tavern is the main public group where all Habitica users can chat and participate in community discussions.
- Get Model Paths: Retrieves all available field paths and their data types for a specified Habitica model. Use this to discover the structure and available fields for user, group, challenge, tag, or task models. Helpful for understanding what fields can be queried or updated.
- Get News: Tool to retrieve the latest Bailey announcement from Habitica. Use when you need to check current news, events, or updates posted by Bailey.
- Get Notifications: Tool to retrieve notifications for the authenticated user. Use when you need to fetch the user's current notification list after authenticating.
- Get Party: Retrieves the authenticated user's party details from Habitica. Returns information about the user's current party including: - Party name, description, and member count - Party leader information - Current quest status and progress - Recent chat messages - Leader-only permissions Note: Returns an error if the user is not currently in a party. No parameters required - automatically fetches the party for the authenticated user.
- Get Party Chat Messages: Tool to retrieve party chat messages from Habitica. Use when you need to fetch recent chat messages from the authenticated user's party.
- Get Party Members: Retrieve members of the authenticated user's party. Returns a list of party members with their IDs, usernames, and display names. The authenticated user must be in a party for this to succeed. Use 'include_all_public_fields=True' for full profile data (avatar, stats, etc.). Supports pagination via 'last_id' parameter for parties with many members.
- Get Shops Market Gear: Tool to retrieve the available gear for purchase in the market shop. Use when you need to check what equipment is available for each character class. Returns gear organized by class: healer, wizard, rogue, and warrior.
- Get Tags: Retrieve all tags for the authenticated Habitica user. Tags are labels that can be attached to tasks for organization. Returns both user-created tags and challenge-related tags. Use this to get tag IDs for filtering tasks or assigning tags to new tasks.
- Get Task by ID: Retrieve a task by its unique ID. Works for any Habitica task type (habit, daily, todo, reward) whether it belongs to a challenge or is a personal user task. Returns full task details including type-specific properties like completion status, streaks, and scheduling information.
- Get Tasks: Tool to retrieve all tasks for the authenticated user. Use when you need the user's current tasks list after authenticating.
- Get Time Travelers Shop: Tool to retrieve available items in the Time Travelers shop. Use when you need to see what quests, backgrounds, pets, or mounts can be purchased with hourglasses.
- Get User Achievements: Tool to retrieve the authenticated user's achievements. Use after authenticating to fetch the current user's achievements.
- Get User Challenges: Tool to retrieve challenges the authenticated user participates in. Use when you need a paginated list of user challenges.
- Get User Inventory: Retrieves the authenticated user's full inventory from Habitica, including eggs, hatching potions, food, quest scrolls, special items, pets, mounts, and gear. Use this to check what items a user owns.
- Get User Profile: Retrieves the authenticated user's complete Habitica profile. Returns comprehensive user data including: - Stats: HP, MP, level, experience, gold, and character class - Inventory: gear, pets, mounts, eggs, potions, and quest items - Achievements: unlocked achievements and completed quests - Party: current party membership and quest progress - Preferences: language, timezone, notification settings - Tasks: order of habits, dailies, todos, and rewards - Tags: user-created tags for task organization This is a read-only endpoint that requires no parameters. The user is identified automatically via the API credentials.
- Get User Quest Progress: Retrieves the authenticated user's party quest progress. Returns information about the current quest including: - Whether a quest is active - Quest key (e.g., 'basilist', 'goldenknight1') - Progress data (boss HP, damage dealt, or items collected) - Which party members have joined the quest If the user is not in a party or there is no active quest, quest_active will be False.
- Get User Stats: Retrieves the authenticated Habitica user's game statistics including health (hp), mana (mp), experience (exp), gold (gp), level, class, attribute points, and active buffs. No parameters required - uses authenticated user credentials automatically. Returns stats for tracking player progress, checking resource levels before using skills, or displaying character status.
- Get User Subscription: Tool to retrieve the authenticated user's subscription details. Use after authenticating to verify current subscription status.
- Get Webhooks: Retrieves all webhooks configured for the authenticated Habitica user. Returns a list of webhooks including their URLs, types, enabled status, and task activity options. Use this to check existing webhook configurations, monitor webhook health via failure counts, or get webhook IDs for updates/deletions.
- Get World State: Retrieves the current state of the Habitica game world including active events, world boss status, and seasonal NPC visual themes. Use when checking for active world events, monitoring world boss progress, or determining current seasonal themes.
- Invite To Group: Tool to invite users to a specific group. Use when you need to send invitations by user UUID, email, or username.
- Invite To Party: Tool to invite users to the authenticated user's party. Use when you have a list of identifiers (UUIDs, emails, or usernames) ready and want to add them to your current party.
- Invite To Quest: Tool to invite party members to a quest. Use when you want to start a quest with a specific quest key in a group. The user must own the quest scroll to invite others.
- Join Challenge: Tool to join a challenge. Use after confirming the challenge ID to participate in a specific challenge.
- Leave Challenge: Tool to leave a Habitica challenge. Use when you need to remove yourself from a specific challenge and decide whether to keep or remove its tasks.
- Leave or Delete Habitica Group: Leave or delete a Habitica group (party or guild). This tool allows you to: 1. Leave a party: Pass 'party' as groupId or the party's UUID to leave your current party. 2. Leave a guild: Pass the guild's UUID to leave the guild. 3. Delete a guild: If you are the leader and there are no other members, passing the guild's UUID will delete it (DELETE endpoint is tried if leave fails). Note: The Habitica API endpoint used is POST /groups/:groupId/leave. Only if that fails (e.g., you're the leader trying to delete an empty guild), the DELETE /groups/:groupId endpoint is attempted.
- Local Login: Tool to authenticate a user via local credentials. Use when needing an API token for subsequent Habitica requests.
- Local User Registration: Tool to register a new Habitica user via email and password. Use when creating a fresh account before authentication.
- Mark Group Chat Seen: Tool to mark all chat messages as read/seen for a specific group. Use when you need to clear unread message notifications in a group chat. Requires a valid group ID ('party' for user's party, 'habitrpg' for Tavern).
- Mark Notification Seen: Tool to mark a single notification as seen in Habitica. Use this when you need to mark one specific notification as read after the user has viewed it.
- Mark Notifications Seen: Marks specific notifications as read/seen in Habitica. Use this after getting notifications to clear unread notification badges. Requires valid notification IDs from the Get Notifications action. Returns updated notification state.
- Move Pinned Item: Tool to move a pinned item in the rewards column to a new position. Use when you need to reorder pinned items after sorting them.
- Move Task To Position: Move a Habitica task to a new position in the task list. Use this when you need to reorder tasks by moving a specific task to the top (position=0), bottom (position=-1), or any specific position. The response returns the updated task order for the task type (habit, daily, todo, or reward) that the moved task belongs to.
- Read Card: Tool to mark a card as read in Habitica. Use when a user receives a special card (birthday, greeting, nye, thankyou, or valentine) and wants to acknowledge it. Updates user.flags.cardReceived and returns updated user.items.special.
- Remove Party Member: Removes a member from the authenticated user's party. Requirements: - You must be the party leader to remove members - You cannot remove yourself (use Leave Party instead) - The member must be currently in your party Use Get Party Members first to obtain member IDs. This action is typically used to remove inactive members or those who no longer wish to participate.
- Reset User Account: Resets the authenticated user's account to starting state. This permanently deletes all tasks, resets character to level 1, and clears progress while retaining some items and achievements. Use with caution as this action is irreversible.
- Score Task: Score a Habitica task to mark it as completed or incomplete. Use this tool to: - Mark a todo as complete ('up') or incomplete ('down') - Check off a daily task ('up') or uncheck it ('down') - Record a positive habit action ('up') or negative habit action ('down') - Redeem a reward (use 'up' direction for rewards) Returns updated user stats including health, mana, experience, gold, and level. Scoring tasks can trigger drops (food, eggs, potions) and quest progress.
- Social Auth: Tool to authenticate a user via a social provider. Use after obtaining an OAuth token or code from Facebook, Google, GitHub, or Apple.
- Subscribe Webhook: Tool to enable (subscribe) an existing webhook by ID for the authenticated user. This aligns with Habitica's documented API by updating the webhook resource to ensure it is enabled. Usage: obtain the webhook ID (e.g., via Get Webhooks or after creating a webhook) and call this action to set enabled=true.
- Unlink All Challenge Tasks: Tool to unlink all tasks from a Habitica challenge. Use when you need to disconnect all tasks associated with a challenge and decide whether to keep or remove them.
- Update Group: Tool to update a Habitica group (party or guild) by modifying its properties. Use when you need to change the name, description, or summary of an existing group. Only the group leader can update group properties.
- Update Tag: Tool to update an existing tag's name. Use when you need to rename a tag after identifying its ID.
- Update Task: Update an existing task in Habitica. Use this to modify task properties like title, notes, priority, or other attributes. Only include fields you want to update - all body parameters are optional.
- Update Task Checklist Item: Tool to update a checklist item in a task. Use when you need to modify the text of a specific checklist item in a todo or daily task.
- Update User: Update the authenticated user's profile, preferences, flags, and other settings in Habitica. Use dot notation for nested fields (e.g., profile.name, preferences.language). Note: Some paths are protected and cannot be modified (e.g., stats.class will be rejected).
- Validate Coupon Code: Validate a Habitica coupon code to check if it is valid and active. Use this tool to verify coupon codes before attempting to apply them to a user account. Returns information about the coupon's validity and type (e.g., subscription, gems).
How to connect Habitica
- Sign in to Definable AI and go to Apps
- Search for Habitica and click Connect
- Authorize via OAuth2 — takes under 30 seconds
- Use Habitica actions in your AI agents and workflows