Pimcore\Model\Version\Dao::maintenanceGetOutdatedVersions PHP Метод

maintenanceGetOutdatedVersions() публичный Метод

public maintenanceGetOutdatedVersions ( $elementTypes, $ignoreIds = [] ) : array
$elementTypes
Результат array
    public function maintenanceGetOutdatedVersions($elementTypes, $ignoreIds = [])
    {
        $ignoreIdsList = implode(",", $ignoreIds);
        if (!$ignoreIdsList) {
            $ignoreIdsList = "0";
            // set a default to avoid SQL errors (there's no version with ID 0)
        }
        $versionIds = [];
        Logger::debug("ignore ID's: " . $ignoreIdsList);
        if (!empty($elementTypes)) {
            $count = 0;
            $stop = false;
            foreach ($elementTypes as $elementType) {
                if ($elementType["days"] > 0) {
                    // by days
                    $deadline = time() - $elementType["days"] * 86400;
                    $tmpVersionIds = $this->db->fetchCol("SELECT id FROM versions as a WHERE (ctype = ? AND date < ?) AND NOT public AND id NOT IN (" . $ignoreIdsList . ")", [$elementType["elementType"], $deadline]);
                    $versionIds = array_merge($versionIds, $tmpVersionIds);
                } else {
                    // by steps
                    $elementIds = $this->db->fetchCol("SELECT cid,count(*) as amount FROM versions WHERE ctype = ? AND NOT public AND id NOT IN (" . $ignoreIdsList . ") GROUP BY cid HAVING amount > ?", [$elementType["elementType"], $elementType["steps"]]);
                    foreach ($elementIds as $elementId) {
                        $count++;
                        Logger::info($elementId . "(object " . $count . ") Vcount " . count($versionIds));
                        $elementVersions = $this->db->fetchCol("SELECT id FROM versions WHERE cid = ? and ctype = ? ORDER BY date DESC LIMIT " . $elementType["steps"] . ",1000000", [$elementId, $elementType["elementType"]]);
                        $versionIds = array_merge($versionIds, $elementVersions);
                        // call the garbage collector if memory consumption is > 100MB
                        if (memory_get_usage() > 100000000 && $count % 100 == 0) {
                            \Pimcore::collectGarbage();
                            sleep(1);
                            $versionIds = array_unique($versionIds);
                        }
                        if (count($versionIds) > 1000) {
                            $stop = true;
                            break;
                        }
                    }
                    $versionIds = array_unique($versionIds);
                    if ($stop) {
                        break;
                    }
                }
            }
        }
        Logger::info("return " . count($versionIds) . " ids\n");
        return $versionIds;
    }