Skip to content

Commit

Permalink
✨ Refactored cloud provider
Browse files Browse the repository at this point in the history
  • Loading branch information
abdheshnayak committed Mar 10, 2024
1 parent a0fb64a commit fd0fce8
Show file tree
Hide file tree
Showing 15 changed files with 506 additions and 233 deletions.
4 changes: 2 additions & 2 deletions Taskfile.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ tasks:
interactive: true
cmds:
- |
BASE_URL=dev.kloudlite.io
BASE_URL=gcp-production.kloudlite.io
COOKIE_DOMAIN=".kloudlite.io"
GATEWAY_URL="http://gateway.kloudlite.svc.cluster.local"
case {{.app}} in
Expand Down Expand Up @@ -55,7 +55,7 @@ tasks:
esac
REMIX_DEV_ORIGIN="https://{{.app}}$URL_SUFFIX.dev.kloudlite.io"
REMIX_DEV_ORIGIN="https://{{.app}}$URL_SUFFIX.$BASE_URL"
cp -r ./static/common/. ./public/
cp -r ./static/{{.app}}/. ./public/
Expand Down
26 changes: 4 additions & 22 deletions gql-queries-generator/doc/queries.graphql
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ query consoleGetAccount($accountName: String!) {
name
annotations
}
targetNamespace
updateTime
contactEmail
displayName
Expand Down Expand Up @@ -300,10 +301,6 @@ query consoleListClusters($search: SearchCluster, $pagination: CursorPaginationI
spec {
messageQueueTopicName
kloudliteRelease
credentialsRef {
namespace
name
}
clusterTokenRef {
key
name
Expand Down Expand Up @@ -398,18 +395,6 @@ query consoleGetCluster($name: String!) {
name
namespace
}
credentialKeys {
keyAccessKey
keyAWSAccountId
keyAWSAssumeRoleExternalID
keyAWSAssumeRoleRoleARN
keyIAMInstanceProfileRole
keySecretKey
}
credentialsRef {
name
namespace
}
kloudliteRelease
messageQueueTopicName
output {
Expand Down Expand Up @@ -480,15 +465,15 @@ query consoleListProviderSecrets($search: SearchProviderSecret, $pagination: Cur
edges {
cursor
node {
aws {
awsAccountId
}
cloudProviderName
createdBy {
userEmail
userId
userName
}
aws {
authMechanism
}
creationTime
displayName
lastUpdatedBy {
Expand Down Expand Up @@ -528,9 +513,6 @@ mutation consoleDeleteProviderSecret($secretName: String!) {

query consoleGetProviderSecret($name: String!) {
infra_getProviderSecret(name: $name) {
aws {
awsAccountId
}
cloudProviderName
createdBy {
userEmail
Expand Down
4 changes: 2 additions & 2 deletions src/apps/console/components/code-view.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ interface ICodeView {
const CodeView = ({
data,
copy,
showShellPrompt,
showShellPrompt: _,
language = 'shell',
title,
}: ICodeView) => {
Expand Down Expand Up @@ -55,7 +55,7 @@ const CodeView = ({
}}
className="group/sha cursor-pointer p-lg rounded-md bodyMd flex flex-row gap-xl items-center hljs w-full"
>
<pre className="flex-1">
<pre className="flex-1 overflow-auto">
<code ref={ref}>{data}</code>
</pre>

Expand Down
15 changes: 11 additions & 4 deletions src/apps/console/page-components/new-cluster.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useNavigate, useParams } from '@remix-run/react';
import { useNavigate, useOutletContext, useParams } from '@remix-run/react';
import { useMemo, useState } from 'react';
import Select from '~/components/atoms/select';
import { toast } from '~/components/molecule/toast';
Expand Down Expand Up @@ -28,6 +28,7 @@ import MultiStepProgressWrapper from '../components/multi-step-progress-wrapper'
import { TitleBox } from '../components/raw-wrapper';
import { BottomNavigation, ReviewComponent } from '../components/commons';
import FillerCluster from '../assets/filler-cluster';
import { IAccountContext } from '../routes/_main+/$account+/_layout';

type props =
| {
Expand All @@ -50,6 +51,8 @@ export const NewCluster = ({ providerSecrets, cloudProvider }: props) => {
[providerSecrets]
);

const { account } = useOutletContext<IAccountContext>();

const options = useMapper(cloudProviders, (provider) => ({
value: parseName(provider),
label: provider.displayName,
Expand Down Expand Up @@ -122,15 +125,19 @@ export const NewCluster = ({ providerSecrets, cloudProvider }: props) => {
spec: {
cloudProvider: validateClusterCloudProvider(val.cloudProvider),
aws: {
credentials: {
authMechanism: 'secret_keys',
secretRef: {
name: val.credentialsRef,
namespace: account.targetNamespace,
},
},
region: selectedRegion.Name,
k3sMasters: {
nvidiaGpuEnabled: true,
instanceType: 'c6a.xlarge',
},
},
credentialsRef: {
name: val.credentialsRef,
},
availabilityMode: validateAvailabilityMode(
val.availabilityMode
),
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
/* eslint-disable react/no-unescaped-entities */
/* eslint-disable no-nested-ternary */
import { IRemixCtx } from '~/root/lib/types/common';
import { useLoaderData, useNavigate, useOutletContext } from '@remix-run/react';
import { defer } from '@remix-run/node';
Expand All @@ -22,6 +20,10 @@ import MultiStepProgress, {
} from '~/console/components/multi-step-progress';
import { Check } from '~/console/components/icons';
import { BottomNavigation } from '~/console/components/commons';
import useForm from '~/root/lib/client/hooks/use-form';
import Yup from '~/root/lib/server/helpers/yup';
import { PasswordInput } from '~/components/atoms/input';
import FillerCloudProvider from '~/console/assets/filler-cloud-provider';
import { IAccountContext } from '../../../../_main+/$account+/_layout';

export const loader = async (ctx: IRemixCtx) => {
Expand Down Expand Up @@ -64,25 +66,90 @@ const Validator = ({ cloudProvider }: { cloudProvider: any }) => {
const [isLoading, setIsLoading] = useState(false);

const { data, isLoading: il } = useCustomSwr(
() => cloudProvider.metadata!.name + isLoading,
() => parseName(cloudProvider) + isLoading,
async () => {
if (!cloudProvider.metadata!.name) {
if (!parseName(cloudProvider.metadata!.name)) {
throw new Error('Invalid cloud provider name');
}
return api.checkAwsAccess({
cloudproviderName: cloudProvider.metadata.name,
cloudproviderName: parseName(cloudProvider),
});
}
);

const { values, handleChange, errors, handleSubmit } = useForm({
initialValues: {
accessKey: '',
secretKey: '',
},
validationSchema: Yup.object({
accessKey: Yup.string().test(
'provider',
'access key is required',
// @ts-ignores
// eslint-disable-next-line react/no-this-in-sfc
function (item) {
return data?.result || item;
}
),
secretKey: Yup.string().test(
'provider',
'secret key is required',
// eslint-disable-next-line func-names
// @ts-ignore
function (item) {
return data?.result || item;
}
),
}),
onSubmit: async (val) => {
if (data?.result) {
navigate(
`/onboarding/${parseName(account)}/${parseName(
cloudProvider
)}/new-cluster`
);
return;
}

try {
const { errors } = await api.updateProviderSecret({
secret: {
metadata: {
name: parseName(cloudProvider),
},
cloudProviderName: cloudProvider.cloudProviderName,
displayName: cloudProvider.displayName,
aws: {
authMechanism: 'secret_keys',
authSecretKeys: {
accessKey: val.accessKey,
secretKey: val.secretKey,
},
},
},
});

if (errors) {
throw errors[0];
}

setIsLoading((s) => !s);
} catch (err) {
handleError(err);
}
},
});

const { currentStep, jumpStep } = useMultiStepProgress({
defaultStep: 3,
totalSteps: 4,
});

return (
<form>
<div>
<MultiStepProgressWrapper
fillerImage={<FillerCloudProvider />}
title="Setup your account!"
subTitle="Simplify Collaboration and Enhance Productivity with Kloudlite
teams"
Expand All @@ -101,10 +168,11 @@ const Validator = ({ cloudProvider }: { cloudProvider: any }) => {
/>
<MultiStepProgress.Step step={2} label="Add your cloud provider" />
<MultiStepProgress.Step step={3} label="Validate cloud provider">
<div className="flex flex-col gap-3xl">
<form className="flex flex-col gap-3xl" onSubmit={handleSubmit}>
<div className="bodyMd text-text-soft">
Validate your cloud provider's credentials
Validate your cloud provider&apos;s credentials
</div>
{/* eslint-disable-next-line no-nested-ternary */}
{il ? (
<div className="py-2xl">
<LoadingPlaceHolder
Expand All @@ -121,9 +189,11 @@ const Validator = ({ cloudProvider }: { cloudProvider: any }) => {
) : (
<div className="flex flex-col gap-3xl p-xl border border-border-default rounded">
<div className="flex gap-xl items-center">
<span>Account ID</span>
<span className="bodyLg-medium">
{cloudProvider.displayName}
</span>
<span className="bodyMd-semibold text-text-primary">
{cloudProvider.aws?.awsAccountId}
({parseName(cloudProvider)})
</span>
</div>
<div className="flex flex-col gap-2xl text-start">
Expand Down Expand Up @@ -161,27 +231,65 @@ const Validator = ({ cloudProvider }: { cloudProvider: any }) => {
to create AWS cloudformation stack
</span>
</div>

{!data?.result && (
<>
<div className="">
Once you have created the cloudformation stack, please
enter the access key and secret key below to validate
your cloud Provider, you can get the access key and
secret key from the output of the cloudformation stack.
</div>

<PasswordInput
name="accessKey"
onChange={handleChange('accessKey')}
error={!!errors.accessKey}
message={errors.accessKey}
value={values.accessKey}
label="Access Key"
/>

<PasswordInput
name="secretKey"
onChange={handleChange('secretKey')}
error={!!errors.secretKey}
message={errors.secretKey}
value={values.secretKey}
label="Secret Key"
/>
</>
)}
</div>
)}
<BottomNavigation
secondaryButton={
data?.result
? undefined
: {
variant: 'primary',
content: 'Skip',
onClick: () => {
navigate(
`/onboarding/${parseName(account)}/${parseName(
cloudProvider
)}/new-cluster`
);
},
}
}
primaryButton={{
variant: 'primary',
content: data?.result ? 'Next' : 'Skip',
onClick: () => {
navigate(
`/onboarding/${parseName(account)}/${parseName(
cloudProvider
)}/new-cluster`
);
},
content: data?.result ? 'Continue' : 'Update',
type: 'submit',
}}
/>
</div>
</form>
</MultiStepProgress.Step>
<MultiStepProgress.Step step={4} label="Setup first cluster" />
</MultiStepProgress.Root>
</MultiStepProgressWrapper>
</form>
</div>
);
};

Expand Down
Loading

0 comments on commit fd0fce8

Please sign in to comment.