Using the bwdesign Utility

The bwdesign utility provides a command line interface for creating, validating, importing or exporting resources stored in a workspace.

Prerequisites

  1. To use the bwdesign utility, open a terminal and navigate to BW_HOME\bin.
  2. Type: bwdesign -data <TIBCO_BusinessStudio_workspace_absolutePath>. For example, bwdesign -data C:\myWorkspace.
To view arguments and options for a command, open a terminal, navigate to the BW_HOME\bin folder, and type bwdesign help command at the command line.
Command Name and Syntax Description
cd
SYNTAX:
cd path
Changes the current working directory to the specified folder.

ARGUMENTS:

  • path - The path of the new current working directory
clear
SYNTAX:
clear
Clears the command line console.
diagram:gen_diagrams
SYNTAX:
diagram:gen_diagrams [project]
Save each process diagram of a project in a .sgv format.

ARGUMENTS:

  • outputfolder - Optional argument, It's used to save the diagrams in a given path.
edition
SYNTAX:
edition
Prints out the edition of this BW Studio
execute
SYNTAX:
execute file
Executes a batch script file containing a set of commands to execute in sequence.

ARGUMENTS:

  • file - Script file which contains a set of commands to be executed in sequence
exit
SYNTAX:
exit
Exits the command line console.
generate_manifest_json
SYNTAX:
generate_manifest_json [options] [ear_location] [manifest_location]
Creates manifest.json from an bw ear file.

ARGUMENTS:

  • ear_location - The location of the BW EAR file
  • manifest_location - The destination folder that contains the created manifest.json file.
ls
SYNTAX:
ls [-f|-p] [-a]
List the projects in current workspace or the files in current working directory.

ARGUMENTS:

  • a - List all the entities including hidden ones.
  • f - List the files in file system
  • p - List the projects in the current workspace
pwd
SYNTAX:
pwd
Prints the location of the current working directory.
quit
SYNTAX:
quit
Exits the command line console.
setedition
SYNTAX:
setedition -name -t
EXAMPLE:
setedition -name test.application -t bwcf
Converts projects from their existing editions to this edition of TIBCO Business Studio™ for BusinessWorks™. If the option -name is not selected this command sets the edition of all the projects in the workspace to the current edition of TIBCO Business Studio for BusinessWorks.

Select the option -name, and provide the names of the projects to be converted.

Provide comma separated values to convert multiple projects. The -t tag changes the edition to the specified edition. The values to be used for the editions are bwcf, bwe and bwcloud.

Optional. If the -f option is used the following message is not prompted:

Are you sure you want to change edition of the given project.

system:create
SYNTAX:
system:create [options]

Alternatively, you can use create command.

EXAMPLE:
create application test2.application test
Note: This example generates test2.application for the test application module.
Creates resource(s) in the workspace.

Options:

  • --help - Display this help message.
  • -verbose - This parameter prints information regarding the workspace that is used for the create command.

    The success or failure message is printed at all times, even if the verbose flag is not used.

  • application [name] [modules] -v [version]

    Create an application project with the given name, including the given module(s).

    Optionally, specify the application version using the -v argument.

    Version format: major.minor.micro.qualifier For example: '1.0.0.qualifier'

  • -f - This parameter checks if an application with a same name exists, if it does it deletes the application and creates a new application. If the application with the same name does not exist, it creates a new application.
system:export
SYNTAX:
system:export [options] [projects] [output folder] 

Alternatively, you can use export command.

EXAMPLE:
export -ear test2.application -removeunused D:\Samples
Exports BW artifacts from the specified projects in the workspace to a folder. The artifacts can be ZIP or EAR files.

ARGUMENTS:

  • projects - The name of the project(s) to export, separated by commas, e.g. project[,project]*., Must specify at least one project. BW Applications can be exported as EAR files.
  • outputfolder - The destination folder to contain the exported module(s). Defaults to local folder.

Options:

  • -alsomoduleproperty - This parameter adds the module property in a property file.
  • -bin, -binary - Export shared model as binary shared module. Can be used with -zip option. Cannot be used with -ear option.
  • -e, -ear - Export application as a deployable ear file (default). Can be used with application projects. Cannot be used with module projects.
  • -force - Export the BW Application as an EAR file even though there are validation errors. By default, erroneous Applications can be generated as ear files.
  • --help - Display this help message.
  • -includesystem - This parameter adds all the predefined properties in a property file. For example, BW.APPNODE.NAME
  • -name [name] - Use the supplied name for the exported module
  • -noprofile - This parameter removes all the profiles from the EAR file.
  • -pf, -profile name - Export the named profile of the given module.
  • -pr - {profile name} - Export the profile in property files. Multiple profiles can be exported by comma separating format.
  • -removeunused - Exclude unused resources from the application when creating the EAR.
  • -removediagraminfo - Removes process diagram information when creating .EAR file.
  • -substvar - Export the substvar file of a given profile to given destination folder.

    For example, export -substvar {profile name} {application or module name} -path {path where substvar file should be exported}

    If no path is given then the default path is taken.

  • -t - This parameter tokenizes the property file if a project is deployed in TIBCO BusinessWorks Container Edition.
  • -z, -zip - Export model as zip file. Cannot be used with -ear option.
  • -dot - This parameter exports the profile using the dot separator.
system:encrypt
SYNTAX:
system:encrypt [options]

Alternatively, you can use encrypt command.

EXAMPLE:

To apply encryption settings:
encrypt -app tibco.bw.sample.binding.rest.Basic.application -settings -kpath "C:\src\Encrpt_Jar\test.jks" -pwd password -kalias alice pkey password
To remove encryption settings:
encrypt -app tibco.bw.sample.binding.rest.Basic.application -settings -remove
To apply encryption of Unixprofile in an application:
encrypt -app tibco.bw.sample.binding.rest.Basic.application -profiles Unixprofile
Adds encryption to applications and encrypt profiles.

ARGUMENTS

-app <app_name> - Give application project name as parameter.

OPTIONS:

  • -settings -kpath <file_path> -kpwd <password> -kalias <alias> -pkey <private key> - Add encryption settings to application project
  • -kpwd <password> - Specify password.
  • -pkey <private Key> - Specify private Key for keystore file.
  • -settings -remove - Remove encryption settings from application project (Also unencrypt all encrypted profile)
  • -profiles <profileList> - Specify the list of profiles to encrypt separated by comma.
  • -kalias <password> - Specify alias
  • -kpath <file_path> - Specify keystore file path
  • -profiles -all - Encrypt all profiles in given application project
  • -remove - Removes encryption settings.
system:decrypt
SYNTAX:
system:decrypt [options]

Alternatively, you can use decrypt command.

EXAMPLE:

To apply decryption of Unixprofile in an application:
decrypt -app tibco.bw.sample.binding.rest.Basic.application -profiles Unixprofile
Remove encryption from profiles.

ARGUMENTS:

-app <app_name> - Give application project name as parameter.

OPTIONS:

  • -profiles <profileList> - Specify the list of profiles to decrypt separated by comma.
  • -profiles -all - Decrypt all encrypted profiles in given application project.
system:import
SYNTAX:
system:import [options] files

Alternatively, you can use import command.

Imports flat or ZIP projects into the current workspace.

ARGUMENTS:

  • files - The names of the folders which contain the target flat projects to import. All the flat projects found in the specified folders are imported. The folders are separated by commas. By default, zip files are ignored. If the items to import are zip archives, use -z, -zip, -fz, -fzip options.

Options:

  • -fz, -fzip - The specified items to import are zip archives located in the folders specified by the arguments. All the zip projects in these folders are imported, while flat projects are ignored. Multiple folders are separated by commas.
  • -z, -zip - The specified items to import are zip archives specified by the arguments. Multiple zip files are separated by commas.

Output:

file status

  • file - Name of the project
  • status - Result of the import, either "imported", "ignored", or "failed {message}"
system:importpreferences
SYNTAX:
system:importpreferences [options] file

Alternatively, you can use importpreferences command.

Imports preferences set in the preferences file.

ARGUMENTS:

  • file - Absolute path of the preferences file to be imported.

Output:

file status

  • file - Name of the project
  • status - Result of the import, either "imported", "ignored", or "failed {message}"
system:validate
SYNTAX:
system:validate [options] [modules]
Validates BW modules in the current workspace. If you don't provide any module name, by default, it validates all modules.

ARGUMENTS:

  • modules -

    The name of the module(s) to validate, separated by commas, e.g. module[,module]*. Defaults to all modules in the workspace.

Options:

  • -h,--help - Display help for this command.
  • -d <Directory path>,--directory <Directory path> - Path of the directory to store validation result.

At the end of validation report, the validate command displays the number of errors and warnings for a project.

system:clean
SYNTAX:
system:clean project1, project2, project3
Cleans specific projects (all the projects if none are specified in the command) in the workspace.

Cleans project1, project2, and project3 in the workspace.

system:delete
SYNTAX:
delete -f 
system:delete project1, project2, project3

Deletes projects from the workspace.

-f - This parameter deletes all the projects in the workspace without any message prompts.

Deletes project1, project2, and project3 from the workspace.