active_documentum 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (242) hide show
  1. data/LICENSE +20 -0
  2. data/README.rdoc +7 -0
  3. data/lib/active_documentum.rb +1 -0
  4. data/lib/active_documentum/access_control_client.rb +1 -0
  5. data/lib/active_documentum/base.rb +1 -0
  6. data/lib/active_documentum/docbase_config.rb +1 -0
  7. data/lib/active_documentum/logging.rb +16 -0
  8. data/lib/active_documentum/object_client.rb +1 -0
  9. data/lib/active_documentum/query_client.rb +1 -0
  10. data/lib/active_documentum/schema.rb +38 -0
  11. data/lib/active_documentum/schema_client.rb +1 -0
  12. data/lib/active_documentum/search_client.rb +1 -0
  13. data/lib/active_documentum/session.rb +1 -0
  14. data/lib/active_documentum/types/dm_acl.rb +24 -0
  15. data/lib/active_documentum/types/dm_acs_config.rb +108 -0
  16. data/lib/active_documentum/types/dm_activity.rb +150 -0
  17. data/lib/active_documentum/types/dm_aggr_domain.rb +23 -0
  18. data/lib/active_documentum/types/dm_alias_set.rb +13 -0
  19. data/lib/active_documentum/types/dm_app_ref.rb +90 -0
  20. data/lib/active_documentum/types/dm_application.rb +103 -0
  21. data/lib/active_documentum/types/dm_assembly.rb +15 -0
  22. data/lib/active_documentum/types/dm_attachments_folder.rb +91 -0
  23. data/lib/active_documentum/types/dm_audittrail.rb +47 -0
  24. data/lib/active_documentum/types/dm_audittrail_acl.rb +58 -0
  25. data/lib/active_documentum/types/dm_audittrail_group.rb +61 -0
  26. data/lib/active_documentum/types/dm_blobstore.rb +28 -0
  27. data/lib/active_documentum/types/dm_bocs_config.rb +100 -0
  28. data/lib/active_documentum/types/dm_builtin_expr.rb +10 -0
  29. data/lib/active_documentum/types/dm_business_pro.rb +93 -0
  30. data/lib/active_documentum/types/dm_ca_store.rb +33 -0
  31. data/lib/active_documentum/types/dm_cabinet.rb +92 -0
  32. data/lib/active_documentum/types/dm_cache_config.rb +96 -0
  33. data/lib/active_documentum/types/dm_category.rb +106 -0
  34. data/lib/active_documentum/types/dm_category_assign.rb +24 -0
  35. data/lib/active_documentum/types/dm_category_class.rb +99 -0
  36. data/lib/active_documentum/types/dm_ci_config.rb +108 -0
  37. data/lib/active_documentum/types/dm_client_registration.rb +93 -0
  38. data/lib/active_documentum/types/dm_client_rights.rb +96 -0
  39. data/lib/active_documentum/types/dm_component.rb +93 -0
  40. data/lib/active_documentum/types/dm_cond_expr.rb +21 -0
  41. data/lib/active_documentum/types/dm_cond_id_expr.rb +23 -0
  42. data/lib/active_documentum/types/dm_cont_transfer_config.rb +93 -0
  43. data/lib/active_documentum/types/dm_cryptographic_key.rb +93 -0
  44. data/lib/active_documentum/types/dm_dd_info.rb +44 -0
  45. data/lib/active_documentum/types/dm_decision.rb +95 -0
  46. data/lib/active_documentum/types/dm_display_config.rb +11 -0
  47. data/lib/active_documentum/types/dm_distributedstore.rb +29 -0
  48. data/lib/active_documentum/types/dm_dms_config.rb +94 -0
  49. data/lib/active_documentum/types/dm_docbase_config.rb +132 -0
  50. data/lib/active_documentum/types/dm_docbaseid_map.rb +9 -0
  51. data/lib/active_documentum/types/dm_docset.rb +94 -0
  52. data/lib/active_documentum/types/dm_docset_run.rb +100 -0
  53. data/lib/active_documentum/types/dm_document.rb +89 -0
  54. data/lib/active_documentum/types/dm_domain.rb +16 -0
  55. data/lib/active_documentum/types/dm_dump_record.rb +21 -0
  56. data/lib/active_documentum/types/dm_email_message.rb +96 -0
  57. data/lib/active_documentum/types/dm_esign_template.rb +94 -0
  58. data/lib/active_documentum/types/dm_expression.rb +9 -0
  59. data/lib/active_documentum/types/dm_extern_file.rb +38 -0
  60. data/lib/active_documentum/types/dm_extern_free.rb +34 -0
  61. data/lib/active_documentum/types/dm_extern_store.rb +34 -0
  62. data/lib/active_documentum/types/dm_extern_url.rb +34 -0
  63. data/lib/active_documentum/types/dm_federation.rb +96 -0
  64. data/lib/active_documentum/types/dm_filestore.rb +29 -0
  65. data/lib/active_documentum/types/dm_folder.rb +91 -0
  66. data/lib/active_documentum/types/dm_foreign_key.rb +20 -0
  67. data/lib/active_documentum/types/dm_format.rb +26 -0
  68. data/lib/active_documentum/types/dm_format_preferences.rb +89 -0
  69. data/lib/active_documentum/types/dm_ftengine_config.rb +91 -0
  70. data/lib/active_documentum/types/dm_ftindex_agent_config.rb +108 -0
  71. data/lib/active_documentum/types/dm_fulltext_index.rb +14 -0
  72. data/lib/active_documentum/types/dm_func_expr.rb +20 -0
  73. data/lib/active_documentum/types/dm_group.rb +57 -0
  74. data/lib/active_documentum/types/dm_java.rb +92 -0
  75. data/lib/active_documentum/types/dm_jms_config.rb +104 -0
  76. data/lib/active_documentum/types/dm_job.rb +114 -0
  77. data/lib/active_documentum/types/dm_job_request.rb +95 -0
  78. data/lib/active_documentum/types/dm_job_sequence.rb +95 -0
  79. data/lib/active_documentum/types/dm_key.rb +9 -0
  80. data/lib/active_documentum/types/dm_ldap_config.rb +123 -0
  81. data/lib/active_documentum/types/dm_linkedstore.rb +28 -0
  82. data/lib/active_documentum/types/dm_literal_expr.rb +9 -0
  83. data/lib/active_documentum/types/dm_load_record.rb +16 -0
  84. data/lib/active_documentum/types/dm_location.rb +94 -0
  85. data/lib/active_documentum/types/dm_locator.rb +90 -0
  86. data/lib/active_documentum/types/dm_media_profile.rb +93 -0
  87. data/lib/active_documentum/types/dm_menu_system.rb +89 -0
  88. data/lib/active_documentum/types/dm_message_address.rb +14 -0
  89. data/lib/active_documentum/types/dm_message_archive.rb +112 -0
  90. data/lib/active_documentum/types/dm_message_attachment.rb +10 -0
  91. data/lib/active_documentum/types/dm_message_container.rb +97 -0
  92. data/lib/active_documentum/types/dm_message_route_user_data.rb +9 -0
  93. data/lib/active_documentum/types/dm_message_user_data.rb +9 -0
  94. data/lib/active_documentum/types/dm_method.rb +104 -0
  95. data/lib/active_documentum/types/dm_migrate_rule.rb +152 -0
  96. data/lib/active_documentum/types/dm_mount_point.rb +95 -0
  97. data/lib/active_documentum/types/dm_network_location_map.rb +95 -0
  98. data/lib/active_documentum/types/dm_nls_dd_info.rb +21 -0
  99. data/lib/active_documentum/types/dm_note.rb +89 -0
  100. data/lib/active_documentum/types/dm_opticalstore.rb +30 -0
  101. data/lib/active_documentum/types/dm_outputdevice.rb +96 -0
  102. data/lib/active_documentum/types/dm_plugin.rb +93 -0
  103. data/lib/active_documentum/types/dm_policy.rb +122 -0
  104. data/lib/active_documentum/types/dm_procedure.rb +90 -0
  105. data/lib/active_documentum/types/dm_process.rb +124 -0
  106. data/lib/active_documentum/types/dm_public_key_certificate.rb +93 -0
  107. data/lib/active_documentum/types/dm_qual_comp.rb +96 -0
  108. data/lib/active_documentum/types/dm_query.rb +89 -0
  109. data/lib/active_documentum/types/dm_reference.rb +30 -0
  110. data/lib/active_documentum/types/dm_registered.rb +100 -0
  111. data/lib/active_documentum/types/dm_relation.rb +15 -0
  112. data/lib/active_documentum/types/dm_relation_ssa_policy.rb +17 -0
  113. data/lib/active_documentum/types/dm_relation_type.rb +18 -0
  114. data/lib/active_documentum/types/dm_retainer.rb +101 -0
  115. data/lib/active_documentum/types/dm_router.rb +130 -0
  116. data/lib/active_documentum/types/dm_scope_config.rb +9 -0
  117. data/lib/active_documentum/types/dm_script.rb +89 -0
  118. data/lib/active_documentum/types/dm_server_config.rb +159 -0
  119. data/lib/active_documentum/types/dm_shmeconfig.rb +7 -0
  120. data/lib/active_documentum/types/dm_smart_list.rb +93 -0
  121. data/lib/active_documentum/types/dm_ssa_policy.rb +90 -0
  122. data/lib/active_documentum/types/dm_staged.rb +91 -0
  123. data/lib/active_documentum/types/dm_state_extension.rb +16 -0
  124. data/lib/active_documentum/types/dm_state_type.rb +7 -0
  125. data/lib/active_documentum/types/dm_store.rb +26 -0
  126. data/lib/active_documentum/types/dm_sync_list_relation.rb +16 -0
  127. data/lib/active_documentum/types/dm_sysobject.rb +89 -0
  128. data/lib/active_documentum/types/dm_sysprocess_config.rb +104 -0
  129. data/lib/active_documentum/types/dm_taxonomy.rb +107 -0
  130. data/lib/active_documentum/types/dm_type.rb +24 -0
  131. data/lib/active_documentum/types/dm_user.rb +45 -0
  132. data/lib/active_documentum/types/dm_validation_descriptor.rb +91 -0
  133. data/lib/active_documentum/types/dm_value_assist.rb +11 -0
  134. data/lib/active_documentum/types/dm_value_func.rb +13 -0
  135. data/lib/active_documentum/types/dm_value_list.rb +12 -0
  136. data/lib/active_documentum/types/dm_value_query.rb +14 -0
  137. data/lib/active_documentum/types/dm_webc_config.rb +114 -0
  138. data/lib/active_documentum/types/dm_webc_target.rb +112 -0
  139. data/lib/active_documentum/types/dm_workflow.rb +39 -0
  140. data/lib/active_documentum/types/dm_xml_application.rb +96 -0
  141. data/lib/active_documentum/types/dm_xml_config.rb +90 -0
  142. data/lib/active_documentum/types/dm_xml_custom_code.rb +92 -0
  143. data/lib/active_documentum/types/dm_xml_style_sheet.rb +90 -0
  144. data/lib/active_documentum/types/dm_xml_zone.rb +91 -0
  145. data/lib/active_documentum/types/dmc_act_group_instance.rb +16 -0
  146. data/lib/active_documentum/types/dmc_aspect_relation.rb +8 -0
  147. data/lib/active_documentum/types/dmc_aspect_type.rb +111 -0
  148. data/lib/active_documentum/types/dmc_class.rb +92 -0
  149. data/lib/active_documentum/types/dmc_comment.rb +97 -0
  150. data/lib/active_documentum/types/dmc_completed_workflow.rb +21 -0
  151. data/lib/active_documentum/types/dmc_completed_workitem.rb +26 -0
  152. data/lib/active_documentum/types/dmc_composite_predicate.rb +7 -0
  153. data/lib/active_documentum/types/dmc_config_scope_relation.rb +17 -0
  154. data/lib/active_documentum/types/dmc_constraint_set.rb +92 -0
  155. data/lib/active_documentum/types/dmc_dar.rb +92 -0
  156. data/lib/active_documentum/types/dmc_jar.rb +91 -0
  157. data/lib/active_documentum/types/dmc_java_library.rb +92 -0
  158. data/lib/active_documentum/types/dmc_metamodel.rb +89 -0
  159. data/lib/active_documentum/types/dmc_module.rb +103 -0
  160. data/lib/active_documentum/types/dmc_module_config.rb +10 -0
  161. data/lib/active_documentum/types/dmc_notepage.rb +90 -0
  162. data/lib/active_documentum/types/dmc_preset_info.rb +19 -0
  163. data/lib/active_documentum/types/dmc_preset_package.rb +93 -0
  164. data/lib/active_documentum/types/dmc_process_correlation_set.rb +17 -0
  165. data/lib/active_documentum/types/dmc_process_parameter.rb +99 -0
  166. data/lib/active_documentum/types/dmc_readcomment.rb +8 -0
  167. data/lib/active_documentum/types/dmc_relationship_def.rb +104 -0
  168. data/lib/active_documentum/types/dmc_richtext.rb +92 -0
  169. data/lib/active_documentum/types/dmc_room.rb +100 -0
  170. data/lib/active_documentum/types/dmc_routecase_condition.rb +23 -0
  171. data/lib/active_documentum/types/dmc_tcf_activity.rb +91 -0
  172. data/lib/active_documentum/types/dmc_tcf_activity_template.rb +91 -0
  173. data/lib/active_documentum/types/dmc_topic.rb +94 -0
  174. data/lib/active_documentum/types/dmc_transition_condition.rb +20 -0
  175. data/lib/active_documentum/types/dmc_validation_module.rb +106 -0
  176. data/lib/active_documentum/types/dmc_validation_relation.rb +17 -0
  177. data/lib/active_documentum/types/dmc_wf_package_schema.rb +16 -0
  178. data/lib/active_documentum/types/dmc_wf_package_skill.rb +17 -0
  179. data/lib/active_documentum/types/dmc_wf_package_type_info.rb +93 -0
  180. data/lib/active_documentum/types/dmc_wfsd_element.rb +96 -0
  181. data/lib/active_documentum/types/dmc_wfsd_element_boolean.rb +97 -0
  182. data/lib/active_documentum/types/dmc_wfsd_element_date.rb +97 -0
  183. data/lib/active_documentum/types/dmc_wfsd_element_double.rb +97 -0
  184. data/lib/active_documentum/types/dmc_wfsd_element_integer.rb +97 -0
  185. data/lib/active_documentum/types/dmc_wfsd_element_parent.rb +92 -0
  186. data/lib/active_documentum/types/dmc_wfsd_element_string.rb +97 -0
  187. data/lib/active_documentum/types/dmc_wfsd_type_info.rb +106 -0
  188. data/lib/active_documentum/types/dmc_wfsdrp_boolean.rb +16 -0
  189. data/lib/active_documentum/types/dmc_wfsdrp_date.rb +16 -0
  190. data/lib/active_documentum/types/dmc_wfsdrp_double.rb +16 -0
  191. data/lib/active_documentum/types/dmc_wfsdrp_integer.rb +16 -0
  192. data/lib/active_documentum/types/dmc_wfsdrp_parent.rb +15 -0
  193. data/lib/active_documentum/types/dmc_wfsdrp_string.rb +16 -0
  194. data/lib/active_documentum/types/dmc_workqueue.rb +9 -0
  195. data/lib/active_documentum/types/dmc_workqueue_category.rb +91 -0
  196. data/lib/active_documentum/types/dmc_workqueue_doc_profile.rb +9 -0
  197. data/lib/active_documentum/types/dmc_workqueue_policy.rb +16 -0
  198. data/lib/active_documentum/types/dmc_workqueue_user_profile.rb +10 -0
  199. data/lib/active_documentum/types/dmc_wpr_parent.rb +16 -0
  200. data/lib/active_documentum/types/dmc_wq_skill_info.rb +14 -0
  201. data/lib/active_documentum/types/dmc_wq_task_skill.rb +10 -0
  202. data/lib/active_documentum/types/dmc_wq_user_skill.rb +10 -0
  203. data/lib/active_documentum/types/dmi_audittrail_attrs.rb +8 -0
  204. data/lib/active_documentum/types/dmi_change_record.rb +13 -0
  205. data/lib/active_documentum/types/dmi_dd_attr_info.rb +116 -0
  206. data/lib/active_documentum/types/dmi_dd_common_info.rb +57 -0
  207. data/lib/active_documentum/types/dmi_dd_type_info.rb +87 -0
  208. data/lib/active_documentum/types/dmi_dist_comp_record.rb +8 -0
  209. data/lib/active_documentum/types/dmi_dump_object_record.rb +9 -0
  210. data/lib/active_documentum/types/dmi_expr_code.rb +91 -0
  211. data/lib/active_documentum/types/dmi_index.rb +15 -0
  212. data/lib/active_documentum/types/dmi_linkrecord.rb +12 -0
  213. data/lib/active_documentum/types/dmi_load_object_record.rb +15 -0
  214. data/lib/active_documentum/types/dmi_otherfile.rb +9 -0
  215. data/lib/active_documentum/types/dmi_package.rb +22 -0
  216. data/lib/active_documentum/types/dmi_queue_item.rb +47 -0
  217. data/lib/active_documentum/types/dmi_recovery.rb +10 -0
  218. data/lib/active_documentum/types/dmi_registry.rb +21 -0
  219. data/lib/active_documentum/types/dmi_replica_record.rb +13 -0
  220. data/lib/active_documentum/types/dmi_sequence.rb +11 -0
  221. data/lib/active_documentum/types/dmi_session.rb +12 -0
  222. data/lib/active_documentum/types/dmi_subcontent.rb +9 -0
  223. data/lib/active_documentum/types/dmi_transactionlog.rb +8 -0
  224. data/lib/active_documentum/types/dmi_type_info.rb +22 -0
  225. data/lib/active_documentum/types/dmi_vstamp.rb +6 -0
  226. data/lib/active_documentum/types/dmi_wf_attachment.rb +11 -0
  227. data/lib/active_documentum/types/dmi_wf_timer.rb +17 -0
  228. data/lib/active_documentum/types/dmi_workitem.rb +35 -0
  229. data/lib/active_documentum/types/dmr_containment.rb +15 -0
  230. data/lib/active_documentum/types/dmr_content.rb +58 -0
  231. data/lib/support.rb +13 -0
  232. data/test/active_documentum/access_control_client_test.rb +15 -0
  233. data/test/active_documentum/docbase_config_test.rb +41 -0
  234. data/test/active_documentum/object_client_test.rb +11 -0
  235. data/test/active_documentum/query_client_test.rb +9 -0
  236. data/test/active_documentum/schema_client_test.rb +27 -0
  237. data/test/active_documentum/search_client_test.rb +9 -0
  238. data/test/active_documentum/types/dm_group_test.rb +151 -0
  239. data/test/active_documentum/types/dm_user_test.rb +106 -0
  240. data/test/active_documentum_test.rb +9 -0
  241. data/test/test_helper.rb +8 -0
  242. metadata +302 -0
data/LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2009 'Luke
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.rdoc ADDED
@@ -0,0 +1,7 @@
1
+ = Active Documentum
2
+
3
+ Active Documentum is a gem designed to enable interactions with Documentum. Particularly using DQL (Documentum Query Language) to be more Active Record like. It was written quite some time ago to help me do administrative tasks.
4
+
5
+ == Copyright
6
+
7
+ Copyright (c) 2009 'Luke Chadwick'. See LICENSE for details.
@@ -0,0 +1 @@
1
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
2
  require entry
1
3
  autoload :DocbaseConfig, 'active_documentum/docbase_config'
2
4
  autoload :Session, 'active_documentum/session'
3
5
  autoload :Base, 'active_documentum/base'
4
6
  autoload :Schema, 'active_documentum/schema'
5
7
 
6
8
  autoload :QueryClient, 'active_documentum/query_client'
7
9
  autoload :SchemaClient, 'active_documentum/schema_client'
8
10
  autoload :ObjectClient, 'active_documentum/object_client'
9
11
  autoload :SearchClient, 'active_documentum/search_client'
10
12
  autoload :AccessControlClient, 'active_documentum/access_control_client'
11
13
  ActiveDocumentum::DocbaseConfig.load
12
14
  Dir[File.join(File.dirname(__FILE__),'active_documentum/types')+'/*'].each do |file_name|
13
15
  autoload camelize(File.basename(file_name,'.rb')).intern, file_name
14
16
  end
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
2
  class Base
1
3
  @@table_name = nil
2
4
  attr_accessor :attributes
3
5
  class << self # Class methods
4
6
 
5
7
  def establish_connection(attributes = {})
6
8
  DocbaseConfig.url = attributes[:url] unless attributes[:url].nil?
7
9
  DocbaseConfig.docbase = attributes[:docbase] unless attributes[:docbase].nil?
8
10
  DocbaseConfig.username = attributes[:username] unless attributes[:username].nil?
9
11
  DocbaseConfig.password = attributes[:password] unless attributes[:password].nil?
10
12
  nil
11
13
  end
12
14
 
13
15
  def find(*args)
14
16
  sym = args.first
15
17
  options = {}
16
18
  options = args.last if args.size > 1
17
19
  #validate_find_options(options)
18
20
  #set_readonly_option!(options)
19
21
  case sym
20
22
  when :first then find_initial(options)
21
23
  when :all then find_every(options)
22
24
  else find_from_ids(args, options)
23
25
  end
24
26
  end
25
27
 
26
28
  # A convenience wrapper for <tt>find(:first, *args)</tt>. You can pass in all the
27
29
  # same arguments to this method as you can to <tt>find(:first)</tt>.
28
30
  def first(*args)
29
31
  find(:first, *args)
30
32
  end
31
33
  # A convenience wrapper for <tt>find(:last, *args)</tt>. You can pass in all the
32
34
  # same arguments to this method as you can to <tt>find(:last)</tt>.
33
35
  def last(*args)
34
36
  find(:last, *args)
35
37
  end
36
38
  # This is an alias for find(:all). You can pass in all the same arguments to this method as you can
37
39
  # to find(:all)
38
40
  def all(*args)
39
41
  find(:all, *args)
40
42
  end
41
43
 
42
44
  private
43
45
  def find_initial(options)
44
46
  options[:limit] = 1
45
47
  result = find_every(options)
46
48
  result.first if result.size > 0
47
49
  end
48
50
  def find_every(options)
49
51
  columns = (options[:columns] || "*")
50
52
  conditions = options[:conditions]
51
53
  order = options[:order]
52
54
  offset = (options[:offset] || 0).to_i
53
55
  page_size = (options[:page_size] || 500).to_i
54
56
  limit = options[:limit]
55
57
  query = "SELECT #{columns} FROM #{self.table_name}"
56
58
  where = ""
57
59
  unless conditions.nil?
58
60
  if conditions.is_a? Hash
59
61
  where = " WHERE "
60
62
  conditions.keys.each do |key|
61
63
  where += "#{key.to_s} = '#{conditions[key]}' AND "
62
64
  end
63
65
  where.chomp!(" AND ")
64
66
  elsif conditions.is_a? String
65
67
  where = " WHERE " + conditions
66
68
  end
67
69
  end
68
70
  query += where
69
71
  query += " ORDER BY " + order unless order.nil?
70
72
  @@connection ||= QueryClient.new
71
73
  total_results = @@connection.result_count(query).to_i
72
74
  unless limit.nil?
73
75
  total_results = limit.to_i
74
76
  page_size = limit.to_i if page_size.to_i > limit.to_i
75
77
  end
76
78
  results = []
77
79
  while(offset < total_results)
78
80
  execute(query, :page_size => page_size, :start_index => offset).each do |row|
79
81
  a = self.new(row)
80
82
  results << a
81
83
  end
82
84
  offset += page_size
83
85
  end
84
86
  return results
85
87
  end
86
88
  def find_from_ids(ids, options)
87
89
  expects_array = ids.first.kind_of?(Array)
88
90
  return ids.first if expects_array && ids.first.empty?
89
91
  ids = ids.flatten.compact.uniq
90
92
  case ids.size
91
93
  when 0
92
94
  raise StandardError, "Couldn't find #{name} without an ID"
93
95
  when 1
94
96
  result = find_one(ids.first, options)
95
97
  expects_array ? [ result ] : result
96
98
  else
97
99
  find_some(ids, options)
98
100
  end
99
101
  end
100
102
  def find_one(id, options)
101
103
  conditions = " AND (#{options[:conditions]})" if options[:conditions]
102
104
  options[:conditions] = "r_object_id = '#{id}'#{conditions}"
103
105
  # Use find_every(options).first since the primary key condition
104
106
  # already ensures we have a single record. Using find_initial adds
105
107
  # a superfluous :limit => 1.
106
108
  if result = find_every(options).first
107
109
  result
108
110
  else
109
111
  raise StandardError, "Couldn't find #{name} with ID=#{id}#{conditions}"
110
112
  end
111
113
  end
112
114
  def find_some(ids, options)
113
115
  conditions = " AND (#{options[:conditions]})" if options[:conditions]
114
116
  ids_list = ids.map { |id| "'#{id}'" }.join(',')
115
117
  options[:conditions] = "r_object_id IN (#{ids_list})#{conditions}"
116
118
  result = find_every(options)
117
119
  # Determine expected size from limit and offset, not just ids.size.
118
120
  expected_size =
119
121
  if options[:limit] && ids.size > options[:limit]
120
122
  options[:limit]
121
123
  else
122
124
  ids.size
123
125
  end
124
126
  # 11 ids with limit 3, offset 9 should give 2 results.
125
127
  if options[:offset] && (ids.size - options[:offset] < expected_size)
126
128
  expected_size = ids.size - options[:offset]
127
129
  end
128
130
  if result.size == expected_size
129
131
  result
130
132
  else
131
133
  raise StandardError, "Couldn't find all IDs (#{ids_list})#{conditions} (found #{result.size} results, but was looking for #{expected_size})"
132
134
  end
133
135
  end
134
136
 
135
137
  # Drying up executes to a single QueryClient instance
136
138
  def execute(query, options = {})
137
139
  @@connection ||= QueryClient.new
138
140
  $log.debug query
139
141
  result = @@connection.execute(query, options)
140
142
  result
141
143
  end
142
144
 
143
145
  end
144
146
  model = self.new(attributes)
145
147
  result = model.save
146
148
  def delete
147
149
  query = "DELETE #{self.class.table_name} OBJECT"
148
150
  query += " WHERE r_object_id = '#{self.r_object_id}'"
149
151
  result = execute(query).first
150
152
  end
151
153
 
152
154
  @table_name = value
153
155
  return @table_name unless @table_name.nil?
154
156
  return self.name.gsub(/([A-Z])/, '_\1').downcase.reverse.chop.reverse
155
157
  # Method missing in this case returns an existing attribute if it exists
156
158
  # and can assign attributes, but only if they already exist. Will need
157
159
  # some work to round it out eventually.
158
160
  def method_missing(meth,*args)
159
161
  unless meth.to_s.include?('=') #TODO dodgy
160
162
  super if @attributes_cache[meth.to_s].nil?
161
163
  return @attributes_cache[meth.to_s]
162
164
  end
163
165
  key = meth.to_s.gsub("=", "")
164
166
  @attributes_cache[key] = args.first
165
167
  return @attributes_cache[key]
166
168
  end
167
169
  "<#{self.class.to_s} @attributes=#{@attributes_cache.inspect}/>"
168
170
  private
169
171
  #raise ReadOnlyRecord if readonly?
170
172
  new_record? ? create_record : update
171
173
  end
172
174
  # Updates the associated record with values matching those of the instance attributes.
173
175
  # Returns the number of affected rows.
174
176
  def update(attribute_names = @attributes.keys)
175
177
  query = "UPDATE #{self.class.table_name} OBJECT"
176
178
  @attributes_cache.keys.each do |key|
177
179
  query += " SET #{key.to_s} = '#{@attributes_cache[key]}'"
178
180
  end
179
181
  query += " WHERE r_object_id = '#{self.r_object_id}'"
180
182
  result = execute(query).first
181
183
  end
182
184
  # Creates a record with values matching those of the instance attributes
183
185
  # and returns its id.
184
186
  def create_record
185
187
  query = "CREATE #{self.class.table_name} OBJECT"
186
188
  @attributes_cache.keys.each do |key|
187
189
  query += " SET #{key.to_s} = '#{@attributes_cache[key]}'"
188
190
  end
189
191
  result = execute(query).first
190
192
  @new_record = false
191
193
  result
192
194
  end
193
195
 
194
196
  # Drying up executes to a single QueryClient instance
195
197
  def execute(query, options = {})
196
198
  @@connection ||= QueryClient.new
197
199
  $log.debug query
198
200
  result = @@connection.execute(query, options)
199
201
  result
200
202
  end
201
203
  end
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
2
  class DocbaseConfig
1
3
  @@config = {}
2
4
  def self.docbase
3
5
  load if @@config.empty?
4
6
  @@config[$environment]["docbase"]
5
7
  end
6
8
  def self.docbase=(value)
7
9
  @@config[$environment] ||= {}
8
10
  @@config[$environment]["docbase"] = value
9
11
  end
10
12
  def self.username
11
13
  load if @@config.empty? or @@config.nil?
12
14
  @@config[$environment]["username"]
13
15
  end
14
16
  def self.username=(value)
15
17
  @@config[$environment] ||= {}
16
18
  @@config[$environment]["username"] = value
17
19
  end
18
20
  def self.password
19
21
  load if @@config.empty? or @@config.nil?
20
22
  @@config[$environment]["password"]
21
23
  end
22
24
  def self.password=(value)
23
25
  @@config[$environment] ||= {}
24
26
  @@config[$environment]["password"] = value
25
27
  end
26
28
  def self.url
27
29
  load if @@config.empty? or @@config.nil?
28
30
  @@config[$environment]["url"]
29
31
  end
30
32
  def self.url=(value)
31
33
  @@config[$environment] ||= {}
32
34
  @@config[$environment]["url"] = value
33
35
  end
34
36
  def self.load
35
37
  $log.debug "Loading config"
36
38
  @@config.merge!(YAML.load(File.open('config/environment.yml')))
37
39
  end
38
40
  end
@@ -0,0 +1,16 @@
1
+ module ActiveDocumentum
2
+ class Logging
3
+ def initialize()
4
+ include Log4r
5
+ $log = Logger.new($environment)
6
+ #$log.level = Log4r::INFO
7
+ format = PatternFormatter.new(:pattern => "[%l] %d :: %m")
8
+ stdout_outputter = Outputter.stdout
9
+ stdout_outputter.formatter = format
10
+ FileUtils.mkdir_p('log')
11
+ file = FileOutputter.new('fileOutputter', :filename => "log/#{$environment}.log",:trunc => false)
12
+ file.formatter = format
13
+ $log.outputters = stdout_outputter, file
14
+ end
15
+ end
16
+ end
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
2
  def get(object_id)
1
3
  objIdentity = ObjectIdentity.new(ObjectId.new(object_id), ActiveDocumentum::DocbaseConfig.docbase)
2
4
  objectIdSet = ObjectIdentitySet.new()
3
5
  objectIdSet.addIdentity(objIdentity)
4
6
  operationOptions = OperationOptions.new()
5
7
 
6
8
  propertyProfile = PropertyProfile.new(PropertyFilterMode.const_get("ALL"))
7
9
  contentProfile = ContentProfile.new
8
10
  contentTransferProfile = ContentTransferProfile.new
9
11
 
10
12
  permissionProfile = PermissionProfile.new
11
13
  permissionProfile.setPermissionTypeFilter(PermissionTypeFilter.const_get("ANY"))
12
14
  operationOptions.setPermissionProfile(permissionProfile)
13
15
  contentTransferProfile.setTransferMode(ContentTransferMode.const_get("MTOM"))
14
16
  contentProfile.setFormatFilter(FormatFilter.const_get("ANY"))
15
17
  operationOptions.setContentTransferProfile(contentTransferProfile)
16
18
  operationOptions.setPropertyProfile(propertyProfile)
17
19
  operationOptions.setContentProfile(contentProfile)
18
20
  operationOptions.setProfile(contentProfile);
19
21
 
20
22
  dataPackage = @service.get(objectIdSet, operationOptions)
21
23
  return dataPackage.getDataObjects().get(0)
22
24
  end
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
2
  results = []
1
3
  begin
2
4
  rescue RuntimeError => e
3
5
  $log.error e.message
4
6
  results << {:error => e.message}
5
7
  end
6
8
  return results
7
9
  elsif k.include?('ObjectId')
8
10
  return value.getValueAsString()
@@ -0,0 +1,38 @@
1
+ module ActiveDocumentum
2
+ class Schema
3
+ include Support
4
+
5
+ @@sc = nil
6
+ @@schema = nil
7
+
8
+ def initialize
9
+ @@sc ||= ActiveDocumentum::SchemaClient.new
10
+ @@schema ||= @@sc.schema_info
11
+ @base_dir = "tmp/types/" #TODO find better way of doing this
12
+ end
13
+
14
+ def load_type(type_name)
15
+ file_name = @base_dir + type_name + '.rb'
16
+ unless File.exists?(file_name)
17
+ type = @@sc.type_info(type_name)
18
+ parent_name = camelize(type[:parent_name]) unless type[:parent_name].empty?
19
+ parent_name ||= "ActiveDocumentum::Base"
20
+ class_def = "class #{camelize(type_name)} < #{parent_name}\n"
21
+ type[:properties].each do |property|
22
+ class_def += "# #{property[:name]} => #{property.inspect}\n"
23
+ end
24
+ class_def += "end"
25
+ FileUtils.mkdir_p(@base_dir)
26
+ File.open(file_name, 'w') {|f| f.puts class_def }
27
+ end
28
+ autoload camelize(type_name).intern, file_name
29
+ end
30
+
31
+ def load
32
+ @@schema[:types].each do |name|
33
+ load_type(name)
34
+ end
35
+ end
36
+
37
+ end
38
+ end
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
@@ -0,0 +1 @@
1
+ module ActiveDocumentum
2
  class Session
1
3
  end
@@ -0,0 +1,24 @@
1
+ class DmAcl < ActiveDocumentum::Base
2
+ # object_name => {:name=>"object_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
3
+ # description => {:name=>"description", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>128, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
4
+ # owner_name => {:name=>"owner_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
5
+ # r_is_internal => {:name=>"r_is_internal", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
6
+ # r_accessor_name => {:name=>"r_accessor_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
7
+ # r_accessor_permit => {:name=>"r_accessor_permit", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
8
+ # r_accessor_xpermit => {:name=>"r_accessor_xpermit", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
9
+ # r_is_group => {:name=>"r_is_group", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
10
+ # globally_managed => {:name=>"globally_managed", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
11
+ # acl_class => {:name=>"acl_class", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
12
+ # r_has_events => {:name=>"r_has_events", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
13
+ # r_permit_type => {:name=>"r_permit_type", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
14
+ # r_application_permit => {:name=>"r_application_permit", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>128, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
15
+ # i_has_required_groups => {:name=>"i_has_required_groups", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
16
+ # i_has_required_group_set => {:name=>"i_has_required_group_set", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
17
+ # i_has_access_restrictions => {:name=>"i_has_access_restrictions", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
18
+ # r_template_id => {:name=>"r_template_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
19
+ # r_alias_set_id => {:name=>"r_alias_set_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
20
+ # i_partition => {:name=>"i_partition", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
21
+ # i_is_replica => {:name=>"i_is_replica", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
22
+ # i_vstamp => {:name=>"i_vstamp", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
23
+ # r_object_id => {:name=>"r_object_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
24
+ end
@@ -0,0 +1,108 @@
1
+ class DmAcsConfig < DmSysobject
2
+ # object_name => {:name=>"object_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>255, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
3
+ # r_object_type => {:name=>"r_object_type", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
4
+ # title => {:name=>"title", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>400, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
5
+ # subject => {:name=>"subject", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>192, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
6
+ # authors => {:name=>"authors", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>48, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
7
+ # keywords => {:name=>"keywords", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>48, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
8
+ # a_application_type => {:name=>"a_application_type", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
9
+ # a_status => {:name=>"a_status", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>16, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
10
+ # r_creation_date => {:name=>"r_creation_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
11
+ # r_modify_date => {:name=>"r_modify_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
12
+ # r_modifier => {:name=>"r_modifier", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
13
+ # r_access_date => {:name=>"r_access_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
14
+ # a_is_hidden => {:name=>"a_is_hidden", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
15
+ # i_is_deleted => {:name=>"i_is_deleted", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
16
+ # a_retention_date => {:name=>"a_retention_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
17
+ # a_archive => {:name=>"a_archive", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
18
+ # a_compound_architecture => {:name=>"a_compound_architecture", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>16, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
19
+ # a_link_resolved => {:name=>"a_link_resolved", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
20
+ # i_reference_cnt => {:name=>"i_reference_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
21
+ # i_has_folder => {:name=>"i_has_folder", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
22
+ # i_folder_id => {:name=>"i_folder_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
23
+ # r_composite_id => {:name=>"r_composite_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
24
+ # r_composite_label => {:name=>"r_composite_label", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
25
+ # r_component_label => {:name=>"r_component_label", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
26
+ # r_order_no => {:name=>"r_order_no", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
27
+ # r_link_cnt => {:name=>"r_link_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
28
+ # r_link_high_cnt => {:name=>"r_link_high_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
29
+ # r_assembled_from_id => {:name=>"r_assembled_from_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
30
+ # r_frzn_assembly_cnt => {:name=>"r_frzn_assembly_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
31
+ # r_has_frzn_assembly => {:name=>"r_has_frzn_assembly", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
32
+ # resolution_label => {:name=>"resolution_label", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
33
+ # r_is_virtual_doc => {:name=>"r_is_virtual_doc", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
34
+ # i_contents_id => {:name=>"i_contents_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
35
+ # a_content_type => {:name=>"a_content_type", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
36
+ # r_page_cnt => {:name=>"r_page_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
37
+ # r_content_size => {:name=>"r_content_size", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
38
+ # a_full_text => {:name=>"a_full_text", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
39
+ # a_storage_type => {:name=>"a_storage_type", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
40
+ # i_cabinet_id => {:name=>"i_cabinet_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
41
+ # owner_name => {:name=>"owner_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
42
+ # owner_permit => {:name=>"owner_permit", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
43
+ # group_name => {:name=>"group_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
44
+ # group_permit => {:name=>"group_permit", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
45
+ # world_permit => {:name=>"world_permit", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
46
+ # i_antecedent_id => {:name=>"i_antecedent_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
47
+ # i_chronicle_id => {:name=>"i_chronicle_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
48
+ # i_latest_flag => {:name=>"i_latest_flag", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
49
+ # r_lock_owner => {:name=>"r_lock_owner", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
50
+ # r_lock_date => {:name=>"r_lock_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
51
+ # r_lock_machine => {:name=>"r_lock_machine", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>80, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
52
+ # log_entry => {:name=>"log_entry", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>120, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
53
+ # r_version_label => {:name=>"r_version_label", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
54
+ # i_branch_cnt => {:name=>"i_branch_cnt", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
55
+ # i_direct_dsc => {:name=>"i_direct_dsc", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
56
+ # r_immutable_flag => {:name=>"r_immutable_flag", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
57
+ # r_frozen_flag => {:name=>"r_frozen_flag", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
58
+ # r_has_events => {:name=>"r_has_events", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
59
+ # acl_domain => {:name=>"acl_domain", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
60
+ # acl_name => {:name=>"acl_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
61
+ # a_special_app => {:name=>"a_special_app", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
62
+ # i_is_reference => {:name=>"i_is_reference", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
63
+ # r_creator_name => {:name=>"r_creator_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
64
+ # r_is_public => {:name=>"r_is_public", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
65
+ # r_policy_id => {:name=>"r_policy_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
66
+ # r_resume_state => {:name=>"r_resume_state", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
67
+ # r_current_state => {:name=>"r_current_state", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
68
+ # r_alias_set_id => {:name=>"r_alias_set_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
69
+ # a_effective_date => {:name=>"a_effective_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
70
+ # a_expiration_date => {:name=>"a_expiration_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
71
+ # a_publish_formats => {:name=>"a_publish_formats", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
72
+ # a_effective_label => {:name=>"a_effective_label", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
73
+ # a_effective_flag => {:name=>"a_effective_flag", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>8, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
74
+ # a_category => {:name=>"a_category", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>64, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
75
+ # language_code => {:name=>"language_code", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>5, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
76
+ # a_is_template => {:name=>"a_is_template", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
77
+ # a_controlling_app => {:name=>"a_controlling_app", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
78
+ # r_full_content_size => {:name=>"r_full_content_size", :description=>"", :data_type=>"DOUBLE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
79
+ # a_extended_properties => {:name=>"a_extended_properties", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
80
+ # a_is_signed => {:name=>"a_is_signed", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
81
+ # a_last_review_date => {:name=>"a_last_review_date", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
82
+ # i_retain_until => {:name=>"i_retain_until", :description=>"", :data_type=>"DATE", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
83
+ # r_aspect_name => {:name=>"r_aspect_name", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>64, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
84
+ # i_retainer_id => {:name=>"i_retainer_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
85
+ # i_partition => {:name=>"i_partition", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
86
+ # i_is_replica => {:name=>"i_is_replica", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
87
+ # i_vstamp => {:name=>"i_vstamp", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
88
+ # svr_config_id => {:name=>"svr_config_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
89
+ # config_type => {:name=>"config_type", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
90
+ # acs_rw_capability => {:name=>"acs_rw_capability", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
91
+ # near_stores => {:name=>"near_stores", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>32, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
92
+ # supported_store_types => {:name=>"supported_store_types", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
93
+ # supported_crypto_mode => {:name=>"supported_crypto_mode", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
94
+ # supported_compression_mode => {:name=>"supported_compression_mode", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
95
+ # acs_base_url => {:name=>"acs_base_url", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>240, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
96
+ # acs_supported_protocol => {:name=>"acs_supported_protocol", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>6, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
97
+ # projection_netloc_enable => {:name=>"projection_netloc_enable", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
98
+ # projection_netloc_ident => {:name=>"projection_netloc_ident", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>80, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
99
+ # projection_enable => {:name=>"projection_enable", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
100
+ # projection_proxval => {:name=>"projection_proxval", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
101
+ # projection_targets => {:name=>"projection_targets", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>80, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
102
+ # projection_ports => {:name=>"projection_ports", :description=>"", :data_type=>"INTEGER", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
103
+ # acs_network_locations => {:name=>"acs_network_locations", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>80, :default_values=>[], :is_array=>true, :is_dynamic=>false, :is_required=>false}
104
+ # is_cache_acs => {:name=>"is_cache_acs", :description=>"", :data_type=>"BOOLEAN", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
105
+ # server_major_version => {:name=>"server_major_version", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>16, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
106
+ # server_minor_version => {:name=>"server_minor_version", :description=>"", :data_type=>"STRING", :dependencies=>[], :length=>16, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
107
+ # r_object_id => {:name=>"r_object_id", :description=>"", :data_type=>"OBJECT_ID", :dependencies=>[], :length=>0, :default_values=>[], :is_array=>false, :is_dynamic=>false, :is_required=>false}
108
+ end