Implemented new enums
This commit is contained in:
parent
977989ffed
commit
d3beb8bc53
32 changed files with 290 additions and 131 deletions
|
@ -40,24 +40,22 @@ class Access
|
|||
$user = Auth::getCurrentUser();
|
||||
$minAccessRank = AccessRank::Nobody;
|
||||
|
||||
$key = TextCaseConverter::convert(Privilege::toString($privilege->primary),
|
||||
$key = TextCaseConverter::convert($privilege->toString(),
|
||||
TextCaseConverter::CAMEL_CASE,
|
||||
TextCaseConverter::SPINAL_CASE);
|
||||
|
||||
if (isset(self::$privileges[$key]))
|
||||
{
|
||||
$minAccessRank = self::$privileges[$key];
|
||||
}
|
||||
if ($privilege->secondary != null)
|
||||
{
|
||||
$key2 = $key . '.' . strtolower($privilege->secondary);
|
||||
if (isset(self::$privileges[$key2]))
|
||||
{
|
||||
$minAccessRank = self::$privileges[$key2];
|
||||
}
|
||||
}
|
||||
$privilege->secondary = null;
|
||||
$key2 = TextCaseConverter::convert($privilege->toString(),
|
||||
TextCaseConverter::CAMEL_CASE,
|
||||
TextCaseConverter::SPINAL_CASE);
|
||||
|
||||
return intval($user->accessRank) >= $minAccessRank;
|
||||
|
||||
if (isset(self::$privileges[$key]))
|
||||
$minAccessRank = self::$privileges[$key];
|
||||
elseif (isset(self::$privileges[$key2]))
|
||||
$minAccessRank = self::$privileges[$key2];
|
||||
|
||||
return $user->getAccessRank()->toInteger() >= $minAccessRank;
|
||||
}
|
||||
|
||||
public static function assertAuthentication()
|
||||
|
@ -98,7 +96,7 @@ class Access
|
|||
|
||||
return array_filter(PostSafety::getAll(), function($safety)
|
||||
{
|
||||
return Access::check(new Privilege(Privilege::ListPosts, PostSafety::toString($safety)))
|
||||
return Access::check(new Privilege(Privilege::ListPosts, $safety->toString()))
|
||||
and Auth::getCurrentUser()->hasEnabledSafety($safety);
|
||||
});
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@ class AddPostJob extends AbstractJob
|
|||
//- move this to PostEntity::isValid()
|
||||
//- create IValidatable interface
|
||||
//- enforce entity validity upon calling save() in models
|
||||
if (empty($post->type))
|
||||
if (empty($post->getType()))
|
||||
throw new SimpleException('No post type detected; upload faled');
|
||||
|
||||
//save to db
|
||||
|
@ -43,7 +43,7 @@ class AddPostJob extends AbstractJob
|
|||
: TextHelper::reprUser(Auth::getCurrentUser()),
|
||||
'post' => TextHelper::reprPost($post),
|
||||
'tags' => TextHelper::reprTags($post->getTags()),
|
||||
'safety' => PostSafety::toString($post->safety),
|
||||
'safety' => $post->getSafety()->toString(),
|
||||
'source' => $post->source]);
|
||||
|
||||
//finish
|
||||
|
|
|
@ -6,9 +6,9 @@ class EditPostSafetyJob extends AbstractPostEditJob
|
|||
public function execute()
|
||||
{
|
||||
$post = $this->post;
|
||||
$newSafety = $this->getArgument(self::SAFETY);
|
||||
$newSafety = new PostSafety($this->getArgument(self::SAFETY));
|
||||
|
||||
$oldSafety = $post->safety;
|
||||
$oldSafety = $post->getSafety();
|
||||
$post->setSafety($newSafety);
|
||||
|
||||
if (!$this->skipSaving)
|
||||
|
@ -19,7 +19,7 @@ class EditPostSafetyJob extends AbstractPostEditJob
|
|||
LogHelper::log('{user} changed safety of {post} to {safety}', [
|
||||
'user' => TextHelper::reprUser(Auth::getCurrentUser()),
|
||||
'post' => TextHelper::reprPost($post),
|
||||
'safety' => PostSafety::toString($post->safety)]);
|
||||
'safety' => $post->getSafety()->toString()]);
|
||||
}
|
||||
|
||||
return $post;
|
||||
|
|
|
@ -6,13 +6,13 @@ class EditUserAccessRankJob extends AbstractUserEditJob
|
|||
public function execute()
|
||||
{
|
||||
$user = $this->user;
|
||||
$newAccessRank = UserModel::validateAccessRank($this->getArgument(self::NEW_ACCESS_RANK));
|
||||
$newAccessRank = new AccessRank($this->getArgument(self::NEW_ACCESS_RANK));
|
||||
|
||||
$oldAccessRank = $user->accessRank;
|
||||
$oldAccessRank = $user->getAccessRank();
|
||||
if ($oldAccessRank == $newAccessRank)
|
||||
return $user;
|
||||
|
||||
$user->accessRank = $newAccessRank;
|
||||
$user->setAccessRank($newAccessRank);
|
||||
|
||||
if (!$this->skipSaving)
|
||||
UserModel::save($user);
|
||||
|
@ -20,7 +20,7 @@ class EditUserAccessRankJob extends AbstractUserEditJob
|
|||
LogHelper::log('{user} changed {subject}\'s access rank to {rank}', [
|
||||
'user' => TextHelper::reprUser(Auth::getCurrentUser()),
|
||||
'subject' => TextHelper::reprUser($user),
|
||||
'rank' => AccessRank::toString($newAccessRank)]);
|
||||
'rank' => $newAccessRank->toString()]);
|
||||
|
||||
return $user;
|
||||
}
|
||||
|
|
|
@ -38,7 +38,7 @@ class GetPostContentJob extends AbstractJob
|
|||
if ($post->hidden)
|
||||
$privileges []= new Privilege(Privilege::ViewPost, 'hidden');
|
||||
|
||||
$privileges []= new Privilege(Privilege::ViewPost, PostSafety::toString($post->safety));
|
||||
$privileges []= new Privilege(Privilege::ViewPost, $post->getSafety()->toString());
|
||||
|
||||
return $privileges;
|
||||
}
|
||||
|
|
|
@ -18,7 +18,7 @@ class GetPostJob extends AbstractPostJob
|
|||
if ($post->hidden)
|
||||
$privileges []= new Privilege(Privilege::ViewPost, 'hidden');
|
||||
|
||||
$privileges []= new Privilege(Privilege::ViewPost, PostSafety::toString($post->safety));
|
||||
$privileges []= new Privilege(Privilege::ViewPost, $post->getSafety()->toString());
|
||||
|
||||
return $privileges;
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@ class GetPostThumbJob extends AbstractJob
|
|||
|
||||
if ($post->hidden)
|
||||
Access::assert(new Privilege(Privilege::ListPosts, 'hidden'));
|
||||
Access::assert(new Privilege(Privilege::ListPosts, PostSafety::toString($post->safety)));
|
||||
Access::assert(new Privilege(Privilege::ListPosts, $post->getSafety()->toString()));
|
||||
|
||||
$post->generateThumb($width, $height);
|
||||
|
||||
|
|
|
@ -70,7 +70,7 @@ class Auth
|
|||
}
|
||||
else
|
||||
{
|
||||
$_SESSION['logged-in'] = $user->accessRank != AccessRank::Anonymous;
|
||||
$_SESSION['logged-in'] = $user->getAccessRank()->toInteger() != AccessRank::Anonymous;
|
||||
$_SESSION['user'] = serialize($user);
|
||||
}
|
||||
}
|
||||
|
@ -87,7 +87,7 @@ class Auth
|
|||
$dummy = UserModel::spawn();
|
||||
$dummy->id = null;
|
||||
$dummy->name = UserModel::getAnonymousName();
|
||||
$dummy->accessRank = AccessRank::Anonymous;
|
||||
$dummy->setAccessRank(new AccessRank(AccessRank::Anonymous));
|
||||
return $dummy;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -81,7 +81,7 @@ class UserController
|
|||
$user->enablePostTagTitles(InputHelper::get('post-tag-titles'));
|
||||
$user->enableHidingDislikedPosts(InputHelper::get('hide-disliked-posts'));
|
||||
|
||||
if ($user->accessRank != AccessRank::Anonymous)
|
||||
if ($user->getAccessRank()->toInteger() != AccessRank::Anonymous)
|
||||
UserModel::save($user);
|
||||
if ($user->id == Auth::getCurrentUser()->id)
|
||||
Auth::setCurrentUser($user);
|
||||
|
@ -168,12 +168,12 @@ class UserController
|
|||
Privilege::ChangeUserSettings,
|
||||
Access::getIdentity($user)));
|
||||
|
||||
if (!in_array($safety, PostSafety::getAll()))
|
||||
throw new SimpleExcetpion('Invalid safety');
|
||||
$safety = new PostSafety($safety);
|
||||
$safety->validate();
|
||||
|
||||
$user->enableSafety($safety, !$user->hasEnabledSafety($safety));
|
||||
|
||||
if ($user->accessRank != AccessRank::Anonymous)
|
||||
if ($user->getAccessRank()->toInteger() != AccessRank::Anonymous)
|
||||
UserModel::save($user);
|
||||
Auth::setCurrentUser($user);
|
||||
}
|
||||
|
|
12
src/Enum.php
12
src/Enum.php
|
@ -1,21 +1,23 @@
|
|||
<?php
|
||||
class Enum
|
||||
abstract class Enum
|
||||
{
|
||||
public static function toString($constant)
|
||||
public abstract function toString();
|
||||
|
||||
public function _toString($constant)
|
||||
{
|
||||
$cls = new ReflectionClass(get_called_class());
|
||||
$constants = $cls->getConstants();
|
||||
return array_search($constant, $constants);
|
||||
}
|
||||
|
||||
public static function toDisplayString($constant)
|
||||
public function toDisplayString()
|
||||
{
|
||||
return TextCaseConverter::convert(static::toString($constant),
|
||||
return TextCaseConverter::convert($this->toString(),
|
||||
TextCaseConverter::SNAKE_CASE,
|
||||
TextCaseConverter::BLANK_CASE);
|
||||
}
|
||||
|
||||
public static function getAll()
|
||||
public static function getAllConstants()
|
||||
{
|
||||
$cls = new ReflectionClass(get_called_class());
|
||||
$constants = $cls->getConstants();
|
||||
|
|
5
src/IValidatable.php
Normal file
5
src/IValidatable.php
Normal file
|
@ -0,0 +1,5 @@
|
|||
<?php
|
||||
interface IValidatable
|
||||
{
|
||||
function validate();
|
||||
}
|
|
@ -88,7 +88,16 @@ abstract class AbstractCrudModel implements IModel
|
|||
TextCaseConverter::LOWER_CAMEL_CASE);
|
||||
}
|
||||
|
||||
$entity->$key = $val;
|
||||
if (property_exists($entity, $key))
|
||||
{
|
||||
$reflectionProperty = new ReflectionProperty(get_class($entity), $key);
|
||||
$reflectionProperty->setAccessible(true);
|
||||
$reflectionProperty->setValue($entity, $val);
|
||||
}
|
||||
else
|
||||
{
|
||||
$entity->$key = $val;
|
||||
}
|
||||
}
|
||||
return $entity;
|
||||
}
|
||||
|
|
|
@ -4,22 +4,22 @@ use \Chibi\Database as Database;
|
|||
|
||||
class PostEntity extends AbstractEntity
|
||||
{
|
||||
public $type;
|
||||
protected $type;
|
||||
public $name;
|
||||
public $origName;
|
||||
public $fileHash;
|
||||
public $fileSize;
|
||||
public $mimeType;
|
||||
public $safety;
|
||||
protected $safety;
|
||||
public $hidden;
|
||||
public $uploadDate;
|
||||
public $imageWidth;
|
||||
public $imageHeight;
|
||||
public $uploaderId;
|
||||
public $source;
|
||||
public $commentCount;
|
||||
public $favCount;
|
||||
public $score;
|
||||
public $commentCount = 0;
|
||||
public $favCount = 0;
|
||||
public $score = 0;
|
||||
|
||||
public function getUploader()
|
||||
{
|
||||
|
@ -173,9 +173,26 @@ class PostEntity extends AbstractEntity
|
|||
$this->hidden = boolval($hidden);
|
||||
}
|
||||
|
||||
public function setSafety($safety)
|
||||
public function getType()
|
||||
{
|
||||
$this->safety = PostModel::validateSafety($safety);
|
||||
return $this->type;
|
||||
}
|
||||
|
||||
public function setType(PostType $type)
|
||||
{
|
||||
$type->validate();
|
||||
$this->type = $type;
|
||||
}
|
||||
|
||||
public function getSafety()
|
||||
{
|
||||
return $this->safety;
|
||||
}
|
||||
|
||||
public function setSafety(PostSafety $safety)
|
||||
{
|
||||
$safety->validate();
|
||||
$this->safety = $safety;
|
||||
}
|
||||
|
||||
public function setSource($source)
|
||||
|
@ -233,7 +250,7 @@ class PostEntity extends AbstractEntity
|
|||
$srcPath = $this->getFullPath();
|
||||
$dstPath = $this->getThumbDefaultPath($width, $height);
|
||||
|
||||
if ($this->type == PostType::Youtube)
|
||||
if ($this->getType()->toInteger() == PostType::Youtube)
|
||||
{
|
||||
return ThumbnailHelper::generateFromUrl(
|
||||
'http://img.youtube.com/vi/' . $this->fileHash . '/mqdefault.jpg',
|
||||
|
@ -263,13 +280,13 @@ class PostEntity extends AbstractEntity
|
|||
case 'image/png':
|
||||
case 'image/jpeg':
|
||||
list ($imageWidth, $imageHeight) = getimagesize($srcPath);
|
||||
$this->type = PostType::Image;
|
||||
$this->setType(new PostType(PostType::Image));
|
||||
$this->imageWidth = $imageWidth;
|
||||
$this->imageHeight = $imageHeight;
|
||||
break;
|
||||
case 'application/x-shockwave-flash':
|
||||
list ($imageWidth, $imageHeight) = getimagesize($srcPath);
|
||||
$this->type = PostType::Flash;
|
||||
$this->setType(new PostType(PostType::Flash));
|
||||
$this->imageWidth = $imageWidth;
|
||||
$this->imageHeight = $imageHeight;
|
||||
break;
|
||||
|
@ -280,7 +297,7 @@ class PostEntity extends AbstractEntity
|
|||
case 'video/x-flv':
|
||||
case 'video/3gpp':
|
||||
list ($imageWidth, $imageHeight) = getimagesize($srcPath);
|
||||
$this->type = PostType::Video;
|
||||
$this->setType(new PostType(PostType::Video));
|
||||
$this->imageWidth = $imageWidth;
|
||||
$this->imageHeight = $imageHeight;
|
||||
break;
|
||||
|
@ -315,7 +332,7 @@ class PostEntity extends AbstractEntity
|
|||
if (preg_match('/youtube.com\/watch.*?=([a-zA-Z0-9_-]+)/', $srcUrl, $matches))
|
||||
{
|
||||
$youtubeId = $matches[1];
|
||||
$this->type = PostType::Youtube;
|
||||
$this->setType(new PostType(PostType::Youtube));
|
||||
$this->mimeType = null;
|
||||
$this->fileSize = null;
|
||||
$this->fileHash = $youtubeId;
|
||||
|
@ -360,7 +377,7 @@ class PostEntity extends AbstractEntity
|
|||
$x []= TextHelper::reprTag($tag->name);
|
||||
foreach ($this->getRelations() as $relatedPost)
|
||||
$x []= TextHelper::reprPost($relatedPost);
|
||||
$x []= $this->safety;
|
||||
$x []= $this->getSafety()->toInteger();
|
||||
$x []= $this->source;
|
||||
$x []= $this->fileHash;
|
||||
natcasesort($x);
|
||||
|
|
|
@ -12,10 +12,21 @@ class UserEntity extends AbstractEntity
|
|||
public $emailConfirmed;
|
||||
public $joinDate;
|
||||
public $lastLoginDate;
|
||||
public $accessRank;
|
||||
protected $accessRank;
|
||||
public $settings;
|
||||
public $banned;
|
||||
|
||||
public function getAccessRank()
|
||||
{
|
||||
return $this->accessRank;
|
||||
}
|
||||
|
||||
public function setAccessRank(AccessRank $accessRank)
|
||||
{
|
||||
$accessRank->validate();
|
||||
$this->accessRank = $accessRank;
|
||||
}
|
||||
|
||||
public function getAvatarUrl($size = 32)
|
||||
{
|
||||
$subject = !empty($this->emailConfirmed)
|
||||
|
@ -44,32 +55,31 @@ class UserEntity extends AbstractEntity
|
|||
$this->settings = $settings;
|
||||
}
|
||||
|
||||
public function hasEnabledSafety($safety)
|
||||
public function hasEnabledSafety(PostSafety $safety)
|
||||
{
|
||||
$all = $this->getSetting(UserModel::SETTING_SAFETY);
|
||||
if (!$all)
|
||||
return $safety == PostSafety::Safe;
|
||||
return $all & PostSafety::toFlag($safety);
|
||||
return $safety->toInteger() == PostSafety::Safe;
|
||||
return $all & $safety->toFlag();
|
||||
}
|
||||
|
||||
public function enableSafety($safety, $enabled)
|
||||
public function enableSafety(PostSafety $safety, $enabled)
|
||||
{
|
||||
$all = $this->getSetting(UserModel::SETTING_SAFETY);
|
||||
if (!$all)
|
||||
$all = PostSafety::toFlag(PostSafety::Safe);
|
||||
|
||||
$new = $all;
|
||||
if (!$enabled)
|
||||
{
|
||||
$new &= ~PostSafety::toFlag($safety);
|
||||
if (!$new)
|
||||
$new = PostSafety::toFlag(PostSafety::Safe);
|
||||
$new &= ~$safety->toFlag();
|
||||
}
|
||||
else
|
||||
{
|
||||
$new |= PostSafety::toFlag($safety);
|
||||
$new |= $safety->toFlag();
|
||||
}
|
||||
|
||||
if (!$new)
|
||||
$new = (new PostSafety(PostSafety::Safe))->toFlag();
|
||||
|
||||
$this->setSetting(UserModel::SETTING_SAFETY, $new);
|
||||
}
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
class AccessRank extends Enum
|
||||
class AccessRank extends Enum implements IValidatable
|
||||
{
|
||||
const Anonymous = 0;
|
||||
const Registered = 1;
|
||||
|
@ -7,4 +7,35 @@ class AccessRank extends Enum
|
|||
const Moderator = 3;
|
||||
const Admin = 4;
|
||||
const Nobody = 5;
|
||||
|
||||
protected $accessRank;
|
||||
|
||||
public function __construct($accessRank)
|
||||
{
|
||||
$this->accessRank = $accessRank;
|
||||
}
|
||||
|
||||
public function toInteger()
|
||||
{
|
||||
return $this->accessRank;
|
||||
}
|
||||
|
||||
public function toString()
|
||||
{
|
||||
return self::_toString($this->accessRank);
|
||||
}
|
||||
|
||||
public static function getAll()
|
||||
{
|
||||
return array_map(function($constantName)
|
||||
{
|
||||
return new self($constantName);
|
||||
}, self::getAllConstants());
|
||||
}
|
||||
|
||||
public function validate()
|
||||
{
|
||||
if (!in_array($this->accessRank, self::getAllConstants()))
|
||||
throw new SimpleException('Invalid access rank "%s"', $this->accessRank);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,12 +1,43 @@
|
|||
<?php
|
||||
class PostSafety extends Enum
|
||||
class PostSafety extends Enum implements IValidatable
|
||||
{
|
||||
const Safe = 1;
|
||||
const Sketchy = 2;
|
||||
const Unsafe = 3;
|
||||
|
||||
public static function toFlag($safety)
|
||||
protected $safety;
|
||||
|
||||
public function __construct($safety)
|
||||
{
|
||||
return pow(2, $safety);
|
||||
$this->safety = $safety;
|
||||
}
|
||||
|
||||
public function toInteger()
|
||||
{
|
||||
return $this->safety;
|
||||
}
|
||||
|
||||
public function toFlag()
|
||||
{
|
||||
return pow(2, $this->safety);
|
||||
}
|
||||
|
||||
public function toString()
|
||||
{
|
||||
return self::_toString($this->safety);
|
||||
}
|
||||
|
||||
public static function getAll()
|
||||
{
|
||||
return array_map(function($constantName)
|
||||
{
|
||||
return new self($constantName);
|
||||
}, self::getAllConstants());
|
||||
}
|
||||
|
||||
public function validate()
|
||||
{
|
||||
if (!in_array($this->safety, self::getAllConstants()))
|
||||
throw new SimpleException('Invalid safety type "%s"', $this->safety);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,8 +1,31 @@
|
|||
<?php
|
||||
class PostType extends Enum
|
||||
class PostType extends Enum implements IValidatable
|
||||
{
|
||||
const Image = 1;
|
||||
const Flash = 2;
|
||||
const Youtube = 3;
|
||||
const Video = 4;
|
||||
|
||||
protected $type;
|
||||
|
||||
public function __construct($type)
|
||||
{
|
||||
$this->type = $type;
|
||||
}
|
||||
|
||||
public function toInteger()
|
||||
{
|
||||
return $this->type;
|
||||
}
|
||||
|
||||
public function toString()
|
||||
{
|
||||
return self::_toString($this->type);
|
||||
}
|
||||
|
||||
public function validate()
|
||||
{
|
||||
if (!in_array($this->type, self::getAllConstants()))
|
||||
throw new SimpleException('Invalid post type "%s"', $this->type);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -51,6 +51,14 @@ class Privilege extends Enum
|
|||
public function __construct($primary, $secondary = null)
|
||||
{
|
||||
$this->primary = $primary;
|
||||
$this->secondary = $secondary;
|
||||
$this->secondary = strtolower($secondary);
|
||||
}
|
||||
|
||||
public function toString()
|
||||
{
|
||||
$string = self::_toString($this->primary);
|
||||
if ($this->secondary)
|
||||
$string .= '.' . $this->secondary;
|
||||
return $string;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,23 +6,33 @@ class PostModel extends AbstractCrudModel
|
|||
{
|
||||
protected static $config;
|
||||
|
||||
public static function getTableName()
|
||||
{
|
||||
return 'post';
|
||||
}
|
||||
|
||||
public static function init()
|
||||
{
|
||||
self::$config = getConfig();
|
||||
}
|
||||
|
||||
public static function getTableName()
|
||||
{
|
||||
return 'post';
|
||||
}
|
||||
|
||||
public static function convertRow($row)
|
||||
{
|
||||
$entity = parent::convertRow($row);
|
||||
|
||||
if (isset($row['type']))
|
||||
$entity->setType(new PostType($row['type']));
|
||||
|
||||
if (isset($row['safety']))
|
||||
$entity->setSafety(new PostSafety($row['safety']));
|
||||
|
||||
return $entity;
|
||||
}
|
||||
|
||||
public static function spawn()
|
||||
{
|
||||
$post = new PostEntity;
|
||||
$post->score = 0;
|
||||
$post->favCount = 0;
|
||||
$post->commentCount = 0;
|
||||
$post->safety = PostSafety::Safe;
|
||||
$post->setSafety(new PostSafety(PostSafety::Safe));
|
||||
$post->hidden = false;
|
||||
$post->uploadDate = time();
|
||||
do
|
||||
|
@ -40,13 +50,13 @@ class PostModel extends AbstractCrudModel
|
|||
self::forgeId($post);
|
||||
|
||||
$bindings = [
|
||||
'type' => $post->type,
|
||||
'type' => $post->getType()->toInteger(),
|
||||
'name' => $post->name,
|
||||
'orig_name' => $post->origName,
|
||||
'file_hash' => $post->fileHash,
|
||||
'file_size' => $post->fileSize,
|
||||
'mime_type' => $post->mimeType,
|
||||
'safety' => $post->safety,
|
||||
'safety' => $post->getSafety()->toInteger(),
|
||||
'hidden' => $post->hidden,
|
||||
'upload_date' => $post->uploadDate,
|
||||
'image_width' => $post->imageWidth,
|
||||
|
@ -266,16 +276,6 @@ class PostModel extends AbstractCrudModel
|
|||
|
||||
|
||||
|
||||
public static function validateSafety($safety)
|
||||
{
|
||||
$safety = intval($safety);
|
||||
|
||||
if (!in_array($safety, PostSafety::getAll()))
|
||||
throw new SimpleException('Invalid safety type "%s"', $safety);
|
||||
|
||||
return $safety;
|
||||
}
|
||||
|
||||
public static function validateSource($source)
|
||||
{
|
||||
$source = trim($source);
|
||||
|
|
|
@ -8,7 +8,12 @@ class CommentSearchParser extends AbstractSearchParser
|
|||
$this->statement->addInnerJoin('post', new Sql\EqualsFunctor('post_id', 'post.id'));
|
||||
$crit = new Sql\ConjunctionFunctor();
|
||||
|
||||
$allowedSafety = Access::getAllowedSafety();
|
||||
$allowedSafety = array_map(
|
||||
function($safety)
|
||||
{
|
||||
return $safety->toInteger();
|
||||
},
|
||||
Access::getAllowedSafety());
|
||||
$crit->add(Sql\InFunctor::fromArray('post.safety', Sql\Binding::fromArray($allowedSafety)));
|
||||
|
||||
if (!Access::check(new Privilege(Privilege::ListPosts, 'hidden')))
|
||||
|
|
|
@ -14,8 +14,13 @@ class PostSearchParser extends AbstractSearchParser
|
|||
$this->tags = [];
|
||||
$crit = new Sql\ConjunctionFunctor();
|
||||
|
||||
$allowedSafety = Access::getAllowedSafety();
|
||||
$crit->add(Sql\InFunctor::fromArray('safety', Sql\Binding::fromArray($allowedSafety)));
|
||||
$allowedSafety = array_map(
|
||||
function($safety)
|
||||
{
|
||||
return $safety->toInteger();
|
||||
},
|
||||
Access::getAllowedSafety());
|
||||
$crit->add(Sql\InFunctor::fromArray('post.safety', Sql\Binding::fromArray($allowedSafety)));
|
||||
|
||||
$this->statement->setCriterion($crit);
|
||||
if (count($tokens) > $config->browsing->maxSearchTokens)
|
||||
|
|
|
@ -5,7 +5,12 @@ class TagSearchParser extends AbstractSearchParser
|
|||
{
|
||||
protected function processSetup(&$tokens)
|
||||
{
|
||||
$allowedSafety = Access::getAllowedSafety();
|
||||
$allowedSafety = array_map(
|
||||
function($safety)
|
||||
{
|
||||
return $safety->toInteger();
|
||||
},
|
||||
Access::getAllowedSafety());
|
||||
$this->statement
|
||||
->addInnerJoin('post_tag', new Sql\EqualsFunctor('tag.id', 'post_tag.tag_id'))
|
||||
->addInnerJoin('post', new Sql\EqualsFunctor('post.id', 'post_tag.post_id'))
|
||||
|
|
|
@ -14,17 +14,29 @@ class UserModel extends AbstractCrudModel
|
|||
return 'user';
|
||||
}
|
||||
|
||||
public static function convertRow($row)
|
||||
{
|
||||
$entity = parent::convertRow($row);
|
||||
|
||||
if (isset($row['access_rank']))
|
||||
$entity->setAccessRank(new AccessRank($row['access_rank']));
|
||||
|
||||
return $entity;
|
||||
}
|
||||
|
||||
public static function spawn()
|
||||
{
|
||||
$user = new UserEntity();
|
||||
$user->setAccessRank(new AccessRank(AccessRank::Anonymous));
|
||||
$user->passSalt = md5(mt_rand() . uniqid());
|
||||
return $user;
|
||||
}
|
||||
|
||||
public static function save($user)
|
||||
{
|
||||
if ($user->accessRank == AccessRank::Anonymous)
|
||||
if ($user->getAccessRank()->toInteger() == AccessRank::Anonymous)
|
||||
throw new Exception('Trying to save anonymous user into database');
|
||||
|
||||
Database::transaction(function() use ($user)
|
||||
{
|
||||
self::forgeId($user);
|
||||
|
@ -38,7 +50,7 @@ class UserModel extends AbstractCrudModel
|
|||
'email_confirmed' => $user->emailConfirmed,
|
||||
'join_date' => $user->joinDate,
|
||||
'last_login_date' => $user->lastLoginDate,
|
||||
'access_rank' => $user->accessRank,
|
||||
'access_rank' => $user->getAccessRank()->toInteger(),
|
||||
'settings' => $user->settings,
|
||||
'banned' => $user->banned
|
||||
];
|
||||
|
@ -234,15 +246,12 @@ class UserModel extends AbstractCrudModel
|
|||
return $email;
|
||||
}
|
||||
|
||||
public static function validateAccessRank($accessRank)
|
||||
public static function validateAccessRank(AccessRank $accessRank)
|
||||
{
|
||||
$accessRank = intval($accessRank);
|
||||
$accessRank->validate();
|
||||
|
||||
if (!in_array($accessRank, AccessRank::getAll()))
|
||||
throw new SimpleException('Invalid access rank type "%s"', $accessRank);
|
||||
|
||||
if ($accessRank == AccessRank::Nobody)
|
||||
throw new SimpleException('Cannot set special accesss rank "%s"', $accessRank);
|
||||
if ($accessRank->toInteger() == AccessRank::Nobody)
|
||||
throw new SimpleException('Cannot set special access rank "%s"', $accessRank->toString());
|
||||
|
||||
return $accessRank;
|
||||
}
|
||||
|
|
|
@ -23,11 +23,11 @@
|
|||
<label>
|
||||
<input type="radio"
|
||||
name="safety"
|
||||
<?php if ($this->context->transport->post->safety == $safety): ?>
|
||||
<?php if ($this->context->transport->post->getSafety() == $safety): ?>
|
||||
checked="checked"
|
||||
<?php endif ?>
|
||||
value="<?= $safety ?>"/>
|
||||
<?= ucfirst(PostSafety::toDisplayString($safety)) ?>
|
||||
value="<?= $safety->toInteger() ?>"/>
|
||||
<?= ucfirst($safety->toDisplayString()) ?>
|
||||
</label>
|
||||
<?php endforeach ?>
|
||||
</div>
|
||||
|
|
|
@ -5,7 +5,7 @@ Assets::setPageThumb(\Chibi\Router::linkTo(
|
|||
$post = $this->context->transport->post;
|
||||
?>
|
||||
|
||||
<?php if ($post->type == PostType::Image): ?>
|
||||
<?php if ($post->getType()->toInteger() == PostType::Image): ?>
|
||||
|
||||
<?php if (!empty($this->context->imageLink)): ?>
|
||||
<a href="<?= $this->context->imageLink ?>">
|
||||
|
@ -20,7 +20,7 @@ $post = $this->context->transport->post;
|
|||
</a>
|
||||
<?php endif ?>
|
||||
|
||||
<?php elseif ($post->type == PostType::Flash): ?>
|
||||
<?php elseif ($post->getType()->toInteger() == PostType::Flash): ?>
|
||||
|
||||
<object
|
||||
type="<?= $post->mimeType ?>"
|
||||
|
@ -37,7 +37,7 @@ $post = $this->context->transport->post;
|
|||
|
||||
</object>
|
||||
|
||||
<?php elseif ($post->type == PostType::Youtube): ?>
|
||||
<?php elseif ($post->getType()->toInteger() == PostType::Youtube): ?>
|
||||
|
||||
<iframe
|
||||
style="width: 800px; height: 600px; border: 0;"
|
||||
|
@ -46,7 +46,7 @@ $post = $this->context->transport->post;
|
|||
|
||||
</iframe>
|
||||
|
||||
<?php elseif ($post->type == PostType::Video): ?>
|
||||
<?php elseif ($post->getType()->toInteger() == PostType::Video): ?>
|
||||
|
||||
<video style="max-width: 100%" controls>
|
||||
<source
|
||||
|
|
|
@ -6,7 +6,7 @@ $classNames =
|
|||
'post',
|
||||
'post-type-' . TextCaseConverter::convert(
|
||||
TextHelper::resolveMimeType($this->context->post->mimeType)
|
||||
?: PostType::toString($this->context->post->type),
|
||||
?: $this->context->post->getType()->toString(),
|
||||
TextCaseConverter::CAMEL_CASE,
|
||||
TextCaseConverter::SPINAL_CASE),
|
||||
];
|
||||
|
|
|
@ -86,9 +86,9 @@ Assets::addScript('../lib/tagit/jquery.tagit.js');
|
|||
<?php if (!$checked): ?>
|
||||
checked="checked"
|
||||
<?php endif ?>
|
||||
value="<?= $safety ?>" />
|
||||
value="<?= $safety->toInteger() ?>" />
|
||||
|
||||
<?= ucfirst(PostSafety::toDisplayString($safety)) ?>
|
||||
<?= ucfirst($safety->toDisplayString()) ?>
|
||||
|
||||
<?php $checked = true ?>
|
||||
</label>
|
||||
|
|
|
@ -116,7 +116,7 @@ $canEditAnything = count(array_filter($editPostPrivileges)) > 0;
|
|||
|
||||
<div class="key-value safety">
|
||||
<span class="key">Safety:</span>
|
||||
<span class="value safety-<?= $val = PostSafety::toDisplayString($this->context->transport->post->safety) ?>"
|
||||
<span class="value safety-<?= $val = $this->context->transport->post->getSafety()->toDisplayString() ?>"
|
||||
title="<?= $val ?>">
|
||||
<?= $val ?>
|
||||
</span>
|
||||
|
@ -184,7 +184,7 @@ $canEditAnything = count(array_filter($editPostPrivileges)) > 0;
|
|||
</div>
|
||||
|
||||
<div class="unit hl-options">
|
||||
<?php if ($this->context->transport->post->type != PostType::Youtube): ?>
|
||||
<?php if ($this->context->transport->post->getType()->toInteger() != PostType::Youtube): ?>
|
||||
<div class="hl-option">
|
||||
<a title="Download" href="<?= \Chibi\Router::linkTo(
|
||||
['PostController', 'fileView'],
|
||||
|
@ -370,7 +370,7 @@ $canEditAnything = count(array_filter($editPostPrivileges)) > 0;
|
|||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div class="post-wrapper post-type-<?= PostType::toString($this->context->transport->post->type) ?>">
|
||||
<div class="post-wrapper post-type-<?= $this->context->transport->post->getType()->toString() ?>">
|
||||
<?= \Chibi\View::render('post-file-render', $this->context) ?>
|
||||
</div>
|
||||
|
||||
|
|
|
@ -112,24 +112,24 @@
|
|||
<?php foreach (PostSafety::getAll() as $safety): ?>
|
||||
<?php if (Access::check(new Privilege(
|
||||
Privilege::ListPosts,
|
||||
PostSafety::toString($safety)))): ?>
|
||||
$safety->toString()))): ?>
|
||||
|
||||
<li class="safety-<?= TextCaseConverter::convert(
|
||||
PostSafety::toString($safety),
|
||||
$safety->toString(),
|
||||
TextCaseConverter::CAMEL_CASE,
|
||||
TextCaseConverter::SPINAL_CASE) ?>">
|
||||
|
||||
<a class="<?= Auth::getCurrentUser()->hasEnabledSafety($safety) ? 'enabled' : 'disabled' ?>"
|
||||
href="<?= \Chibi\Router::linkTo(
|
||||
['UserController', 'toggleSafetyAction'],
|
||||
['safety' => $safety]) ?>"
|
||||
['safety' => $safety->toInteger()]) ?>"
|
||||
title="<?= sprintf('Searching %s posts: %s',
|
||||
PostSafety::toDisplayString($safety),
|
||||
$safety->toDisplayString(),
|
||||
Auth::getCurrentUser()->hasEnabledSafety($safety)
|
||||
? 'enabled'
|
||||
: 'disabled') ?>">
|
||||
|
||||
<span><?= ucfirst(PostSafety::toDisplayString($safety)) ?></span>
|
||||
<span><?= ucfirst($safety->toDisplayString()) ?></span>
|
||||
|
||||
</a>
|
||||
</li>
|
||||
|
|
|
@ -91,14 +91,15 @@
|
|||
<div class="input-wrapper">
|
||||
<select name="access-rank" id="access-rank">
|
||||
<?php foreach (AccessRank::getAll() as $rank): ?>
|
||||
<?php if ($rank == AccessRank::Nobody) continue ?>
|
||||
<?php if ($rank == InputHelper::get('access-rank') or (!InputHelper::get('access-rank')
|
||||
and $rank == $this->context->transport->user->accessRank)): ?>
|
||||
<option value="<?= $rank ?>" selected="selected">
|
||||
<?php if ($rank->toInteger() == AccessRank::Nobody) continue ?>
|
||||
<?php if ($rank->toInteger() == InputHelper::get('access-rank')
|
||||
or (!InputHelper::get('access-rank') and
|
||||
$rank == $this->context->transport->user->getAccessRank())): ?>
|
||||
<option value="<?= $rank->toInteger() ?>" selected="selected">
|
||||
<?php else: ?>
|
||||
<option value="<?= $rank ?>">
|
||||
<option value="<?= $rank->toInteger() ?>">
|
||||
<?php endif ?>
|
||||
<?= AccessRank::toDisplayString($rank) ?>
|
||||
<?= $rank->toDisplayString() ?>
|
||||
</option>
|
||||
<?php endforeach ?>
|
||||
</select>
|
||||
|
|
|
@ -11,19 +11,19 @@
|
|||
<?php foreach (PostSafety::getAll() as $safety): ?>
|
||||
<?php if (Access::check(new Privilege(
|
||||
Privilege::ListPosts,
|
||||
PostSafety::toString($safety)))): ?>
|
||||
$safety->toString()))): ?>
|
||||
<label>
|
||||
<?php
|
||||
$attrs = [];
|
||||
$attrs['type'] = 'checkbox';
|
||||
$attrs['name'] = 'safety[]';
|
||||
$attrs['value'] = $safety;
|
||||
$attrs['value'] = $safety->toInteger();
|
||||
if ($this->context->transport->user->hasEnabledSafety($safety))
|
||||
$attrs['checked'] = 'checked';
|
||||
|
||||
echo TextHelper::htmlTag('input', TextHelper::HTML_LEAF, $attrs);
|
||||
?>
|
||||
<?= ucfirst(PostSafety::toDisplayString($safety)) ?>
|
||||
<?= ucfirst($safety->toDisplayString()) ?>
|
||||
</label>
|
||||
<?php endif ?>
|
||||
<?php endforeach ?>
|
||||
|
|
|
@ -45,7 +45,7 @@ Assets::addStylesheet('user-view.css');
|
|||
<span class="key">Access rank:</span>
|
||||
<span
|
||||
class="value"
|
||||
title="<?= $val = AccessRank::toDisplayString($this->context->transport->user->accessRank) ?>">
|
||||
title="<?= $val = $this->context->transport->user->getAccessRank()->toDisplayString() ?>">
|
||||
|
||||
<?= $val ?>
|
||||
|
||||
|
|
Loading…
Reference in a new issue