Friday, 19 July 2013

D2 Solution in ECM space

There is quite a buzz now a day about D2 which was developed by a company called C6 and later on acquired by EMC2.

I am working on D2 for couple of years now and for the same reason I am very excited to share few things about D2 with you all.

D2 is a fully configurable web application designed to create tailor made solution effectively within short period of time by simplifying the application implementation via configuration rather than code. D2 interface is built on ActiveX platform.

D2 mainly comprises of two applications i.e. D2-Client and D2-Config.

D2-Client

  D2-Client is user friendly graphical interface to work on documents. It provides a rich and highly personalized user experience.

    The general view of the D2-Client application is similar to the Windows Explorer concept. A cabinet and a folder tree on the left allow users to browse the structure and a content pane on the right that shows the content of the selected cabinets or folders. 

One of the interesting feature it provides that by selecting a document, we can easily locate the document, view all the versions, check all the renditions available, view the audit trail entries , check any workflow is running on that document and many more by just clicking on the tabs available in the lower pane of the user work space. 





D2-Config:


 D2 provides most of the buisness rules  as configurable features.


 Using D2-Config one can easily and  quickly configure or map business rules  as it uses familiar spread sheet type  configuration.


 D2-Config consists of group of in built  configurable modules which enables user to configure features like security, properties page, life cycles, inheritance, autolinking,   autonaming and workflows etc.



Few points to highlight about D2 solution are



1. Object Model of D2 is different from the traditional Documentum object model.

2. Security is implemented in different way. Security objects are stored as d2_acl object type.

3. Integration of existing documentum lifecycle is not possible in D2. D2 manage lifecycle in different way. Beautiful part of D2 lifecycle is its easy to deploy and for that we just need to save the configuration. We can easily enforce many condition on different states like condition on document property, permissions etc and also perform many actions like update of one  property, create new version, apply autolink and request for rendition etc without using custom code. 

4. There is another configurable feature named batch lifecycle which we can use to update state of several documents in one go.

5. Workflows created through workflow manager can be integrated in D2. D2 also provides some advance features like electronic signature which we can configure with the workflow settings. We can also configure custom mail as well as reminder mail with it.

6. Autonaming and Autolinking of documents are one of the in built out of the box features. We just need to configure it as per our buisness requirements.

7. Value assistance and data mapping is very easy with the in built configurable feature Dictionary and Taxonomy.

8. Check in and Check out functionality is highly configurable. By default document versions are managed as starting from 0.1 but there is option of changing it to 1.0.

9. D2 supports full text to advanced search and also it provides one unique feature Query form where we can easily create our own queries combining operators and Document properties which in turn make the searching simpler. 

10. There is another unique feature i.e. Email where you can configure different email notification based on specific workflow events such as dm_completedworkitem ,dm_startworkflow etc. 

11. Restrict access to both the application i.e. D2-Client and D2-Config is easily configurable using group names [Only group members mentioned in the D2 config can access applications]. 




We have seen many times that at the time of final deployment, requirements are changed with the changing business scenarios. This is where D2 comes into the picture by providing functionalities via configurations rather than customizations, thus reducing custom code, providing rapid deployment which in turn helps to adapt changing business scenarios with ease.


I will try to elaborate on different features of D2 in my subsequent blogs. Thanks for reading :-)

Thursday, 6 June 2013

DQL (Document Query Language) for Documentum




DQL is Document Query Language for Documentum, which is a content management system used to create, manage, deliver, and archive all types of content. 


Some useful DQLs are :



·         Query to list objects having duplicate names
select object_name, count(*) FROM dm_document group by object_name having count(*) > 1 order by object_name

·         Query to find checked out documents
select * from dm_document where (r_lock_owner is not nullstring or r_lock_owner <> ' ')

·         Query to find documents without pdf rendition
select * from dm_document doc where not exists(select * from dmr_content where any parent_id=doc.r_object_id and full_format='pdf')

·         Query to find documents having file size more than 10 MB
select * from dm_document where r_full_content_size > 10000000;

·         Query to fetch specific number of documents
select * from dm_document enable (RETURN_TOP 50)

·         Query to fetch document owner name and number of document owns
select owner_name,count(*) from dm_document group by owner_name


·         Query to find all documents under a cabinet
select r_object_id, object_name from dm_document(all) where folder(’/[cabinet name]’, descend)

·         Query to find all documents which are modified from a particular date
select * from dm_document where r_modify_date > DATE('06/05/2013 00:00:00','MM/DD/YYYY hh:mm:ss') and r_modify_date < DATE('TODAY)


·         Query to find documents which are in workflows (active)
select r_object_id, object_name, title, owner_name,r_object_type, r_creation_date, r_modify_date, a_content_type from dm_document where r_object_id in(select r_component_id from dmi_package where r_workflow_id in (select r_object_id from dm_workflow where r_runtime_state = 1))

·         Query to find running workflow list
select distinct wi.r_object_id, wf.r_object_id as workflow_id, wf.object_name as workflow_name, wf.supervisor_name as supervisor_name,wi.r_performer_name as performer_name, wf.r_start_date as start_date from dm_workflow wf, dmi_package pkg, dmi_workitem wi where wf.r_runtime_state <2 and wf.r_object_id=pkg.r_workflow_id and wf.r_object_id=wi.r_workflow_id and pkg.r_workflow_id=wi.r_workflow_id and wi.r_runtime_state < 2 and any pkg.r_component_id in (select r_object_id from dm_document(all) where i_latest_flag=TRUE)

·         Query to find workflow id of a particular document
select r_workflow_id from dmi_package where any r_component_id ='[r_object_id]'



·         Query to find inbox details of an user
EXECUTE get_inbox WITH name='[user_name]'


·         Query to check registered types and the full-text user name
select distinct t.name, t.r_object_id, i.user_name from dm_type t,dmi_registry i where t.r_object_id = i.registered_id and i.user_name like '%fulltext%'

·         Query to verify that Content Server has loaded the correct full-text plugin

select r_object_id,object_name from dm_ftengine_config





·         Query to get all the users created from yesterday

Select user_name,user_os_name,user_address,user_group_name,r_modify_date from dm_user where r_modify_date >DATE('YESTERDAY')



·         Query to create user

create “dm_user” object
set client_capability=2,set default_folder=’’,
set home_docbase=’’,set user_address=’demo@test.com’,
set user_os_domain=’’,set user_name=’’,
set user_os_name=’’,set user_privileges=0,set user_source=’’


·         Query to retrieve group to which user has direct membership

Select group_name from dm_group where any users_names =’[user_name]’



·         Query to retrieve all groups to which user has membership

Select group_name from dm_group where any i_all_users_names =’[user_name]’




·         Query to get list of users and groups they directly belong to

select distinct ur.user_name,ur.user_os_name, gr.group_name FROM dm_user ur, dm_group gr where any gr.users_names = ur.user_name and r_is_group = 0 order by ur.user_name


·         Query to add user in group

alter group [group_name] add ‘user_name’

If wants to add more than one user then

alter group [group_name] add (select user_name from dm_user where user_name in (‘A’,’B’,’C’))


·         Query to drop user from a group

alter group [group_name] drop ‘user_name’


·         Query to get all the subgroups of a group

Select groups_names from dm_group where group_name=’[Group Name]’




·         Query to view details of active jobs

select r_object_id, object_name, method_name,start_date, expiration_date, run_interval, run_mode, a_last_invocation, a_last_completion, a_last_return_code as error_txt, a_next_invocation, a_iterations, a_current_status from dm_job where is_inactive=FALSE order by 2


·         Query to determine which jobs are currently running

select object_name, r_object_id from dm_job where a_special_app ='agentexec'


·         Query to get details virtual documents

select * from dm_document(all) where r_link_cnt>0


·         Query to get directly contained components of a virtual document

select r_object_id,r_object_type from dm_document(deleted) IN DOCUMENT ID ('[RootId]')


·         Query to get all contained components of a virtual document tree

select r_object_id,r_object_type from dm_document(deleted) IN DOCUMENT ID ('[RootId]') DESCEND




·         Query to execute SQL query

EXECUTE exec_sql WITH query=’sql_query’


·         Query to register a table from the underlying RDBMS with the Docbase

register table dm_dbo.testtable(id String(10),name String(35),address String(40))


·         Query to unregister a table from the underlying RDBMS with the Docbase

UNREGISTER TABLE testable


·         Query to get information of DAR installed in the Docbase

select * from dmc_dar


·         Query to get information of docbroker

execute list_targets


·         Query to retrieve the SQL translation of the last DQL statement

EXECUTE get_last_sql







Please feel free to contact me or just leave a comment if you want me to add any more DQL statements :-) :-). 
   
  

Make life easier — Git automation with single command file

Make life easier — Git automation with single command file Posted on medium #makelifeeasier series - Automation of git related activity...