These are some notes I have written in order to help myself to get ready to clear the TIBCO ActiveMatrix BusinessWorks 5 Certification Exam (TB0-123). More details about the exam, click here. This entry is about TIBCO BW Process Design Guide document. Any comment or suggestion, please write to luisagcenteno@gmail.com. Further details can be found at TIBCO Documentation. I hope these notes can help you as well as they did to me...
TIBCO ActiveMatrix BusinessWorks Process Design Guide (Part 3 of 3)
-The schema import tool, allows to import resources such as XSDs or WSDL files into a TIBCO ActiveMatrix BusinessWorks project. The tool can also resolve references to other resources within the imported resources. The tool can be used to import,
-XSD. XML schema definition language for declaring schema components like elements, attributes and notations.
-WSDL. Web Services Definition Language for declaring the interface definition of a web services. WSDL files typically include XSD definitions as well.
-Schema import tool helps to resolve broken references to other resources using import and include statements.
- To invoke the schema import tool, choose Tools>Schema Importer from the TIBCO Designer menu.
- The Schema Import tool stores imported resources in a Location resource in the project. This resource is a temporary holding area for XSDs and WSDL files while importing and resolving references in the resources. The Location resource corresponds to one XSD or WSDL file. The Location resource holds the specified resource and any resources referenced by the XSD or WSDL file. A new Location resource must be created for each XSD or WSDL file to be imported.
- The imported resources remain in the Location resource so that any conflicts or errors can be resolved in the imported resource. Once all conflicts and errors have been resolved, the XSDor WSDL resources can be imported into the project.
- Once resources have been imported into the project, the Location object stores a pointer to where the imported resources were originally located. Location resources can be removed after the desired resources have been imported into the project.
- To import XSD or WSDL resources.
1. Choose Tools>Schema Importer from TIBCO Designer menu or use Control+Shift+L keyboard shortcut.
2. Click the Down arrows button next to the text Add a New Location at the top left of the schema Importer dialog. Select New Import Resolver from the pop menu. Select New Import Resolver from the popup menu. A Location resource appears in the project tree in the Schema Importer dialog.
3. In the URI field, enter a valid URI that specifies the location of the resource to import. Browse button can be used to locate resources in the file system, or HTTP or FTP protocol to locate remote resources.
4. In the Download Folder field, specify the folder in the project in which to place the imported resources once any conflicts or errors have been resolved. Browse button can be used to locate a folder in the current project.
5. Click the Fetch button to retrieve the specified resource. The resource and any referenced resources are stopped temporarily in the Location resource created in step 2. Location resource can expand to view the retrieved resources. Select a resource to view the Information tab or Source tab to see more details about the resource.
6. Any errors are reported on the Errors tab. Select each error and choose the correct option to resolve the error. Ignore the error can also be chosen in order to not resolve the error.
7. Click the Save button to import the resources into the project. The schema import tool does not allow to import any resources until all errors have been either resolved or marked to ignore.
- TIBCO ActiveMatrix BusinessWorks can use Secure Sockets Layer (SSL) to provide secure communication. The successor to SSL is Transport Layer Security (TLS), but the term is used synonymously with TLS in this document.
- Secure Sockets Layer (SSL) is a protocol that uses public and private keys to secure communication between parties.
- When an SSL connection is requested, the initiator (or client) and responder (or server) perform a handshake where digital identities or certificates are exchanged to ensure that both parties are who each party expects.
- SSL can also be used to specify an encryption algorithm for the data that is exchanged between the parties.
- TIBCO ActiveMatrix BusinessWorks can act as an initiator or a responder in an SSL connection. Several types of connections can optionally use SSL, such as,
FTP Connection
HTTP Connection
JMS Connection
Rendezvous Transport
In addition, the following activities can also specify SSL connections
ActiveEnterprise Adapter activities using JMS or RV transports
Send HTTP Request
SOAP Request Reply
- TIBCO ActiveMatrix BusinessWorks uses digital certificates to validate the identity of parties in an SSL connection. TIBCO ActiveMatrix BusinessWorks requires that both initiators (clients) and responders (servers) must present certificates during SSL handshake. Typically, only the server is required to present its certificate to the client for verification, but TIBCO ActiveMatrix BusinessWorks enforces a bi-lateral model where both client and server must present certificates.
- TIBCO ActiveMatrix BusinessWorks uses the Identity resource to configure the identity of activities that act as initiators (clients) or responders (servers) in an SSL connection. The Identity resource stores the certificate of the activity (initiator or responder) and the location of the folder in the project that contains the trusted certificates of other parties that can participate in an SSL connection.
- Identity resources contain information that is used to authorize a connection. The responder (or server) in an SSL connection request must have an identity, but the initiator (client) must also have an identity. The identity resource can be used to store one of the following types of identitites,
-Username/Password. Used to store a username and password. Useful when basic client authentication is needed. Typically not used within TIBCO ActiveMatrix BusinessWorks.
-Certificate/Private Key. Used when public key and the certificate are stored in two separate files. Typically certificates are stored in Privacy-enhanced Electronic Mail (PEM) format. The URL for the certificate and key must be provided, as well as the password for the key. This identity can be used when acting as initiator or responder in an SSL connection.
-Identity File. Used when the certificate includes the public key information in the certificate file. The URL and file type of the certificate must be provided as well as the password for the key. The certificate can be on of the following formats
Entrust.
JCEKS. Java Cryptography Extension key Store file format
JKS. Java Key Store file format.
PEM. Privacy-enhanced Electronic Mail file format.
PKCS12. Public Key Cryptography Standard (12) file format.
- Trusted certificates are typically issued by a trusted third party, such as a certificate authority. There are several commercial certificate authorities, such as Entrust or VeriSign.
- Both clients and servers can also store a list of trusted certificates. When a connection is requested, each party presents their certificate and that certificate is checked against the list of trusted certificates. If the certificate is not found, the connection is refused. Checking trusted certificates allows clients to ensure that they are connecting to the correct server. For servers, trusted certificates are used to ensure only the authorized clients can connect to the server.
- Checking a certificate involves checking the certificate of the party that signed the certificate. There can be a hierarchy of intermediate certificates, also known as a certificate chain, that must be checked up to the root certificate to ensure that a certificate is authentic. TIBCO ActiveMatrix BusinessWorks requires that all intermediate certificates are stored in the trusted certificate location so that certificates can be properly verified.
- Adding Certificates to a project. To add a certificate in PEM format to a project
1. Select a folder into which the certificate will be imported
2. From the menu bar, choose Tools > Trusted Certificates > Import into PEM Format.
3. Provide the certificate URL when prompted.
Certificates in PKCS7 and PEM formats (these formats do not store keys). A new certificate copy is created when the import is done. If the certificate to be imported is already in PEM format, a new copy is created as is. Certificates from storage formats that require a password cannot be imported (PKCS12 and KeyStore)
- Storing trusted certificates outside the project. (Avoids re-create EAR file and re-deploy)
1. Create a folder in the file system, where the trusted certificate will be stored. Copy this folder to each machine where the process engine will be deployed, or the location can be shared network area accessible by all process engines.
2. In the TIBCO ActiveMatrix BusinessWorks, create a global variable named BW_GLOBAL_TRUSTED_CA_STORE
3. Set BW_GLOBAL_TRUSTED_CA_STORE to the location of the trusted certificates folder on the file system. The location can either be the same for all deployed engines, or the global variable value can be changed when the project is deployed to the location on the machine where the trusted certificates is placed. The value for BW_GLOBAL_TRUSTED_CA_STORE must be a file URL (file:///c:/tibco/certs)
4. Specify a value in the Trusted Certificates field in the SSL Configuration dialog. When the project runs, the value of BW_GLOBAL_TRUSTED_CA_STORE overrides the value specified with the location provided.
- For connections that allow to use SSL, there is a checkbox on the configuration that, when checked, allows to click the Configure SSL button which brings up an SSL configuration dialog with specific options for the type of activity or connection that is being configured. Potential configuration fields,
FTP Connection. Used to specify FTP server. TIBCO BW acts as an initiator
-Trusted Certificates folder. Folder in the project containing one or more trusted certificates. This folder is checked when an FTP activity connects to ensure that the responder’s certificate is from a trusted authority. This prevents connections to rogue servers.
- Identity.Identity resource that contains the client digital certificate and a private key.Optional
- Verify Host Name. Specifies to check that the host name of the FTP server against the host name listed in the server’s digital certificate. If it does not match, the connection is refused. If a hostname equivalent is specified in the Host field, but it does not match the host name, connection is refused.
- Strong Cipher Suites Only. When checked, this field specifies that the minimum strength of the cipher suites used can be specified with the bw.plugin.security.strongcipher.minstrength custom engine property. Default value of the property disables cipher suites with an effective key length below 128 bits. When this field is unchecked, only cipher suites with an effective key length of up to 128 bits can be used.
HTTP Connection
- Requires Client Authentication. Checking this field requires initiators to present their digital certificate before connecting to the HTTP server. When this field is checked , the Trusted Certificates folder becomes enabled so that a location containing the list of trusted certificates can be specified.
- Identity.Identity resource that contains the client digital certificate and a private key.Optional
- Verify Host Name. Specifies to check that the host name of the HTTP server against the host name listed in the server’s digital certificate. If it does not match, the connection is refused. If a hostname equivalent is specified in the Host field, but it does not match the host name, connection is refused.
- Strong Cipher Suites Only. When checked, this field specifies that the minimum strength of the cipher suites used can be specified with the bw.plugin.security.strongcipher.minstrength custom engine property. Default value of the property disables cipher suites with an effective key length below 128 bits. When this field is unchecked, only cipher suites with an effective key length of up to 128 bits can be used.
JMS Connection
Basic tab
-Trusted Certificates folder. Folder in the project containing one or more trusted certificates. This folder is checked when an JMS activity connects to ensure that the responder’s certificate is from a trusted authority. This prevents connections to rogue servers.
- Identity.Identity resource that contains the client digital certificate and a private key.Optional
Advanced tab.
- Trace. Specifies whether SSL tracing should be enabled during the connection.
- Debug Trace. Specifies whether SSL debug tracing should be enabled during the connection
- Verify Host Name. Specifies to check that the host name of the HTTP server against the host name listed in the server’s digital certificate. If it does not match, the connection is refused. If a hostname equivalent is specified in the Host field, but it does not match the host name, connection is refused. Note: The default context factories for TIBCO EMS automatically determines if host name verification is necessary. If custom implementation of the context factories is used, custom implementation must explicitly set the verify host property to the correct value.
- Expected Host Name. This name provided in this field must match the name in the responder’s certificate.
- Strong Cipher Suites Only. When checked, this field specifies that the minimum strength of the cipher suites used can be specified with the bw.plugin.security.strongcipher.minstrength custom engine property. Default value of the property disables cipher suites with an effective key length below 128 bits. When this field is unchecked, only cipher suites with an effective key length of up to 128 bits can be used.
Rendezvous Connection
- Daemon Certificate. Folder in the project containing one or more trusted certificates. This folder is checked when connecting to a daemon that is trusted. This prevents connections to rogue servers. A daemon’s certificate can be retrieved using the administration interface in TIBCO Rendezvous. Once retrieved, a folder in the project can be selected to import this certificate in the folder using the Tools > Trusted Certificates > Import into PEM Format menu item.
- Identity. An Identity resource used to authenticate to the TIBCO Rendezvous daemon. The Browse button allows to select from a list of appropriately configured Identity resources. Only Identity resources whose Type field is set to Identity file or Username/Password are listed.
- A process definition can be packaged into a custom activity that hides the implementation details of the process from the user. Custom process starters can also be created.
- Custom activities can appear in a custom palette.
- Process definitions referenced by a custom activity are referenced by name. A convention that ensures uniqueness of process definition names should be developed in order to avoid naming conflicts.
- Start activity for a process definition can optionally specify an input schema.
- Only process definition that do not have a process starters can be referenced by a custom activity.
- Global variables used within the process definitions referenced by custom activities are automatically added to the clobal variable list of the project when the activity is added to a process definition. Thus a naming convention for Global variables should be specified.
- WSDL or XSD files are not automtically included when the process definition is placed in a custom activity. WSDL and XSD files must be made available to any user of custom activity.
- Creating a custom activity.
1. Create a folder (uniquely named is strongly recommended)
2. Create a process definition
3. Optionally, create output schema to the process definition Start activity.
4. Implement business logic for process definition.
5. Optionally, specify input schema for the End activity in the process definition and mapping
6. In the project panel, click on the root node of the project, then select the General Activity palette in the palette panel.
7. Create a Custom Activity resource
8. Specify a name and an custom icon
9. Click on Browse button to select the process definition
10. Click Apply
- Any resources referenced by the process definition in a custom activity are automatically included in the custom activity. Dynamically called subprocesses are not known at design time, and therefore are not referenced by the process definition. Therefore, dynamically called subprocesses cannot be used by a process definition within a custom activity.
- Creating a Custom palette with Custom activities.
1. Create a Custom palette
a) Select Palettes > My Palettes > New Palette from TIBCO Designer menu.
b) Specify a nam in the dialog that appears
c) Custom palette appears in palette panel.
2. Drag and drop custom activity to custom palette.
3. Save the project
- Distributing custom palette
1. Locate the file(s) containing the custom palette(s) which, by default, are stored in the location specified in the User Palette Directory foeld of the General User Preferences dialog. The file extension of the custom palette is .mypalette.
2. Copy the .mypalette file to the custom palette directory on the machines to use the custome palette. An installation program may be created to perform this step so that users can easily install the custom palettes.
3. Start TIBCO Designer and click the MyPalettes tab to see the custom palette. If TIBCO Designer is already running, click on Palettes > My Palettes > Reload Palettes from the menu to retrieve the new custom palette.
- Custom activities behave like any other activity in TIBCO ActiveMatrix BusinessWorks. The name of the Custom Activity and the name of the process definition in which the Custom Activity is included should be unique. If names are the same, input and output schemas are not displayed.
- Global Variables used in Custom Activity are automatically added to the Global Variable list in the project (if they are not included yet).
- When tracing is enabled, the trace information for activities executing within a custom activity is written to a log file.
- The Java Event Source process starter allows to create a custom process starter based on Java code.
- Java Event Source provides the features (such as Sequencing key) of other process starters without the need to write extra code.
- Java Event Source provides an abstract class to extend to create a process starter. The abstract class describes the methods that interact with the process engine. Custom code must provide implementation for the methods,
- init(). Called when the process engine starts. Can initialize any resource connections. Specify a Java Global instance on the Advanced tab that initializes resource connections. Java Global instances are loaded and initialized during process engine start up. this.getJavaGlobalInstance() can be executed to obtain the Java Global Instance resource in process starter code.
- onStart(). Called by the process engine to activate the process starter. This method must activate any event notifier or resource observer code. The notifier or observer code can then call the onEvent() method to start a process instance.
- onStop(). Called by the process engine to deactivate the process starter. This method must deactivate any event notifier or resource observer code.
- onShutdown(). Called by the process engine when the engine shuts down. The method should release any resources and resource connections and perform any required clean up operations.
- Methods already implemented.
- onEvent(Object object). Called when a listener or resource observer catches a new event. Input to this is a Java object containing the event data.
- getGlobalInstance(). Returns an object reference to the Java Global resource specified on the Advanced tab of the process starter. Useful when initialization code is placed in a Java Global Resource instead of the init() method.
- onError(). Throws the exception specified in the input parameter. Used to propagate an error to the TIBCO ActiveMatrix BusinessWorks process instance when a listener or resource observer fails to generate an event.
- TIBCO ActiveMatrix BusinessWorks provides a testing environment for stepping through a process model and determining the sources of errors. Entering the testing environment starts a TIBCO ActiveMatrix BusinessWorks engine. The engine starts process instances based on the process definitions stored in the project. One running process instance can be selected in order to display in the design panel and the currently executed activity is highlighted as the process instance runs.
- Testing a process definition,
1. Select the process definition to test from the project panel.
2. Set breakpoints in the process definition where to stop running process and examine its state.
3. Provide input data to the process if it has an input schema defined.
4. Click the Tester tab on the left of the project panel.
5. Examine the data of the process by selecting any of the activities in the process. The current state of the process is displayed on the Process Data tab of each activity.
6. Use the toolbar buttons (Pause, Step to Next Activity and so on) in the test panel to either continue through the process instance or to stop the current process instance.
- Once in testing mode, changes are not reflected in the running process instance. Return to design mode before changing process definitions.
- Breakpoints allow to suspend a running process instance at a specific point so that process data can be examined. breakpoints persist after a project is closed.
- Breakpoints should be set before or after activities execute (except for before Start and after End activities).
- A breakpoint can also occur based on a given XPath condition. In order to set a condition to the breakpoint, Set Breakpoint button must be used. To set breakpoints with no condition, select from right-click menu the Set/Clear Breakpoint Before/After options.
- When a breakpoint is set on an activity, a red octagon (a stop sign) appeards next to the task’s icon to indicate the task has a breakpoint. A breakpoint before appears to the top left of the activity. A breakpoint after the activity appears to the top right of the activity.
- When a process instance is stopped at a breakpoint, the breakpoint becomes a stop sign inside a triangle (rombo) to indicate where the process instance has stopped.
- The Start Testing Vioewed Process button allows to create a process instance for the currently viewed process definition and all of its dependent subprocesses. Othe process definition can also be selected to load.
- If the loaded process begins with a Start activity that requires input, input to the process starter can be supplied by clicking on the Supply input Data to Starter button on the TIBCO Designer toolbar. This button is not required for processes that do not require input data on the Start activity.
- Once the Start testing Viewed Process button is clicked, the Select Processes to Load dialog appears. Process Definitions to load into the test engine can be selected in this dialog.
- The Advanced button on this dialog allows to specify any arguments to use when starting the test engine. This is useful when using custom engine properties. A database to use for storage of process engine information can also be specified. The Test Engine Database field specifies the JDBC Connection resource to the database to use.
- If the loaded process begins with a Start activity, one process instance is created to execute the process definition. Processing continues until the End activity is reached. If the loaded process begins with a process starter, the process engine waits for an incoming event before creating a process instance. Each incoming event causes a process instance to be created, and each process instance is listed in the test panel.
- New process of any loaded process instances can be created using the Create a Job button. The process instance can also be created by selecting in the right-click menu the option Create a Job.
- Each process instance is independent in the test panel. Each process instance can be started, stopped, stepped through individually. When a process instance is running, its description is (running) in the test panel. Once a process instance completes its processing (End activity is reached), its description is changed to (completed job) in the test panel. If a process instance fails to complete, its description is charged to (failed). Any running, completed or failed job can be viewed.
- Execution of a process instance can be stopped by selecting it and clicking the Stop the Current Job button in the test panel.
- Any completed or failed process instances can be deleted from the test panel by selecting it and clicking the Delete a Completed Job button.
-Changes performed during testing will not take effect during current testing session.
- Colors in test mode
- Black transition arrow. Transition not evaluated yet
- Green transition arrow. Transition evaluated and condition evaluated to true
- Red transition arrow. Transition evaluated and condition evaluated to false.
- Red activity. The activity encountered an error while processing.
- Bright yellow activity. Process definition is paused at this activity (Breakpoint or Step to Next Activity or Run To This Resource). Activity has not been executed yet, but it is the next activity to execute when process instance continues
- Yellow activity. Activity is currently executing, but the focus is not on the activity. This can occur if there are many paths in process definition and focus is not on the current path.
- Toolbar icons for testing (Also available by View > Test Options)
- Set Breakpoints. Brings up the Set Breakpoint dialog that allows to specify which activities should have breakpoints
- Add Input Data. Allows to specify data for the process starter’s input schema. Only enabled for process that start with a Start activity and it has an input schema.
- Test Mode. Information icon displayed when a process engine has been started for testing process definitions.
- Go To Started Process. This item is only available on the View > Test menu and displays the process definition that began this testing session.
- Moving Ball Options. Brings up a dialog that allows to set whether the moving ball is displayed. Moving ball shows the current execution path. Speed of the moving ball can also be set.
- Test panel icons.
- Start. Allows to load the viewed process and select any other processes to load. All dependent subprocesses for any loaded processes are also loaded. The process definitions are loaded into a process engine.
- Resume. Resumes any process instances that are paused or stopped at a breakpoint.
- Stop. Kills the current engine and exits testing mode. All process instances are removed from the test panel. In some situations, this button might not stop the process immediately because TIBCO ActiveMatrixmight be waiting for the current operation to be completed.
- Pause. Temporarily suspends the process instance. Resume the process instance with the Resume button.
- Step Over. When a process is paused on an activity, click this icon to step ahead in the process definition and execute the next activity.
- Step Into. Once a Call Process activity is reached, this icon allows to display the process definition of the called process and step through it. Only available when Call Process is the next activity to be processed.
- Step Out. After stepping into a subprocess, this toolbar icon can be used to return to the process that called the subprocess. Only available when in a subprocess.
- Show Current Job Location. When a process instance is paused at a breakpoint or any other point, focus can be changed to display or edit other resources in project. This icon and menu item allows to return focus to the process definition for the currently running process instance. Focus returns to the highlighted activity in a process where the process instance is paused.
- Delete. Deletes the selected jobs marked as (completed job) from the test panel. Only completed jobs can be deleted.
- Create Job. Creates a New Process Instance for the selected process definition.
- Stop Current Job. Stops currently executing process instance, but does not exit test mode. This is useful to examine the data of the process instance but not want to continue running the process
- Run To This Resource. Menu item that executes the running process instance up to the selected activity.
- TIBCO Designer allows to create alias to resources that are to be reused in other projects. Alias are used in two resources,
- AliasLibrary. Allows to specify aliases to files stored in the file system into the project. Before including a file, an Alias is created that specifies the file’s location. An alias is part of the preferences and is common to all of the projects. Aliases are created and managed under the File Alias tab in the Preferences dialog.
- LibraryBuilder. Allows to build a design-time library that includes resources defined in one project that can be shared with other projects. A LibraryBuilder resource can be maintained using a revision control system or placed in a shared directory. If the LibraryBuilder is to be shared by many project developers, the resource should be managed in a revision control system where users can sync regularly to get updates. In a smaller environment, LibraryBuilder resource can be placed in a shared folder.
- If the LibraryBuilder resource changes, the resource must be reloaded into project. The best practice is to minimize changes to the resource. It should be built and tested, then updated infrequently.
- Designer uses aliases to specify libraries locations as projects are exported or deployed to different machines and different environments. Before using a library, an alias is created that specifies its location.
- When an EAR file from a project containing a LibraryBuilder is created, all resources renferenced in LibraryBuilder resource are included in the archive, just as resources in local project are included.
- Creating an Alias. After creating an alias, it can be used in AliasLibrary or LibraryBuilder.
1. Click Edit > Preferences
2. Click File Aliases tab
3. Click New
4. Under the Alias column, double-click and provide an alias name.
5. Under the File Path column, double-click and navigate to the design-time library location. Select the file name and click Open.
6. Click OK.
- Exporting an Alias.
1. Click Edit > Preferences
2. Click the File Aliases tab
3. Click Export to save the alias list so others can use it.
4. Navigate to a location that others can access.
5. Provide a name for the alias.
6. Click Save.
- Importing an Alias.
1. Click Edit > Preferences
2. Click the File Aliases tab
3. Click Import to add a previously exported alias list to your preferences.
4. Navigate to the location of the alias file and select it.
5. Click Open.
6. Click OK.
- Resources in the project can reference aliases in the AliasLibrary to resolve external file dependencies that they may have at runtime or debug time.
- When an EAR file is built, the files referenced by the aliases defined in an AliasLibrary included in the project, are included in the EAR file.
- Creating an AliasLibrary
1. Select the top level folder and locate the AliasLibrary resource (General palette)
2. Drag the AliasLibrary resource into the design panel
3. Under Configuration tab, provide a name and description for the AliasLibrary
4. Click the Aliases tab and add files or directories to the list of aliases. The dialog allows to choose a Folder or All Files. If a folder is selected, all files in the folder become part of the alias as well as any other sub folders. A warning appears if the selected folder or files exceed a certain size. The warning can be customized. Deleting aliases from Alias tab, does not remove the alias from Edit > Preferences alias tab.
5. Whether aliases within AliasLibrary should be included in the CLASSPATH can be specified. This may be required for a TIBCO ActiveMatrix BusinessWorks Java Activity that loads a jar file in order to find its executable or its supporting code.
6. Click Apply.
- Creating a LibraryBuilder resource.
1. Select the top-level folder and locate the LibraryBuilder resource (General palette)
2. Drag the LibraryBuild resource into the design panel.
3. Under the Configuration tab, provide a name for the LibraryBuilder resource.
4. In the File Location field, provide the absolute path and name for the library file. The directory should be accessible by other developers.
5. Click the Resources tab and click the browse icon to select resources to add to the LibraryBuilder. The list can be limited to resources matching a filter term entered in the Filter Name field.
6. Click Apply
7. Click Build Library.
- A LibraryBuilder resource is the basis for a design-time library. Before creating a design-time library, access to a LibraryBuilder resource alias is required.
- Aliases are used to manage access to LibraryBuilder resources.
- When a LibraryBuilder resource is imported to a project, an alias to it can be created when loading the library , or pick an alias and load the corresponding library.
- If working from a different machine, or are not the user who created the alias, an alias can be imported to the alias list.
- Click New when adding a LibraryBuilder resource allows to define an alias and load the LibraryBuilder resource in one operation. The alias is then added to the list.
- To update a LibraryBuilder resources, delete the alias to it, then add it back.
- To delete a LibraryBuilder resource from a project, delete the alias to it.
- Creating a design-time library
1. Open the project to which the LibraryBuilder will be added.
2. Click Project > Save
3. Select the project’s root folder
4. Click the Design Time Libraries tab
5. Click Pick if there is an alias defined for the library. Click New and navigate to the location of the design-time library. After clicking Apply, a new alias for the library is added to alias list.
6. Click OK
7. Click Apply
- Updating a Design-time Library
1. Open the project in which the design-time library will be updated
2. Select the project’s root folder
3. Select the Design Time Libraries tab
4. Select the File Alias for the design-time library to update.
5. Click Delete
6. Click Apply
7. Click Pick.
8. Select the file alias for the design time library to update
9. Click OK
10. Click Apply.
- Deleting a Design-time library
1. Open the project in which the design-time library will be deleted.
2. Select the project’s root folder.
3. Click the Design Time Libraries tab
4. Select the File Aliases for the design-time library to remove.
5. Click Delete
6. Click Apply.
- When a LibraryBuilder resource is added to a project, the resources defined in it, can be used. The resources deisplay in the project view like other resources but, they cannot be modified, they are greyed out and not editable.
- Design-time libraries added to a project can be hidden. When design-time libraries are hidden, resources in the libraries are not available to a project. If a resource in design-time library is used and have hidden the library, when an EAR file is built, the resource will not be part of the archive.
- Hide/Show Design-time Libraries
- Click Project > Hide Library Resources
- Click Project > Show Library Resources
- If there is a name conflict, the resource in the local project is always used. If there is a name conflict among the design-time libraries loaded, there are these choices,
- Use arrows on the left to reorder the libraries. Libraries are ordered according to when they were imported. The earliest imported library is at top of the list. The library at the top of the list has precedence over those in the list.
- If reordering does not resolve the conflict, design-time library can be re-built or create another one.
- A resource cannot be renamed in a desgin-time library to break a conflict.
- Each resource with a conflict is marked so can easily be seen
- For multiple developers to work in the same project, it can be used file sharing/locking or a revision control system (multi-file project). Changes from User A don’t show up or User B until User B syncs.
- TIBCO Designer creates a file that can be shared and locked for each top-level resource, such as an adapter configuration or process definition. It does not create a file for each resource. TIBCO Designer also creates folder for folders created in the project. Each folder can be locked as needed.
- Revision control options are available
- File Sharing. In Windows, project located in a folder accessible by all TIBCO developers (r+w access). In UNIX, the project must be located on a mounted drive accessible by all TIBCO developers.
1. Create a Unix group for the TIBCO developers
2. Create a Unix account for each developer. Each account must have its Primary Group ID set to the group “tibdev”.
3. For each account, the umask must be set to 002 to ensure the entire group has write permission on resources (folder and file) in Designer projects. Set the umask in the .login or .profile file.
- Microsoft Visual SourceSafe. Not supported under UNIX.
1. Instal Microsoft VSS 6.0 Client on each machine from which to use TIBCO Designer in conjunction with a VSS database.
2. To make the VSS database available, set the ssdir environment variable to the location of the VSS database (containingthe Srcsafe.ini).
- Perforce. Perforce has comprehensive software configuration management capabilities built around a scalable client/server architecture. Perforce Server must be installed and running. Perforce client must be installed on machine where TIBCO Designer runs.
- XML Canon. XML Canon/Developer (XCD) is a comprenhensive development platform that allows organizations to store their XML assets in a central repository that facilitates adaptability, collaboration and management. XML Canon is a persistence system that has some RCS capability but not a multi-file project per se.
- Clearcase. Tracks the file versions used to build a product release and helps to organize the work of groups of engineers.
- CVS. Version Control System that records the history of source files used to build a software product. CVS also allows engineers to work in their own directory, and merges each engineer’s work into a source tree.
- PVCS. PVCS allows developers to manage software development by controling access and revisions to source code. It automates and simplifies access to development objects including source code, ASCII files, graphics, documentation and binary data files, allowing developers to share archive information and manage projects, even in cross-platform development environments.
- TIBCO Designer allows interaction with revision control system to check who owns the lock for each locked resource.
- Icons Used by RCS Projects.
- A lock icon indicates that the resource was checked into the revision control system. Other users might be making changes. Checking out the resource is required to safely make changes.
- A yellow square icon indicates that the RCS does not know about this resource or its state. If the resource is new, it has to be added to the RCS. If it has been checked in before, it has to be checked in again.
- A red square indicates, on systems that support that functionality, that another user has locked the resource.
- If no special icon is displayed, the resource has been checked out and is in the same state as the corresponding RCS resource.
- Deleting RCS projects
1. In the startup panel, click the Delete project button
2. In the Delete Project dialog that appears, supply the information about the project.
- For projects that use File Sharing, use either the None or File Sharing Revision Control System and any user name, supply the project location.
- For Visual SourceSafe and Perforce make sure that the project listed in the Project Directory field corresponds to the project checked into RCS.
3. Click OK.
- To acquire a resource Multi-User > Acquire-Checkout Resource
- To release a resource Multi-User > Release-Revert Resource
- Global Variables are acquired through the Acquire-Check out Global Variable group option of the right-button menu.
This blog has been created to share TIBCO and Java resources that help the community to accomplish goals quickly and easily.
miércoles, 5 de octubre de 2011
TIBCO BW Process Design Guide (2 - 3)
These are some notes I have written in order to help myself to get ready to clear the TIBCO ActiveMatrix BusinessWorks 5 Certification Exam (TB0-123). More details about the exam, click here. This entry is about TIBCO BW Process Design Guide document. Any comment or suggestion, please write to luisagcenteno@gmail.com. Further details can be found at TIBCO Documentation. I hope these notes can help you as well as they did to me...
TIBCO ActiveMatrix BusinessWorks Process Design Guide (Part 2 of 3)
- XPath is an expression language developed by World Wide Web Consortium (W3C) for addressing parts of XML documents. XPath also has basic manipulation for strings, numbers and booleans.
- TIBCO ActiveMatrix BusinessWorks uses XPath language to specify and process elements of data schema.
- All process data and activity input are represented as an XML schema. Regardless of where the data comes from or its format, TIBCO ActiveMatrix BusinessWorks represents the data as a schema tree.
- Complex elements are structures that contain other schema elements, either simple elements or other complex elements. Both simple and complex elements can also repeat.
- In order to refer to a particular item in a schema, start with the root node and then use slashes to indicate a path to the desired data element. Relative paths can be used as well
- Namespaces are automatically added to elements that require this when creating mappings on the input tab of an activity or when dragging and dropping data in the XPath formula builder.
- An XPath expression can have a search predicate. The search predicate is used to locate a specific element of a repeating schema item.
$GetOrderInformation/OrderDetails/OrderItem[1]
$GetOrderInformation/OrderDetails/OrderItem[ProductId=”3A54”]
$GetOrderInformation/OrderDetails/OrderItem[position()>1]
- In order to test an element to determine if it is set to nil or not.
$Order/Item/OnSale/@xsi:nil=”true”
- Comments to XPath expressions
$GetOrderInformation/ShipName/Street {--returnsthe street--}
- XPath Formula Builder can be used where XPath expressions are allowed.
Elements in XPath Formula Builder
-Data tab. Contains the Process Data schema tree.
-Functions tab. Displays all available XPath functions.
-Constants tab. Displays all constants available for use in XPath expressions
-Documentation panel. Describes each selected function
-Evaluation Context field. Displays the evaluation context of the expression field that the editor was invoked from.
-XPath Formula field. Displays the XPath formula to create
-Expression evaluates to Panel. Displays the result of evaluating the formula shown in the XPath Formula field.If there are error in the formula, they are displayed there.
- <<>> are called placeholder
- When data must be represented in the input or output of an activity, the data is represented as string.
Numeric datatypes. xs:integer,xs:decimal,xs:float,xs:double
Decimal, float and double numbers are compressed to an integer when represented if there are only zeros following the decimal point (“1.000” is represented as “1”).
Scientific notation is never used to represent a floating point number as string (xs:double(‘1.2345E05’) is represented as 123400).
Data is truncated if the number of digits exceeds the maximum precision for the datatype (xs:float(‘1.23456789’) is represented as 1.2345679.
Both Zero and Negative Zero are represented as 0.
Positive and negative intinity are represented as Infinity and -Infinity.
Not a Number is represented as NaN
Boolean
xs:boolean(‘true’) and xs:boolean(‘1’) are represented by true as well as XPath function true().
xs:boolean(‘false’) and xs:boolean(‘0’) are represented by false as well as XPath function false()
Date Datatypes. Activities in TIBCO ActiveMatrx BusinessWorks implement dates in one of two ways.
Stored as the number of milliseconds since January 1, 1970 (Activities that are associated with Java)
Implemented according to XPath 2.0 or XQuery 1.0 standards as a set of normalized components (xs:date, xs:time, xs:dateTime, and so on) with an optional timezone offset. (Activities associated with XML). Supports arbitrary precision of the seconds component.
Conversion between date representations may result in a loss of information either because of the difference in time zone representation or the precision of the seconds
- XPath formulas to parse and format strings that represent dates and times.
format-dateTime(<>,<>)
format-date(<>,<>)
format-time(<>,<
TIBCO ActiveMatrix BusinessWorks Process Design Guide (Part 2 of 3)
- XPath is an expression language developed by World Wide Web Consortium (W3C) for addressing parts of XML documents. XPath also has basic manipulation for strings, numbers and booleans.
- TIBCO ActiveMatrix BusinessWorks uses XPath language to specify and process elements of data schema.
- All process data and activity input are represented as an XML schema. Regardless of where the data comes from or its format, TIBCO ActiveMatrix BusinessWorks represents the data as a schema tree.
- Complex elements are structures that contain other schema elements, either simple elements or other complex elements. Both simple and complex elements can also repeat.
- In order to refer to a particular item in a schema, start with the root node and then use slashes to indicate a path to the desired data element. Relative paths can be used as well
- Namespaces are automatically added to elements that require this when creating mappings on the input tab of an activity or when dragging and dropping data in the XPath formula builder.
- An XPath expression can have a search predicate. The search predicate is used to locate a specific element of a repeating schema item.
$GetOrderInformation/OrderDetails/OrderItem[1]
$GetOrderInformation/OrderDetails/OrderItem[ProductId=”3A54”]
$GetOrderInformation/OrderDetails/OrderItem[position()>1]
- In order to test an element to determine if it is set to nil or not.
$Order/Item/OnSale/@xsi:nil=”true”
- Comments to XPath expressions
$GetOrderInformation/ShipName/Street {--returnsthe street--}
- XPath Formula Builder can be used where XPath expressions are allowed.
Elements in XPath Formula Builder
-Data tab. Contains the Process Data schema tree.
-Functions tab. Displays all available XPath functions.
-Constants tab. Displays all constants available for use in XPath expressions
-Documentation panel. Describes each selected function
-Evaluation Context field. Displays the evaluation context of the expression field that the editor was invoked from.
-XPath Formula field. Displays the XPath formula to create
-Expression evaluates to Panel. Displays the result of evaluating the formula shown in the XPath Formula field.If there are error in the formula, they are displayed there.
- <<>> are called placeholder
- When data must be represented in the input or output of an activity, the data is represented as string.
Numeric datatypes. xs:integer,xs:decimal,xs:float,xs:double
Decimal, float and double numbers are compressed to an integer when represented if there are only zeros following the decimal point (“1.000” is represented as “1”).
Scientific notation is never used to represent a floating point number as string (xs:double(‘1.2345E05’) is represented as 123400).
Data is truncated if the number of digits exceeds the maximum precision for the datatype (xs:float(‘1.23456789’) is represented as 1.2345679.
Both Zero and Negative Zero are represented as 0.
Positive and negative intinity are represented as Infinity and -Infinity.
Not a Number is represented as NaN
Boolean
xs:boolean(‘true’) and xs:boolean(‘1’) are represented by true as well as XPath function true().
xs:boolean(‘false’) and xs:boolean(‘0’) are represented by false as well as XPath function false()
Date Datatypes. Activities in TIBCO ActiveMatrx BusinessWorks implement dates in one of two ways.
Stored as the number of milliseconds since January 1, 1970 (Activities that are associated with Java)
Implemented according to XPath 2.0 or XQuery 1.0 standards as a set of normalized components (xs:date, xs:time, xs:dateTime, and so on) with an optional timezone offset. (Activities associated with XML). Supports arbitrary precision of the seconds component.
Conversion between date representations may result in a loss of information either because of the difference in time zone representation or the precision of the seconds
- XPath formulas to parse and format strings that represent dates and times.
format-dateTime(<
format-date(<
format-time(<
Suscribirse a:
Entradas (Atom)