Skip to content

Commit

Permalink
Fix: Requested changes
Browse files Browse the repository at this point in the history
  • Loading branch information
DanielHougaard committed Jun 20, 2024
1 parent 9aa2efc commit 6a9e47a
Show file tree
Hide file tree
Showing 6 changed files with 62 additions and 62 deletions.
1 change: 0 additions & 1 deletion backend/src/server/routes/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -455,7 +455,6 @@ export const registerRoutes = async (
userDAL,
authService: loginService,
serverCfgDAL: superAdminDAL,
orgDAL,
orgService,
keyStore
});
Expand Down
2 changes: 1 addition & 1 deletion backend/src/server/routes/v1/admin-router.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ export const registerAdminRouter = async (server: FastifyZodProvider) => {
allowedSignUpDomain: z.string().optional().nullable(),
trustSamlEmails: z.boolean().optional(),
trustLdapEmails: z.boolean().optional(),
defaultAuthOrgSlug: z.string().optional().nullable()
defaultAuthOrgId: z.string().optional().nullable()
}),
response: {
200: z.object({
Expand Down
26 changes: 20 additions & 6 deletions backend/src/services/super-admin/super-admin-dal.ts
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
import { Knex } from "knex";

import { TDbClient } from "@app/db";
import { TableName, TSuperAdmin } from "@app/db/schemas";
import { TableName, TSuperAdmin, TSuperAdminUpdate } from "@app/db/schemas";
import { ormify } from "@app/lib/knex";

export type TSuperAdminDALFactory = ReturnType<typeof superAdminDALFactory>;

export const superAdminDALFactory = (db: TDbClient) => {
const orm = ormify(db, TableName.SuperAdmin);
const superAdminOrm = ormify(db, TableName.SuperAdmin);

const findById = async (id: string) => {
const config = await db(TableName.SuperAdmin)
const findById = async (id: string, tx?: Knex) => {
const config = await (tx || db)(TableName.SuperAdmin)
.where(`${TableName.SuperAdmin}.id`, id)
.leftJoin(TableName.Organization, `${TableName.SuperAdmin}.defaultAuthOrgId`, `${TableName.Organization}.id`)
.select(
Expand All @@ -23,8 +25,20 @@ export const superAdminDALFactory = (db: TDbClient) => {
} as TSuperAdmin & { defaultAuthOrgSlug: string | null };
};

const updateById = async (id: string, data: TSuperAdminUpdate, tx?: Knex) => {
const updatedConfig = await superAdminOrm.transaction(async (trx) => {
await superAdminOrm.updateById(id, data, tx || trx);
const config = await findById(id, tx || trx);

return config;
});

return updatedConfig;
};

return {
...orm,
findById
...superAdminOrm,
findById,
updateById
};
};
38 changes: 6 additions & 32 deletions backend/src/services/super-admin/super-admin-service.ts
Original file line number Diff line number Diff line change
@@ -1,24 +1,21 @@
import bcrypt from "bcrypt";

import { TOrganizations, TSuperAdmin } from "@app/db/schemas";
import { TSuperAdmin, TSuperAdminUpdate } from "@app/db/schemas";
import { TKeyStoreFactory } from "@app/keystore/keystore";
import { getConfig } from "@app/lib/config/env";
import { infisicalSymmetricEncypt } from "@app/lib/crypto/encryption";
import { getUserPrivateKey } from "@app/lib/crypto/srp";
import { BadRequestError } from "@app/lib/errors";
import { omit } from "@app/lib/fn";

import { TAuthLoginFactory } from "../auth/auth-login-service";
import { AuthMethod } from "../auth/auth-type";
import { TOrgDALFactory } from "../org/org-dal";
import { TOrgServiceFactory } from "../org/org-service";
import { TUserDALFactory } from "../user/user-dal";
import { TSuperAdminDALFactory } from "./super-admin-dal";
import { TAdminSignUpDTO, TUpdateServerCfgDTO } from "./super-admin-types";
import { TAdminSignUpDTO } from "./super-admin-types";

type TSuperAdminServiceFactoryDep = {
serverCfgDAL: TSuperAdminDALFactory;
orgDAL: Pick<TOrgDALFactory, "findOne">;
userDAL: TUserDALFactory;
authService: Pick<TAuthLoginFactory, "generateUserTokens">;
orgService: Pick<TOrgServiceFactory, "createOrganization">;
Expand All @@ -36,7 +33,6 @@ const ADMIN_CONFIG_DB_UUID = "00000000-0000-0000-0000-000000000000";

export const superAdminServiceFactory = ({
serverCfgDAL,
orgDAL,
userDAL,
authService,
orgService,
Expand Down Expand Up @@ -76,33 +72,11 @@ export const superAdminServiceFactory = ({
return newCfg;
};

const updateServerCfg = async (data: TUpdateServerCfgDTO) => {
let organization: TOrganizations | undefined;
if (data.defaultAuthOrgSlug) {
organization = await orgDAL.findOne({
slug: data.defaultAuthOrgSlug
});

if (!organization) {
throw new BadRequestError({
name: "Update server config",
message: "Failed to find default organization"
});
}
}

const updatedServerCfg = await serverCfgDAL.updateById(ADMIN_CONFIG_DB_UUID, {
...omit(data, ["defaultAuthOrgSlug"]),
defaultAuthOrgId: organization?.id || null
});

const result = {
...updatedServerCfg,
defaultAuthOrgSlug: organization?.slug || null
};
const updateServerCfg = async (data: TSuperAdminUpdate) => {
const updatedServerCfg = await serverCfgDAL.updateById(ADMIN_CONFIG_DB_UUID, data);

await keyStore.setItemWithExpiry(ADMIN_CONFIG_KEY, ADMIN_CONFIG_KEY_EXP, JSON.stringify(result));
return result;
await keyStore.setItemWithExpiry(ADMIN_CONFIG_KEY, ADMIN_CONFIG_KEY_EXP, JSON.stringify(updatedServerCfg));
return updatedServerCfg;
};

const adminSignUp = async ({
Expand Down
6 changes: 0 additions & 6 deletions backend/src/services/super-admin/super-admin-types.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
import { TSuperAdminUpdate } from "@app/db/schemas";

export type TAdminSignUpDTO = {
email: string;
password: string;
Expand All @@ -17,7 +15,3 @@ export type TAdminSignUpDTO = {
ip: string;
userAgent: string;
};

export type TUpdateServerCfgDTO = Omit<TSuperAdminUpdate, "defaultAuthOrgId"> & {
defaultAuthOrgSlug?: string | null;
};
51 changes: 35 additions & 16 deletions frontend/src/views/admin/DashboardPage/DashboardPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import {
Tabs
} from "@app/components/v2";
import { useOrganization, useServerConfig, useUser } from "@app/context";
import { useUpdateServerConfig } from "@app/hooks/api";
import { useGetOrganizations, useUpdateServerConfig } from "@app/hooks/api";

import { RateLimitPanel } from "./RateLimitPanel";

Expand All @@ -40,7 +40,7 @@ const formSchema = z.object({
allowedSignUpDomain: z.string().optional().nullable(),
trustSamlEmails: z.boolean(),
trustLdapEmails: z.boolean(),
defaultAuthOrgSlug: z.string().optional().nullable()
defaultAuthOrgId: z.string()
});

type TDashboardForm = z.infer<typeof formSchema>;
Expand All @@ -62,7 +62,7 @@ export const AdminDashboardPage = () => {
allowedSignUpDomain: config.allowedSignUpDomain,
trustSamlEmails: config.trustSamlEmails,
trustLdapEmails: config.trustLdapEmails,
defaultAuthOrgSlug: config.defaultAuthOrgSlug
defaultAuthOrgId: config.defaultAuthOrgId ?? ""
}
});

Expand All @@ -72,6 +72,8 @@ export const AdminDashboardPage = () => {
const { orgs } = useOrganization();
const { mutateAsync: updateServerConfig } = useUpdateServerConfig();

const organizations = useGetOrganizations();

const isNotAllowed = !user?.superAdmin;

// TODO(akhilmhdh): on nextjs 14 roadmap this will be properly addressed with context split
Expand All @@ -91,11 +93,11 @@ export const AdminDashboardPage = () => {
allowedSignUpDomain,
trustSamlEmails,
trustLdapEmails,
defaultAuthOrgSlug
defaultAuthOrgId
} = formData;

await updateServerConfig({
defaultAuthOrgSlug,
defaultAuthOrgId: defaultAuthOrgId || null,
allowSignUp: signUpMode !== SignUpModes.Disabled,
allowedSignUpDomain: signUpMode === SignUpModes.Anyone ? allowedSignUpDomain : null,
trustSamlEmails,
Expand Down Expand Up @@ -151,13 +153,13 @@ export const AdminDashboardPage = () => {
name="signUpMode"
render={({ field: { onChange, ...field }, fieldState: { error } }) => (
<FormControl
className="max-w-72 w-72"
className="max-w-sm"
errorText={error?.message}
isError={Boolean(error)}
>
<Select
className="w-72 bg-mineshaft-700"
dropdownContainerClassName="bg-mineshaft-700"
className="w-full bg-mineshaft-700"
dropdownContainerClassName="bg-mineshaft-800"
defaultValue={field.value}
onValueChange={(e) => onChange(e)}
{...field}
Expand Down Expand Up @@ -199,7 +201,7 @@ export const AdminDashboardPage = () => {

<div className="flex flex-col justify-start">
<div className="mb-2 text-xl font-semibold text-mineshaft-100">
Default organization slug
Default organization
</div>
<div className="mb-4 max-w-sm text-sm text-mineshaft-400">
Select the slug of the organization you want to set as default for SAML/LDAP
Expand All @@ -208,16 +210,33 @@ export const AdminDashboardPage = () => {
</div>
<Controller
control={control}
defaultValue=""
name="defaultAuthOrgSlug"
render={({ field, fieldState: { error } }) => (
name="defaultAuthOrgId"
render={({ field: { onChange, ...field }, fieldState: { error } }) => (
<FormControl
label="Default organization slug"
className="w-72"
isError={Boolean(error)}
className="max-w-sm"
errorText={error?.message}
isError={Boolean(error)}
>
<Input {...field} value={field.value || ""} placeholder="acme-corp" />
<Select
className="w-full bg-mineshaft-700"
dropdownContainerClassName="bg-mineshaft-800"
defaultValue={field.value ?? " "}
onValueChange={(e) => {
if (e === " ") {
onChange(null);
} else {
onChange(e);
}
}}
{...field}
>
<SelectItem value=" ">Select organization...</SelectItem>
{organizations.data?.map((org) => (
<SelectItem key={org.id} value={org.id}>
{org.name}
</SelectItem>
))}
</Select>
</FormControl>
)}
/>
Expand Down

0 comments on commit 6a9e47a

Please sign in to comment.