Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP: Move to tofu controller #878

Open
wants to merge 48 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
0726993
Moving to tofu-controller
laszlocph Sep 18, 2024
088dd10
Databases editor
laszlocph Sep 21, 2024
74ed3e5
WIP
laszlocph Sep 24, 2024
23e023f
Merge branch 'main' into move-to-tofu-controller
laszlocph Sep 25, 2024
b9b169e
Merge remote-tracking branch 'origin/main' into move-to-tofu-controller
laszlocph Sep 26, 2024
edb6ebc
Helm UI css improvements
laszlocph Sep 26, 2024
9d28d66
removed excess css
laszlocph Sep 26, 2024
99734ba
experimenting with helm ui
laszlocph Sep 26, 2024
b437932
schema preps
laszlocph Sep 26, 2024
413588d
minor thing
laszlocph Sep 26, 2024
6c46ba2
wip
laszlocph Sep 26, 2024
f4779cc
dependencies inner state
laszlocph Sep 26, 2024
c032c41
combobox with module title
laszlocph Sep 26, 2024
a4389d1
module selector done
laszlocph Sep 26, 2024
3b5f38d
wip
laszlocph Sep 26, 2024
81fd58d
add and remove dependencies
laszlocph Sep 27, 2024
b0be881
populating depenencies
laszlocph Sep 27, 2024
fccaf9e
Pod names shown
laszlocph Sep 27, 2024
cf4bd06
rendering plain modules
laszlocph Sep 27, 2024
a888d10
rendering plain modules
laszlocph Sep 27, 2024
4b4fbf3
unused
laszlocph Sep 30, 2024
e365cd7
modelling belongsTo relationship
laszlocph Sep 30, 2024
2b33049
Merge remote-tracking branch 'origin/main' into move-to-tofu-controller
laszlocph Oct 9, 2024
5c86c21
Fix
laszlocph Oct 9, 2024
752ad10
monkeypatch podLogs call that was deployment based to take a faked de…
laszlocph Oct 10, 2024
5b03440
PlainSpec
laszlocph Oct 10, 2024
c88d0ba
unified deps
laszlocph Oct 13, 2024
fb670a1
Catalog
laszlocph Oct 14, 2024
b2afbe1
Baby steps
laszlocph Oct 14, 2024
bfa7958
model change
laszlocph Oct 14, 2024
dc499b5
chart.repository to contain git urls
laszlocph Oct 14, 2024
8001b53
Iteration
laszlocph Oct 14, 2024
3031a89
Iteration
laszlocph Oct 14, 2024
df6f302
Updating catalog
laszlocph Oct 15, 2024
bba0cc1
Terraform resources
laszlocph Oct 16, 2024
c62d3ed
Refactoring prop stuffing
laszlocph Oct 16, 2024
4e3fa6b
Refactoring intermediate model
laszlocph Oct 16, 2024
0d8088d
Terraform state streaming
laszlocph Oct 16, 2024
cbb93a6
Navigate to footer
laszlocph Oct 16, 2024
8c19ecb
Fixing ellipsis
laszlocph Oct 17, 2024
867d3dd
Refactor describe
laszlocph Oct 17, 2024
983556f
Describing tf resourece
laszlocph Oct 17, 2024
862aff4
Describing tf resourece
laszlocph Oct 17, 2024
675f07b
TF reconciling state
laszlocph Oct 18, 2024
48240c1
..
laszlocph Oct 19, 2024
ae49dab
Prevent duplicates
laszlocph Oct 19, 2024
422eafc
More robust org token manager
laszlocph Nov 7, 2024
11ee5a8
More robust local dev experience
laszlocph Nov 12, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Merge remote-tracking branch 'origin/main' into move-to-tofu-controller
  • Loading branch information
laszlocph committed Oct 9, 2024
commit 2b33049ff09f35e5e8917dca1de42001f82ae2d2
192 changes: 55 additions & 137 deletions web/src/views/envConfig/envConfig.jsx
Original file line number Diff line number Diff line change
@@ -7,12 +7,14 @@ import ImageWidget from "./imageWidget";
import SealedSecretWidget from "./sealedSecretWidget";
import * as Diff from "diff";
import { Generaltab, templateIdentity } from './generalTab';
import { DatabasesTab } from './databasesTab';
import { Modal } from '../../components/modal'
import { ArrowTopRightOnSquareIcon, FolderIcon } from '@heroicons/react/24/solid';
import IngressWidget from "../envConfig/ingressWidget";
import { useNavigate, useLocation, useParams } from 'react-router-dom'
import {produce} from 'immer';
import { toast } from 'react-toastify';
import { InProgress, Success, Error } from '../../popUpWindow';
import { DatabasesTab } from './databasesTab';
import { produce } from 'immer';

export function EnvConfig(props) {
const { store, gimletClient } = props
@@ -98,7 +100,6 @@ export function EnvConfig(props) {
.then(data => {
setPlainModules(data)
}, () => {/* Generic error handler deals with it */ });

// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

@@ -153,6 +154,20 @@ export function EnvConfig(props) {
}))
}

const setDependencies = (dependencies) => {
if (dependencies.length === 0) {
setConfigFile(produce(configFile, draft => {
delete draft.dependencies
}))
return
}

setConfigFile(prevState => ({
...prevState,
dependencies: dependencies,
}));
}

const setDeployFilter = (filter) => {
setConfigFile(prevState => {
if (prevState.deploy.event === "tag") {
@@ -207,44 +222,6 @@ export function EnvConfig(props) {
}));
}

const setDependencies = (dependencies) => {
if (dependencies.length === 0) {
setConfigFile(produce(configFile, draft => {
delete draft.dependencies
}))
return
}

setConfigFile(prevState => ({
...prevState,
dependencies: dependencies,
}));
}

const resetNotificationStateAfterThreeSeconds = () => {
setTimeout(() => {
store.dispatch({
type: ACTION_TYPE_POPUPWINDOWRESET
});
}, 3000);
}

const startApiCallTimeOutHandler = () => {
const timeoutTimer = setTimeout(() => {
if (popupWindow.visible) {
store.dispatch({
type: ACTION_TYPE_POPUPWINDOWERROR, payload: {
header: "Error",
message: "Saving failed: The process has timed out."
}
});
resetNotificationStateAfterThreeSeconds()
}
}, 60000);

setTimeoutTimer(timeoutTimer)
}

const save = () => {
if (errors) {
errors.forEach(e => toast.warn(e.message), {
@@ -253,12 +230,12 @@ export function EnvConfig(props) {
return
}

progressToastId.current = toast(<InProgress header="Saving..."/>, { autoClose: false });
progressToastId.current = toast(<InProgress header="Saving..." />, { autoClose: false });

gimletClient.saveEnvConfig(owner, repo, env, encodeURIComponent(config), configFile)
.then((data) => {
toast.update(progressToastId.current, {
render: <Success header="Configuration Saved" message={<div className='pb-4'>Deploy it on <span className='underline cursor-pointer' onClick={()=>navigate(`/repo/${owner}/${repo}/commits`)}>Commits view</span></div>} link={data.link}/>,
render: <Success header="Configuration Saved" message={<div className='pb-4'>Deploy it on <span className='underline cursor-pointer' onClick={() => navigate(`/repo/${owner}/${repo}/commits`)}>Commits view</span></div>} link={data.link} />,
className: "bg-green-50 shadow-lg p-2",
bodyClassName: "p-2",
});
@@ -271,7 +248,7 @@ export function EnvConfig(props) {
window.scrollTo({ top: 0, left: 0 });
}, err => {
toast.update(progressToastId.current, {
render: <Error header="Error" message={err.data?.message ?? err.statusText}/>,
render: <Error header="Error" message={err.data?.message ?? err.statusText} />,
className: "bg-red-50 shadow-lg p-2",
bodyClassName: "p-2",
progressClassName: "!bg-red-200",
@@ -281,12 +258,12 @@ export function EnvConfig(props) {
}

const deleteApp = () => {
progressToastId.current = toast(<InProgress header="Deleting..."/>, { autoClose: false });
progressToastId.current = toast(<InProgress header="Deleting..." />, { autoClose: false });

gimletClient.deleteEnvConfig(owner, repo, env, config)
.then((data) => {
toast.update(progressToastId.current, {
render: <Success header="Configuration deleted" link={data.link}/>,
render: <Success header="Configuration deleted" link={data.link} />,
className: "bg-green-50 shadow-lg p-2",
bodyClassName: "p-2",
});
@@ -295,7 +272,7 @@ export function EnvConfig(props) {
window.scrollTo({ top: 0, left: 0 });
}, err => {
toast.update(progressToastId.current, {
render: <Error header="Error" message={err.data?.message ?? err.statusText}/>,
render: <Error header="Error" message={err.data?.message ?? err.statusText} />,
className: "bg-red-50 shadow-lg p-2",
bodyClassName: "p-2",
progressClassName: "!bg-red-200",
@@ -432,60 +409,17 @@ export function EnvConfig(props) {
</div>
<div className="border-b border-neutral-200 dark:border-neutral-700"></div>
</div>
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 pt-2 pb-4 flex items-center">
{fileInfo &&
<a className="externalLink flex space-x-1 text-sm font-mono font-thin items-center text-neutral-500" href={`${scmUrl}/${repoName}/blob/${fileInfo.branch}/.gimlet/${encodeURIComponent(fileInfo.fileName)}`} target="_blank" rel="noopener noreferrer">
<FolderIcon className="externalLinkIcon" aria-hidden="true" />
<span>{`.gimlet/${fileInfo.fileName}`}</span>
<ArrowTopRightOnSquareIcon className="externalLinkIcon" aria-hidden="true" />
</a>
}
</div>
<div className="border-b border-neutral-200 dark:border-neutral-700"></div>
</div>
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 flex pt-56">
<div className="sticky top-0 h-96 top-56">
<SideBar
navigation={navigation}
selected={selectedNavigation}
/>
</div>
<div className="w-full ml-14">
{ (!selectedNavigation || selectedNavigation?.name === "General") &&
<Generaltab
config={config}
action={action}
configFile={configFile}
setAppName={setAppName}
setNamespace={setNamespace}
deleteApp={deleteApp}
toggleDeployPolicy={toggleDeployPolicy}
setDeployEvent = {setDeployEvent}
setDeployFilter = {setDeployFilter}
templates = {templates}
selectedTemplate={patchedTemplate}
setDeploymentTemplate={setDeploymentTemplate}
preview={preview}
/>
}
{ selectedNavigation && selectedNavigation.name !== "General"
&& selectedNavigation.name !== "Containerized Dependencies"
&& selectedNavigation.name !== "Cloud Dependencies" &&
<>
<div className='w-full card p-6 pb-8'>
<HelmUI
key={`helmui-${selectedNavigation.name}`}
schema={patchedTemplate.schema}
config={[patchedTemplate.uiSchema[selectedNavigation.uiSchemaOrder]]}
fields={customFields}
values={configFile.values}
setValues={setValues}
validate={true}
validationCallback={validationCallback}
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8 flex pt-56">
<div className="sticky top-0 h-96 top-56">
<SideBar
navigation={navigation}
selected={selectedNavigation}
/>
</div>
<div className="w-full ml-14">
{(!selectedNavigation || selectedNavigation?.name === "General") &&
{selectedNavigation && selectedNavigation.name !== "General"
&& selectedNavigation.name !== "Containerized Dependencies"
&& selectedNavigation.name !== "Cloud Dependencies" &&
<Generaltab
config={config}
action={action}
@@ -543,44 +477,28 @@ export function EnvConfig(props) {
}
</>
}
{selectedNavigation.name === "Secrets" &&
<div className='-mt-2 learnMoreBox'>
Learn more about <a href="https://gimlet.io/docs/deployment-settings/secrets" className='learnMoreLink'>Encrypted Secrets <ArrowTopRightOnSquareIcon className="externalLinkIcon" aria-hidden="true" /></a>
</div>
}
{selectedNavigation.name === "Resources" &&
<div className='-mt-2 learnMoreBox'>
Learn more about <a href="https://gimlet.io/docs/deployment-settings/resource-usage" className='learnMoreLink'>Resource Usage <ArrowTopRightOnSquareIcon className="externalLinkIcon" aria-hidden="true" /></a>
</div>
{selectedNavigation?.name === "Containerized Dependencies" &&
<DatabasesTab
gimletClient={gimletClient}
store={store}
app={configFile.app}
environment={env}
plainModules={plainModules}
configFileDependencies={configFile.dependencies}
setConfigFileDependencies={setDependencies}
/>
}
{selectedNavigation.name === "Volumes" &&
<div className='-mt-2 learnMoreBox'>
Learn more about <a href="https://gimlet.io/docs/deployment-settings/volumes" className='learnMoreLink'>Volumes <ArrowTopRightOnSquareIcon className="externalLinkIcon" aria-hidden="true" /></a>
</div>
{selectedNavigation?.name === "Cloud Dependencies" &&
<DatabasesTab
gimletClient={gimletClient}
store={store}
app={configFile.app}
environment={env}
configFileDependencies={configFile.dependencies}
setConfigFileDependencies={setDependencies}
/>
}
</>
}
{ selectedNavigation?.name === "Containerized Dependencies" &&
<DatabasesTab
gimletClient={gimletClient}
store={store}
app={configFile.app}
environment={env}
plainModules={plainModules}
configFileDependencies={configFile.dependencies}
setConfigFileDependencies={setDependencies}
/>
}
{ selectedNavigation?.name === "Cloud Dependencies" &&
<DatabasesTab
gimletClient={gimletClient}
store={store}
app={configFile.app}
environment={env}
configFileDependencies={configFile.dependencies}
setConfigFileDependencies={setDependencies}
/>
}
</div>
</div>
</>
);
@@ -735,9 +653,9 @@ export const extractIngressAnnotations = (stackConfig, stackDefinition) => {
}

function translateToNavigation(template) {
const navigation = template.uiSchema.map((elem, idx) => ({name: elem.metaData.name, href: ref(elem.metaData.name), uiSchemaOrder: idx}))
navigation.unshift({name: "General", href: "/general"})
navigation.push({name: "Containerized Dependencies", href: "/containerized-databases"})
const navigation = template.uiSchema.map((elem, idx) => ({ name: elem.metaData.name, href: ref(elem.metaData.name), uiSchemaOrder: idx }))
navigation.unshift({ name: "General", href: "/general" })
navigation.push({ name: "Containerized Dependencies", href: "/containerized-databases" })
// navigation.push({name: "Cloud Dependencies", href: "/cloud-databases"})
return navigation
}
Loading
You are viewing a condensed version of this merge commit. You can view the full changes here.