HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/zaklada/wp-content/plugins/acfml/classes/class-wpml-acf-migrate-option-page-strings.php
<?php

class WPML_ACF_Migrate_Option_Page_Strings {
	const CONTEXT = "ACF Option";
	const OPTION_PREFIX = "options";
	private $wpdb;

	public function __construct( wpdb $wpdb ) {
		$this->wpdb = $wpdb;
	}

	public function run_migration() {
		if ( $this->revert_should_run() ) {
			$this->revert_options_page_handling();
		}
	}

	/**
	 * Function moves ACF Option Pages' values translations from icl tables back to wp_options (where ACF stored this
	 * before ACFML 1.2)
	 */
	private function revert_options_page_handling() {
		$original_strings = $this->get_all_original_strings();
		if ( $original_strings ) {
			foreach ( $original_strings as $original_string ) {
				if ( $this->is_original_string_in_options_table( $original_string ) ) {
					$string_translations = $this->get_original_string_translations( $original_string );
					if ( $string_translations ) {
						foreach ( $string_translations as $string_translation ) {
							$this->move_translation( $string_translation, $original_string );
						}
					}
				}
				$this->all_string_translations_moved( $original_string );
			}
		} else { // no more strings in icl_strings so migration is done or user actually didn't translate any string
			update_option( 'acfml_options_page_revert_done', true );
		}
	}

	private function revert_should_run() {
		return false == get_option( 'acfml_options_page_revert_done' );
	}

	private function get_all_original_strings() {
		$original_strings_query = "SELECT id, name, value FROM {$this->wpdb->prefix}icl_strings WHERE context = %s";
		$original_strings_query = $this->wpdb->prepare( $original_strings_query, self::CONTEXT );
		$original_strings = $this->wpdb->get_results( $original_strings_query );

		return $original_strings;
	}

	private function is_original_string_in_options_table( $original_string ) {
		$original_wp_option_name = self::OPTION_PREFIX . "_" . $original_string->name;
		$original_wp_option_value = get_option( $original_wp_option_name );

		return $original_string->value === $original_wp_option_value;
	}

	private function get_original_string_translations( $original_string ) {
		$string_translations_query = "SELECT id, value, status, language FROM {$this->wpdb->prefix}icl_string_translations WHERE string_id = %d";
		$string_translations_query = $this->wpdb->prepare( $string_translations_query, $original_string->id );
		$string_translations = $this->wpdb->get_results( $string_translations_query );

		return $string_translations;
	}

	private function move_translation( $string_translation, $original_string ) { // from icl_string_translations to wp_options
		if ( $string_translation->status == ICL_TM_COMPLETE ) {
			$translated_wp_options_name = self::OPTION_PREFIX . "_" . $string_translation->language . "_" . $original_string->name;
			update_option( $translated_wp_options_name, $string_translation->value );
			// string translation have to be deleted as well
			$this->wpdb->delete( $this->wpdb->prefix . 'icl_string_translations',
				array( 'id' => $string_translation->id ),
				array( '%d' ) );
		}
	}

	private function all_string_translations_moved( $original_string ) {
		// each string have to be deleted from icl_strings
		$this->wpdb->delete( $this->wpdb->prefix . 'icl_strings',
			array( 'id' => $original_string->id ),
			array( '%d' ) );
	}
}