lasthourcloud/resources/views/livewire/source/github/change.blade.php

159 lines
8.4 KiB
PHP
Raw Normal View History

2023-05-09 08:01:57 +00:00
<div x-data="{ deleteSource: false }">
<x-naked-modal show="deleteSource" message='Are you sure you would like to delete this source?' />
2023-05-08 11:36:49 +00:00
<form wire:submit.prevent='submit'>
2023-05-18 11:26:35 +00:00
<div class="flex items-center gap-2">
<h1>GitHub App</h1>
2023-06-12 20:02:10 +00:00
<div class="flex gap-2">
2023-05-18 11:26:35 +00:00
@if ($github_app->app_id)
2023-05-25 12:05:44 +00:00
<x-forms.button type="submit">Save</x-forms.button>
<x-forms.button x-on:click.prevent="deleteSource = true">
2023-05-18 11:26:35 +00:00
Delete
2023-05-25 12:05:44 +00:00
</x-forms.button>
2023-06-14 09:03:54 +00:00
<a href="{{ get_installation_path($github_app) }}">
2023-05-25 12:05:44 +00:00
<x-forms.button>
2023-05-18 11:26:35 +00:00
@if ($github_app->installation_id)
Update Repositories
<x-external-link />
@else
Install Repositories
<x-external-link />
@endif
2023-05-25 12:05:44 +00:00
</x-forms.button>
2023-05-18 11:26:35 +00:00
</a>
@else
2023-05-25 12:05:44 +00:00
<x-forms.button disabled type="submit">Save</x-forms.button>
<x-forms.button x-on:click.prevent="deleteSource = true">
2023-05-18 11:26:35 +00:00
Delete
2023-05-25 12:05:44 +00:00
</x-forms.button>
2023-05-31 20:23:17 +00:00
2023-05-18 11:26:35 +00:00
@endif
</div>
</div>
2023-06-12 20:02:10 +00:00
<div class="pt-2 pb-10 text-sm">Your Private GitHub App for private repositories.</div>
2023-05-08 11:36:49 +00:00
@if ($github_app->app_id)
2023-06-14 07:44:40 +00:00
<div class="flex gap-2">
<x-forms.input id="github_app.name" label="App Name" disabled />
<x-forms.input id="github_app.organization" label="Organization" disabled
placeholder="If empty, personal user will be used" />
</div>
<div class="flex gap-2">
<x-forms.input id="github_app.html_url" label="HTML Url" disabled />
<x-forms.input id="github_app.api_url" label="API Url" disabled />
</div>
<div class="flex gap-2">
@if ($github_app->html_url === 'https://github.com')
<x-forms.input id="github_app.custom_user" label="User" disabled />
<x-forms.input type="number" id="github_app.custom_port" label="Port" disabled />
@else
<x-forms.input id="github_app.custom_user" label="User" required />
<x-forms.input type="number" id="github_app.custom_port" label="Port" required />
@endif
</div>
2023-06-12 20:02:10 +00:00
<div class="flex gap-2">
<x-forms.input type="number" id="github_app.app_id" label="App Id" disabled />
<x-forms.input type="number" id="github_app.installation_id" label="Installation Id" disabled />
</div>
<div class="flex gap-2">
<x-forms.input id="github_app.client_id" label="Client Id" type="password" disabled />
2023-06-13 09:04:11 +00:00
<x-forms.input id="github_app.client_secret" label="Client Secret" type="password" />
2023-06-12 20:30:47 +00:00
<x-forms.input id="github_app.webhook_secret" label="Webhook Secret" type="password" />
2023-05-08 11:36:49 +00:00
</div>
2023-06-12 20:02:10 +00:00
<x-forms.checkbox noDirty label="System Wide?"
helper="If checked, this GitHub App will be available for everyone in this Coolify instance."
instantSave id="is_system_wide" />
@else
2023-06-14 07:44:40 +00:00
<div class="text-sm ">You need to register a GitHub App before using this source.</div>
<div class="flex items-end gap-4 pt-2 pb-10">
<form class="flex gap-2">
<x-forms.select wire:model='webhook_endpoint' label="Webhook Endpoint"
helper="All Git webhooks will be sent to this endpoint. <br><br>If you would like to use domain instead of IP address, set your Coolify instance's FQDN in the Settings menu.">
@if ($ipv4)
<option value="{{ $ipv4 }}">Use {{ $ipv4 }}</option>
@endif
@if ($ipv6)
<option value="{{ $ipv6 }}">Use {{ $ipv6 }}</option>
@endif
@if ($fqdn)
<option value="{{ $fqdn }}">Use {{ $fqdn }}</option>
@endif
</x-forms.select>
<x-forms.button x-on:click.prevent="createGithubApp('{{ $webhook_endpoint }}')">Register a GitHub
Application
</x-forms.button>
</form>
</div>
<div class="flex gap-2">
<x-forms.input id="github_app.name" label="App Name" disabled />
<x-forms.input id="github_app.organization" label="Organization"
placeholder="If empty, personal user will be used" disabled />
</div>
<div class="flex gap-2">
<x-forms.input id="github_app.html_url" label="HTML Url" disabled />
<x-forms.input id="github_app.api_url" label="API Url" disabled />
</div>
<div class="flex gap-2">
@if ($github_app->html_url === 'https://github.com')
<x-forms.input id="github_app.custom_user" label="User" disabled />
<x-forms.input type="number" id="github_app.custom_port" label="Port" disabled />
@else
<x-forms.input id="github_app.custom_user" label="User" required />
<x-forms.input type="number" id="github_app.custom_port" label="Port" required />
@endif
</div>
2023-06-12 20:02:10 +00:00
<x-forms.checkbox
helper="If checked, this GitHub App will be available for everyone in this Coolify instance." noDirty
2023-06-14 07:44:40 +00:00
label="System Wide?" instantSave disabled id="is_system_wide" />
<script>
function createGithubApp(webhook_endpoint) {
const {
organization,
uuid,
html_url
} = @json($github_app);
let baseUrl = webhook_endpoint;
const name = @js($name);
const isDev = @js(config('app.env')) === 'local';
const devWebhook = @js(config('coolify.dev_webhook'));
if (isDev && devWebhook) {
baseUrl = devWebhook;
}
const webhookBaseUrl = `${baseUrl}/webhooks`;
const path = organization ? `organizations/${organization}/settings/apps/new` : 'settings/apps/new';
const data = {
name,
url: baseUrl,
hook_attributes: {
url: `${webhookBaseUrl}/source/github/events`,
active: true,
},
redirect_url: `${webhookBaseUrl}/source/github/redirect`,
callback_urls: [`${baseUrl}/login/github/app`],
public: false,
request_oauth_on_install: false,
setup_url: `${webhookBaseUrl}/source/github/install?source=${uuid}`,
setup_on_update: true,
default_permissions: {
contents: 'read',
metadata: 'read',
pull_requests: 'write',
emails: 'read'
},
default_events: ['pull_request', 'push']
};
const form = document.createElement('form');
form.setAttribute('method', 'post');
form.setAttribute('action', `${html_url}/${path}?state=${uuid}`);
const input = document.createElement('input');
input.setAttribute('id', 'manifest');
input.setAttribute('name', 'manifest');
input.setAttribute('type', 'hidden');
input.setAttribute('value', JSON.stringify(data));
form.appendChild(input);
document.getElementsByTagName('body')[0].appendChild(form);
form.submit();
}
</script>
2023-05-08 11:36:49 +00:00
@endif
</form>
</div>