Compare commits

...

No commits in common. "main" and "0.0.1" have entirely different histories.
main ... 0.0.1

28 changed files with 72 additions and 316 deletions

View file

@ -1,8 +0,0 @@
# Custom Dictionary Words
goskola
pubtypes
skola
xscope
zadachin
zervo
zervó

View file

@ -45,9 +45,9 @@ func main() {
``` ```
The rest of the README is documented examples, as well as information on the available methods and types. All the other information below is documentation on examples, the available methods and types.
Please note that some methods are not strongly typed due to a lack of data to develop against. This is clearly marked by the warnings under the affected methods. If you find a host that provides this data, please let me know. Please that some methods are not strongly typed due to a lack of data to develop against. This is clearly marked by the warnings under the affected methods.
* [Examples](#examples) * [Examples](#examples)

View file

@ -28,8 +28,6 @@ func main() {
} }
} }
terms, _ := api.GetTerms()
rooms, err := api.GetRooms(schools[4], true) rooms, err := api.GetRooms(schools[4], true)
if err != nil { if err != nil {
fmt.Println(err.Error()) fmt.Println(err.Error())
@ -58,11 +56,4 @@ func main() {
} }
fmt.Println(key) fmt.Println(key)
schedule, err := api.GetWeekSchedule(2024, 50, schools[4], terms.ActiveTerms[0], classes[0])
if err != nil {
fmt.Println(err.Error())
}
fmt.Println(schedule)
} }

View file

@ -1,17 +0,0 @@
{
"version": "0.2",
"ignorePaths": [],
"dictionaryDefinitions": [
{
"name": "custom-dictionary",
"path": "./.cspell/custom-dictionary.txt",
"addWords": true
}
],
"dictionaries": [
"custom-dictionary"
],
"words": [],
"ignoreWords": [],
"import": []
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -33,37 +33,26 @@ type Skola24API struct {
Host string Host string
} }
// Get all available terms (aka semesters) from the active host/domain
func (api Skola24API) GetTerms() (_result pubtypes.Terms, _error error) { func (api Skola24API) GetTerms() (_result pubtypes.Terms, _error error) {
return requests.GetTerms(api.Host) return requests.GetTerms(api.Host)
} }
// Get all available schools from the active host/domain
func (api Skola24API) GetSchools() (_result []pubtypes.School, _error error) { func (api Skola24API) GetSchools() (_result []pubtypes.School, _error error) {
return requests.GetSchools(api.Host) return requests.GetSchools(api.Host)
} }
// Get all available rooms from a school
func (api Skola24API) GetRooms(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Room, _error error) { func (api Skola24API) GetRooms(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Room, _error error) {
return requests.GetRooms(school, checkAvailability) return requests.GetRooms(school, checkAvailability)
} }
// Get all available teachers from a school
func (api Skola24API) GetTeachers(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Teacher, _error error) { func (api Skola24API) GetTeachers(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Teacher, _error error) {
return requests.GetTeachers(school, checkAvailability) return requests.GetTeachers(school, checkAvailability)
} }
// Get all available students from a school (EXPERIMENTAL)
func (api Skola24API) GetStudents(school pubtypes.School, checkAvailability bool) (_result any, _error error) { func (api Skola24API) GetStudents(school pubtypes.School, checkAvailability bool) (_result any, _error error) {
return requests.GetStudents(school, checkAvailability) return requests.GetStudents(school, checkAvailability)
} }
// Get all available classes from a school
func (api Skola24API) GetClasses(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Class, _error error) { func (api Skola24API) GetClasses(school pubtypes.School, checkAvailability bool) (_result []pubtypes.Class, _error error) {
return requests.GetClasses(school, checkAvailability) return requests.GetClasses(school, checkAvailability)
} }
// Get a week schedule for the provided date, school, term and class
func (api Skola24API) GetWeekSchedule(year int, week int, school pubtypes.School, term pubtypes.SchoolTerm, class pubtypes.Class) (_result any, _error error) {
return requests.GetSchedule(year, week, 0, school, term, class)
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,89 +0,0 @@
/*
GoSkola24API
Copyright (C) 2024, Zervó Zadachin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License version 3
as published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License version 3 for more details.
This program incorporates external libraries for certain functionalities.
These libraries are covered by their respective licenses, and their usage
agreements are as outlined in their respective documentation or source
code.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package requests
import (
"errors"
"fmt"
"git.zervo.org/zervo/goskola24api/internal/types"
"git.zervo.org/zervo/goskola24api/internal/utility"
pubtypes "git.zervo.org/zervo/goskola24api/types"
)
func GetSchedule(year int, week int, day int, school pubtypes.School, term pubtypes.SchoolTerm, class pubtypes.Class) (_result any, _error error) {
// Verify week number
if week > 52 || week < 1 {
return nil, errors.New("week number out of range (1-53): " + fmt.Sprint(week))
}
// Verify year
if year > 9999 || year < 2000 {
return nil, errors.New("year number out of range (2000-9999): " + fmt.Sprint(year))
}
// Verify day
if day > 7 || day < 0 {
return nil, errors.New("day number out of range (0-7): " + fmt.Sprint(day))
}
// Get render key
renderKey, err := utility.GetRendererKey()
if err != nil {
return nil, errors.New("failed to get render key: " + err.Error())
}
// Construct request
request := types.RequestSchedule{
RenderKey: renderKey,
Host: school.HostName,
UnitGuid: school.SchoolId,
StartDate: nil,
EndDate: nil,
ScheduleDay: day,
BlackAndWhite: false,
Width: 1000,
Height: 1000,
SelectionType: 0,
Selection: class.ClassId,
ShowHeader: false,
PeriodText: "",
Week: week,
Year: year,
SchoolYear: term.TermId,
PersonalTimetable: false,
PrivateFreeTextMode: nil,
PrivateSelectionMode: false,
CustomerKey: "",
}
response, err := utility.Request(request, "render/timetable")
if err != nil {
return nil, errors.New("could not get schedule data: " + err.Error())
}
return response, nil
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,48 +0,0 @@
/*
GoSkola24API
Copyright (C) 2024, Zervó Zadachin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License version 3
as published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License version 3 for more details.
This program incorporates external libraries for certain functionalities.
These libraries are covered by their respective licenses, and their usage
agreements are as outlined in their respective documentation or source
code.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package types
type RequestSchedule struct {
RenderKey string `json:"renderKey"`
Host string `json:"host"`
UnitGuid string `json:"unitGuid"`
StartDate *string `json:"startDate"`
EndDate *string `json:"endDate"`
ScheduleDay int `json:"scheduleDay"`
BlackAndWhite bool `json:"blackAndWhite"`
Width int `json:"width"`
Height int `json:"height"`
SelectionType int `json:"selectionType"`
Selection string `json:"selection"`
ShowHeader bool `json:"showHeader"`
PeriodText any `json:"periodText"`
Week int `json:"week"`
Year int `json:"year"`
SchoolYear string `json:"schoolYear"`
PersonalTimetable bool `json:"personalTimetable"`
PrivateFreeTextMode *string `json:"privateFreeTextMode"`
PrivateSelectionMode bool `json:"privateSelectionMode"`
CustomerKey string `json:"customerKey"`
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -27,17 +27,8 @@ package types
type BaseResponse struct { type BaseResponse struct {
Error interface{} `json:"error"` Error interface{} `json:"error"`
Data interface{} `json:"data"` Data interface{} `json:"data"`
Exception *ResponseError `json:"exception"` Exception interface{} `json:"exception"`
Validation []interface{} `json:"validation"` Validation []interface{} `json:"validation"`
SessionExpires interface{} `json:"sessionExpires"` SessionExpires interface{} `json:"sessionExpires"`
NeedSessionRefresh bool `json:"needSessionRefresh"` NeedSessionRefresh bool `json:"needSessionRefresh"`
} }
type ResponseError struct {
Code int `json:"code"`
Context string `json:"context"`
ErrorId int `json:"errorId"`
ErrorTime string `json:"errorTime"`
Message *string `json:"message"`
Source any `json:"source"`
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -71,16 +71,6 @@ func Request(data any, endpoint string) (_response interface{}, _error error) {
var responseData types.BaseResponse var responseData types.BaseResponse
json.Unmarshal(bodyBytes, &responseData) json.Unmarshal(bodyBytes, &responseData)
// Check for reported exceptions
if responseData.Exception != nil {
return nil, errors.New("server replied with an exception")
}
// Check for reported errors
if responseData.Error != nil {
return nil, errors.New("server replied with an error")
}
// Return as raw bytes (let consumer do type assertion) // Return as raw bytes (let consumer do type assertion)
return responseData.Data, nil return responseData.Data, nil
} }

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -24,18 +24,17 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
package types package types
// Holds data about a class, which is usually a group of people studying a subject together
type Class struct { type Class struct {
Name string `json:"name"` // Friendly-name of the class Name string `json:"name"`
ClassId string `json:"classId"` // UUID identifying the class ClassId string `json:"classId"`
AbsenceMessageNotDeliveredCount int `json:"absenceMessageNotDeliveredCount"` // Purpose unknown AbsenceMessageNotDeliveredCount int `json:"absenceMessageNotDeliveredCount"`
IsResponsible bool `json:"isResponsible"` // Purpose unknown IsResponsible bool `json:"isResponsible"`
IsClass bool `json:"isClass"` // Purpose unknown IsClass bool `json:"isClass"`
IsAdmin bool `json:"isAdmin"` // Purpose unknown IsAdmin bool `json:"isAdmin"`
IsPrincipal bool `json:"isPrincipal"` // Purpose unknown IsPrincipal bool `json:"isPrincipal"`
IsMentor bool `json:"isMentor"` // Purpose unknown IsMentor bool `json:"isMentor"`
IsPreschoolGroup bool `json:"isPreschoolGroup"` // Purpose unknown IsPreschoolGroup bool `json:"isPreschoolGroup"`
Teachers any `json:"teachers"` // Teachers for the class. TODO: MAKE TYPED Teachers any `json:"teachers"` // TODO: MAKE TYPED
SubstituteTeacherId string `json:"substituteTeacherId"` // Teacher ID of the substitute teacher, if any SubstituteTeacherId string `json:"substituteTeacherId"`
TeacherChangeStudents int `json:"teacherChangeStudents"` // Purpose unknown TeacherChangeStudents int `json:"teacherChangeStudents"`
} }

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -24,9 +24,8 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
package types package types
// Holds data about a room; a physical location within a school
type Room struct { type Room struct {
Name string `json:"name"` // Name describing the room Name string `json:"name"`
RoomId string `json:"roomId"` // UUID identifying the room RoomId string `json:"roomId"`
External bool `json:"external"` // Whether or not the room is external (purpose unknown) External bool `json:"external"`
} }

View file

@ -1,36 +0,0 @@
/*
GoSkola24API
Copyright (C) 2024, Zervó Zadachin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License version 3
as published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License version 3 for more details.
This program incorporates external libraries for certain functionalities.
These libraries are covered by their respective licenses, and their usage
agreements are as outlined in their respective documentation or source
code.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package types
import "time"
// Holds data about a lesson, usually occurring once a week
type Lesson struct {
LessonId string `json:"lessonId"` // UUID identifying the lesson
DayOfWeek int `json:"dayOfWeek"` // Day of the week where lesson occurs (monday=1)
Start time.Time `json:"start"` // Time when the lesson starts
End time.Time `json:"end"` // Time when the lesson ends
Texts []string `json:"texts"` // Extra texts that may be displayed on a timetable
}

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -24,23 +24,21 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
package types package types
// Holds data about a school
type School struct { type School struct {
Name string `json:"name"` // Friendly-name of the school Name string `json:"name"`
SchoolId string `json:"schoolId"` // UUID identifying the school SchoolId string `json:"schoolId"`
HostName string `json:"hostName"` // The hostname (domain) that the school belongs to HostName string `json:"hostName"`
AllowCalendarExport bool `json:"allowCalendarExport"` // Whether traditional calendar export is allowed, does not affect this module AllowCalendarExport bool `json:"allowCalendarExport"`
AvailableData DataAvailability `json:"availableData"` // The types of data that the school provides AvailableData DataAvailability `json:"availableData"`
} }
// Defines data availability, showing what type of data can be retrieved from an entity
type DataAvailability struct { type DataAvailability struct {
HasClasses bool `json:"hasClasses"` // Whether the school provides class data HasClasses bool `json:"hasClasses"`
HasCourses bool `json:"hasCourses"` // Whether the school provides course data HasCourses bool `json:"hasCourses"`
HasGroups bool `json:"hasGroups"` // Whether the school provides group data HasGroups bool `json:"hasGroups"`
HasResources bool `json:"hasResources"` // Whether the school provides resource data HasResources bool `json:"hasResources"`
HasRooms bool `json:"hasRooms"` // Whether the school provides room data HasRooms bool `json:"hasRooms"`
HasStudents bool `json:"hasStudents"` // Whether the school provides student data HasStudents bool `json:"hasStudents"`
HasSubjects bool `json:"hasSubjects"` // Whether the school provides subject data HasSubjects bool `json:"hasSubjects"`
HasTeachers bool `json:"hasTeachers"` // Whether the school provides teacher data HasTeachers bool `json:"hasTeachers"`
} }

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -24,15 +24,14 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
package types package types
// Holds data about a teacher
type Teacher struct { type Teacher struct {
FirstName string `json:"firstName"` // Teacher's first name FirstName string `json:"firstName"`
LastName string `json:"lastName"` // Teacher's last name LastName string `json:"lastName"`
FullName string `json:"fullName"` // Teacher's full name, usually including their initials FullName string `json:"fullName"`
FriendlyId string `json:"friendlyId"` // Friendly-ID of the teacher, usually their initials FriendlyId string `json:"friendlyId"`
TeacherId string `json:"teacherId"` // UUID identifying the teacher TeacherId string `json:"teacherId"`
IsActive bool `json:"isActive"` // Purpose unknown IsActive bool `json:"isActive"`
Integrity bool `json:"integrity"` // Purpose unknown Integrity bool `json:"integrity"`
Reported bool `json:"reported"` // Purpose unknown Reported bool `json:"reported"`
ReadOnly bool `json:"readOnly"` // Purpose unknown ReadOnly bool `json:"readOnly"`
} }

View file

@ -1,6 +1,6 @@
/* /*
GoSkola24API GoSkola24API
Copyright (C) 2024, Zervó Zadachin Copyright (C) 2024, Marco Vitchi Thulin
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
@ -24,16 +24,14 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
package types package types
// Holds data about a school term, aka semester
type SchoolTerm struct { type SchoolTerm struct {
Start string `json:"start"` // Start-date of the term Start string `json:"start"`
TermId string `json:"termId"` // UUID identifying the term TermId string `json:"termId"`
Name string `json:"name"` // Friendly-name of the term Name string `json:"name"`
End string `json:"end"` // End-date of the term End string `json:"end"`
} }
// Holds a list of active school terms
type Terms struct { type Terms struct {
ActiveTerms []SchoolTerm `json:"activeSchoolYears"` // List of active terms ActiveTerms []SchoolTerm `json:"activeSchoolYears"`
UseSchoolYearsFeatures bool `json:"useSchoolYearsFeatures"` // Purpose unknown UseSchoolYearsFeatures bool `json:"useSchoolYearsFeatures"`
} }