function doBulkUpdate($filter, $do, $ids = array()) { @set_time_limit(0); $change_fields = array(); $custom_fields = array(); // Make sure we have actions if (empty($do)) { return; } // Make sure we have checked items if we want a checked list if (0 == strcasecmp($filter, "checks") && empty($ids)) { return; } if (is_array($do)) { foreach ($do as $k => $v) { switch ($k) { // $change_fields[DAO_Message::ID] = intval($v); // $change_fields[DAO_Message::ACCOUNT_ID] = intval($v); // $change_fields[DAO_Message::CREATED_DATE] = intval($v); // $change_fields[DAO_Message::UPDATED_DATE] = intval($v); // $change_fields[DAO_Message::MESSAGE] = intval($v); // $change_fields[DAO_Message::PARAMS_JSON] = intval($v); // $change_fields[DAO_Message::PARAMS] = intval($v); // [TODO] Implement actions case 'example': //$change_fields[DAO_Message::EXAMPLE] = 'some value'; break; default: // Custom fields if (substr($k, 0, 3) == "cf_") { $custom_fields[substr($k, 3)] = $v; } } } } $pg = 0; if (empty($ids)) { do { list($objects, $null) = DAO_Message::search($this->params, 100, $pg++, SearchFields_Message::ID, true, false); $ids = array_merge($ids, array_keys($objects)); } while (!empty($objects)); } $batch_total = count($ids); for ($x = 0; $x <= $batch_total; $x += 100) { $batch_ids = array_slice($ids, $x, 100); DAO_Message::update($batch_ids, $change_fields); // Custom Fields self::_doBulkSetCustomFields(FegCustomFieldSource_Message::ID, $custom_fields, $batch_ids); unset($batch_ids); } unset($ids); }