2024-06-20 14:10:42 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Class: Category
|
|
|
|
* The model for the Categorize SQL table.
|
|
|
|
*
|
|
|
|
* See Also:
|
|
|
|
* <Model>
|
|
|
|
*/
|
|
|
|
class Category extends Model {
|
|
|
|
/**
|
|
|
|
* Function: __construct
|
|
|
|
*
|
|
|
|
* See Also:
|
|
|
|
* <Model::grab>
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function __construct(
|
|
|
|
$category_id,
|
|
|
|
$options = array()
|
|
|
|
) {
|
2024-06-20 14:10:42 +00:00
|
|
|
$options["from"] = "categorize";
|
|
|
|
parent::grab($this, $category_id, $options);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: find
|
|
|
|
*
|
|
|
|
* See Also:
|
|
|
|
* <Model::search>
|
|
|
|
*/
|
|
|
|
public static function find(
|
|
|
|
$options = array(),
|
|
|
|
$options_for_object = array()
|
|
|
|
): array {
|
|
|
|
$options["from"] = "categorize";
|
|
|
|
return parent::search(
|
|
|
|
self::class,
|
|
|
|
$options,
|
|
|
|
$options_for_object
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: add
|
|
|
|
* Adds a category to the database.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* $name - The display name for this category.
|
|
|
|
* $clean - The unique slug for this category.
|
|
|
|
* $show_on_home - Show in the categories list?
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* The newly created <Category>.
|
|
|
|
*
|
|
|
|
* See Also:
|
|
|
|
* <update>
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function add(
|
|
|
|
$name,
|
|
|
|
$clean = null,
|
|
|
|
$show_on_home = true
|
|
|
|
): self {
|
2024-06-20 14:10:42 +00:00
|
|
|
$sql = SQL::current();
|
|
|
|
|
2025-01-13 09:56:01 +00:00
|
|
|
fallback($clean, self::check_clean(slug(8)));
|
|
|
|
fallback($show_on_home, true);
|
|
|
|
|
2024-06-20 14:10:42 +00:00
|
|
|
$sql->insert(
|
|
|
|
table:"categorize",
|
|
|
|
data:array(
|
2025-01-13 09:56:01 +00:00
|
|
|
"name" => sanitize_db_string($name, 128),
|
|
|
|
"clean" => sanitize_db_string($clean, 128),
|
2024-06-20 14:10:42 +00:00
|
|
|
"show_on_home" => $show_on_home
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$new = new self($sql->latest("categorize"));
|
|
|
|
Trigger::current()->call("add_category", $new);
|
|
|
|
return $new;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: update
|
|
|
|
* Updates a category with the given attributes.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* $name - The display name for this category.
|
|
|
|
* $clean - The unique slug for this category.
|
|
|
|
* $show_on_home - Show in the categories list?
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* The updated <Category>.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function update(
|
|
|
|
$name,
|
|
|
|
$clean = null,
|
|
|
|
$show_on_home = null
|
|
|
|
): self|false {
|
2024-06-20 14:10:42 +00:00
|
|
|
if ($this->no_results)
|
|
|
|
return false;
|
|
|
|
|
2025-01-13 09:56:01 +00:00
|
|
|
fallback($clean, $this->clean);
|
|
|
|
fallback($show_on_home, $this->show_on_home);
|
|
|
|
|
2024-06-20 14:10:42 +00:00
|
|
|
$new_values = array(
|
2025-01-13 09:56:01 +00:00
|
|
|
"name" => sanitize_db_string($name, 128),
|
|
|
|
"clean" => sanitize_db_string($clean, 128),
|
2024-06-20 14:10:42 +00:00
|
|
|
"show_on_home" => $show_on_home
|
|
|
|
);
|
|
|
|
|
|
|
|
SQL::current()->update(
|
|
|
|
table:"categorize",
|
|
|
|
conds:array("id" => $this->id),
|
|
|
|
data:$new_values
|
|
|
|
);
|
|
|
|
|
|
|
|
$category = new self(
|
|
|
|
null,
|
|
|
|
array(
|
|
|
|
"read_from" => array_merge(
|
|
|
|
$new_values,
|
|
|
|
array("id" => $this->id)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
Trigger::current()->call("update_category", $category, $this);
|
|
|
|
return $category;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: delete
|
|
|
|
* Deletes a category from the database.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function delete(
|
|
|
|
$category_id
|
|
|
|
): void {
|
2024-06-20 14:10:42 +00:00
|
|
|
$trigger = Trigger::current();
|
|
|
|
$sql = SQL::current();
|
|
|
|
|
|
|
|
if ($trigger->exists("delete_category")) {
|
|
|
|
$category = new self($category_id);
|
|
|
|
$trigger->call("delete_category", $category);
|
|
|
|
}
|
|
|
|
|
|
|
|
$sql->delete(
|
|
|
|
table:"categorize",
|
|
|
|
conds:array("id" => $category_id)
|
|
|
|
);
|
|
|
|
|
|
|
|
$sql->delete(
|
|
|
|
table:"post_attributes",
|
|
|
|
conds:array(
|
|
|
|
"name" => "category_id",
|
|
|
|
"value" => $category_id
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: deletable
|
|
|
|
* Checks if the <User> can delete the category.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function deletable(
|
|
|
|
$user = null
|
|
|
|
): bool {
|
2024-06-20 14:10:42 +00:00
|
|
|
if ($this->no_results)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
fallback($user, Visitor::current());
|
|
|
|
return $user->group->can("manage_categorize");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: editable
|
|
|
|
* Checks if the <User> can edit the category.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function editable(
|
|
|
|
$user = null
|
|
|
|
): bool {
|
2024-06-20 14:10:42 +00:00
|
|
|
if ($this->no_results)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
fallback($user, Visitor::current());
|
|
|
|
return $user->group->can("manage_categorize");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: check_clean
|
|
|
|
* Checks if a given slug is already being used as another category's slug.
|
|
|
|
*
|
|
|
|
* Parameters:
|
|
|
|
* $clean - The slug to check.
|
|
|
|
*
|
|
|
|
* Returns:
|
|
|
|
* The unique version of the slug.
|
|
|
|
* If it's not used, it's the same as $clean. If it is, a number is appended.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function check_clean(
|
|
|
|
$clean
|
|
|
|
): string {
|
2024-06-20 14:10:42 +00:00
|
|
|
if (empty($clean))
|
|
|
|
return $clean;
|
|
|
|
|
|
|
|
$count = 1;
|
|
|
|
$unique = substr($clean, 0, 128);
|
|
|
|
|
|
|
|
while (
|
|
|
|
SQL::current()->count(
|
|
|
|
tables:"categorize",
|
|
|
|
conds:array("clean" => $unique)
|
|
|
|
)
|
|
|
|
) {
|
2025-01-13 09:56:01 +00:00
|
|
|
$unique = mb_strcut(
|
|
|
|
$clean,
|
|
|
|
0,
|
|
|
|
(127 - strlen($count)),
|
|
|
|
"UTF-8"
|
|
|
|
).
|
|
|
|
"-".
|
|
|
|
$count;
|
2024-06-20 14:10:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return $unique;
|
|
|
|
}
|
|
|
|
|
2024-09-05 17:51:48 +00:00
|
|
|
/**
|
|
|
|
* Function: url
|
|
|
|
* Returns a category's URL.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function url(
|
|
|
|
): string|false {
|
2024-09-05 17:51:48 +00:00
|
|
|
if ($this->no_results)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
return url(
|
|
|
|
"category/".urlencode($this->clean),
|
|
|
|
MainController::current()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-06-20 14:10:42 +00:00
|
|
|
/**
|
|
|
|
* Function: install
|
|
|
|
* Creates the database table.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function install(
|
|
|
|
): void {
|
2024-06-20 14:10:42 +00:00
|
|
|
SQL::current()->create(
|
|
|
|
table:"categorize",
|
|
|
|
cols:array(
|
|
|
|
"id INTEGER PRIMARY KEY AUTO_INCREMENT",
|
|
|
|
"name VARCHAR(128) NOT NULL",
|
|
|
|
"clean VARCHAR(128) NOT NULL UNIQUE",
|
|
|
|
"show_on_home BOOLEAN DEFAULT '1'"
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function: uninstall
|
|
|
|
* Drops the database table.
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public static function uninstall(
|
|
|
|
): void {
|
2024-06-20 14:10:42 +00:00
|
|
|
$sql = SQL::current();
|
|
|
|
|
|
|
|
$sql->drop("categorize");
|
|
|
|
$sql->delete(
|
|
|
|
table:"post_attributes",
|
|
|
|
conds:array("name" => "category_id")
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|