Clarion IPDS Reference Guide

Transcription

Clarion IPDS Reference Guide
Clarion IP Driver and Server Reference
2
IP Driver and Server Reference
© COPYRIGHT 2005 SoftVelocity Incorporated. All rights reserved.
This publication is protected by copyright and all rights are reserved by SoftVelocity Incorporated. It may not, in whole or
part, be copied, photocopied, reproduced, translated, or reduced to any electronic medium or machine-readable form
without prior consent, in writing, from SoftVelocity Incorporated.
This publication supports Clarion. It is possible that it may contain technical or typographical errors. SoftVelocity
Incorporated provides this publication “as is,” without warranty of any kind, either expressed or implied.
SoftVelocity Incorporated
2335 East Atlantic Blvd. Suite 410
Pompano Beach, Florida 33062
(954) 785-4555
www.softvelocity.com
Updated for Version 2.0
Trademark Acknowledgements:
SoftVelocity is a trademark of SoftVelocity Incorporated.
Clarion™ is a trademark of SoftVelocity Incorporated.
Microsoft®, Windows®, and Visual Basic® are registered trademarks of Microsoft Corporation.
All other products and company names are trademarks of their respective owners.
Printed in the United States of America (1005)
IP Driver and Server Reference
3
Contents:
IP Driver and Data Server - Overview
7
What’s New in Version 1.3/1.4
8
New Timeout setting on the server for sessions ........................................................................................................ 8
Forced disconnect on a new Remote Administrator session..................................................................................... 8
Guest User Administration ......................................................................................................................................... 8
Improved Connection Handling.................................................................................................................................. 8
What’s New in Version 2.0
9
Server Side VIEWS.................................................................................................................................................... 9
Multiple Request Packets........................................................................................................................................... 9
Template Support for Remote Variables.................................................................................................................... 9
New “From List” Connection Option........................................................................................................................... 9
Installation
10
Register the Driver and Templates .......................................................................................................................... 10
Install the Java runtime (1.4 or higher) .................................................................................................................... 11
Install Notes
12
Fast Start.................................................................................................................................................................. 12
Online Tutorials ........................................................................................................................................................ 12
Server Directory structure ........................................................................................................................................ 12
RMAdmin ........................................................................................................................................................... 12
SoftVelocity IP Data Server Service ........................................................................................................................ 12
IP Data Server Manager .......................................................................................................................................... 13
Architecture
15
How to IP-enable a FILE
15
An IP-enabled Application in 10 minutes (or less)
17
Summary: ................................................................................................................................................................. 22
A Multi-DLL example
23
IPS File Defined................................................................................................................................................. 23
IPC File Defined................................................................................................................................................. 24
Deployment Checklist
26
Server Security Settings........................................................................................................................................... 28
SSL Deployment Considerations ............................................................................................................................. 29
Optional Dictionary Settings
31
IP Driver Template Support
32
IP Server Template .................................................................................................................................................. 33
The IPS file ........................................................................................................................................................ 33
General tab ........................................................................................................................................................ 33
File Control tab .................................................................................................................................................. 34
IPServer Version................................................................................................................................................ 34
Data Manager DLL Wizard....................................................................................................................................... 35
IPDRV Extended Server Support Extensions .......................................................................................................... 38
Technical Notes ................................................................................................................................................. 38
IP Server Extension – IPDRV Extended ........................................................................................................... 39
IP Server Extension – Runtime Names............................................................................................................. 40
IP Server Extension – Server Variables ............................................................................................................ 40
IPEXEC Source Procedure Template...................................................................................................................... 41
IP Client Template.................................................................................................................................................... 42
The IPC File....................................................................................................................................................... 42
Select IPS File ................................................................................................................................................... 43
4
IP Driver and Server Reference
Connection Type................................................................................................................................................ 43
Extended Server Support Extensions – Client......................................................................................................... 47
IP Client Extension – General ........................................................................................................................... 47
IP Client Extension – Imported Procedures ...................................................................................................... 47
IP Client Extension – Remote Variables ........................................................................................................... 48
IPDriver Code Templates – Client Application......................................................................................................... 49
IPChangeFileName Code Template ................................................................................................................. 49
IPEXEC Code Template.................................................................................................................................... 50
IPTransferFileCode Code Template.................................................................................................................. 51
IPIsAlive Code Template ................................................................................................................................... 52
IPKeepAlive Code Template ............................................................................................................................. 53
IPSetRemoteVariable Code Template .............................................................................................................. 54
IPGetRemoteVariable Code Template.............................................................................................................. 54
IPTransferFile Control Template – Client Application.............................................................................................. 55
Extended Server Support Extensions Examples ..................................................................................................... 56
File Transfer....................................................................................................................................................... 56
Multidataset ....................................................................................................................................................... 56
Server-side Embeds and Procedures
57
GetFName (change the name of the data file or path)...................................................................................... 58
Program Setup access ...................................................................................................................................... 59
BeforeOpen (called prior to the server opening the file) ................................................................................... 59
Calling the Server-side Remote Procedure....................................................................................................... 60
IPDRV Extended Server Embeds ............................................................................................................................ 62
IPEXEC Dispatch Procedure............................................................................................................................. 62
IPSetFilename Procedure ................................................................................................................................. 63
IPGetFilename Procedure ................................................................................................................................. 63
Client-side Embeds and Procedures
64
File Transfer Embed Points...................................................................................................................................... 64
Advanced Server Support
65
Multiple Request Packet (MRP) support for ADD, APPEND, NEXT and PREVIOUS statements.......................... 65
MRP Property:.......................................................................................................................................................... 65
IPRequestCount ................................................................................................................................................ 65
FAQs ........................................................................................................................................................................ 67
Error Handling .......................................................................................................................................................... 67
MRP Conceptual Examples ..................................................................................................................................... 68
Example 1: How to create a packet with multiple ADD requests. ..................................................................... 68
Example 2. How to send a packet immediately................................................................................................. 68
Example 3. How to create a packet with an unknown number of requests....................................................... 68
Example 4. How to kill the current packet. ........................................................................................................ 69
Example 5. How to create a packet with multiple NEXT requests. ................................................................... 69
Example 6. How to create a packet with multiple PREVIOUS requests. .......................................................... 70
Example 7. How to kill a received packet.......................................................................................................... 70
Example 8. Adding NOMEMO support.............................................................................................................. 71
Server Side VIEW support ....................................................................................................................................... 72
Filtering Rules.................................................................................................................................................... 72
IP Driver Class Library Reference
73
Overview .................................................................................................................................................................. 73
IPFileTransfer and IPExtender Class Source Files ................................................................................................. 73
Template Support..................................................................................................................................................... 73
IPExtender methods:................................................................................................................................................ 74
SetConnectionString (set OWNER attribute of IP file) ...................................................................................... 74
GetConnectionString (get OWNER attribute of IP file)...................................................................................... 74
Exec(call a remote procedure) .......................................................................................................................... 75
SetFileName (change remote file name)........................................................................................................... 76
GetFilename (read remote file name)................................................................................................................ 76
SetRemoteVariable (change remote variable) .................................................................................................. 77
IP Driver and Server Reference
5
GetRemoteVariable (read remote variable) ...................................................................................................... 77
IsAlive (is the IP Server connection active?) ..................................................................................................... 78
CloseConnection (close internal Server connection) ........................................................................................ 78
SetKeepAlive (activate internal KeepAlive mode) ............................................................................................. 79
IPFileTransfer Methods............................................................................................................................................ 80
SetConnectionString (set OWNER attribute of IP file) ...................................................................................... 80
GetConnectionString (get OWNER attribute of IP file)...................................................................................... 80
SetSourceFileName(Set the source file name) ................................................................................................. 81
SetTargetFileName(Set the target file name).................................................................................................... 81
GetRemoteFileName(Get the Remote File Name) ........................................................................................... 81
SetControls(Set pause and progress controls) ................................................................................................. 81
Init(Initialize the class) ....................................................................................................................................... 82
SetSilent(set visible error message).................................................................................................................. 83
GetSilent(get the silent error state).................................................................................................................... 83
InitSend(begin the SEND process).................................................................................................................... 84
InitReceive(begin the RECEIVE process) ......................................................................................................... 85
TakeEvent(monitor transfer process) ................................................................................................................ 86
Start(transfer started) ........................................................................................................................................ 87
Pause(transfer paused) ..................................................................................................................................... 87
Cancel(transfer cancelled)................................................................................................................................. 87
Aborted(transfer aborted) .................................................................................................................................. 87
Finish(transfer finished) ..................................................................................................................................... 87
Send(begin internal SEND) ............................................................................................................................... 87
Receive(begin internal RECEIVE)..................................................................................................................... 87
GetErrorCode(get transfer errorcode) ............................................................................................................... 88
GetError(get transfer error)................................................................................................................................ 88
SetBuffersPerCycle (set buffers read per cycle) ............................................................................................... 88
GetBuffersPerCycle (get buffers read per cycle)............................................................................................... 88
SetTimer(set transfer interval) ........................................................................................................................... 89
GetTimer(get transfer Interval) .......................................................................................................................... 89
SetAllowPause(set transfer pause action) ........................................................................................................ 90
GetAllowPause(get transfer pause action)........................................................................................................ 90
GetAction(get the transfer action)...................................................................................................................... 90
SwapPauseText(transfer control text) ............................................................................................................... 91
StartTimer(transfer interval started)................................................................................................................... 91
StopTimer(transfer interval stopped) ................................................................................................................. 91
Error Codes and Error Trapping
92
Socket Errors ........................................................................................................................................................... 92
Common Errors........................................................................................................................................................ 93
Detecting an invalid connection to the IP Data Server ............................................................................................ 94
SoftVelocity IP Data Server Service
95
Server Ports ............................................................................................................................................................. 95
UNC support for the SoftVelocity IP Data Server Service ....................................................................................... 96
A note about Mapped Drives.................................................................................................................................... 96
Remote Administration Application (RMAdmin)
97
Main Menu ......................................................................................................................................................... 98
Toolbar............................................................................................................................................................... 99
Tree-View Pane ................................................................................................................................................. 99
Details View Pane............................................................................................................................................ 100
Sessions View ................................................................................................................................................. 100
Active Table View ............................................................................................................................................ 101
Table View ....................................................................................................................................................... 102
Account Administration View ........................................................................................................................... 103
Table Permissions (Access Rights)................................................................................................................. 104
IP Server Settings............................................................................................................................................ 105
Data Manager Aliases ..................................................................................................................................... 105
Status Bar Information..................................................................................................................................... 105
6
IP Driver and Server Reference
Connect to IP Server ....................................................................................................................................... 106
Possible Connection Errors ............................................................................................................................. 107
Stored configuration properties ....................................................................................................................... 107
IP Driver Specifications
108
Files: ................................................................................................................................................................ 108
Data Types and File Specifications ................................................................................................................. 108
Driver Strings ................................................................................................................................................... 109
Supported Commands and Attributes ............................................................................................................. 109
DEBUGVIEW Support
110
Advanced Deployment Tips
111
Clarion Runtime Files ...................................................................................................................................... 111
Location of Data Managers and Data Files ..................................................................................................... 111
Distribution Guide
112
IP Data Manager Distribution ................................................................................................................................. 112
IP Client Applications ............................................................................................................................................. 112
IP Data Server (IPDS) Distribution......................................................................................................................... 112
How to Distribute the IP Data Server ..................................................................................................................... 113
Distributed Applications
114
Divided............................................................................................................................................................. 114
Separate Processes ........................................................................................................................................ 114
Advanced......................................................................................................................................................... 114
Globalization
115
Performance Tips
116
Troubleshooting
117
Index
119
IP Driver and Server Reference
7
IP Driver and Data Server - Overview
The IP (Internet Protocol) Driver enables any Clarion application to use familiar Clarion FILE access syntax to transmit
and receive data over the IP protocol from a “data server”. The client-side IP driver is a Clarion FILE driver, but instead of
using local physical files for storing data it communicates over IP to a server where the physical data is processed. The
SoftVelocity IP Data Server is a Win32 service running on the machine where the physical data files are located and
accessed.
The IP Driver is compatible with any application written using either the Clarion or ABC template chains. The client
application can make use of the entire Clarion runtime library, any Windows API functions, ActiveX controls, any
supported FILE driver, both MDI and SDI windows, and any 3rd Party tool set. The Client application can be configured to
be 100% remote database client, or can use a mix of both local physical files and remote data files. The Client application
can also use a mix of different FILE drivers.
The IP Driver and Server (IPDS) has three major components:
•
The IP Driver, which becomes part of the client application, requests and accepts data from the IP Data Server.
The communication stream can be performed with or without SSL (Secure Socket Layer) support.
•
The IP Data Server accepts requests for data from the client, processes the request and returns the data. The
IP Data Server can be installed on Windows NT, Windows 2000, Windows 2003 or Windows XP.
You may also install the IP Data Server on Windows 98/ME, however neither of these platforms are server
Operating Systems, so we do not support them for deployments. Your results with these O/S's will vary according
to various factors such as the amount of RAM installed, service packs installed, etc.
•
Remote Administrator: the Remote Administration Console application is designed for administrators, and allows
you to Shutdown the Server, Register/UnRegister Data Manager DLLs, monitor connections, specify USER
accounts and permissions for tables, and more.
To enable a Clarion application to function as a remote database client, there are only three steps; adding the IP Client
extension template to the client application(s), the creation of a server side Data Manager DLL, and registering the Data
Manager DLL on the server.
8
IP Driver and Server Reference
What’s New in Version 1.3/1.4
The following section documents key new features and changes in the IP Driver Version 1.3:
New Timeout setting on the server for sessions
•
See the Tools > ServerSettings menu item in the Remote Administrator. This affects both IP Client applications
AND the Remote Administrator sessions (anything that connects to the IP Driver Service).
Forced disconnect on a new Remote Administrator session
•
Forced disconnect on a new Remote Administrator session when a Remote Administrator is already connected
Guest User Administration
•
•
•
•
•
You can now delete the Guest user account for added security.
You can’t modify the Guest user (You can only delete it or add again).
Any password that you set for the Guest user is ignored.
It is not possible to assign administrative rights to Guest user.
Finally, the name “Guest” cannot be assigned to another account (when you are modifying it).
Improved Connection Handling
•
Re-establishing a connection is implemented in this release, when all FILEs are CLOSEd the next OPEN starts a
new connection. This is a change from previous versions, where the connection would remain opened even after
all files were closed, and only terminated when the client program was shut down.
•
There is also template and class support for this new feature. See the Extended Server Support Extensions –
Client in this PDF, and the new SetKeepAlive, IsAlive, and CloseConnection methods in the IP Driver Class
Library Reference. There are two new code templates available to help you implement more robust connection
handling, IPKeepAlive and IPIsAlive.
IP Driver and Server Reference
9
What’s New in Version 2.0
Version 2 has two important new features:
•
Support for Server-side VIEWS, and
•
Support for Multiple Request Packets (MRPs).
Server Side VIEWS
Up until Version 2, all VIEWs defined in the IP Client application were processed on the client side, which meant that all
ordering and filtering was also performed on the client side. This meant unwanted data traffic between the IP client
application and the Server side Data Manager.
Server-side VIEWS allow all ordering and filtering to be performed on the server side, and only the pertinent data is
returned to the Client application, resulting in better performance with this version.
Multiple Request Packets
In Windows terms, a request packet is defined as a data structure used to represent a single input/output request and
control its process. The I/O request packet structure consists of a header and one or more stack locations.
Version 2 of the IP Driver supports Multiple Request Packets, which means in Clarion terms that multiple requests for data
can be contained in a single packet. You can also include NOMEMO support for an even greater performance.
Both of these new features are designed to enhance the performance of your IP Client application with the streamlining of
the contents and amount of data packets transferred. The supporting templates in this release have also been updated to
support these new features.
Please see the Advanced Server Support section in this document for more detailed information.
Template Support for Remote Variables
There are two new code templates available in the IP Client application that allow you to achieve better control of remote
variables that are stored in the target server’s Data Manager DLL. IPSetRemoteVariable is used to prime the contents of
a target remote variable with a particular value. IPGetRemoteVariable is used to return the current value of a remote
variable that is defined in the Data Manager. See the IP Driver Code Templates – Client Application section in this
document for more details.
New “From List” Connection Option
In the IP Client Global template, you can now specify a “From List” Connection Option. The accompanying list contains a
list of different types of server connections that you specify, and you can select one type before compiling the application.
This allows you to store a “development” connection and a “production” connection, and maintain both easily.
10
IP Driver and Server Reference
Installation
There are two installation programs for the IPDS; one install for the IP Driver and another install program for the IP Data
Server. During the development cycle, the client application and IP Data Server may be run on the same machine, or you
can choose to install the server on a separate machine. The same is true when you deploy the application.
From your installation media run the following programs:
IPDriver_setup.exe
IPDataServer_setup.exe
Register the Driver and Templates
Register the IP Driver in the Clarion IDE. From the Clarion IDE main menu choose Setup-> Database Driver Registry.
Select the C60IPD.DLL and press the “Add” button.
Register the templates. This is accomplished by selecting the Template Registry menu item from the Clarion IDE Setup
main menu. You will register two template files; IPDRV.TPL and IPSERVER.TPL
IP Driver and Server Reference
Both the IP Client and Server templates are compatible with ABC and Clarion template family applications.
Install the Java runtime (1.4 or higher)
The RMadmin application requires Java 1.4 or higher. If you don’t have Java installed open this URL
http://www.softvelocity.com/java/index.htm and download the Java install.
11
12
IP Driver and Server Reference
Install Notes
The IP Driver ships with two example applications found in: \Clarion6\Examples\IPdriver\People and
\Clarion6\Examples\IPdriver\MultiDLL
Fast Start
This manual quickly guides you through both IP examples. It is very strongly recommended that you work through both
examples before proceeding with new projects.
Online Tutorials
See the online help file that ships with this product for a series of Flash tutorial movies that demonstrate the
implementation and design of an IP enabled application.
Server Directory structure
By default, the IP Data Server is installed into the \ClarionDataServer folder and RMAdmin is created as a subfolder :
\ClarionDataServer
This folder contains the engine, libraries and configuration files needed for the IP Data Server.
RMAdmin
This folder contains the Remote Administrator Console. The Admin console can be launched from the RUN.BAT batch
file, or by double-clicking the RMadmin.jar file.
You must have Java SDK or JRE versions 1.4 or greater installed on your development machine.
More information on this utility can be found in the Java Remote Administrator topic in this manual.
SoftVelocity IP Data Server Service
The installation program installs the SoftVelocity IP Data Server service by running:
\ClarionDataServer\IPREQ –i
You can manually install or uninstall the SoftVelocity IP Data Server service from the command line:
IPREQ –i
(the parameter is case sensitive, lower case “i”)
The –i switch indicates “Install”.
The –u switch uninstalls the data server.
IP Driver and Server Reference
13
IP Data Server Manager
The IP Data Server Manager (IPSRVMGR.EXE) is a handy utility that you can use to perform a number of operations on
the Data Server. It also displays the Machine IP Address and Port number assignments:
Install Service
Press this button to auto install the SoftVelocity IP Data Server Service. After accepting the license agreement, you will
receive a confirmation message that the service has been successfully installed.
To confirm the successful installation, navigate to the Control Panel > Administrative Tools > Services (in XP and
W2000), and verify that there is a SoftVelocity IP Data Server Service installed:
Remove Service
Press this button to automatically remove the SoftVelocity IP Data Server Service. You will receive a confirmation
message when it has been successfully removed from the Windows Services.
Start Service
Press this button to start the SoftVelocity IP Data Server Service. The service must be running before accessing the
Remote Administrator, or running any Client application. You should receive a confirmation message when the service is
started correctly.
14
IP Driver and Server Reference
Stop Service
Press this button if you need to stop the SoftVelocity IP Data Server service for any reason. You should receive a
confirmation message when the service is stopped.
Change Port
The IP Data Server Manager displays the current ports used for SSL and Non-SSL protocols. If these default port
numbers are in conflict with another application, press this button to change the port numbers if needed.
Delete Config File
The IPREQ.CFG file contains information regarding the Data Managers that you have installed, and authorized users. If
for some reason you would like to empty these values completely, press this button. You will receive a message to
confirm your delete action before actually deleting this file.
IP Driver and Server Reference
15
Architecture
The Clarion application program is linked with the IP Driver. When the client application issues an OPEN(file) for an IPenabled file, the IP driver transmits a request to the IP data server to load the specified Data Manager and OPEN the file.
If the request is successful the IP Data Server spawns a new thread for that client session.
How to IP-enable a FILE
To IP-enable any FILE structure, you only need to modify the OWNER attribute of the FILE structure, and change the
FILE driver to the IP Driver. For an IP-enabled FILE the OWNER attribute uses the following syntax to specify the
parameters to communicate with the IP Data Server:
DataManagerDLL@HostName:Port[:UserName:password]
The “DataManagerDLL” parameter is the name of a DLL that you create from your Dictionary using the IP Server
template. It is comparable to the traditional “Data DLL” commonly used by most multi-dll applications in that it represents
the tables in your dictionary.
The “HostName” parameter is the data server’s IP address or a hostname that can be resolved using DNS.
The “Port” parameter is the port number the IP Data Server is configured to listen on.
The “UserName:Password” are optional parameters to specify a user account you created on the server and the
associated password.
Let’s take a look at an example File Structure.
16
IP Driver and Server Reference
Here is the structure before IP-enabling the FILE
people
KeyId
KeyLastName
Record
Id
FirstName
LastName
Gender
FILE,DRIVER('TOPSPEED'),PRE(PEO),THREAD
KEY(PEO:Id),NOCASE,OPT
KEY(PEO:LastName),DUP,NOCASE
RECORD,PRE()
LONG
STRING(30)
STRING(30)
STRING(1)
END
END
and here it is after IP-enabling the FILE
people
KeyId
KeyLastName
Record
Id
FirstName
LastName
Gender
FILE,DRIVER('IPDRIVER'),PRE(PEO),THREAD,OWNER(‘ip_people.dll@localhost:2339)
KEY(PEO:Id),NOCASE,OPT
KEY(PEO:LastName),DUP,NOCASE
RECORD,PRE()
LONG
STRING(30)
STRING(30)
STRING(1)
END
END
As you can see, the OWNER attribute was added to the FILE structure in order to specify the Data Manager DLL, IP Data
Server, and the Port. The DRIVER attribute is also changed to reflect the IP Driver. In this example, our Data Manager
DLL is named ip_people.dll , and the data server is running on our local machine (localhost), listening on Port 2339. This
single change (and a Data Manager) is all that it takes to access a remote data source.
The support template that ship with the IP Driver will handle all of this configuration process for you. This section is only to
describe what is happening behind the scenes.
IP Driver and Server Reference
17
An IP-enabled Application in 10 minutes (or less)
Now that you have a feel for the architecture of the IP Data Server (IPDS), we’ll build and deploy our first IP-enabled
application. If you haven’t already installed the IP Data Server and Driver please do so now. If you need help with the
installation process refer to the “Installation” chapter in this manual.
We’ll use the “People.app” that was installed with the IP Driver for this exercise. We’ve already done the work of adding
the extension templates for you, so the whole process will likely take less than 10 minutes.
1. Start Clarion and then open \Clarion6\Examples\IPdriver\people\IP_people.App
This is the “Data Manager” application. If you look at the Application Properties, you’ll see that it was defined to use the
People dictionary (people.DCT) and the IPServer application template.
2. The creation of the Data Manager DLL will be your first step when IP-enabling any application. Go ahead and
press the Make button. The compiler will create “IP_people.DLL”.
NOTE: All IP-enabled applications (Data Managers and Client Applications) must be linked in “StandAlone” mode.
You can also use the Data Manager DLL Wizard to help you to generate the Data Manager. See the Data Manager DLL
Wizard section later on in this PDF for more information.
3. Look in \Clarion6\Examples\IPdriver\people\ and copy the IP_people.DLL it to your data server directory.
4. Next, copy the physical data file to the server directory.
From \Clarion6\Examples\IPdriver\people\ copy “PEOPLE.TPS” to your data server directory.
NOTE: If your target server does not have Clarion installed, you will also have to copy the C60RUNX.DLL and
Database driver DLL (i.e., C60TPSX.DLL) to the target server’s directory root. See the Deployment Checklist section
in this PDF for a complete list of files to copy, or, if you have any problems running the completed Client application.
After you have deployed the necessary files to the target server , it is now time to register the newly created Data
Manager. You do this by running the Remote Administrator (rmadmin.jar) application.
NOTE: RMadmin requires Java 1.4 or higher is installed. If you don’t have Java installed yet, go to
http://www.softvelocity.com/java/index.htm right now for a convenient link to download the Java install.
5. Open Explorer. Navigate to \ClarionDataServer\RMadmin and double-click on the rmadmin.jar file. Make sure
that the SoftVelocity IP Data Server Service is started (see page 8).
TIP: If the RMadmin main window doesn’t appear, go to a command prompt in the same directory and execute “Run.bat”.
The batch file will report any problems locating the correct version of “Java .exe”.
18
IP Driver and Server Reference
6. Once you have the RMadmin console running from the main menu choose
Connection->Connect to IP Server…
You’ll see this dialog:
7. When the IP Data Server is first installed, use “Administrator” for the User name and leave the Password blank.
If you didn’t install the server on your local machine enter the correct IP address and if you changed the Port the
server is listening on, then set that to the proper value.
8. Press the “Connect” button.
9. Right-click on the Data Managers icon and from the popup menu choose Register Data Managers…
IP Driver and Server Reference
19
10. The dialog shown below shows available “Data Managers” and the IP_People.dll we just created is listed. Press
the “Register” button.
Next, expand the Data Managers node by clicking on the plus sign in the tree display. Select IP_people.dll in the tree list.
The right-hand panel display now looks like this:
20
IP Driver and Server Reference
11. Right-click on the PEOPLE table as shown here:
12. Choose Table Permissions from the popup menu. NOTE: In the following steps, your install program may have
already included the Guest and Administrator accounts with all permissions granted. However, it’s a good idea to
review this process at this time.
13. In the dialog shown below, press the “Plus (+) ” button.
IP Driver and Server Reference
14. From the list of users in the Select Accounts dialog, highlight the Guest user, and then press the Select button.
15. Finally, press the OK button to close the Permissions dialog.
21
22
IP Driver and Server Reference
Summary:
At this point we have done the following:
•
created the Data Manager “IP_People.dll” and deployed it to the server
•
copied the PEOPLE.TPS data file to the server
•
registered the Data Manager DLL “IP_People.DLL” on the server
•
granted access permissions to PEOPLE.TPS for the Guest and Administrator account (this was preset by the
install).
Now it’s time to build our IP client application. Switch back to Clarion6, and Open
\Clarion6\Examples\IPdriver\People\People.app. Press the Make and Run button.
When the application starts choose one of the Menu items to Browse the file.
You now have your first IP-enabled application up and running!
IP Driver and Server Reference
23
A Multi-DLL example
The first example was intentionally very simple. Now we’ll look at the steps needed to IP-enable a multi-DLL application.
1. Startup Clarion6 and open \Clarion6\Examples\IPdriver\MultiDLL\IP_country.app
This application is our Data Manager DLL for the server.
2. Open the Global Properties:
The global properties dialog displays:
IPS File Defined
The IPS file is a helper file generated by the IP Server template. It contains the name of the Data Manager DLL, a list of
all the tables that you have IP-enabled in this particular application, and a list of remote procedures available in the data
manager. The IP Client template reads the IPS file to obtain that list of IP-enabled tables so that you don’t have to
remember them.
The template constructs the name of the IPS file as applicationName.IPS.
3. Press the Make button. Copy the IP_Country.DLL to your data server directory.
4. Copy the country.tps file to your data server directory.
24
IP Driver and Server Reference
5. Run the RMadmin application and register the IP_Country.DLL. Refer to the previous quick start example if you
need help remembering how to register a Data Manager. Don’t forget to grant access permissions to the Guest
account.
6. We’re IP-enabling a multi-DLL app, so our next step is to open \Clarion6\Examples\IPdriver\MultiDLL\DataDLL.app
7. Open the Global Properties and click the Extensions button. You’ll see the following dialog:
Note that the template prompt, Select IPS File has the value IP_Country.IPS. Remember that the IPS helper file was
created when we built our Data Manager DLL.
But now we see there is something else new, the IP Client template informs us that the generated IPC File name is
DataDLL.IPC.
IPC File Defined
The IPC file is another helper file; the IP Client template generates this one. It contains the list of all the tables that you
have IP-enabled in your Data DLL application. The IPC Client template reads the IPS file to obtain that list of IP-enabled
tables, but you are free to override which files are IP-enabled for this application. So the IPC file is generally equivalent
to the IPS (IP server template generated) file. But it can also contain a subset of the files listed in the IPS file.
The template constructs the name of the IPC file as applicationName.IPC.
To review, the IPS file (S is for server) is generated by the IP Server template when you create your Data Manager DLL.
The IPC file (C is for client) is generated by the IP Client Template when your project is set to create a DLL. In other
words, it is created when you build the Data DLL for your multi-dll application. Don’t confuse the Data Manager DLL that
is deployed to the IP data server, with the traditional Data DLL that is deployed with the client application.
8. Press the Make button to build your IP-enabled Data DLL.
9. Open \Clarion6\Examples\IPdriver\MultiDLL\ProcsDLL.app
10. Open the Global Properties and click the Extensions button. You’ll see the following dialog:
IP Driver and Server Reference
25
Make sure that the IPC file is correctly named as shown above.
Are you wondering where the prompts for the Data Manager, Hostname, Port, etc. went? When the IP Client Template
detects that you have your Files defined as “All External” as shown here, the IP Client template only prompts for the IPC
file name.
The template has enough “brains” to know that all of the component DLLs in a multi-DLL application must share the same
Data Manager and server connection information. So the only thing the template needs is the list of tables that your Data
DLL has IP-enabled. The template reads that information from the IPC file.
11. Close the Global Properties dialog, and press the Make button.
12. Open \Clarion6\Examples\IPdriver\MultiDLL\Country.app
If you open the Global properties and check the settings for the IP Client template you’ll see that as expected in a
multi-dll application where all files are external, the IP Client template only prompts for the IPC file.
13. Finally, press the Make and Run button.
That’s all that is needed. You have now created and deployed your second IP-enabled application. The steps you
just went through are the same you’ll do for any application multi-DLL application.
26
IP Driver and Server Reference
Deployment Checklist
To deploy an IP-enabled application, always follow these guidelines:
•
Copy the Data Manager DLL to the IP Data Server folder. Run the RMAdmin application to Register the Data
Manager and grant file access permissions.
During the development phase, you will probably need to test locally on your machine. To expedite this,
create an entry in your Redirection file so that files named as IP_*.dll are created in your data server directory (by
default , \ClarionDataServer).
Example:
[Common]
IP_*.DLL = C:\ClarionDataServer
•
Copy the required data tables to the IP Data Server. For example, if you are testing locally, copy them to
C:\ClarionDataServer.
•
Copy the runtime libraries to the IP Data Server root folder.
Note: during development you can skip this step if your machine has a PATH setting that includes
C:\Clarion6\bin.
Both the server-side Data Manager and the Client application must be able to load the required Clarion
runtime DLLs and IP Driver support DLLs. An example of Clarion runtime files to copy to the server would
be as follows:
C60RUNX.DLL
C60TPSX.DLL (application is using TopSpeed tables)
Client Application:
LIBEAY32.DLL (IP Driver support library)
SSLEAY32.DLL (IP Driver support library)
OSSLWRAP.DLL (IP Driver support library)
NOTE: The following Microsoft system libraries must also be in the system path for both client and server
locations:
MSVCRT.DLL
MFC42.DLL
MSVCP60.DLL
(See the Advanced Deployment Tips and Distribution Guide sections in this manual for additional options)
•
Register the Data Manager DLL: From the menu select Tools->Register Data manager and select the Data
Manager DLL (IP_*.DLL) and then press the register button. Your Data Manager DLL will appear in the righthand panel of the console.
Select the registered data manager in the tree. The right panel will display all available tables.
IP Driver and Server Reference
Right-click on any table and select the Table Permissions… option from the popup menu.
In the Table Permissions dialog, press + and select Guest.
Specify the required access for the guest account. You can repeat this for each individual table, or press the
Apply to all Tables button to cascade these settings to all tables.
This completes the deployment setup! You can now run your Client application to begin testing.
27
28
IP Driver and Server Reference
Server Security Settings
If the client application does not specify a user name and password the connection is treated as anonymous, and the
server automatically assigns the 'Guest' account with an empty password for the session.
In the Administrative Console the "administrator" must assign permissions for the Guest account to the appropriate data
files in the Data Manager DLL (IPFiles.dll)
If the client application specifies a user name and password, the Administrator must specify account permissions for that
user as well.
In summary, the "Administrator" must register the data manager(s) before the client application is started and provide
appropriate permission for accounts to be used by client application. In the case that there is no account (no user name
and password) the Guest account is used.
IP Driver and Server Reference
29
SSL Deployment Considerations
This section discusses the setup of SSL connections used with the IP Driver and Server.
Enabling a SSL connection in your IP Client application is easy! All you need to do is modify the PORT number in the
Connection information setting in the template:
When the IP Data Server is installed the SSL port is set to 2340. To change or verify the SSL port setting, open
\ClarionDataServer\Claipsrv.ini and modify the SSL_PORT entry.
OpenSSL is a cryptography toolkit implementing the Secure Sockets Layer (SSL v2/v3) and Transport Layer Security
(TLS v1) network protocols and related cryptography standards required by them. SSL can protect data in transit on a
live connection, but it cannot protect data before it is sent or after it arrives.
The Openssl.exe program is a command line tool for using the various cryptography functions of OpenSSL's crypto
library. You can obtain the OpenSSL utilities from various Internet download sites.
OpenSSL is available for download in source format from http://www.openssl.org/
There are also pre-built binary versions available for download, one source for a Win32 binary version is the Win32
OpenSSL Installation Project available from: http://www.slproweb.com/products/Win32OpenSSL.html
To make use of SSL with your Clarion IP-enabled application you need to deploy the key pair files. OpenSSL supports
two standard formats for storing and exchanging key pairs. The format used with the IP driver is PEM (Privacy Enhanced
Mail), which is defined in RFCs 1421,1422,1423 and 1424. PEM data is base-64 encoded and provides abilities to
encrypt the data before its encoded.
There are two example PEM files installed in \Clarion6\Examples\IPdriver, server.pem and client.pem. If you want to test
your application using SSL, copy the server.pem file to the root of the IP Data Server, and copy client.pem to the same
location as the IP Client application.
Documentation and further information on OpenSSL is available at:
http://www.openssl.org/related/
In addition, O'Reilly publishes a very good book on OpenSSL: Network Security with OpenSSL, by John Viega, Matt
Messier, and Pravir Chandra. ISBN: 0-596-00270-X
30
IP Driver and Server Reference
LEGAL NOTICE: This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit.
(http://www.openssl.org/). The OpenSSL toolkit is licensed under an Apache-style license, which basically means that
you are free to get and use it for commercial and non-commercial purposes subject to some simple license conditions. For
details of the license please refer to http://www.openssl.org/source/license.html.
Please remember that export/import and/or use of strong cryptography software, providing cryptography hooks or even
just communicating technical details about cryptography software is illegal in some parts of the world. So, when you
import this package to your country, re-distribute it from there or even just email technical suggestions or even source
patches to the author or other people you are strongly advised to pay close attention to any export/import and/or use laws
which apply to you. Neither SoftVelocity nor the authors of OpenSSL are liable for any violations you make here. So be
careful, it is your responsibility.
IP Driver and Server Reference
31
Optional Dictionary Settings
In the design and implementation of an “IP-enabled” application used with the IP Driver, the target dictionary does not
require any modifications. However, by specifying a special User Option setting on selected tables, you can define these
tables that are always to be IP-enabled by default, or never enabled by default.
To accomplish this, from any table add the IPDRV = TRUE setting in the Table Properties’ Options dialog (Boolean
value). The actual File “Driver” setting should remain unchanged (i.e. TopSpeed, Btrieve, etc).
The IPDRV option sets the table as a default IP-enabled table when the IPServer Template is applied. You can always
override this setting from the IP Server global properties if required.
To summarize, this setting is used to notify the IPServer application as to which tables it will include in the generated Data
Manager DLL by default. In the IP Server application’s Global Properties, you can always override this setting as needed.
32
IP Driver and Server Reference
IP Driver Template Support
There are two templates included with the IP Data Server. The Client side application support is located in the IP Client
Global Extension: IPDRV.TPL.
The Server-side application is created using the IP Data Server template: IPSERVER.TPL
IP Driver and Server Reference
33
IP Server Template
The IP Server template is used to create the “Data Manager” DLL. The Data Manager application defines the tables that
are allowed to be accessed by an IP-enabled client application. This template also includes a simple wizard interface that
allows you to quickly generate a new Data Manager DLL as needed. You only need to know the data dictionary, and
include the IPServer Application template in the appropriate prompt in the Application Properties window. The online help
file describes this wizard in detail.
When you generate an Application that has the IPSERVER template applied to it, the IP Server template creates an
associated (ApplicationName.IPS) file. The IPS file is used by the IP Client template to obtain the list of IP-enabled tables
available in the Data Manager application.
The IPS file
The IPS file is a helper file generated by the IP Server template. It contains the name of the Data Manager DLL and a list
of all the tables that you have IP-enabled in this particular application. The IP Client template reads the IPS file to obtain
that list of IP-enabled tables so that you don’t have to remember them.
The template constructs the name of the IPS file as applicationName.IPS.
Under the Global Properties of the application that uses this template, the following prompts are available:
General tab
If you check “Generate Table names using table labels” all of your files will be referenced with their table label, and the
NAME attribute will be ignored.
34
IP Driver and Server Reference
File Control tab
All the files in your data dictionary default to “IP enabled” unless you have used the IPDRV User Option (described in the
Dictionary Preparation section) to turn this option OFF. The File Control tab is used to override the default settings for
individual files.
To change the Default setting for the table, highlight the table and press the Properties button. You can specify Default
(use the dictionary’s setting), or you can override the dictionary setting by choosing Generate or Don’t generate.
The Don’t Export check box is enabled whenever the Generate option is selected. When checked, this option will not
generate this file declaration into the IPS configuration file. Use this option when you only need a dictionary table to be
visible to the Data Manager only. For example, you could have a remote procedure defined in the Data Manager that only
accesses a table defined on the server location. The Client application and the Remote Administartor will not be able to
“see” this table.
IPServer Version
The last tab control displays the version number of the IP Data Server templates.
IP Driver and Server Reference
35
Data Manager DLL Wizard
Although the process of creating a Data Manager DLL using the IP Server Application template is fairly straightforward,
we extend its ease of use with the addition of the Data Manager DLL Wizard.
Starting in the Application Properties dialog settings:
•
•
•
•
Set the server application Dictionary File to use your planned client application's Data Dictionary.
Clear the First Procedure entry field
Select DLL for Destination Type
In the Application Template entry field, press the ellipsis button and choose IPServer from the Select Application
Type dialog:
•
Check the Application Wizard. Press the OK button to begin the Data Manager DLL Wizard.
36
IP Driver and Server Reference
1. This first screen is merely an introduction. Press the Next button to continue.
2. This window allows you to control which files in your dictionary will be deployed to the target server, and
referenced by the Data Manager DLL. If you uncheck the above option, an additional dialog is available
through the Next button. Otherwise, you can click on the Finish button to create the application.
IP Driver and Server Reference
3. After selecting or deselecting the desired files to use, press the Finish button to create the application.
To complete this development phase, press the Make button to create the DLL.
37
38
IP Driver and Server Reference
IPDRV Extended Server Support Extensions
The IPDRV Extended server support global template extensions allow you to add new functions to your IP enabled
application with the help of template support.
These functions are:
•
Calling any Data Manager custom procedure from an IP-enabled Client application.
•
Automating the use of runtime file name variables in your IP-enabled application.
•
Allow any file type to be easily transferred from Client application to IP Data Server in both directions.
•
Support for multiple data sets in different locations can be easily supported.
There are two Global Extensions that are available in this template set. The first is used for the Data Manager application,
and the second is used for the Client application. We will look at the Data Manager application support first.
Examples for each of these techniques are demonstrated and found in your default examples that are included in this
install.
Technical Notes
Note: This template creates two file structures that will be used internally and should not be used or modified.
Both use the DOS file driver. IPSENDRemoteFile is used as the conduit for the IPEXEC method. This file will be created
in the Data Manager root DLL as "IPSEND.IPSEND." The other file is used to send and receive files from the client.
IP Driver and Server Reference
39
IP Server Extension – IPDRV Extended
This template adds some new embeds and functions in the Data Manager application that can be called from the IPenabled client application.
The IPDRV Extended options in the Data Manager application are as follows:
Enable support for Global Variables as file names
This option will automatically enable any file that is using a global variable as the file name to be supported in the
IPSetFileName procedure (see the Server Side Embeds and Procedures topic in this PDF). All other file can also be
supported by enabling them in the Runtime Names option.
If this option is on (checked), any file using a variable in the dictionary’s File name prompt will not appear in the Runtime
Names list box.
Enable secure file name(s) support
If this option is on (checked) any file name sent by the client application via the IPSetFileName procedure will be
automatically translated to be in the same directory of the Data Manager DLL location. For example, C:\people
example\people.tps will be translated to .\people example\people.tps in the Data Server root.
If the extra directory does not exist on the server, it will be automatically created.
With this option you can be sure that the user will never have access to a file that is restricted. The file name translation is
performed by the GetSafeName procedure. This procedure also supports TopSpeed super files.
Enable Debug using TRACE
Enable this option to include the TRACE prototype in your Data manager application for its use with the DebugView utility.
For more information, see the DebugView Support topic in this PDF.
40
IP Driver and Server Reference
IP Server Extension – Runtime Names
The Runtime Names tab control contains a list box of all tables used in the Data Manager application that does not have
a variable name defined in the dictionary table’s file name prompt (i.e.,!GLO:Peoplename):
Allow runtime Filename change
If a selected file does not use a variable in the File Name option in the data dictionary, you can still enable the file name to
be changed by enabling this option. For example, you use PROP:Name at runtime instead of a global variable.
Use different name for each thread
If your application requires a different filename each time a new thread is launched, check this option. You must make
sure that you set the file name on each thread prior to the file open.
IP Server Extension – Server Variables
If there is any defined variables in your IP Server application that need to be “visible” (or exported) to your IP Client
application or other DLLs, include them here. These variables will also be included automatically in the generated IPS file,
used to identify these Remote Variables in the IP Client application.
The description of the IPDRV Extended Options for the Client application is discussed just following the IP Client
Template section.
IP Driver and Server Reference
41
IPEXEC Source Procedure Template
Overview
The use of the IPEXEC Source Procedure Template in your Data Manager application provides an easy way to execute a
remote procedure. The procedure defined here will be called from the Client application with the use of the EXEC method.
The Client application calls the EXEC method from the IPExtender class as follows:
IPx.Exec('ProcedureName',Par1,Par2,[,..,Par20])
Up to 20 parameters are supported, and an optional return value is also available.
On the server side (in the Data Manager application) IPEXECDispatch handles any information received by the Client’s
EXEC method. It will parse the incoming string, check for the procedure, and call it with the appropriate parameters.
A remote procedure should always be created with the Procedure Template IPEXEC Source Procedure for the
IPEXECDispatch to be automatically called.
The source procedure template is nearly identical to a standard source procedure template ,but contains a single
additional option:
Enable Parameters Debug
As discussed in the DEBUGVIEW support section, the use of the built-in TRACE procedure is available to send
information to the DEBUGVIEW utility. This option simply enables the parameters passed to this procedure to be applied
to an embedded TRACE statement.
42
IP Driver and Server Reference
IP Client Template
The IP Client Global Extension template is used to make the client application IP-enabled. The prompts presented by the
template changes based on the application’s setting for the Global Properties->File Control->File Attributes->External
If the client application has its Files declared as “All External”,
The template dialog prompts for the name of the IPC file:
The IPC file is created by the template when you generate your traditional “Data DLL”. In other words the IPC file is
created whenever an application using the IP Client template has its target type set to DLL.
The IPC File
The IPC file is another helper file; this one is generated by the IP Client template. It contains the list of all the tables that
you have IP-enabled in your Data DLL application. The IPC Client template reads the IPS file to obtain that list of IPenabled tables, but you are free to override which files are IP-enabled for this application. So the IPC file is generally
equivalent to the IPS (IP server template generated) file. But it can contain a subset of the files listed in the IPS file.
The template constructs the name of the IPC file as applicationName.IPC
IP Driver and Server Reference
43
If the client application has its Files declared as “None External”, the IP Client template presents these prompts:
Select IPS File
Type in the name of the IPS file, or press the ellipsis button to select it.
Note: The IPS file was created when you built the “Data Manager” DLL using the IP Server template and lists all the FILEs
that are “IP Enabled”.
After the IPS file is selected, a list of IP-enabled tables will be available in the Tables dialog listbox.
Connection Type
The IP Client application needs to know the connection information to reach the IP Data Server. There are three options in
the dropdown list for the ways that connection information can be specified; Fix, Variable and Handcoded.
44
IP Driver and Server Reference
Fix
Use the Fix option when you know the IP address or Hostname of the data server before deploying the client application.
Data Manager
Enter the name of the “Data Manager” DLL that this client application will use. The full name of the DLL (including
the extension) is required (i.e., IP_FILES.DLL). In addition, if your Data Manager is stored in a sub folder of the
data server’s target folder, specify the sub folder here ((i.e., school\IP_School.DLL)
Host Name
Enter the name of the server here. This can be a hard coded IP address (i.e., 192.168.0.0), or a domain name
that resolves to the appropriate IP address (dataserver.MYdomain.com).
Note: If you are developing and testing on the same machine you can use the value localhost for the Host Name.
Port
Enter the port number the data server is running on. By default the install program specifies that the IP Data
Server uses port 2339 for non-SSL connections, and 2340 for connections using SSL protocol. The ports used by
the server are specified in the INI file: Claipsrv.ini located in the root directory of the IP data server.
Typical contents of Claipsrv.ini:
[REQUESTER]
PORT=2339
PORT_SSL=2340
To change the ports the data server uses, go to your system Services program and stop the SoftVelocity IP Data
Server service, then edit the port numbers and restart the service.
User Name and Password
If you leave these entry fields blank, the Client application will attach anonymously, and will be granted the
privileges associated with the “Guest” account.
Access to the IP Data Server can be controlled by specifying permissions for the Guest account and by creating
additional User Accounts on the data server and specifying User Name and Password in the connection
information template prompts.
The Remote Administrator application is used to create User accounts and set file access permissions.
The information specified in the Connection Information entry fields is used to construct the OWNER attribute
for all IP-enabled files in the application.
IP Driver and Server Reference
45
Variable
The connection type can also be specified as “Variable”.
The form of the connection information is as follows:
DataManagerDLL@HostName:Port[:UserName:password]
Examples:
IPFILES.DLL@192.168.0.0:2339
IPFILES.DLL@mydomain.com:2340:superuser:mypassword
Variable Name
Enter the name of the variable that will contain the connection information. This variable should be a string data
type, like a STRING or CSTRING and must be defined as a Global data.
The variable used to store the connection information must be initialized in any embed point prior to the assignment of the
internally defined IPDRV::OWNER variable. You can also store the connection information in any preserved variable
stored in your program’s INI file.
Handcoded
The handcoded option for Connection Information allows you to enter a connection information string manually.
Connection String
Enter a complete connection string using the following format:
DataManager@HostName:Port[:UserName:password]
From List
The From List option for Connection Information allows you to enter a series of different fixed connection strings that you
can select and use at different times in the development cycle.
The most common use of this option will be to easily switch from a development server to a production server connection.
Press the Insert button to add a new connection. The standard connection information is exactly the same as the prompts
described in the Fix option discussed previously, with the exception of the Name prompt, which allows you to easily
identify the type of connection from the list (i.e., My Test Connection, Production Connection, Alternate Server
Connection, etc.).
46
IP Driver and Server Reference
Tables Tab
The Tables tab contains a list of all tables that have been “IP-enabled” in the Data Manager application. The tables listed
here are read in from the *.IPS file that you selected earlier.
You can override the settings in the IPS file. Any table selected in the list box will not be enabled for IP access in this
application but will be generated as a regular local physical file to the application.
IP Driver and Server Reference
47
Extended Server Support Extensions – Client
Extended support for a variety of special method calls used by the Client application is provided through the IPDRV
Global Extension. This template is only required if you are taking advantage of one of the following IP Driver features:
•
You want the template to automatically derive the appropriate IPX object from the IPExtender Class. This class is
documented in the IPDriver Class Library Reference topic in this PDF.
•
Use of the IPX.IPEXEC method to call a procedure in the target Data Manager. This method is documented in
detail in the IPDriver Class Library Reference topic in this PDF.
•
Use of the IPX.SetFileName method to change a file name located on the Data Server. This method is
documented in detail in the IPDriver Class Library Reference topic in this PDF.
•
You want the template to automatically derive the appropriate IPFileTransfer object from the IPTransfer Class.
This class is also documented in the IPDriver Class Library Reference topic in this PDF.
A series of code templates are provided by the IPDriver template to allow the syntactically correct execution of these
methods.
IP Client Extension – General
The General tab provides a brief description of the template’s functions (which were described in the section above), and
one important new template option (as of Version 1.3):
Keep Connection Alive
As of version 1.3, when all FILEs are CLOSEd in your Client application, the connection to the IP Server is also closed.
The next OPEN will start a new connection. This is a change from previous versions, where the connection would remain
opened even after all files were closed, and only terminated when the client program was shut down. To maintain the
same behavior as in prior versions, check this box to allow a persistent connection to the IP Server for the life of the Client
program.
IP Client Extension – Imported Procedures
The Imported Procedures tab control identifies remote procedures that exist in the target Data Manager. The procedures
listed here are READ ONLY, and loaded from the generated IPS file that contains the available procedures.
These procedures are intended to by called by the IPExtender class IPEXEC method. A code template is available to
allow you to easily prototype and execute this method.
48
IP Driver and Server Reference
IP Client Extension – Remote Variables
Remote Variables are defined as those variables that are exported by the IP Server Data DLL, and are available to be
referenced by the Client application. The IPS file loaded by the Client application contains the definition of these variables.
You have the ability to add new remote variables. These are usually hand-coded variables that were not automatically
exported by the Data Manager DLL. You can also remove selected remote variables. This is useful when different IP
Client applications share a single Data Manager, and not all variables need to be exposed in all Client applications.
IP Driver and Server Reference
49
IPDriver Code Templates – Client Application
When you include the Extended Server Support Extension for your IP-enabled client application, the following support
code templates are also available:
IPChangeFileName Code Template
The IPChangeFileName code template is used to modify the table name at runtime, prior to opening the file. With this
implementation, a user can have a secure and distinct data set to use with his application.
Connection String
Press this button if you wish to modify the default connection to the Data Server. Use this option if you have different data
sets in different Data Managers contained within the same application.
File
Select the file name to change from the drop list provided. The files listed here are those that you have IP enabled in your
application.
New Name
Enter a new name in the prompt provided. If the New Name is a variable or an expression, prepend the line with an
exclamation point.
50
IP Driver and Server Reference
IPEXEC Code Template
The IPEXEC Code template is used to call a remote procedure that is contained within the Data Manager. This procedure
should be created using the IPEXEC Source Procedure template.
Connection String
Press this button if you wish to modify the default connection to the Data Server. Use this option if you have different data
sets in different Data Managers contained within the same application.
Procedure
Select a procedure name from the drop list provided. The procedure names that are listed here are stored in the IPS file
that you selected in the Global Properties of the IP Client extension.
Parameter 1 … Parameter 20
Enter up to 20 parameters using values extracted from the ellipsis buttons for each, or by simply entering a value.
NOTE: Variable parameter must be designated with a prepended exclamation point. If you do not use an
exclamation point, the parameter will be translated to a string constant.
Return Value
You can also enter a variable name to hold the value returned by the remote procedure.
IP Driver and Server Reference
51
IPTransferFileCode Code Template
The IPTransferFileCode Code Template is used to send and receive files between the Client application and Data
Manager via IP protocol. The prompts are simple and intuitive, and there is no restriction as to the type of file that you
need to transfer. This template can be used in any code embed point in your application, like the Accepted event of a
button.
Connection String
Press this button if you wish to modify the default connection to the Data Server. Use this option if you have different data
sets in different Data Managers contained within the same application.
Send or Receive
From the drop list, select SEND or RECEIVE to specify the direction of file transfer to the Data Server. SEND a file to the
Data Server, or receive a file from the Data Server.
Source Name
The Source Name is always the source of the transfer. If you specify SEND, the source name is a file that is located at
the Client application. If you specify RECEIVE, the source name is a file that is located at the data server.
Target Name
The Target Name always specifies the destination of the transfer. If you specify SEND, the target name is a file that is
located at the data server. If you specify RECEIVE, the target name is the file that is located at the client application.
52
IP Driver and Server Reference
IPIsAlive Code Template
The IpIsAlive Code Template is used to detect if an IP Connection is still alive (i.e. active). If the connection is not active,
this template provides additional actions to perform. This code template is only available if you have the IP Client
Extended template active in your application. In any application that does not use a persistent IP Server connection, this
template is not needed because by default when all files are closed, the connection is closed, and only reopened when
the first file is again reopened.
The following actions are available:
Connection String
Press this button if you wish to modify the default connection to the Data Server. Use this option if you have different data
sets in different Data Managers contained within the same application. Use the default Global Connection String, or set a
new string from a Fixed (template guided) value, Variable value, or a Hand Coded connection string.
Action:
Store Alive Value
Use this option to select a variable that holds the value returned by the IPExtender Class IsAlive method. Simply stated,
you can name a variable here that holds the status of the active IP Server connection, and execute additional code based
on that condition. This action is always generated, whether the IP Connection is active or not.
If an IP connection is not available, you can alternatively:
Reconnect
This option attempts a reconnection to the IPServer based on the Connection String settings.
Execute Routine
Enter the name (or label) of a defined ROUTINE. If an IP Server Connection is NOT active, this ROUTINE will be
executed.
Execute Code
Enter valid source code that will be executed if an IP Server Connection is NOT active. For multiple lines of code, use a
semicolon to separate source lines. For example:
DISABLE(?tbAccounts);MESSAGE('The server time out|Select a new Ledger year to continue.','Attention')
Call a Procedure
Finally, if an IP connection has become inactive, you can execute a procedure.
IP Driver and Server Reference
53
IPKeepAlive Code Template
The IPKeepAlive Code Template is used to maintain a persistent connection to the IP Server Data Manager. This
template is only available if you have the IP Client Extended template active in your application.
This template is handy if a user needs to keep open a browse that could possibly timeout, where any action on that
browse could return an error. The solution is to add this code template to a timer event embed on that procedure or on the
parent frame.
The difference between the IPKeepAlive and IPIsAlive code templates is that the IpKeepAlive always tries to establish a
connection, whether a connection is active or not. The logic for controlling this is handled by the support IpExtenderClass
methods.
54
IP Driver and Server Reference
IPSetRemoteVariable Code Template
The IPSetRemoteVariable code template is designed to allow you to set the value of any Remote Variable defined in the
target server Data Manager DLL. Here is the process of setting up a remote variable:
1. Define the variable in the Data Manager DLL, and using the Global IP Server Extension, select the appropriate
variable for export. (For more information see the IP Server Extension – Server Variables section in this
document.) This variable will be generated in the template IPS file used by the IP Client application.
2. Verify that the target Remote Variable is available via the Extended Server Support Extensions – Client (note, this
extension is not required to use this template, it simply shows you an easy way to view all Remote Variables
defined via the template interface).
3. Select the Remote Variable to set in the Variable drop list provided. In the Value prompt, add a constant or
variable value. If specifying a value, make sure to prepend the variable name with an exclamation point
(i.e., !MyVariable)
IPGetRemoteVariable Code Template
The IPGetRemoteVariable code template is designed to allow you to get (or retrieve) the value of any Remote Variable
defined in the target server Data Manager DLL. The same rules apply as in the IPSetRemoteVariable code template
described above. The Remote Variable must be exported and visible to the IP Client application.
Select the Remote Variable to get in the Variable drop list provided. In the ReturnValue prompt, select a variable that will
receive the value of the selected Remote Variable. Check the Refresh window after getting the value check box to
force a window refresh after the value has been retrieved (this is useful for instantly displaying the result).
IP Driver and Server Reference
55
IPTransferFile Control Template – Client Application
The IPTransferFile Control Template is used to send and receive files between the Client application and Data Manager
via IP protocol. The prompts are simple and intuitive, and there is no restriction as to the type of file that you need to
transfer. This template can be used in any window in your application. It populates a Transfer button, which starts the
transfer process, a progress control to keep track of the transfer progress, and a cancel button to abort the transfer if
needed.
Connection String
Press this button if you wish to modify the default connection to the Data Server. Use this option if you have different data
sets in different Data Managers contained within the same application.
Pause Text
Enter a string that will be used on the Transfer button control while the transfer process is active. The default value is
“Pause”
Window Timer
This number is a value assigned to the TIMER attribute of the window. It allows you to control how “process intensive” the
file transfer will be. Enter a low value if you need little or no control of the window during transfer, or a higher value
otherwise.
Send or Receive
From the drop list, select SEND or RECEIVE to specify the direction of file transfer to the Data Server. SEND a file to the
Data Server, or RECEIVE a file from the Data Server.
Source Name
The Source Name is always the source of the transfer. If you specify SEND, the source name is a file that is located at
the Client application. If you specify RECEIVE, the source name is a file that is located at the data server.
Target Name
The Target Name always specifies the destination of the transfer. If you specify SEND, the target name is a file that is
located at the data server. If you specify RECEIVE, the target name is the file that is located at the client application.
56
IP Driver and Server Reference
Extended Server Support Extensions Examples
Your install in this version includes two example applications that demonstrate the raw power and ease of use of the
Extended Server templates. These examples can be found in the Examples\IP Driver folder located in your Clarion root.
File Transfer
This folder contains two applications; the IP_Transfer application is used to create the data manager, and the
Transfer_Example application is the IP-enabled Client application.
Start by making the Data Manager (IP_Transfer.APP). Deploy it to your IP Data Server location and register the Data
Manager (IP_Transfer). You should notice two files that are created internally by the templates. These files will handle the
housekeeping of your file transfers. Also, examine the application and you will notice that there are two remote
procedures defined, and both are using the IPEXEC Source Procedure template.
Next, compile and run the Transfer_Example application. This application demonstrates two powerful functions, calling a
remote procedure and performing a file send/receive to/from the server.
Note that during a SEND, the target file designates the name and destination of the file uploaded to the server. If your
target string is “C:\Upload\Myfile.txt”, the location of the transferred file will be in a folder named “\Upload” in your Ip Data
Server location, and the file contained in that folder will be “MyFile.TXT”.
Study all embeds and template prompts in this example, and refer to the template help when necessary.
Multidataset
This folder contains two applications; the IP_Ledger application is used to create the data manager, and the Ledger
application is the IP enabled Client application.
Start by making the Data Manager (IP_Ledger.APP). Create a folder named LEDGER on your IP Data Server location,
deploy the IP_Ledger.DLL to the new LEDGER folder and register the Data Manager (IP_Ledger).
Next, compile and run the Ledger application. When you select a Year, the program will create a folder in the Server
Ledger that names the year you selected (Example: \2003). For each year that you select, a separate folder will be
created with a unique data set!
Examine the Ledger application again, and you will notice the use of the new Change Filename template, which
concatenates a valid year to the default file names used in the application.
IP Driver and Server Reference
57
Server-side Embeds and Procedures
The IP Server template embeds
The code that you embed in your Data Manager DLL executes on the server, so it is critical that you do not embed code
that displays a user interface and requires user intervention to continue. This includes the use of the MESSAGE()
and STOP() functions. You should never use HALT(), as this prevents the server from properly closing the session.
The IP Server template provides some new embed points to take advantage of procedures that execute on the data
server.
58
IP Driver and Server Reference
GetFName (change the name of the data file or path)
GetFName() is called for each file used by the client application, and is intended to allow the user to change the name of
the file at runtime. It receives the original strSrcName name and returns the new name set by pstrNewName. This is the
best and recommended place where changes in any IP enabled filename should be performed.
If the function returns TRUE, the name will be changed, if it returns FALSE (the default) the new name designated by the
pstrNewName parameter is ignored. You need to set the ReturnValue to TRUE for the filename change to be activated.
Implementation: Access to the GetFName procedure is available in the IPServer application’s Change FileName Data
and Code embed points.
GetFName(strSrcName, pstrNewName),LONG
strSrcName
A string constant or variable that identifies the original file name to change.
pstrNewName A reference to the new file name to process.
Examples:
!code in BLUE is embedded code
GetFName
PROCEDURE(STRING strSrcName, *STRING pstrNewName)
ReturnValue
LONG
CODE
!Change FileName - strip out hard coded path
IF LEFT(strSrcName,3) = 'C:\'
pstrNewName = '.' & SUB(strSrcName,3,LEN(CLIP(strSrcName)))
ReturnValue = TRUE
! change filename
END
RETURN ReturnValue
*********************
!here is an example of changing the path of the data files at runtime
!Code in
LOC:Path
LOC:Dir
LOC:File
LOC:Ext
DATA Embed
CSTRING(FILE:MaxFileName+1)
CSTRING(FILE:MaxFileName+1)
CSTRING(FILE:MaxFileName+1)
CSTRING(FILE:MaxFileName+1)
!Code in the CODE embed
LOC:Path = strSrcName
!call internal PathSplit function to extract components
PathSplit(LOC:Path,, LOC:Dir, LOC:File, LOC:Ext)
!assign new path passed to GLO:DataDir via remote procedure
pstrNewName = GLO:DataDir & '\' & LOC:File & LOC:Ext
!debug just in case
TRACE(pstrNewName)
!use internal GetSafeName function to create folder if it does not already exist
pstrNewName = GetSafeName(pstrNewName)
!Finally, force a return value of TRUE to activate new path change
RETURN TRUE
IP Driver and Server Reference
59
Program Setup access
Although there is no specific server procedure associated with this embed point, this area allows access to any setup
option that you need to execute (i.e. – data path setup):
!embed code to read from INI file.
DATAPATH = GETINI('Locations','DataPath','','.\People.ini')
IF DATAPATH <> ''
SETPATH(DATAPATH)
ELSE
PUTINI('Locations','DataPath','','.\People.ini')
END
BeforeOpen (called prior to the server opening the file)
BeforeOpen is called when the client application executes an OPEN command just before the server opens the file. If
BeforeOpen returns FALSE the target file is not opened.
Return Value: LONG
Implementation: Access to the BeforeOpen procedure is available in the IPServer application’s Before Open File Data
and Code embed points.
BeforeOpen( RemoteFile, sDrvString),LONG
RemoteFile
The label of a FILE structure included in the Data Manager DLL.
sDrvString
A string passed to the server side BeforeOpen procedure
Example:
BeforeOpen
PROCEDURE(FILE RemoteFile,STRING sDrvString)
ReturnValue
LONG
CODE
!Before Opening File
IF RemoteFile{Prop:Name} = ‘MyFile’
! do some work here
END
RETURN ReturnValue
60
IP Driver and Server Reference
Calling the Server-side Remote Procedure
The IP Driver provides support for executing code contained in your Data Manager DLL on the server. You accomplish
this using the SEND command in your IP Client application with the message parameter containing the string “IPEXEC ”.
The return value of the SEND command can be used to retrieve specific information from the Server DLL.
SEND Syntax to invoke the RemoteExecute() procedure
returnvalue = SEND(file,'IPEXEC stringValue')
file
the name of a file that is defined in the IPServer Data Manager DLL, which is used by the RemoteExecute
procedure
stringValue
a string value to be used in the RemoteExecute procedure.
When the SEND command is processed on the server the first 7 characters of the message parameter are checked, and
if the string “IPEXEC “ is found (including the space character) the RemoteExecute() procedure is called.
RemoteExecute() is passed a reference to the FILE and the stringValue beginning at position 8. The “IPEXEC “ is
stripped from the stringValue before its passed to the RemoteExecute() procedure.
NOTE: The SEND command for the IP Driver MUST be called AFTER THE TABLE IS OPENED, and not before.
The RemoteExecute() procedure allows the developer to execute code on the server and return a string value
(returnvalue variable) back to the client application.
IP Driver and Server Reference
61
RemoteExecute(RemoteFile, RemoteCommand)
RemoteFile a reference to the FILE parameter of the SEND command
RemoteCommand
process.
A STRING constant or variable passed to the procedure used as a condition or parameter to
Return Value: STRING (2048)
RemoteExecute receives the message parameter from the SEND command with the “IPEXEC “ string removed, and the
remaining string contents clipped and left justified.
The code you embed in the RemoteExecute procedure receives a reference to the FILE and the passed
RemoteCommand value.
To return a value to the client, the developer must set the value of the ReturnValue variable declared in the
RemoteExecute procedure.
Implementation: Access to the RemoteExecute procedure is available in the IPServer application’s Remote Execute
Procedure Data and Code embed points.
Example:
!Client sends the date to the server to determine if the data file needs
! to be backed up
SEND(MyImportantFile, ‘IPEXEC ’ & GLO:LoginDate)
62
IP Driver and Server Reference
IPDRV Extended Server Embeds
If you are using the IRDRV Extended Server Global Extension to perform file transfers, remote procedure calls, or runtime
filename changes, there are three new embed points that are added to the Data Manager application:
IPEXEC Dispatch Procedure
The IPEXEC Dispatch procedure is used by the Data Manager application to parse an incoming RemoteString sent by the
Client application and searching for the function name and the parameters and then call the correct IPEXEC Procedure.
After parsing, it looks for a valid procedure to execute. These procedures are those that are built in to the extended server
templates, or those that you have registered as remote procedures. If you are hand coding a remote call from the client,
you can use this embed point to launch the appropriate procedure.
Example:
IF lParTotal
TRACE('IPEXECDispatch Total Param:'&lParTotal&'|
Param1='&UPPER(UNQUOTE(sMsg[(lParStart[1]):(lParEnd[1])])))
CASE UPPER(UNQUOTE(sMsg[(lParStart[1]):(lParEnd[1])]))
OF 'IPGETRMT'
RETURN CLIP(GLO_FileName:IPRemoteFile)
OF 'IPGETNAME'
RETURN CLIP(IPGetFileName(UNQUOTE(sMsg[(lParStart[2]):(lParEnd[2])])))
OF 'IPCHNAME' !Built-in procedure
IPSetFileName(UNQUOTE(sMsg[(lParStart[2]):(lParEnd[2])]),UNQUOTE(sMsg[(lParStart[3]):(lParEnd[3])]))
OF 'SAYHELLO' !Custom Remote Procedure
RETURN SayHello(UNQUOTE(sMsg[(lParStart[2]):(lParEnd[2])]),|
UNQUOTE(sMsg[(lParStart[3]):(lParEnd[3])]),|
UNQUOTE(sMsg[(lParStart[4]):(lParEnd[4])]),|
UNQUOTE(sMsg[(lParStart[5]):(lParEnd[5])]),|
UNQUOTE(sMsg[(lParStart[6]):(lParEnd[6])]),|
UNQUOTE(sMsg[(lParStart[7]):(lParEnd[7])]),|
UNQUOTE(sMsg[(lParStart[8]):(lParEnd[8])]),|
UNQUOTE(sMsg[(lParStart[9]):(lParEnd[9])]),|
UNQUOTE(sMsg[(lParStart[10]):(lParEnd[10])]),|
UNQUOTE(sMsg[(lParStart[11]):(lParEnd[11])]),|
UNQUOTE(sMsg[(lParStart[12]):(lParEnd[12])]),|
UNQUOTE(sMsg[(lParStart[13]):(lParEnd[13])]),|
UNQUOTE(sMsg[(lParStart[14]):(lParEnd[14])]),|
UNQUOTE(sMsg[(lParStart[15]):(lParEnd[15])]),|
UNQUOTE(sMsg[(lParStart[16]):(lParEnd[16])]),|
UNQUOTE(sMsg[(lParStart[17]):(lParEnd[17])]),|
UNQUOTE(sMsg[(lParStart[18]):(lParEnd[18])]),|
UNQUOTE(sMsg[(lParStart[19]):(lParEnd[19])]),|
UNQUOTE(sMsg[(lParStart[19]):(lParEnd[20])]),|
UNQUOTE(sMsg[(lParStart[20]):(lParEnd[21])]))
ELSE
!Call your custom procedure here
END
IP Driver and Server Reference
63
IPSetFilename Procedure
The IPSetFileName Procedure is called any time the Client application sends a Change FileName request to the server.
In the appropriate embed point of the client application, you can issue a SEND command from the Client and control your
target file name here.
Example:
IPSetFileName PROCEDURE(STRING FileLabel,STRING RemoteFileName)
CODE
TRACE('IPSetFileName FileLabel='&FileLabel&' RemoteFileName='&RemoteFileName)
CASE UPPER(FileLabel)
OF 'IPREMOTEFILE'
GLO_FileName:IPRemoteFile = GetSafeName(RemoteFileName)
ELSE
TRACE('IPSetFileName Unknown FileLabel='&FileLabel)
!Set a filename here – this is the embed point
END
IPGetFilename Procedure
The IPGetFileName Procedure is called any time the Client application sends a Get FileName request to the server. In the
appropriate embed point of the client application you can issue a SEND command from the Client and extract and process
your target file name here.
Example:
IPGetFileName PROCEDURE(STRING FileLabel)
CODE
TRACE('IPGetFileName FileLabel='&FileLabel)
CASE UPPER(FileLabel)
OF 'IPREMOTEFILE'
RETURN GLO_FileName:IPRemoteFile
ELSE
TRACE('IPGetFileName Unknown FileLabel='&FileLabel)
!Get a filename here – this is the embed point
END
64
IP Driver and Server Reference
Client-side Embeds and Procedures
If you have applied the IPDRV Extended Server Support extension template to your IP-enabled Client application, a
number of embeds are at your disposal to give you added control to a number of special actions:
File Transfer Embed Points
If you have added a file transfer template to a target window, the following embed points are available:
Each embed point allows you to add additional messaging or processing during a particular transfer action. Each action is
summarized briefly below. See the IPDriver Class Library Reference section in this PDF for more information.
Aborted
Indicates that an error occurred that halted the transfer process
Cancel
Indicates that the program user has halted the transfer process
Finish
Indicates that the transfer process was completed successfully
Pause
Indicates that the user has stopped the transfer temporarily.
Start
Begins the actual transfer process
StartTimer
Sets the TIMER attribute of the target window.
StopTimer
Clear the TIMER attribute of the target window
SwapPauseText
Performs the logic of swapping the text of the transfer control button when a pause action is detected.
IP Driver and Server Reference
65
Advanced Server Support
This section documents two important server side features of the IP Driver. These features are design to streamline and
enhance the speed and power of your IP Client applications.
Multiple Request Packet (MRP) support for ADD, APPEND, NEXT and PREVIOUS
statements
An IP packet is a chunk of data transferred over the Internet using standard Internet protocol (IP). Each packet begins
with a header containing addressing and system control information. IP packets vary in length depending on the data
being transmitted.
Version 2 of the IP Driver now has the ability to create Multiple Request Packets (MRP), defined as a single IP packet that
contains multiple requests for information. Version 2 of the IP Server now has the ability to process MRPs containing
multiple requests from the IP Client application.
The use of MRPs is designed for the acceleration of Browse procedures with LIST controls, by allowing them to be filled
using only one IP packet from the Server. Other possible uses could be with the Clarion In-Memory Database Driver (and
other drivers) to quickly add/append blocks of data (records) back to the server. The use and support of MRPs are built in
to all template based Browse procedures.
There is only one important rule to this usage of MRPs:
Any given MRP can only contain a single type of I/O statement.
In other words, you cannot mix NEXT, PREVIOUS, ADD or APPEND into one MRP. An MRP can only have a specific
number of I/O requests using only one of these statements per packet.
MRP Property:
The following property is used in the implementation of MRPs
IPRequestCount
entity{PROP:IPRequestCount} = number
entity
the label of a FILE or VIEW
number
the number of requests to be sent to the server in a single MRP. The maximum value is 1,000,000.
IPRequestCount is a read/write property that sets the number of requests to be sent to the server in a single MRP. The
server will then execute the specified number of statements, and return the results in an MRP packet to the client. If this
property is set to –1, the current packet is immediately sent. If this property is set to zero, the current packet is reset, and
nothing is sent to the server.
This property can also be used to determine how many records were actually read.
Example:
entity{PROP:IPRequestCount} = 20
NEXT(entity)
nRecNum = entity{PROP:IPRequestCount}
! create packet with 20 requests
! send packet to server with 20 NEXTs
! get number of records in MRP packet
66
IP Driver and Server Reference
The nRecNum value holds how many records were actually read from the database. We can use the nRecNum value
later to extract the information like this:
LOOP nRecNum TIMES
NEXT(entity)
! get cached record from received packet
IF ERRORCODE() <> 0
BREAK.
END
! add new record to list-box in Browse dialog
END
IPRequestCount should be used for each packet explicitly. Therefore if the user wants to send two MRP packets, then
the code will look like:
entity{PROP:IPRequestCount} = 20
NEXT(entity)
!handle MRP packet
…
entity{PROP:IPRequestCount} = 20
NEXT(entity)
!handle MRP packet
! create packet with 20 requests
! send packet to server with 20 NEXTs
! create packet with 20 requests
! send packet to server with 20 NEXTs
Finally, when an IP-enabled table contains MEMOs or BLOBs, you can improve the speed of the loading of browses and
reduce network traffic with the use of the NOMEMO statement.
The NOMEMO statement arms "memoless" record retrieval for the next GET, REGET, NEXT, or PREVIOUS statement
encountered. The following GET, REGET, NEXT, or PREVIOUS gets the record but does not get any associated MEMO
or BLOB field(s) for the record. Generally, this speeds up access to the record when the contents of the MEMO or BLOB
field(s) are not needed by the procedure.
Example:
CODE
...
NOMEMO(file)
file{PROP:IPRequestCount} = 1000
NEXT(file)
...
IP Driver and Server Reference
67
FAQs
How does the driver know when to request a new packet instead of reading from an already received packet?
When the IP Driver receives a packet from server, it initializes an internal counter with the number of records in the
packet. Each time the user issues a NEXT/PREVIOUS statement, the IP Driver checks the counter for 0, and
automatically determines whether to get the record from the received MRP packet, or decides it is time to send a new
request to the server.
If the packet received from the server contains less records than what was requested using IPRequestCount, then the
error code will be returned on the following NEXT/PREVIOUS, after the last record is read from the packet.
For example:
LOOP 20 TIMES
NEXT(entity)
! after 8 records, 9th NEXT sets error code
IF ERRORCODE() <> 0
BREAK
END
! add new record to list-box in Browse dialog
END
What if user receives a packet with 20 records from server, but did not issue 20 NEXT statements?
Data may be lost in this case. For example, let’s assume that after 5 NEXT statements, a BUILD statement is issued. In
this case, the IP Driver will free the last MRP packet and send a new request to the server with the BUILD statement. This
means that after the BUILD is issued, the user will not be able to read the other 15 records.
Error Handling
There are two methods that you can take to check for errors contained within an MRP packet. In the first method, check
immediately to see if the number of records in the packet matches the request, and if it does not, get the error right away.
The second method is to write your code as if you are not using an MRP. Here are two examples:
Method 1:
! check for any error immediately
entity{PROP:IPRequestCount} = 20
NEXT(entity)
nRecNum = entity{PROP:IPRequestCount}
IF nRecNum < 20
nError = ERRORCODE()
END
LOOP nRecNum TIMES
NEXT(entity)
END
! test if error
IF nError <> 0
! handle error
END
! create packet with 20 requests
! send packet to server
! get number of records
! save error code for later use
! get cached record from received packet
Method 2:
! check error as usual
entity{PROP:IPRequestCount} = 20 ! create packet with 20 requests
NEXT(entity)
! send packet to server
LOOP 20 TIMES
NEXT(entity)
! after 8 records, 9th NEXT sets error code
IF ERRORCODE() <> 0
BREAK
END
! add new record to list-box in Browse dialog
END
You can use whatever is more appropriate in a given situation.
68
IP Driver and Server Reference
MRP Conceptual Examples
The following section demonstrates a number of techniques when using MRPs. The support of MRPs are built in to all
template based browse procedures, but there may be occasions when you need to customize the handling of MRPs.
Example 1: How to create a packet with multiple ADD requests.
! prepare packet with 10 requests
entity{PROP:IPRequestCount} = 10
LOOP 10 TIMES
! fill new record
…
ADD(entity) ! cache request in IP Driver, or
! send packet to server on 10th request
END
IF ERRORCODE()
! get number of requests actually sent to server
nSentRequests = entity{PROP:IPRequestCount}
! handle error
…
END
Example 2. How to send a packet immediately.
! step 1, prepare packet with 1000 requests
entity{PROP:IPRequestCount} = 1000
! add 7 records
LOOP 7 TIMES
! fill new record
…
ADD(entity) ! cache request in IP Driver
END
! step 2, send the current packet to server right now
entity{PROP:IPRequestCount} = -1
IF ERRORCODE()
! get number of actually sent requests to server
nSentRequests = entity{PROP:IPRequestCount}
! handle error
…
END
Example 3. How to create a packet with an unknown number of requests.
! step 1, prepare packet with unknown number of requests
entity{PROP:IPRequestCount} = 1000000
! MAX allowed number is 1,000,000,000
LOOP 1000000 TIMES
! obtain data from some source
IF ObtainDataFromOtherSource( ) <> 0
BREAK
END
! fill new record
…
APPEND(entity)
! cache request in IP Driver
END
! step 2, send packet to server right now
entity{PROP:IPRequestCount} = -1
IF ERRORCODE()
! get number of actually sent requests to server
nSentRequests = entity{PROP:IPRequestCount}
! handle error
…
END
IP Driver and Server Reference
69
Example 4. How to kill the current packet.
a) Using property syntax:
! step 1, prepare packet with 1000 requests
entity{PROP:IPRequestCount} = 1000
! add 7 records
LOOP 7 TIMES
! fill new record
…
ADD(entity) ! step 2, cache request in IP Driver
END
! step 3, reset number of requests, will NOT send cached data, just deletes the packet
entity{PROP:IPRequestCount} = 0
b) Kill the current packet by using another statement:
! step 1, prepare packet with 1000 requests
entity{PROP:IPRequestCount} = 1000
! add 7 records
LOOP 7 TIMES
! fill new record
…
ADD(entity)
! step 2, cache request in IP Driver
END
! step 3, issue any kind of statement other than on step 2
CLOSE(entity)
! doesn’t send cached data, deletes the packet, sends a close request
c) Kill the current packet by using a new packet request:
! step 1, prepare packet with 100 requests
entity{PROP:IPRequestCount} = 100
LOOP 7 TIMES
! step 2, fill new record
…
APPEND(entity)
! cache request in IP Driver
END
! step 3, initialize packet request number with the new value
entity{PROP:IPRequestCount} = 5 ! doesn’t send cached data, deletes the
LOOP 5 TIMES
! fill record
APPEND(entity)
! cache request in IP Driver, or
! send packet to server after 5th request
END
Example 5. How to create a packet with multiple NEXT requests.
! step 1, prepare packet with 20 requests
entity{PROP:IPRequestCount} = 20
LOOP 20 TIMES
! sends packet on 1st request and primes the record buffer with 1st record
! otherwise it reads the cached record
NEXT(entity)
IF ERRORCODE()
! handle error
…
BREAK
ELSE
! process the record from cache
…
END
END
old packet
70
IP Driver and Server Reference
Example 6. How to create a packet with multiple PREVIOUS requests.
! step 1, prepare packet with 20 requests
entity{PROP:IPRequestCount} = 20
PREVIOUS (entity)
! send packet to server and read 1st rec in to buffer
IF ERRORCODE()
! handle error
…
ELSE
! handle first record
…
! get number of remaining records
nReadRec = entity{PROP:IPRequestCount}
LOOP nReadRec TIMES
! get cached record from packet
PREVIOUS (entity)
! handle received record
…
END
END
Example 7. How to kill a received packet.
a) Using property syntax:
! step 1, prepare packet with 100 requests
entity{PROP:IPRequestCount} = 100
LOOP 100 TIMES
NEXT(entity) ! step 2, send packet for the 1st record, otherwise get cached record
IF ERRORCODE()
! handle error
…
ELSE
! handle received record
…
END
BREAK
END
! step 3, reset number of requests, delete cached packet
entity{PROP:IPRequestCount} = 0
b) Using another statement:
! step 1, prepare packet with 100 requests
entity{PROP:IPRequestCount} = 100
LOOP 100 TIMES
NEXT(entity) ! step 2, send packet for the 1st record, otherwise get cached record
IF ERRORCODE()
! handle error
…
ELSE
! handle received record
…
END
BREAK
END
! step 3, issue any kind of statement other than on step 2
CLOSE(entity) ! delete cached data, send CLOSE request to server
IP Driver and Server Reference
71
c) Using a new packet request:
! step 1, prepare packet with 100 requests
entity{PROP:IPRequestCount} = 100
LOOP 100 TIMES
NEXT(entity)
! step 2, send packet on 1st record, otherwise get cached record
IF ERRORCODE()
! handle error
…
ELSE
! handle received record
…
END
BREAK
END
! step 3, initialize packet request number with the new value
entity{PROP:IPRequestCount} = 50 ! delete cached data, createnew MRP packet
PREVIOUS(entity)
! send new packet to server
Example 8. Adding NOMEMO support.
You can also add the NOMEMO statement to any IP-enabled table to defer the reading of any MEMOS when processing
MRPs:
Example:
CODE
…
NOMEMO(file)
File{PROP:IPRequestCount} = 1000
NEXT(file)
This results in a faster loading of selected browses, in addition to a reduction of network traffic.
72
IP Driver and Server Reference
Server Side VIEW support
A VIEW structure is defined in Clarion as a virtual file (or table). Just like a real table, a view consists of rows with
columns, and you can retrieve data from a view (and even update data in a view). The fields in the view’s virtual table are
the fields of one or more real tables defined in the dictionary. See the online help and specifically the VIEW topic for more
information.
VIEWs are used throughout the application templates in many ways. You can use views to join two tables in your
dictionary and present the underlying data as if the data were coming from a single table, thus simplifying the schema of
your database for users performing ad-hoc reporting. You can also use views as a security mechanism to restrict the data
available to end-users. Views can also aggregate data (particularly useful if you can take advantage of indexed views),
and help partition data. In this article we will look at these different types of view to see when we can take advantage of a
view for our application.
With this latest version of the IP Driver, as you open a VIEW, the structure information is sent to the server to be created
there. All processing of the VIEW, including the joining of tables and any filters applied, are now processed on the server.
Only the results that you need are sent back to the IP Client application. This results in a big improvement of speed and
performance in any part of your application that is using VIEWs (i.e., Browses and Reports).
The IP Extender templates, specifically the Remote Procedures that are used to set variables in the server can now be
used to set a variable that is in a filter on the server.
The Version 2 templates also allow you to set/get values of global variables in the server. There is also support to BIND
those variables in the server so they can be used in any server side filter.
Filtering Rules
All VIEW structures may be filtered. With server side VIEWs, the support for filtering with the IP Driver is virtually
automatic. Using the template based VIEWs in Browses and Reports, modifications required by the developer are
minimal.
Here is a detailed summary of filtering rules as they apply to server side VIEWs:
•
If a filter uses only dictionary based table fields, the RECORD structure is bound (BINDed) on both sides
automatically (IP Client and the IP Server Data Manager DLL).
•
If a filter uses local and/or global variables, these variables need to be bound (BINDed) in the IP Client application
(this is done automatically by the templates using the “AutoBind” option).
•
If a filter use hand coded variables, the variables need to be bound (BINDed) in the IP client application, by hand
coding with the BIND statement, or using the procedure template prompts.
•
If a filter uses any runtime library function (TODAY(), INSTRING(), etc.), no action is needed. The filter engine
automatically recognizes all runtime library functions.
•
If a filter uses any user defined function, this function need to be defined and bound (BINDed) in both IP client
application and the IP Server Data Manager DLL. The actual user defined function that will be executed is the one
located in the IP Server Data Manager DLL. The client function can optionally be an “stub” function.
If the IP client application does not BIND the function, the filter will be ignored. If the function is bound on the
client but not on the server, the NEXT statement will return an ERRORCODE 90, the FILEERRORCODE returns
“1011”, and the FILEERROR returned will be a standard “BIND error”.
IP Driver and Server Reference
73
IP Driver Class Library Reference
This section documents two classes that are used to provide additional functionality to the IP-enabled Client application
and its target Data Manager application.
Overview
The IP Driver has powerful logic built into the runtime library that helps you transfer data from a Data Manager to the IPenabled Client application via IP protocol. There are two classes that are also provided to allow additional functions to any
application.
The IPExtended Class is used to simplify remote procedure calls and runtime filename assignment between the IPenabled client application and the Data Manager.
The IPFileTransfer Class is used to simplify the transfer of files between the IP-enabled client application and the Data
Manager.
IPFileTransfer and IPExtender Class Source Files
The source code for the IPFileTransfer and IPExtender classes is installed by default to the Clarion \LIBSRC folder. The
source code and their respective components are contained in:
IPExtend.INC
IPExtend.CLW
Class declarations
Class method definitions
Template Support
A robust set of Extender templates are provided to allow easy implementation of these classes into your applications. See
the Extended Server Support Extension sections in this PDF for a detailed description of these template tools.
Essentially, global extensions in the IP-enabled Client application and the Data Manager (IP server) application include
the proper class derivations needed. Other templates implement the appropriate methods needed for file transfer, remote
procedure calls, and runtime filename modifications.
74
IP Driver and Server Reference
IPExtender methods:
There are four methods available in the IPExtender Class. The extender template will create a global object that
instantiates this class:
IPx
IPExtender
SetConnectionString (set OWNER attribute of IP file)
GetConnectionString (get OWNER attribute of IP file)
SetConnectionString(ConnectionString)
GetConnectionString()
ConnectionString
A string constant, variable, or EQUATE that contains the parameters to communicate with the IP
Data Server.
To IP-enable any FILE structure, you only need to modify the OWNER attribute of the FILE structure, and change the
FILE driver to the IP Driver. For an IP-enabled FILE the OWNER attribute uses the following syntax to specify the
parameters to communicate with the IP Data Server:
DataManagerDLL@HostName:Port[:UserName:password]
Normally, a connection string is the same as the IPDRV::OWNER global setting, but you can also modify the connection
string if necessary to attach to another Data Manager.
These methods are used to set and get that information. Connection information must be set before calling any other
method in this class.
Implementation:
SetConnectionString and GetConnectionString methods are called using the IPx object, when the extender template is
included in the IP-enabled Client application.
Example:
CODE
LOOP
! This method receive all EVENT:Accepted's
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
CASE ACCEPTED()
OF ?SayHello
IPx.SetConnectionString(IPDRV::OWNER) !Set Connection before remote proc call
LOC:Message = IPx.Exec('SAYHELLO',LOC:Name,,,,,,,,,,,,,,,,,,,)
MESSAGE(LOC:Message,'Value Returned From IPDRV')
END
IP Driver and Server Reference
75
Exec(call a remote procedure)
Exec(RemoteProcedureName,<parameter1>…<parameter20>) ,<returnvalue>
RemoteProcedureName
A string constant that identifies the name of a remote procedure that is defined in the
target Data Manager.
Parameters
A string constant, variable, or EQUATE that identifies up to 20 possible parameters to
pass to the remote procedure.
Returnvalue
If the remote procedure defined on the Data Manager returns a value, return value is a
string that is returned to the IP-enabled Client application
The Exec method calls a remote procedure in the Data Manager. It internally executes a SEND command that is parsed
by the Data Manager, and executes the remote procedure (if it exists in the Data Manager) and returns a return value (if it
exists).
The parameter count will stop with the first omitted parameter, because there is no way to differentiate between an
omitted parameter and a null parameter. Therefore, if you call IPx.Exec('MyProc',1,2,3,,5) is it equivalent to
IPx.Exec('MyProc',1,2,3). If you need the 4th parameter, use IPx.Exec('MyProc',1,2,3,'',5). To use a single quote, you
should use a double single quote.
Implementation:
The Exec method is called using the IPx object, when the extender template is included in the IP-enabled Client
application.
Example:
CODE
LOOP
! This method receive all EVENT:Accepted's
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
CASE ACCEPTED()
OF ?SayHello
IPx.SetConnectionString(IPDRV::OWNER) !Set Connection before remote proc call
LOC:Message = IPx.Exec('SAYHELLO',LOC:Name,,,,,,,,,,,,,,,,,,,)
MESSAGE(LOC:Message,'Value Returned From IPDRV')
END
76
IP Driver and Server Reference
SetFileName (change remote file name)
GetFilename (read remote file name)
SetFileName(FileLabel, RemoteFileName)
GetFileName(FileLabel)
FileLabel
A label of the file that is located on the IP Data Server and defined by the Data Manager
RemoteFileName
A string constant, variable, or equate containing the new name of the target FileLabel.
SetFileName is a client side method that changes the name of the target file in the Data Manager.
GetFilename is a client side method that returns the value of a target file located in the Data Manager.
Implementation:
SetFileName should always be called after the SetConnectionString method and just prior to opening the file. The
GetFileName method can be called after the file is opened to retrieve and verify the active file’s name and location.
Example:
ThisWindow.Init PROCEDURE
ReturnValue
BYTE,AUTO
CODE
GlobalErrors.SetProcedureName('Main')
SELF.Request = GlobalRequest
! Store the incoming request
ReturnValue = PARENT.Init()
IF ReturnValue THEN RETURN ReturnValue.
SELF.FirstField = 1
SELF.VCRRequest &= VCRRequest
SELF.Errors &= GlobalErrors
! Set this windows ErrorManager to the global ErrorManager
SELF.AddItem(Toolbar)
CLEAR(GlobalRequest)
! Clear GlobalRequest after storing locally
CLEAR(GlobalResponse)
IPx.SetConnectionString(IPDRV::OWNER)
IPx.SetFileName('people',GLO:PeopleName)
Relate:people.Open
!File people used by this procedure,
!so make sure it's RelationManager is open
SELF.FilesOpened = True
SELF.Open(AppFrame)
! Open window
Do DefineListboxStyle
SELF.SetAlerts()
RETURN ReturnValue
IP Driver and Server Reference
77
SetRemoteVariable (change remote variable)
GetRemoteVariable (read remote variable)
SetRemoteVariable (VariableLabel, VariableValue)
GetRemoteVariable (VariableLabel),STRING
VariableLabel
The label of the variable that is located on the IP Data Server and defined by the Data Manager
VariableValue
A string constant, variable, or equate containing the new value of the target VariableLabel.
SetRemoteVariable is a client side method that changes the name of the target variable in the Data Manager.
GetRemoteVariable is a client side method that returns the value of a target variable located in the Data Manager.
Implementation:
SetRemoteVariable should always be called after the target variable has been initialized. The GetRemoteVariable
method can be called after the variable has been initialized to retrieve and verify its contents.
Return Value:
The GetRemoteVariable method returns a STRING
Example:
ThisWindow.Init PROCEDURE
ReturnValue
BYTE,AUTO
CODE
GlobalErrors.SetProcedureName('Main')
SELF.Request = GlobalRequest
! Store the incoming request
ReturnValue = PARENT.Init()
IF ReturnValue THEN RETURN ReturnValue.
SELF.FirstField = 1
SELF.VCRRequest &= VCRRequest
SELF.Errors &= GlobalErrors
! Set this windows ErrorManager to the global ErrorManager
SELF.AddItem(Toolbar)
CLEAR(GlobalRequest)
! Clear GlobalRequest after storing locally
CLEAR(GlobalResponse)
IPx.SetConnectionString(IPDRV::OWNER)
IPx.SetFileName('people',GLO:PeopleName)
Relate:people.Open
!File people used by this procedure,
!so make sure it's RelationManager is open
SELF.FilesOpened = True
SELF.Open(AppFrame)
! Open window
Do DefineListboxStyle
SELF.SetAlerts()
RETURN ReturnValue
78
IP Driver and Server Reference
IsAlive (is the IP Server connection active?)
IsAlive( ), BYTE
The IsAlive method is used to detect if an IP Server connection to the target Data Manager is active. If active, the method
returns one (1), and if inactive, the method returns zero (0).
Implementation:
You can call this method at any time in the application to detect if a connection to the IP Server has been lost. This may
occur due to a loss in the IP connection, a server timeout, or all tables have been closed, and a persistent connection is
not active. A persistent connection is established by the SetKeepAlive method.
Return Value: BYTE
Example:
ThisWindow.TakeWindowEvent PROCEDURE
ReturnValue
BYTE,AUTO
Looped BYTE
CODE
LOOP
! This method receives all window specific events
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
ReturnValue = PARENT.TakeWindowEvent()
CASE EVENT()
OF EVENT:GainFocus
IPx.SetConnectionString(IPDRV::OWNER)
IF NOT IPx.IsAlive()
DISABLE(?tbAccounts)
MESSAGE('The server time out|Select a new Ledger year to continue.','Attention')
END
END
RETURN ReturnValue
END
ReturnValue = Level:Fatal
RETURN ReturnValue
NOTE: THIS METHOD IS ALSO DUPLICATED IN THE IPFILETRANSFER CLASS.
See Also: SetKeepAlive
CloseConnection (close internal Server connection)
CloseConnection( )
The CloseConnection method is used to close an internal file used by the IPExtender or IPFileTransfer class, which is
maintaining a persistent connection with the Server Data Manager.
Implementation:
You can call this method at any time in the application to prepare to disconnect from the server Data Manager. The
connection will be closed only after all other tables are closed in your application, or the Client application itself is closed.
This method is useful and necessary when an error has occurred in a particular table connection, and you wish to shut
down and restart the connection again without closing the Client application.
NOTE: THIS METHOD IS ALSO DUPLICATED IN THE IPFILETRANSFER CLASS.
IP Driver and Server Reference
79
SetKeepAlive (activate internal KeepAlive mode)
SetKeepAlive(flag)
flag
A BYTE value that controls an internal KeepAlive setting.
The SetKeepAlive method is used to activate a persistent connection between the Client application and Server Data
Manager. It does this by keeping an internal table opened in the Data Manager. The end result is that all tables in your
Client application may be closed, but a connection is maintained with the Data Manager until the program is closed, the
CloseConnection method is called, or the Server has simply timed out.
Implementation:
When using the supporting Client IPDRV Extended Options template, the internal KeepAlive internal flag is defaulted to
ON. You should only need to call the SetKeepAlive method to explicitly turn off the persistent connection to the server.
The KeepAlive setting is only necessary if you are using an IPExtender object to set a global variable, call any
RemoteProcedure or activate any FileTransfer options. In a normal IP Client application not using the Extender Class, this
method is not needed and the application will close the server connection when there are no more files open.
Any IP Client application that uses variable file names, or anything that needs to be persistent in the server throughout the
application’s life, will need to set the internal KeepAlive flag to True (the default).
Note: Even with the KeepAlive mode active, an application will disconnect from the Server after a specified period of
client inactivity (whose value is set in the Remote Administrator).
NOTE: THIS METHOD IS DUPLICATED IN THE IPFILETRANSFER CLASS.
Example:
CODE
GlobalErrors.Init(GlobalErrorStatus)
INIMgr.Init('Ledger.INI', NVD_INI)
! Configure INIManager to use INI file
DctInit
IPDRV::OWNER = 'Ledger\IP_Ledger.DLL'&'@'&'localhost'&':'&'2339'
IPx.SetKeepAlive(False)
IPx.SetConnectionString(IPDRV::OWNER)
IPx.SetFileName('Year','YEAR.TPS')
SystemParametersInfo (38, 0, lCurrentFDSetting, 0)
! Configure frame dragging
IF lCurrentFDSetting = 1
SystemParametersInfo (37, 0, lAdjFDSetting, 3)
END
Main
INIMgr.Update
IF lCurrentFDSetting = 1
SystemParametersInfo (37, 1, lAdjFDSetting, 3)
END
INIMgr.Kill
See Also:
IsAlive
80
IP Driver and Server Reference
IPFileTransfer Methods
The IPFileTransfer Class contains a comprehensive set of methods that simply the process of transferring files with IPenabled applications. The IPTransferFileCode and IPTransferFileControl templates create a local object that
instantiates this class:
IPTransfer CLASS(IPFileTransfer)
END
SetConnectionString (set OWNER attribute of IP file)
GetConnectionString (get OWNER attribute of IP file)
SetConnectionString(ConnectionString)
GetConnectionString()
ConnectionString
A string constant, variable, or EQUATE that contains the parameters to communicate with the IP
Data Server.
To IP-enable any FILE structure, you only need to modify the OWNER attribute of the FILE structure, and change the
FILE driver to the IP Driver. For an IP-enabled FILE the OWNER attribute uses the following syntax to specify the
parameters to communicate with the IP Data Server:
DataManagerDLL@HostName:Port[:UserName:password]
Normally, a connection string is the same as the IPDRV::OWNER global setting, but you can also modify the connection
string if necessary to attach to another Data Manager.
These methods are used to set and get that information. Connection information must be set before calling any other
method in this class.
Implementation:
SetConnectionString and GetConnectionString methods are called using the IPTransfer object, when the appropriate
template is included in the IP-enabled Client application.
Example:
CODE
LOOP
! This method receive all EVENT:Accepted's
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
CASE ACCEPTED()
OF ?SayHello
IPx.SetConnectionString(IPDRV::OWNER) !Set Connection before remote proc call
LOC:Message = IPx.Exec('SAYHELLO',LOC:Name,,,,,,,,,,,,,,,,,,,)
MESSAGE(LOC:Message,'Value Returned From IPDRV')
END
IP Driver and Server Reference
81
SetSourceFileName(Set the source file name)
SetTargetFileName(Set the target file name)
GetRemoteFileName(Get the Remote File Name)
SetSourceFileName(SourceFileName)
SetTargetFileName(TargetFileName)
GetRemoteFileName()
SourceFileName
TargetFileName
A string constant or variable that identifies the name of the file to transfer.
A string constant or variable that identifies the destination of the file transfer.
SetSourceFileName sets the file name that will be transferred. The SetTargetFileName method sets the destination file
name that will receive the transfer. GetRemoteFileName is used to return the actual file name and path that is located on
the IP Data Server.
Source and destination locations are dependant upon the direction of transfer. The SourceFileName will be located on the
Client application when a SEND operation is executed, and located on the server in the event of a RECEIVE.
Implementation:
The SetSourceFileName and SetTargetFileName methods are called by other IPTransfer methods that initialize SEND
and RECEIVE transfer operations(i.e., InitSend, InitReceive, Send, Receive)
Example:
IPFileTransfer.InitSend PROCEDURE(STRING pSourceFileName,<STRING pTargetFileName>,LONG TransferIndex=0)
CODE
IF SELF.ProgressStatus = IPTransferNone
SELF.SetSourceFileName(pSourceFileName)
IF OMITTED(3) OR CLIP(pTargetFileName)=''
SELF.SetTargetFileName(pSourceFileName)
ELSE
SELF.SetTargetFileName(pTargetFileName)
END
SELF.InitSend(TransferIndex)
END
SetControls(Set pause and progress controls)
SetControls(ProgressControl,PauseControl,CancelControl)
ProgressControl
PauseControl
CancelControl
An unsigned integer that identifies the field equate number of a valid progress control used in the
transfer process.
An unsigned integer that identifies the field equate number of a valid pause button control used in
the transfer process.
An unsigned integer that identifies the field equate number of a valid cancel button control used in
the transfer process.
The SetControls method is used to pass valid field equates to the other class methods If the class will be used with a
progress, pause and cancels controls.
Example:
IPFileTransfer.Init PROCEDURE(BYTE pAction,UNSIGNED pProgressControl,|
UNSIGNED pStartPauseControl,UNSIGNED pCancelControl)
CODE
SELF.SetError('')
SELF.Init(pAction)
SELF.SetControls(pProgressControl,pStartPauseControl,pCancelControl)
82
IP Driver and Server Reference
Init(Initialize the class)
Init(action)
Init(action, ProgressControl,PauseControl,CancelControl)
Action
ProgressControl
PauseControl
CancelControl
A BYTE value that identifies the direction of the imminent file transfer. A value of one (1 )
indicates a SEND action, and a value of two (2) indicates a RECEIVE action.
An unsigned integer that identifies the field equate number of a valid progress control used in the
transfer process.
An unsigned integer that identifies the field equate number of a valid pause button control used in
the transfer process.
An unsigned integer that identifies the field equate number of a valid cancel button control used in
the transfer process.
The Init method is used to initialize the appropriate IPFileTransfer class methods prior to starting any transfer. If the Init
method is called without passing the appropriate control equates, this implies that the transfer will be done without any
end user control. An overloaded method to initialize the class and assign the controls at the same time allows end user
interaction during the transfer process.
Example:
ThisWindow.Init PROCEDURE
ReturnValue
BYTE,AUTO
CODE
GlobalErrors.SetProcedureName('TransferFileSend')
SELF.Request = GlobalRequest
! Store the incoming request
ReturnValue = PARENT.Init()
IF ReturnValue THEN RETURN ReturnValue.
SELF.FirstField = ?LOC:FileName:Prompt
SELF.VCRRequest &= VCRRequest
SELF.Errors &= GlobalErrors
! Set this windows ErrorManager to the global ErrorManager
SELF.AddItem(Toolbar)
CLEAR(GlobalRequest)
! Clear GlobalRequest after storing locally
CLEAR(GlobalResponse)
SELF.AddItem(?Close,RequestCancelled) ! Add the close control to the window amanger
SELF.Open(Window)
! Open window
IPTransfer.SetConnectionString(IPDRV::OWNER)
IPTransfer.Init(IPTransferSend,?Progress:Thermometer,?Transfer,?CancelTransfer)
IPTransfer.SetAllowPause(True,'Pause')
Do DefineListboxStyle
FileLookup1.Init
FileLookup1.ClearOnCancel = True
FileLookup1.Flags=BOR(FileLookup1.Flags,FILE:LongName)
! Allow long filenames
FileLookup1.SetMask('All Files','*.*')
! Set the file mask
SELF.SetAlerts()
RETURN ReturnValue
IP Driver and Server Reference
83
SetSilent(set visible error message)
GetSilent(get the silent error state)
SetSilent( value )
GetSilent ()
value
A BYTE value that sets the visible error mode. If the value is set to FALSE (0 – the default) a message will popup
if any error happens during the transfer process. If value is set to TRUE the process will stop without posting any
visible errors.
SetSilent sets the error display mode during the transfer process. The GetSilent method is used to retrieve the error
state prior to the transfer process. If the silent mode is active, the appropriate GetError or GetErrorCode methods can be
retrieved later for additional processing.
Implementation:
The silent mode if off by default. If you wish to override this, use the appropriate embed point to activate the silent error
mode.
84
IP Driver and Server Reference
InitSend(begin the SEND process)
InitSend ( TransferIndex)
InitSend (SourceFileName, TargetFileName, TransferIndex)
TransferIndex
SourceFileName
TargetFileName
A LONG value that is used to omit a specific number of bytes from the source before sending.
The default value is zero (0).
A string constant or variable that identifies the name of the file to transfer.
A string constant or variable that identifies the destination of the file transfer.
The InitSend method starts the SEND process. The SEND process always transfers the SourceFileName from the Client
to the Server. The overloaded InitSend method is used to initialize the send process and at the same time set the source
and target file name. If the TransferIndex value is not 0 the first TransferIndex bytes of the file will be omitted in the send
process.
Implementation:
InitSend is used to begin the file transfer process from client application to the IP Data Server designated location.
Example:
ThisWindow.TakeAccepted PROCEDURE
ReturnValue
BYTE,AUTO
Looped BYTE
CODE
LOOP
! This method receive all EVENT:Accepted's
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
CASE ACCEPTED()
OF ?Transfer
IpTransfer.InitSend(LOC:FileName,LOC:TargetName)
END
ReturnValue = PARENT.TakeAccepted()
CASE ACCEPTED()
OF ?LookupFile
ThisWindow.Update
LOC:FileName = FileLookup1.Ask(1)
DISPLAY
LOC:TargetName = LOC:FileName
END
RETURN ReturnValue
END
ReturnValue = Level:Fatal
RETURN ReturnValue
IP Driver and Server Reference
85
InitReceive(begin the RECEIVE process)
InitReceive ( TransferIndex)
InitReceive (SourceFileName, TargetFileName, TransferIndex)
TransferIndex
SourceFileName
TargetFileName
A LONG value that is used to omit a specific number of bytes from the source before sending.
The default value is zero (0).
A string constant or variable that identifies the name of the file to transfer.
A string constant or variable that identifies the destination of the file transfer.
The InitReceive method starts the RECEIVE process. The RECEIVE process always transfers the SourceFileName from
the Server side to the Client application location. The overloaded InitReceive method is used to initialize the receive
process and at the same time set the source and target file name. If the TransferIndex value is not 0 the first
TransferIndex bytes of the file will be omitted in the receive process.
Implementation:
InitReceive is used to begin the file transfer process from IP Data Server to the client application’s designated location.
Example:
ThisWindow.TakeAccepted PROCEDURE
ReturnValue
BYTE,AUTO
Looped BYTE
CODE
LOOP
! This method receive all EVENT:Accepted's
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
CASE ACCEPTED()
OF ?Transfer
IpTransfer.InitReceive(LOC:FileName,LOC:TargetName)
END
ReturnValue = PARENT.TakeAccepted()
CASE ACCEPTED()
OF ?LookupFile
ThisWindow.Update
LOC:FileName = FileLookup1.Ask(1)
DISPLAY
LOC:TargetName = LOC:FileName
END
RETURN ReturnValue
END
ReturnValue = Level:Fatal
RETURN ReturnValue
86
IP Driver and Server Reference
TakeEvent(monitor transfer process)
TakeEvent()
The TakeEvent method will monitor the status of the class and execute the corresponding action if the window ACCEPT
loop is the choice of transfer implementation. This allows a user to better monitor and control a file transfer, andd provide
them with a progress control, pause and cancel buttons. The alternative is to use an internal loop that is contained in the
class.
Implementation:
The TakeEvent method is called within the standard TakeEvent method of the Window Manager.
Example:
ThisWindow.TakeEvent PROCEDURE
ReturnValue
BYTE,AUTO
Looped BYTE
CODE
LOOP
IF Looped
RETURN Level:Notify
ELSE
Looped = 1
END
IPTransfer.TakeEvent()
ReturnValue = PARENT.TakeEvent()
RETURN ReturnValue
END
ReturnValue = Level:Fatal
RETURN ReturnValue
! This method receives all events
IP Driver and Server Reference
87
Start(transfer started)
Pause(transfer paused)
Cancel(transfer cancelled)
Aborted(transfer aborted)
Finish(transfer finished)
Start(TransferIndex)
Pause()
Cancel()
Aborted()
Finish()
TransferIndex
A LONG value that is used to omit a specific number of bytes from the source before sending. The default
value is zero (0).
Start, Pause, Cancel, Aborted, and Finish are virtual methods that are called when the corresponding action is
executed. Embed points are available through the template interface to allow you to add additional messaging or
processes as needed. See the Client-side Embeds and Procedures section for more information.
Send(begin internal SEND)
Send ( TransferIndex)
Send (SourceFileName, TargetFileName, TransferIndex)
TransferIndex
SourceFileName
TargetFileName
A LONG value that is used to omit a specific number of bytes from the source before sending.
The default value is zero (0).
A string constant or variable that identifies the name of the file to transfer.
A string constant or variable that identifies the destination of the file transfer.
The Send method starts the SEND process. The SEND process always transfers the SourceFileName from the Client to
the Server. The overloaded Send method is used to initialize the send process and at the same time set the source and
target file name. If the TransferIndex value is not 0 the first TransferIndex bytes of the file will be omitted in the send
process.
Implementation:
Send is similar to the InitSend method, but uses an internal loop to perform the transfer. No user interaction is available.
Receive(begin internal RECEIVE)
Receive ( TransferIndex)
Receive (SourceFileName, TargetFileName, TransferIndex)
TransferIndex
SourceFileName
TargetFileName
A LONG value that is used to omit a specific number of bytes from the source before sending.
The default value is zero (0).
A string constant or variable that identifies the name of the file to transfer.
A string constant or variable that identifies the destination of the file transfer.
The Receive method starts the RECEIVE process. The RECEIVE process always transfers the SourceFileName from the
Server side to the Client application location. The overloaded Receive method is used to initialize the receive process
and at the same time set the source and target file name. If the TransferIndex value is not 0 the first TransferIndex bytes
of the file will be omitted in the receive process.
Implementation:
Receive is similar to the InitReceive method, but uses an internal loop to perform the transfer. No user interaction is
available.
88
IP Driver and Server Reference
GetErrorCode(get transfer errorcode)
GetError(get transfer error)
GetErrorCode( )
GetError( )
The GetErrorCode and GetError methods are used to return the respective ERRORCODE or ERROR that was posted if
an error occurred during the send or receive process.
Implementation:
Any errors encountered during the transfer process are saved internally by the IPFileTransfer class. By using these
methods, any errors stored can be read if needed.
Example:
IPFileTransfer.Start
PROCEDURE(LONG TransferIndex=0)
CODE
IF SELF.Action = IPTransferSend
SELF.SourceFile &= IPLocalFile
SELF.TargetFile &= IPRemoteFile
ELSIF SELF.Action = IPTransferReceive
SELF.SourceFile &= IPRemoteFile
SELF.TargetFile &= IPLocalFile
END
SELF.SourceRecord &= SELF.SourceFile{PROP:Record}
SELF.SourceBuffer &= WHAT(SELF.SourceRecord,1)
SELF.TargetRecord &= SELF.TargetFile{PROP:Record}
SELF.TargetBuffer &= WHAT(SELF.TargetRecord,1)
OPEN(SELF.SourceFile,40h)
SELF.SetError('Source')
IF SELF.GetErrorCode()
SELF.Aborted()
RETURN
END
SetBuffersPerCycle (set buffers read per cycle)
GetBuffersPerCycle (get buffers read per cycle)
SetBuffersPerCycle(value)
GetBuffersPerCycle()
value
A BYTE value that sets the number of buffers read per cycle. The default value is five (5).
During every file transfer process, there are two LOOP structures. The outer LOOP is used to control the window
responsiveness during the transfer process, while the second loop controls how many fixed buffers are read per cycle.
The fixed buffer size is 64K less 512 bytes (65024).
Implementation:
Use these methods to set and get the number of buffers read per cycle. You can fine-tune your window response with the
amount of data transferred per cycle. For larger file transfers you should increase this setting.
Example:
IPFileTransfer.Init
PROCEDURE(BYTE pAction)
CODE
SELF.SetBuffersPerCycle(5)
SELF.SetControls(0,0,0)
SELF.Action = pAction!Must be IPTransferSend OR IPTransferReceive
IP Driver and Server Reference
89
SetTimer(set transfer interval)
GetTimer(get transfer Interval)
SetTimer(value)
GetTimer()
value
A LONG value that sets the TIMER attribute of the WINDOW used in the transfer process. The default value set
by the class is ten (10).
The SetTimer/GetTimer methods are used to query and set the TIMER attribute on a WINDOW that has the file transfer
controls populated. When using the window ACCEPT loop, the timer value can be changed. The larger the value, the
more responsive will the window be, but the whole file transfer process will take longer.
Implementation:
Use these methods to control the responsiveness of the end user in controlling the file transfer controls. SetTimer should
be set prior to opening the window.
Example:
IPFileTransfer.Construct
PROCEDURE
CODE
SELF.Extender &= NEW(IPExtender)
SELF.ProgressStatus = IPTransferNone
SELF.SourceFileOpen = False
SELF.TargetFileOpen = False
SELF.SetTimer(10)
SELF.Silent = False
90
IP Driver and Server Reference
SetAllowPause(set transfer pause action)
GetAllowPause(get transfer pause action)
SetAllowPause(AllowPause,PauseText)
GetAllowPause()
AllowPause
PauseText
A BYTE value that when set to TRUE (1), allows pausing the file transfer process
A string constant or variable that contains text to substitute on the target pause control when the pause
action is active.
When using the window ACCEPT loop (transfers using the InitSend or InitReceive methods) the process can also
support pausing the file transfer at any time, and later restarting it. The SetAllowPause method sets the pause capability.
Optional text to the target pause control will be applied when the pause action is active.
Implementation:
SetAllowPause is set in the WindowManager.Init method to activate the pause activity.
Example:
ThisWindow.Init PROCEDURE
ReturnValue
BYTE,AUTO
CODE
GlobalErrors.SetProcedureName('TransferFileSend')
SELF.Request = GlobalRequest
! Store the incoming request
ReturnValue = PARENT.Init()
IF ReturnValue THEN RETURN ReturnValue.
SELF.FirstField = ?LOC:FileName:Prompt
SELF.VCRRequest &= VCRRequest
SELF.Errors &= GlobalErrors
! Set this windows ErrorManager to the global ErrorManager
SELF.AddItem(Toolbar)
CLEAR(GlobalRequest)
! Clear GlobalRequest after storing locally
CLEAR(GlobalResponse)
SELF.AddItem(?Close,RequestCancelled) ! Add the close control to the window amanger
SELF.Open(Window)
! Open window
IPTransfer.SetConnectionString(IPDRV::OWNER)
IPTransfer.Init(IPTransferSend,?Progress:Thermometer,?Transfer,?CancelTransfer)
IPTransfer.SetAllowPause(True,'Pause')
Do DefineListboxStyle
FileLookup1.Init
FileLookup1.ClearOnCancel = True
FileLookup1.Flags=BOR(FileLookup1.Flags,FILE:LongName)
! Allow long filenames
FileLookup1.SetMask('All Files','*.*')
! Set the file mask
SELF.SetAlerts()
RETURN ReturnValue
GetAction(get the transfer action)
GetAction()
The GetAction method returns a byte value that indicates what type of file transfer action is being executed. A value of
one (1) indicates a client to server SEND action. A value of two (2) indicates a server to client RECEIVE action.
IP Driver and Server Reference
SwapPauseText(transfer control text)
StartTimer(transfer interval started)
StopTimer(transfer interval stopped)
SwapPauseText ()
StartTimer()
StopTimer()
These virtual methods are called internally, and can be used during the transfer to monitor the progress or the
corresponding action.
Implementation:
SwapPauseText performs the text substitution when a pause action is detected.
StartTimer is used to reset the TIMER attribute of the target WINDOW.
StopTimer is used to completely clear the window of any TIMER attribute.
91
92
IP Driver and Server Reference
Error Codes and Error Trapping
There are two types of errors that the IP driver might report; standard Clarion errors as listed in ERRORS.CLW, and
communication errors. In both cases ERROR() and ERRORCODE() can be used to check for an error, but in the case of
a communication error ERRRORCODE() is set to 90, and you must check the FILEERROR() and FILEERRORCODE()
functions to retrieve the extended error information from the driver.
FILERRROR() returns the associated message text about the error. Here is a list of possible extended FileErrorCodes
that may be returned:
Condition
ACCESS DENIED
OBJECT NOT FOUND
FUNCTION NOT SUPPORTED
UKNOWN COMMAND
INVALID PACKET
INTERNAL ERROR
INVALID DATAMANAGER DLL
MISSING PARAMETER
TIMEOUT ON OPERATION
TABLE OPERATION FAILED
ADMIN RIGHTS REQUIRED
READ ONLY OBJECT
BUILD() IN PROGRESS
INVALID REQUEST
ADMIN CONNECTION ALREADY ACTIVE
INVALID PASSWORD
DELETE OF SYSTEM OBJECT FAILED
DELETE OF LOCKED OBJECT FAILED
INVALID USER NAME
INVALID OBJECT
TOO MANY OPENED SESSIONS
NEW SESSIONS DISABLED
HANDSHAKE FAILED
SOCKET CONNECTION FAILED
FileErrorCode
1
2
3
5
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
23
25
26
29
30
Socket Errors
The most common error will likely be a socket error in the event of lost communications.
Socket errors can be caused by a problem on the client, the server, or by a problem on the network itself.
The better prepared your application is for any error, the more gracefully you'll handle it, and the easier you'll make your
job.
Here are some handy links to help you evaluate a socket error when encountered.
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/winsock/winsock/windows_sockets_error_codes_2.asp
http://www.sockets.com/err_lst1.htm - ErrorsInNumericOrder
IP Driver and Server Reference
93
Common Errors
Here is a short list of some common errors that you may encounter during the development cycle:
ERRORCODE (9) "Data Manager Not Found"
Data Manager is wrong. The Data Manager name passed by the Client application is not recognized by the IP Data
Server.
ERRORCODE (18) "Invalid User Password"
Password is set incorrectly.
ERRORCODE (21) "Unknown User Name"
User name is set incorrectly.
ERRORCODE (28) "Error: User Permissions not found"
The supplied User name & Password is correct, but Table Permissions are not set in the Remote Administrator.
ERRORCODE (30) "Socket Error 10054"
The Data Manager DLL is linked incorrectly (e.g. Local mode), or is missing a dependent DLL or for some other reason is
invalid.
ERRORCODE (30) "Socket Error 10061"
Port number is wrong.
ERRORCODE (30) "Socket Error 11001"
Host Name is wrong (irresolvable).
94
IP Driver and Server Reference
Detecting an invalid connection to the IP Data Server
people FILE,DRIVER('IPDRV'),PRE(PEO),CREATE,BINDABLE,THREAD,OWNER(IPDRV::OWNER)
KeyId
KEY(PEO:Id),NOCASE,OPT
KeyLastName KEY(PEO:LastName),DUP,NOCASE
Record
RECORD,PRE()
Id
LONG
FirstName
STRING(30)
LastName
STRING(30)
Gender
STRING(1)
END
END
Code
IPDRV::OWNER = 'ip_people.dll'&'@'&'localhost'&':'&'2339'
The table is attempted to be opened, the code checks for extended FILEERRORCODE() 30 to verify whether the problem
is that the IP Data Server connection failed any reason:
OPEN(People)
IF Errorcode() = 90 AND FILEERRORCODE() = 30
MESSAGE('Unable to establish connection to IP Data Server,'Connection Error')
END
CLOSE(People)
This code above attempts to open the People file on the remote server and traps for the extended ERRORCODE 90 and
associated FILEERRORCODE 30.
IP Driver and Server Reference
SoftVelocity IP Data Server Service
To verify that the SoftVelocity IP Data Driver Service is started:
Open Control Panel > Administrative Tools > Services:
The ports used by the server are specified in the INI file Claipsrv.ini located in the root directory of the IP data server.
Typical contents of Claipsrv.ini
[REQUESTER]
PORT=2339
PORT_SSL=2340
Server Ports
To change the ports the data server uses, go to your system Services program and stop the SoftVelocity IP Data Driver
service, then edit the port numbers and restart the SoftVelocity IP Data Driver service.
The SoftVelocity IP Data Driver Service should be set to run on the Local System account and the Allow service to
interact with desktop option should be checked.
95
96
IP Driver and Server Reference
UNC support for the SoftVelocity IP Data Server Service
This section describes an alternate configuration for the SoftVelocity IP Data Server service.
By default, most Windows services run under a LocalService account, which does not have access to the network. By
default, the SoftVelocity IP Data Server service is installed under the LocalService account. If you need to use UNC
(Uniform Naming Convention, i.e., \\server\share\directory\program.exe) to access remote files on the network, you will
need to set the user account under which the service runs to an account that has access to the network.
In order to run a system service correctly using a user account, you must manually set the user account to have the "Log
on as a service" right. The method of doing this varies between versions of Windows NT and Windows 2000/XP/2003.
In the Services Control Panel, change the account of the IP Data Server service so that it is running under “your” account
instead of "Local System". Next, go to the System Security Policy editor in the Control Panel and make sure your account
has "Log on as a service" rights.
Your on-line help file has a special Flash movie that describes this setup in greater detail.
A note about Mapped Drives
A service shouldn't access local or network resources through mapped drive letters. Your IP Data Manager is executed by
the IP Server service and so it runs in a different security context. A service should only access a remote resource using
the Universal Naming Convention (UNC) name to access the resource.
IP Driver and Server Reference
97
Remote Administration Application (RMAdmin)
NOTE: In order to run the Remote Administrator Console you must have the Java SDK or JRE version 1.4 or
greater installed on your development machine.
The RMadmin console can be run from any machine capable of running a Java application, just copy the rmadmin.jar file
to the machine and double-click on it to launch it.
When initially installed use the following information to log into the RMadmin console:
User Name: Administrator
Password: <leave the password blank>
The first time you log in to the console use User name of Administrator, and leave the Password empty. After your initial
login, you can specify a password for the Administrator account.
Main Menu contains all primary commands and functions of the Remote Administrator Console
Toolbar contains graphical buttons to the most commonly used commands
Tree View Pane on the left side of the window groups different function levels.
Details View Pane on the right-hand side of the window lists detailed information for the selected function level
Status Bar to display session status
Popup menus contain the list of available commands for the selected element.
98
IP Driver and Server Reference
Main Menu
The main menu contains the following items/sub-items
Connection
Connect to IP Data Server
Refresh
Refresh Speed
Exit
establish a new connection from the RMAdmin with a Clarion IP Data Server
(see Connection to server dialog for details)
refresh the displayed data
provides possibility to choose the refresh mode
Actions
Sessions
CREATE Table(s)
BUILD Keys for Table(s)
menu item contains submenu with session related operations (Close Sessions,
Force Close Sessions, Prevent New Sessions, Allow New Sessions, Close
All Sessions)
create the physical file(s) for selected table(s)
build/rebuild keys for the selected table
Tools
Accounts
contains a submenu that provides user account related operations: (Add New
Account, Modify Account, Delete Account).
Table Permissions
provides a dialog to modify permissions for the selected table
Register/Unregister Data Manager
intended to register a new Data Manager DLL on the server, or un-register the
selected Data Manager DLL. Only registered Data Manager DLLs are available
for the user. (Note: It is responsibility of an administrator to manually copy the
necessary DLLs to the server).
Refresh Registrations/Refresh Data Manager
provide for refreshing information about the registered Data Manager. It is useful
in the case when the Administrator replaces a Data Manager DLL with a new
one. The First menu item refreshes all registered Data Managers. The second
item – refreshed just the selected Data Manager.
Data Managers Aliases
provides a dialog to add/remove/modify aliases for the Data Manager DLL’s.
Server Settings
provides the ability to specify the Maximum number of simultaneous connections
allowed, and a session timeout setting.
Help
In the current version only an About sub-item is supported
Note: The availability of the listed menu items depends on the node selected on the left hand tree-list and or the item
selected on the right table pane.
IP Driver and Server Reference
99
Toolbar
The toolbar provides easy access to the most common main menu actions.
From left to right:
Connect to IP Data Server
Refresh
Close Sessions
New Account
Register Data Managers
Server Settings
Tree-View Pane
The Tree View Pane contains the following nodes:
IP Data Server
Sessions
Data Managers
Accounts
high-level node corresponding to the current connection of the RMAdmin to a Data Server. This
node has the following child nodes:
corresponds to currently active user sessions. When the node is selected the right Details pane
contains the Session view. (See Sessions view section for details.). The child nodes of the node
represent the currently active sessions.
The child nodes of this node correspond to specific Data Manager DLL’s, installed (registered) on
the server. When you select the DLL under this node the right-hand Details pane displays the
tables available in that Data Manager DLL. For more details, see the Table maintenance view
section.
corresponds to the user accounts registered on the server. If this node is selected then the righthand Details pane lists the Accounts available on the data server. For more details, see the
Account administration view section.)
100
IP Driver and Server Reference
Details View Pane
The views presented in the right-hand Details pane are dependent on the items selected in the Tree View Pane.
Sessions View
The Sessions view is displayed in the details pane when the Sessions node is selected in the left-hand tree list. This view
displays information about currently active sessions on the server and provides access to a set of related operations. This
view is used to monitor and control IP client sessions.
ID
Status
User Name
Transaction (Status)
an internal ID for the session
displays the session status. This can be active or terminating.
name of the user that owns the session
this box is checked if a transaction is started or in progress.
The following operations are available when this view is active:
Close Sessions
Force Close Sessions
Prevent New Sessions
Allow New Sessions
terminate the selected session(s). If a transaction has been started by a session, the
session isn’t terminated until the transaction is finished.
terminate the sessions immediately even if a transaction in progress
prevent (disable) subsequent user connections to the server.
enable new sessions if they were disabled
IP Driver and Server Reference
101
Active Table View
The Active Table view is displayed in the Details pane when a node corresponding to a session is selected in the left-hand
tree list. This view displays information about tables currently used in the selected session. Its purpose is to monitor and
control IP driver sessions with the Remote Administrator.
This view is a table grid with the following columns:
Data Manager
Table
Table Status
Open Mode
Record Held
contains the name of Data Manager DLL used by the session
contains the name of the database table used in the session
can be opened and/or locked.
The table open mode. It can be any of the following pairs;
User Access( Read Only, Write Only, Read/Write)/
Other's Access ( Any Access, Deny All, Deny Write, Deny Read, Deny None)
Checked if a record is locked by the session
102
IP Driver and Server Reference
Table View
The Table view lists all tables for the selected Data Manager and provides for setting of access rights for the tables. You
can also perform some basic operations on the tables; CREATE() and BUILD().
NOTE: CREATE() and BUILD() will only succeed if the physical data tables are located in the root directory of the data
server and do not contain a NAME attribute.
The view is a grid with the following columns:
Prefix
Table
Status
Sessions
Locked by
Records Held
The table prefix (value of a FILE’s PRE attribute)
Table name that is used to store the table (value of a FILE’s NAME attribute or the label
of the FILE structure if the NAME attribute is empty).
The default value is ready. Status can change during a BUILD operation (build in
progress, build failed)
Holds the number of sessions working with the table at this time.
Holds the name of the user that locked the table (if locked).
Stores the number of records locked in the table
The following operations are available in this view:
CREATE Table(s)
BUILD Keys for Table(s)
Create or recreate the corresponding data file
Rebuild all keys for the selected table.
You can also use the following session operations available for any tables selected in the right pane:
Permissions dialog (see the Permissions dialog section that follows).
Close Sessions
Force Close Sessions
IP Driver and Server Reference
103
Account Administration View
The Account Administration view displays information about users currently registered on the server. It is used to specify
create user accounts and passwords, modify users and delete them.
Accounts are used to control specific data access from IP Client applications. One user account could be used for read
only access only, and another account can offer additional access.
The view is a grid with the following columns
User Name
Administrator
Identifies the name of the user account
A checked value means that the user account has administrative rights.
The following operations are available in this view:
Add New Account
User Name
Password
Confirm password
Administrative access
Modify Account
Delete Account
Create a new account. The operation displays the dialog to create a new user account.
Enter the name of the newly created user
Enter the password
Enter the password again, confirming the password
When checked, this account is granted access to the Remote Administrator Console.
This option provides the same dialog as in Add New Account to modify user’s data
Deletes the selected account.
104
IP Driver and Server Reference
Table Permissions (Access Rights)
The Table Permissions dialog allows you to set and change user access rights for a selected table. Whenever a new
account is established for an IP Client application, a User account must be specified and Table Permissions must
be granted to allow table access.
The Permissions dialog is called from the Table Permissions… menu or popup item when a selected table is highlighted.
The Permissions dialog is shown above. The first column contains a list of users allocated to access the selected table.
Other columns contain check boxes that enable specified access rights of the selected user for the table(s).
The list includes the following options (check boxes).
When checked:
Read
Write
Deny Read
Deny Write
Create
Build key
Lock
Hold record
Read access is permitted
Write access is permitted
Opening the file with Deny Read is permitted
Opening the file with Deny Write is permitted
CREATE, COPY, and REMOVE operations are permitted
BUILD and PACK operations are permitted
LOCK operation is permitted
Record locking is permitted
The dialog provides the possibility to apply the permission settings to all tables belonging to the selected Data Manager
(Apply to All Tables button).
IP Driver and Server Reference
105
IP Server Settings
The IP Server Settings dialog provides the ability to specify the Maximum number of simultaneous connections allowed,
and a session timeout setting. (Tools > Server Settings)
To modify the setting’s value double-click to use edit-in-place.
The following entries are available:
MaxConnectionNumber
SessionTimeoutMinutes
maximum number of simultaneous connections
time in minutes that the server will wait to automatically disconnect a session, if no client
activity is detected. The maximum value is 10000.
Data Manager Aliases
Data Manager Aliases are intended to simplify access to the Data Manager DLL. Each Data Manager DLL may have an
Alias. An Alias provides a convenient way to refer to the corresponding Data Manager DLL. A Client program may use a
Data Manager alias instead of the Data Manager DLL’s relative path, located in the OWNER attribute of the IP enabled
FILE structure.
The Data Manager Aliases dialog allows you to add/remove/modify aliases for a target Data Manager DLL.
The dialog contains an Edit-in-Place table with the following column options:
Alias
Contains the unique alias name for a target Data Manager
Data Manager Contains the Data Manager DLL (path and name)
The dialog works in two modes. If a specific Data Manager is selected, the dialog contains aliases only for that selected
Data Manager. Otherwise, the dialog contains all aliases registered in the system for all Data Managers.
Status Bar Information
The RMAdmin console has status bar that is used to display information about the current server status. The information
includes server state (Not Connected, Connected) and total number of active sessions.
106
IP Driver and Server Reference
Connect to IP Server
This dialog is used to connect to an IP Data Server.
User Name and Password
Enter a valid User Name and Password.
Only users with administrative access rights can connect to the server.
If the connection fails, a message box displays the type of error. On success this dialog is closed automatically. The
Connection dialog can be invoked at any time through the menu command, toolbar button or by hot key.
The Server entry for local testing should use localhost:2339 . The remote administrator uses its own internal encryption,
so do not use an SSL port in this entry.
IP Driver and Server Reference
107
Possible Connection Errors
The following errors may be posted:
Error in Communication with the specified IP Data Server. Connection Refused:
Connect.
Possible Cause: SoftVelocity IP Data Server Service not started, or a connection is already active from another location.
The Specified IP Data Server could not be found
Possible Cause: Invalid Host name or IP address
Communication Port is not defined
Possible Cause: Missing Port address in Server entry field
The User Name is either not specified or not recognized
Possible Cause: An invalid User Name, or leaving the User Name blank.
The Password you entered is not valid. Please try again. If you still
experiencing difficulties please refer to your System Administrator.
Possible Cause: An invalid Password, or leaving the Password blank when it is required.
Stored configuration properties
The Remote Administrator Console stores a variety of configuration properties such as the main window size and last
accessed hosts in the text file properties.txt located in the RMAdmin working directory.
108
IP Driver and Server Reference
IP Driver Specifications
The IP driver reads and writes data stored on a target server location. If no NAME is specified, then the label of the file is
used to find the data to be used.
Files:
C60IPDX.LIB
Windows Static Link Library
C60IPDX.DLL
Windows Dynamic Link Library
Data Types and File Specifications
BYTE
SHORT
USHORT
LONG
ULONG
SREAL
REAL
BFLOAT4
BFLOAT8
DECIMAL
PDECIMAL
STRING
CSTRING
PSTRING
DATE
TIME
GROUP
Notes:
1. Data Types and File Specifications are dependent upon the type of table that the IP Driver is enabling. For
example, if you IP enable a TopSpeed table, the IP enabled TopSpeed table has all of the characteristics of a
standard TopSpeed table.
2. Since Clarion’s In Memory Database Driver (IMDD) creates a file on the client’s local machine, and not the server,
the IP enabling of the IMDD is not supported.
IP Driver and Server Reference
109
Driver Strings
There are switches or "driver strings" you can set to control the way your application creates, reads, and writes files with a
specific driver. Driver strings are simply messages or parameters that are sent to the file driver at run-time to control its
behavior. More information regarding these strings can be found in the Language Reference PDF
Some driver strings have no effect after the file is open, so no SEND function syntax is listed for those strings. However,
the SEND function syntax to return the value of the switch is listed for all driver strings.
The IP DRiver supports the following Driver String:
IPEXEC
The IP Driver provides support for executing code contained in your Data Manager DLL on the server. You accomplish
this using the SEND command with the message parameter containing the keyword “IPEXEC”.
returnvalue = SEND(file,'IPEXEC stringValue')
file
the name of a file that is defined in the IPServer Data Manager DLL, which is used by the RemoteExecute
procedure
stringValue
a string value to be used in the RemoteExecute procedure.
When the SEND command is processed on the server the first 7 characters of the message parameter are checked, and
if the string “IPEXEC “ is found (including the space character) the RemoteExecute() procedure is called.
RemoteExecute() is passed a reference to the FILE and the stringValue beginning at position 8. The “IPEXEC “ is
stripped from the stringValue before its passed to the RemoteExecute() procedure.
NOTE: The SEND command for the IP Driver MUST be called AFTER THE TABLE IS OPENED, and not before.
Supported Commands and Attributes
The IP driver transmits Clarion language commands to the IP Data server where they are executed using the database
driver as specified in your Data Dictionary (TopSpeed, etc). To check whether a specific command or attribute is
supported refer to the documentation for the database driver you specified in your Data Dictionary.
110
IP Driver and Server Reference
DEBUGVIEW Support
Support is available for using the DEBUGVIEW utility. DEBUGVIEW lets you monitor debug output without the need to
run a debugger to catch the output you specify in your applications.
Support for the DEBUGVIEW utility is provided through the following built-in procedure:
TRACE( string )
string
A STRING constant, variable, or expression that contains information to send to the DEBUGVIEW utility.
TRACE is used to send debug information to the DEBUGVIEW utility.
You can download the debug viewer from the following link:
http://www.sysinternals.com/ntw2k/freeware/debugview.shtml
IP Driver and Server Reference
111
Advanced Deployment Tips
Clarion Runtime Files
When deploying IP Client applications to your users, you may find it useful to have the C60RUNX.DLL and the database
drivers you are using located in a common location on the PATH, so that all of your Client applications can share them.
Multiple IPServer DLLs are permitted, but we recommend that each DLL have a unique set of tables defined. If two IP
Data Server DLLs reference the same table, the table definitions must match exactly.
Location of Data Managers and Data Files
The simplest deployment places both the Data Manager DLL(s) and the associated data files in the root of the IP Data
Server. But you have flexibility in where you deploy both file groups.
Data in a subdirectory
If your FILE provides a NAME attribute such as NAME(‘DATA\MYFILE.TPS’), the Data Manager will attempt to OPEN the
FILE in the “Data” subdirectory relative to its own location. That means if the Data Manager is located in the root of the
data server install (e.g \ClarionDataServer) then the data files would be deployed to \ClarionDataServer\Data.
Data Manager in a subdirectory
You can place Data Manager DLLs in a subdirectory under the root of the data server.
If you do this the data files must be deployed to that directory, unless you are using the NAME attribute as explained
above.
112
IP Driver and Server Reference
Distribution Guide
This section discusses the key files and other steps needed to distribute your IP-enabled applications to your customers.
IP Data Manager Distribution
The Data Manager DLL that you create will also require the minimum files to be distributed:
C60RUNX.DLL
<any driver dll(s) specified in your dictionary>
For example, if your dictionary had some files defined as TopSpeed and others as ASCII
then you would distribute both C60TPSX.DLL and C60ASCX.DLL.
Please refer to the Clarion Database Drivers PDF for the names of other driver DLLs.
IP Client Applications
In addition to the files you would normally distribute, your client application also needs:
LIBEAY32.DLL (IP Driver support library)
SSLEAY32.DLL (IP Driver support library)
OSSLWRAP.DLL (IP Driver support library)
IP Data Server (IPDS) Distribution
In accordance with the license terms of the IPDS you can redistribute the IPDS files with your application. The license is
installed in the root directory of the IP Data Server (by default, C:\ClarionDataServer). Any distributions of the IP Data
Server must include the SoftVelocity IP Driver and Data Server license text as installed to IPDSlicense.txt.
The IP Data Server requires the following files:
Claipdat.exe
IPReq.exe
Libeay32.dll
Ssleay32.dll
IPDSlicense.txt
If you are using SSL connections you also need to ship an appropriate server.pem file. (See the SSL Deployment
Considerations section in this manual for more information).
You are also licensed to distribute the Java Remote Administrator Console (rmadmin.jar) and this PDF manual.
IP Driver and Server Reference
113
How to Distribute the IP Data Server
We recommend the use of Lindersoft's SetupBuilder tool for your installation program. Lindersoft's SetupBuilder 5 makes
it easy to properly distribute the IP Data Server, with built-in support for the IP server. The developer only has to enter the
location of his IP Data Server and all the required files are linked into the Setup.exe and the service is set to install.
More information regarding the use and purchase of SetupBuilder can be found at http://www.lindersoft.com/
You can "pre-register" the Data Manager DLL(s) that your applications use. To do this, follow these steps on your
development machine:
1.
2.
3.
4.
Stop the SoftVelocity IP Data Driver service. (see page 8).
Delete or rename ipreq.cfg (located in the root of the Data Server directory).
Start the SoftVelocity IP Data Driver service.
Using the RMadmin application, "Register" the required Data Manager DLLs, create user accounts (if needed),
and then set the appropriate file access permissions.
The ipreq.cfg you just created now contains the Data Manager DLL entries, and can now be deployed as part of your
installation of the IP Data server.
114
IP Driver and Server Reference
Distributed Applications
Divided
When you IP-enable your application, you are dividing your application to run in separate processes. The processes may
run on the same machine (if the machine is running the SoftVelocity IP Data Server service), or they may be run on two or
more machines.
Separate Processes
Keep in mind that the process (code) executing on the Data Manager DLL on the server does not have access to any
variables defined in your Client application, except for values in record buffers. You can however use the
RemoteExecute() procedure to “SEND” values of variables to the server.
Advanced
With some careful planning you can use the RemoteExecute() procedure to offload work to the server. RemoteExecute()
can also be used to spawn other processes, but remember that if you do start a new process it is detached from control
by your client application.
IP Driver and Server Reference
115
Globalization
Globalization (also known as internationalization) is also supported in your IP Driver Client applications as well as the
Data Manager you create for the IP Data Server.
An environment file contains internationalization settings for an application. On program initialization, the Clarion run-time
library attempts to locate an environment file with the same name and location as your application's program file (i.e.,
appname.ENV).
If you are using an environment file to specify internationalization settings for your application you will need to deploy the
.ENV file with both client and server applications. You can use the Program Setup embed point in the appropriate Data
Manager DLL to call the LOCALE() procedure.
Example:
LOCALE('ip_people.env')
LOCALE('CLACOLSEQ','DdCcBbAa')
Some Environment file options may not be applicable in an IP-enabled application:
•
•
Use of CLABUTTON
Errors returned by the client application are extended errors, and cannot be changed with the Environment file.
For more information regarding globalization, please refer to the Environment Files topic found in the Clarion online help.
116
IP Driver and Server Reference
Performance Tips
The real measure to look at for maximum performance is a result of several factors:
1. The number of "different" applications that run on the server (e.g., the Data Manager DLLs). The Windows operating
system shares the code sections from the "same" DLLs amongst running processes, so if the applications are all using
the same Data Manager then the OS will use less memory then it would if many clients each connected to unique Data
Managers.
2. The number of threads open in the client program (each thread in the client has a mirrored thread on the server)
There is a limit in the OS of ~32000 threads, but really the OS slows down well before that limit, if too many threads are
actively seeking time slices.
3. The amount of memory in the server (obviously the more the better).
4. The CPU in the server (obviously the faster the better).
5. If the data is local to the IP server then the hard drive access speed is also a factor
The IP architecture is superb for scalability because:
1. A client program can connect simultaneously to several IP servers, so memory usage and data loads can be spread
over different machines.
2. You can have several IP servers, and each server may access common data, and Data Managers may access data on
any machine in the network.
3. A combination of 1 and 2.
Performance over ADSL will be a direct function of the latency in the routers between the client and the server.
If you run a “traceroute” or a path ping you can see where any routers are slowing down the network connection from
client to server.
With the combination of the IMDD (in Version 2.0) you can also cache data in the client, thereby reducing the effects of
latency if it becomes an issue.
IP Driver and Server Reference
117
Troubleshooting
Problem: I am having a problem starting the Remote Administrator Console.
Solution: Make sure that you have the Java SDK or JRE versions 1.4 or greater installed on your development machine.
The JRE (Java Runtime Environment) is a free download available at www.java.com or java.sun.com
After installing, you should be able to run the rmadmin.jar program by simply double-clicking on it. The RUN.BAT file will
only run the console properly if the environment JAVA_HOME path variable is properly set.
Problem: I’ve started the Remote Administrator Console, but cannot log in (Connect to the IP Data Server)
Solution: The first time you use the Remote Administrator Console, enter a User name of Administrator, and leave the
Password entry blank. If you are already using the default port of 2339 in another service, you may have to modify the
claipsrv.ini entries to reflect a different port address.
EXAMPLE claipsrv.ini contents:
[REQUESTER]
PORT=2339
PORT_SSL=2340
Problem: I am running my first IP Client application, and receive the following message:
“Error: Entry Point not found for ordinal #### in LIBEAY32.DLL”
Solution: Both LIBEAY32.DLL and SSLEAY32.DLL are used by other products. Your client application is finding older
copies of these files on the system PATH. The correct copies are installed in the Clarion6/BIN folder. Copy both DLLs to
the folder that contains the IP Client application.
Problem: Can I use the IP Driver to connect to an ODBC data source?
Solution: When any application is running as a Windows service (as in the SoftVelocity IP Data Server), the ODBC data
source must be identified as a System Data Source (or System DSN).
Problem: Does the IP Driver support the UNC (Uniform Naming Conventions) for tables?
Solution: Yes, but you need to configure the SoftVelocity IP Data Server Service to allow access to the network. For
more details on how to do this, please refer to the UNC support for the SoftVelocity IP Data Server Service section in this
document.
Problem: What about using the IP Driver to connect to a mapped drive?
Solution: A service should not directly access local or network resources through mapped drive letters. Additionally, a
service should not use the WNetxxxx APIs to add, remove, or query any mapped drive letters. Although the WNetxxxx
APIs may return successfully, the results will be incorrect. A service (or any process that is running in a different security
context) that must access a remote resource should use the Universal Naming Convention (UNC) name to access the
resource.
118
IP Driver and Server Reference
Problem: I just installed the IP Data Server on a Windows XP (Service Pack 2) machine, and tried to connect to my data
from another machine, but I could not connect. What might be the problem?
Solution: Windows XP SP2 now has default firewall protection installed. There are two things that you can do:
1) Add the 2339 default IP Server port to the windows firewall "Exceptions" tab.
or
2) Add the IPREQ.EXE Data Server executable to the windows firewall "Exceptions" tab.
To add exceptions, go to Windows Firewall in Control Panel. To open Windows Firewall, click Start, click Control
Panel, and then double-click Windows Firewall.
Problem:
On occasion, my client application may receive a “Socket Error” when losing an IP connection. What is the best way to
handle this under program control? What must be done to re-establish a connection?
Solution:
The new connection protocol in Version 1.3 allows you to re-establish any connection easily if you should lose it for any
reason. Two steps are needed. First, make sure that all IP tables are closed in your application. This can be done by
calling a custom “CloseAll” procedure that checks the STATUS of each table, and closes them if needed. Second, reopening any table will establish a new connection if it is available.
Problem:
I have just reinstalled a new version of the IP Server, and now I cannot see any of my new Data Managers to register in
the pop up list?
Solution:
It is possible that your ipreg.cfg file needs to be re-initialized. Use the IPSRVMGR.exe (Delete Config File) to remove the
ipreq.cfg, and then restart the Remote Administrator.
Problem:
I have an executable located in the ClarionDataManager folder. The executable (backup.exe) may create a backup file on
another computer on the network. If the executable is run via RUN('Backup.exe') from the Data Manager DLL as a remote
procedure (called from the IP Client application) any attempt to create the file on another computer on the network or
create a new folder does not work. It is as if normal network permissions as far as file copying or folder creation are not
allowed when attempted from the Data Manager DLL.
Solution:
Make sure that the SoftVelocity IP Data Server service Log On option is using an account that has the proper
permissions set. Do not use the Local System account option.
IP Driver and Server Reference
119
Index
Aborted..........................................................................87
Account Administration view .......................................103
Active Table view ........................................................101
Aliases.........................................................................105
BeforeOpen ...................................................................59
Cancel ...........................................................................87
CloseConnection...........................................................78
Connection Errors .......................................................107
custom procedure .........................................................38
Customer Permissions ................................................104
Data Manager................................................................44
Data Manager Aliases.................................................105
Data Manager DLL Wizard............................................35
DebugView Support ......................................................39
deployment notes..........................................................28
Details pane ................................................................100
Driver, IP .........................................................................7
DynFile Class ................................................................73
Examples.......................................................................56
Exec ..............................................................................75
Extended Server Support Extensions – Client..............47
File Transfer ..................................................................56
File Transfer Embed Points...........................................64
file transfers...................................................................38
Filtering Rules ...............................................................72
Finish.............................................................................87
firewall .........................................................................118
From List
Connection Type .......................................................45
GetAction.......................................................................90
GetAllowPause..............................................................90
GetBuffersPerCycle ......................................................88
GetConnectionString...............................................74, 80
GetError...................................................................83, 88
GetErrorCode ..........................................................83, 88
GetFileName .................................................................76
GetFName.....................................................................58
GetRemoteFileName ....................................................81
GetRemoteVariable.......................................................77
GetSilent........................................................................83
GetTimer .......................................................................89
Globalization................................................................115
Imported Procedures.....................................................47
Init..................................................................................82
InitReceive.....................................................................85
InitSend .........................................................................84
Install Considerations....................................................12
IP Client Global Extension ............................................42
IP Data Server Service..................................................13
IP Driver ..........................................................................7
ODBC ......................................................................117
IPC File Defined ............................................................24
IPChangeFileName Code Template .............................49
IPDRV = TRUE .............................................................31
IPDRV Extended ...........................................................39
IPDRV Extended Server Embeds .................................62
IPDRV Extended server support................................... 38
IPEXEC................................................................. 60, 109
IPEXEC Code template ................................................ 50
IPEXEC Dispatch.......................................................... 62
IPEXEC Source Procedure Template........................... 41
IPExtended Class ......................................................... 73
IPFileTransfer Class ............................................... 73, 80
IPGetFileName ............................................................. 63
IPGetRemoteVariable................................................... 54
IpIsAlive ........................................................................ 52
IPKeepAlive .................................................................. 53
IPRequestCount............................................................ 65
IPS file defined.............................................................. 23
IPServer template ......................................................... 33
IPSetFileName.............................................................. 63
IPSetRemoteVariable ................................................... 54
IPTransferFile Control Template................................... 55
IPTransferFileCode Code Template ................. 51, 52, 53
IsAlive ........................................................................... 78
Java SDK or JRE versions ......................................... 117
LEDGER ....................................................................... 56
LIBEAY32.DLL.............................................................. 26
Mapped Drives.................................................... 117, 118
MFC42.DLL................................................................... 26
MSVCP60.DLL.............................................................. 26
MSVCRT.DLL ............................................................... 26
Multidataset................................................................... 56
Multiple Request Packets ......................................... 9, 65
NOMEMO ............................................................... 66, 71
ODBC.......................................................................... 117
OSSLWRAP.DLL .......................................................... 26
Pause............................................................................ 87
Performance Tips........................................................ 116
Receive ......................................................................... 87
Register
IP Driver .................................................................... 10
Templates.................................................................. 10
Remote Administrator ................................................... 97
Account Administration View................................... 103
Active Table view .................................................... 101
Customer Permissions ............................................ 104
Details Pane ............................................................ 100
Main Menu................................................................. 98
Server Settings........................................................ 105
Sessions View ......................................................... 100
Table Maintenance view ......................................... 102
Toolbar ...................................................................... 99
Tree View Pane......................................................... 99
remote procedure calls ................................................. 38
Remote Variables ......................................................... 48
runtime file name variables........................................... 38
Runtime Names ............................................................ 40
Send.............................................................................. 87
Server Settings ........................................................... 105
Server Side VIEWs ....................................................... 72
Server Variables ........................................................... 40
120
Server-side VIEWS .........................................................9
Services.........................................................................13
Sessions view..............................................................100
SetAllowPause ..............................................................90
SetBuffersPerCycle.......................................................88
SetConnectionString ...............................................74, 80
SetControls....................................................................81
SetFileName............................................................76, 79
SetKeepAlive.................................................................79
SetRemoteVariable .......................................................77
SetSilent ........................................................................83
SetSourceFileName ......................................................81
SetTargetFileName .......................................................81
SetTimer........................................................................89
Socket errors .................................................................92
IP Driver and Server Reference
SoftVelocity IP Data Server Service ............................. 13
SSL ............................................................................... 29
SSLEAY32.DLL ............................................................ 26
Start .............................................................................. 87
StartTimer ..................................................................... 91
StopTimer ..................................................................... 91
SwapPauseText............................................................ 91
Table Maintenance view ............................................. 102
Table Permissions ................................................ 27, 104
TakeEvent..................................................................... 86
thread...................................................................... 15, 40
Tree View Pane ............................................................ 99
UNC ............................................................................ 117
UNC support ................................................................. 96
Windows Firewall ........................................................ 118