Compare commits
15 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a276065288 | |||
| 1461caf68a | |||
| e7c7fedf8b | |||
| 5f4e0d4262 | |||
| c072fed99f | |||
| b4a9f917b5 | |||
| 078e5ba95f | |||
| 495509c888 | |||
| 03b4240b8b | |||
| 9a3e82470a | |||
| ee2319996b | |||
| c979adfe69 | |||
| 17d1cb45e3 | |||
| c18a5f4162 | |||
| a40026040c |
+4
-3
@@ -1,11 +1,12 @@
|
|||||||
NEXTAUTH_SECRET=very_sensitive_secret
|
|
||||||
NEXTAUTH_URL=http://localhost:3000/api/v1/auth
|
NEXTAUTH_URL=http://localhost:3000/api/v1/auth
|
||||||
|
NEXTAUTH_SECRET=
|
||||||
|
|
||||||
# Manual installation database settings
|
# Manual installation database settings
|
||||||
DATABASE_URL=postgresql://user:password@localhost:5432/linkwarden
|
# Example: DATABASE_URL=postgresql://user:password@localhost:5432/linkwarden
|
||||||
|
DATABASE_URL=
|
||||||
|
|
||||||
# Docker installation database settings
|
# Docker installation database settings
|
||||||
POSTGRES_PASSWORD=super_secret_password
|
POSTGRES_PASSWORD=
|
||||||
|
|
||||||
# Additional Optional Settings
|
# Additional Optional Settings
|
||||||
PAGINATION_TAKE_COUNT=
|
PAGINATION_TAKE_COUNT=
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ const InstallApp = (props: Props) => {
|
|||||||
const [isOpen, setIsOpen] = useState(true);
|
const [isOpen, setIsOpen] = useState(true);
|
||||||
|
|
||||||
return isOpen && !isPWA() ? (
|
return isOpen && !isPWA() ? (
|
||||||
<div className="fixed left-0 right-0 bottom-10 w-full p-5">
|
<div className="fixed left-0 right-0 bottom-10 w-full">
|
||||||
<div className="mx-auto w-fit p-2 flex justify-between gap-2 items-center border border-neutral-content rounded-xl bg-base-300 backdrop-blur-md bg-opacity-80 max-w-md">
|
<div className="mx-auto w-fit p-2 flex justify-between gap-2 items-center border border-neutral-content rounded-xl bg-base-300 backdrop-blur-md bg-opacity-80 max-w-md">
|
||||||
<svg
|
<svg
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
|||||||
@@ -57,8 +57,8 @@ export default async function deleteCollection(
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
await removeFolder({ filePath: `archives/${collectionId}` });
|
removeFolder({ filePath: `archives/${collectionId}` });
|
||||||
await removeFolder({ filePath: `archives/preview/${collectionId}` });
|
removeFolder({ filePath: `archives/preview/${collectionId}` });
|
||||||
|
|
||||||
await removeFromOrders(userId, collectionId);
|
await removeFromOrders(userId, collectionId);
|
||||||
|
|
||||||
@@ -100,8 +100,8 @@ async function deleteSubCollections(collectionId: number) {
|
|||||||
where: { id: subCollection.id },
|
where: { id: subCollection.id },
|
||||||
});
|
});
|
||||||
|
|
||||||
await removeFolder({ filePath: `archives/${subCollection.id}` });
|
removeFolder({ filePath: `archives/${subCollection.id}` });
|
||||||
await removeFolder({ filePath: `archives/preview/${subCollection.id}` });
|
removeFolder({ filePath: `archives/preview/${subCollection.id}` });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1186,10 +1186,42 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
providerAccountId: account?.providerAccountId,
|
providerAccountId: account?.providerAccountId,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!existingUser && newSsoUsersDisabled) {
|
if (!existingUser && newSsoUsersDisabled) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If user is already registered, link the provider
|
||||||
|
if (user.email && account) {
|
||||||
|
const findUser = await prisma.user.findFirst({
|
||||||
|
where: {
|
||||||
|
email: user.email,
|
||||||
|
},
|
||||||
|
include: {
|
||||||
|
accounts: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (findUser && findUser.accounts.length === 0) {
|
||||||
|
await prisma.account.create({
|
||||||
|
data: {
|
||||||
|
userId: findUser.id,
|
||||||
|
type: account.type,
|
||||||
|
provider: account.provider,
|
||||||
|
providerAccountId: account.providerAccountId,
|
||||||
|
id_token: account.id_token,
|
||||||
|
access_token: account.access_token,
|
||||||
|
refresh_token: account.refresh_token,
|
||||||
|
expires_at: account.expires_at,
|
||||||
|
token_type: account.token_type,
|
||||||
|
scope: account.scope,
|
||||||
|
session_state: account.session_state,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
async jwt({ token, trigger, user }) {
|
async jwt({ token, trigger, user }) {
|
||||||
@@ -1198,13 +1230,28 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
token.id = user?.id as number;
|
token.id = user?.id as number;
|
||||||
|
|
||||||
if (trigger === "signUp") {
|
if (trigger === "signUp") {
|
||||||
const checkIfUserExists = await prisma.user.findUnique({
|
const userExists = await prisma.user.findUnique({
|
||||||
where: {
|
where: {
|
||||||
id: token.id,
|
id: token.id,
|
||||||
},
|
},
|
||||||
|
include: {
|
||||||
|
accounts: true,
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
if (checkIfUserExists && !checkIfUserExists.username) {
|
// Verify SSO user email
|
||||||
|
if (userExists && userExists.accounts.length > 0) {
|
||||||
|
await prisma.user.update({
|
||||||
|
where: {
|
||||||
|
id: userExists.id,
|
||||||
|
},
|
||||||
|
data: {
|
||||||
|
emailVerified: new Date(),
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (userExists && !userExists.username) {
|
||||||
const autoGeneratedUsername =
|
const autoGeneratedUsername =
|
||||||
"user" + Math.round(Math.random() * 1000000000);
|
"user" + Math.round(Math.random() * 1000000000);
|
||||||
|
|
||||||
@@ -1217,6 +1264,22 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
} else if (trigger === "signIn") {
|
||||||
|
const user = await prisma.user.findUnique({
|
||||||
|
where: {
|
||||||
|
id: token.id,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (user && !user.username) {
|
||||||
|
const autoGeneratedUsername =
|
||||||
|
"user" + Math.round(Math.random() * 1000000000);
|
||||||
|
|
||||||
|
await prisma.user.update({
|
||||||
|
where: { id: user.id },
|
||||||
|
data: { username: autoGeneratedUsername },
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return token;
|
return token;
|
||||||
@@ -1224,6 +1287,8 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
async session({ session, token }) {
|
async session({ session, token }) {
|
||||||
session.user.id = token.id;
|
session.user.id = token.id;
|
||||||
|
|
||||||
|
console.log("session", session);
|
||||||
|
|
||||||
if (STRIPE_SECRET_KEY) {
|
if (STRIPE_SECRET_KEY) {
|
||||||
const user = await prisma.user.findUnique({
|
const user = await prisma.user.findUnique({
|
||||||
where: {
|
where: {
|
||||||
@@ -1235,6 +1300,7 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
if (user) {
|
if (user) {
|
||||||
|
//
|
||||||
const subscribedUser = await verifySubscription(user);
|
const subscribedUser = await verifySubscription(user);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user