mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-01-10 16:40:12 +00:00
fc3741365c
* Add Swagger spec test script * Fix Swagger spec errors not related to statuses with polls * Add API tests that post a status with a poll * Fix creating a status with a poll from form params * Fix Swagger spec errors related to statuses with polls (this is the last error) * Fix Swagger spec warnings not related to unused definitions * Suppress a duplicate list update params definition that was somehow causing wrong param names * Add Swagger test to CI - updates Drone config - vendorizes go-swagger - fixes a file extension issue that caused the test script to generate JSON instead of YAML with the vendorized version * Put `Sample: ` on its own line everywhere * Remove unused id param from emojiCategoriesGet * Add 5 more pairs of profile fields to account update API Swagger * Remove Swagger prefix from dummy fields It makes the generated code look weird * Manually annotate params for statusCreate operation * Fix all remaining Swagger spec warnings - Change some models into operation parameters - Ignore models that already correspond to manually documented operation parameters but can't be trivially changed (those with file fields) * Documented that creating a status with scheduled_at isn't implemented yet * sign drone.yml * Fix filter API Swagger errors * fixup! Fix filter API Swagger errors --------- Co-authored-by: tobi <tobi.smethurst@protonmail.com>
102 lines
3.8 KiB
Go
102 lines
3.8 KiB
Go
// Copyright (C) MongoDB, Inc. 2017-present.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
// not use this file except in compliance with the License. You may obtain
|
|
// a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
package bson
|
|
|
|
import (
|
|
"bytes"
|
|
|
|
"go.mongodb.org/mongo-driver/bson/bsoncodec"
|
|
"go.mongodb.org/mongo-driver/bson/bsonrw"
|
|
"go.mongodb.org/mongo-driver/bson/bsontype"
|
|
)
|
|
|
|
// Unmarshaler is an interface implemented by types that can unmarshal a BSON
|
|
// document representation of themselves. The BSON bytes can be assumed to be
|
|
// valid. UnmarshalBSON must copy the BSON bytes if it wishes to retain the data
|
|
// after returning.
|
|
type Unmarshaler interface {
|
|
UnmarshalBSON([]byte) error
|
|
}
|
|
|
|
// ValueUnmarshaler is an interface implemented by types that can unmarshal a
|
|
// BSON value representation of themselves. The BSON bytes and type can be
|
|
// assumed to be valid. UnmarshalBSONValue must copy the BSON value bytes if it
|
|
// wishes to retain the data after returning.
|
|
type ValueUnmarshaler interface {
|
|
UnmarshalBSONValue(bsontype.Type, []byte) error
|
|
}
|
|
|
|
// Unmarshal parses the BSON-encoded data and stores the result in the value
|
|
// pointed to by val. If val is nil or not a pointer, Unmarshal returns
|
|
// InvalidUnmarshalError.
|
|
func Unmarshal(data []byte, val interface{}) error {
|
|
return UnmarshalWithRegistry(DefaultRegistry, data, val)
|
|
}
|
|
|
|
// UnmarshalWithRegistry parses the BSON-encoded data using Registry r and
|
|
// stores the result in the value pointed to by val. If val is nil or not
|
|
// a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
|
|
func UnmarshalWithRegistry(r *bsoncodec.Registry, data []byte, val interface{}) error {
|
|
vr := bsonrw.NewBSONDocumentReader(data)
|
|
return unmarshalFromReader(bsoncodec.DecodeContext{Registry: r}, vr, val)
|
|
}
|
|
|
|
// UnmarshalWithContext parses the BSON-encoded data using DecodeContext dc and
|
|
// stores the result in the value pointed to by val. If val is nil or not
|
|
// a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
|
|
func UnmarshalWithContext(dc bsoncodec.DecodeContext, data []byte, val interface{}) error {
|
|
vr := bsonrw.NewBSONDocumentReader(data)
|
|
return unmarshalFromReader(dc, vr, val)
|
|
}
|
|
|
|
// UnmarshalExtJSON parses the extended JSON-encoded data and stores the result
|
|
// in the value pointed to by val. If val is nil or not a pointer, Unmarshal
|
|
// returns InvalidUnmarshalError.
|
|
func UnmarshalExtJSON(data []byte, canonical bool, val interface{}) error {
|
|
return UnmarshalExtJSONWithRegistry(DefaultRegistry, data, canonical, val)
|
|
}
|
|
|
|
// UnmarshalExtJSONWithRegistry parses the extended JSON-encoded data using
|
|
// Registry r and stores the result in the value pointed to by val. If val is
|
|
// nil or not a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
|
|
func UnmarshalExtJSONWithRegistry(r *bsoncodec.Registry, data []byte, canonical bool, val interface{}) error {
|
|
ejvr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), canonical)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return unmarshalFromReader(bsoncodec.DecodeContext{Registry: r}, ejvr, val)
|
|
}
|
|
|
|
// UnmarshalExtJSONWithContext parses the extended JSON-encoded data using
|
|
// DecodeContext dc and stores the result in the value pointed to by val. If val is
|
|
// nil or not a pointer, UnmarshalWithRegistry returns InvalidUnmarshalError.
|
|
func UnmarshalExtJSONWithContext(dc bsoncodec.DecodeContext, data []byte, canonical bool, val interface{}) error {
|
|
ejvr, err := bsonrw.NewExtJSONValueReader(bytes.NewReader(data), canonical)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return unmarshalFromReader(dc, ejvr, val)
|
|
}
|
|
|
|
func unmarshalFromReader(dc bsoncodec.DecodeContext, vr bsonrw.ValueReader, val interface{}) error {
|
|
dec := decPool.Get().(*Decoder)
|
|
defer decPool.Put(dec)
|
|
|
|
err := dec.Reset(vr)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = dec.SetContext(dc)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return dec.Decode(val)
|
|
}
|