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