DataStage Commands PDF
DataStage Commands PDF
Version 8 Release 7
Programmer's Guide
SC19-3449-01
IBM InfoSphere DataStage
Version 8 Release 7
Programmer's Guide
SC19-3449-01
   Note
  Before using this information and the product that it supports, read the information in “Notices and trademarks” on page
  127.
iv     Programmer's Guide
Chapter 1. Command line interface
                          The InfoSphere® DataStage® CLI comprises four groups of commands, one for
                          running jobs, one for administering projects, one for importing objects, and one for
                          checking and repairing objects.
                          The command options used with the dsjob command give you access to the same
                          functionality as the InfoSphere DataStage API functions described in “API
                          Functions” on page 33 or the BASIC functions described in “InfoSphere DataStage
                          BASIC Interface” on page 90.
                          There is a single command, dsjob, with a large range of options. These options are
                          described in the following topics:
                          v The logon clause
                          v Starting a job
                          v   Stopping a job
                          v   Listing projects, jobs, stages, links, and parameters
                          v   Setting an alias for a job
                          v   Retrieving information
                          v   Accessing log files
                          v   Generating a report
                          All output from the dsjob command is in plain text without column headings on
                          lists, or any other sort of description. This enables the command to be used in shell
                          or batch scripts without extra processing.
                         You can use encrypted credentials and encrypted parameter file values in your
                         dsjob commands so that you can avoid typing clear data on the screen when you
                         run commands in the command line. See the Encrypt command documentation in
                         the IBM® InfoSphere Information Server Administration Guide for information
                         about this command.
                         Procedure
                         1. Encrypt your information by running the encrypt command, and copy and
                            save the encrypted values in a file:
                            v If you are encrypting credentials, create the credentials file (*.txt) and
                              securely store the file. See the topic on the credentials file for restrictions and
                              sample contents for the credentials file.
                            v If you are encrypting job parameter values, store the encrypted values in the
                              appropriate job parameters file by copying the encrypted output and pasting
                              the value in the job parameter file. For example:
                               job_parameter_name=encrypted_job_parameter_value
                               You can create aliases for the job parameter values. You cannot encrypt job
                               parameter names.
                            Save the file.
                         2. Run the dsjob command. You can enter your credentials securely by using one
                            of these methods:
                            v Using the credentials file. If you are running a dsjob command that requires
                               your user credentials, run your command with the -authfile parameter and
                               specify the full path of the credentials file that you want to use. A sample
                               syntax for using the -authfile parameter in a dsjob command that uses a
                               parameters file with encrypted data is as follows:
                               dsjob -authfile c:\cred_file.txt
                                -run -paramfile c:\paramfile.txt dstage1 testJob
                            v Credentials prompting. If you are not using a credentials file and are instead
                              specifying credential data through the command line, specify only the
                              -domain and -server options, and you will receive prompts for the user
                              name and password. (The password is hidden in the command window.) If
                              you include the -domain, -server, and -user parameters in your command,
                              then you will be prompted for the password. Here is a sample command and
                              interaction:
                               C:\IBM\InformationServer\Clients\Classic>dsjob
                               -domain [2002:920:c000:217:9:32:217:32]:9080 -server RemoteServer
                               -ljobs newTest
                               Please type user name:admin
                               Please type password:
                               Job_ODBC
                               Job_UDT5
                               Job_UDT6
                               Job_Universe
                               PXJob_DC
                               Sequence_ODBC
                               Sequence_UDT5
                               Sequence_UDT6
                               Sequence_Universe
Status code = 0
2   Programmer's Guide
The logon clause
      By default, the InfoSphere DataStage CLI connects to the engine on the local
      system using the user name and password of the user running the command.
      You can specify a different domain, engine, user name, or password using the
      logon clause, which is equivalent to the API DSSetServerParams function. Its
      syntax is as follows:
      [-domain domain_name ][ -user username ][ -password password ][ -server enginename ]
      domain_name specifies the domain to log on to. For dsjob, you can set -domain NONE
      to log on to the engine rather than the domain. In this case the user name and
      password are for the engine, not for the domain.
      If you do not want to type your credentials in the command line and you do not
      want to use a credentials file, specify only the -domain and -server options, and
      you will receive prompts for the user name and password. (The password is
      hidden as you type in the command window.) If you include the -domain, -server,
      and -user parameters in your command, then you will be prompted for only the
      password. Here is a sample command and interaction:
      C:\IBM\InformationServer\Clients\Classic>dsjob
      -domain [2002:920:c000:217:9:32:217:32]:9080 -server RemoteServer
      -ljobs newTest
      Please type user name:admin
      Please type password:
      Job_ODBC
Status code = 0
      For computers that do not use the default ports, to connect to a project that is on a
      local server, specify the -server option with only the port number and do not
      specify the server name. You do not need to specify your user name and password.
      For example: dsjob -server :31539 -lprojects
      For a more secure login for the dsjob command, you can use a credentials file that
      can contain encrypted data:
      -authfile credentials_filename
Note: The -authfile credentials file can also contain unencrypted data.
      For the dsjob command, you can also use the command:
      -file credentials_filename NONE enginename
enginename specifies the engine for which the file contains logon details.
                         -authfile credentials_filename is the full path and name of the file that contains the
                         logon details. This file supports encrypted and unencrypted data. See The
                         credentials file for details and sample contents for the file.
                         -file filename is the full path and name of the file that contains the logon details.
                         This file supports only unencrypted data. The file should contain the following
                         information if logging on to the domain:
The file must contain the following information if logging on to the engine:
You can use the logon clause with any CLI command.
                         Including the logon clause in your commands can expose your username and
                         password. It is better to use the -authfile option and hold the encrypted logon
                         information in a separate file, or to let the computer prompt you for your
                         password.
             Starting a job
                         You can start, stop, validate, and reset jobs using the -run option.
                         dsjob -run
                         [ -mode [ NORMAL | RESET | VALIDATE | RESTART ] ]
                         [ -param name=value ]
                         [ -paramfile filename ]
                         [ -warn n ]
                         [ -rows n ]
                         [ -wait ]
                         [ -stop ]
                         [ -jobstatus ]
                         [ -userstatus ]
                         [ -local ]
                         [ -opmetadata [ TRUE | FALSE ] ]
                         [ -disableprjhandler ]
                         [ -disablejobhandler ]
                         [ -useid ] project job | job_id
                         -mode specifies the type of job run. NORMAL starts a job run, RESET resets the
                         job, VALIDATE validates the job, and RESTART resumes a restartable job sequence
                         from the last checkpoint using the original job parameter values. If -mode is not
                         specified, a normal job run is started.
                         -param specifies a parameter value to pass to the job. The value is in the format
                         name=value, where name is the parameter name, and value is the value to be set. If
                         you use this to pass a value of an environment variable for a job (as you might do
                         for parallel jobs), you need to quote the environment variable and its value, for
                         example -param '$APT_CONFIG_FILE=test.apt' otherwise the current value of the
                         environment variable will be used.
4   Programmer's Guide
      -paramfile specifies a file that contains parameter values to pass to the job. The
      parameter values are in the same format as the values specified for -param. If a
      parameter name is specified by both -param and -paramfile, the last value
      specified is passed to the job.
-wait waits for the job to complete (equivalent to the DSWaitForJob function).
      -jobstatus waits for the job to complete, then returns an exit code derived from the
      job status.
      -userstatus waits for the job to complete, then returns an exit code derived from
      the user status if that status is defined. The user status is a string, and it is
      converted to an integer exit code. The exit code 0 indicates that the job completed
      without an error, but that the user status string could not be converted. If a job
      returns a negative user status value, it is interpreted as an error.
      -local use this when running a job from within a shell script on a UNIX system.
      Provided the script is run in the project directory, the job will pick up the settings
      for any environment variables set in the script and any setting specific to the user
      environment.
      -opmetadata use this to have the job generate operational metadata as it runs. If
      you specify TRUE, operational metadata is generated, whatever the default setting
      for the project. If you specify FALSE, the job will not generate operational
      metadata, whatever the default setting for the project.
      -disableprjhandler use this to disable any error message handler that has been set
      on a project wide basis.
      -disablejobhandler use this to disable any error message handler that has been set
      for this job.
      -useid specify this if you intend to use a job alias (jobid) rather than a job name
      (job) to identify the job.
job is the name of the job. To run a job invocation, use the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
Stopping a job
      You can stop a job using the -stop option.
      dsjob -stop [-useid] project job|job_id
                         -useid specify this if you intend to use a job alias (jobid) rather than a job name
                         (job) to identify the job.
job is the name of the job. To stop a job invocation, use the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
The different versions of the syntax are described in the following sections.
Listing projects
                         The following syntax displays a list of all known projects on the server:
                         dsjob -lprojects
Listing jobs
                         The following syntax displays a list of all jobs in the specified project:
                         dsjob -ljobs project
                         The following syntax displays a list of all jobs in the specified project with specific
                         job status values:
                         dsjob -ljobs [-status status_list] project
                         The following command lists all jobs in the dstage1 project with statuses of
                         DSJS_CRASHED or DSJS_STOPPED:
                         dsjob –ljobs -status 96/97 dstage1
Listing stages
                         -useid specify this if you intend to use a job alias (jobid) rather than a job name
                         (job) to identify the job.
6   Programmer's Guide
project is the name of the project containing job.
job is the name of the job containing the stages to list. To identify a job invocation,
use the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
Listing links
The following syntax displays a list of all the links to or from a stage:
dsjob -llinks [-useid] project job|job_id stage
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job is the name of the job containing stage. To identify a job invocation, use the
format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
Listing parameters
The following syntax display a list of all the parameters in a job and their values:
dsjob -lparams [-useid] project job|job_id
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job is the name of the job whose parameters are to be listed. To identify a job
invocation, use the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
Listing invocations
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
                         job is the name of the job whose parameters are to be listed. To identify a job
                         invocation, use the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
                         Other commands can then use that alias to refer to the job.
                         dsjob -jobid [my_ID] project job
                         my_ID is the alias you want to set for the job. If you omit my_ID, the command
                         will return the current alias for the specified job. An alias must be unique within
                         the project, if the alias already exists an error message is displayed.
                         job is the name of the job. To identify a job invocation, use the format
                         job.invocation_id.
             Retrieving information
                         The dsjob command can be used to retrieve and display the available information
                         about specific projects, jobs, stages, or links.
The different versions of the syntax are described in the following sections.
                         The following syntax displays the available information about a specified job:
                         dsjob -jobinfo [-useid] project job|job_id
                         -useid specify this if you intend to use a job alias (jobid) rather than a job name
                         (job) to identify the job.
                         job is the name of the job. To identify a job invocation, use the format
                         job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
8   Programmer's Guide
Displaying stage information
The following syntax displays all the available information about a stage:
dsjob -stageinfo [-useid] project job|job_id stage
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job is the name of the job containing stage. To identify a job invocation, use the
format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job is the name of the job containing stage. To identify a job invocation, use the
format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command
(see “Setting an alias for a job” on page 8).
                          -useid specify this if you intend to use a job alias (jobid) rather than a job name
                          (job) to identify the job.
                          job is the name of the job containing parameter. To identify a job invocation, use the
                          format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
The different versions of the syntax are described in the following sections.
                          The following syntax adds an entry to the specified log file. The text for the entry
                          is taken from standard input to the terminal, ending with Ctrl-D.
                          dsjob -log [ -info | -warn ] [ -useid ] project job|job_id
                          -info specifies an information message. This is the default if no log entry type is
                          specified.
                          -useid specify this if you intend to use a job alias (jobid) rather than a job name
                          (job) to identify the job.
                          job is the name of the job that the log entry refers to. To identify a job invocation,
                          use the format job.invocation_id.
10   Programmer's Guide
job_id is an alias for the job that has been set using the dsjob -jobid command.
-type type specifies the type of log entry to retrieve. If -type type is not specified, all
the entries are retrieved. type can be one of the following options:
This option...
       Retrieves this type of log entry...
INFO Information.
WARNING
     Warning.
FATAL
        Fatal error.
REJECT
      Rejected rows from a Transformer stage.
STARTED
     All control logs.
RESET
        Job reset.
BATCH
        Batch control.
ANY     All entries of any type. This is the default if type is not specified.
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job is the job whose log entries are to be retrieved. To identify a job invocation, use
the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
The following syntax displays the specified entry in a job log file:
dsjob -logdetail [ -useid ] project job|job_id entry
-useid specify this if you intend to use a job alias (jobid) rather than a job name
(job) to identify the job.
job_id is an alias for the job that has been set using the dsjob -jobid command.
entry is the event number assigned to the entry. The first entry in the file is 0.
                          The following syntax displays the ID of the newest log entry of the specified type:
                          dsjob -lognewest [ -useid ] project job|job_id type
                          -useid specify this if you intend to use a job alias (jobid) rather than a job name
                          (job) to identify the job.
                          job is the job whose log entries are to be retrieved. To identify a job invocation, use
                          the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
             Generating a report
                          The dsjob command can be used to generate an XML format report containing job,
                          stage, and link information.
                          dsjob -report [-useid] project job|jobid [report_type]
                          -useid specify this if you intend to use a job alias (jobid) rather than a job name
                          (job) to identify the job.
12   Programmer's Guide
             project is the project containing job.
             job specifies the job to be reported on by job name. To identify a job invocation, use
             the format job.invocation_id.
job_id is an alias for the job that has been set using the dsjob -jobid command.
             You can specify a different domain, engine, user name, or password using the
             logon clause, which is equivalent to the API DSSetServerParams function. Its
             syntax is as follows:
             [-domain domain_name ][ -user username ][ -password password ][ -server enginename ]
                          domain_name specifies the domain to log on to. For dsjob, you can set -domain NONE
                          to log on to the engine rather than the domain. In this case the user name and
                          password are for the engine, not for the domain.
                          If you do not want to type your credentials in the command line and you do not
                          want to use a credentials file, specify only the -domain and -server options, and
                          you will receive prompts for the user name and password. (The password is
                          hidden as you type in the command window.) If you include the -domain, -server,
                          and -user parameters in your command, then you will be prompted for only the
                          password. Here is a sample command and interaction:
                          C:\IBM\InformationServer\Clients\Classic>dsjob
                          -domain [2002:920:c000:217:9:32:217:32]:9080 -server RemoteServer
                          -ljobs newTest
                          Please type user name:admin
                          Please type password:
                          Job_ODBC
Status code = 0
                          For computers that do not use the default ports, to connect to a project that is on a
                          local server, specify the -server option with only the port number and do not
                          specify the server name. You do not need to specify your user name and password.
                          For example: dsjob -server :31539 -lprojects
                          For a more secure login for the dsjob command, you can use a credentials file that
                          can contain encrypted data:
                          -authfile credentials_filename
Note: The -authfile credentials file can also contain unencrypted data.
                          For the dsjob command, you can also use the command:
                          -file credentials_filename NONE enginename
                          domainname specifies the domain for which the file contains logon details. For
                          dsjob, you can set NONE to log on to the engine rather than the domain. In this case
                          the username and password are for the engine, not for the domain.
enginename specifies the engine for which the file contains logon details.
14   Programmer's Guide
      -authfile credentials_filename is the full path and name of the file that contains the
      logon details. This file supports encrypted and unencrypted data. See The
      credentials file for details and sample contents for the file.
      -file filename is the full path and name of the file that contains the logon details.
      This file supports only unencrypted data. The file should contain the following
      information if logging on to the domain:
The file must contain the following information if logging on to the engine:
You can use the logon clause with any CLI command.
      Including the logon clause in your commands can expose your username and
      password. It is better to use the -authfile option and hold the encrypted logon
      information in a separate file, or to let the computer prompt you for your
      password.
Creating a project
      The dsadmin command can be used for creating projects.
      You need to have InfoSphere DataStage administrator status in order to use this
      command:
      dsadmin -createproject ProjectName [-location ProjectLocation]
      -location ProjectLocation is the location of the project in the form of a path name
      and with the project name included. In the following example, test is the project
      name.
      dsadmin -createproject test [-location /u1/IS85/IBM/InformationServer/Projects/test]
Deleting a project
      The dsadmin command can be used for deleting existing projects.
      You need to have InfoSphere DataStage administrator status in order to use this
      command:
      dsadmin -deleteproject ProjectName
      You need to have InfoSphere DataStage administrator status in order to use this
      command:
      dsadmin -oshvisible TRUE | FALSE ProjectName
                          You need to have InfoSphere DataStage administrator status in order to use this
                          command:
                          dsadmin -enablercp TRUE | FALSE ProjectName
                          ProjectName is the project whose parallel jobs are to have runtime column
                          propagation enabled or disabled.
                          You need to have InfoSphere DataStage administrator status to use this command:
                          dsadmin -enablejobadmin TRUE | FALSE ProjectName
                          ProjectName is the project for which job administration in the Director client will be
                          enabled or disabled.
                          The deployment package can include a job report in XML format, and this
                          command enables or disables the generation of this report.
                          dsadmin -enablegeneratexml TRUE | FALSE ProjectName
                          ProjectName is the project whose parallel jobs are to have XML reports enabled or
                          disabled.
                          You need to have InfoSphere DataStage administrator status in order to use this
                          command:
                          dsadmin -advancedruntime "AdvancedRuntimeOptions" ProjectName
                          ProjectName is the project whose parallel jobs will have the specified advanced
                          runtime options set.
16   Programmer's Guide
      This command is only available for parallel jobs.
      To unset the properties repeat the command with an empty string, for example:
      dsadmin -advancedruntime "" myproject
      You need to have InfoSphere DataStage administrator status in order to use this
      command:
      dsadmin -basedirectory BaseDirectoryName ProjectName
ProjectName is the project whose parallel jobs the base directory is being set for.
      You need to have InfoSphere DataStage administrator status in order to use this
      command:
      dsadmin -deploymentdirectory DirectoryTemplate ProjectName
      ProjectName is the project whose parallel jobs are having the deployment directory
      template defined.
      -type specified the type of the environment variable and should be set to either
      STRING or ENCRYPTED.
      -value Value is the value for the new environment variable. Value must be quoted.
      If this is not given, the value for the environment variable will need to be set using
      the dsadmin -envset command.
                          If you are setting a boolean type environment variable, set the value to 1 for TRUE
                          and 0 for FALSE.
                          If you are using $ENV to set the value of an environment variable to its current
                          setting in the environment, then you should use single quotation marks to ensure
                          that it picks up the correct value (for example, dsadmin -envset NEW3 -value
                          '$ENV' dstage).
                          dsadmin -envset EnvVarName -value "Value" ProjectName
-value "Value" is the value for the environment variable and must be quoted.
ProjectName is the project for which the environment variable is being set.
             Listing projects
                          The dsadmin command can be used for listing the projects on an engine tier.
                          dsadmin -listprojects
             Listing properties
                          The dsadmin command can be used for listing the properties of a project.
18   Programmer's Guide
              v   Advanced runtime options for parallel jobs.
              v   Custom deployment commands for parallel jobs.
              v   Deployed job directory template.
              v   Whether job administration is enabled in the Director client or not.
              The parallel job properties will only be listed if parallel jobs are available.
              dsadmin -listproperties ProjectName
              The DSXImportService command has several options. You can use the command to
              import the contents of an entire .dsx file, or specified objects within a .dsx file, and
              you can generate a report of the import process. You can also use the
              DSXImportService command to list the contents of a .dsx file.
              You can run the DSXImportService command on any computer that has ASBNode
              installed.
Purpose
              The DSXImportService command imports the objects from a .dsx file into an IBM
              InfoSphere DataStage repository.
Parameters
              You can specify domain, user name, and password details in a file, or you can
              specify the details directly on the command line. If you specify details in a file,
              you can also specify the details on the command line to override some of the
              contents of the file. For example, you can specify a different domain but take the
              user name and password as specified in the file, so you can use the same file to
              connect to different computers. Specifying user name and password in a file rather
              than on the command line gives greater security.
                          The following syntax specifies connection details directly on the command line:
                          -ISHost isHost[:port]
                          -ISUser isUser
                          -ISPassword isPassword
                          [-DSHost dsHost[:port]]
                          -DSProject dsProject
                          –DSXFile dsxFile
                          [-Overwrite | -OverwriteReadOnly]
                          [-Verbose]
                          [-StopOnError]
                          [selected_import]
                          -ISFile isFile
                                   Specifies the file name that contains the connection details. Using this
                                   option provides a level of security by hiding the login details from view. If
                                   you use this option, you do not have to provide the connection details on
                                   the command line. If any connection details are specified on the command
                                   line, however, they override those defined within the file. The file specifies
                                   the connection details in the following arguments:
                                  -ISHost isHost -ISUser isUser -ISPassword isPassword
                          -ISHost isHost[:port]
                                 Specifies the name of the computer that hosts the domain. If you do not
                                 specify a port number, the default port number, 9080, is used.
                          -ISUser isUser
                                 The name of a user on the domain.
                          -ISPassword isPassword
                                 The password for the domain user.
                          -DSHost dsHost[:port]
                                If the engine tier is not installed on the same computer as the services tier,
                                you must specify the computer that hosts the engine tier. If you do not
                                specify a port number, the default port number is used.
                          -DSProject dsProject
                                 Specifies the project into which the objects are imported.
                          -DSXFile dsxFile
                                 Specifies the .dsx file from which to import objects. You can specify a full
                                 path name, which can be local or remote.
                          -Overwrite
                                Specify this option to overwrite existing objects in the repository. If you do
                                not specify this option, attempting to re-import existing objects causes an
                                error.
                          -OverwriteReadOnly
                                This option does the same as -Overwrite but additionally replaces any
                                read-only items found. If this option is not specified, existing read-only
                                items are not overwritten.
                          -Verbose
                                 Specify this option to generate a full report of the objects imported. By
                                 default, only import errors are reported.
20   Programmer's Guide
       -StopOnError
              Specify this option to stop the import if an error is encountered when
              importing an object.
       selected_import
                You can specify options here to import selected objects from a .dsx file. You
                specify the object type and the object name as specified in the following
                table. You can specify a full name or an abbreviated name for the object
                type.
       Table 1. Selected import options
       Abbreviated option             Full option                Object type
       -JB                            -JOB                       job
       -EJ                            -EXECUTABLEJOB             job executable
       -DE                            -DATAELEMENT               data element
       -TD                            -TABLEDEFINITION           table definition
       -ST                            -STAGETYPE                 stage type
       -TR                            -TRANSFORM                 transform
       -RT                            -ROUTINE                   routine
       -ID                            -IMSDATABASE               IMS database
       -IV                            -IMSVIEWSET                IMS viewset
       -MP                            -MACHINEPROFILE            machine profiles
       -SC                            -SHAREDCONTAINER           shared container
       -QR                            -QSRULEASSEMBLY            QualityStage rule set
       -PS                            -PARAMETERSET              parameter set
       -DC                            -DATACONNECTION            data connection
Sample
       The following command imports the objects in the file oldproject.dsx into the
       project dstage. Connection details are specified in the file myconnection.
       DSXImportService -ISFile myconnection –DSProject dstage
       –DSXFile c:\export\oldproject.dsx
       The following command imports the objects in the file newproject.dsx into the
       project dstage. Connection details are specified in the command.
       DSXImportService -ISHost isserver:9080 -ISUser wgamsworth
       -ISPassword paddock –DSProject dstage –DSXFile c:\export\newproject.dsx
       The following command imports selected objects from the file partproject.dsx into
       the project dstage. Connection details are specified in the file myconnection.
       DSXImportService -ISFile myconnection –DSProject dstage
       -DSXFile c:\export\oldproject.dsx -JB job1 job2
       –TD APTSchemas\CFDImport\XYZ_RECORD –ROUTINE routine1 routine2
                          Use the List parameter with the DSXImportService command to list the objects that
                          a .dsx file contains. You do not have to connect to a domain to list the file.
Parameters
Sample
                          If the design-time assets for a project that are held in the metadata repository are
                          out of step with the server project, then the server project, or assets within the
                          server project, can become unusable.
                          You can use the SyncProject command to check for inconsistencies, and to repair
                          inconsistencies if any are detected. You might use the command as part of your
                          normal maintenance schedule to check for problems. If any problems are detected,
                          use the command in repair mode to fix the problems. Alternatively, you can use
                          the command interactively and be prompted if repair action is needed.
                          The SyncProject command can detect and attempt to repair, the following issues:
                          Project missing in metadata repository
                                  This fault arises if a server project exists, but the corresponding project
                                  does not exist in the metadata repository. SyncProject attempts to repair
                                  the fault by removing the server project.
                          Server project missing
                                  This fault arises if a project exists in the metadata repository, but the
                                  corresponding server project does not exist. SyncProject attempts to repair
                                  the fault by recreating the server project. If SyncProject succeeds in
                                  recreating the project, any jobs that the project contains must be
                                  recompiled.
                          Server project files are corrupted
                                  The server project holds descriptions of project objects in files. If these files
                                  are corrupted, SyncProject attempts to resolve the issue by returning the
                                  corrupted project file to its initial state.
                          Job or shared container missing from the metadata repository
                                  This fault arises if a server job or shared container exists, but the
22   Programmer's Guide
              corresponding metadata repository job or shared container does not exist.
              SyncProject attempts to repair the fault by removing the server job or
              shared container.
      Server job or shared container missing
              This fault arises if a job or shared container exists in the metadata
              repository, but the corresponding server job or shared container does not
              exist. SyncProject attempts to repair the fault by recreating the server job
              or shared container. If SyncProject succeeds in recreating the job, it must
              be recompiled.
      Corrupted server engine job files
             This fault arises if the files in which the server engine defines an
             executable job and its state become corrupted. To recover a corrupted file,
             SyncProject recreates an empty file. As a consequence, the job might need
             to be recompiled and the job log history and current job status information
             might be lost.
      Incorrect server job or shared container folder
              This fault arises if a job or shared container is in a different folder on the
              server compared to the metadata repository. SyncProject attempts to repair
              the fault by updating the folder attribute of the job or shared container in
              the server project.
      If the SyncProject command cannot repair a server project, you can use the
      SyncProject command to reconstruct the project from the metadata repository.
Parameters
      You can specify services tier host, user name, and password details in a file, or you
      can specify the details directly on the command line. If you specify details in a file,
      you can also specify the details on the command line to override some of the
      contents of the file. For example, you could specify a different host but take the
      user name and password as specified in the file, so you could use the same file to
      connect to different computers. Specifying user name and password in a file rather
      than on the command line gives greater security.
      The following syntax specifies connection details directly on the command line:
      SyncProject
      -ISHost isHost[:port]
      -ISUser isUser
      -ISPassword isPassword
      [–DSHost dsHost[:port]]
      -ISFile isFile
               Specifies the file name that contains the connection details. This parameter
               provides a level of security by hiding the login details from view. If you
Parameters
Examples
                          The following command requests a consistency report for the project named
                          dstage3. In this case both the services tier and the engine tier are on the computer
                          named R101.
                          SyncProject -ISHost R101:9080 -ISUser admin -ISPassword pword -project dstage3
                          -report
                          IS Host = R101
                          IS Port = 9080
24   Programmer's Guide
IS User = admin
DS Host = R101
DS Port = 3158
0 Issues Found.
Overall Summary
---------------
0 Issues found.
The following command requests a consistency report for all the projects with the
name dstagen. The command returns results for the projects dstage3, dstage4,
dstage5, and dstage9. The report is written to a file as well as being output to the
screen.
SyncProject -ISHost R101:9080 -ISUser admin -ISPassword pword -project dstage*
-report c:\myprojrep
In this case, two inconsistencies are found in the project named dstage9. The
following report is output, and written to the file c:\myprojrep:
DSEngine Restorer Report
IS Host = R101
IS Port = 9080
IS User = admin
DS Host = R101
DS Port = 3158
0 Issues Found.
0 Issues Found.
0 Issues Found.
2 Issues Found.
Overall Summary
---------------
2 Issues found.
Parameters
Examples
                          The following command requests that fixes are made to the projects dstage3 and
                          dstage5.
                          SyncProject -ISFile islogin -project dstage3 dstage5 -Fix
                          The command is able to make the necessary repairs outputs the following report.
                          DSEngine Restorer Fix Results
                          IS Host = R101
                          IS Port = 9080
                          IS User = admin
                          DS Host = R101
                          DS Port = 3158
                          2 Issues resolved.
                          0 Issues remaining.
26   Programmer's Guide
      1 Issues resolved.
      0 Issues remaining.
      Overall Summary
      ---------------
      3 Issues resolved.
      0 Issues remaining.
      The following command requests that fixes are made to the project dstage6, and
      the results written the file c:\fixresults:
      SyncProject -ISFile islogin -project dstage6 -fix c:\fixresults
      The command is not able to make the necessary repairs. The command outputs the
      following report and writes it to the file c:\fixresults:
      DSEngine Restorer Fix Results
      IS Host = R101
      IS Port = 9080
      IS User = admin
      DS Host = R101
      DS Port = 3158
      Overall Summary
      ---------------
      0 Issues resolved.
      2 Issues remaining.
Parameters
Examples
                          The following command requests a consistency report for the project named
                          dstage3 and that any inconsistencies found are repaired:
                          SyncProject -ISHost R101:9080 -ISUser admin -ISPassword pword
                              -Project dstage3 -Report -Fix
                          IS Host = R101
                          IS Port = 9080
                          IS User = admin
                          DS Host = R101
                          DS Port = 3158
2 Issues Found.
                          Overall Summary
                          ---------------
                          2 Issues found.
                          You are prompted whether to fix the detected issues. SyncProject then reports on
                          the success of the fix as follows:
                          DSEngine Restorer Fix Results
                          IS Host = R101
                          IS Port = 9080
                          IS User = admin
                          DS Host = R101
                          DS Port = 3158
                          2 Issues resolved.
                          0 Issues remaining.
28   Programmer's Guide
      Overall Summary
      ---------------
      2 Issues resolved.
      0 Issues remaining.
Reconstructing a project
      Use the SyncProject command to reconstruct a project from the repository.
Parameters
      The project directory is deleted before the project is reconstructed from the
      repository. The reconstructed project does not retain any log or job status data.
Example
      IS Host = R101
      IS Port = 9080
      IS User = admin
      DS Host = R101
      DS Port = 3158
      Overall Summary
      ---------------
      5 Issues Resolved.
      0 Issues Unresolved.
Parameters
Example
                          The following command requests that a backup copy is made of the project named
                          dstage3 to a tar archive file called dstage3.tar.
                          SyncProject -ISHost R101:9080 -ISUser admin -ISPassword pword -project dstage3
                          -backup dstage3.tar
             Restoring a project
                          Use the SyncProject command to restore a project from a backup copy.
                          Parameters
                          The SyncProject command has the following syntax:
                          SyncProject authentication_parameters
                          -Project Projectname
                          -Restore filename
                          -Project Projectname
                                  Specifies the project to be restored.
                          -Restore [filename]
                                  Specifies the name of the tar archive file that you previously created.
Example
                          The following command requests that a project named dstage3 is restored from a
                          tar archive file called dstage3.tar.
                          SyncProject -ISHost R101:9080 -ISUser admin -ISPassword pword -project dstage3
                          -restore dstage3.tar
30   Programmer's Guide
Chapter 2. InfoSphere DataStage Development Kit (Job
Control Interfaces)
                          InfoSphere DataStage provides a range of methods that enable you to run server or
                          parallel jobs directly on the engine, without using the Director client. The methods
                          are:
                          v   C/C++ API (the InfoSphere DataStage development kit)
                          v   InfoSphere DataStage BASIC calls
                          v   Command line Interface commands (CLI)
                          v   InfoSphere DataStage macros
This section gives general information about using the InfoSphere DataStage API.
                          Each thread within a calling application is allocated a separate storage area. Each
                          call to an InfoSphere DataStage API routine overwrites any existing contents of this
                          data area with the results of the call, and returns a pointer into the area for the
                          requested data.
                          This means that if the results of an InfoSphere DataStage API function need to be
                          reused later, the application should make its own copy of the data before making a
                          new InfoSphere DataStage API call. Alternatively, the calls can be used in multiple
                          threads.
                          InfoSphere DataStage API stores errors for each thread: a call to the
                          DSGetLastError function returns the last error generated within the calling thread.
                          Your application should use the InfoSphere DataStage API functions in a logical
                          order to ensure that connections are opened and closed correctly, and jobs are run
                          effectively. The following procedure suggests an outline for the program logic to
                          follow, and which functions to use at each step:
                          Procedure
                           1. If required, set the host name, user name, and password to use for connecting
                              to InfoSphere DataStage (DSSetServerParams).
                           2. Obtain the list of valid projects (DSGetProjectList).
                           3. Open a project (DSOpenProject).
                           4. Obtain a list of jobs (DSGetProjectInfo).
                           5. Open one or more jobs (DSOpenJob).
                           6. List the job parameters (DSGetParamInfo).
                           7. Lock the job (DSLockJob).
                           8. Set the job's parameters and limits (DSSetJobLimit, DSSetParam).
                           9. Start the job running (DSRunJob).
                          10. Poll for the job or wait for job completion (DSWaitForJob, DSStopJob,
                              DSGetJobInfo).
                          11. Unlock the job (DSUnlockJob).
                          12. Display a summary of the job's log entries (DSFindFirstLogEntry,
                              DSFindNextLogEntry).
                          13. Display details of specific log events (DSGetNewestLogId, DSGetLogEntry).
32   Programmer's Guide
      14. Examine and display details of job stages (DSGetJobInfo - stage list,
          DSGetStageInfo).
      15. Examine and display details of links within active stages (DSGetStageInfo -
          link list, DSGetLinkInfo).
      16. Close all open jobs (DSCloseJob).
      17. Detach from the project (DSCloseProject).
      Everything you need to create an application that uses the InfoSphere DataStage
      API is in a subdirectory called dsdk (DataStage Development Kit) in the
      IBM\InformationServer\Server installation directory on the engine tier host
      machine.
      Procedure
      1. Write the program, including the dsapi.h header file in all source modules that
         uses the InfoSphere DataStage API.
      2. Compile the code. Ensure that the WIN32 token is defined. (This happens
         automatically in the Microsoft Visual C/C++ compiler environment.)
      3. Link the application, including vmdsapi.lib, in the list of libraries to be
         included.
Redistributing Applications
      If you intend to run your InfoSphere DataStage API application on a computer
      where the engine tier is installed, you do not need to include InfoSphere DataStage
      API DLLs or libraries as these are installed as part of the engine tier.
vmdsapi.dll
      If you intend to run the program from a computer that has neither the engine tier
      nor any InfoSphere DataStage client installed, in addition to the library mentioned
      above, you should also redistribute the following:
      You should locate these files where they will be in the search path of any user who
      uses the application, for example, in the %SystemRoot%\System32 directory.
API Functions
      This section details the functions provided in the InfoSphere DataStage API. These
      functions are described in alphabetical order. The following table briefly describes
      the functions categorized by usage:
34   Programmer's Guide
     Usage                         Function                           Description
                                   DSLogEvent                         Adds a new entry to the log.
     Administering Projects and    DSAddEnvVar                        Adds a new environment
     jobs                                                             variable.
                                   DSAddProject                       Add a project.
                                   DSDeleteEnvVar                     Delete an environment
                                                                      variable.
                                   DSDeleteProject                    Delete a project.
                                   DSListEnvVars                      List environment variables.
                                   DSListProjectProperties            List the properties of a
                                                                      project.
                                   DSSetEnvVar                        Set an environment variable.
                                   DSSetProjectProperty               Set property for a project.
     Handling errors               DSGetLastError                     Retrieves the last error code
                                                                      value generated by the
                                                                      calling thread.
                                   DSGetLastErrorMsg                  Retrieves the text of the last
                                                                      reported error.
DSAddEnvVar
     Add an environment variable to the specified project. It is added to the User
     Defined category.
     Syntax
     int DSAddEnvVar(   DSPROJECT hProject,
           char *EnvVarName,
           char *Type,
           char *PromptText,
           char *Value);
Parameters
Return Values
     If the function fails, then the return value is one of the following:
     v DSJE_BADENVVARNAME invalid environment variable name
     v DSJE_BADENVVARTYPE invalid type
Remarks
                          To use this method, the program needs to have previously attached to a project
                          using DSOpenProject. This returns a handle to the project, hProject.
             DSAddProject
                          Creates a new project. The user who runs the code containing this function must
                          be an InfoSphere DataStage administrator.
                          Syntax
                          int DSAddProject(
                            char *ProjectName,
                            char *ProjectLocation);
Parameters
                          ProjectLocation is the path name of the directory to create the project in. To create a
                          project in the default project directory (install path/Projects/projectName), this
                          argument should be set to "".
Return Values
                          If the function fails, then the return value is one of the following:
                          v   DSJE_NOTADMINUSER user is not an administrator
                          v   DSJE_ISADMINFAILED failed to determine whether user is an administrator
                          v   DSJE_BADPROJNAME invalid project name supplied
                          v   DSJE_GETDEFAULTPATHFAILED failed to determine default project directory
                          v   DSJE_BADPROJLOCATION invalid path name supplied
                          v   DSJE_INVALIDPROJECTLOCATION invalid path name supplied
                          v   DSJE_OPENFAILED failed to open UV.ACCOUNT file
                          v   DSJE_READUFAILED failed to lock project create lock record
                          v   DSJE_ADDPROJECTBLOCKED another user is adding a project
                          v   DSJE_ADDPROJECTFAILED failed to add project
                          v   DSJE_LICENSEPROJECTFAILED failed to license project
                          v   DSJE_RELEASEFAILED failed to release project create lock record
36   Programmer's Guide
DSCloseJob
     Closes a job that was opened using DSOpenJob.
     Syntax
     int DSCloseJob(
          DSJOB JobHandle
     );
Parameter
Return Values
Remarks
     If the job is running when DSCloseJob is called, the job is allowed to finish, and
     the function returns a value of DSJE_NOERROR immediately.
DSCloseProject
     Closes a project that was opened using the DSOpenProject function.
     Syntax
     int DSCloseProject(
        DSPROJECT ProjectHandle
     );
Parameter
Return Value
Remarks
     Any open jobs in the project are closed, running jobs are allowed to finish, and the
     function returns immediately.
DSDeleteEnvVar
     Delete a user-defined environment variable in a specified project.
Parameters
Return Values
                          If the function fails, then the return value is one of the following:
                          v DSJE_READENVVARDEFNS failed to read environment variable definitions
                          v DSJE_READENVVARVALUES failed to read environment variable values
                          v   DSJE_BADENVVAR environment variable does not exist
                          v   DSJE_WRITEENVVARDEFNS failed to write environment variable definitions
                          v   DSJE_WRITEENVVARVALUES failed to write environment variable values
                          v   DSJE_NOTUSERDEFINED environment variable is not user-defined and
                              therefore cannot be deleted
If the function fails, then the return value is one of the following:
             DSDeleteProject
                          Deletes a project. The user who runs the code containing this function must be an
                          InfoSphere DataStage administrator. Note that any jobs scheduled to be run that
                          are included in this project will also be deleted.
                          Syntax
                          int DSDeleteProject(
                                 char *ProjectName
                          );
Parameter
Return Value
                          If the function fails, then the return value is one of the following:
                          v DSJE_NOTADMINUSER user is not an administrator
                          v   DSJE_ISADMINFAILED failed to determine whether user is an administrator
                          v   DSJE_OPENFAILED failed to open UV.ACCOUNT file
                          v   DSJE_READUFAILED failed to lock project record
                          v   DSJE_RELEASEFAILED failed to release project record
                          v   DSJE_LISTSCHEDULEFAILED failed to get list of scheduled jobs for project
38   Programmer's Guide
      v   DSJE_CLEARSCHEDULEFAILED failed to clear scheduled jobs for project
      v   DSJE_DELETEPROJECTBLOCKED project locked by another user
      v   DSJE_NOTAPROJECT failed to log to project
      v   DSJE_ACCOUNTPATHFAILED failed to get account path
      v   DSJE_LOGTOFAILED failed to log to UV account
      v DSJE_DELPROJFAILED failed to delete project definition
      v DSJE_DELPROJFILESFAILED failed to delete project files
DSFindFirstLogEntry
      Retrieves all the log entries that meet the specified criteria, and writes the first
      entry to a data structure. Subsequent log entries can then be read using the
      DSFindNextLogEntry function.
      Syntax
      int DSFindFirstLogEntry(
         DSJOB JobHandle,
         int EventType,
         time_t StartTime,
         time_t EndTime,
         int MaxNumber,
         DSLOGEVENT *Event);
Parameters
                          EndTime limits the returned log events to those that occurred before the specified
                          date and time. Set this value to 0 to return all entries up to the most recent.
                          MaxNumber specifies the maximum number of log entries to retrieve, starting from
                          the latest.
Event is a pointer to a data structure to use to hold the first retrieved log entry.
Return Values
                          If the function succeeds, the return value is DSJE_NOERROR, and summary details
                          of the first log entry are written to Event.
Remarks
                          The retrieved log entries are cached for retrieval by subsequent calls to
                          DSFindNextLogEntry. Any cached log entries that are not processed by a call to
                          DSFindNextLogEntry are discarded at the next DSFindFirstLogEntry call (for any
                          job), or when the project is closed.
                          Note: The log entries are cached by project handle. Multiple threads using the
                          same open project handle must coordinate access to DSFindFirstLogEntry and
                          DSFindNextLogEntry.
             DSFindNextLogEntry
                          Retrieves the next log entry from the cache.
                          Syntax
                          int DSFindNextLogEntry(
                             DSJOB JobHandle,
                             DSLOGEVENT *Event
                          );
40   Programmer's Guide
     Parameters
Event is a pointer to a data structure to use to hold the next log entry.
Return Values
     If the function succeeds, the return value is DSJE_NOERROR and summary details
     of the next available log entry are written to Event.
Remarks
     This function retrieves the next log entry from the cache of entries produced by a
     call to DSFindFirstLogEntry.
     Note: The log entries are cached by project handle. Multiple threads using the
     same open project handle must coordinate access to DSFindFirstLogEntry and
     DSFindNextLogEntry.
DSGetCustInfo
     Obtains information reported at the end of execution of certain parallel stages. The
     information collected, and available to be interrogated, is specified at design time.
     For example, Transformer stage information is specified in the Triggers tab in the
     Transformer stage Properties dialog box.
     Syntax
     int DSGetCustInfo(   DSJOB JobHandle,
           char *StageName,
           char *CustinfoName
           int InfoType,
           DSSTAGEINFO *ReturnInfo
     );
Parameters
Return Values
             DSGetJobInfo
                          Retrieves information about the status of a job.
                          Syntax
                          int DSGetJobInfo(   DSJOB JobHandle,
                                int InfoType,
                                DSJOBINFO *ReturnInfo
                          );
Parameters
                          InfoType is a key indicating the information to be returned and can have any of the
                          following values:
                          This key...
                                 Returns this information...
                          DSJ_JOBSTATUS
                                The current status of the job.
                          DSJ_JOBNAME
                                The name of the job referenced by JobHandle.
                          DSJ_JOBCONTROLLER
                                The name of the job controlling the job referenced by JobHandle.
42   Programmer's Guide
DSJ_JOBSTARTTIMESTAMP
      The date and time when the job started.
DSJ_JOBWAVENO
      The wave number of last or current run.
DSJ_JOBDESC
      The Job Description specified in the Job Properties dialog box.
DSJ_JOBFULLDESSC
      The Full Description specified in the Job Properties dialog box.
DSJ_JOBDMISERVICE
      Set to true if this is a Web service job.
DSJ_JOBMULTIINVOKABLE
      Set to true if this job supports multiple invocations.
DSJ_PARAMLIST
      A list of job parameter names. Separated by nulls.
DSJ_STAGELIST
      A list of active stages in the job. Separated by nulls.
DSJ_USERSTATUS
      The value, if any, set as the user status by the job.
DSJ_JOBCONTROL
      Whether a stop request has been issued for the job referenced by JobHandle.
DSJ_JOBPID
      Process id of DSD.RUN process.
DSJ_JOBLASTTIMESTAMP
      The date and time when the job last finished.
DSJ_JOBINVOCATIONS
      List of job invocation ids. The ids are separated by nulls.
DSJ_JOBINTERIMSTATUS
      The status of a job after it has run all stages and controlled jobs, but before
      it has attempted to run an after-job subroutine. (Designed to be used by an
      after-job subroutine to get the status of the current job.)
DSJ_JOBINVOCATIONID
      Invocation name of the job referenced by JobHandle.
DSJ_JOBDESC
      A description of the job.
DSJ_STAGELIST2
      A list of passive stages in the job. Separated by nulls.
DSJ_JOBELAPSED
      The elapsed time of the job in seconds.
Remarks
                          For controlled jobs, this function can be used either before or after a call to
                          DSRunJob.
             DSGetLastError
                          Returns the calling thread's last error code value.
                          Syntax
                          int DSGetLastError(void);
Return Values
                          The return value is the last error code value. The "Return Values" section of each
                          reference page notes the conditions under which the function sets the last error
                          code.
Remarks
                          Use DSGetLastError immediately after any function whose return value on failure
                          might contain useful data, otherwise a later, successful function might reset the
                          value back to 0 (DSJE_NOERROR).
             DSGetLastErrorMsg
                          Retrieves the text of the last reported error from the engine.
                          Syntax
                          char *DSGetLastErrorMsg(
                             DSPROJECT ProjectHandle
                          );
Parameter
44   Programmer's Guide
      Return Values
      The return value is a pointer to a series of null-terminated strings, one for each line
      of the error message associated with the last error generated by the engine in
      response to an InfoSphere DataStage API function call. Use DSGetLastError to
      determine what the error number is.
      The following example shows the buffer contents with <null> representing the
      terminating NULL character:
      line1<null>line2<null>line3<null><null>
Remarks
      If ProjectHandle is NULL, this function retrieves the error message associated with
      the last call to DSOpenProject or DSGetProjectList, otherwise it returns the last
      message associated with the specified project.
      Note: The text retrieved by a call to DSGetLastErrorMsg relates to the last error
      generated by the engine and not necessarily the last error reported back to a thread
      using InfoSphere DataStage API. Multiple threads using InfoSphere DataStage API
      must cooperate in order to obtain the correct error message text.
DSGetLinkInfo
      Retrieves information relating to a specific link of the specified active stage of a
      job.
      Syntax
      int DSGetLinkInfo(
         DSJOB JobHandle,
         char *StageName,
         char *LinkName,
         int InfoType,
         DSLINKINFO *ReturnInfo);
Parameters
Return Value
Remarks
             DSGetLogEntry
                          Retrieves detailed information about a specific entry in a job log.
                          Syntax
                          int DSGetLogEntry(
                               DSJOB JobHandle,
                               int EventId,
                               DSLOGDETAIL *Event
                          );
46   Programmer's Guide
     Parameters
Return Values
     If the function succeeds, the return value is DSJE_NOERROR and the event
     structure contains the details of the requested event.
Remarks
     Entries in the log file are numbered sequentially starting from 0. The latest event
     ID can be obtained through a call to DSGetNewestLogId. When a log is cleared,
     there always remains a single entry saying when the log was cleared.
DSGetLogEventIds
     Retrieves a list of event log IDs for a given job invocation.
     Syntax
     int DSGetLogEventIds(
           DSJOB JobHandle,
           int RunNumber,
           char *Filter,
           char **List);
Parameters
     RunNumber identifies the job invocation run for which event IDs are returned.
     Usually a zero value requests IDs for the most recent run of the job invocation. To
     retrieve details for earlier runs, supply negative values, such as -1 for details about
     the run before the most recent, -2 for details about the run before that, and so
     forth. Where explicit run numbers are known, you can retrieve details by
     supplying the run number as a positive value.
     Filter restricts the types of event log entry for which IDs are returned. By default,
     IDs for all log event entries are returned. Include characters in the filter string to
     restrict entries as follows:
     I       Informational
Return Values
Remarks
                          To use this method, the program needs to have previously acquired a job handle
                          by calling DSOpenJob().
                          The run number for a job invocation is reset when the job is compiled, thus it is
                          not possible to use this method to retrieve job event IDs for runs that occurred
                          prior to the most recent job compilation.
             DSGetNewestLogId
                          Obtains the identifier of the newest entry in the jobs log.
                          Syntax
                          int DSGetNewestLogId(
                             DSJOB JobHandle,
                            int EventType
                          );
Parameters
                          EventType is a key specifying the type of log entry whose identifier you want to
                          retrieve and can be one of the following:
                          This key...
                                 Retrieves this type of log entry...
48   Programmer's Guide
     DSJ_LOGINFO
           Information
     DSJ_LOGWARNING
           Warning
     DSJ_LOGFATAL
           Fatal
     DSJ_LOGREJECT
           Transformer row rejection
     DSJ_LOGSTARTED
           Job started
     DSJ_LOGRESET
           Job reset
     DSJ_LOGOTHER
           Any other log event type
     DSJ_LOGBATCH
           Batch control
     DSJ_LOGANY
           Any type of event
Return Values
     If the function succeeds, the return value is the positive identifier of the most
     recent entry of the requested type in the job log file.
     If the function fails, the return value is -1. Use DSGetLastError to retrieve one of
     the following error codes:
     Token Description
     DSJE_BADHANDLE
           Invalid JobHandle.
     DSJE_BADTYPE
           Invalid EventType value.
Remarks
     Use this function to determine the ID of the latest entry in a log file before starting
     a job run. After the job has started or finished, it is then possible to determine
     which entries have been added by the job run.
DSGetParamInfo
     Retrieves information about a particular parameter within a job.
     Syntax
     int DSGetParamInfo(     DSJOB JobHandle,       char *ParamName,        DSPARAMINFO *ReturnInfo
     );
Parameters
Return Values
Remarks
                          Unlike the other information retrieval functions, DSGetParamInfo returns all the
                          information relating to the specified item in a single call. The DSPARAMINFO
                          data structure contains all the information required to request a new parameter
                          value from a user and partially validate it. See “Data Structures” on page 71.
                          This function can be used either before or after a DSRunJob call has been issued:
                          v If called after a successful call to DSRunJob, the information retrieved refers to
                            that run of the job.
                          v If called before a call to DSRunJob, the information retrieved refers to any
                            previous run of the job, and not to any call to DSSetParam that might have been
                            issued.
             DSGetProjectInfo
                          Obtains a list of jobs in a project.
                          Syntax
                          int DSGetProjectInfo(
                              DSPROJECT ProjectHandle,
                              int InfoType,
                              DSPROJECTINFO *ReturnInfo
                          );
Parameters
50   Programmer's Guide
      DSJ_HOSTNAME
            Host name of the engine tier.
Return Values
Remarks
      The DSPROJECTINFO data structure contains a union with an element for each
      of the possible return values from a call to DSGetProjectInfo.
      Note: The returned list contains the names of all jobs known to the project,
      whether they can be opened or not.
DSGetProjectList
      Obtains a list of all projects on the host system
      Syntax
      char* DSGetProjectList(void);
Return Values
      If the function fails, the return value is NULL. And the DSGetLastError function
      retrieves the following error code:
Remarks
This function can be called before any other InfoSphere DataStage API function.
      Note: DSGetProjectList opens, uses, and closes its own communications link with
      the engine, so it might take some time to retrieve the project list.
                          Syntax
                          int DSGetReposInfo (
                              DSPROJECThProject,
                              int ObjectType,
                              int InfoType,
                              const char *SearchCriteria,
                              const char *StartingCategory,
                              int Subcategories,
                              DSREPOSINFO *ReturnInfo);
Parameters
                          hProject is the value returned from DSOpenProject for the project whose jobs you
                          want to search.
                          ObjectType must currently be set to DSS_JOBS to indicate that you want to search
                          for jobs.
                          SearchCriteria is the name to match against. Partial name matching can be used,
                          with multiple * characters used as wild cards anywhere in the search string.
                          SearchSubcategories can have one of two values: 1 (TRUE) and 0 (FALSE). These
                          define whether the search is to include subcategories.
Return Value
On success, DSGetReposInfo returns the number of objects that have been found.
52   Programmer's Guide
     v DSJE_BADTYPE ObjectType or InfoType values was not recognized
     v DSJE_REPERROR An error occurred while trying to access the repository. Call
       DSGetLastErrorMsg to get the error message associated with the error code
     v DSJE_NO_DATASTAGE The attached project does not appear to be a valid
       InfoSphere DataStage project
DSGetReposUsage
     Returns a list of objects based on the required relationship.
     Syntax
     int DSGetReposUsage(
        DSPROJECT hProject,
        int RelationshipType,
        const char *ObjectName,
        int Recursive,
        DSREPOSUSAGE *ReturnInfo);
Parameters
     hProject is the value returned from DSOpenProject for the project whose jobs you
     want to search.
     ObjectName specifies the job or table, and varies according to which RelationshipType
     is specified:
     v for DSS_JOB_USES_JOB and DSS_JOB_USEDBY_JOB relationships, the job name
        (without category qualification) should be given.
     v for remaining relationships, the fully qualified table name should be given.
     v For the DRS Stage table definition relationships, partial matching of the table
        name using * characters as wild cards is allowed. Multiple wildcard characters
        can be used
Return Value
             DSGetStageInfo
                          Obtains information about a particular stage within a job.
                          Syntax
                          int DSGetStageInfo(
                             DSJOB JobHandle,
                             char *StageName,
                             int InfoType,
                             DSSTAGEINFO *ReturnInfo
                          );
Parameters
54   Programmer's Guide
DSJ_VARLIST
      Null-separated list of stage variable names in the stage.
DSJ_STAGESTARTTIMESTAMP
      Date and time when stage started.
DSJ_STAGEENDTIMESTAMP
      Date and time when stage finished.
DSJ_STAGEDESC
      Stage description (from stage properties)
DSJ_STAGEINST
      Null-separated list of instance ids (parallel jobs).
DSJ_STAGECPU
      List of CPU time in seconds.
DSJ_LINKTYPES
      Null-separated list of link types.
DSJ_STAGEELAPSED
      Elapsed time in seconds.
DSJ_STAGEPID
      Null-separated list of process ids.
DSJ_STAGESTATUS
      Stage status.
DSJ_CUSTINFOLIST
      Null-separated list of custinfo items.
Return Values
Remarks
This function can be used either before or after a DSRunJob function has been
issued.
The DSSTAGEINFO data structure contains a union with an element for each of
the possible return values from the call to DSGetStageInfo.
                          Syntax
                          int DSGetVarInfo(
                             DSJOB JobHandle,
                             char *StageName,
                             char *VarName
                             int InfoType,
                             DSSTAGEINFO *ReturnInfo
                          );
Parameters
Return Values
             DSListEnvVars
                          Obtain a list of environment variables and their values in a specified project.
56   Programmer's Guide
      Syntax
      char *DSListEnvVars(
            DSPROJECT hProject);
Parameter
      hProject is the value returned from DSOpenProject for the project whose
      environment variables you want to list.
Return Values
      If the function fails, the return value is NULL and the DSGetLastError function can
      be used to retrieve an error code as follows:
      v DSJE_READENVVARDEFNS failed to read environment variable definitions
      v DSJE_READENVVARVALUES failed to read environment variable values
      v DSJE.ISPARALLELLICENCED failed to determine if parallel jobs are available
Remarks
      To use this method, the program needs to have previously attached to a project
      using DSOpenProject. This returns a handle to the project, hProject.
      Environment variables in the parallel category will only be listed if parallel jobs are
      available.
DSListProjectProperties
      Obtain a list of the values of project properties for specified project. Properties
      supported are:
      v Whether generated OSH is visible in parallel jobs.
      v Whether runtime column propagation is enabled in parallel jobs.
      v The base directory name for parallel jobs.
      v   Advanced runtime options for parallel jobs.
      v   Custom deployment commands for parallel jobs.
      v   Deployment job template directory.
      v   Whether job administration is enabled in the Director client or not.
      Syntax
      char *DSListProjectProperties(
            DSPROJECT hProject
      );
Parameter
      hProject is the value returned from DSOpenProject for the project whose
      properties you want to list.
These tokens are defined in dsapi.h (see “The dsapi.h Header File” on page 31).
                          If the function fails, the return value is NULL and the DSGetLastError function
                          can be used to retrieve one of the following error code:
                          v DSJE_READPROJPROPERTY failed to read property
                          v DSJE_ISPARALLELLICENCED failed to determine if parallel jobs are available
                          v DSJE_OSHVISIBLEFLAG failed to get value for OSHVisible
Remarks
                          To use this method, the program needs to have previously attached to a project
                          using DSOpenProject. This returns a handle to the project, hProject.
             DSLockJob
                          Locks a job. This function must be called before setting a job's run parameters or
                          starting a job run.
58   Programmer's Guide
     Syntax
     int DSLockJob(
        DSJOB JobHandle
     );
Parameter
Return Values
Remarks
     Locking a job prevents any other process from modifying the job details or status.
     This function must be called before any call of DSSetJobLimit, DSSetParam, or
     DSRunJob.
     If you try to lock a job you already have locked, the call succeeds. If you have the
     same job open on several InfoSphere DataStage API handles, locking the job on
     one handle locks the job on all the handles.
DSLogEvent
     Adds a new entry to a job log file.
     Syntax
     int DSLogEvent(
        DSJOB JobHandle,
        int EventType,
        char *Reserved,
        char *Message
     );
Parameters
     EventType is one of the following keys specifying the type of event to be logged:
     This key...
            Specifies this type of event...
     DSJ_LOGINFO
           Information
     DSJ_LOGWARNING
           Warning
Return Values
Remarks
                          Messages that contain more that one line of text should contain a newline character
                          (\n) to indicate the end of a line.
             DSMakeJobReport
                          Generates a report describing the complete status of a valid attached job.
                          Syntax
                          int DSMakeJobReport(
                             DSJOB JobHandle,
                             int ReportType,
                             char *LineSeparator,
                             DSREPORTINFO *ReturnInfo);
Parameters
60   Programmer's Guide
     "CR" => CHAR(13)
Return Values
DSOpenJob
     Opens a job. This function must be called before any other function that
     manipulates the job.
     Syntax
     DSJOB DSOpenJob(
        DSPROJECT ProjectHandle,
        char *JobName
     );
Parameters
     JobName is a pointer to a null-terminated string that specifies the name of the job
     that is to be opened. This might be in either of the following formats:
     job     Finds the latest version of the job.
     job%Reln.n.n
            Finds a particular release of the job on a development system.
Return Values
     If the function fails, the return value is NULL. Use DSGetLastError to retrieve one
     of the following:
     Token Description
     DSJE_OPENFAIL
           Engine failed to open job.
     DSJE_NO_MEMORY
           Memory allocation failure.
Remarks
     The DSOpenJob function must be used to return a job handle before a job can be
     addressed by any of the InfoSphere DataStage API functions. You can gain
     exclusive access to the job by locking it with DSLockJob.
     The same job can be opened more than once and each call to DSOpenJob will
     return a unique job handle. Each handle must be separately closed.
                          Syntax
                          DSPROJECT DSOpenProject(
                             char *ProjectName
                          );
Parameter
Return Values
                          If the function fails, the return value is NULL. Use DSGetLastError to retrieve one
                          of the following:
                          Token Description
                          DSJE_BAD_VERSION
                                The engine is an older version than the InfoSphere DataStage API.
                          DSJE_INCOMPATIBLE_SERVER
                                The engine is either older or newer than that supported by this version of
                                InfoSphere DataStage API.
                          DSJE_SERVER_ERROR
                                Internal error. Engine returned invalid data.
                          DSJE_BADPROJECT
                                Invalid project name.
                          DSJE_NO_DATASTAGE
                                InfoSphere DataStage is not correctly installed on engine tier host.
Remarks
                          The DSGetProjectList function can return the name of a project that does not
                          contain valid InfoSphere DataStage jobs, but this is detected when DSOpenProject
                          is called. A process can only have one project open at a time.
             DSRunJob
                          Starts a job run.
                          Syntax
                          int DSRunJob(   DSJOB JobHandle,
                                int RunMode
                          );
Parameters
62   Programmer's Guide
     RunMode is a key determining the run mode and should be one of the following
     values:
     DSJ_RUNNORMAL
           Start a job run.
     DSJ_RUNRESET
           Reset the job.
     DSJ_RUNVALIDATE
           Validate the job.
     DSJ_RUNRESTART
           Restart a restartable job sequence with the original job parameter values.
Return Values
     If the function fails, the return value is one of the following tokens:
     DSJE_BADHANDLE
           Invalid JobHandle.
     DSJE_BADSTATE
           Job is not in the right state (must be compiled and not running).
     DSJE_BADTYPE
           RunMode is not recognized.
     DSJE_SERVER_ERROR
           Internal error. The engine returned invalid data.
Remarks
     The job specified by JobHandle must be locked, using DSLockJob, before the
     DSRunJob function is called.
If no limits were set by calling DSSetJobLimit, the default limits are used.
DSSetEnvVar
     Set the value for an environment variable in a specified project.
     Syntax
     int DSSetEnvVar(
           DSPROJECT hProject,
           char *EnvVarName,
           char *Value
     );
Parameters
                          If the function fails, then the return value is one of the following:
                          v DSJE_READENVVARDEFNS failed to read environment variable definitions
                          v DSJE_READENVVARVALUES failed to read environment variable values
                          v DSJE_BADENVVAR environment variable does not exist
                          v DSJE_WRITEENVVARVALUES failed to write environment variable values
                          v DSJE_ENCODEFAILED failed to encode an encrypted value
                          v DSJE_BADBOOLEANVALUE invalid value given for a boolean environment
                            variable
                          v DSJE_BADNUMERICVAL UE invalid value given for an integer environment
                            variable
                          v DSJE_BADLISTVALUE invalid value given for an environment variable with a
                            fixed list of values
                          v DSJE_PXNOTINSTALLED environment variable is specific to parallel jobs which
                            are not available
                          v DSJE_ISPARALLELLICENCED failed to determine if parallel jobs are available
Remarks
                          You can only set values for environment variables in the parallel category if
                          parallel jobs are available.
                          If you are setting a boolean type environment variable, set the value to 1 for TRUE
                          and 0 for FALSE.
             DSSetGenerateOpMetaData
                          Use this to specify whether the job generates operational metadata or not. This
                          overrides the default setting for the project.
                          Syntax
                          int DSSetGenerateOpMetaData (
                             JobHandle,
                             value
                          );
Parameters
                          value is TRUE (1) to generate operational metadata, FALSE (0) to not generate
                          operational metadata.
64   Programmer's Guide
     Return Values
DSSetJobLimit
     Sets row or warning limits for a job.
     Syntax
     int DSSetJobLimit(
        DSJOB JobHandle,
        int LimitType,
        int LimitValue
     );
Parameters
Return Values
Remarks
                          The job specified by JobHandle must be locked, using DSLockJob, before the
                          DSSetJobLimit function is called.
                          Any job limits that are not set explicitly before a run will use the default values.
                          Make two calls to DSSetJobLimit in order to set both types of limit.
Set the value to 0 to indicate that there should be no limit for the job.
             DSSetParam
                          Sets job parameter values before running a job. Any parameter that is not explicitly
                          set uses the default value.
                          Syntax
                          int DSSetParam(
                             DSJOB JobHandle,
                             char *ParamName,
                             DSPARAM *Param);
Parameters
                          Param is a pointer to a structure that specifies the name, type, and value of the
                          parameter to set.
                          Note: The type specified in Param need not match the type specified for the
                          parameter in the job definition, but it must be possible to convert it. For example,
                          if the job defines the parameter as a string, it can be set by specifying it as an
                          integer. However, it will cause an error with unpredictable results if the parameter
                          is defined in the job as an integer and a nonnumeric string is passed by
                          DSSetParam.
Return Values
66   Programmer's Guide
      DSJE_BADTYPE
            Param does not specify a valid parameter type.
      DSJE_BADVALUE
            Param does not specify a value that is appropriate for the parameter type
            as specified in the job definition.
      DSJE_SERVER_ERROR
            Internal error. Engine returned invalid data.
Remarks
      The job specified by JobHandle must be locked, using DSLockJob, before the
      DSSetParam function is called.
DSSetProjectProperty
      Sets the value of a property in a specified project. The user who runs the code
      containing this function must be an InfoSphere DataStage administrator.
      Syntax
      int DSSetProjectProperty(
            DSPROJECT hProject,
            char *Property,
            char *Value
      );
      Parameters
      hProject is the value returned from DSOpenProject
      Property is the name of the property to set. The following properties are supported:
      This key...
             Indicates this property...
      DSA_OSHVISIBLEFLAG
           Generated OSH is visible in parallel jobs, Value is 0 for false or 1 for true.
           Parallel jobs only.
      DSA_PRJ_RTCP_ENABLED
           Runtime column propagation is enabled in parallel jobs, Value is 0 for false
           or 1 for true. Parallel jobs only.
      DSA_PRJ_PX_ADVANCED_RUNTIME_OPTS
           Specifies advanced runtime properties for parallel jobs, Value is the
           advanced properties to set. Parallel jobs only.
      DSA_PRJ_PX_BASEDIR
           Specifies the base directory for parallel jobs. Value is the base directory.
           Parallel jobs only.
      DSA_PRJ_PX_DEPLOY_JOBDIR_TEMPLATE
           Specifies the deployment directory template for parallel jobs. Value is the
           deployment directory template. Parallel jobs only.
      DSA_PRJ_PX_DEPLOY_CUSTOM_ACTION
           Specifies custom deployment commands for parallel jobs. Value is the
           commands. Parallel jobs only.
Return Values
                          If the function fails, then the return value is one of the following:
                          v   DSJE_NOTADMINUSER user is not an administrator
                          v   DSJE_ISADMINFAILED failed to determine whether user is an administrator
                          v   DSJE_READPROJPROPERTY failed to read property
                          v   DSJE_WRITEPROJPROPERTY failed to write property
                          v   DSJE_PROPNOTSUPPORTED property not supported
                          v   DSJE_BADPROPERTY unknown property name
                          v   DSJE_BADPROPVALUE invalid value for this property
                          v DSJE_PXNOTINSTALLED parallel jobs not available
                          v DSJE_ISPARALLELLICENCED failed to determine if parallel jobs are available
                          v DSJE_OSHVISIBLEFLAG failed to set value for OSHVisible
Remarks
                          To use this method, the program needs to have previously attached to a project
                          using DSOpenProject. This returns a handle to the project, hProject.
             DSSetServerParams
                          Sets the logon parameters to use for opening a project or retrieving a project list.
                          Syntax
                          void DSSetServerParams(
                                char *DomainName,
                                char *UserName,
                                char *Password,
                                char *ServerName
                          );
Parameters
68   Programmer's Guide
     Return Values
Remarks
DSStopJob
     Aborts a running job.
     Syntax
     int DSStopJob(
        DSJOB JobHandle
     );
Parameter
Return Values
Remarks
     The DSStopJob function should be used only after a DSRunJob function has been
     issued. The stop request is sent regardless of the job's current status. To ascertain if
     the job has stopped, use the DSWaitForJob function or the DSJobStatus macro.
DSUnlockJob
     Unlocks a job, preventing any further manipulation of the job's run state and
     freeing it for other processes to use.
     Syntax
     int DSUnlockJob(
        DSJOB JobHandle
     );
Parameter
Remarks
                          The DSUnlockJob function returns immediately without waiting for the job to
                          finish. Attempting to unlock a job that is not locked does not cause an error. If you
                          have the same job open on several handles, unlocking the job on one handle
                          unlocks it on all handles.
             DSWaitForJob
                          Waits to the completion of a job run.
                          Syntax
                          int DSWaitForJob(
                             DSJOB JobHandle
                          );
Parameter
Return Values
Remarks
                          This function is only valid if the current job has issued a DSRunJob call on the
                          given JobHandle. It returns if the job was started since the last DSRunJob, and has
                          since finished. The finishing status can be found by calling DSGetJobInfo.
70   Programmer's Guide
Data Structures
      The InfoSphere DataStage API uses the data structures described in this section to
      hold data passed to, or returned from, functions. (See “Data Structures, Result
      Data, and Threads” on page 32). The data structures are summarized below, with
      full descriptions in the following sections:
DSCUSTINFO
      The DSCUSTINFO structure represents various information values about a link to
      or from an active stage within an InfoSphere DataStage job.
      Syntax
      typedef struct _DSCUSTINFO {
      int infoType: /
      union {
         char *custinfoValue;
         char *custinfoDesc;} info;
      } DSCUSTINFO;
                          infoType is a key indicating the type of information and is one of the following
                          values:
                          This key...
                                 Indicates this information...
                          DSJ_CUSTINFOVALUE
                                The value of the specified custinfo item.
                          DSJ_CUSTINFODESC
                                The description of the specified custinfo item.
             DSJOBINFO
                          The DSJOBINFO structure represents information values about an InfoSphere
                          DataStage job.
                          Syntax
                          typedef struct _DSJOBINFO {
                             int infoType;
                             union {
                                int jobStatus;
                                char *jobController;
                                time_t jobStartTime;
                                int jobWaveNumber;
                                char *userStatus;
                                char *paramList;
                                char *stageList;
                                char *jobname;
                                int jobcontrol;
                                int jobPid;
                                time_t jobLastTime;
                                char *jobInvocations;
                                int jobInterimStatus;
                                char *jobInvocationid;
                                char *jobDesc;
                                char *stageList2;
                                char *jobElapsed;
                                char *jobFullDesc;
                                int jobDMIService;
                                int jobMultiInvokable;
                             } info;
                          } DSJOBINFO;
Members
72   Programmer's Guide
DSJ_JOBSTARTTIMESTAMP
      The date and time when the job started.
DSJ_JOBWAVENO
      Wave number of the current (or last) job run.
DSJ_PARAMLIST
      A list of the names of the job's parameters. Separated by nulls.
DSJ_STAGELIST
      A list of active stages in the job. Separated by nulls.
DSJ_USERSTATUS
      The status reported by the job itself as defined in the job's design.
DSJ_JOBCONTROL
      Whether a stop request has been issued for the job.
DSJ_JOBPID
      Process id of DSD.RUN process.
DSJ_JOBLASTTIMESTAMP
      The date and time on the engine when the job last finished.
DSJ_JOBINVOCATIONS
      List of job invocation ids. Separated by nulls.
DSJ_JOBINTERIMSTATUS
      Current Interim status of the job.
DSJ_JOBINVOVATIONID
      Invocation name of the job referenced.
DSJ_JOBDESC
      A description of the job.
DSJ_STAGELIST2
      A list of passive stages in the job. Separated by nulls.
DSJ_JOBELAPSED
      The elapsed time of the job in seconds.
DSJ_JOBFULLDESSC
      The Full Description specified in the Job Properties dialog box.
DSJ_JOBDMISERVICE
      Set to true if this is a Web service job.
DSJ_JOBMULTIINVOKABLE
      Set to true if this job supports multiple invocations.
jobStatus is returned when infoType is set to DSJ_JOBSTATUS. Its value is one of the
following keys:
This key...
       Indicates this status...
DSJS_RUNNING
      Job running.
DSJS_RUNOK
      Job finished a normal run with no warnings.
DSJS_RUNWARN
      Job finished a normal run with warnings.
                          jobController is the name of the job controlling the job reference and is returned
                          when infoType is set to DSJ_JOBCONTROLLER. Note that this can be several job
                          names, separated by periods, if the job is controlled by a job which is itself
                          controlled, and so on.
                          jobStartTime is the date and time when the last or current job run started and is
                          returned when infoType is set to DSJ_JOBSTARTTIMESTAMP.
                          jobWaveNumber is the wave number of the last or current job run and is returned
                          when infoType is set to DSJ_JOBWAVENO.
                          userStatus is the value, if any, set by the job as its user defined status, and is
                          returned when infoType is set to DSJ_USERSTATUS.
             DSLINKINFO
                          The DSLINKINFO structure represents various information values about a link to
                          or from an active stage within an InfoSphere DataStage job.
74   Programmer's Guide
    Syntax
    typedef struct _DSLINKINFO {
    int infoType: /
    union {
       DSLOGDETAIL lastError;
       int rowCount;
       char *linkName;
       char *linkSQLState;
       char *linkDBMSCode;
       char *linkDesc;
       char *linkedStage;
       char *rowCountList;
    } info;
    } DSLINKINFO;
Members
    infoType is a key indicating the type of information and is one of the following
    values:
    This key...
           Indicates this information...
    DSJ_LINKLASTERR
          The last error message reported from a link.
    DSJ_LINKNAME
          Actual name of link.
    DSJ_LINKROWCOUNT
          The number of rows that have been passed down a link.
    DSJ_LINKSQLSTATE
          SQLSTATE value from last error message.
    DSJ_LINKDBMSCODE
          DBMSCODE value from last error message.
    DSJ_LINKDESC
          Description of the link.
    DSJ_LINKSTAGE
          Name of the stage at the other end of the link.
    DSJ_INSTROWCOUNT
          Comma-separated list of row counts, one per instance (parallel jobs)
    lastError is a data structure containing the error log entry for the last error message
    reported from a link and is returned when infoType is set to DSJ_LINKLASTERR.
    rowCount is the number of rows that have been passed down a link so far and is
    returned when infoType is set to DSJ_LINKROWCOUNT.
DSLOGDETAIL
    The DSLOGDETAIL structure represents detailed information for a single entry
    from a job log file.
    Syntax
    typedef struct _DSLOGDETAIL {
       int eventId;
       time_t timestamp;
Members
eventId is a number, 0 or greater, that uniquely identifies the log entry for the job.
timestamp is the date and time at which the entry was added to the job log file.
                          type is a key indicting the type of the event, and is one of the following values:
                          This key...
                                 Indicates this type of log entry...
                          DSJ_LOGINFO
                                Information
                          DSJ_LOGWARNING
                                Warning
                          DSJ_LOGFATAL
                                Fatal error
                          DSJ_LOGREJECT
                                Transformer row rejection
                          DSJ_LOGSTARTED
                                Job started
                          DSJ_LOGRESET
                                Job reset
                          DSJ_LOGBATCH
                                Batch control
                          DSJ_LOGOTHER
                                Any other type of log entry
reserved is reserved for future use with a later release of InfoSphere DataStage.
             DSLOGEVENT
                          The DSLOGEVENT structure represents the summary information for a single
                          entry from a job's event log.
                          Syntax
                          typedef struct _DSLOGEVENT {
                             int eventId;
                             time_t timestamp;
                             int type;
                             char *message;
                          } DSLOGEVENT;
76   Programmer's Guide
    Members
eventId is a number, 0 or greater, that uniquely identifies the log entry for the job.
timestamp is the date and time at which the entry was added to the job log file.
    type is a key indicating the type of the event, and is one of the following values:
    This key...
           Indicates this type of log entry...
    DSJ_LOGINFO
          Information
    DSJ_LOGWARNING
          Warning
    DSJ_LOGFATAL
          Fatal error
    DSJ_LOGREJECT
          Transformer row rejection
    DSJ_LOGSTARTED
          Job started
    DSJ_LOGRESET
          Job reset
    DSJ_LOGBATCH
          Batch control
    DSJ_LOGOTHER
          Any other type of log entry
DSPARAM
    The DSPARAM structure represents information about the type and value of an
    InfoSphere DataStage job parameter.
    Syntax
    typedef struct _DSPARAM {
    int paramType;
    union {
       char *pString;
       char *pEncrypt;
       int pInt;
       float pFloat;
       char *pPath;
       char *pListValue;
       char *pDate;
       char *pTime;
    } paramValue;
    } DSPARAM;
Members
    paramType is a key specifying the type of the job parameter. Possible values are as
    follows:
                          pPath is a null-terminated character string specifying a file system path name and
                          is returned when paramType is set to DSJ_PARAMTYPE_PATHNAME.
                          Note: This parameter does not need to specify a valid path name on the engine.
                          Interpretation and validation of the path name is performed by the job.
78   Programmer's Guide
DSPARAMINFO
    The DSPARAMINFO structure represents information values about a parameter of
    an InfoSphere DataStage job.
    Syntax
    typedef struct _DSPARAMINFO {
       DSPARAM defaultValue;
       char *helpText;
       char *paramPrompt;
       int paramType;
       DSPARAM desDefaultValue;
       char *listValues;
       char *desListValues;
       int promptAtRun;
    } DSPARAMINFO;
Members
    paramType is a key specifying the type of the job parameter. Possible values are as
    follows:
    This key...
           Indicates this type of parameter...
    DSJ_PARAMTYPE_STRING
          A character string.
    DSJ_PARAMTYPE_ENCRYPTED
          An encrypted character string (for example, a password).
    DSJ_PARAMTYPE_INTEGER
          An integer.
    DSJ_PARAMTYPE_FLOAT
          A floating-point number.
    DSJ_PARAMTYPE_PATHNAME
          A file system path name.
    DDSJ_PARAMTYPE_LIST
          A character string specifying one of the values from an enumerated list.
    DDSJ_PARAMTYPE_DATE
          A date in the format YYYY-MM-DD.
    DSJ_PARAMTYPE_TIME
          A time in the format HH:MM:SS.
desDefaultValue is the default value set for the parameter by the job's designer.
                          desListValues is a pointer to a buffer containing the default list of values set for the
                          parameter by the job's designer. The buffer contains a series of null-terminated
                          strings, one for each valid string that can be used as the parameter value, that ends
                          with a second null character. The following example shows the buffer contents
                          with <null> representing the terminating null character:
                          first<null>second<null><null>
             DSPROJECTINFO
                          The DSPROJECTINFO structure represents information values for an InfoSphere
                          DataStage project.
                          Syntax
                          typedef struct _DSPROJECTINFO {
                             int infoType;
                             union {
                             char *jobList;
                             } info;
                          } DSPROJECTINFO;
Members
80   Programmer's Guide
DSREPOSINFO
    The DSREPOSINFO structure gives information about design-time objects that
    have been searched for.
    Syntax
    struct _DSREPOSJOBINFO;
    typedef struct _DSREPOSJOBINFO DSREPOSJOBINFO;
    struct _DSREPOSJOBINFO
    {
          char* jobname;    /* Includes category */
          int jobtype;      /* InfoType constant */
          DSREPOSJOBINFO* nextjob; /* ptr next job or NULL */
    };
    typedef struct _DSREPOSINFO
    {
          int infoType;
          union
          {
             DSREPOSJOBINFO* jobs; /*linkedlist of found jobs */
          } info;
    } DSREPOSINFO;
Members
DSREPOSUSAGE
    The DSREPOSUSAGE structure gives information about objects meeting a specified
    relationship.
DSREPOSUSAGE
Members
             DSSTAGEINFO
                          The DSSTAGEINFO structure represents various information values about an
                          active stage within an InfoSphere DataStage job.
                          Syntax
                          typedef struct _DSSTAGEINFO {
                          int infoType;
                          union {
                             DSLOGDETAIL lastError;
                             char *typeName;
                             int inRowNum;
                             char *linkList;
                             char *stagename;
                             char *varlist;
                             char *stageStartTime;
                             char *stageEndTime;
                             char *linkTypes;
                             char *stageDesc;
                             char *instList;
                             char *cpuList;
                             time_t stageElapsed;
                             char *pidList;
82   Programmer's Guide
   int stageStatus;
   char *custInfoList
} info;
} DSSTAGEINFO;
Members
lastError is a data structure containing the error message for the last error (if any)
reported from any link of the stage. It is returned when infoType is set to
DSJ_STAGELASTERR.
                          inRowNum is the primary link's input row number and is returned when infoType is
                          set to DSJ_STAGEINROWNUM.
              DSVARINFO
                          The DSVARINFO structure represents various information values about a link to
                          or from an active stage within an InfoSphere DataStage job.
                          Syntax
                          typedef struct _DSVARINFO {
                          int infoType: /
                          union {
                             char *varValue;
                             char *varDesc;
                          } info;
                          } DSVARINFO;
Members
                          infoType is a key indicating the type of information and is one of the following
                          values:
                          This key...
                                 Indicates this information...
                          DSJ_VARVALUE
                                The value of the specified variable.
                          DSJ_VARDESC
                                The description of the specified variable.
              Error Codes
                          The following table lists InfoSphere DataStage API error codes in alphabetic order:
Table 2. API Error Codes
Error Token                             Code                                  Description
DSJE_ACCOUNTPATHFAILED                  -140                                  Failed to get account path.
DSJE_ADDPROJECTBLOCKED                  -134                                  Another user is adding a project.
DSJE_ADDPROJECTFAILED                   -135                                  Failed to add project.
DSJEBADBOOLEANVALUE                     -118                                  Invalid value given for a boolean
                                                                              environment variable.
DSJE_BADENVVAR                          -116                                  Environment variable does not exist.
DSJE_BADENVVARNAME                      -108                                  Invalid environment variable name.
DSJE_BADENVVARTYPE                      -109                                  Invalid environment variable type.
DSJE_BADENVVARPROMPT                    -110                                  No prompt supplied.
84   Programmer's Guide
Table 2. API Error Codes (continued)
Error Token                            Code                                       Description
DSJE_BADHANDLE                         -1                                         Invalid JobHandle.
DSJE_BADLINK                           -9                                         LinkName does not refer to a known
                                                                                  link for the stage in question.
DSJE_BADLISTVALUE                      -120                                       Invalid value given for a list
                                                                                  environment variable.
DSJE_BADNAME                           -12                                        Invalid project name.
DSJE_BADNUMERICVALUE                   -119                                       Invalid value given for an integer
                                                                                  environment variable.
DSJE_BADPARAM                          -3                                         ParamName is not a parameter name
                                                                                  in the job.
DSJE_BADPROJECT                        -1002                                      ProjectName is not a known
                                                                                  InfoSphere DataStage project.
DSJE_BADPROJLOCATION                   -130                                       Invalid path name supplied.
DSJE_BADPROJNAME                       -128                                       Invalid project name supplied.
DSJE_BADPROPERTY                       -104                                       Unknown property name.
DSJE_BADPROPVALUE                      -106                                       Invalid value for this property.
DSJE_BADSTAGE                          -7                                         StageName does not refer to a known
                                                                                  stage in the job.
DSJE_BADSTATE                          -2                                         Job is not in the right state (compiled,
                                                                                  not running).
DSJE_BADTIME                           -13                                        Invalid StartTime or EndTime value.
DSJE_BADTYPE                           -5                                         Information or event type was
                                                                                  unrecognized.
DSJE_BAD_VERSION                       -1008                                      The engine does not support this
                                                                                  version of the InfoSphere DataStage
                                                                                  API.
DSJE_BADVALUE                          -4                                         Invalid MaxNumber value.
DSJE_CLEARSCHEDULEFAILED               -127                                       Failed to clear scheduled jobs for
                                                                                  project.
DSJE_DECRYPTERR                        -15                                        Failed to decrypt encrypted values.
DSJE_DELETEPROJECTBLOCKED              -138                                       Project locked by another user.
DSJE_DELPROJFAILED                     -124                                       Failed to delete project definition.
DSJE_DELPROJFILESFAILED                -125                                       Failed to delete project files.
DSJE_DUPENVVARNAME                     -115                                       Environment variable being added
                                                                                  already exists.
DSJE_ENCODEFAILED                      -123                                       Failed to encode an encrypted value.
DSJE_GETDEFAULTPATHFAILED              -129                                       Failed to determine default project
                                                                                  directory.
DSJE_INCOMPATIBLE_SERVER               -1009                                      The engine version is incompatible
                                                                                  with this version of the InfoSphere
                                                                                  DataStage API.
DSJE_ISADMINFAILED                     -101                                       Failed to determine whether user is
                                                                                  an administrator.
DSJE_ISPARALLELLICENCED                -122                                       Failed to determine if parallel jobs
                                                                                  are available.
86   Programmer's Guide
Table 2. API Error Codes (continued)
Error Token                            Code                                      Description
DSJE_TIMEOUT                           -14                                       The job appears not to have started
                                                                                 after waiting for a reasonable length
                                                                                 of time. (About 30 minutes.)
DSJE_UNKNOWN_JOBNAME                   -201                                      The supplied job name cannot be
                                                                                 found in the project.
DSJE_WRITEENVVARDEFNS                  -113                                      Failed to write environment variable
                                                                                 definitions.
DSJE_WRITEENVVARVALUES                 -114                                      Failed to write environment variable
                                                                                 values.
DSJE_WRITEPROJPROPERTY                 -103                                      Property not supported.
DSJE_WRONGJOB                          -6                                        Job for this JobHandle was not started
                                                                                 from a call to DSRunJob by the
                                                                                 current process.
                        The following table lists InfoSphere DataStage API error codes in numeric order:
Table 3. API error codes in numeric order
Code                                   Error Token                               Description
0                                      DSJE_NOERROR                              No InfoSphere DataStage API error
                                                                                 has occurred.
-1                                     DSJE_BADHANDLE                            Invalid JobHandle.
-2                                     DSJE_BADSTATE                             Job is not in the right state (compiled,
                                                                                 not running).
-3                                     DSJE_BADPARAM                             ParamName is not a parameter name
                                                                                 in the job.
-4                                     DSJE_BADVALUE                             Invalid MaxNumber value.
-5                                     DSJE_BADTYPE                              Information or event type was
                                                                                 unrecognized.
-6                                     DSJE_WRONGJOB                             Job for this JobHandle was not started
                                                                                 from a call to DSRunJob by the
                                                                                 current process.
-7                                     DSJE_BADSTAGE                             StageName does not refer to a known
                                                                                 stage in the job.
-8                                     DSJE_NOTINSTAGE                           Internal engine error.
-9                                     DSJE_BADLINK                              LinkName does not refer to a known
                                                                                 link for the stage in question.
-10                                    DSJE_JOBLOCKED                            The job is locked by another process.
-11                                    DSJE_JOBDELETED                           The job has been deleted.
-12                                    DSJE_BADNAME                              Invalid project name.
-13                                    DSJE_BADTIME                              Invalid StartTime or EndTime value.
-14                                    DSJE_TIMEOUT                              The job appears not to have started
                                                                                 after waiting for a reasonable length
                                                                                 of time. (About 30 minutes.)
-15                                    DSJE_DECRYPTERR                           Failed to decrypt encrypted values.
88     Programmer's Guide
Table 3. API error codes in numeric order (continued)
Code                                   Error Token                              Description
-127                                   DSJE_CLEARSCHEDULEFAILED                 Failed to clear scheduled jobs for
                                                                                project.
-128                                   DSJE_BADPROJNAME                         Invalid project name supplied.
-129                                   DSJE_GETDEFAULTPATHFAILED                Failed to determine default project
                                                                                directory.
-130                                   DSJE_BADPROJLOCATION                     Invalid path name supplied.
-131                                   DSJE_INVALIDPROJECTLOCATION              Invalid path name supplied.
-132                                   DSJE_OPENFAILED                          Failed to open UV.ACCOUNT file.
-133                                   DSJE_READUFAILED                         Failed to lock project create lock
                                                                                record.
-134                                   DSJE_ADDPROJECTBLOCKED                   Another user is adding a project.
-135                                   DSJE_ADDPROJECTFAILED                    Failed to add project.
-136                                   DSJE_LICENSEPROJECTFAILED                Failed to license project.
-137                                   DSJE_RELEASEFAILED                       Failed to release project create lock
                                                                                record.
-138                                   DSJE_DELETEPROJECTBLOCKED                Project locked by another user.
-139                                   DSJE_NOTAPROJECT                         Failed to log to project.
-140                                   DSJE_ACCOUNTPATHFAILED                   Failed to get account path.
-141                                   DSJE_LOGTOFAILED                         Failed to log to UV account.
-201                                   DSJE_UNKNOWN_JOBNAME                     The supplied job name cannot be
                                                                                found in the project.
-1001                                  DSJE_NOMORE                              All events matching the filter criteria
                                                                                have been returned.
-1002                                  DSJE_BADPROJECT                          ProjectName is not a known
                                                                                InfoSphere DataStage project.
-1003                                  DSJE_NO_DATASTAGE                        InfoSphere DataStage is not installed
                                                                                on the system.
-1004                                  DSJE_OPENFAIL                            The attempt to open the job failed -
                                                                                perhaps it has not been compiled.
-1005                                  DSJE_NO_MEMORY                           Failed to allocate dynamic memory.
-1006                                  DSJE_SERVER_ERROR                        An unexpected or unknown error
                                                                                occurred in the engine.
-1007                                  DSJE_NOT_AVAILABLE                       The requested information was not
                                                                                found.
-1008                                  DSJE_BAD_VERSION                         The engine does not support this
                                                                                version of the InfoSphere DataStage
                                                                                API.
-1009                                  DSJE_INCOMPATIBLE_SERVER                 The engine version is incompatible
                                                                                with this version of the InfoSphere
                                                                                DataStage API.
                        The following table lists some common errors that might be returned from the
                        lower-level communication tiers:
90   Programmer's Guide
     Table 5. BASIC Functions (continued)
     To do this...                                     Use this...
     Log an information message in a job's log         DSLogInfo
     file.
     Put an info message in the job log of a job       DSLogToController
     controlling current job.
     Log a warning message in a job's log file.        DSLogWarn
     Generate a string describing the complete         DSMakeJobReport
     status of a valid attached job.
     Insert arguments into the message template.       DSMakeMsg
     Ensure a job is in the correct state to be run    DSPrepareJob
     or validated.
     Interface to system send mail facility.           DSSendMail
     Log a warning message to a job log file.          DSTransformError
     Convert a job control status or error code        DSTranslateCode
     into an explanatory text message.
     Suspend a job until a named file either exists DSWaitForFile
     or does not exist.
     Checks if a BASIC routine is cataloged,           DSCheckRoutine
     either in VOC as a callable item, or in the
     catalog space.
     Execute a DOS or engine command from a            DSExecute
     before/after subroutine.
     Set a status message for a job to return as a     DSSetUserStatus
     termination message when it finishes
     Specifies whether a job generates operational DSSetGenerateOpMetaData
     metadata as it runs. This overrides the
     default setting for the project.
DSAttachJob
     Attaches to a job in order to run it in job control sequence. A handle is returned
     which is used for addressing the job. There can only be one handle open for a
     particular job at any one time.
     Syntax
     JobHandle = DSAttachJob (JobName, ErrorMode)
     JobHandle is the name of a variable to hold the return value which is subsequently
     used by any other function or routine when referring to the job. Do not assume
     that this value is an integer.
     ErrorMode is a value specifying how other routines using the handle should report
     errors. It is one of:
     v DSJ.ERRFATAL Log a fatal message and abort the controlling job (default).
     v DSJ.ERRWARNING Log a warning message but carry on.
     v DSJ.ERRNONE No message logged - caller takes full responsibility (failure of
        DSAttachJob itself will be logged, however).
                          The JobName parameter can specify either an exact version of the job in the form
                          job%Reln.n.n, or the latest version of the job in the form job. If a controlling job is
                          itself released, you will get the latest released version of job. If the controlling job is
                          a development version, you will get the latest development version of job.
Example
             DSCheckRoutine
                          Checks if a BASIC routine is cataloged, either in the VOC as a callable item, or in
                          the catalog space.
                          Syntax
                          Found = DSCheckRoutine(RoutineName)
                          Example
                          rtn$ok = DSCheckRoutine("DSU.DSSendMail")
                          If(NOT(rtn$ok)) Then
                             * error handling here
                          End.
             DSDetachJob
                          Gives back a JobHandle acquired by DSAttachJob if no further control of a job is
                          required (allowing another job to become its controller). It is not necessary to call
                          this function, otherwise any attached jobs will always be detached automatically
                          when the controlling job finishes.
                          Syntax
                          ErrCode = DSDetachJob (JobHandle)
                          The only possible error is an attempt to close DSJ.ME. Otherwise, the call always
                          succeeds.
Example
                          The following command detaches the handle for the job qsales:
                          Deterr = DSDetachJob (qsales_handle)
92   Programmer's Guide
DSExecute
     Executes a DOS, UNIX, or engine command from a before/after subroutine.
     Syntax
     Call DSExecute (ShellType, Command, Output, SystemReturnCode)
     ShellType (input) specifies the type of command that you want to execute and is
     NT, UNIX, or UV (for engine).
     Command (input) is the command to execute. Command should not prompt for
     input when it is executed.
     Output (output) is any output from the command. Each line of output is separated
     by a field mark, @FM. Output is added to the job log file as an information
     message.
Remarks
     Do not use DSExecute from a transform; the overhead of running a command for
     each row processed by a stage will degrade performance of the job.
DSGetCustInfo
     Obtains information reported at the end of execution of certain parallel stages. The
     information collected, and available to be interrogated, is specified at design time.
     For example, transformer stage information is specified in the Triggers tab of the
     Transformer stage Properties dialog box.
     Syntax
     Result = DSGetCustInfo (JobHandle, StageName, CustInfoName, InfoType)
     JobHandle is the handle for the job as derived from DSAttachJob, or it might be
     DSJ.ME to refer to the current job.
DSJ.CUSTINFOVALUE
DSJ.CUSTINFODESC
             DSGetJobInfo
                          Provides a method of obtaining information about a job, which can be used
                          generally as well as for job control. It can refer to the current job or a controlled
                          job, depending on the value of JobHandle.
                          Syntax
                          Result = DSGetJobInfo (JobHandle, InfoType)
                          JobHandle is the handle for the job as derived from DSAttachJob, or it might be
                          DSJ.ME to refer to the current job.
DSJ.JOBSTATUS
DSJ.JOBNAME
DSJ.JOBCONTROLLER
DSJ.JOBSTARTTIMESTAMP
DSJ.JOBWAVENO
DSJ.PARAMLIST
DSJ.STAGELIST
DSJ.USERSTATUS
DSJ.JOBCONTROL
DSJ.JOBPID
DSJ.JPBLASTTIMESTAMP
DSJ.JOBINVOCATIONS
DSJ.JOBINTERIMSTATUS
DSJ.JOBINVOCATIONID
DSJ.JOBDESC
DSJ.JOBFULLDESC
94   Programmer's Guide
DSJ.STAGELIST2
DSJ.JOBELAPSED
DSJ.JOBEOTCOUNT
DSJ.JOBEOTTIMESTAMP
DSJ.JOBRTISERVICE
DSJ.JOBMULTIINVOKABLE
DSJ.JOBFULLSTAGELIST
Remarks
                          When referring to a controlled job, DSGetJobInfo can be used either before or after
                          a DSRunJob has been issued. Any status returned following a successful call to
                          DSRunJob is guaranteed to relate to that run of the job.
Examples
                          The following command requests the job status of the job qsales:
                          q_status = DSGetJobInfo(qsales_handle, DSJ.JOBSTATUS)
                          The following command requests the actual name of the current job:
                          whatname = DSGetJobInfo (DSJ.ME, DSJ.JOBNAME)
             DSGetLinkInfo
                          Provides a method of obtaining information about a link on an active stage, which
                          can be used generally as well as for job control. This routine might reference either
                          a controlled job or the current job, depending on the value of JobHandle.
                          Syntax
                          Result = DSGetLinkInfo (JobHandle, StageName, LinkName, InfoType)
                          JobHandle is the handle for the job as derived from DSAttachJob, or it can be
                          DSJ.ME to refer to the current job.
                          StageName is the name of the active stage to be interrogated. might also be DSJ.ME
                          to refer to the current stage if necessary.
96   Programmer's Guide
LinkName is the name of a link (input or output) attached to the stage. might also
be DSJ.ME to refer to current link (for example, when used in a Transformer
expression or transform function called from link code).
DSJ.LINKLASTERR
DSJ.LINKNAME
DSJ.LINKROWCOUNT
DSJ.LINKSQLSTATE
DSJ.LINKDBMSCODE
DSJ.LINKDESC
DSJ.LINKSTAGE
DSJ.INSTROWCOUNT
DSJ.LINKEOTROWCOUNT
Example
                          The following command requests the number of rows that have passed down the
                          order_feed link in the loader stage of the job qsales:
                          link_status = DSGetLinkInfo(qsales_handle, "loader",
                          → "order_feed", DSJ.LINKROWCOUNT)
             DSGetLogEntry
                          Reads the full event details given in EventId.
                          Syntax
                          EventDetail = DSGetLogEntry (JobHandle, EventId)
                          EventId is an integer that identifies the specific log event for which details are
                          required. This is obtained using the DSGetNewestLogId function.
                          If an error occurs, the error is reported by one of the following negative integer
                          result codes:
                          v DSJE.BADHANDLE Invalid JobHandle.
                          v DSJE.BADVALUE Error accessing EventId.
Example
                          The following commands first get the EventID for the required log event and then
                          reads full event details of the log event identified by LatestLogid into the string
                          LatestEventString:
                          latestlogid =
                          → DSGetNewestLogId(qsales_handle,DSJ.LOGANY)
                          LatestEventString =
                          → DSGetLogEntry(qsales_handle,latestlogid)
             DSGetLogEventIds
                          Returns a list of log event IDs for a given run of a job invocation.
98   Programmer's Guide
     Syntax
     IdList = DSGetLogEventIds (JobHandle, RunNumber, EventTypeFilter)
     RunNumber identifies the job invocation run for which event IDs are returned.
     Usually a zero value requests IDs for the most recent run of the job invocation. To
     retrieve details for earlier runs, supply negative values, such as -1 for details about
     the run before the most recent, -2 for details about the run before that, and so
     forth. Where explicit run numbers are known, you can retrieve details by
     supplying the run number as a positive value.
     EventTypeFilter restricts the types of event log entry for which IDs are returned. By
     default, IDs for all log entries are returned. Include characters in the filter string to
     restrict entries as follows:
     I       Informational
     W       Warning
     F       Fatal
     S       Start or End events
     B       Batch or Control events
     R       Purge or reset events
     J       Reject events
     IdList is returned as a list of positive integers that identify the required log events.
     In the case of an error, IdList can also be returned as a negative integer, in which
     case it contains one of these error codes:
     DSJE.BADHANDLE
           Invalid JobHandle.
     DSJE.BADTYPE
           Invalid EventTypeFilter.
     DSJE.BADVALUE
           Invalid RunNumber.
Remarks
     To use this method, the program needs to have previously acquired a job handle
     by calling DSAttachJob.
     The run number for a job invocation is reset when the job is compiled, thus it is
     not possible to use this method to retrieve job event IDs for runs that occurred
     prior to the most recent job compilation.
DSGetLogSummary
     Returns a list of short log event details. The details returned are determined by the
     setting of some filters. (Care should be taken with the setting of the filters,
     otherwise a large amount of information can be returned.)
                       If an error occurs, the error is reported by one of the following negative integer
                       result codes:
                       v DSJE.BADHANDLE Invalid JobHandle.
                       v DSJE.BADTYPE Invalid EventType.
                       v DSJE.BADTIME Invalid StartTime or EndTime.
                       v DSJE.BADVALUE Invalid MaxNumber.
Example
                       The following command produces an array of reject link active events recorded for
                       the qsales job between 18th August 1998, and 18th September 1998, up to a
                       maximum of MAXREJ entries:
                       RejEntries = DSGetLogSummary (qsales_handle,
                       → DSJ.LOGREJECT, "1998-08-18 00:00:00", "1998-09-18
                       → 00:00:00", MAXREJ)
            DSGetNewestLogId
                       Gets the ID of the most recent log event in a particular category, or in any
                       category.
     EventId is a positive integer that identifies the specific log event. In the case of an
     error, EventId can also be returned as a negative integer, in which case it contains
     an error code as follows:
     v DSJE.BADHANDLE Invalid JobHandle.
     v DSJE.BADTYPE Invalid EventType.
Example
     The following command obtains an ID for the most recent warning message in the
     log for the qsales job:
     Warnid = DSGetNewestLogId (qsales_handle,
     → DSJ.LOGWARNING)
DSGetParamInfo
     Provides a method of obtaining information about a parameter, which can be used
     generally as well as for job control. This routine might reference either a controlled
     job or the current job, depending on the value of JobHandle.
     Syntax
     Result = DSGetParamInfo (JobHandle, ParamName, InfoType)
     JobHandle is the handle for the job as derived from DSAttachJob, or it might be
     DSJ.ME to refer to the current job.
DSJ.PARAMDEFAULT
DSJ.PARAMHELPTEXT
DSJ.PARAMPROMPT
DSJ.PARAMTYPE
DSJ.PARAMVALUE
DSJ.PARAMLISTVALUES
DSJ.PARAMDES.LISTVALUES
DSJ.PARAMPROMPT.AT.RUN
Remarks
      The following command requests the default value of the quarter parameter for the
      qsales job:
      Qs_quarter = DSGetparamInfo(qsales_handle, "quarter",
      → DSJ.PARAMDEFAULT)
DSGetProjectInfo
      Provides a method of obtaining information about the current project.
      Syntax
      Result = DSGetProjectInfo (InfoType)
DSJ.JOBLIST
DSJ.PROJECTNAME
DSJ.HOSTNAME
DSGetStageInfo
      Provides a method of obtaining information about a stage, which can be used
      generally as well as for job control. It can refer to the current job, or a controlled
      job, depending on the value of JobHandle.
      Syntax
      Result = DSGetStageInfo (JobHandle, StageName, InfoType)
      JobHandle is the handle for the job as derived from DSAttachJob, or it might be
      DSJ.ME to refer to the current job.
DSJ.LINKLIST
DSJ.STAGELASTERR
DSJ.STAGENAME
DSJ.STAGEINROWNUM
DSJ.VARLIST
DSJ.STAGESTARTTIMESTAMP
DSJ.STAGEENDTIMESTAMP
DSJ.STAGEDESC
DSJ.STAGEINST
DSJ.STAGECPU
DSJ.LINKTYPES
DSJ.STAGEELAPSED
DSJ.STAGEPID
DSJ.STAGESTATUS
DSJ.STAGEEOTCOUNT
DSJ.STAGEEOTTIMESTAMP
DSJ.CUSTINFOLIST
DSJ.STAGEEOTSTART
     Remarks
     When referring to a controlled job, DSGetStageInfo can be used either before or
     after a DSRunJob has been issued. Any status returned following a successful call
     to DSRunJob is guaranteed to relate to that run of the job.
Example
     The following command requests the last error message for the loader stage of the
     job qsales:
     stage_status = DSGetStageInfo(qsales_handle, "loader",
     → DSJ.STAGELASTERR)
DSGetVarInfo
     Provides a method of obtaining information about variables used in transformer
     stages.
     Syntax
     Result = DSGetVarInfo (JobHandle, StageName, VarName, InfoType)
     JobHandle is the handle for the job as derived from DSAttachJob, or it might be
     DSJ.ME to refer to the current job.
DSJ.VARVALUE
DSJ.VARDESCRIPTION
            DSLogEvent
                       Logs an event message to a job other than the current one. (Use DSLogInfo,
                       DSLogFatal, or DSLogWarn to log an event to the current job.)
                       Syntax
                       ErrCode = DSLogEvent (JobHandle, EventType, EventMsg)
Example
                       The following command, when included in the msales job, adds the message
                       "monthly sales complete" to the log for the qsales job:
                       Logerror = DsLogEvent (qsales_handle, DSJ.LOGINFO,
                       → "monthly sales complete")
            DSLogFatal
                       Logs a fatal error message in a job's log file and terminates the job.
                       Syntax
                       Call DSLogFatal (Message, CallingProgName)
                       Message (input) is the warning message you want to log. Message is automatically
                       prefixed with the name of the current stage and the calling before/after subroutine.
                       CallingProgName (input) is the name of the before/after subroutine that calls the
                       DSLogFatal subroutine.
     DSLogFatal writes the fatal error message to the job log file and aborts the job.
     DSLogFatal never returns to the calling before/after subroutine, so it should be
     used with caution. If a job stops with a fatal error, it must be reset by using the
     Director client before it can be rerun.
     Example
     Call DSLogFatal("Cannot open file", "MyRoutine")
DSLogInfo
     Logs an information message in a job's log file.
     Syntax
     Call DSLogInfo (Message, CallingProgName)
Remarks
     DSLogInfo writes the message text to the job log file as an information message
     and returns to the calling routine or transform. If DSLogInfo is called during the
     test phase for a newly created routine in the repository, the two arguments are
     displayed in the results window.
     Unlimited information messages can be written to the job log file. However, if a lot
     of messages are produced, the job might run slowly and the Director client might
     take some time to display the job log file.
     Example
     Call DSLogInfo("Transforming: ":Arg1, "MyTransform")
DSLogToController
     This routine might be used to put an info message in the log file of the job
     controlling this job, if any. If there isn't one, the call is just ignored.
     Syntax
     Call DSLogToController(MsgString)
                       Example
                       Call DSLogToController("This is logged to parent")
            DSLogWarn
                       Logs a warning message in a job's log file.
                       Syntax
                       Call DSLogWarn (Message, CallingProgName)
                       Message (input) is the warning message you want to log. Message is automatically
                       prefixed with the name of the current stage and the calling before/after subroutine.
                       CallingProgName (input) is the name of the before/after subroutine that calls the
                       DSLogWarn subroutine.
Remarks
                       DSLogWarn writes the message to the job log file as a warning and returns to the
                       calling before/after subroutine. If the job has a warning limit defined for it, when
                       the number of warnings reaches that limit, the call does not return and the job is
                       aborted.
                       Example
                       If InputArg > 100 Then
                          Call DSLogWarn("Input must be =< 100; received
                             ":InputArg,"MyRoutine")
                       End Else
                          * Carry on processing unless the job aborts
                       End
            DSMakeJobReport
                       Generates a report describing the complete status of a valid attached job.
                       Syntax
                       ReportText = DSMakeJobReport(JobHandle, ReportLevel, LineSeparator)
    LineSeparator is the string used to separate lines of the report. Special values
    recognized are:
    v "CRLF" => CHAR(13):CHAR(10)
    v "LF" => CHAR(10)
    v "CR" => CHAR(13)
Remarks
    Example
    h$ = DSAttachJob("MyJob", DSJ.ERRNONE)
    rpt$ = DSMakeJobReport(h$,0,"CRLF")
DSMakeMsg
    Insert arguments into a message template. Optionally, it will look up a template ID
    in the standard InfoSphere DataStage message file, and use any returned message
    template instead of that given to the routine.
    Syntax
    FullText = DSMakeMsg(Template, ArgList)
Remarks
This routine is called from job control code created by the JobSequence Generator.
    It will also perform local job parameter substitution in the message text. That is, if
    called from within a job, it looks for substrings such as "#xyz#" and replaces them
    with the value of the job parameter named "xyz".
    Example
    t$ = DSMakeMsg("Error calling DSAttachJob(%1)<L>%2",
    →jb$:@FM:DSGetLastErrorMsg())
                       Syntax
                       JobHandle = DSPrepareJob(JobHandle)
                       Example
                       h$ = DSPrepareJob(h$)
            DSRunJob
                       Starts a job running. Note that this call is asynchronous; the request is passed to
                       the runtime engine, but you are not informed of its progress.
                       Syntax
                       ErrCode = DSRunJob (JobHandle, RunMode)
                       RunMode is the name of the mode that the job is to be run in and is one of:
                       v DSJ.RUNNORMAL (Default) Standard job run.
                       v DSJ.RUNRESET Job is to be reset.
                       v DSJ.RUNVALIDATE Job is to be validated only.
                       v DSJ.RUNRESTART Restartable job sequence is to be restarted with the original
                         job parameter values.
Remarks
                       If the controlling job is running in validate mode, then any calls of DSRunJob will
                       act as if RunMode was DSJ.RUNVALIDATE, regardless of the actual setting.
                       A job in validate mode will run its JobControl routine (if any) rather than just
                       check for its existence, as is the case for before/after routines. This allows you to
                       examine the log of what jobs it started up in validate mode.
                       After a call of DSRunJob, the controlled job's handle is unloaded. If you require to
                       run the same job again, you must use DSDetachJob and DSAttachJob to set a new
                       handle. Note that you will also need to use DSWaitForJob, as you cannot attach to
                       a job while it is running.
DSSendMail
     This routine is an interface to a sendmail program that is assumed to exist
     somewhere in the search path of the current user (on the engine tier host). It hides
     the different call interfaces to various sendmail programs, and provides a simple
     interface for sending text. For example:
     Syntax
     Reply = DSSendMail(Parameters)
       Note: The text of the body might contain the tokens "%report% or %fullreport%
       anywhere within it, which will cause a report on the current job status to be
       inserted at that point. A full report contains stage and link information as well
       as job status.
Remarks
     The routine looks for a local file, in the current project directory, with a
     well-known name. That is, a template to describe exactly how to run the local
     sendmail command.
            DSSetDisableJobHandler
                       Enable or disable job-level message handling.
                       Syntax
                       ErrCode = DSSetDisableJobHandler (JobHandle, value)
Example
                       The following command disables job-level message handling for the qsales job:
                       GenErr = DSSetDisableJobHandler (qsales_handle, TRUE)
            DSSetDisableProjectHandler
                       Enable or disable project-level message handling.
                       Syntax
                       ErrCode = DSSetDisableProjectHandler (ProjectHandle, value)
Example
                       The following command disables project-level message handling for the qsales
                       project:
                       GenErr = DSSetDisableProjectHandler (qsales_handle, TRUE)
            DSSetGenerateOpMetaData
                       Use this to specify whether the job generates operational metadata or not. This
                       overrides the default setting for the project.
Example
     The following command causes the job qsales to generate operational metadata
     whatever the project default specifies:
DSSetJobLimit
     By default a controlled job inherits any row or warning limits from the controlling
     job. These can, however, be overridden using the DSSetJobLimit function.
     Syntax
     ErrCode = DSSetJobLimit (JobHandle, LimitType, LimitValue)
     LimitType is the name of the limit to be applied to the running job and is one of:
     v DSJ.LIMITWARN Job to be stopped after LimitValue warning events.
     v DSJ.LIMITROWS Stages to be limited to LimitValue rows.
     LimitValue is an integer specifying the value to set the limit to. Set this to 0 to
     specify unlimited warnings.
Example
     The following command sets a limit of 10 warnings on the qsales job before it is
     stopped:
     LimitErr = DSSetJobLimit(qsales_handle,
     → DSJ.LIMITWARN, 10)
                       Syntax
                       ErrCode = DSSetParam (JobHandle, ParamName, ParamValue)
Example
                       The following commands set the quarter parameter to 1 and the startdate
                       parameter to 1/1/97 for the qsales job:
                       paramerr = DSSetParam (qsales_handle, "quarter", "1")
                       paramerr = DSSetParam (qsales_handle, "startdate",
                       → "1997-01-01")
            DSSetUserStatus
                       Applies only to the current job, and does not take a JobHandle parameter. It can be
                       used by any job in either a JobControl or After routine to set a termination code
                       for interrogation by another job. In fact, the code might be set at any point in the
                       job, and the last setting is the one that will be picked up at any time. So to be
                       certain of getting the actual termination code for a job the caller should use
                       DSWaitForJob and DSGetJobInfo first, checking for a successful finishing status.
                       This routine is defined as a subroutine not a function because there are no possible
                       errors.
                       Syntax
                       Call DSSetUserStatus (UserStatus)
DSStopJob
     This routine should only be used after a DSRunJob has been issued. It immediately
     sends a stop request to the runtime engine. The call is asynchronous. If you need
     to know that the job has actually stopped, you must call DSWaitForJob or use the
     Sleep statement and poll for DSGetJobStatus. Note that the stop request gets sent
     regardless of the job's current status.
     Syntax
     ErrCode = DSStopJob (JobHandle)
Example
DSTransformError
     Logs a warning message to a job log file. This function is called from transforms
     only.
     Syntax
     Call DSTransformError (Message, TransformName)
     Message (input) is the warning message you want to log. Message is automatically
     prefixed with the name of the current stage and the calling transform.
     TransformName (input) is the name of the transform that calls the DSTransformError
     subroutine.
Remarks
     DSTransformError writes the message (and other information) to the job log file as
     a warning and returns to the transform. If the job has a warning limit defined for
     it, when the number of warnings reaches that limit, the call does not return and
     the job is aborted.
     Example
     Function MySqrt(Arg1)
     If Arg1 < 0 Then
        Call DSTransformError("Negative value:"Arg1, "MySqrt")
            DSTranslateCode
                       Converts a job control status or error code into an explanatory text message.
                       Syntax
                       Ans = DSTranslateCode(Code)
                       Code is:
                       v If Code > 0, it's assumed to be a job status.
                       v If Code < 0, it's assumed to be an error code.
                       v (0 should never be passed in, and will return "no error")
Remarks
                       Example
                       code$ = DSGetLastErrorMsg()
                       ans$ = DSTranslateCode(code$)
            DSWaitForFile
                       Suspend a job until a named file either exists or does not exist.
                       Syntax
                       Reply = DSWaitForFile(Parameters)
                       Parameters is the full path of file to wait on. No check is made as to whether this is
                       a reasonable path (for example, whether all directories in the path exist). A path
                       name starting with "-", indicates a flag to check the nonexistence of the path. It is
                       not part of the path name.
                       Parameters might also end in the form " timeout:NNNN" (or "timeout=NNNN")
                       This indicates a non-default time to wait before giving up. There are several
                       possible formats, case-insensitive:
                       v nnn number of seconds to wait (from now)
                       v nnnS ditto
                       v nnnM number of minutes to wait (from now)
                       v nnnH number of hours to wait (from now)
                       v nn:nn:nn wait until this time in 24HH:NN:SS. If this or nn:nn time has passed,
                         will wait till next day.
                       The format might optionally terminate "/nn", indicating a poll delay time in
                       seconds. If omitted, a default poll time is used.
             Examples
             Reply = DSWaitForFile("C:\ftp\incoming.txt timeout:2H")
       DSWaitForJob
             This function is only valid if the current job has issued a DSRunJob on the given
             JobHandle(s). If one of the jobs whose handles are in the list has finished, the
             DSWaitForJob function returns immediately. If none of the jobs has finished, the
             DSWaitForJob function returns as soon as one of the jobs finishes.
             Syntax
             ErrCode = DSWaitForJob (JobHandle)
ErrCode is >0 => handle of the job that finished from a multi-job wait.
Remarks
Example
                          The files are all located in the InfoSphere DataStage client directory
                          (\IBM\InformationServer\Clients\Classic).
                          You can embed a reference to a stylesheet when you create the report using any of
                          the commands listed above. After the report is generated you can view it in an
                          Internet browser.
                          Alternatively you can use an xslt processor such as saxon or msxsl to convert an
                          already generated report. For example:
                          java - jar saxon.jar jobreport.xml DSReport-Monitor.xsl > jobmonitor.htm
                          would generate an HTML file called jobmonitor.htm from the report jobreport.xml,
                          while:
                          maxsl jobreport.xml DSReport-Waterfall.xsl > jobwaterfall.htm
                          The IBM InfoSphere Information Server product modules and user interfaces are
                          not fully accessible. The installation program installs the following product
                          modules and components:
                          v IBM InfoSphere Business Glossary
                          v IBM InfoSphere Business Glossary Anywhere
                          v IBM InfoSphere DataStage
                          v IBM InfoSphere FastTrack
                          v   IBM   InfoSphere   Information Analyzer
                          v   IBM   InfoSphere   Information Services Director
                          v   IBM   InfoSphere   Metadata Workbench
                          v   IBM   InfoSphere   QualityStage®
                          For information about the accessibility status of IBM products, see the IBM product
                          accessibility information at http://www.ibm.com/able/product_accessibility/
                          index.html.
Accessible documentation
                          See the IBM Human Ability and Accessibility Center for more information about
                          the commitment that IBM has to accessibility.
                          You can use the following methods to open the installed information center.
                          v Click the Help link in the upper right of the client interface.
                            Note: From IBM InfoSphere FastTrack and IBM InfoSphere Information Server
                            Manager, the main Help item opens a local help system. Choose Help > Open
                            Info Center to open the full suite information center.
                          v Press the F1 key. The F1 key typically opens the topic that describes the current
                            context of the client interface.
                          A subset of the information center is also available on the IBM Web site and
                          periodically refreshed at http://publib.boulder.ibm.com/infocenter/iisinfsv/v8r7/
                          index.jsp.
                       You can send your comments about documentation in the following ways:
                       v Online reader comment form: www.ibm.com/software/data/rcf/
                       v E-mail: comments@us.ibm.com
                          When you access a non-IBM Web site, even one that may contain the IBM-logo,
                          please understand that it is independent from IBM, and that IBM does not control
                          the content on that Web site. It is up to you to take precautions to protect yourself
                          from viruses, worms, trojan horses, and other potentially destructive programs,
                          and to protect your information as you deem appropriate.
Notices
                          IBM may not offer the products, services, or features discussed in this document in
                          other countries. Consult your local IBM representative for information on the
                          products and services currently available in your area. Any reference to an IBM
                          product, program, or service is not intended to state or imply that only that IBM
                          product, program, or service may be used. Any functionally equivalent product,
                          program, or service that does not infringe any IBM intellectual property right may
                          be used instead. However, it is the user's responsibility to evaluate and verify the
                          operation of any non-IBM product, program, or service.
                          IBM may have patents or pending patent applications covering subject matter
                          described in this document. The furnishing of this document does not grant you
                          any license to these patents. You can send license inquiries, in writing, to:
                          The following paragraph does not apply to the United Kingdom or any other
                          country where such provisions are inconsistent with local law:
                          INTERNATIONAL BUSINESS MACHINES CORPORATION PROVIDES THIS
                          PUBLICATION "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER
                          EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
                          WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS
                          FOR A PARTICULAR PURPOSE. Some states do not allow disclaimer of express or
                          implied warranties in certain transactions, therefore, this statement may not apply
                          to you.
                          Any references in this information to non-IBM Web sites are provided for
                          convenience only and do not in any manner serve as an endorsement of those Web
                       IBM may use or distribute any of the information you supply in any way it
                       believes appropriate without incurring any obligation to you.
                       Licensees of this program who wish to have information about it for the purpose
                       of enabling: (i) the exchange of information between independently created
                       programs and other programs (including this one) and (ii) the mutual use of the
                       information which has been exchanged, should contact:
                       IBM Corporation
                       J46A/G4
                       555 Bailey Avenue
                       San Jose, CA 95141-1003 U.S.A.
                       The licensed program described in this document and all licensed material
                       available for it are provided by IBM under terms of the IBM Customer Agreement,
                       IBM International Program License Agreement or any equivalent agreement
                       between us.
                       All statements regarding IBM's future direction or intent are subject to change or
                       withdrawal without notice, and represent goals and objectives only.
                       This information is for planning purposes only. The information herein is subject to
                       change before the products described become available.
                       This information contains examples of data and reports used in daily business
                       operations. To illustrate them as completely as possible, the examples include the
                       names of individuals, companies, brands, and products. All of these names are
                       fictitious and any similarity to the names and addresses used by an actual business
                       enterprise is entirely coincidental.
COPYRIGHT LICENSE:
Each copy or any portion of these sample programs or any derivative work, must
include a copyright notice as follows:
© (your company name) (year). Portions of this code are derived from IBM Corp.
Sample Programs. © Copyright IBM Corp. _enter the year or years_. All rights
reserved.
If you are viewing this information softcopy, the photographs and color
illustrations may not appear.
Trademarks
IBM, the IBM logo, and ibm.com are trademarks of International Business
Machines Corp., registered in many jurisdictions worldwide. Other product and
service names might be trademarks of IBM or other companies. A current list of
IBM trademarks is available on the Web at www.ibm.com/legal/copytrade.shtml.
Intel, Intel logo, Intel Inside, Intel Inside logo, Intel Centrino, Intel Centrino logo,
Celeron, Intel Xeon, Intel SpeedStep, Itanium, and Pentium are trademarks or
registered trademarks of Intel Corporation or its subsidiaries in the United States
and other countries.
Microsoft, Windows, Windows NT, and the Windows logo are trademarks of
Microsoft Corporation in the United States, other countries, or both.
UNIX is a registered trademark of The Open Group in the United States and other
countries.
                       The United States Postal Service owns the following trademarks: CASS, CASS
                       Certified, DPV, LACSLink, ZIP, ZIP + 4, ZIP Code, Post Office, Postal Service, USPS
                       and United States Postal Service. IBM Corporation is a non-exclusive DPV and
                       LACSLink licensee of the United States Postal Service.
                          The following table lists resources for customer support, software services, training,
                          and product and solutions information.
                          Table 6. IBM resources
                          Resource                                   Description and location
                          IBM Support Portal                         You can customize support information by
                                                                     choosing the products and the topics that
                                                                     interest you at www.ibm.com/support/
                                                                     entry/portal/Software/
                                                                     Information_Management/
                                                                     InfoSphere_Information_Server
                          Software services                          You can find information about software, IT,
                                                                     and business consulting services, on the
                                                                     solutions site at www.ibm.com/
                                                                     businesssolutions/
                          My IBM                                     You can manage links to IBM Web sites and
                                                                     information that meet your specific technical
                                                                     support needs by creating an account on the
                                                                     My IBM site at www.ibm.com/account/
                          Training and certification                 You can learn about technical training and
                                                                     education services designed for individuals,
                                                                     companies, and public organizations to
                                                                     acquire, maintain, and optimize their IT
                                                                     skills at http://www.ibm.com/software/sw-
                                                                     training/
                          IBM representatives                        You can contact an IBM representative to
                                                                     learn about solutions at
                                                                     www.ibm.com/connect/ibm/us/en/
                          Providing feedback
                          The following table describes how to provide feedback to IBM about products and
                          product documentation.
                          Table 7. Providing feedback to IBM
                          Type of feedback                           Action
                          Product feedback                           You can provide general product feedback
                                                                     through the Consumability Survey at
                                                                     www.ibm.com/software/data/info/
                                                                     consumability-survey
Printed in USA
SC19-3449-01
Spine information: