2023-07-28 13:31:47 +02:00
< div >
< x - modal yesOrNo modalId = " deleteSource " modalTitle = " Delete Source " >
< x - slot : modalBody >
< p > This source will be deleted . It is not reversible . < br > Please think again .</ p >
</ x - slot : modalBody >
</ x - modal >
2023-08-28 21:15:30 +02:00
< form wire : submit . prevent = 'submit' x - data >
2023-05-18 13:26:35 +02:00
< div class = " flex items-center gap-2 " >
< h1 > GitHub App </ h1 >
2023-06-12 22:02:10 +02:00
< div class = " flex gap-2 " >
2023-05-18 13:26:35 +02:00
@ if ( $github_app -> app_id )
2023-05-25 14:05:44 +02:00
< x - forms . button type = " submit " > Save </ x - forms . button >
2023-07-26 13:23:47 +02:00
2023-06-14 11:03:54 +02:00
< a href = " { { get_installation_path( $github_app ) }} " >
2023-05-25 14:05:44 +02:00
< x - forms . button >
2023-05-18 13:26:35 +02:00
@ if ( $github_app -> installation_id )
Update Repositories
2023-08-11 20:19:42 +02:00
< x - external - link />
2023-05-18 13:26:35 +02:00
@ else
Install Repositories
2023-08-11 20:19:42 +02:00
< x - external - link />
2023-05-18 13:26:35 +02:00
@ endif
2023-05-25 14:05:44 +02:00
</ x - forms . button >
2023-05-18 13:26:35 +02:00
</ a >
@ else
2023-05-25 14:05:44 +02:00
< x - forms . button disabled type = " submit " > Save </ x - forms . button >
2023-05-18 13:26:35 +02:00
@ endif
2023-07-28 13:31:47 +02:00
< x - forms . button isError isModal modalId = " deleteSource " >
Delete
</ x - forms . button >
2023-05-18 13:26:35 +02:00
</ div >
</ div >
2023-08-14 14:00:10 +02:00
< div class = " subtitle " > Your Private GitHub App for private repositories .</ div >
2023-05-08 13:36:49 +02:00
@ if ( $github_app -> app_id )
2023-07-04 13:08:27 +02:00
< div class = " w-48 " >
2023-07-13 13:16:24 +02:00
< x - forms . checkbox label = " System Wide? "
2023-08-11 20:19:42 +02:00
helper = " If checked, this GitHub App will be available for everyone in this Coolify instance. "
instantSave id = " is_system_wide " />
2023-07-04 13:08:27 +02:00
</ div >
2023-06-14 09:44:40 +02:00
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.name " label = " App Name " disabled />
2023-06-14 09:44:40 +02:00
< x - forms . input id = " github_app.organization " label = " Organization " disabled
2023-08-11 20:19:42 +02:00
placeholder = " If empty, personal user will be used " />
2023-06-14 09:44:40 +02:00
</ div >
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.html_url " label = " HTML Url " disabled />
< x - forms . input id = " github_app.api_url " label = " API Url " disabled />
2023-06-14 09:44:40 +02:00
</ div >
< div class = " flex gap-2 " >
@ if ( $github_app -> html_url === 'https://github.com' )
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.custom_user " label = " User " disabled />
< x - forms . input type = " number " id = " github_app.custom_port " label = " Port " disabled />
2023-06-14 09:44:40 +02:00
@ else
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.custom_user " label = " User " required />
< x - forms . input type = " number " id = " github_app.custom_port " label = " Port " required />
2023-06-14 09:44:40 +02:00
@ endif
</ div >
2023-06-12 22:02:10 +02:00
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< 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 />
2023-06-12 22:02:10 +02:00
</ div >
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.client_id " label = " Client Id " type = " password " disabled />
< x - forms . input id = " github_app.client_secret " label = " Client Secret " type = " password " />
< x - forms . input id = " github_app.webhook_secret " label = " Webhook Secret " type = " password " />
2023-05-08 13:36:49 +02:00
</ div >
2023-06-12 22:02:10 +02:00
@ else
2023-06-14 13:07:58 +02:00
< form class = " flex gap-4 " >
< div class = " flex items-end gap-2 " >
< h3 > Register a GitHub App </ h3 >
< x - forms . button
x - on : click . prevent = " createGithubApp(' { { $webhook_endpoint }}',' { { $preview_deployment_permissions }}') " >
Register a
GitHub
2023-06-14 09:44:40 +02:00
Application
</ x - forms . button >
2023-06-14 13:07:58 +02:00
</ div >
2023-06-16 12:35:40 +02:00
< div class = " pt-1 pb-2 " > You need to register a GitHub App before using this source .</ div >
2023-06-14 13:07:58 +02:00
< div class = " pt-2 pb-10 " >
2023-08-28 21:15:30 +02:00
@ if ( ! is_cloud () || isDev ())
2023-08-28 21:03:07 +02:00
< div class = " flex items-end 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 >
</ div >
@ endif
2023-06-14 13:07:58 +02:00
< div class = " flex flex-col gap-2 pt-4 " >
< x - forms . checkbox disabled instantSave id = " default_permissions " label = " Default Permissions "
2023-08-11 20:19:42 +02:00
helper = " Contents: read<br>Metadata: read<br>Email: read " />
2023-06-14 13:07:58 +02:00
< x - forms . checkbox instantSave id = " preview_deployment_permissions "
2023-08-11 20:19:42 +02:00
label = " Preview Deployments Permission "
helper = " Necessary for updating pull requests with useful comments (deployment status, links, etc.)<br><br>Pull Request: read & write " />
2023-06-14 13:07:58 +02:00
</ div >
</ div >
</ form >
2023-06-14 09:44:40 +02:00
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.name " label = " App Name " disabled />
2023-06-14 09:44:40 +02:00
< x - forms . input id = " github_app.organization " label = " Organization "
2023-08-11 20:19:42 +02:00
placeholder = " If empty, personal user will be used " disabled />
2023-06-14 09:44:40 +02:00
</ div >
< div class = " flex gap-2 " >
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.html_url " label = " HTML Url " disabled />
< x - forms . input id = " github_app.api_url " label = " API Url " disabled />
2023-06-14 09:44:40 +02:00
</ div >
< div class = " flex gap-2 " >
@ if ( $github_app -> html_url === 'https://github.com' )
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.custom_user " label = " User " disabled />
< x - forms . input type = " number " id = " github_app.custom_port " label = " Port " disabled />
2023-06-14 09:44:40 +02:00
@ else
2023-08-11 20:19:42 +02:00
< x - forms . input id = " github_app.custom_user " label = " User " required />
< x - forms . input type = " number " id = " github_app.custom_port " label = " Port " required />
2023-06-14 09:44:40 +02:00
@ endif
</ div >
2023-08-28 21:15:30 +02:00
@ if ( ! is_cloud () || isDev ())
2023-08-28 21:03:07 +02:00
< x - forms . checkbox
helper = " If checked, this GitHub App will be available for everyone in this Coolify instance. "
label = " System Wide? " disabled id = " is_system_wide " />
@ endif
2023-06-14 09:44:40 +02:00
< script >
2023-06-14 13:07:58 +02:00
function createGithubApp ( webhook_endpoint , preview_deployment_permissions ) {
2023-06-14 09:44:40 +02:00
const {
organization ,
uuid ,
html_url
} = @ json ( $github_app );
let baseUrl = webhook_endpoint ;
const name = @ js ( $name );
2023-08-08 11:51:36 +02:00
const isDev = @ js ( config ( 'app.env' )) ===
2023-08-11 20:19:42 +02:00
'local' ;
2023-06-14 09:44:40 +02:00
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' ;
2023-06-14 13:07:58 +02:00
const default_permissions = {
contents : 'read' ,
metadata : 'read' ,
emails : 'read'
};
if ( preview_deployment_permissions ) {
default_permissions . pull_requests = 'write' ;
}
2023-06-14 09:44:40 +02:00
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 ,
2023-06-14 13:07:58 +02:00
default_permissions ,
2023-06-14 09:44:40 +02:00
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 13:36:49 +02:00
@ endif
</ form >
</ div >