You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
3.8 KiB
155 lines
3.8 KiB
<?php |
|
/** |
|
* Yoast SEO Plugin File. |
|
* |
|
* @package WPSEO\Migrations |
|
*/ |
|
|
|
use Yoast\WP\Free\ORM\Yoast_Model; |
|
use YoastSEO_Vendor\Ruckusing_Migration_Base; |
|
|
|
/** |
|
* Indexable migration. |
|
*/ |
|
class WpYoastIndexable extends Ruckusing_Migration_Base { |
|
|
|
/** |
|
* Migration up. |
|
*/ |
|
public function up() { |
|
$table_name = $this->get_table_name(); |
|
|
|
$indexable_table = $this->create_table( $table_name ); |
|
|
|
$indexable_table->column( 'permalink', 'string', array( 'null' => true, 'limit' => 191 ) ); |
|
|
|
$indexable_table->column( 'object_id', 'integer', array( 'unsigned' => true, 'null' => true, 'limit' => 11 ) ); |
|
$indexable_table->column( 'object_type', 'string', array( 'limit' => 16 ) ); |
|
$indexable_table->column( 'object_sub_type', 'string', array( 'null' => true, 'limit' => 100 ) ); |
|
|
|
$indexable_table->column( |
|
'number_of_pages', |
|
'integer', |
|
array( |
|
'unsigned' => true, |
|
'null' => true, |
|
'default' => null, |
|
'limit' => 11, |
|
) |
|
); |
|
|
|
$indexable_table->column( 'canonical', 'string', array( 'null' => true, 'limit' => 191 ) ); |
|
|
|
$indexable_table->column( 'title', 'string', array( 'null' => true, 'limit' => 191 ) ); |
|
$indexable_table->column( 'description', 'text', array( 'null' => true ) ); |
|
$indexable_table->column( 'breadcrumb_title', 'string', array( 'null' => true, 'limit' => 191 ) ); |
|
|
|
$indexable_table->column( 'is_robots_noindex', 'boolean', array( 'null' => true, 'default' => false ) ); |
|
$indexable_table->column( 'is_robots_nofollow', 'boolean', array( 'null' => true, 'default' => false ) ); |
|
$indexable_table->column( 'is_robots_noarchive', 'boolean', array( 'null' => true, 'default' => false ) ); |
|
$indexable_table->column( 'is_robots_noimageindex', 'boolean', array( 'null' => true, 'default' => false ) ); |
|
$indexable_table->column( 'is_robots_nosnippet', 'boolean', array( 'null' => true, 'default' => false ) ); |
|
|
|
$indexable_table->column( 'primary_focus_keyword', 'string', array( 'null' => true, 'limit' => 191 ) ); |
|
$indexable_table->column( 'primary_focus_keyword_score', 'integer', array( 'null' => true, 'limit' => 3 ) ); |
|
|
|
$indexable_table->column( 'readability_score', 'integer', array( 'null' => true, 'limit' => 3 ) ); |
|
|
|
$indexable_table->column( 'is_cornerstone', 'boolean', array( 'default' => false ) ); |
|
|
|
$indexable_table->column( 'link_count', 'integer', array( 'null' => true, 'limit' => 11 ) ); |
|
$indexable_table->column( 'incoming_link_count', 'integer', array( 'null' => true, 'limit' => 11 ) ); |
|
|
|
// Exexcute the SQL to create the table. |
|
$indexable_table->finish(); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'permalink', |
|
), |
|
array( |
|
'name' => 'unique_permalink', |
|
'unique' => true, |
|
) |
|
); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'object_type', |
|
'object_sub_type', |
|
), |
|
array( |
|
'name' => 'indexable', |
|
) |
|
); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'primary_focus_keyword_score', |
|
'object_type', |
|
'object_sub_type', |
|
), |
|
array( |
|
'name' => 'primary_focus_keyword_score', |
|
) |
|
); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'is_cornerstone', |
|
'object_type', |
|
'object_sub_type', |
|
), |
|
array( |
|
'name' => 'cornerstones', |
|
) |
|
); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'incoming_link_count', |
|
'object_type', |
|
'object_sub_type', |
|
), |
|
array( |
|
'name' => 'orphaned_content', |
|
) |
|
); |
|
|
|
$this->add_index( |
|
$table_name, |
|
array( |
|
'is_robots_noindex', |
|
'object_id', |
|
'object_type', |
|
'object_sub_type', |
|
), |
|
array( |
|
'name' => 'robots_noindex', |
|
) |
|
); |
|
|
|
$this->add_timestamps( $table_name ); |
|
} |
|
|
|
/** |
|
* Migration down. |
|
*/ |
|
public function down() { |
|
$this->drop_table( $this->get_table_name() ); |
|
} |
|
|
|
/** |
|
* Retrieves the table name to use. |
|
* |
|
* @return string The table name to use. |
|
*/ |
|
protected function get_table_name() { |
|
return Yoast_Model::get_table_name( 'Indexable' ); |
|
} |
|
}
|
|
|