// eslint-disable-next-line @typescript-eslint/no-unused-vars import { ObjectID, GridFSBucket } from 'mongodb'; import fs from 'fs'; import { Dictionary, NumericDictionary } from 'lodash'; type document = typeof import('./model/document'); export interface System { _id: string, value: any, } export interface SystemKeys { 'smtp.user': string, 'smtp.from': string, 'smtp.pass': string, 'smtp.host': string, 'smtp.port': number, 'smtp.secure': boolean, 'user': number, 'server.name': string, 'server.url': string, 'server.xff': string, 'server.worker': number, 'server.port': number, 'session.keys': string[], 'session.secure': boolean, 'session.expire_seconds': number, 'session.unsaved_expire_seconds': number, 'lostpass_token_expire_seconds': number, 'registration_token_expire_seconds': number, 'changemail_token_expire_seconds': number, 'user.quota': number, } export interface Setting { family: string, key: string, range: Array<[string, string]> | Dictionary, value: any, type: string, name: string, desc: string, flag: number, } export interface Udoc extends Dictionary { _id: number, mail: string, mailLower: string, uname: string, unameLower: string, salt: string, hash: string, hashType: string, priv: number, regat: Date, loginat: Date, regip: string, loginip: string, } export interface User extends Dictionary { udoc: () => Udoc, dudoc: () => any, _id: number, mail: string, uname: string, salt: () => string, hash: () => string, hashType: string, priv: number, regat: Date, loginat: Date, perm: () => bigint, role: string, regip: () => string, loginip: () => string, hasPerm: (...perm: bigint[]) => boolean, hasPriv: (...priv: number[]) => boolean, checkPassword: (password: string) => void, } export type Udict = NumericDictionary; export interface ProblemDataSource { host?: string, // Empty for local domainId: string, pid: number, } // ObjectID for built-in files, ProblemDataSource for other source (RemoteJudge, etc.) export type ProblemData = ObjectID | ProblemDataSource; export interface TestCaseConfig { input: string, output: string, time?: number, memory?: number, } export enum LocalProblemType { Default = 'default', SubmitAnswer = 'submit_answer', Interactive = 'interactive', } export enum RemoteProblemType { RemoteJudge = 'remotejudge', } export enum RemoteServerType { vj4 = 'vj4', syzoj = 'syzoj', } export enum SubtaskType { min = 'min', max = 'max', sum = 'sum', } export interface SubtaskConfig { time?: number, memory?: number, score?: number, type?: SubtaskType, cases?: TestCaseConfig[], } export interface LocalProblemConfig { type?: LocalProblemType, score?: number, time?: string, memory?: string, filename?: string, checker_type?: string, checker?: string, interactor?: string, user_extra_files?: string[], judge_extra_files?: string[], cases?: TestCaseConfig[], subtasks?: SubtaskConfig[], } export interface RemoteProblemConfig { type?: RemoteProblemType, server_type?: RemoteServerType, url?: string, // TODO handle username&password storage pid?: string, } export type ProblemConfig = LocalProblemConfig | RemoteProblemConfig; export interface Pdoc { _id: ObjectID, domainId: string, docType: 10, docId: number, pid: string, owner: number, title: string, content: string, nSubmit: number, nAccept: number, tag: string[], category: string[], data?: ProblemData, hidden: boolean, config: ProblemConfig, acMsg?: string, html?: boolean, difficulty?: number, difficultyAlgo?: number, difficultyAdmin?: number, difficultySetting?: any, } export type Pdict = NumericDictionary; export interface StatusDoc { _id: ObjectID, docId: any, docType: number, domainId: string, uid: number, } export interface Document { _id: ObjectID, docId: any, docType: number, domainId: string, owner: number, } export interface ProblemStatusDoc extends StatusDoc { docId: number, docType: 10, rid?: ObjectID, status?: number, nSubmit?: number, nAccept?: number, star?: boolean, } export interface TestCase { time: number, memory: number, status: number, message: string, } export interface HackConfig { hack: string, } export interface PretestConfig { time?: string, memory?: string, input: string, } export type RunConfig = HackConfig | PretestConfig; export interface ContestInfo { type: 30 | 60, tid: ObjectID, } export interface Rdoc { _id: ObjectID, domainId: string, pid: number uid: number, lang: string, code: string, score: number, memory: number, time: number, judgeTexts: string[], compilerTexts: string[], testCases: TestCase[], rejudged: boolean, judger: number, judgeAt: Date, status: number, hidden: boolean, progress?: number, config?: RunConfig, contest?: ContestInfo, } export interface ScoreboardNode { type: string, value: string, raw?: any, } export type PenaltyRules = Dictionary; export interface TrainingNode { _id: number, title: string, requireNids: number[], pids: number[], } export interface Tdoc extends Document { docId: ObjectID, docType: document['TYPE_CONTEST'] | document['TYPE_HOMEWORK'] | document['TYPE_TRAINING'], beginAt: Date, endAt: Date, attend: number, title: string, content: string, rule: string, pids: number[], rated?: boolean, // For homework penaltySince?: Date, penaltyRules?: PenaltyRules, // For training description?: string, dag?: TrainingNode[], } export interface TrainingDoc extends Tdoc { description: string, dag: TrainingNode[], } export interface DomainDoc extends Dictionary { _id: string, owner: number, roles: Dictionary, gravatar: string, bulletin: string, pidCounter: number, join?: any, } // Message export interface Mdoc { _id: ObjectID, from: number, to: number, content: string, flag: number, } // Userfile export interface Ufdoc { _id: ObjectID, secret: string, md5?: string, owner: number, size?: number, filename: string, } // Blacklist export interface Bdoc { _id: string, // ip expireAt: Date, } // Discussion export interface Ddoc extends Document { docType: document['TYPE_DISCUSSION'], docId: ObjectID, parentType: number, parentId: ObjectID | number | string, title: string, content: string, ip: string, pin: boolean, highlight: boolean, updateAt: Date, nReply: number, views: number, } // Discussion reply export interface Drdoc extends Document { docType: document['TYPE_DISCUSSION_REPLY'], docId: ObjectID, parentType: document['TYPE_DISCUSSION'], parentId: ObjectID, ip: string, content: string, reply: Drrdoc[], } // Discussion Tail Reply export interface Drrdoc { _id: ObjectID, owner: number, content: string, ip: string, } export interface TokenDoc { _id: string, tokenType: number, createAt: Date, updateAt: Date, expireAt: Date, [key: string]: any, } export interface ContestStat extends Dictionary { detail: any, } export interface ContestRule { TEXT: string, check: (args: any) => any, statusSort: any, showScoreboard: (tdoc: Tdoc, now: Date) => boolean, showRecord: (tdoc: Tdoc, now: Date) => boolean, stat: (tdoc: Tdoc, journal: any[]) => ContestStat, scoreboard: ( isExport: boolean, _: (s: string) => string, tdoc: Tdoc, rankedTsdocs: any[] | Generator, udict: Udict, pdict: Pdict ) => ScoreboardNode[][], rank: (tsdocs: any[]) => any[] | Generator, } export type ContestRules = Dictionary; export type ProblemImporter = (url: string, handler: any) => Promise<[Pdoc, fs.ReadStream?]> | [Pdoc, fs.ReadStream?]; export interface Script { run: (args: any, report: Function) => any, description: string, validate: any, } export interface JudgeResultBody { domainId: string, rid: ObjectID, judger?: number, progress?: number case?: { status: number, time: number, memory: number, message?: string, }, status?: number, score?: number, time?: number, memory?: number, message?: string, compilerText?: string, // For pretest stdout?: string, stderr?: string, } export interface Task { _id: ObjectID, type: string, executeAfter?: Date, priority: number, [key: string]: any } export type PathComponent = [string, string, Dictionary?, boolean?]; export interface Collections { 'blacklist': Bdoc, 'contest': Tdoc, 'domain': DomainDoc, 'domain.user': any, 'record': Rdoc, 'document': any, 'problem': Pdoc, 'user': Udoc, 'check': any, 'message': Mdoc, 'token': TokenDoc, 'file': Ufdoc, 'status': any, 'oauth': any, 'system': System, 'task': Task, 'opcount': any, 'fs.chunks': any, 'fs.files': any, 'document.status': any, } export interface Model { blacklist: typeof import('./model/blacklist'), builtin: typeof import('./model/builtin'), contest: typeof import('./model/contest'), discussion: typeof import('./model/discussion'), document: typeof import('./model/document'), domain: typeof import('./model/domain'), file: typeof import('./model/file'), message: typeof import('./model/message'), opcount: typeof import('./model/opcount'), problem: typeof import('./model/problem'), record: typeof import('./model/record'), setting: typeof import('./model/setting'), solution: typeof import('./model/solution'), system: typeof import('./model/system'), task: typeof import('./model/task'), token: typeof import('./model/token'), training: typeof import('./model/training'), user: typeof import('./model/user'), oauth: typeof import('./model/oauth'), } export interface Service { bus: typeof import('./service/bus'), db: typeof import('./service/db'), gridfs: GridFSBucket, monitor: typeof import('./service/monitor'), server: typeof import('./service/server'), } interface GeoIP { provider: string, lookup: (ip: string, locale?: string) => any, } export interface Lib { download: typeof import('./lib/download'), 'hash.hydro': typeof import('./lib/hash.hydro'), i18n: typeof import('./lib/i18n'), jwt: typeof import('./lib/jwt'), logger: typeof import('./lib/logger'), mail: typeof import('./lib/mail'), md5: typeof import('./lib/md5'), misc: typeof import('./lib/misc'), paginate: typeof import('./lib/paginate'), rank: typeof import('./lib/rank'), rating: typeof import('./lib/rating'), testdataConfig: typeof import('./lib/testdataConfig'), sha1: typeof import('./lib/sha1'), sysinfo: typeof import('./lib/sysinfo'), 'testdata.convert.ini': typeof import('./lib/testdata.convert.ini'), useragent: typeof import('./lib/useragent'), validator: typeof import('./lib/validator'), template?: any, geoip?: GeoIP, } export interface UI { manifest: Dictionary, template: Dictionary, nodes: { nav: any[], problem_add: any[], }, Nav: typeof import('./lib/ui').Nav, ProblemAdd: typeof import('./lib/ui').ProblemAdd, } declare global { namespace NodeJS { interface Global { Hydro: { model: Model, handler: Dict, script: Dict