2025-09-13 22:02:27 +01:00
|
|
|
import { defineSchema, defineTable } from "convex/server"
|
|
|
|
import { v } from "convex/values"
|
|
|
|
|
|
|
|
const schema = defineSchema({
|
|
|
|
users: defineTable({
|
|
|
|
name: v.string(),
|
|
|
|
email: v.string(),
|
|
|
|
createdAt: v.string(),
|
|
|
|
updatedAt: v.string(),
|
|
|
|
}),
|
|
|
|
files: defineTable({
|
|
|
|
storageId: v.id("_storage"),
|
|
|
|
userId: v.id("users"),
|
|
|
|
directoryId: v.optional(v.id("directories")),
|
|
|
|
name: v.string(),
|
|
|
|
size: v.number(),
|
2025-09-14 18:49:28 +00:00
|
|
|
mimeType: v.optional(v.string()),
|
2025-09-13 22:02:27 +01:00
|
|
|
createdAt: v.string(),
|
|
|
|
updatedAt: v.string(),
|
2025-09-14 10:59:49 +00:00
|
|
|
deletedAt: v.optional(v.string()),
|
|
|
|
})
|
|
|
|
.index("byDirectoryId", ["directoryId", "deletedAt"])
|
2025-09-14 18:12:29 +00:00
|
|
|
.index("byDeletedAt", ["deletedAt"])
|
|
|
|
.index("uniqueFileInDirectory", ["directoryId", "name", "deletedAt"]),
|
2025-09-13 22:02:27 +01:00
|
|
|
directories: defineTable({
|
|
|
|
name: v.string(),
|
2025-09-14 18:50:49 +00:00
|
|
|
userId: v.id("users"),
|
2025-09-13 22:02:27 +01:00
|
|
|
parentId: v.optional(v.id("directories")),
|
|
|
|
createdAt: v.string(),
|
|
|
|
updatedAt: v.string(),
|
2025-09-14 18:12:29 +00:00
|
|
|
deletedAt: v.optional(v.string()),
|
|
|
|
})
|
2025-09-14 18:50:49 +00:00
|
|
|
.index("byUserId", ["userId"])
|
2025-09-14 18:12:29 +00:00
|
|
|
.index("byParentId", ["parentId", "deletedAt"])
|
|
|
|
.index("uniqueDirectoryInDirectory", ["parentId", "name", "deletedAt"]),
|
2025-09-13 22:02:27 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
export default schema
|