refactor(api): simplify response structures for GetDocuments and GetDocument endpoints

Closes #198
This commit is contained in:
Dominik Schröter 2025-02-07 16:31:54 +01:00
parent 712ed53c1c
commit d5a41ae4e7

View file

@ -1,58 +1,58 @@
package main package main
import ( // GetTagsApiResponse is the response payload for /tags endpoint.
"time" // But we are only interested in a subset of the fields.
)
type GetDocumentsApiResponse struct { type GetDocumentsApiResponse struct {
Count int `json:"count"` Count int `json:"count"`
Next interface{} `json:"next"` // Next interface{} `json:"next"`
Previous interface{} `json:"previous"` // Previous interface{} `json:"previous"`
All []int `json:"all"` All []int `json:"all"`
Results []struct { Results []struct {
ID int `json:"id"` ID int `json:"id"`
Correspondent int `json:"correspondent"` Correspondent int `json:"correspondent"`
DocumentType interface{} `json:"document_type"` // DocumentType interface{} `json:"document_type"`
StoragePath interface{} `json:"storage_path"` // StoragePath interface{} `json:"storage_path"`
Title string `json:"title"` Title string `json:"title"`
Content string `json:"content"` Content string `json:"content"`
Tags []int `json:"tags"` Tags []int `json:"tags"`
Created time.Time `json:"created"` // Created time.Time `json:"created"`
CreatedDate string `json:"created_date"` // CreatedDate string `json:"created_date"`
Modified time.Time `json:"modified"` // Modified time.Time `json:"modified"`
Added time.Time `json:"added"` // Added time.Time `json:"added"`
ArchiveSerialNumber interface{} `json:"archive_serial_number"` // ArchiveSerialNumber interface{} `json:"archive_serial_number"`
OriginalFileName string `json:"original_file_name"` // OriginalFileName string `json:"original_file_name"`
ArchivedFileName string `json:"archived_file_name"` // ArchivedFileName string `json:"archived_file_name"`
Owner int `json:"owner"` // Owner int `json:"owner"`
UserCanChange bool `json:"user_can_change"` // UserCanChange bool `json:"user_can_change"`
Notes []interface{} `json:"notes"` Notes []interface{} `json:"notes"`
SearchHit struct { // SearchHit struct {
Score float64 `json:"score"` // Score float64 `json:"score"`
Highlights string `json:"highlights"` // Highlights string `json:"highlights"`
NoteHighlights string `json:"note_highlights"` // NoteHighlights string `json:"note_highlights"`
Rank int `json:"rank"` // Rank int `json:"rank"`
} `json:"__search_hit__"` // } `json:"__search_hit__"`
} `json:"results"` } `json:"results"`
} }
// GetDocumentApiResponse is the response payload for /documents/{id} endpoint.
// But we are only interested in a subset of the fields.
type GetDocumentApiResponse struct { type GetDocumentApiResponse struct {
ID int `json:"id"` ID int `json:"id"`
Correspondent int `json:"correspondent"` Correspondent int `json:"correspondent"`
DocumentType interface{} `json:"document_type"` // DocumentType interface{} `json:"document_type"`
StoragePath interface{} `json:"storage_path"` // StoragePath interface{} `json:"storage_path"`
Title string `json:"title"` Title string `json:"title"`
Content string `json:"content"` Content string `json:"content"`
Tags []int `json:"tags"` Tags []int `json:"tags"`
Created time.Time `json:"created"` // Created time.Time `json:"created"`
CreatedDate string `json:"created_date"` // CreatedDate string `json:"created_date"`
Modified time.Time `json:"modified"` // Modified time.Time `json:"modified"`
Added time.Time `json:"added"` // Added time.Time `json:"added"`
ArchiveSerialNumber interface{} `json:"archive_serial_number"` // ArchiveSerialNumber interface{} `json:"archive_serial_number"`
OriginalFileName string `json:"original_file_name"` // OriginalFileName string `json:"original_file_name"`
ArchivedFileName string `json:"archived_file_name"` // ArchivedFileName string `json:"archived_file_name"`
Owner int `json:"owner"` // Owner int `json:"owner"`
UserCanChange bool `json:"user_can_change"` // UserCanChange bool `json:"user_can_change"`
Notes []interface{} `json:"notes"` Notes []interface{} `json:"notes"`
} }