mirror of
https://github.com/LukeHagar/libopenapi.git
synced 2025-12-07 20:47:45 +00:00
Starting work on oAuth Flows.
This commit is contained in:
@@ -16,6 +16,10 @@ type Link struct {
|
||||
Extensions map[low.KeyReference[string]]low.ValueReference[any]
|
||||
}
|
||||
|
||||
func (l *Link) FindParameter(pName string) *low.ValueReference[string] {
|
||||
return FindItemInMap[string](pName, l.Parameters.Value)
|
||||
}
|
||||
|
||||
func (l *Link) Build(root *yaml.Node) error {
|
||||
extensionMap, err := ExtractExtensions(root)
|
||||
if err != nil {
|
||||
|
||||
@@ -1,24 +1,40 @@
|
||||
package v3
|
||||
|
||||
import (
|
||||
"github.com/pb33f/libopenapi/datamodel/low"
|
||||
"gopkg.in/yaml.v3"
|
||||
"github.com/pb33f/libopenapi/datamodel/low"
|
||||
"gopkg.in/yaml.v3"
|
||||
)
|
||||
|
||||
type OAuthFlows struct {
|
||||
Node *yaml.Node
|
||||
Implicit OAuthFlow
|
||||
Password OAuthFlow
|
||||
ClientCredentials OAuthFlow
|
||||
AuthorizationCode OAuthFlow
|
||||
Extensions map[string]low.ObjectReference
|
||||
Implicit low.NodeReference[*OAuthFlow]
|
||||
Password low.NodeReference[*OAuthFlow]
|
||||
ClientCredentials low.NodeReference[*OAuthFlow]
|
||||
AuthorizationCode low.NodeReference[*OAuthFlow]
|
||||
Extensions map[low.KeyReference[string]]low.ValueReference[any]
|
||||
}
|
||||
|
||||
func (o *OAuthFlows) Build(root *yaml.Node) error {
|
||||
extensionMap, err := ExtractExtensions(root)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
o.Extensions = extensionMap
|
||||
return nil
|
||||
}
|
||||
|
||||
type OAuthFlow struct {
|
||||
Node *yaml.Node
|
||||
AuthorizationUrl low.NodeReference[string]
|
||||
TokenURL low.NodeReference[string]
|
||||
RefreshURL low.NodeReference[string]
|
||||
Scopes map[string]string
|
||||
Extensions map[string]low.ObjectReference
|
||||
AuthorizationUrl low.NodeReference[string]
|
||||
TokenURL low.NodeReference[string]
|
||||
RefreshURL low.NodeReference[string]
|
||||
Scopes map[low.KeyReference[string]]low.ValueReference[string]
|
||||
Extensions map[low.KeyReference[string]]low.ValueReference[any]
|
||||
}
|
||||
|
||||
func (o *OAuthFlow) Build(root *yaml.Node) error {
|
||||
extensionMap, err := ExtractExtensions(root)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
o.Extensions = extensionMap
|
||||
return nil
|
||||
}
|
||||
|
||||
@@ -1,24 +1,31 @@
|
||||
package v3
|
||||
|
||||
import (
|
||||
"github.com/pb33f/libopenapi/datamodel/low"
|
||||
"gopkg.in/yaml.v3"
|
||||
"github.com/pb33f/libopenapi/datamodel/low"
|
||||
"gopkg.in/yaml.v3"
|
||||
)
|
||||
|
||||
type SecurityScheme struct {
|
||||
Node *yaml.Node
|
||||
Type low.NodeReference[string]
|
||||
Description low.NodeReference[string]
|
||||
Name low.NodeReference[string]
|
||||
In low.NodeReference[string]
|
||||
Scheme low.NodeReference[string]
|
||||
BearerFormat low.NodeReference[string]
|
||||
Flows OAuthFlows
|
||||
OpenIdConnectURL low.NodeReference[string]
|
||||
Extensions map[string]low.ObjectReference
|
||||
Type low.NodeReference[string]
|
||||
Description low.NodeReference[string]
|
||||
Name low.NodeReference[string]
|
||||
In low.NodeReference[string]
|
||||
Scheme low.NodeReference[string]
|
||||
BearerFormat low.NodeReference[string]
|
||||
Flows low.NodeReference[*OAuthFlows]
|
||||
OpenIdConnectURL low.NodeReference[string]
|
||||
Extensions map[low.KeyReference[string]]low.ValueReference[any]
|
||||
}
|
||||
|
||||
func (ss *SecurityScheme) Build(root *yaml.Node) error {
|
||||
extensionMap, err := ExtractExtensions(root)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
ss.Extensions = extensionMap
|
||||
return nil
|
||||
}
|
||||
|
||||
type SecurityRequirement struct {
|
||||
Node *yaml.Node
|
||||
Value []low.NodeReference[string]
|
||||
Value low.NodeReference[[]low.ValueReference[string]]
|
||||
}
|
||||
|
||||
@@ -214,4 +214,10 @@ func TestCreateDocument_Paths(t *testing.T) {
|
||||
assert.Len(t, links.Value, 2)
|
||||
assert.Equal(t, "locateBurger", okCode.Value.FindLink("LocateBurger").Value.OperationId.Value)
|
||||
|
||||
locateBurger := okCode.Value.FindLink("LocateBurger").Value
|
||||
|
||||
burgerIdParam := locateBurger.FindParameter("burgerId")
|
||||
assert.NotNil(t, burgerIdParam)
|
||||
assert.Equal(t, "$response.body#/id", burgerIdParam.Value)
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user