# Classmarker

```json
{
  "name": "Classmarker",
  "slug": "classmarker",
  "url": "https://composio.dev/toolkits/classmarker",
  "markdown_url": "https://composio.dev/toolkits/classmarker.md",
  "logo_url": "https://logos.composio.dev/api/classmarker",
  "categories": [
    "education & lms"
  ],
  "is_composio_managed": false,
  "updated_at": "2026-05-12T10:06:19.859Z"
}
```

![Classmarker logo](https://logos.composio.dev/api/classmarker)

## Description

Securely connect your AI agents and chatbots (Claude, ChatGPT, Cursor, etc) with Classmarker MCP or direct API to create exams, grade submissions, fetch detailed results, and manage test-taker access through natural language.

## Summary

ClassMarker is a professional online quiz maker for business and education. It provides instant grading, flexible test design, and in-depth reporting.

## Categories

- education & lms

## Toolkit Details

- Tools: 28

## Images

- Logo: https://logos.composio.dev/api/classmarker

## Authentication

- **Api Key**
  - Type: `api_key`
  - Description: Api Key authentication for Classmarker.
  - Setup:
    - Configure Api Key credentials for Classmarker.
    - Use the credentials when creating an auth config in Composio.

## Suggested Prompts

- Add student to biology exam access list
- Create a new question for math quiz
- Delete user account for withdrawn student
- Organize new hires into onboarding group

## Supported Tools

| Tool slug | Name | Description |
|---|---|---|
| `CLASSMARKER_CREATE_ACCESS_LIST_ITEM` | Create Access List Item | Tool to add one or more access codes to an access list. Use after obtaining a valid access_list_id to grant exam access. |
| `CLASSMARKER_CREATE_CATEGORY` | Create a new question category | Tool to create a new question category. Use after confirming the parent category ID. |
| `CLASSMARKER_CREATE_GROUP` | Create Group | Tool to create a new group. Use when you need to organize users into a specific group after planning your user structure. |
| `CLASSMARKER_CREATE_QUESTION` | Create Question | Tool to create a new question with specified text, type, and category in ClassMarker. Supports multiplechoice, multipleresponse, truefalse, and essay question types. |
| `CLASSMARKER_CREATE_USER` | Create ClassMarker User | Tool to create a new user in ClassMarker. Use after gathering user details to provision accounts. Provide user info and optional group assignments. Returns the complete API response. |
| `CLASSMARKER_DELETE_ACCESS_LIST_ITEM` | Delete Access List Item | Removes one or more access codes from a ClassMarker access list. Access lists are used to control exam access by requiring users to provide unique identifiers (e.g., email addresses, employee IDs, student numbers). Each code can be used a limited number of times per exam, and codes are recorded with exam results. To use this action: 1. First call GET_ALL_GROUPS_LINKS_EXAMS to find available access list IDs 2. Provide the access_list_id and the list of codes to remove 3. Up to 100 codes can be removed per request Note: This action is idempotent - deleting codes that don't exist will not cause an error. |
| `CLASSMARKER_DELETE_API_KEY` | Delete API Key | Tool to delete an API key by its ID. Use when you need to revoke an API key immediately. |
| `CLASSMARKER_DELETE_GROUP` | Delete Group | Tool to delete a group by its ID. Use when you need to remove a group from ClassMarker. |
| `CLASSMARKER_DELETE_TEST_LINK` | Delete Test Link | Deletes a specific link assignment from a test/exam in ClassMarker. Links are unique URLs that provide access to tests. This action is idempotent - deleting a non-existent link returns success. Use this when you need to remove a link from a test to revoke access via that specific URL. |
| `CLASSMARKER_DELETE_USER` | Delete User | Tool to delete a specific user by ID. Use when you need to remove a user from ClassMarker after verifying the user's identity. |
| `CLASSMARKER_DELETE_WEBHOOK` | Delete Webhook | Deletes a webhook listener from your ClassMarker account. This action removes a webhook configuration that was previously set up to receive real-time exam results. The ClassMarker API is idempotent - attempting to delete a non-existent webhook will return success without error. Webhook IDs are typically obtained from the ClassMarker web interface (My Account > Webhooks / API Keys) or through other webhook management tools if available. Note: This is a destructive operation and cannot be undone through the API. |
| `CLASSMARKER_GET_GROUP_DETAILS` | Get Group Details | Retrieve detailed information about a specific group by ID. Returns group name and assigned tests. Note: This fetches all accessible groups and filters for the specified group_id, as ClassMarker API doesn't provide a direct single-group endpoint. |
| `CLASSMARKER_GET_INITIAL_FINISHED_AFTER_TIMESTAMP` | Get Initial Finished After Timestamp | Compute the initial finishedAfterTimestamp for paginating ClassMarker test results. Use this action when you need to retrieve recent test results for the first time and don't have a previous 'next_finished_after_timestamp' value. This returns a Unix timestamp set to 2 weeks ago, which is the ClassMarker API's default starting point for result pagination. **When to use this:** - Starting a new pagination sequence for test results - You don't have a stored 'next_finished_after_timestamp' from a previous request **When NOT to use this:** - You have a 'next_finished_after_timestamp' from a previous response - use that value instead - For subsequent pagination requests - use the timestamp from the last successful response **Important:** ClassMarker API requires the finishedAfterTimestamp to be less than 3 months old. This action ensures compliance by setting it to 2 weeks ago. |
| `CLASSMARKER_GET_QUESTION` | Get Question | Tool to retrieve a specific question by its ID. Use when you need detailed information of a question after confirming the question_id. |
| `CLASSMARKER_GET_RECENT_RESULTS_GROUP_EXAM` | Get Recent Results For Group Exam | Tool to fetch recent test results for a specific group and exam. Use after determining a UNIX timestamp to retrieve only results finished after that time for the group and exam. |
| `CLASSMARKER_GET_RECENT_RESULTS_LINK_EXAM` | Get Recent Results Link Exam | Fetch recent exam results for a specific link and test combination. Use CLASSMARKER_GET_ALL_GROUPS_LINKS_EXAMS first to obtain valid link_id and test_id values. This endpoint returns paginated results based on finishedAfterTimestamp for efficient incremental data retrieval. Supports up to 200 results per request. |
| `CLASSMARKER_GET_TEST_DETAILS` | Get Test Details | Retrieves detailed information for a specific test (exam) including its name and all assignment contexts. Returns a list of groups and/or links where the test is assigned, with their IDs, names, and URL identifiers. Use when you need to find where a specific test is deployed or to get the complete deployment context for a test. Returns 'no_results' status if test ID doesn't exist. |
| `CLASSMARKER_GET_USER_DETAILS` | Get User Details | Tool to retrieve detailed information about a specific user. Use after you have the user's ID and need the full user profile. |
| `CLASSMARKER_LIST_CATEGORIES` | List Question Categories | Retrieves all question categories organized in a hierarchical structure. Returns parent categories with their nested sub-categories. Use this to browse available categories before creating questions or filtering content. |
| `CLASSMARKER_LIST_CERTIFICATES` | List Certificates | Tool to list all certificates. Use when you need to retrieve all certificates available in the account. |
| `CLASSMARKER_LIST_QUESTIONS` | List Questions | Retrieve a paginated list of questions from your question bank. Returns up to 200 questions per page. Use the optional 'page' parameter to navigate through multiple pages. Each question includes type, content, points, options, correct answers, and metadata. |
| `CLASSMARKER_LIST_RECENT_RESULTS_FOR_GROUPS` | List Recent Results For Groups | Retrieve recent exam results for all groups in your ClassMarker account. Returns results from the last 2 weeks by default, or from a specified timestamp (must be within 3 months). Use this to fetch user performance data including scores, pass/fail status, and certificates. |
| `CLASSMARKER_LIST_RECENT_RESULTS_FOR_LINKS` | List Recent Results for Links | Retrieves recent test results from ALL links accessible to your API key. Returns results completed after a specified timestamp (defaults to 2 weeks ago). Supports pagination for large result sets (max 200 per request). Use the next_finished_after_timestamp from the response for subsequent requests to fetch newer results without duplicates. Ideal for syncing or monitoring exam completions across all your test links. |
| `CLASSMARKER_LIST_USERS` | List Users | Tool to list all users. Use when you need to retrieve every user in your account after confirming authentication. |
| `CLASSMARKER_LIST_WEBHOOKS` | List Webhooks | Tool to retrieve all configured webhooks. Use when you need to programmatically list your webhook configurations. |
| `CLASSMARKER_PUT_CATEGORY` | Update Sub-Category | Tool to update an existing sub-category. Use when you need to rename or move a sub-category after confirming its IDs. |
| `CLASSMARKER_PUT_PARENT_CATEGORY` | Update an existing parent category | Tool to update an existing parent category. Use after confirming the parent category ID. |
| `CLASSMARKER_PUT_QUESTION` | Update Question | Updates an existing question in the ClassMarker question bank. IMPORTANT CONSTRAINTS: - Cannot change the question_type of an existing question (must match original) - random_answers is only valid for multiplechoice and multipleresponse types - grade_style is only valid for multipleresponse type - options and correct_options are required for multiplechoice, multipleresponse, and truefalse - essay questions cannot have options, correct_options, or grade_style Set verify_only=True to validate changes without applying them. |

## Supported Triggers

None listed.

## Installation and MCP Setup

### Path 1: SDK Installation

#### Path 1, Step 1: Install Composio

Install the Composio SDK
```python
pip install composio_openai
```

```typescript
npm install @composio/openai
```

#### Path 1, Step 2: Initialize Composio and Create Tool Router Session

Import and initialize Composio client, then create a 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')
```

```typescript
import OpenAI from 'openai';
import { Composio } from '@composio/core';
import { OpenAIResponsesProvider } from '@composio/openai';

const composio = new Composio({
  provider: new OpenAIResponsesProvider(),
});
const openai = new OpenAI({});
const session = await composio.create('your-user-id');
```

#### Path 1, Step 3: Execute Classmarker Tools via Tool Router with Your Agent

Get tools from Tool Router session and execute Classmarker actions with your Agent
```python
tools = session.tools
response = openai.responses.create(
  model='gpt-4.1',
  tools=tools,
  input=[{
    'role': 'user',
    'content': 'Create a new user and assign to the Sales group in ClassMarker.'
  }]
)
result = composio.provider.handle_tool_calls(
  response=response,
  user_id='your-user-id'
)
print(result)
```

```typescript
const tools = session.tools;
const response = await openai.responses.create({
  model: 'gpt-4.1',
  tools: tools,
  input: [{
    role: 'user',
    content: 'Create a new user and assign to the Sales group in ClassMarker.'
  }],
});
const result = await composio.provider.handleToolCalls(
  'your-user-id',
  response.output
);
console.log(result);
```

### Path 2: MCP Server Setup

#### Path 2, Step 1: Install Composio

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

```typescript
npm install @composio/core ai @ai-sdk/openai @ai-sdk/mcp
```

#### Path 2, Step 2: Create Tool Router Session

Initialize the Composio client and create a 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
```

```typescript
import { Composio } from '@composio/core';

const composio = new Composio({ apiKey: 'your-api-key' });

console.log("Creating Tool Router session...");
const { mcp } = await composio.create('your-user-id');
console.log(`Tool Router session created: ${mcp.url}`);
```

#### Path 2, Step 3: Connect to AI Agent

Use the MCP server with your 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 Classmarker tools.',
    max_turns=10
)

async def main():
    async with ClaudeSDKClient(options=options) as client:
        await client.query('Create a new user in ClassMarker with name John Doe and email john.doe@example.com')
        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())
```

```typescript
import { openai } from '@ai-sdk/openai';
import { experimental_createMCPClient as createMCPClient } from '@ai-sdk/mcp';
import { generateText, stepCountIs } from 'ai';

const client = await createMCPClient({
  transport: {
    type: 'http',
    url: mcp.url,
    headers: { 'x-api-key': 'your-composio-api-key' }
  }
});

const tools = await client.tools();

const { text } = await generateText({
  model: openai('gpt-4o'),
  tools,
  messages: [{ role: 'user', content: 'Create a new user in ClassMarker with name John Doe and email john.doe@example.com' }],
  stopWhen: stepCountIs(5)
});

console.log(`Agent: ${text}`);
```

## Why Use Composio?

### 1. AI Native Classmarker Integration

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

### 2. Managed Auth

- Built-in API key management with secure storage and handling
- Central place to manage, scope, and revoke Classmarker access
- Per user and per environment credentials instead of hard-coded keys

### 3. 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

### 4. Enterprise Grade Security

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

## Use Classmarker with any AI Agent Framework

Choose a framework you want to connect Classmarker with:

- [OpenAI Agents SDK](https://composio.dev/toolkits/classmarker/framework/open-ai-agents-sdk)
- [Claude Agent SDK](https://composio.dev/toolkits/classmarker/framework/claude-agents-sdk)
- [Claude Code](https://composio.dev/toolkits/classmarker/framework/claude-code)
- [Claude Cowork](https://composio.dev/toolkits/classmarker/framework/claude-cowork)
- [Codex](https://composio.dev/toolkits/classmarker/framework/codex)
- [OpenClaw](https://composio.dev/toolkits/classmarker/framework/openclaw)
- [Hermes](https://composio.dev/toolkits/classmarker/framework/hermes-agent)
- [Google ADK](https://composio.dev/toolkits/classmarker/framework/google-adk)
- [LangChain](https://composio.dev/toolkits/classmarker/framework/langchain)
- [Vercel AI SDK](https://composio.dev/toolkits/classmarker/framework/ai-sdk)
- [Mastra AI](https://composio.dev/toolkits/classmarker/framework/mastra-ai)
- [LlamaIndex](https://composio.dev/toolkits/classmarker/framework/llama-index)
- [CrewAI](https://composio.dev/toolkits/classmarker/framework/crew-ai)
- [Pydantic AI](https://composio.dev/toolkits/classmarker/framework/pydantic-ai)
- [AutoGen](https://composio.dev/toolkits/classmarker/framework/autogen)

## Related Toolkits

- [Canvas](https://composio.dev/toolkits/canvas) - Canvas is a learning management system for online courses, assignments, grading, and collaboration. It's trusted by educators and students to streamline virtual classrooms and enhance digital learning.
- [Accredible certificates](https://composio.dev/toolkits/accredible_certificates) - Accredible Certificates is a platform for creating and managing digital certificates, badges, and blockchain credentials. It streamlines issuing, tracking, and verifying professional achievements for organizations of any size.
- [Api bible](https://composio.dev/toolkits/api_bible) - API.Bible is a developer platform for Scripture content and passage search. Easily integrate Bible verses and translations into your apps or chatbots.
- [Blackboard](https://composio.dev/toolkits/blackboard) - Blackboard is a digital learning platform for higher education and schools, offering tools to manage courses, track engagement, and deliver interactive content. It helps institutions improve student outcomes through actionable analytics and in-app guidance.
- [Certifier](https://composio.dev/toolkits/certifier) - Certifier is a platform for creating, managing, and issuing digital certificates and credentials. Organizations use it to automate and secure the entire credentialing process.
- [Coassemble](https://composio.dev/toolkits/coassemble) - Coassemble is a flexible platform for building, managing, and delivering online training courses. It helps teams streamline onboarding, upskilling, and ongoing learning for employees or partners.
- [D2lbrightspace](https://composio.dev/toolkits/d2lbrightspace) - D2L Brightspace is a learning management system for delivering and managing online courses and assessments. It helps educators streamline digital teaching, assignments, and communication with students.
- [Dictionary api](https://composio.dev/toolkits/dictionary_api) - Dictionary api is the Merriam-Webster API providing rich dictionary and thesaurus data for developers. Instantly access definitions, synonyms, etymologies, and audio pronunciations in your apps.
- [Google Classroom](https://composio.dev/toolkits/google_classroom) - Google Classroom is a free web service for educators and students to manage assignments and communication. It streamlines classroom collaboration and grading, making teaching simpler and more connected.
- [Lessonspace](https://composio.dev/toolkits/lessonspace) - Lessonspace is an online collaborative classroom platform offering video, whiteboards, and real-time interaction for educators and students. It streamlines remote teaching with integrated tools for engagement and communication.
- [Linguapop](https://composio.dev/toolkits/linguapop) - Linguapop is a web platform for administering language placement tests in English, German, Spanish, Italian, and French. It helps schools and organizations efficiently manage multilingual assessments and analyze results.
- [Memberspot](https://composio.dev/toolkits/memberspot) - Memberspot is an online course and video-hosting platform for business learning. It helps teams manage, deliver, and track knowledge efficiently.
- [Membervault](https://composio.dev/toolkits/membervault) - Membervault is a platform for hosting courses, memberships, and digital products in one place. It helps you build stronger relationships with your audience by centralizing digital offers and customer engagement.
- [Gmail](https://composio.dev/toolkits/gmail) - Gmail is Google's email service with powerful spam protection, search, and G Suite integration. It keeps your inbox organized and makes communication fast and reliable.
- [Google Calendar](https://composio.dev/toolkits/googlecalendar) - Google Calendar is a time management service for scheduling meetings, events, and reminders. It streamlines personal and team organization with integrated notifications and sharing options.
- [Google Drive](https://composio.dev/toolkits/googledrive) - Google Drive is a cloud storage platform for uploading, sharing, and collaborating on files. It's perfect for keeping your documents accessible and organized across devices.
- [Outlook](https://composio.dev/toolkits/outlook) - Outlook is Microsoft's email and calendaring platform for unified communications and scheduling. It helps users stay organized with powerful email, contacts, and calendar management.
- [Twitter](https://composio.dev/toolkits/twitter) - Twitter is a social media platform for sharing real-time updates, conversations, and news. Stay connected, informed, and engaged with communities worldwide.
- [Google Sheets](https://composio.dev/toolkits/googlesheets) - Google Sheets is a cloud-based spreadsheet tool for real-time collaboration and data analysis. It lets teams work together from anywhere, updating information instantly.
- [Supabase](https://composio.dev/toolkits/supabase) - Supabase is an open-source backend platform offering scalable Postgres databases, authentication, storage, and real-time APIs. It lets developers build modern apps without managing infrastructure.

## Frequently Asked Questions

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

Yes, Classmarker requires you to configure your own API key credentials. Once set up, Composio handles secure credential storage and API request handling for you.

### Can I use multiple toolkits together?

Yes! Composio's Tool Router enables agents to use multiple toolkits. [Learn more](https://docs.composio.dev/tool-router/overview).

### Is Composio secure?

Composio is SOC 2 and ISO 27001 compliant with all data encrypted in transit and at rest. [Learn more](https://trust.composio.dev).

### What if the API changes?

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

---
[See all toolkits](https://composio.dev/toolkits) · [Composio docs](https://docs.composio.dev/llms.txt)
