mirror of
https://codeberg.org/yeentown/barkey.git
synced 2025-10-24 10:14:51 +00:00
add instance properties for persisted block data
This commit is contained in:
parent
566f92ab73
commit
45e5749cca
2 changed files with 139 additions and 0 deletions
|
@ -0,0 +1,89 @@
|
||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: hazelnoot and other Sharkey contributors
|
||||||
|
* SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @typedef {import('typeorm').MigrationInterface} MigrationInterface
|
||||||
|
* @typedef {{ blockedHosts: string[], silencedHosts: string[], mediaSilencedHosts: string[], federationHosts: string[], bubbleInstances: string[] }} Meta
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @class
|
||||||
|
* @implements {MigrationInterface}
|
||||||
|
*/
|
||||||
|
export class AddInstanceBlockColumns1748105111513 {
|
||||||
|
name = 'AddInstanceBlockColumns1748105111513'
|
||||||
|
|
||||||
|
async up(queryRunner) {
|
||||||
|
// Schema migration
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "isBlocked" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."isBlocked" IS 'True if this instance is blocked from federation.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "isAllowListed" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."isAllowListed" IS 'True if this instance is allow-listed.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "isBubbled" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."isBubbled" IS 'True if this instance is part of the local bubble.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "isSilenced" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."isSilenced" IS 'True if this instance is silenced.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "isMediaSilenced" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."isMediaSilenced" IS 'True if this instance is media-silenced.'`);
|
||||||
|
|
||||||
|
// Data migration
|
||||||
|
/** @type {Meta[]} */
|
||||||
|
const metas = await queryRunner.query(`SELECT "blockedHosts", "silencedHosts", "mediaSilencedHosts", "federationHosts", "bubbleInstances" FROM "meta"`);
|
||||||
|
if (metas.length > 0) {
|
||||||
|
/** @type {Meta} */
|
||||||
|
const meta = metas[0];
|
||||||
|
|
||||||
|
// Blocked hosts
|
||||||
|
if (meta.blockedHosts.length > 0) {
|
||||||
|
const pattern = buildPatterns(meta.blockedHosts);
|
||||||
|
await queryRunner.query(`UPDATE "instance" SET "isBlocked" = true WHERE ((lower(reverse("host")) || '.')::text) LIKE ANY ${pattern}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Silenced hosts
|
||||||
|
if (meta.silencedHosts.length > 0) {
|
||||||
|
const pattern = buildPatterns(meta.silencedHosts);
|
||||||
|
await queryRunner.query(`UPDATE "instance" SET "isSilenced" = true WHERE ((lower(reverse("host")) || '.')::text) LIKE ANY ${pattern}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Media silenced hosts
|
||||||
|
if (meta.mediaSilencedHosts.length > 0) {
|
||||||
|
const pattern = buildPatterns(meta.mediaSilencedHosts);
|
||||||
|
await queryRunner.query(`UPDATE "instance" SET "isMediaSilenced" = true WHERE ((lower(reverse("host")) || '.')::text) LIKE ANY ${pattern}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Allow-listed hosts
|
||||||
|
if (meta.federationHosts.length > 0) {
|
||||||
|
const pattern = buildPatterns(meta.federationHosts);
|
||||||
|
await queryRunner.query(`UPDATE "instance" SET "isAllowListed" = true WHERE ((lower(reverse("host")) || '.')::text) LIKE ANY ${pattern}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Bubbled hosts
|
||||||
|
if (meta.bubbleInstances.length > 0) {
|
||||||
|
const pattern = buildPatterns(meta.bubbleInstances);
|
||||||
|
await queryRunner.query(`UPDATE "instance" SET "isBubbled" = true WHERE ((lower(reverse("host")) || '.')::text) LIKE ANY ${pattern}`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async down(queryRunner) {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "isMediaSilenced"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "isSilenced"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "isBubbled"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "isAllowListed"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "isBlocked"`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {string[]} input
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
function buildPatterns(input) {
|
||||||
|
const strings = input
|
||||||
|
.map(i => i.toLowerCase().split('').reverse().join('') + '.%')
|
||||||
|
.map(i => `'${i}'`)
|
||||||
|
.join(', ');
|
||||||
|
return `(array[${strings}]::text[])`;
|
||||||
|
}
|
|
@ -99,6 +99,56 @@ export class MiInstance {
|
||||||
})
|
})
|
||||||
public suspensionState: 'none' | 'manuallySuspended' | 'goneSuspended' | 'autoSuspendedForNotResponding';
|
public suspensionState: 'none' | 'manuallySuspended' | 'goneSuspended' | 'autoSuspendedForNotResponding';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True if this instance is blocked from federation.
|
||||||
|
*/
|
||||||
|
@Column('boolean', {
|
||||||
|
nullable: false,
|
||||||
|
default: false,
|
||||||
|
comment: 'True if this instance is blocked from federation.',
|
||||||
|
})
|
||||||
|
public isBlocked: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True if this instance is allow-listed.
|
||||||
|
*/
|
||||||
|
@Column('boolean', {
|
||||||
|
nullable: false,
|
||||||
|
default: false,
|
||||||
|
comment: 'True if this instance is allow-listed.',
|
||||||
|
})
|
||||||
|
public isAllowListed: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True if this instance is part of the local bubble.
|
||||||
|
*/
|
||||||
|
@Column('boolean', {
|
||||||
|
nullable: false,
|
||||||
|
default: false,
|
||||||
|
comment: 'True if this instance is part of the local bubble.',
|
||||||
|
})
|
||||||
|
public isBubbled: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True if this instance is silenced.
|
||||||
|
*/
|
||||||
|
@Column('boolean', {
|
||||||
|
nullable: false,
|
||||||
|
default: false,
|
||||||
|
comment: 'True if this instance is silenced.',
|
||||||
|
})
|
||||||
|
public isSilenced: boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* True if this instance is media-silenced.
|
||||||
|
*/
|
||||||
|
@Column('boolean', {
|
||||||
|
nullable: false,
|
||||||
|
default: false,
|
||||||
|
comment: 'True if this instance is media-silenced.',
|
||||||
|
})
|
||||||
|
public isMediaSilenced: boolean;
|
||||||
|
|
||||||
@Column('varchar', {
|
@Column('varchar', {
|
||||||
length: 64, nullable: true,
|
length: 64, nullable: true,
|
||||||
comment: 'The software of the Instance.',
|
comment: 'The software of the Instance.',
|
||||||
|
|
Loading…
Add table
Reference in a new issue