Skip to content

Commit

Permalink
Move existing integration authorization and creation into separate steps
Browse files Browse the repository at this point in the history
  • Loading branch information
dangtony98 committed Feb 7, 2023
1 parent 5ea5887 commit 679b1d9
Show file tree
Hide file tree
Showing 32 changed files with 1,765 additions and 427 deletions.
40 changes: 32 additions & 8 deletions backend/src/controllers/v1/integrationAuthController.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,31 @@ import { INTEGRATION_SET, INTEGRATION_OPTIONS } from '../../variables';
import { IntegrationService } from '../../services';
import { getApps, revokeAccess } from '../../integrations';

/***
* Return integration authorization with id [integrationAuthId]
*/
export const getIntegrationAuth = async (req: Request, res: Response) => {
let integrationAuth;
try {
const { integrationAuthId } = req.params;
integrationAuth = await IntegrationAuth.findById(integrationAuthId);

if (!integrationAuth) return res.status(400).send({
message: 'Failed to find integration authorization'
});
} catch (err) {
Sentry.setUser({ email: req.user.email });
Sentry.captureException(err);
return res.status(400).send({
message: 'Failed to get integration authorization'
});
}

return res.status(200).send({
integrationAuth
});
}

export const getIntegrationOptions = async (
req: Request,
res: Response
Expand All @@ -31,7 +56,6 @@ export const oAuthExchange = async (
) => {
try {
const { workspaceId, code, integration } = req.body;

if (!INTEGRATION_SET.has(integration))
throw new Error('Failed to validate integration');

Expand Down Expand Up @@ -81,6 +105,13 @@ export const saveIntegrationAccessToken = async (
integration: string;
} = req.body;

const bot = await Bot.findOne({
workspace: new Types.ObjectId(workspaceId),
isActive: true
});

if (!bot) throw new Error('Bot must be enabled to save integration access token');

integrationAuth = await IntegrationAuth.findOneAndUpdate({
workspace: new Types.ObjectId(workspaceId),
integration
Expand All @@ -91,13 +122,6 @@ export const saveIntegrationAccessToken = async (
new: true,
upsert: true
});

const bot = await Bot.findOne({
workspace: new Types.ObjectId(workspaceId),
isActive: true
});

if (!bot) throw new Error('Bot must be enabled to save integration access token');

// encrypt and save integration access token
integrationAuth = await IntegrationService.setIntegrationAuthAccess({
Expand Down
15 changes: 13 additions & 2 deletions backend/src/controllers/v1/integrationController.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,23 +24,34 @@ export const createIntegration = async (req: Request, res: Response) => {
app,
appId,
isActive,
sourceEnvironment,
targetEnvironment,
owner
} = req.body;

// TODO: validate [sourceEnvironment] and [targetEnvironment]

// initialize new integration after saving integration access token
integration = await new Integration({
workspace: req.integrationAuth.workspace._id,
environment: req.integrationAuth.workspace?.environments[0].slug,
environment: sourceEnvironment,
isActive,
app,
appId,
targetEnvironment,
owner,
integration: req.integrationAuth.integration,
integrationAuth: new Types.ObjectId(integrationAuthId)
}).save();

// TODO: run sync function
if (integration) {
// trigger event - push secrets
EventService.handleEvent({
event: eventPushSecrets({
workspaceId: integration.workspace.toString()
})
});
}

} catch (err) {
Sentry.setUser({ email: req.user.email });
Expand Down
12 changes: 0 additions & 12 deletions backend/src/helpers/integration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,9 +43,7 @@ const handleOAuthExchangeHelper = async ({
code: string;
environment: string;
}) => {
let action;
let integrationAuth;
// let newIntegration;
try {
const bot = await Bot.findOne({
workspace: workspaceId,
Expand Down Expand Up @@ -100,16 +98,6 @@ const handleOAuthExchangeHelper = async ({
accessExpiresAt: res.accessExpiresAt
});
}

// // initialize new integration after exchange
// newIntegration = await new Integration({
// workspace: workspaceId,
// isActive: false,
// app: null,
// environment,
// integration,
// integrationAuth: integrationAuth._id
// }).save();
} catch (err) {
Sentry.setUser(null);
Sentry.captureException(err);
Expand Down
8 changes: 4 additions & 4 deletions backend/src/integrations/exchange.ts
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ const exchangeCodeAzure = async ({
scope: 'https://vault.azure.net/.default openid offline_access', // TODO: do we need all these permissions?
client_id: CLIENT_ID_AZURE,
client_secret: CLIENT_SECRET_AZURE,
redirect_uri: `${SITE_URL}/azure-key-vault`
redirect_uri: `${SITE_URL}/integrations/azure-key-vault/oauth2/callback`
} as any)
)).data;

Expand Down Expand Up @@ -227,7 +227,7 @@ const exchangeCodeVercel = async ({ code }: { code: string }) => {
code: code,
client_id: CLIENT_ID_VERCEL,
client_secret: CLIENT_SECRET_VERCEL,
redirect_uri: `${SITE_URL}/vercel`
redirect_uri: `${SITE_URL}/integrations/vercel/oauth2/callback`
} as any)
)
).data;
Expand Down Expand Up @@ -267,7 +267,7 @@ const exchangeCodeNetlify = async ({ code }: { code: string }) => {
code: code,
client_id: CLIENT_ID_NETLIFY,
client_secret: CLIENT_SECRET_NETLIFY,
redirect_uri: `${SITE_URL}/netlify`
redirect_uri: `${SITE_URL}/integrations/netlify/oauth2/callback`
} as any)
)
).data;
Expand Down Expand Up @@ -319,7 +319,7 @@ const exchangeCodeGithub = async ({ code }: { code: string }) => {
client_id: CLIENT_ID_GITHUB,
client_secret: CLIENT_SECRET_GITHUB,
code: code,
redirect_uri: `${SITE_URL}/github`
redirect_uri: `${SITE_URL}/integrations/github/oauth2/callback`
},
headers: {
Accept: 'application/json'
Expand Down
2 changes: 0 additions & 2 deletions backend/src/integrations/sync.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,7 @@
import axios from 'axios';
import * as Sentry from '@sentry/node';
import { Octokit } from '@octokit/rest';
// import * as sodium from 'libsodium-wrappers';
import sodium from 'libsodium-wrappers';
// const sodium = require('libsodium-wrappers');
import { IIntegration, IIntegrationAuth } from '../models';
import {
INTEGRATION_AZURE_KEY_VAULT,
Expand Down
1 change: 1 addition & 0 deletions backend/src/routes/v1/integration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ router.post( // new: add new integration for integration auth
body('app').isString().trim(),
body('isActive').exists().isBoolean(),
body('appId').trim(),
body('sourceEnvironment').trim(),
body('targetEnvironment').trim(),
body('owner').trim(),
validateRequest,
Expand Down
13 changes: 13 additions & 0 deletions backend/src/routes/v1/integrationAuth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,19 @@ router.get(
integrationAuthController.getIntegrationOptions
);

router.get(
'/:integrationAuthId',
requireAuth({
acceptedAuthModes: ['jwt']
}),
requireIntegrationAuthorizationAuth({
acceptedRoles: [ADMIN, MEMBER]
}),
param('integrationAuthId'),
validateRequest,
integrationAuthController.getIntegrationAuth
);

router.post(
'/oauth-token',
requireAuth({
Expand Down
Loading

0 comments on commit 679b1d9

Please sign in to comment.