![]() |
![]() |
|
|
Configuring BEA eLink TCP for Tuxedo for Data Mapping
The key to the high degree of transparency between systems is the eLink for Mainframe TCP for Tuxedo (hereafter referenced as eLink TCP for Tuxedo) configuration. Environmental differences, such as data formats, are concealed from programmers and programs through this mechanism.
This document provides information about the following topics:
This document also provides information about creating VIEW definitions. VIEW definitions are descriptions of data structures that are used for input and output in the BEA Tuxedo environment. The eLink TCP for Tuxedo product uses VIEW definitions to determine how to convert input data and output data into formats that are acceptable to target systems.
For detailed information about updating the eLink TCP for Tuxedo configuration files (GWICONFIG and DMCONFIG), see the Configuring BEA eLink TCP for Tuxedo section.
Note: The task of configuring data mappings could be considered a programming activity because it requires knowledge of the BEA Tuxedo programming environment. However, because configuration parameters affect many application programs, configuration is usually an administrator's responsibility.
Converting Input and Output Data
This section introduces procedures that eLink TCP for Tuxedo follows to process and convert input and output data.
Buffers and Records
In this guide, the following terms are used to describe input and output data.
These terms make it easier to understand how eLink TCP for Tuxedo handles input and output data.
Buffers Received from Local Programs
The eLink TCP for Tuxedo gateway processes buffers from local programs in the following manner.
The eLink TCP for Tuxedo product automatically "types" input buffers that local client programs send to remote services.
The eLink TCP for Tuxedo product automatically "types" output buffers that local services return to remote client programs.
Client requests sent to remote services may need to be converted to record formats that are meaningful to those services.
Server responses returned to remote client programs may need to be converted to record formats that are meaningful to those programs.
Records Received from Remote Programs
The eLink TCP for Tuxedo gateway processes buffers from remote programs in the following manner.
Client requests from remote client programs may need to be converted to buffer formats that are acceptable to local service routines.
Server responses returned from remote services may need to be converted to buffer formats that are acceptable to local client programs.
Managing Parameters for Buffer and Record Conversion
The eLink TCP for Tuxedo product provides four configuration parameters you can use to map buffers and records. For more information about buffers and records, see the Buffers and Records section.
Specify the following buffer configuration parameters in the domain configuration file (DMCONFIG).
Specify the following record configuration parameters in the gateway configuration file (GWICONFIG).
Each of these four parameters has two possible meanings or interpretations—one for service requests that originate locally, and one for service requests that originate on remote systems.
The following sections, Parameters for Locally Originated Calls and Parameters for Remotely Originated Calls, explore these different meanings in detail.
Parameters for Locally Originated Calls
This section takes a closer look at how eLink TCP for Tuxedo handles service calls that originate locally, within the immediate BEA Tuxedo region. Also, it explains how the INBUFTYPE, INRECTYPE, OUTRECTYPE, and OUTBUFTYPE parameters can be used to manage the conversion of buffers and records that flow between local client programs and remote services.
In the following figure, a local BEA Tuxedo client program issues a service call that a local eLink TCP for Tuxedo gateway routes to a remote server through eLink TCP for Tuxedo.
Figure 3-1 How Parameters Are Mapped During Locally Originated Calls
In this situation, the four configuration parameters that are shown in the figure have the following meanings:
Guidelines for Mapping Input Buffers to Input Records
The following sections provide detailed information explaining how to use the INBUFTYPE and INRECTYPE parameters for service calls that originate locally (where local client programs call remote services).
Guidelines for Mapping Output Records to Output Buffers
The following sections provide detailed information explaining how to use the OUTRECTYPE and OUTBUFTYPE parameters for service calls that originate locally (where local client programs call remote services and receive output from those services).
Parameters for Remotely Originated Calls
This section takes a closer look at how eLink TCP for Tuxedo handles service calls that originate on remote computers, outside the local BEA Tuxedo region. Also, it explains how the INRECTYPE, INBUFTYPE, OUTBUFTYPE, and OUTRECTYPE parameters can be used to manage the conversion of buffers and records that flow between remote client programs and local services.
In the following figure, a remote client program issues a service request that a remote eLink TCP gateway routes to the local eLink TCP for Tuxedo gateway. The gateway receives the request from the network and passes the request to a local BEA Tuxedo server.
Figure 3-2 How Parameters Are Mapped During Remotely Originated Calls
In this situation, the four configuration parameters that are shown in the figure have the following meanings:
Guidelines for Mapping Input Records to Input Buffers
The following sections provide detailed information explaining how to use the INRECTYPE and INBUFTYPE parameters for service calls that originate on remote systems (where remote client programs call local services).
Guidelines for Mapping Output Buffers to Output Records
The following sections provide detailed information explaining how to use the OUTBUFTYPE and OUTRECTYPE parameters for service calls that originate on remote computers (where remote client programs call local services and receive output from those services).
Mapping Buffers to Records
The following figure shows all the possibilities for mapping buffers to records. The eLink TCP for Tuxedo gateway is responsible for mapping buffers to records, based on information it finds in the eLink TCP for Tuxedo configuration. This mapping occurs for Tuxedo client requests and Tuxedo server responses.
Figure 3-3 Buffer to Record Mappings
Setting the INBUFTYPE and INRECTYPE Parameters The following table lists some of the mapping possibilities that are shown in the previous figure and some suggestions for setting the INBUFTYPE and INRECTYPE parameters.
Mapping Records to Buffers
The following figure shows all the possibilities for mapping records to buffers. The eLink TCP for Tuxedo gateway is responsible for mapping records to buffers, based on information it finds in the eLink TCP for Tuxedo configuration. This mapping occurs for remote client requests and remote server responses.
Figure 3-4 Record to Buffer Mappings
Setting the OUTRECTYPE and OUTBUFTYPE Parameters The following table lists some of the mapping possibilities that are shown in the previous figure and some suggestions for setting the OUTRECTYPE and OUTBUFTYPE parameters (for service calls that originate locally).
Creating VIEW Definitions to Facilitate Buffer Conversion
VIEW definitions are used to describe input and output records that are sent to and received from remote systems. They describe data elements and indicate how data elements are typed and sequenced. Based on these descriptions, eLink TCP for Tuxedo translates field data types as required to maintain transparency between dissimilar systems.
You should create VIEW definitions before you configure eLink TCP for Tuxedo. For complete information about VIEW definitions and related topics, see the BEA Tuxedo Programmer's Guide.
The eLink TCP for Tuxedo buffer and record conversion capabilities are extremely powerful and flexible. The key to maximizing these capabilities is to thoroughly understand the BEA Tuxedo VIEW definition mechanism.
VIEW definitions make it possible to specify composite data structures that can be used:
Preparing VIEW Definitions
After determining the input and output record layouts for the remote application programs you are working with, you need to prepare VIEW definitions and specify these definitions in the configuration files.
Note: FML fields must be specified for all VIEWs that eLink TCP for Tuxedo converts. In other words, any VIEW that you specify as an INRECTYPE, OUTRECTYPE, INBUFTYPE, or OUTBUFTYPE must be defined with appropriate FML fields (no dashes in the FNAME column of the VIEW definition). For the FML fields to match, you must compile these VIEWs without the -n option specified.
For detailed information about configuring eLink TCP for Tuxedo, see the Configuring BEA eLink TCP for Tuxedo section.
Translating Data
When a local client program sends data to (or receives data from) a service routine on a different kind of computer, eLink TCP for Tuxedo automatically translates data as required. Translation involves changing the representation of intrinsic data types by changing attributes such as word length and byte order.
The eLink TCP for Tuxedo gateway automatically translates input and output data as required, following rules that are described in the following section. Read the information carefully before you create VIEW definitions (to facilitate buffer conversion) and configure eLink TCP for Tuxedo.
Basic rules for how eLink TCP for Tuxedo translates data are described in the following subsection. For detailed information about how eLink TCP for Tuxedo handles string and numeric data, refer to the NULL Characters in String Length Calculations (C Programs) section.
Data Translation Rules
The following information outlines the data translation rules that eLink TCP for Tuxedo follows:
Warning: dec_t cannot be used with VIEW translations.
Note: BEA Tuxedo provides a field type named dec_t that supports decimal values within VIEWs. The eLink TCP for Tuxedo gateway translates these fields into machine independent representations of packed decimals. For example, dec_t(m,n) becomes S9(2*m-(n+1))V9(n) COMP-3. Therefore, a decimal field with a size of 8,5 corresponds to S9(10)V9(5) COMP-3.
The following table summarizes the relationships.
NULL Characters in String Length Calculations (C Programs)
When you create VIEW definitions for input and output buffers that are used by C language applications, you must specify extra characters for terminating NULL characters that are used in string fields.
For example, when a local application program expects a 10-byte string in an output buffer, you would specify 11 for that field—10 for the string plus 1 for the terminating NULL character.
NULL Characters in String Length Calculations (COBOL Programs)
When you create VIEW definitions for input and output buffers that are used by COBOL language applications, do not specify extra characters for terminating NULL characters that are used in string fields.
For example, when a remote COBOL application program expects 10 characters in an input record, you would specify 10 for that field, not 10 plus 1 (for the terminating NULL character).
Note: Although eLink TCP for Tuxedo does not require strings to be NULL-terminated, it respects NULL termination. Therefore, when eLink TCP for Tuxedo detects a NULL (zero) character within a string, it does not process any subsequent characters. To pass full 8-bit data that contains embedded NULL values, use a CARRAY type field or buffer.
The eLink TCP for Tuxedo product provides standard character translation from ASCII-to-EBCDIC and EBCDIC-to-ASCII. eLink TCP for Tuxedo automatically performs this translation on the STRING data type.
Converting Numeric Data
Numeric data can easily be converted into different data types, provided that you have enough range in the intermediate and destination types to handle the maximum value you need to represent.
For example, you can convert numeric values into strings (and the reverse). For example, while FML buffers do not directly support the dec_t type, you can place decimal values in STRING fields and map these to dec_t fields within VIEW definitions.
Encoding COBOL Data Types
An additional encoding library, ConvMVSC, has been included for Tuxedo clients using COBOL data types. This library, ConvMVSC, is similar to the default library, ConvMVS, but differs in the following ways:
Using the COBOL Data Encoding Library
There are two methods for enabling the COBOL data encoding library:
Encoding for All Services
To enable COBOL data encoding for every service in the gateway, set the parameter DFLTTYPE="MVSC" in the GLOBAL section of the GWICONFIG file.
Listing 3-1 Encoding for All Services
*GLOBAL
DFLTTYPE="MVSC"
Encoding Messages To and From a Specific Host
To enable COBOL data encoding for messages to and from a specific host, set the parameter TYPE="MVSC" for that hosts FOREIGN entry in the GWICONFIG file.
Listing 3-2 Encoding for Messages To and From a Specific Host
*FOREIGN
HOST_NAME
TYPE="MVSC"
Using Code Page Translation Tables
The eLink TCP software includes translation tables which enable conversions of single byte character sets (SBCS) between ASCII and EBCDIC. These tables are based on IBM-defined code sets and include the default Tuxedo code page, which is the default code page translation table used in previous releases of eLink TCP.
Each translation table consists of two mapping tables, one for outbound conversions (Tuxedo to mainframe) and one for inbound conversions (mainframe to Tuxedo). You do not have to specify the direction of a translation; however, you must determine the national language in which the host application is written. The following figure illustrates code page translation.
Figure 3-5 eLink TCP Code Page Translation
The figure demonstrates how a Tuxedo application using the Latin-1 ASCII code page CP-00819 character set operates with a host application using German EBCDIC code page CP-00273. The eLink TCP translation table 00819x00273 provides both the inbound and outbound conversions. Specifying a Translation Table To designate the translation table for your applications, make an entry in the DMCONFIG file definition for each remote domain. Use the CODEPAGE parameter in the DM_REMOTE_DOMAINS section of the DMCONFIG file. Specify the translation table to use. To specify a default code page translation for remote hosts to use, specify the translation table filename in the CODEPAGE parameter for the local gateway entry in the DM_LOCAL_DOMAINS section of the DMCONFIG file. The following table lists the translation tables provided with the eLink TCP software. Table 3-1 eLink TCP Code Page Translation Tables
Note: The Tuxedo default ASCII and EBCDIC code pages differ slightly from CP-00819 and CP-00037. How the Translation Tables Work At start up, the eLink TCP for Tuxedo gateway loads a translation table for each remote domain. You can modify any of the tables to suit your application translation needs, except the default Tuxedo tables, which are hard-coded. You must restart the gateway to change any translation table definitions. The eLink TCP translation tables are located in $TUXDIR/udataobj/codepage. For table contents, refer to the Code Page Translation Tables section. If no CODEPAGE specification is made for a remote domain, the eLink TCP for Tuxedo software uses the Tuxedo default translation tables. Note: Copies of the default Tuxedo translation tables are included with your product software in $TUXDIR/udataobj/codepage. These copies are provided for you to apply modifications if necessary for your applications. These copies are not the actual default tables used by the gateway. You cannot modify the default Tuxedo tables because they are hard-coded. Troubleshooting Translation Table Errors The following information assists you in resolving errors associated with translation tables that cause the gateway to fail. The gateway issues the following message when encountering an error associated with the specified translation table. For a description of error messages, refer to the Error and Information Messages section. The following causes may be responsible for the gateway issuing the previous error.
1072:ERROR Cannot read CODEPAGE <filename> for <LOCAL | REMOTE> DOMAIN <domainname>
Verify that you specified the correct codepage name in the CODEPAGE parameter in the DM_REMOTE_DOMAIN section of the DMCONFIG file and that the file resides in $TUXDIR/udataobj/codepage.
Verify that the file name specified for the CODEPAGE parameter is valid. Also, verify that the specified file is not corrupt.
Verify that the specified translation table file in the $TUXDIR/udataobj/codepage directory has read permissions.
Sample DMCONFIG Definition for ASCII to EBCDIC Translations
The following listing shows entries defining one local domain (CIXA) and two remote domains (CISA and IMSA). In the following example, it is assumed that the local domain uses ASCII code page CP-00819 and the two remote domains use the German and French EBCDIC code pages CP-00273 and CP-00297, respectively.
Listing 3-3 Code Page Definition Example
# DMCONFIG
*DM_LOCAL_DOMAINS
CIXA
TYPE=IDOMAIN
*DM_REMOTE_DOMAINS
CISA
TYPE=IDOMAIN
CODEPAGE=00819X00273
IMSA
TYPE=IDOMAIN
CODEPAGE="00819X00297"
![]() |
![]() |
![]() |
|
Copyright © 2001 BEA Systems, Inc. All rights reserved.
|