Linear Integration for AI Agents

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Linear MCP or direct API to create, update, assign, and comment on issues through natural language.
Linear Logo
Gradient Top
Gradient Middle
Gradient Bottom
divider

Supported Tools and Triggers

Tools
Triggers
Create linear attachmentCreates a new attachment and associates it with a specific, existing linear issue.
Create a commentCreates a new comment on a specified linear issue.
Create linear issueCreates a new issue in a specified linear project and team, requiring a title and description, and allowing for optional properties like assignee, state, priority, cycle, and due date.
Get create issue default paramsFetches a linear team's default issue estimate and state, useful for pre-filling new issue forms.
Create a labelCreates a new label in linear for a specified team, used to categorize and organize issues.
Delete issueArchives an existing linear issue by its id, which is linear's standard way of deleting issues; the operation is idempotent.
Get all teamsRetrieves all teams from the linear workspace without requiring any parameters.
Download issue attachmentsDownloads a specific attachment from a linear issue; the `file name` must include the correct file extension.
Get current userGets the currently authenticated user's id, name, email, and other profile information.
Get cycles by team IDRetrieves all cycles for a specified linear team id; cycles are time-boxed work periods (like sprints) and the team id must correspond to an existing team.
Get Linear issueRetrieves an existing linear issue's comprehensive details, including title, description, attachments, and comments.
Get all cyclesRetrieves all cycles (time-boxed iterations for work) from the linear account; no filters are applied.
List Linear issuesLists non-archived linear issues; if project id is not specified, issues from all accessible projects are returned.
Get labels by teamRetrieves all labels associated with a given team id in linear; the team id must refer to an existing team.
List linear projectsRetrieves all projects from the linear account.
List Linear statesRetrieves all workflow states for a specified team in linear, representing the stages an issue progresses through in that team's workflow.
Get teams by projectRetrieves all teams, including their members, and filters each team's associated projects by the provided 'project id'.
List Linear usersLists all users in the linear workspace with their ids, names, emails, and active status.
Remove label from Linear issueRemoves a specified label from an existing linear issue using their ids; successful even if the label isn't on the issue.
Run Query or MutationWildcard action that executes any graphql query or mutation against the linear api.
Update issueUpdates an existing linear issue using its `issue id`; requires at least one other attribute for modification, and all provided entity ids (for state, assignee, labels, etc.

Connect Linear MCP Tool with your Agent

Python
TypeScript

Install Composio

python
pip install composio claude-agent-sdk
Install the Composio SDK and Claude Agent SDK

Create Tool Router Session

python
from composio import Composio
from claude_agent_sdk import ClaudeSDKClient, ClaudeAgentOptions

composio = Composio(api_key='your-composio-api-key')
session = composio.create(user_id='your-user-id')
url = session.mcp.url
Initialize the Composio client and create a Tool Router session

Connect to AI Agent

python
import asyncio

options = ClaudeAgentOptions(
    permission_mode='bypassPermissions',
    mcp_servers={
        'tool_router': {
            'type': 'http',
            'url': url,
            'headers': {
                'x-api-key': 'your-composio-api-key'
            }
        }
    },
    system_prompt='You are a helpful assistant with access to Linear tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Create a new Linear issue titled "Bug: Login page fails on submit" in the Web team project')
        async for message in client.receive_response():
            if hasattr(message, 'content'):
                for block in message.content:
                    if hasattr(block, 'text'):
                        print(block.text)

asyncio.run(main())
Use the MCP server with your AI agent

Connect Linear API Tool with your Agent

Python
TypeScript

Install Composio

python
pip install composio_openai
Install the Composio SDK

Initialize Composio and Create Tool Router Session

python
from openai import OpenAI
from composio import Composio
from composio_openai import OpenAIResponsesProvider

composio = Composio(provider=OpenAIResponsesProvider())
openai = OpenAI()
session = composio.create(user_id='your-user-id')
Import and initialize Composio client, then create a Tool Router session

Execute Linear Tools via Tool Router with Your Agent

python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'List all open Linear issues assigned to me this week'
  }]
)
result = composio.provider.handle_tool_calls(
  response=response,
  user_id='your-user-id'
)
print(result)
Get tools from Tool Router session and execute Linear actions with your Agent

Why Use Composio?

AI Native Linear Integration

  • Supports both Linear MCP and direct API based integrations
  • Structured, LLM-friendly schemas for reliable tool execution
  • Rich coverage for reading, writing, and querying your Linear data

Managed Auth

  • Built-in OAuth handling with automatic token refresh and rotation
  • Central place to manage, scope, and revoke Linear access
  • Per user and per environment credentials instead of hard-coded keys

Agent Optimized Design

  • Tools are tuned using real error and success rates to improve reliability over time
  • Comprehensive execution logs so you always know what ran, when, and on whose behalf

Enterprise Grade Security

  • Fine-grained RBAC so you control which agents and users can access Linear
  • Scoped, least privilege access to Linear resources
  • Full audit trail of agent actions to support review and compliance

Frequently Asked Questions

Do I need my own developer credentials to use Linear with Composio?

No, you can get started immediately using Composio's built-in Linear app. For production, we recommend configuring your own OAuth credentials.

Can I use multiple toolkits together?

Yes! Composio's Tool Router enables agents to use multiple toolkits. Learn more.

Is Composio secure?

Composio is SOC 2 and ISO 27001 compliant with all data encrypted in transit and at rest. Learn more.

What if the API changes?

Composio maintains and updates all toolkit integrations automatically, so your agents always work with the latest API versions.

Used by agents from

Context
ASU
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
ASU
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai
Context
ASU
Letta
glean
HubSpot
Agent.ai
Altera
DataStax
Entelligence
Rolai

Never worry about agent reliability

We handle tool reliability, observability, and security so you never have to second-guess an agent action.