From c5f8ff663d77e2ff0cd31eef31af34a218ee2995 Mon Sep 17 00:00:00 2001
From: Yoshinori Okuji <yo@nexedi.com>
Date: Wed, 31 Aug 2005 11:56:26 +0000
Subject: [PATCH] Add a new method exportSQLMethods.

git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@3688 20353a03-c40f-0410-a6d1-a30d3c3de9de
---
 product/ERP5Catalog/CatalogTool.py | 39 ++++++++++++++++++++++++++++++
 1 file changed, 39 insertions(+)

diff --git a/product/ERP5Catalog/CatalogTool.py b/product/ERP5Catalog/CatalogTool.py
index 0e336e2b0c..9737384ec3 100755
--- a/product/ERP5Catalog/CatalogTool.py
+++ b/product/ERP5Catalog/CatalogTool.py
@@ -184,7 +184,46 @@ class CatalogTool (UniqueObject, ZCatalog, CMFCoreCatalogTool, ActiveObject):
 
       # Make this the default.
       self.default_sql_catalog_id = config_id
+      
+    security.declareProtected( 'Import/Export objects', 'exportSQLMethods' )
+    def exportSQLMethods(self, id=None, config_id='erp5'):
+      """
+        Export SQL methods for a given configuration.
+      """
+      # For compatibility.
+      if config_id.lower() == 'erp5':
+        config_id = 'erp5_mysql'
+      elif config_id.lower() == 'cps3':
+        config_id = 'cps3_mysql'
 
+      catalog = self.getSQLCatalog(config_id)
+      product_path = package_home(globals())
+      common_sql_dir = os.path.join(product_path, 'sql', 'common_mysql')
+      config_sql_dir = os.path.join(product_path, 'sql', config_id)
+      common_sql_list = ('z0_drop_record.zsql', 'z_read_recorded_object_list', 'z_catalog_paths',
+                          'z_record_catalog_object', 'z_clear_reserved', 'z_record_uncatalog_object',
+                          'z_create_record', 'z_related_security', 'z_delete_recorded_object_list',
+                          'z_reserve_uid', 'z_getitem_by_path', 'z_show_columns', 'z_getitem_by_path',
+                          'z_show_tables', 'z_getitem_by_uid', 'z_unique_values', 'z_produce_reserved_uid_list',)
+    
+      msg = ''
+      for id in catalog.objectIds(spec=('Z SQL Method',)):
+        if id in common_sql_list:
+          d = common_sql_dir
+        else:
+          d = config_sql_dir
+        sql = catalog._getOb(id)
+        # First convert the skin to text
+        text = sql.manage_FTPget()
+        name = os.path.join(d, '%s.zsql' % (id,))
+        msg += 'Writing %s\n' % (name,)
+        f = open(name, 'w')
+        try:
+          f.write(text)
+        finally:
+          f.close()
+      return msg
+        
     def _listAllowedRolesAndUsers(self, user):
       try:
         from Products.NuxUserGroups.CatalogToolWithGroups import _getAllowedRolesAndUsers
-- 
2.30.9