Chapter 17 - Project AppServ1 |
Project Structure
| AppServ1.dpr |
program AppServ1;
uses
Forms,
AppServForm in 'AppServForm.pas' ,
AppServ1_TLB in 'AppServ1_TLB.pas',
AppServRdm in 'AppServRdm.pas' ;
begin
Application.Initialize;
Application.CreateForm(TForm1, Form1);
Application.Run;
end.
| AppServForm.pas |
unit AppServForm;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
StdCtrls;
type
TForm1 = class(TForm)
Label1: TLabel;
private
public
end;
var
Form1: TForm1;
implementation
end.
| AppServ1_TLB.pas |
unit AppServ1_TLB;
interface
uses Windows, ActiveX, Classes, Graphics, OleServer, OleCtrls, StdVCL,
Midas;
const
AppServ1MajorVersion = 1;
AppServ1MinorVersion = 0;
LIBID_AppServ1: TGUID = '{09E11D60-4A55-11D3-B9F1-00000100A27B}';
IID_IAppServerOne: TGUID = '{09E11D61-4A55-11D3-B9F1-00000100A27B}';
CLASS_AppServerOne: TGUID = '{09E11D63-4A55-11D3-B9F1-00000100A27B}';
type
IAppServerOne = interface;
IAppServerOneDisp = dispinterface;
AppServerOne = IAppServerOne;
IAppServerOne = interface(IAppServer)
['{09E11D61-4A55-11D3-B9F1-00000100A27B}']
end;
IAppServerOneDisp = dispinterface
['{09E11D61-4A55-11D3-B9F1-00000100A27B}']
function AS_ApplyUpdates(const ProviderName: WideString; Delta: OleVariant;
MaxErrors: Integer; out ErrorCount: Integer; var OwnerData: OleVariant): OleVariant; dispid 20000000;
function AS_GetRecords(const ProviderName: WideString; Count: Integer; out RecsOut: Integer;
Options: Integer; const CommandText: WideString;
var Params: OleVariant; var OwnerData: OleVariant): OleVariant; dispid 20000001;
function AS_DataRequest(const ProviderName: WideString; Data: OleVariant): OleVariant; dispid 20000002;
function AS_GetProviderNames: OleVariant; dispid 20000003;
function AS_GetParams(const ProviderName: WideString; var OwnerData: OleVariant): OleVariant; dispid 20000004;
function AS_RowRequest(const ProviderName: WideString; Row: OleVariant; RequestType: Integer;
var OwnerData: OleVariant): OleVariant; dispid 20000005;
procedure AS_Execute(const ProviderName: WideString; const CommandText: WideString;
var Params: OleVariant; var OwnerData: OleVariant); dispid 20000006;
end;
CoAppServerOne = class
class function Create: IAppServerOne;
class function CreateRemote(const MachineName: string): IAppServerOne;
end;
TAppServerOneProperties= class;
TAppServerOne = class(TOleServer)
private
FIntf: IAppServerOne;
FProps: TAppServerOneProperties;
function GetServerProperties: TAppServerOneProperties;
function GetDefaultInterface: IAppServerOne;
protected
procedure InitServerData; override;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure Connect; override;
procedure ConnectTo(svrIntf: IAppServerOne);
procedure Disconnect; override;
function AS_ApplyUpdates(const ProviderName: WideString; Delta: OleVariant;
MaxErrors: Integer; out ErrorCount: Integer; var OwnerData: OleVariant): OleVariant;
function AS_GetRecords(const ProviderName: WideString; Count: Integer; out RecsOut: Integer;
Options: Integer; const CommandText: WideString;
var Params: OleVariant; var OwnerData: OleVariant): OleVariant;
function AS_DataRequest(const ProviderName: WideString; Data: OleVariant): OleVariant;
function AS_GetProviderNames: OleVariant;
function AS_GetParams(const ProviderName: WideString; var OwnerData: OleVariant): OleVariant;
function AS_RowRequest(const ProviderName: WideString; Row: OleVariant; RequestType: Integer;
var OwnerData: OleVariant): OleVariant;
procedure AS_Execute(const ProviderName: WideString; const CommandText: WideString;
var Params: OleVariant; var OwnerData: OleVariant);
property DefaultInterface: IAppServerOne read GetDefaultInterface;
published
property Server: TAppServerOneProperties read GetServerProperties;
end;
TAppServerOneProperties = class(TPersistent)
private
FServer: TAppServerOne;
function GetDefaultInterface: IAppServerOne;
constructor Create(AServer: TAppServerOne);
protected
public
property DefaultInterface: IAppServerOne read GetDefaultInterface;
published
end;
procedure Register;
implementation
uses ComObj;
class function CoAppServerOne.Create: IAppServerOne;
begin
Result := CreateComObject(CLASS_AppServerOne) as IAppServerOne;
end;
class function CoAppServerOne.CreateRemote(const MachineName: string): IAppServerOne;
begin
Result := CreateRemoteComObject(MachineName, CLASS_AppServerOne) as IAppServerOne;
end;
procedure TAppServerOne.InitServerData;
const
CServerData: TServerData = (
ClassID: '{09E11D63-4A55-11D3-B9F1-00000100A27B}';
IntfIID: '{09E11D61-4A55-11D3-B9F1-00000100A27B}';
EventIID: '';
LicenseKey: nil;
Version: 500);
begin
ServerData := @CServerData;
end;
procedure TAppServerOne.Connect;
var
punk: IUnknown;
begin
if FIntf = nil then
begin
punk := GetServer;
Fintf:= punk as IAppServerOne;
end;
end;
procedure TAppServerOne.ConnectTo(svrIntf: IAppServerOne);
begin
Disconnect;
FIntf := svrIntf;
end;
procedure TAppServerOne.DisConnect;
begin
if Fintf <> nil then
begin
FIntf := nil;
end;
end;
function TAppServerOne.GetDefaultInterface: IAppServerOne;
begin
if FIntf = nil then
Connect;
Assert(FIntf <> nil, 'DefaultInterface is NULL. Component is not connected to Server. You must call ''Connect'' or ''ConnectTo'' before this operation');
Result := FIntf;
end;
constructor TAppServerOne.Create(AOwner: TComponent);
begin
inherited Create(AOwner);
FProps := TAppServerOneProperties.Create(Self);
end;
destructor TAppServerOne.Destroy;
begin
FProps.Free;
inherited Destroy;
end;
function TAppServerOne.GetServerProperties: TAppServerOneProperties;
begin
Result := FProps;
end;
function TAppServerOne.AS_ApplyUpdates(const ProviderName: WideString; Delta: OleVariant;
MaxErrors: Integer; out ErrorCount: Integer;
var OwnerData: OleVariant): OleVariant;
begin
Result := DefaultInterface.AS_ApplyUpdates(ProviderName, Delta, MaxErrors, ErrorCount, OwnerData);
end;
function TAppServerOne.AS_GetRecords(const ProviderName: WideString; Count: Integer;
out RecsOut: Integer; Options: Integer;
const CommandText: WideString; var Params: OleVariant;
var OwnerData: OleVariant): OleVariant;
begin
Result := DefaultInterface.AS_GetRecords(ProviderName, Count, RecsOut, Options, CommandText,
Params, OwnerData);
end;
function TAppServerOne.AS_DataRequest(const ProviderName: WideString; Data: OleVariant): OleVariant;
begin
Result := DefaultInterface.AS_DataRequest(ProviderName, Data);
end;
function TAppServerOne.AS_GetProviderNames: OleVariant;
begin
Result := DefaultInterface.AS_GetProviderNames;
end;
function TAppServerOne.AS_GetParams(const ProviderName: WideString; var OwnerData: OleVariant): OleVariant;
begin
Result := DefaultInterface.AS_GetParams(ProviderName, OwnerData);
end;
function TAppServerOne.AS_RowRequest(const ProviderName: WideString; Row: OleVariant;
RequestType: Integer; var OwnerData: OleVariant): OleVariant;
begin
Result := DefaultInterface.AS_RowRequest(ProviderName, Row, RequestType, OwnerData);
end;
procedure TAppServerOne.AS_Execute(const ProviderName: WideString; const CommandText: WideString;
var Params: OleVariant; var OwnerData: OleVariant);
begin
DefaultInterface.AS_Execute(ProviderName, CommandText, Params, OwnerData);
end;
constructor TAppServerOneProperties.Create(AServer: TAppServerOne);
begin
inherited Create;
FServer := AServer;
end;
function TAppServerOneProperties.GetDefaultInterface: IAppServerOne;
begin
Result := FServer.DefaultInterface;
end;
procedure Register;
begin
RegisterComponents('Servers',[TAppServerOne]);
end;
end.
| AppServRdm.pas |
unit AppServRdm;
interface
uses
Windows, Messages, SysUtils, Classes, ComServ, ComObj, VCLCom, DataBkr,
DBClient, AppServ1_TLB, StdVcl, Provider, Db, DBTables, DBXpress, FMTBcd,
SqlExpr;
type
TAppServerOne = class(TRemoteDataModule, IAppServerOne)
DataSetProvider1: TDataSetProvider;
SQLConnection1: TSQLConnection;
SQLDataSet1: TSQLDataSet;
private
protected
class procedure UpdateRegistry(Register: Boolean; const ClassID, ProgID: string); override;
public
end;
implementation
class procedure TAppServerOne.UpdateRegistry(Register: Boolean; const ClassID, ProgID: string);
begin
if Register then
begin
inherited UpdateRegistry(Register, ClassID, ProgID);
EnableSocketTransport(ClassID);
EnableWebTransport(ClassID);
end else
begin
DisableSocketTransport(ClassID);
DisableWebTransport(ClassID);
inherited UpdateRegistry(Register, ClassID, ProgID);
end;
end;
initialization
TComponentFactory.Create(ComServer, TAppServerOne,
Class_AppServerOne, ciMultiInstance, tmApartment);
end.
| AppServForm.dfm |
object Form1: TForm1
Left = 199
Top = 124
Width = 293
Height = 86
Caption = 'AppServ1'
Color = clBtnFace
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'MS Sans Serif'
Font.Style = []
OldCreateOrder = False
PixelsPerInch = 96
TextHeight = 13
object Label1: TLabel
Left = 13
Top = 16
Width = 264
Height = 24
Caption = 'Remote Data Module Server (1)'
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -19
Font.Name = 'MS Sans Serif'
Font.Style = []
ParentFont = False
end
end
| AppServRdm.dfm |
object AppServerOne: TAppServerOne
OldCreateOrder = False
Left = 405
Top = 227
Height = 260
Width = 310
object DataSetProvider1: TDataSetProvider
DataSet = SQLDataSet1
Constraints = True
Left = 176
Top = 32
end
object SQLConnection1: TSQLConnection
ConnectionName = 'IBLocal'
DriverName = 'Interbase'
GetDriverFunc = 'getSQLDriverINTERBASE'
LibraryName = 'dbexpint.dll'
LoginPrompt = False
Params.Strings = (
'BlobSize=-1'
'CommitRetain=False'
'Database=c:\program files\interbase corp\interbase6\examples\dat' +
'abase\employee.gdb'
'DriverName=Interbase'
'LocaleCode='
'Password=masterkey'
'RoleName=RoleName'
'ServerCharSet=ASCII'
'SQLDialect=1'
'Interbase TransIsolation=ReadCommited'
'User_Name=sysdba'
'WaitOnLocks=True')
VendorLib = 'GDS32.DLL'
Left = 64
Top = 40
end
object SQLDataSet1: TSQLDataSet
SQLConnection = SQLConnection1
CommandText =
'select DEPT_NO, EMP_NO, FIRST_NAME, FULL_NAME, HIRE_DATE, JOB_CO' +
'DE, JOB_COUNTRY, JOB_GRADE, LAST_NAME, PHONE_EXT, SALARY from EM' +
'PLOYEE'
Params = <>
Left = 128
Top = 96
end
end
|
|