import { FindOptions } from 'sequelize' import { AllowNull, BelongsTo, Column, CreatedAt, DataType, ForeignKey, Model, Table, UpdatedAt } from 'sequelize-typescript' import { MRunner } from '@server/types/models/runners' import { Runner } from '@shared/models' import { AttributesOnly } from '@shared/typescript-utils' import { getSort } from '../shared' import { RunnerRegistrationTokenModel } from './runner-registration-token' import { CONSTRAINTS_FIELDS } from '@server/initializers/constants' @Table({ tableName: 'runner', indexes: [ { fields: [ 'runnerToken' ], unique: true }, { fields: [ 'runnerRegistrationTokenId' ] }, { fields: [ 'name' ], unique: true } ] }) export class RunnerModel extends Model>> { // Used to identify the appropriate runner when it uses the runner REST API @AllowNull(false) @Column runnerToken: string @AllowNull(false) @Column name: string @AllowNull(true) @Column(DataType.STRING(CONSTRAINTS_FIELDS.RUNNERS.DESCRIPTION.max)) description: string @AllowNull(false) @Column lastContact: Date @AllowNull(false) @Column ip: string @CreatedAt createdAt: Date @UpdatedAt updatedAt: Date @ForeignKey(() => RunnerRegistrationTokenModel) @Column runnerRegistrationTokenId: number @BelongsTo(() => RunnerRegistrationTokenModel, { foreignKey: { allowNull: false }, onDelete: 'cascade' }) RunnerRegistrationToken: RunnerRegistrationTokenModel // --------------------------------------------------------------------------- static load (id: number) { return RunnerModel.findByPk(id) } static loadByToken (runnerToken: string) { const query = { where: { runnerToken } } return RunnerModel.findOne(query) } static loadByName (name: string) { const query = { where: { name } } return RunnerModel.findOne(query) } static listForApi (options: { start: number count: number sort: string }) { const { start, count, sort } = options const query: FindOptions = { offset: start, limit: count, order: getSort(sort) } return Promise.all([ RunnerModel.count(query), RunnerModel.findAll(query) ]).then(([ total, data ]) => ({ total, data })) } // --------------------------------------------------------------------------- toFormattedJSON (this: MRunner): Runner { return { id: this.id, name: this.name, description: this.description, ip: this.ip, lastContact: this.lastContact, createdAt: this.createdAt, updatedAt: this.updatedAt } } }