ip.sql.ts 612 B

12345678910111213141516171819202122
  1. import { mysqlTable, int, primaryKey, varchar } from "drizzle-orm/mysql-core"
  2. import { timestamps } from "../drizzle/types"
  3. export const IpTable = mysqlTable(
  4. "ip",
  5. {
  6. ip: varchar("ip", { length: 45 }).notNull(),
  7. ...timestamps,
  8. usage: int("usage"),
  9. },
  10. (table) => [primaryKey({ columns: [table.ip] })],
  11. )
  12. export const IpRateLimitTable = mysqlTable(
  13. "ip_rate_limit",
  14. {
  15. ip: varchar("ip", { length: 45 }).notNull(),
  16. interval: varchar("interval", { length: 10 }).notNull(),
  17. count: int("count").notNull(),
  18. },
  19. (table) => [primaryKey({ columns: [table.ip, table.interval] })],
  20. )