123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- <?php
- namespace App\Http\Controllers\Api;
- use Illuminate\Http\Request;
- use App\Http\Controllers\Controller;
- use Illuminate\Support\Str;
- use App\Jobs\StatusPipeline\StatusDelete;
- use Laravel\Passport\Passport;
- use Auth, Cache, DB;
- use Carbon\Carbon;
- use App\{
- Like,
- Media,
- Profile,
- Status
- };
- use App\Services\NotificationService;
- class ApiV1Controller extends Controller {
- public function apps(Request $request)
- {
- abort_if(!config('pixelfed.oauth_enabled'), 404);
- $this->validate($request, [
- 'client_name' => 'required',
- 'redirect_uris' => 'required',
- 'scopes' => 'nullable',
- 'website' => 'nullable'
- ]);
- $client = Passport::client()->forceFill([
- 'user_id' => null,
- 'name' => e($request->client_name),
- 'secret' => Str::random(40),
- 'redirect' => $request->redirect_uris,
- 'personal_access_client' => false,
- 'password_client' => false,
- 'revoked' => false,
- ]);
- $client->save();
- $res = [
- 'id' => $client->id,
- 'name' => $client->name,
- 'website' => null,
- 'redirect_uri' => $client->redirect,
- 'client_id' => $client->id,
- 'client_secret' => $client->secret,
- 'vapid_key' => null
- ];
- return $res;
- }
- }
|