. */ namespace Poniverse\Ponyfm\Http\Controllers\Api\Web; use Poniverse\Ponyfm\Http\Controllers\ApiControllerBase; use Poniverse\Ponyfm\Commands\SaveAccountSettingsCommand; use Poniverse\Ponyfm\Models\User; use Cover; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Input; use Illuminate\Support\Facades\Response; class AccountController extends ApiControllerBase { public function getSettings($slug = -1) { $user = null; $current_user = Auth::user(); if ($slug == -1 || $slug == $current_user->slug) { $user = $current_user; } else if ($current_user->hasRole('admin')) { $user = User::where('slug', $slug)->whereNull('disabled_at')->first(); } if ($user == null) { if ($current_user->hasRole('admin')) { return Response::json(['error' => 'User does not exist'], 404); } else { return Response::json(['error' => 'You cannot do that. So stop trying!'], 403); } } return Response::json([ 'id' => $user->id, 'bio' => $user->bio, 'can_see_explicit_content' => $user->can_see_explicit_content == 1, 'display_name' => $user->display_name, 'sync_names' => $user->sync_names == 1, 'username' => $user->username, 'gravatar' => $user->gravatar ? $user->gravatar : $user->email, 'avatar_url' => !$user->uses_gravatar ? $user->getAvatarUrl() : null, 'uses_gravatar' => $user->uses_gravatar == 1 ], 200); } public function postSave($slug = -1) { return $this->execute(new SaveAccountSettingsCommand(Input::all(), $slug)); } }