Use the call "tw.system.model.processAppSnapshot.id" to fetch the ID of the currently execution snapshot.
Monday, January 27, 2014
Wednesday, January 15, 2014
BPM 7.5 PO Type Codes
CODE | TABLE NAME | Common Name 1 | Common Name 2 |
1 | "LSW_PROCESS" | "process" | "Service" |
2 | "LSW_IC" | "integrationComponent" | "IC" |
3 | "LSW_CONNECTOR" | "connector" | "Connector" |
4 | "LSW_UCA" | "underCoverAgent" | "UCA" |
7 | "LSW_WEB_SERVICE" | "webService" | "WebService" |
8 | null | "webScript" | "WebScript" |
11 | "LSW_REPORT" | "report" | "Report" |
12 | "LSW_CLASS" | "twClass" | "VariableType" |
13 | "LSW_SCBD" | "scoreboard" | "Scoreboard" |
14 | "LSW_TRACKING_GROUP" | "trackingGroup" | "TrackingGroup" |
15 | "LSW_TIMING_INTERVAL" | "timingInterval" | "TimingInterval" |
16 | "LSW_TRACKING_POINT" | ||
17 | "LSW_TRACKED_VARIABLE" | ||
20 | "LSW_LAYOUT" | "layout" | "Layout" |
21 | "LSW_EPV" | "epv" | "EPV" |
22 | null | "globalVariable" | "GlobalVariable" |
24 | "LSW_PARTICIPANT" | "participant" | "Participant" |
25 | "LSW_BPD" | "bpd" | "BPD" |
30 | "LSW_PRIORITY" | "priority" | "Priority" |
31 | null | "calendar" | "Calendar" |
40 | null | "customStatus" | "CustomStatus" |
42 | null | "alertSeverity" | "AlertSeverity" |
43 | "LSW_INFOPATH_FORM" | "infoPathForm" | "InfoPathForm" |
47 | "LSW_SLA" | "sla" | "SLA" |
49 | "LSW_METRIC" | "metric" | "Metric" |
50 | "LSW_RESOURCE_BUNDLE_GROUP" | "resourceBundleGroup" | "ResourceBundleGroup" |
51 | "LSW_USER_ATTRIBUTE_DEF" | "userAttributeDefinition" | "UserAttributeDefinition" |
52 | "LSW_SIM_SCENARIO" | "simulationScenario" | "SimulationScenario" |
53 | "LSW_HIST_SCENARIO" | "historicalScenario" | "HistoricalScenario" |
54 | "LSW_ORG_CHART" | "orgChart" | "OrgChart" |
60 | "LSW_EXTERNAL_ACTIVITY" | "externalActivity" | "ExternalActivity" |
61 | "LSW_MANAGED_ASSET" | "managedAsset" | "ManagedAsset" |
62 | "LSW_ENV_VAR_SET" | "environmentVariableSet" | "EnvironmentVariableSet" |
63 | "LSW_PROJECT_DEFAULTS" | "projectDefaults" | "ProjectDefaults" |
2001 | null | "alertType" | "AlertType" |
2005 | "LSW_BREAKPOINT" | ||
2006 | "LSW_BPD_EVENT" | ||
2007 | "LSW_BPD_PARAMETER" | ||
2013 | "LSW_EPV_VAR" | ||
2014 | "LSW_EPV_VAR_VALUE" | ||
2015 | "LSW_FAVORITE" | ||
2018 | "LSW_IC_INPUT_PROPERTY" | ||
2019 | "LSW_IC_OUTPUT_PROPERTY" | ||
2020 | "LSW_TIMING_INTERVAL_BOUND" | ||
2022 | "LSW_LAUNCHER" | ||
2023 | "LSW_LAYOUT_PARAM" | ||
2025 | "LSW_PROCESS_ITEM" | ||
2027 | "LSW_PROCESS_LINK" | ||
2028 | "LSW_PROCESS_LABEL" | ||
2029 | "LSW_PROCESS_ITEM_PRE_POST" | ||
2030 | "LSW_REPORT_PAGE" | ||
2031 | "LSW_REPORT_CHART" | ||
2032 | "LSW_REPORT_DATASOURCE" | ||
2033 | "LSW_REPORT_DATASOURCE_IC_LINK" | ||
2034 | "LSW_REPORT_DS_LAYOUT_LINK" | ||
2035 | "LSW_REPORT_VARIABLES" | ||
2036 | "LSW_REPORT_EPV_LINK" | ||
2037 | "LSW_REPORT_TG_LINK" | ||
2038 | "LSW_RESOURCE_BUNDLE" | ||
2039 | "LSW_RESOURCE_BUNDLE_KEY" | ||
2040 | "LSW_SAVED_SEARCHES" | ||
2041 | "LSW_SCBD_RPT_LINK" | ||
2044 | "LSW_UCA_SYNC_QUEUE" | ||
2045 | "LSW_UCA_BLACKOUT" | ||
2046 | "LSW_UCA_PARM" | ||
2047 | "LSW_USR" | ||
2048 | "LSW_USR_XREF" | ||
2049 | "LSW_USR_ATTR" | ||
2050 | "LSW_USER_ATTR_DEF_VALUES" | ||
2052 | "LSW_WEB_SERVICE_OP" | ||
2054 | "LSW_PARAMETER_MAPPING" | ||
2055 | "LSW_PROCESS_PARAMETER" | ||
2056 | "LSW_PROCESS_VARIABLE" | ||
2058 | "LSW_EPV_PROCESS_LINK" | ||
2059 | "LSW_RESOURCE_PROCESS_LINK" | ||
2060 | "LSW_EXTACT_PARAMETER" | ||
2061 | "LSW_EXTACT_PROPERTY" | ||
2063 | "LSW_BRANCH" | ||
2064 | "LSW_SNAPSHOT" | ||
2065 | "LSW_DEPLOYMENT" | ||
2066 | "LSW_PROJECT" | "Process App" | "Process App" |
2068 | "LSW_SERVER" | ||
2069 | "LSW_PROJECT_DEPENDENCY" | "toolkit" | "toolkit" |
2072 | "LSW_BPD_INSTANCE" | ||
2073 | "LSW_BPD_INSTANCE_DATA" | ||
2075 | "LSW_USR_GRP_XREF" | ||
2076 | "LSW_RELEASE" | ||
2077 | "LSW_ENV_VAR_VAL" | ||
2078 | "LSW_TASK" | ||
2079 | "LSW_USER_FAVORITE" | ||
2080 | "LSW_FILE" | ||
2081 | "LSW_TASK_NARR" | ||
2082 | "LSW_TASK_ADDR" | ||
2084 | "LSW_TASK_EXECUTION_CONTEXT" | ||
2085 | "LSW_TASK_IPF_DATA" | ||
2086 | "LSW_TASK_EXTACT_DATA" | ||
2087 | "LSW_USR_ASSUME" | ||
2089 | "LSW_BPD_NOTIFICATION" | ||
2090 | "LSW_DEP_PATH" | ||
2091 | "LSW_PO_REFERENCE" | ||
2092 | "LSW_ENV_VAR_DEFAULT" | "environmentDefault" | "EnvironmentDefault" |
2093 | "LSW_ENV_TYPE" | ||
2094 | "LSW_ENV_VAR" | "environmentVariable" | "EnvironmentVariable" |
2095 | "LSW_RT_REFERENCE" | ||
2096 | "LSW_REPOSITORY_HISTORY" | ||
2097 | "LSW_TIME_PERIOD" | ||
2098 | "LSW_TIME_SCHEDULE" | ||
2099 | "LSW_HOLIDAY_SCHEDULE" | ||
2100 | "LSW_ACL_ENTRY" | ||
2101 | "LSW_SMART_FOLDER" | "SmartFolder" | null |
2102 | "LSW_REPORT_DATASOURCE_SRV_LINK" | ||
2103 | "LSW_INSTALLATION" | ||
2104 | "LSW_BLUEPRINT_SUBSCRIPTION" | ||
2105 | "LSW_REPORT_RBG_LINK" | ||
2106 | "LSW_ENV_VAR_TYPE" | ||
2107 | "LSW_SERVER_CAPABILITY" | ||
2108 | "LSW_CAPABILITY_TYPE" | ||
6001 | "BPM_CONTRIBUTION" | "contribution" | "Contribution" |
6002 | "BPM_CTRB_PROPERTY" | ||
6004 | "BPM_CTRB_DEPENDENCY" | ||
6003 | "BPM_ARTIFACT" | "artifact" | "Artifact" |
6005 | "BPM_PROC_ARTIFACT_REF" | ||
6006 | "BPM_CLS_ARTIFACT_REF" | ||
6007 | "BPM_BPD_ARTIFACT_REF" | ||
6008 | "BPM_MON_MODEL_DATA" |
Fetch Duplicate Artifacts in BPM 7.5
Get a list a artifacts duplicated across Process-App or Toolkits (Oracle 11g and up only)
WITH po AS (
SELECT distinct
ver.PO_NAME,
ver.PO_TYPE,
/* snap.is_default,
snap.name AS "Snapshot Name",
snap.acronym AS "Snapshot Acronym",
snap.is_archived AS "Is Snapshot Archived",
proj.name AS "Process App",
*/ --LISTAGG(TO_CHAR(proj.short_name), '; ') within group( order by proj.short_name) AS "PROCESS APP ACRONYM",
TO_CHAR(proj.short_name) AS short_name
FROM bpi_procc_shr_shr.lsw_branch brnch,
bpi_procc_shr_shr.lsw_po_versions ver,
bpi_procc_shr_shr.lsw_snapshot snap,
bpi_procc_shr_shr.lsw_project proj
WHERE ver.branch_id = brnch.branch_id
AND brnch.tip_snapshot_id = snap.snapshot_id
AND snap.project_id = proj.project_id
AND proj.short_name NOT IN ('TWSYS', 'TWP', 'HSS', 'LSWPSC', 'SACOMMC', 'BDS2', 'SAPAPPS', 'OF_DEM')
AND ver.PO_NAME IS NOT NULL
AND snap.name IS NOT NULL
AND
-- ver.po_name like 'Submit Requisition' and
snap.is_archived = 'F'-- and
-- ver.end_seq_num is null
ORDER BY ver.PO_NAME
--group by ver.PO_NAME
)
select
po.PO_NAME,
po.PO_TYPE,
LISTAGG(po.short_name, '; ') within group(order by po.short_name) AS "APP_LIST",
count(1) "DUPLICATE COUNT"
-- po.short_name
from po
group by po.PO_NAME, po.PO_TYPE
having count(1) > 1
;
Monday, January 13, 2014
Calling services in iFrame
In version 6.2 to invoke any service in an URL we used the “teamworks/process.lsw? zWorkflowState=5&zProcessName=” pattern. But in version 7.5 we need to use “/teamworks/executeServiceByName?processApp=<APP-ACRONYM>&serviceName=” pattern. As you could notice it takes an extra parameter for “processApp”, which is used to identify the process-app or toolkit in which the service resides.
Friday, January 10, 2014
Types of GROUPs in IBM BPM 7.5
In IBM BPM 7.5 the user -groups can be categorized into 3 types:
- Groups that exist and managed in external directory services like LDAP.
- Groups that are created in the environment through Admin Console.
- Groups that are dynamically created by virtue of task allocation.
Groups that exist and managed in external directory services like LDAP
Such groups are created and managed in external directory services like LDAP. Such groups are imported into the BPM database when an user logs in for the first time. Such groups have a GROUP_TYPE as "0" in the table LSW_USR_GRP_XREF. Such groups cannot be edited or deleted through the default Process Admin Console.
TODO : Verify that the group memberships are synced automatically.
Groups that are created in the environment through Admin Console.
These groups are created and managed through the Process Admin Console. Since these groups are not represented in the centralized directory services like LDAP, these are purposed to be used inside BPM applications only. These are analogous to Teamworks logical roles in Teamworks 6.2. These groups have a GROUP_TYPE as "3" in the table LSW_USR_GRP_XREF.
Groups that are dynamically created by virtue of task allocation.
Groups are dynamically created when a new task is routed to a lane participant (Participant Group) or assigned to a list of users (Ad-hoc group). Dynamic groups corresponding to Teamworks logical roles are also created during import from a 6.2 environment. These groups are not visible on the Process Admin console, hence cannot be managed. Dynamic groups that are created from Participant Groups or Logical Roles have GROUP_TYPE as "1" in the table LSW_USR_GRP_XREF, where as the dynamic groups crated from list of users have GROUP_TYPE as "2" in the table LSW_USR_GRP_XREF.
Dynamic groups are not reused hence are good candidates for purging once the task has been completed.
Wednesday, October 30, 2013
Teamworks Localhost Access Log - 6.2 and JBoss
How To Configure Localhost Access log in Teamworks 6.2 on JBoss
Teamworks localhost access log provides a means to track the requests and responses passing through the JBoss server. This includes access to all the static files (images, JS and CSS) as well as the dynamic resources (JSP, Servlets).
This configuration can be found in the file process-server/deploy/jbossweb-tomcat55.sar/server.xml. In this file locate the entry <Valve className="org.apache.catalina.valves.FastCommonAccessLogValve", un-comment this tag to enable the logging. For various aspects of logging available, please refer the link given below.
Note: Tomcat does not support automatic house keeping of the logs, i.e. if you need to keep only "n" days worth of log, you would need to schedule jobs to delete the logs jobs. Tomcat does not handle this.
Tuesday, October 29, 2013
Oracle Automatic Segment Advisor - Read Advisor findings
Oracle Automatic Segment Advisor runs during maintenance window and collects information regarding various facets of your database, namely SQL optimization, table segment fragmentation, I/O wait reduction methods, ...
You can use a combination of DBA_ADVISOR_FINDINGS, DBA_ADVISOR_OBJECTS AND DBA_ADVISOR_LOG to read those findings.
The underlying query gives you the findings related to tables.
You can use a combination of DBA_ADVISOR_FINDINGS, DBA_ADVISOR_OBJECTS AND DBA_ADVISOR_LOG to read those findings.
The underlying query gives you the findings related to tables.
SELECT TO_CHAR(log.execution_start, 'YYYY-MM-DD') AS "ADVISOR DATE",
af.task_name,
ao.owner,
ao.attr2 segname,
ao.attr3 partition,
ao.type,
af.message
FROM dba_advisor_findings af,
dba_advisor_objects ao,
dba_advisor_log log
WHERE ao.task_id = af.task_id
AND ao.task_id = log.task_id
AND ao.object_id = af.object_id
AND ao.type = 'TABLE'
AND log.execution_start > SYSDATE-1
ORDER BY log.execution_start DESC, ao.attr2;
af.task_name,
ao.owner,
ao.attr2 segname,
ao.attr3 partition,
ao.type,
af.message
FROM dba_advisor_findings af,
dba_advisor_objects ao,
dba_advisor_log log
WHERE ao.task_id = af.task_id
AND ao.task_id = log.task_id
AND ao.object_id = af.object_id
AND ao.type = 'TABLE'
AND log.execution_start > SYSDATE-1
ORDER BY log.execution_start DESC, ao.attr2;
Subscribe to:
Posts (Atom)