Compare commits

..

2 Commits

Author SHA1 Message Date
philipp lang f4629e7902 Add support for submit in proxy 2024-02-08 02:23:11 +01:00
philipp lang 05a6fca5cc Add form id to form component 2024-02-08 02:22:12 +01:00
3 changed files with 18 additions and 8 deletions

View File

@ -6,4 +6,5 @@
single-url="{{__SELF__.settings.singleUrl}}"
register-url="{{__SELF__.settings.registerUrl}}"
config-var-name="adrema_event_config"
form-id="{{__SELF__.event.id }}"
></event-form>

View File

@ -2,8 +2,7 @@
use Silva\Adrema\Support\Proxy;
Route::get(
'/adrema-api/{route}',
fn (string $route) => Response::json(app(Proxy::class)->run($route))
)
Route::get('/adrema-api/{route}', fn (string $route) => Response::json(app(Proxy::class)->run($route, 'get')))
->where('route', '[a-zA-Z0-9\-/]+')->middleware('api');
Route::post('/adrema-api/{route}', fn (string $route) => app(Proxy::class)->submit($route))
->where('route', '[a-zA-Z0-9\-/]+')->middleware('api');

View File

@ -4,15 +4,13 @@ namespace Silva\Adrema\Support;
use Silva\Adrema\Models\Settings;
use Http;
use Illuminate\Http\JsonResponse;
class Proxy
{
public function run(string $url): ?array
{
$url = str($url)->start('/');
$baseUrl = Settings::get('base_url');
$response = Http::get($baseUrl . $url);
$response = Http::acceptJson()->get($this->url($url));
if (!$response->ok()) {
return null;
@ -20,4 +18,16 @@ class Proxy
return $response->json();
}
public function submit(string $url): JsonResponse
{
$response = Http::acceptJson()->post($this->url($url), request()->input());
return response()->json($response->json(), $response->status());
}
private function url(string $internal): string
{
return Settings::get('base_url') . str($internal)->start('/');
}
}