feat: cloudflare integration auth page

This commit is contained in:
Stijn-Kuijper
2023-06-13 11:52:40 +02:00
parent db28536ea8
commit dffcee52d7
3 changed files with 93 additions and 0 deletions

View File

@@ -219,6 +219,9 @@ export default function Integrations() {
case 'hashicorp-vault':
link = `${window.location.origin}/integrations/hashicorp-vault/authorize`;
break;
case 'cloudflare-pages':
link = `${window.location.origin}/integrations/cloudflare-pages/authorize`;
break;
default:
break;
}
@@ -283,6 +286,8 @@ export default function Integrations() {
case 'hashicorp-vault':
link = `${window.location.origin}/integrations/hashicorp-vault/create?integrationAuthId=${integrationAuth._id}`;
break;
case 'cloudflare-pages':
link = `${window.location.origin}/integrations/cloudflare-pages/create?integrationAutHId=${integrationAuth._id}`;
default:
break;
}

View File

@@ -0,0 +1,88 @@
import { useState } from 'react';
import { useRouter } from 'next/router';
import { Card, CardTitle, FormControl, Input, Button } from '../../../components/v2';
import saveIntegrationAccessToken from '~/pages/api/integrations/saveIntegrationAccessToken';
export default function CloudflarePagesIntegrationPage() {
const router = useRouter();
const [accessKey, setAccessKey] = useState('');
const [accessKeyErrorText, setAccessKeyErrorText] = useState('');
const [accountId, setAccountId] = useState('');
const [accountIdErrorText, setAccountIdErrorText] = useState('');
const [isLoading, setIsLoading] = useState(false);
const handleButtonClick = async () => {
try {
setAccessKeyErrorText('');
setAccountIdErrorText('');
if (accessKey.length === 0 || accountId.length === 0) {
if (accessKey.length === 0) setAccessKeyErrorText('Access key cannot be blank!');
if (accountId.length === 0) setAccountIdErrorText('Account ID cannot be blank!');
return;
}
setIsLoading(true);
const integrationAuth = await saveIntegrationAccessToken({
workspaceId: localStorage.getItem('projectData.id'),
integration: 'cloudflare-pages',
accessId: accessKey,
accessToken: accountId,
url: null,
namespace: null
});
setAccessKey('');
setAccountId('');
setIsLoading(false);
router.push(`/integrations/cloudflare-pages/create?integrationAuthId=${integrationAuth._id}`);
} catch (err) {
console.error(err);
}
}
return (
<div className="flex h-full w-full items-center justify-center">
<Card className="max-w-lg rounded-md border border-mineshaft-600 mb-12">
<CardTitle className="text-left px-6" subTitle="After adding your API-key, you will be prompted to set up an integration for a particular Infisical project and environment.">Cloudflare Pages Integration</CardTitle>
<FormControl
label="Cloudflare Pages API token"
errorText={accessKeyErrorText}
isError={accessKeyErrorText !== '' ?? false}
className="mx-6"
>
<Input
placeholder=""
value={accessKey}
onChange={(e) => setAccessKey(e.target.value)}
/>
</FormControl>
<FormControl
label="Cloudflare Pages Account ID"
errorText={accountIdErrorText}
isError={accountIdErrorText !== '' ?? false}
className="mx-6"
>
<Input
placeholder=""
value={accountId}
onChange={(e) => setAccountId(e.target.value)}
/>
</FormControl>
<Button
onClick={handleButtonClick}
color="mineshaft"
variant="outline_bg"
className="mb-6 mt-2 ml-auto mr-6 w-min"
isFullWidth={false}
isLoading={isLoading}
>
Connect to Cloudflare Pages
</Button>
</Card>
</div>
);
}
CloudflarePagesIntegrationPage.requireAuth = true;