From ed75d853a46c32a7b8a3910fa7d030a331c1c34a Mon Sep 17 00:00:00 2001 From: shreddedbacon Date: Wed, 15 Nov 2023 09:55:07 +1100 Subject: [PATCH 1/2] refactor: send organization information in build and task payloads --- node-packages/commons/src/api.ts | 28 +++++++++++++++++++++++- node-packages/commons/src/tasks.ts | 35 +++++++++++++++++++++++++++--- 2 files changed, 59 insertions(+), 4 deletions(-) diff --git a/node-packages/commons/src/api.ts b/node-packages/commons/src/api.ts index 2bd3866ab0..f88ec4517e 100644 --- a/node-packages/commons/src/api.ts +++ b/node-packages/commons/src/api.ts @@ -1140,6 +1140,7 @@ export const getOpenShiftInfoForProject = (project: string): Promise => { project:projectByName(name: "${project}"){ id + organization openshift { ...${deployTargetMinimalFragment} } @@ -1256,7 +1257,7 @@ export const getEnvironmentsForProject = ( } `); -export async function getOrganizationById(id: number): Promise { +export async function getOrganizationByIdWithEnvs(id: number): Promise { const result = await graphqlapi.query(` { organization:organizationById(id: ${id}) { @@ -1268,6 +1269,7 @@ export async function getOrganizationById(id: number): Promise { quotaEnvironment quotaGroup quotaNotification + quotaRoute environments { name id @@ -1288,6 +1290,30 @@ export async function getOrganizationById(id: number): Promise { return result.organization; } +export async function getOrganizationById(id: number): Promise { + const result = await graphqlapi.query(` + { + organization:organizationById(id: ${id}) { + id + name + friendlyName + description + quotaProject + quotaEnvironment + quotaGroup + quotaRoute + quotaNotification + } + } + `); + + if (!result || !result.organization) { + throw new OrganizationNotFound(`Cannot find organization ${id}`); + } + + return result.organization; +} + export const setEnvironmentServices = ( environment: number, services: string[] diff --git a/node-packages/commons/src/tasks.ts b/node-packages/commons/src/tasks.ts index 3be8efba20..1ad8bac361 100644 --- a/node-packages/commons/src/tasks.ts +++ b/node-packages/commons/src/tasks.ts @@ -18,6 +18,7 @@ import { addDeployment, Project, DeployTarget, + getOrganizationByIdWithEnvs, getOrganizationById } from './api'; import { @@ -601,13 +602,23 @@ export const getControllerBuildData = async function(deployData: any) { // encode some values so they get sent to the controllers nicely const sshKeyBase64 = new Buffer(deployPrivateKey.replace(/\\n/g, "\n")).toString('base64') const [routerPattern, envVars, projectVars] = await getEnvironmentsRouterPatternAndVariables( - result.project, + lagoonProjectData, environment.addOrUpdateEnvironment, deployTarget.openshift, bulkId, bulkName, buildPriority, buildVariables, bulkType.Deploy ) + let organization = {} + if (lagoonProjectData.organization != null) { + const curOrg = await getOrganizationById(lagoonProjectData.organization); + organization = { + name: curOrg.name, + id: curOrg.id, + } + } + + // this is what will be returned and sent to the controllers via message queue, it is the lagoonbuild controller spec var buildDeployData: any = { metadata: { @@ -631,6 +642,7 @@ export const getControllerBuildData = async function(deployData: any) { project: { id: lagoonProjectData.id, name: projectName, + organization: organization, gitUrl: gitUrl, uiLink: deployment.addDeployment.uiLink, environment: environmentName, @@ -704,7 +716,7 @@ export const getEnvironmentsRouterPatternAndVariables = async function name( if (project.organization) { // check the environment quota, this prevents environments being deployed by the api or webhooks const curOrg = await getOrganizationById(project.organization); - project.envVariables.push({"name":"LAGOON_ROUTE_QUOTA", "value":curOrg.quotaRoute.toString(), "scope":"internal_system"}) + project.envVariables.push({"name":"LAGOON_ROUTE_QUOTA", "value":`"${curOrg.quotaRoute}"`, "scope":"internal_system"}) } // handle any bulk deploy related injections here @@ -771,7 +783,7 @@ export const createDeployTask = async function(deployData: any) { // if this would be a new environment, check it against the environment quota if (!environments.project.environments.map(e => e.name).find(i => i === branchName)) { // check the environment quota, this prevents environments being deployed by the api or webhooks - const curOrg = await getOrganizationById(project.organization); + const curOrg = await getOrganizationByIdWithEnvs(project.organization); if (curOrg.environments.length >= curOrg.quotaEnvironment && curOrg.quotaEnvironment != -1) { throw new OrganizationEnvironmentLimit( `'${branchName}' would exceed organization environment quota: ${curOrg.environments.length}/${curOrg.quotaEnvironment}` @@ -1161,6 +1173,15 @@ export const createTaskTask = async function(taskData: any) { environment: envVars, } + if (project.organization != null) { + const curOrg = await getOrganizationById(project.organization); + const organization = { + name: curOrg.name, + id: curOrg.id, + } + taskData.project.organization = organization + } + if (typeof projectSystem.activeSystemsTask === 'undefined') { throw new UnknownActiveSystem( `No active system for 'task' for project ${project.name}` @@ -1379,6 +1400,14 @@ export const createMiscTask = async function(taskData: any) { break; } // send the task to the queue + if (project.organization != null) { + const curOrg = await getOrganizationById(project.organization); + const organization = { + name: curOrg.name, + id: curOrg.id, + } + miscTaskData.project.organization = organization + } return sendToLagoonTasks(deployTarget+':misc', miscTaskData); default: break; From fafeaaadebed8507a208b1101c9bb2c9ccaced67 Mon Sep 17 00:00:00 2001 From: shreddedbacon Date: Tue, 12 Dec 2023 17:16:55 +1100 Subject: [PATCH 2/2] fix: set organization to null initially --- node-packages/commons/src/tasks.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/node-packages/commons/src/tasks.ts b/node-packages/commons/src/tasks.ts index 186238a0d2..9af665f082 100644 --- a/node-packages/commons/src/tasks.ts +++ b/node-packages/commons/src/tasks.ts @@ -609,7 +609,7 @@ export const getControllerBuildData = async function(deployData: any) { bulkType.Deploy ) - let organization = {} + let organization = null; if (lagoonProjectData.organization != null) { const curOrg = await getOrganizationById(lagoonProjectData.organization); organization = {