don't force the user to set a rating

This commit is contained in:
Shish 2009-08-13 20:10:48 +01:00
parent d6b3da3461
commit afa1f4a583

View file

@ -10,6 +10,7 @@ class RatingSetEvent extends Event {
var $image, $user, $rating; var $image, $user, $rating;
public function RatingSetEvent(Image $image, User $user, $rating) { public function RatingSetEvent(Image $image, User $user, $rating) {
assert(in_array($rating, array("s", "q", "e", "u")));
$this->image = $image; $this->image = $image;
$this->user = $user; $this->user = $user;
$this->rating = $rating; $this->rating = $rating;
@ -58,7 +59,7 @@ class Ratings implements Extension {
} }
$config->set_default_string("ext_rating_anon_privs", 'squ'); $config->set_default_string("ext_rating_anon_privs", 'squ');
$config->set_default_string("ext_rating_user_privs", 'squ'); $config->set_default_string("ext_rating_user_privs", 'sqeu');
$config->set_default_string("ext_rating_admin_privs", 'sqeu'); $config->set_default_string("ext_rating_admin_privs", 'sqeu');
} }
@ -67,13 +68,13 @@ class Ratings implements Extension {
} }
if($event instanceof ImageInfoBoxBuildingEvent) { if($event instanceof ImageInfoBoxBuildingEvent) {
if($user->is_admin()) { if($this->can_rate()) {
$event->add_part($this->theme->get_rater_html($event->image->id, $event->image->rating), 80); $event->add_part($this->theme->get_rater_html($event->image->id, $event->image->rating), 80);
} }
} }
if($event instanceof ImageInfoSetEvent) { if($event instanceof ImageInfoSetEvent) {
if($user->is_admin()) { if($this->can_rate() && isset($_POST["rating"])) {
send_event(new RatingSetEvent($event->image, $user, $_POST['rating'])); send_event(new RatingSetEvent($event->image, $user, $_POST['rating']));
} }
} }
@ -133,6 +134,15 @@ class Ratings implements Extension {
} }
} }
// FIXME: this is a bit ugly and guessey, should have proper options
private function can_rate() {
global $config, $user;
if($user->is_anonymous() && $config->get_string("ext_rating_anon_privs") == "sqeu") return false;
if($user->is_admin()) return true;
if(!$user->is_anonymous() && $config->get_string("ext_rating_user_privs") == "sqeu") return true;
return false;
}
private function no_rating_query($context) { private function no_rating_query($context) {
foreach($context as $term) { foreach($context as $term) {
if(preg_match("/^rating=/", $term)) { if(preg_match("/^rating=/", $term)) {