blessing-skin-server/app/Models/Player.php

278 lines
6.5 KiB
PHP
Raw Normal View History

2016-07-21 22:01:57 +08:00
<?php
namespace App\Models;
2016-08-29 15:28:20 +08:00
use Event;
2016-09-25 11:40:50 +08:00
use Response;
2016-10-07 16:06:38 +08:00
use App\Models\User;
use App\Events\GetPlayerJson;
use App\Events\PlayerProfileUpdated;
use App\Exceptions\PrettyPageException;
2016-10-23 11:41:52 +08:00
use Illuminate\Database\Eloquent\Model;
2016-07-21 22:01:57 +08:00
2016-10-23 11:41:52 +08:00
class Player extends Model
2016-07-21 22:01:57 +08:00
{
2016-10-23 11:41:52 +08:00
/**
* Json APIs.
*/
const CSL_API = 0;
const USM_API = 1;
/**
* Set of models.
*/
2016-10-23 12:19:19 +08:00
protected static $models = ['steve', 'alex', 'cape'];
2016-10-23 11:41:52 +08:00
/**
* Properties for Eloquent Model.
*/
2016-10-16 18:16:15 +08:00
public $primaryKey = 'pid';
public $timestamps = false;
protected $fillable = ['uid', 'player_name', 'preference', 'last_modified'];
2016-07-21 22:01:57 +08:00
2018-02-23 09:51:23 +08:00
/**
* The attributes that should be cast to native types.
*
* @var array
*/
protected $casts = [
'pid' => 'integer',
'uid' => 'integer',
'tid_steve' => 'integer',
'tid_alex' => 'integer',
'tid_cape' => 'integer',
];
/**
2016-10-16 18:16:15 +08:00
* Check if the player is banned.
*
2016-10-16 18:16:15 +08:00
* @return bool
*/
2016-10-16 18:16:15 +08:00
public function isBanned()
2016-07-21 22:01:57 +08:00
{
2016-10-23 11:41:52 +08:00
return $this->user->getPermission() == User::BANNED;
}
/**
* Return the owner of the player.
*
2017-11-14 23:25:04 +08:00
* @return \App\Models\User
2016-10-23 11:41:52 +08:00
*/
public function user()
{
return $this->belongsTo('App\Models\User', 'uid');
2016-07-21 22:01:57 +08:00
}
/**
2016-10-16 18:16:15 +08:00
* Get specific texture of player.
*
2018-02-16 17:31:04 +08:00
* @param string $type "steve" or "alex" or "cape".
* @return string The sha256 hash of texture file.
2016-07-21 22:01:57 +08:00
*/
public function getTexture($type)
{
if ($type == "skin")
$type = ($this->getPreference() == "default") ? "steve" : "alex";
2016-10-16 18:16:15 +08:00
2016-10-23 12:19:19 +08:00
if (in_array($type, self::$models)) {
2016-10-16 18:16:15 +08:00
return Texture::find($this["tid_$type"])['hash'];
2016-07-21 22:01:57 +08:00
}
2016-10-16 18:16:15 +08:00
2016-07-21 22:01:57 +08:00
return false;
}
2016-10-16 18:16:15 +08:00
/**
* Set textures for the player.
*
* @param array $tids
2017-11-14 23:25:04 +08:00
* @return $this
2016-10-16 18:16:15 +08:00
*/
2016-07-21 22:01:57 +08:00
public function setTexture(Array $tids)
{
2016-10-23 12:19:19 +08:00
foreach (self::$models as $model) {
2016-09-10 21:39:45 +08:00
$property = "tid_$model";
2016-10-16 18:16:15 +08:00
2016-09-10 21:39:45 +08:00
if (isset($tids[$property])) {
2016-10-16 18:16:15 +08:00
$this->$property = $tids[$property];
2016-09-10 21:39:45 +08:00
}
}
2016-07-21 22:01:57 +08:00
2018-08-17 22:54:26 +08:00
$this->last_modified = get_datetime_string();
2016-08-29 15:28:20 +08:00
2016-10-16 18:16:15 +08:00
$this->save();
2016-08-29 15:28:20 +08:00
2017-11-14 23:25:04 +08:00
event(new PlayerProfileUpdated($this));
return $this;
2016-07-21 22:01:57 +08:00
}
/**
* Check and delete invalid textures from player profile.
*
2018-02-16 17:31:04 +08:00
* @return $this
*/
public function checkForInvalidTextures()
{
foreach (self::$models as $model) {
$property = "tid_$model";
2018-02-16 17:31:04 +08:00
if (! Texture::find($this->$property)) {
// reset texture
$this->$property = 0;
}
}
2018-02-16 17:31:04 +08:00
$this->save();
return $this;
}
2016-10-16 18:16:15 +08:00
/**
* Clear the textures of player.
*
* @param array|string $types
* @return $this
2016-10-16 18:16:15 +08:00
*/
public function clearTexture($types)
{
$types = (array) $types;
$map = [];
foreach ($types as $type) {
$map["tid_$type"] = 0;
}
$this->setTexture($map);
2016-10-16 18:16:15 +08:00
return $this;
}
2016-07-21 22:01:57 +08:00
/**
2016-10-16 18:16:15 +08:00
* Set preferred model for the player.
2016-10-07 16:06:38 +08:00
*
2018-02-16 17:31:04 +08:00
* @param string $type "slim" or "default".
2017-11-14 23:25:04 +08:00
* @return $this
2016-07-21 22:01:57 +08:00
*/
public function setPreference($type)
{
2016-10-16 18:16:15 +08:00
$this->update([
2016-07-21 22:01:57 +08:00
'preference' => $type,
2018-08-17 22:54:26 +08:00
'last_modified' => get_datetime_string()
2016-07-21 22:01:57 +08:00
]);
2016-08-29 15:28:20 +08:00
2017-11-14 23:25:04 +08:00
event(new PlayerProfileUpdated($this));
return $this;
2016-07-21 22:01:57 +08:00
}
2016-10-23 11:41:52 +08:00
/**
* Get model preference of the player.
*
* @return string
*/
public function getPreference()
{
2016-10-16 18:16:15 +08:00
return $this['preference'];
2016-10-07 16:06:38 +08:00
}
/**
* Rename the player.
*
2018-02-16 17:31:04 +08:00
* @param string $newName
* @return $this
2016-10-07 16:06:38 +08:00
*/
2018-02-16 17:31:04 +08:00
public function rename($newName)
{
2016-10-16 18:16:15 +08:00
$this->update([
2018-02-16 17:31:04 +08:00
'player_name' => $newName,
2018-08-17 22:54:26 +08:00
'last_modified' => get_datetime_string()
]);
2018-02-16 17:31:04 +08:00
$this->player_name = $newName;
2017-11-14 23:25:04 +08:00
event(new PlayerProfileUpdated($this));
return $this;
}
2016-10-07 16:06:38 +08:00
/**
* Set a new owner for the player.
*
2018-02-16 17:31:04 +08:00
* @param int $uid
2017-11-14 23:25:04 +08:00
* @return $this
2016-10-07 16:06:38 +08:00
*/
2016-07-23 15:20:10 +08:00
public function setOwner($uid) {
2016-10-16 18:16:15 +08:00
$this->update(['uid' => $uid]);
2016-08-29 15:28:20 +08:00
2017-11-14 23:25:04 +08:00
event(new PlayerProfileUpdated($this));
return $this;
2016-07-23 15:20:10 +08:00
}
2016-07-21 22:01:57 +08:00
/**
2016-10-16 18:16:15 +08:00
* Get Json profile of player.
2016-08-29 15:28:20 +08:00
*
* @param int $api_type Which API to use, 0 for CustomSkinAPI, 1 for UniSkinAPI
* @return string User profile in json format
2016-07-21 22:01:57 +08:00
*/
public function getJsonProfile($api_type)
{
2016-07-21 22:01:57 +08:00
// Support both CustomSkinLoader API & UniSkinAPI
2016-08-29 15:28:20 +08:00
if ($api_type == self::CSL_API || $api_type == self::USM_API) {
2016-11-21 21:50:24 +08:00
2019-02-27 23:44:50 +08:00
$responses = Event::dispatch(new GetPlayerJson($this, $api_type));
2016-11-21 21:50:24 +08:00
2018-02-16 17:31:04 +08:00
// If listeners return nothing
2016-08-30 10:10:11 +08:00
if (isset($responses[0]) && $responses[0] !== null) {
return $responses[0]; // @codeCoverageIgnore
2016-08-30 10:10:11 +08:00
} else {
return $this->generateJsonProfile($api_type);
}
2016-07-21 22:01:57 +08:00
} else {
throw new \InvalidArgumentException('The given api type should be Player::CSL_API or Player::USM_API.');
2016-07-21 22:01:57 +08:00
}
2016-08-29 15:28:20 +08:00
}
2016-08-30 10:10:11 +08:00
/**
2016-10-16 18:16:15 +08:00
* Generate player profile in json format.
2016-08-30 10:10:11 +08:00
*
* @param int $api_type
* @return string
*/
2016-08-29 15:28:20 +08:00
public function generateJsonProfile($api_type)
{
$json[($api_type == self::CSL_API) ? 'username' : 'player_name'] = $this->player_name;
$model = $this->getPreference();
$sec_model = ($model == 'default') ? 'slim' : 'default';
if ($api_type == self::USM_API) {
2018-08-05 16:38:46 +08:00
$json['last_update'] = strtotime($this->last_modified);
2016-08-29 15:28:20 +08:00
$json['model_preference'] = [$model, $sec_model];
}
if ($this->getTexture('steve') || $this->getTexture('alex')) {
// Skins dict order by preference model
$json['skins'][$model] = $this->getTexture($model == "default" ? "steve" : "alex");
$json['skins'][$sec_model] = $this->getTexture($sec_model == "default" ? "steve" : "alex");
}
$json['cape'] = $this->getTexture('cape');
2016-07-21 22:01:57 +08:00
2016-11-11 21:19:45 +08:00
return json_encode($json, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE);
2016-07-21 22:01:57 +08:00
}
2016-10-16 18:16:15 +08:00
/**
* Update the date of last modified.
*
* @return mixed
*/
public function updateLastModified()
{
2016-07-21 22:01:57 +08:00
// @see http://stackoverflow.com/questions/2215354/php-date-format-when-inserting-into-datetime-in-mysql
2018-08-17 22:54:26 +08:00
$this->update(['last_modified' => get_datetime_string()]);
return event(new PlayerProfileUpdated($this));
2016-07-21 22:01:57 +08:00
}
}