2022-09-17 18:27:08 +00:00
|
|
|
import { Inject, Injectable } from '@nestjs/common';
|
|
|
|
import { DataSource } from 'typeorm';
|
|
|
|
import { Endpoint } from '@/server/api/endpoint-base.js';
|
|
|
|
import { DI } from '@/di-symbols.js';
|
2021-05-08 03:51:23 +00:00
|
|
|
|
|
|
|
export const meta = {
|
2022-01-18 13:27:10 +00:00
|
|
|
requireCredential: true,
|
2023-01-12 12:02:26 +00:00
|
|
|
requireAdmin: true,
|
2021-05-08 03:51:23 +00:00
|
|
|
|
|
|
|
tags: ['admin'],
|
2022-02-19 05:05:32 +00:00
|
|
|
} as const;
|
2021-05-08 03:51:23 +00:00
|
|
|
|
2022-02-20 04:15:40 +00:00
|
|
|
export const paramDef = {
|
2022-02-19 05:05:32 +00:00
|
|
|
type: 'object',
|
|
|
|
properties: {},
|
|
|
|
required: [],
|
2022-01-18 13:27:10 +00:00
|
|
|
} as const;
|
2021-05-08 03:51:23 +00:00
|
|
|
|
2022-01-02 17:12:50 +00:00
|
|
|
// eslint-disable-next-line import/no-default-export
|
2022-09-17 18:27:08 +00:00
|
|
|
@Injectable()
|
|
|
|
export default class extends Endpoint<typeof meta, typeof paramDef> {
|
|
|
|
constructor(
|
|
|
|
@Inject(DI.db)
|
|
|
|
private db: DataSource,
|
|
|
|
) {
|
|
|
|
super(meta, paramDef, async () => {
|
|
|
|
const stats = await this.db.query('SELECT * FROM pg_indexes;').then(recs => {
|
|
|
|
const res = [] as { tablename: string; indexname: string; }[];
|
|
|
|
for (const rec of recs) {
|
|
|
|
res.push(rec);
|
|
|
|
}
|
|
|
|
return res;
|
|
|
|
});
|
2021-05-08 03:51:23 +00:00
|
|
|
|
2022-09-17 18:27:08 +00:00
|
|
|
return stats;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|