- Introduced `ValidGitRepositoryUrl` and `ValidGitBranch` validation rules to ensure safe and valid input for Git repository URLs and branch names. - Updated relevant Livewire components and API controllers to utilize the new validation rules, enhancing security against command injection and invalid inputs. - Refactored existing validation logic to improve consistency and maintainability across the application.
86 lines
4.7 KiB
PHP
86 lines
4.7 KiB
PHP
<div x-data x-init="$nextTick(() => { if ($refs.autofocusInput) $refs.autofocusInput.focus(); })">
|
|
<h1>Create a new Application</h1>
|
|
<div class="pb-8">Deploy any public Git repositories.</div>
|
|
|
|
<!-- Repository URL Form -->
|
|
<form class="flex flex-col gap-2" wire:submit='loadBranch'>
|
|
<div class="flex flex-col gap-2">
|
|
<div class="flex gap-2 items-end">
|
|
<x-forms.input required id="repository_url" label="Repository URL (https://)"
|
|
helper="{!! __('repository.url') !!}" autofocus />
|
|
<x-forms.button type="submit">
|
|
Check repository
|
|
</x-forms.button>
|
|
</div>
|
|
<div>
|
|
For example application deployments, checkout <a class="underline dark:text-white"
|
|
href="https://github.com/coollabsio/coolify-examples/" target="_blank">Coolify
|
|
Examples</a>.
|
|
</div>
|
|
</div>
|
|
</form>
|
|
|
|
@if ($branchFound)
|
|
@if ($rate_limit_remaining && $rate_limit_reset)
|
|
<div class="flex gap-2 py-2">
|
|
<div>Rate Limit</div>
|
|
<x-helper
|
|
helper="Rate limit remaining: {{ $rate_limit_remaining }}<br>Rate limit reset at: {{ $rate_limit_reset }} UTC" />
|
|
</div>
|
|
@endif
|
|
|
|
<!-- Application Configuration Form -->
|
|
<form class="flex flex-col gap-2 pt-4" wire:submit='submit'>
|
|
<div class="flex flex-col gap-2 pb-6">
|
|
<div class="flex gap-2">
|
|
@if ($git_source === 'other')
|
|
<x-forms.input id="git_branch" label="Branch"
|
|
helper="You can select other branches after configuration is done." />
|
|
@else
|
|
<x-forms.input disabled id="git_branch" label="Branch"
|
|
helper="You can select other branches after configuration is done." />
|
|
@endif
|
|
<x-forms.select wire:model.live="build_pack" label="Build Pack" required>
|
|
<option value="nixpacks">Nixpacks</option>
|
|
<option value="static">Static</option>
|
|
<option value="dockerfile">Dockerfile</option>
|
|
<option value="dockercompose">Docker Compose</option>
|
|
</x-forms.select>
|
|
@if ($isStatic)
|
|
<x-forms.input id="publish_directory" label="Publish Directory"
|
|
helper="If there is a build process involved (like Svelte, React, Next, etc..), please specify the output directory for the build assets." />
|
|
@endif
|
|
</div>
|
|
@if ($build_pack === 'dockercompose')
|
|
<div x-data="{ baseDir: '{{ $base_directory }}', composeLocation: '{{ $docker_compose_location }}' }" class="gap-2 flex flex-col">
|
|
<x-forms.input placeholder="/" wire:model.blur-sm="base_directory" label="Base Directory"
|
|
helper="Directory to use as root. Useful for monorepos." x-model="baseDir" />
|
|
<x-forms.input placeholder="/docker-compose.yaml" wire:model.blur-sm="docker_compose_location"
|
|
label="Docker Compose Location" helper="It is calculated together with the Base Directory."
|
|
x-model="composeLocation" />
|
|
<div class="pt-2">
|
|
<span>
|
|
Compose file location in your repository: </span><span class='dark:text-warning'
|
|
x-text='(baseDir === "/" ? "" : baseDir) + (composeLocation.startsWith("/") ? composeLocation : "/" + composeLocation)'></span>
|
|
</div>
|
|
</div>
|
|
@else
|
|
<x-forms.input wire:model="base_directory" label="Base Directory"
|
|
helper="Directory to use as root. Useful for monorepos." />
|
|
@endif
|
|
@if ($show_is_static)
|
|
<x-forms.input type="number" id="port" label="Port" :readonly="$isStatic || $build_pack === 'static'"
|
|
helper="The port your application listens on." />
|
|
<div class="w-64">
|
|
<x-forms.checkbox instantSave id="isStatic" label="Is it a static site?"
|
|
helper="If your application is a static site or the final build assets should be served as a static site, enable this." />
|
|
</div>
|
|
@endif
|
|
</div>
|
|
<x-forms.button type="submit">
|
|
Continue
|
|
</x-forms.button>
|
|
</form>
|
|
@endif
|
|
</div>
|