delphimvcframework/lib/swagdoc/Source/Swag.Doc.SecurityDefinitionOAuth2.pas

174 lines
6.1 KiB
ObjectPascal
Raw Permalink Normal View History

{******************************************************************************}
{ }
{ Delphi SwagDoc Library }
{ Copyright (c) 2018 Marcelo Jaloto }
{ https://github.com/marcelojaloto/SwagDoc }
{ }
{******************************************************************************}
{ }
{ 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 }
{ }
{ Unless required by applicable law or agreed to in writing, software }
{ distributed under the License is distributed on an "AS IS" BASIS, }
{ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. }
{ See the License for the specific language governing permissions and }
{ limitations under the License. }
{ }
{******************************************************************************}
unit Swag.Doc.SecurityDefinitionOAuth2;
interface
uses
System.JSON,
System.SysUtils,
System.Generics.Collections,
Swag.Common.Types,
Swag.Doc.SecurityDefinition;
type
TSwagSecurityDefinitionOAuth2Scope = class(TObject)
private
fScopeName: string;
fDescription: string;
public
function GenerateJsonObject: TJSONObject;
procedure Load(pJson: TJSONPair);
property ScopeName: string read fScopeName write fScopeName;
property Description: string read fDescription write fDescription;
end;
/// <summary>
/// The security scheme object for OAuth2
/// </summary>
[ASecurityDefinition(ssdOAuth2)]
TSwagSecurityDefinitionOAuth2 = class(TSwagSecurityDefinition)
private
fName: string;
fAuthorizationUrl: string;
fFlow: string;
fScopes : TObjectList<TSwagSecurityDefinitionOAuth2Scope>;
protected
function GetTypeSecurity: TSwagSecurityDefinitionType; override;
public
function GenerateJsonObject: TJSONObject; override;
procedure Load(pJson: TJSONObject); override;
property Name: string read fName write fName;
property AuthorizationUrl: string read fAuthorizationUrl write fAuthorizationUrl;
property Flow: string read fFlow write fFlow;
property Scopes: TObjectList<TSwagSecurityDefinitionOAuth2Scope> read fScopes;
constructor Create; override;
destructor Destroy; override;
end;
implementation
uses
Classes;
const
c_SwagSecurityDefinitionOAuth2Type = 'type';
c_SwagSecurityDefinitionOAuth2Description = 'description';
c_SwagSecurityDefinitionOAuth2Name = 'name';
c_SwagSecurityDefinitionOAuth2AuthorizationUrl = 'authorizationUrl';
c_SwagSecurityDefinitionOAuth2Flow = 'flow';
c_SwagSecurityDefinitionOAuth2Scopes = 'scopes';
{ TSwagSecurityDefinitionOAuth2Scopes }
function TSwagSecurityDefinitionOAuth2Scope.GenerateJsonObject: TJSONObject;
begin
Result := TJSONObject.Create;
Result.AddPair(fScopeName, fDescription);
end;
procedure TSwagSecurityDefinitionOAuth2Scope.Load(pJson: TJSONPair);
begin
fScopeName := pJson.JsonString.Value;
fDescription := pJson.JsonValue.Value;
end;
{ TSwagSecurityDefinitionOAuth2 }
constructor TSwagSecurityDefinitionOAuth2.Create;
begin
inherited;
fScopes := TObjectList<TSwagSecurityDefinitionOAuth2Scope>.Create;
end;
destructor TSwagSecurityDefinitionOAuth2.Destroy;
begin
FreeAndNil(fScopes);
inherited;
end;
function TSwagSecurityDefinitionOAuth2.GenerateJsonObject: TJSONObject;
var
vJsonItem: TJsonObject;
vJsonScopes: TJsonObject;
vScopeIndex: Integer;
begin
vJsonItem := TJsonObject.Create;
vJsonItem.AddPair(c_SwagSecurityDefinitionOAuth2Type, ReturnTypeSecurityToString);
if fDescription.Length > 0 then
vJsonItem.AddPair(c_SwagSecurityDefinitionOAuth2Description, fDescription);
vJsonItem.AddPair(c_SwagSecurityDefinitionOAuth2AuthorizationUrl, fAuthorizationUrl);
vJsonItem.AddPair(c_SwagSecurityDefinitionOAuth2Flow, fFlow);
if fScopes.Count > 0 then
begin
vJsonScopes := TJSONObject.Create;
for vScopeIndex := 0 to fScopes.Count - 1 do
begin
vJsonScopes.AddPair(FScopes[vScopeIndex].ScopeName, fScopes[vScopeIndex].fDescription);
end;
vJsonItem.AddPair(c_SwagSecurityDefinitionOAuth2Scopes, vJsonScopes);
end;
Result := vJsonItem;
end;
function TSwagSecurityDefinitionOAuth2.GetTypeSecurity: TSwagSecurityDefinitionType;
begin
Result := TSwagSecurityDefinitionType.ssdOAuth2;
end;
procedure TSwagSecurityDefinitionOAuth2.Load(pJson: TJSONObject);
var
vScopeIndex: Integer;
vJsonScope: TJSONObject;
vScope: TSwagSecurityDefinitionOAuth2Scope;
begin
inherited;
if Assigned(pJson.Values[c_SwagSecurityDefinitionOAuth2Description]) then
fDescription := pJson.Values[c_SwagSecurityDefinitionOAuth2Description].Value;
if Assigned(pJson.Values[c_SwagSecurityDefinitionOAuth2AuthorizationUrl]) then
fAuthorizationUrl := pJson.Values[c_SwagSecurityDefinitionOAuth2AuthorizationUrl].Value;
if Assigned(pJson.Values[c_SwagSecurityDefinitionOAuth2Flow]) then
fFlow := pJson.Values[c_SwagSecurityDefinitionOAuth2Flow].Value;
if Assigned(pJson.Values[c_SwagSecurityDefinitionOAuth2Scopes]) then
begin
vJsonScope := pJson.Values[c_SwagSecurityDefinitionOAuth2Scopes] as TJSONObject;
for vScopeIndex := 0 to vJsonScope.Count - 1 do
begin
vScope := TSwagSecurityDefinitionOAuth2Scope.Create;
vScope.Load(vJsonScope.Pairs[vScopeIndex]);
fScopes.Add(vScope);
end;
end;
end;
initialization
RegisterClass(TSwagSecurityDefinitionOAuth2);
end.