Enable contribution cancel actions
authoreileen <emcnaughton@wikimedia.org>
Tue, 20 Oct 2020 22:56:52 +0000 (11:56 +1300)
committereileen <emcnaughton@wikimedia.org>
Wed, 21 Oct 2020 02:13:04 +0000 (15:13 +1300)
Once completed this extension will be unhidden and available to disable

CRM/Upgrade/Incremental/php/FiveThirtyTwo.php
xml/templates/civicrm_data.tpl

index 890695e34a7a5141dcc9a68371c7149f8bcae33e..14e1412333166149c7f3968db134a2309f6926d2 100644 (file)
@@ -47,6 +47,38 @@ class CRM_Upgrade_Incremental_php_FiveThirtyTwo extends CRM_Upgrade_Incremental_
     // }
   }
 
+  /**
+   * Install contributioncancelactions extension.
+   *
+   * This feature is restructured as a core extension - which is primarily a code cleanup step but
+   * also permits sites / extensions to disable the core actions to do their own workflows.
+   *
+   * @param \CRM_Queue_TaskContext $ctx
+   *
+   * @return bool
+   *
+   * @throws \CRM_Core_Exception
+   */
+  public static function installContributionCancelActions(CRM_Queue_TaskContext $ctx) {
+    // Install via direct SQL manipulation. Note that:
+    // (1) This extension has no activation logic.
+    // (2) On new installs, the extension is activated purely via default SQL INSERT.
+    // (3) Caches are flushed at the end of the upgrade.
+    // ($) Over long term, upgrade steps are more reliable in SQL. API/BAO sometimes don't work mid-upgrade.
+    $insert = CRM_Utils_SQL_Insert::into('civicrm_extension')->row([
+      'type' => 'module',
+      'full_name' => 'contributioncancelactions',
+      'name' => 'contributioncancelactions',
+      'label' => 'Contribution cancel actions',
+      'file' => 'contributioncancelactions',
+      'schema_version' => NULL,
+      'is_active' => 1,
+    ]);
+    CRM_Core_DAO::executeQuery($insert->usingReplace()->toSQL());
+
+    return TRUE;
+  }
+
   /**
    * Upgrade function.
    *
@@ -57,6 +89,7 @@ class CRM_Upgrade_Incremental_php_FiveThirtyTwo extends CRM_Upgrade_Incremental_
     $this->addTask('Add column civicrm_saved_search.name', 'addColumn', 'civicrm_saved_search', 'name', "varchar(255)   DEFAULT NULL COMMENT 'Unique name of saved search'");
     $this->addTask('Add column civicrm_saved_search.label', 'addColumn', 'civicrm_saved_search', 'label', "varchar(255)   DEFAULT NULL COMMENT 'Administrative label for search'");
     $this->addTask('Add index civicrm_saved_search.UI_name', 'addIndex', 'civicrm_saved_search', 'name', 'UI');
+    $this->addTask('Install contribution cancel actions extension', 'installContributionCancelActions');
   }
 
 }
index e86bd1e5847280612e4c9f0293eed2eb36f878ec..50a26abd2b2bd0c7434a6e01a1541124c74f1438 100644 (file)
@@ -1782,3 +1782,4 @@ INSERT IGNORE INTO civicrm_extension (type, full_name, name, label, file, is_act
 INSERT IGNORE INTO civicrm_extension (type, full_name, name, label, file, is_active) VALUES ('module', 'greenwich', 'Theme: Greenwich', 'Theme: Greenwich', 'greenwich', 1);
 INSERT IGNORE INTO civicrm_extension (type, full_name, name, label, file, is_active) VALUES ('module', 'eventcart', 'Event cart', 'Event cart', 'eventcart', 1);
 INSERT IGNORE INTO civicrm_extension (type, full_name, name, label, file, is_active) VALUES ('module', 'financialacls', 'Financial ACLs', 'Financial ACLs', 'financialacls', 1);
+INSERT IGNORE INTO civicrm_extension (type, full_name, name, label, file, is_active) VALUES ('module', 'contributioncancelactions', 'Contribution cancel actions', 'Contribution cancel actions', 'contributioncancelactions', 1);