Skip to main content
Glama

search_courses

Search for courses in the Swedish national curriculum by school type, subject, and time period to build course offerings and plan study paths.

Instructions

Sök efter kurser i Skolverkets läroplan.

ANVÄNDNINGSFALL:

  • Hitta kurser inom ett specifikt ämne

  • Filtrera kurser efter skoltyp och tidsperiod

  • Bygga upp kursutbud

  • Planera studiegång

RETURNERAR: Lista över kurser med kod, namn, poäng och beskrivning.

EXEMPEL: För Matematik 1c på gymnasiet, sök med schooltype="GY" och subjectCode="MATMAT01c".

TIPS: Använd subjectCode för att filtrera på ämne.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
schooltypeNo
timespanNo
typeOfSyllabusNo
subjectCodeNo

Implementation Reference

  • Main execution logic for the 'search_courses' tool. Calls syllabus API, limits results, formats JSON response with courses data.
    export async function searchCourses(params: { schooltype?: string; timespan?: 'LATEST' | 'FUTURE' | 'EXPIRED' | 'MODIFIED'; date?: string; subjectCode?: string; limit?: number; }) { try { const result = await syllabusApi.searchCourses(params); // Begränsa antal resultat för att undvika stora responses const maxResults = Math.min(params.limit || 50, 200); const limitedCourses = result.courses.slice(0, maxResults); const hasMore = result.totalElements > maxResults; return { content: [ { type: 'text' as const, text: JSON.stringify({ totalElements: result.totalElements, returned: limitedCourses.length, hasMore: hasMore, message: hasMore ? `Visar ${limitedCourses.length} av ${result.totalElements} kurser. Använd subjectCode eller andra filter för att begränsa resultatet.` : undefined, courses: limitedCourses.map(c => ({ code: c.code, name: c.name, subjectCode: c.subjectCode, schoolType: c.schoolType, points: c.points, version: c.version, description: c.description?.substring(0, 150) + (c.description && c.description.length > 150 ? '...' : '') })) }, null, 2) } ] }; } catch (error) { return { content: [ { type: 'text' as const, text: `Fel vid sökning av kurser: ${error instanceof Error ? error.message : String(error)}` } ], isError: true }; } }
  • Zod schema defining input parameters and descriptions for the search_courses tool.
    export const searchCoursesSchema = { schooltype: z.string().optional().describe('Skoltyp (t.ex. "GY" för gymnasium)'), timespan: z.enum(['LATEST', 'FUTURE', 'EXPIRED', 'MODIFIED']).default('LATEST').describe('Tidsperiod: LATEST (gällande), FUTURE (framtida), EXPIRED (utgångna), MODIFIED (ändrade)'), date: z.string().optional().describe('Datum i formatet YYYY-MM-DD för att hämta kurser som var giltiga vid det datumet'), subjectCode: z.string().optional().describe('Ämneskod för att filtrera kurser'), limit: z.number().optional().default(50).describe('Max antal resultat att returnera (default: 50, max: 200)') };
  • Maps the 'search_courses' tool name to the searchCourses handler function in the central tools registry.
    search_courses: searchCourses,
  • Imports the searchCourses handler from its implementation file for use in tool registration.
    import { searchCourses, getCourseDetails, getCourseVersions } from './tools/syllabus/courses.js';
  • Underlying API client method called by the tool handler to fetch course data from Skolverket's syllabus API.
    async searchCourses(params: CourseSearchParams = {}): Promise<CoursesResponse> { return this.get<CoursesResponse>('/v1/courses', params); }

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/isakskogstad/skolverket-syllabus-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server