ApiV1Controller.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Support\Str;
  6. use App\Jobs\StatusPipeline\StatusDelete;
  7. use Laravel\Passport\Passport;
  8. use Auth, Cache, DB;
  9. use App\{
  10. Like,
  11. Media,
  12. Profile,
  13. Status
  14. };
  15. use League\Fractal;
  16. use App\Transformer\Api\{
  17. AccountTransformer,
  18. RelationshipTransformer,
  19. StatusTransformer,
  20. };
  21. use League\Fractal\Serializer\ArraySerializer;
  22. use League\Fractal\Pagination\IlluminatePaginatorAdapter;
  23. use App\Services\NotificationService;
  24. class ApiV1Controller extends Controller
  25. {
  26. protected $fractal;
  27. public function __construct()
  28. {
  29. $this->fractal = new Fractal\Manager();
  30. $this->fractal->setSerializer(new ArraySerializer());
  31. }
  32. public function apps(Request $request)
  33. {
  34. abort_if(!config('pixelfed.oauth_enabled'), 404);
  35. $this->validate($request, [
  36. 'client_name' => 'required',
  37. 'redirect_uris' => 'required',
  38. 'scopes' => 'nullable',
  39. 'website' => 'nullable'
  40. ]);
  41. $client = Passport::client()->forceFill([
  42. 'user_id' => null,
  43. 'name' => e($request->client_name),
  44. 'secret' => Str::random(40),
  45. 'redirect' => $request->redirect_uris,
  46. 'personal_access_client' => false,
  47. 'password_client' => false,
  48. 'revoked' => false,
  49. ]);
  50. $client->save();
  51. $res = [
  52. 'id' => $client->id,
  53. 'name' => $client->name,
  54. 'website' => null,
  55. 'redirect_uri' => $client->redirect,
  56. 'client_id' => $client->id,
  57. 'client_secret' => $client->secret,
  58. 'vapid_key' => null
  59. ];
  60. return $res;
  61. }
  62. public function accountById(Request $request, $id)
  63. {
  64. $profile = Profile::whereNull('status')->findOrFail($id);
  65. $resource = new Fractal\Resource\Item($profile, new AccountTransformer());
  66. $res = $this->fractal->createData($resource)->toArray();
  67. return response()->json($res);
  68. }
  69. public function accountUpdateCredentials(Request, $request)
  70. {
  71. abort_if(!$request->user(), 403);
  72. $this->validate($request, [
  73. 'display_name' => 'nullable|string',
  74. 'note' => 'nullable|string',
  75. 'locked' => 'nullable|boolean',
  76. // 'source.privacy' => 'nullable|in:unlisted,public,private',
  77. // 'source.sensitive' => 'nullable|boolean'
  78. ]);
  79. $user = $request->user();
  80. $profile = $user->profile;
  81. $displayName = $request->input('display_name');
  82. $note = $request->input('note');
  83. $locked = $request->input('locked');
  84. // $privacy = $request->input('source.privacy');
  85. // $sensitive = $request->input('source.sensitive');
  86. $changes = false;
  87. if($displayName !== $user->name) {
  88. $user->name = $displayName;
  89. $profile->name = $displayName;
  90. $changes = true;
  91. }
  92. if($note !== $profile->bio) {
  93. $profile->bio = e($note);
  94. $changes = true;
  95. }
  96. if(!is_null($locked)) {
  97. $profile->is_private = $locked;
  98. $changes = true;
  99. }
  100. if($changes) {
  101. $user->save();
  102. $profile->save()
  103. }
  104. $resource = new Fractal\Resource\Item($profile, new AccountTransformer());
  105. $res = $this->fractal->createData($resource)->toArray();
  106. return response()->json($res);
  107. }
  108. public function statusById(Request $request, $id)
  109. {
  110. $status = Status::whereVisibility('public')->findOrFail($id);
  111. $resource = new Fractal\Resource\Item($status, new StatusTransformer());
  112. $res = $this->fractal->createData($resource)->toArray();
  113. return response()->json($res);
  114. }
  115. public function instance(Request $request)
  116. {
  117. $res = [
  118. 'description' => 'Pixelfed - Photo sharing for everyone',
  119. 'email' => config('instance.email'),
  120. 'languages' => ['en'],
  121. 'max_toot_chars' => config('pixelfed.max_caption_length'),
  122. 'registrations' => config('pixelfed.open_registration'),
  123. 'stats' => [
  124. 'user_count' => 0,
  125. 'status_count' => 0,
  126. 'domain_count' => 0
  127. ],
  128. 'thumbnail' => config('app.url') . '/img/pixelfed-icon-color.png',
  129. 'title' => 'Pixelfed (' . config('pixelfed.domain.app') . ')',
  130. 'uri' => config('app.url'),
  131. 'urls' => [],
  132. 'version' => '2.7.2 (compatible; Pixelfed ' . config('pixelfed.version') . ')'
  133. ];
  134. return response()->json($res, 200, [], JSON_PRETTY_PRINT);
  135. }
  136. public function filters(Request $request)
  137. {
  138. // Pixelfed does not yet support keyword filters
  139. return response()->json([]);
  140. }
  141. public function context(Request $request)
  142. {
  143. // todo
  144. $res = [
  145. 'ancestors' => [],
  146. 'descendants' => []
  147. ];
  148. return response()->json($res);
  149. }
  150. public function createStatus(Request $request)
  151. {
  152. abort_if(!$request->user(), 403);
  153. $this->validate($request, [
  154. 'status' => 'string',
  155. 'media_ids' => 'array',
  156. 'media_ids.*' => 'integer|min:1',
  157. 'sensitive' => 'nullable|boolean',
  158. 'visibility' => 'string|in:private,unlisted,public',
  159. 'in_reply_to_id' => 'integer'
  160. ]);
  161. if(!$request->filled('media_ids') && !$request->filled('in_reply_to_id')) {
  162. abort(403, 'Empty statuses are not allowed');
  163. }
  164. }
  165. }