Mini Shell

Direktori : /home/rubikeu/public_html/
Upload File :
Current File : /home/rubikeu/public_html/wp-cron.php

<?php
/**
 * A pseudo-cron daemon for scheduling WordPress tasks.
 *
 * WP-Cron is triggered when the site receives a visit. In the scenario
 * where a site may not receive enough visits to execute scheduled tasks
 * in a timely manner, this file can be called directly or via a server
 * cron daemon for X number of times.
 *
 * Defining DISABLE_WP_CRON as true and calling this file directly are
 * mutually exclusive and the latter does not rely on the former to work.
 *
 * The HTTP request to this file will not slow down the visitor who happens to
 * visit when a scheduled cron event runs.
 *
 * @package WordPress
 */

ignore_user_abort( true );

if ( ! headers_sent() ) {
	header( 'Expires: Wed, 11 Jan 1984 05:00:00 GMT' );
	header( 'Cache-Control: no-cache, must-revalidate, max-age=0' );
}

// Don't run cron until the request finishes, if possible.
if ( function_exists( 'fastcgi_finish_request' ) ) {
	fastcgi_finish_request();
} elseif ( function_exists( 'litespeed_finish_request' ) ) {
	litespeed_finish_request();
}

if ( ! empty( $_POST ) || defined( 'DOING_AJAX' ) || defined( 'DOING_CRON' ) ) {
	die();
}

/**
 * Tell WordPress the cron task is running.
 *
 * @var bool
 */
define( 'DOING_CRON', true );

if ( ! defined( 'ABSPATH' ) ) {
	/** Set up WordPress environment */
	require_once __DIR__ . '/wp-load.php';
}

// Attempt to raise the PHP memory limit for cron event processing.
wp_raise_memory_limit( 'cron' );

/**
 * Retrieves the cron lock.
 *
 * Returns the uncached `doing_cron` transient.
 *
 * @ignore
 * @since 3.3.0
 *
 * @global wpdb $wpdb WordPress database abstraction object.
 *
 * @return string|int|false Value of the `doing_cron` transient, 0|false otherwise.
 */
function _get_cron_lock() {
	global $wpdb;

	$value = 0;
	if ( wp_using_ext_object_cache() ) {
		/*
		 * Skip local cache and force re-fetch of doing_cron transient
		 * in case another process updated the cache.
		 */
		$value = wp_cache_get( 'doing_cron', 'transient', true );
	} else {
		$row = $wpdb->get_row( $wpdb->prepare( "SELECT option_value FROM $wpdb->options WHERE option_name = %s LIMIT 1", '_transient_doing_cron' ) );
		if ( is_object( $row ) ) {
			$value = $row->option_value;
		}
	}

	return $value;
}

$crons = wp_get_ready_cron_jobs();
if ( empty( $crons ) ) {
	die();
}

$gmt_time = microtime( true );

// The cron lock: a unix timestamp from when the cron was spawned.
$doing_cron_transient = get_transient( 'doing_cron' );

// Use global $doing_wp_cron lock, otherwise use the GET lock. If no lock, try to grab a new lock.
if ( empty( $doing_wp_cron ) ) {
	if ( empty( $_GET['doing_wp_cron'] ) ) {
		// Called from external script/job. Try setting a lock.
		if ( $doing_cron_transient && ( $doing_cron_transient + WP_CRON_LOCK_TIMEOUT > $gmt_time ) ) {
			return;
		}
		$doing_wp_cron        = sprintf( '%.22F', microtime( true ) );
		$doing_cron_transient = $doing_wp_cron;
		set_transient( 'doing_cron', $doing_wp_cron );
	} else {
		$doing_wp_cron = $_GET['doing_wp_cron'];
	}
}

/*
 * The cron lock (a unix timestamp set when the cron was spawned),
 * must match $doing_wp_cron (the "key").
 */
if ( $doing_cron_transient !== $doing_wp_cron ) {
	return;
}

foreach ( $crons as $timestamp => $cronhooks ) {
	if ( $timestamp > $gmt_time ) {
		break;
	}

	foreach ( $cronhooks as $hook => $keys ) {

		foreach ( $keys as $k => $v ) {

			$schedule = $v['schedule'];

			if ( $schedule ) {
				$result = wp_reschedule_event( $timestamp, $schedule, $hook, $v['args'], true );

				if ( is_wp_error( $result ) ) {
					error_log(
						sprintf(
							/* translators: 1: Hook name, 2: Error code, 3: Error message, 4: Event data. */
							__( 'Cron reschedule event error for hook: %1$s, Error code: %2$s, Error message: %3$s, Data: %4$s' ),
							$hook,
							$result->get_error_code(),
							$result->get_error_message(),
							wp_json_encode( $v )
						)
					);

					/**
					 * Fires if an error happens when rescheduling a cron event.
					 *
					 * @since 6.1.0
					 *
					 * @param WP_Error $result The WP_Error object.
					 * @param string   $hook   Action hook to execute when the event is run.
					 * @param array    $v      Event data.
					 */
					do_action( 'cron_reschedule_event_error', $result, $hook, $v );
				}
			}

			$result = wp_unschedule_event( $timestamp, $hook, $v['args'], true );

			if ( is_wp_error( $result ) ) {
				error_log(
					sprintf(
						/* translators: 1: Hook name, 2: Error code, 3: Error message, 4: Event data. */
						__( 'Cron unschedule event error for hook: %1$s, Error code: %2$s, Error message: %3$s, Data: %4$s' ),
						$hook,
						$result->get_error_code(),
						$result->get_error_message(),
						wp_json_encode( $v )
					)
				);

				/**
				 * Fires if an error happens when unscheduling a cron event.
				 *
				 * @since 6.1.0
				 *
				 * @param WP_Error $result The WP_Error object.
				 * @param string   $hook   Action hook to execute when the event is run.
				 * @param array    $v      Event data.
				 */
				do_action( 'cron_unschedule_event_error', $result, $hook, $v );
			}

			/**
			 * Fires scheduled events.
			 *
			 * @ignore
			 * @since 2.1.0
			 *
			 * @param string $hook Name of the hook that was scheduled to be fired.
			 * @param array  $args The arguments to be passed to the hook.
			 */
			do_action_ref_array( $hook, $v['args'] );

			// If the hook ran too long and another cron process stole the lock, quit.
			if ( _get_cron_lock() !== $doing_wp_cron ) {
				return;
			}
		}
	}
}

if ( _get_cron_lock() === $doing_wp_cron ) {
	delete_transient( 'doing_cron' );
}

die();
Rubik Software Europe
Loading...

Your Software Partner
in Europe

Build Software in the European Way!
Smart teams. Scalable tech. Full compliance.

Innovate Together Next Level Innovate Together Next Level Innovate Together

What We Do

We support from innovative start-ups to large international groups through two flexible engagement models:

Time & Material

For long-term projects where priorities and team composition evolve over time.
→ Dedicated software engineers integrated with your team.

Fixed Price

For projects with defined scope and timeline.
→ Complete delivery with milestones, roadmap, and end-to-end project management.

Our
Technology Expertise

Backend Frontend Mobile DevOps & Cloud Data & Analytics ERP & CRM

Our Story

We were born from code, challenges and a shared vision, not just puzzles!
Founded by engineers with a shared past in outsourced collaboration, Rubik Europe grew from a lean idea to a distributed software powerhouse, built around European values, real partnerships, and a drive for excellence in digital delivery.

#1
Foundation of Rubik Europe

Rubik was founded in 2017, when two professionals, collaborating through outsourcing, turned their shared vision into a company inspired by the Rubik’s Cube: structured, logical, and built to solve real business challenges.

#2
Commitment to Innovation

Over time, Rubik expanded beyond Italy, opening operational hubs in Albania, Malta, and Sweden, and building a distributed delivery model that combines cultural proximity, technical coordination, and full GDPR compliance.

#3
Growth and Expansion

Rubik initially focused on the Italian market, building strong ties with leading enterprises and digital agencies. The team grew organically, shaped by hands-on experience, long-term clients, and a deep commitment to technical reliability.

#4
Future Vision

Today, Rubik Europe empowers companies across the continent to build software smarter. With a core focus on Time & Material and Fixed Price delivery models, we continue to serve complex projects with agility, ownership, and a European mindset!

Meet Founders

Alessio Puddu

CEO & Founder

Aldi Leka

CTO

Core Values & Strategic Outlook

Mission

Our mission is to build scalable and secure software solutions through distributed teams, combining engineering excellence, European standards, and a delivery culture focused on transparency and agility.

Vision

Our vision is to become the go-to European partner for modern software development, empowering companies to grow through flexible collaboration models and a solid, GDPR-compliant tech backbone.

Our
Industry Solutions Lead.

#1
Finance

We develop secure, compliant software solutions for banks, fintechs, and financial institutions, helping them modernize legacy systems and streamline digital operations.

#2
Insurance

We support insurance companies with custom platforms and tools that automate workflows, manage policies and claims, and integrate securely with third-party systems.

#3
Automotive

We build robust software solutions for mobility and automotive players, from fleet platforms to connected services, improving efficiency, safety, and innovation.

#4
Retail

We deliver scalable digital products that enhance customer experience, manage inventory and logistics, and support omnichannel sales strategies.

#5
Logistic

We create software that supports logistics operations, including warehouse management, transport tracking, and real-time coordination of supply chains across borders.

#6
Public Administration

We support public institutions with digital solutions that simplify services, enhance citizen access, and ensure compliance with EU regulations and standards.

Clients we worked with