mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 10:22:25 -05:00 
			
		
		
		
	[bugfix] Fix Swagger spec and add test script (#2698)
* 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>
This commit is contained in:
		
					parent
					
						
							
								68c8fe67cc
							
						
					
				
			
			
				commit
				
					
						fc3741365c
					
				
			
		
					 672 changed files with 135624 additions and 713 deletions
				
			
		
							
								
								
									
										127
									
								
								vendor/github.com/go-openapi/spec/resolver.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								vendor/github.com/go-openapi/spec/resolver.go
									
										
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,127 @@ | |||
| package spec | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 
 | ||||
| 	"github.com/go-openapi/swag" | ||||
| ) | ||||
| 
 | ||||
| func resolveAnyWithBase(root interface{}, ref *Ref, result interface{}, options *ExpandOptions) error { | ||||
| 	options = optionsOrDefault(options) | ||||
| 	resolver := defaultSchemaLoader(root, options, nil, nil) | ||||
| 
 | ||||
| 	if err := resolver.Resolve(ref, result, options.RelativeBase); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // ResolveRefWithBase resolves a reference against a context root with preservation of base path | ||||
| func ResolveRefWithBase(root interface{}, ref *Ref, options *ExpandOptions) (*Schema, error) { | ||||
| 	result := new(Schema) | ||||
| 
 | ||||
| 	if err := resolveAnyWithBase(root, ref, result, options); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return result, nil | ||||
| } | ||||
| 
 | ||||
| // ResolveRef resolves a reference for a schema against a context root | ||||
| // ref is guaranteed to be in root (no need to go to external files) | ||||
| // | ||||
| // ResolveRef is ONLY called from the code generation module | ||||
| func ResolveRef(root interface{}, ref *Ref) (*Schema, error) { | ||||
| 	res, _, err := ref.GetPointer().Get(root) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	switch sch := res.(type) { | ||||
| 	case Schema: | ||||
| 		return &sch, nil | ||||
| 	case *Schema: | ||||
| 		return sch, nil | ||||
| 	case map[string]interface{}: | ||||
| 		newSch := new(Schema) | ||||
| 		if err = swag.DynamicJSONToStruct(sch, newSch); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 		return newSch, nil | ||||
| 	default: | ||||
| 		return nil, fmt.Errorf("type: %T: %w", sch, ErrUnknownTypeForReference) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // ResolveParameterWithBase resolves a parameter reference against a context root and base path | ||||
| func ResolveParameterWithBase(root interface{}, ref Ref, options *ExpandOptions) (*Parameter, error) { | ||||
| 	result := new(Parameter) | ||||
| 
 | ||||
| 	if err := resolveAnyWithBase(root, &ref, result, options); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return result, nil | ||||
| } | ||||
| 
 | ||||
| // ResolveParameter resolves a parameter reference against a context root | ||||
| func ResolveParameter(root interface{}, ref Ref) (*Parameter, error) { | ||||
| 	return ResolveParameterWithBase(root, ref, nil) | ||||
| } | ||||
| 
 | ||||
| // ResolveResponseWithBase resolves response a reference against a context root and base path | ||||
| func ResolveResponseWithBase(root interface{}, ref Ref, options *ExpandOptions) (*Response, error) { | ||||
| 	result := new(Response) | ||||
| 
 | ||||
| 	err := resolveAnyWithBase(root, &ref, result, options) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return result, nil | ||||
| } | ||||
| 
 | ||||
| // ResolveResponse resolves response a reference against a context root | ||||
| func ResolveResponse(root interface{}, ref Ref) (*Response, error) { | ||||
| 	return ResolveResponseWithBase(root, ref, nil) | ||||
| } | ||||
| 
 | ||||
| // ResolvePathItemWithBase resolves response a path item against a context root and base path | ||||
| func ResolvePathItemWithBase(root interface{}, ref Ref, options *ExpandOptions) (*PathItem, error) { | ||||
| 	result := new(PathItem) | ||||
| 
 | ||||
| 	if err := resolveAnyWithBase(root, &ref, result, options); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return result, nil | ||||
| } | ||||
| 
 | ||||
| // ResolvePathItem resolves response a path item against a context root and base path | ||||
| // | ||||
| // Deprecated: use ResolvePathItemWithBase instead | ||||
| func ResolvePathItem(root interface{}, ref Ref, options *ExpandOptions) (*PathItem, error) { | ||||
| 	return ResolvePathItemWithBase(root, ref, options) | ||||
| } | ||||
| 
 | ||||
| // ResolveItemsWithBase resolves parameter items reference against a context root and base path. | ||||
| // | ||||
| // NOTE: stricly speaking, this construct is not supported by Swagger 2.0. | ||||
| // Similarly, $ref are forbidden in response headers. | ||||
| func ResolveItemsWithBase(root interface{}, ref Ref, options *ExpandOptions) (*Items, error) { | ||||
| 	result := new(Items) | ||||
| 
 | ||||
| 	if err := resolveAnyWithBase(root, &ref, result, options); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return result, nil | ||||
| } | ||||
| 
 | ||||
| // ResolveItems resolves parameter items reference against a context root and base path. | ||||
| // | ||||
| // Deprecated: use ResolveItemsWithBase instead | ||||
| func ResolveItems(root interface{}, ref Ref, options *ExpandOptions) (*Items, error) { | ||||
| 	return ResolveItemsWithBase(root, ref, options) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue