mirror of
https://github.com/Drop-OSS/drop.git
synced 2026-01-31 15:37:09 +01:00
Internal server error fixes, 7z fixes, OIDC fixes (#289)
* fix: add no-prisma-delete lint * fix: typescript for lint * fix: bump droplet * fix: oidc scopes override * fix: type errors * feat: delete all notifications * fix: lint * fix: light mode style fixes
This commit is contained in:
34
rules/no-prisma-delete.mts
Normal file
34
rules/no-prisma-delete.mts
Normal file
@@ -0,0 +1,34 @@
|
||||
import type { TSESLint } from "@typescript-eslint/utils";
|
||||
|
||||
export default {
|
||||
meta: {
|
||||
type: "problem",
|
||||
docs: {
|
||||
description: "Don't use Prisma error-prone .delete function",
|
||||
},
|
||||
messages: {
|
||||
noPrismaDelete:
|
||||
"Prisma .delete(...) function is used. Use .deleteMany(..) and check count instead.",
|
||||
},
|
||||
schema: [],
|
||||
},
|
||||
create(context) {
|
||||
return {
|
||||
CallExpression: function (node) {
|
||||
// @ts-expect-error It ain't typing properly
|
||||
const funcId = node.callee.property;
|
||||
if (!funcId || funcId.name !== "delete") return;
|
||||
// @ts-expect-error It ain't typing properly
|
||||
const tableExpr = node.callee.object;
|
||||
if (!tableExpr) return;
|
||||
const prismaExpr = tableExpr.object;
|
||||
if (!prismaExpr || prismaExpr.name !== "prisma") return;
|
||||
context.report({
|
||||
node,
|
||||
messageId: "noPrismaDelete",
|
||||
});
|
||||
},
|
||||
};
|
||||
},
|
||||
defaultOptions: [],
|
||||
} satisfies TSESLint.RuleModule<"noPrismaDelete">;
|
||||
Reference in New Issue
Block a user