un_actions.~pas

来自「信息系统工作核心代码,若要具体可以联系我,这只是一部分核心代码,大家一起交流分享」· ~PAS 代码 · 共 67 行

~PAS
67
字号
unit Un_Actions;

interface

uses
  classes, SysUtils, Un_DAO, Un_System;

type
  TActionPermission=class(TInterfacedObject, IActionPermission)
  private
    FIsSA: Boolean;
    FDAO: TDAO;
  public
    constructor Create;
    destructor Destroy; override;
    procedure LoadActions(IsSA: Boolean; UId, TreeId: Integer);
    function GetPermission(ActionId: string): Boolean;
  end;

implementation

{ TActionPermission }

constructor TActionPermission.Create;
begin
  FDAO:= TDAO.Create;
end;

destructor TActionPermission.Destroy;
begin
  FDAO.Free;
  inherited;
end;

function TActionPermission.GetPermission(ActionId: string): Boolean;
begin
  Result:= False;
  if FIsSA then begin
    Result:= True;
    Exit;
  end;
  FDAO.ResultSet.First;
  while not FDAO.ResultSet.Eof do begin
    if Pos(ActionId, FDAO.ResultSet.FieldByName('Actions').AsString)<>0 then begin
      Result:= True;
      Break;
    end;
    FDAO.ResultSet.Next;
  end;
end;

procedure TActionPermission.LoadActions(IsSA: Boolean; UId, TreeId: Integer);
begin
  FIsSA:= IsSA;
  if FIsSA then
    Exit;
  FDAO.SQL:= 'Select Actions From UserRole, MyRoles, MyUsers, Permissions '
            +'Where UserRole.UId=MyUsers.Id '
            +'and MyUsers.Id='+IntToStr(UId)+' and MyUsers.Useable=1 '
            +'and UserRole.RId=MyRoles.Id and MyRoles.Useable=1 '
            +'and Permissions.RoleId=MyRoles.Id '
            +'and Permissions.TreeId='+IntToStr(TreeId);
  FDAO.ExecuteQuery;
end;

end.

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?