at path:
ROOT
/
wp-content
/
plugins
/
wpforms-lite
/
src
/
Migrations
/
Upgrade175.php
run:
R
W
Run
Tasks
DIR
2026-04-11 05:03:40
R
W
Run
Base.php
12.04 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Migrations.php
992 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade159.php
707 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1672.php
863 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade168.php
1.24 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade175.php
2.67 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1751.php
562 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade177.php
1.21 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade182.php
3.1 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade183.php
769 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade184.php
909 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade186.php
395 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade187.php
1.35 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1_9_1.php
1.37 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1_9_2.php
911 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1_9_7.php
333 By
2026-04-11 05:03:40
R
W
Run
Delete
Rename
Upgrade1_9_8_6.php
2.74 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
UpgradeBase.php
3.43 KB
2026-04-11 05:03:40
R
W
Run
Delete
Rename
error_log
up
📄
Upgrade175.php
Save
<?php namespace WPForms\Migrations; use WPForms\Tasks\Meta; use WPForms\Tasks\Tasks; /** * Class v1.7.5 upgrade. * * @since 1.7.5 * * @noinspection PhpUnused */ class Upgrade175 extends UpgradeBase { /** * Delete all task meta of not active tasks. * * @since 1.7.5 * * @noinspection ElvisOperatorCanBeUsedInspection * * @return bool|null Upgrade result: * true - the upgrade completed successfully, * false - in the case of failure, * null - upgrade started but not yet finished (background task). */ public function run() { global $wpdb; if ( ! $this->as_tables_exist() ) { return true; } $group = Tasks::GROUP; $sql = "SELECT DISTINCT a.args FROM {$wpdb->prefix}actionscheduler_actions a JOIN {$wpdb->prefix}actionscheduler_groups g ON g.group_id = a.group_id WHERE g.slug = '$group' AND a.status IN ( 'pending', 'in-progress' )"; // phpcs:disable WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.PreparedSQL.NotPrepared $results = $wpdb->get_results( $sql, 'ARRAY_A' ); // phpcs:enable WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching, WordPress.DB.PreparedSQL.NotPrepared $results = $results ? $results : []; $meta_ids = []; foreach ( $results as $result ) { $args = isset( $result['args'] ) ? json_decode( $result['args'], true ) : null; if ( $args && ! empty( $args['tasks_meta_id'] ) ) { $meta_ids[] = $args['tasks_meta_id']; } } $table_name = Meta::get_table_name(); $not_in = $meta_ids ? wpforms_wpdb_prepare_in( $meta_ids ) : '0'; // phpcs:disable WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.PreparedSQL.InterpolatedNotPrepared, WordPress.DB.DirectDatabaseQuery.NoCaching $wpdb->query( "DELETE FROM $table_name WHERE id NOT IN ( $not_in )" ); // phpcs:enable WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.PreparedSQL.InterpolatedNotPrepared, WordPress.DB.DirectDatabaseQuery.NoCaching return true; } /** * Check whether AS tables exist. * * @since 1.7.6 * * @return bool */ private function as_tables_exist() { global $wpdb; $required_tables = [ $wpdb->prefix . 'actionscheduler_actions', $wpdb->prefix . 'actionscheduler_groups', ]; // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching $tables = $wpdb->get_col( "SHOW TABLES LIKE '{$wpdb->prefix}actionscheduler%'" ); $intersect = array_values( array_intersect( $tables, $required_tables ) ); sort( $intersect ); sort( $required_tables ); return $intersect === $required_tables; } }