oont-contents/plugins/wp-rocket/inc/classes/admin/class-options.php
2025-02-08 15:10:23 +01:00

95 lines
2 KiB
PHP

<?php
namespace WP_Rocket\Admin;
/**
* Manages options using the WordPress options API.
*
* @since 3.0
* @author Remy Perona
*/
class Options extends Abstract_Options {
/**
* The prefix used by WP Rocket options.
*
* @since 3.0
* @author Remy Perona
*
* @var string
*/
private $prefix;
/**
* Constructor
*
* @since 3.0
* @author Remy Perona
*
* @param string $prefix WP Rocket options prefix.
*/
public function __construct( $prefix = '' ) {
$this->prefix = $prefix;
}
/**
* Gets the option name used to store the option in the WordPress database.
*
* @since 3.0
* @author Remy Perona
*
* @param string $name Unprefixed name of the option.
*
* @return string Option name used to store it
*/
public function get_option_name( $name ) {
return $this->prefix . $name;
}
/**
* Gets the option for the given name. Returns the default value if the value does not exist.
*
* @since 3.0
* @author Remy Perona
*
* @param string $name Name of the option to get.
* @param mixed $default Default value to return if the value does not exist.
*
* @return mixed
*/
public function get( $name, $default = null ) {
$option = get_option( $this->get_option_name( $name ), $default );
if ( is_array( $default ) && ! is_array( $option ) ) {
$option = (array) $option;
}
return $option;
}
/**
* Sets the value of an option. Update the value if the option for the given name already exists.
*
* @since 3.0
* @author Remy Perona
* @param string $name Name of the option to set.
* @param mixed $value Value to set for the option.
*
* @return void
*/
public function set( $name, $value ) {
update_option( $this->get_option_name( $name ), $value );
}
/**
* Deletes the option with the given name.
*
* @since 3.0
* @author Remy Perona
*
* @param string $name Name of the option to delete.
*
* @return void
*/
public function delete( $name ) {
delete_option( $this->get_option_name( $name ) );
}
}