Compare commits
No commits in common. "4007000c600b614c0e04920f2c174672d7afff1d" and "8b7bbf8edd2d1d67757018e04140152ba90711f8" have entirely different histories.
4007000c60
...
8b7bbf8edd
9 changed files with 41 additions and 109 deletions
|
@ -2,7 +2,6 @@ export interface CreateCalendarTypeCommand {
|
||||||
type: string;
|
type: string;
|
||||||
nscdr: boolean;
|
nscdr: boolean;
|
||||||
color: string;
|
color: string;
|
||||||
passphrase?: string;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface UpdateCalendarTypeCommand {
|
export interface UpdateCalendarTypeCommand {
|
||||||
|
@ -10,7 +9,6 @@ export interface UpdateCalendarTypeCommand {
|
||||||
type: string;
|
type: string;
|
||||||
nscdr: boolean;
|
nscdr: boolean;
|
||||||
color: string;
|
color: string;
|
||||||
passphrase?: string;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface DeleteCalendarTypeCommand {
|
export interface DeleteCalendarTypeCommand {
|
||||||
|
|
|
@ -18,7 +18,6 @@ export default abstract class CalendarTypeCommandHandler {
|
||||||
type: createCalendarType.type,
|
type: createCalendarType.type,
|
||||||
nscdr: createCalendarType.nscdr,
|
nscdr: createCalendarType.nscdr,
|
||||||
color: createCalendarType.color,
|
color: createCalendarType.color,
|
||||||
passphrase: createCalendarType.nscdr ? null : createCalendarType.passphrase,
|
|
||||||
})
|
})
|
||||||
.execute()
|
.execute()
|
||||||
.then((result) => {
|
.then((result) => {
|
||||||
|
@ -42,7 +41,6 @@ export default abstract class CalendarTypeCommandHandler {
|
||||||
type: updateCalendarType.type,
|
type: updateCalendarType.type,
|
||||||
nscdr: updateCalendarType.nscdr,
|
nscdr: updateCalendarType.nscdr,
|
||||||
color: updateCalendarType.color,
|
color: updateCalendarType.color,
|
||||||
passphrase: updateCalendarType.nscdr ? null : updateCalendarType.passphrase,
|
|
||||||
})
|
})
|
||||||
.where("id = :id", { id: updateCalendarType.id })
|
.where("id = :id", { id: updateCalendarType.id })
|
||||||
.execute()
|
.execute()
|
||||||
|
|
|
@ -101,13 +101,11 @@ export async function createCalendarType(req: Request, res: Response): Promise<a
|
||||||
const type = req.body.type;
|
const type = req.body.type;
|
||||||
const nscdr = req.body.nscdr;
|
const nscdr = req.body.nscdr;
|
||||||
const color = req.body.color;
|
const color = req.body.color;
|
||||||
const passphrase = req.body.passphrase;
|
|
||||||
|
|
||||||
let createType: CreateCalendarTypeCommand = {
|
let createType: CreateCalendarTypeCommand = {
|
||||||
type,
|
type,
|
||||||
nscdr,
|
nscdr,
|
||||||
color,
|
color,
|
||||||
passphrase,
|
|
||||||
};
|
};
|
||||||
let id = await CalendarTypeCommandHandler.create(createType);
|
let id = await CalendarTypeCommandHandler.create(createType);
|
||||||
|
|
||||||
|
@ -156,14 +154,12 @@ export async function updateCalendarType(req: Request, res: Response): Promise<a
|
||||||
const type = req.body.type;
|
const type = req.body.type;
|
||||||
const nscdr = req.body.nscdr;
|
const nscdr = req.body.nscdr;
|
||||||
const color = req.body.color;
|
const color = req.body.color;
|
||||||
const passphrase = req.body.passphrase;
|
|
||||||
|
|
||||||
let updateType: UpdateCalendarTypeCommand = {
|
let updateType: UpdateCalendarTypeCommand = {
|
||||||
id,
|
id,
|
||||||
type,
|
type,
|
||||||
nscdr,
|
nscdr,
|
||||||
color,
|
color,
|
||||||
passphrase,
|
|
||||||
};
|
};
|
||||||
await CalendarTypeCommandHandler.update(updateType);
|
await CalendarTypeCommandHandler.update(updateType);
|
||||||
|
|
||||||
|
|
|
@ -4,96 +4,63 @@ import CalendarTypeService from "../service/calendarTypeService";
|
||||||
import { calendar } from "../entity/calendar";
|
import { calendar } from "../entity/calendar";
|
||||||
import { createEvents } from "ics";
|
import { createEvents } from "ics";
|
||||||
import moment from "moment";
|
import moment from "moment";
|
||||||
import InternalException from "../exceptions/internalException";
|
|
||||||
import CalendarFactory from "../factory/admin/calendar";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description get all calendar items by types or nscdr
|
* @description get all calendar items by types or nscdr
|
||||||
* @summary passphrase is passed as value pair like `type:passphrase`
|
|
||||||
* @param req {Request} Express req object
|
* @param req {Request} Express req object
|
||||||
* @param res {Response} Express res object
|
* @param res {Response} Express res object
|
||||||
* @returns {Promise<*>}
|
* @returns {Promise<*>}
|
||||||
*/
|
*/
|
||||||
export async function getCalendarItemsByTypes(req: Request, res: Response): Promise<any> {
|
export async function getCalendarItemsByTypes(req: Request, res: Response): Promise<any> {
|
||||||
let types = Array.isArray(req.query.types) ? req.query.types : [req.query.types];
|
let types = Array.isArray(req.query.types) ? req.query.types : [req.query.types];
|
||||||
let output = (req.query.output as "ics" | "json") ?? "ics";
|
|
||||||
|
|
||||||
if (output != "ics" && output != "json") {
|
|
||||||
throw new InternalException("set output query value to `ics` or `json` (defaults to `ics`)");
|
|
||||||
}
|
|
||||||
|
|
||||||
types = types.filter((t) => t);
|
|
||||||
|
|
||||||
let items: Array<calendar> = [];
|
let items: Array<calendar> = [];
|
||||||
if (types.length != 0) {
|
if (types.length == 0) {
|
||||||
let typeIds = await CalendarTypeService.getByTypes((types as Array<string>).map((t) => t.split(":")[0]));
|
let typeIds = await CalendarTypeService.getByTypes(types as Array<string>);
|
||||||
typeIds = typeIds.filter(
|
|
||||||
(ti) =>
|
|
||||||
ti.passphrase == null ||
|
|
||||||
ti.passphrase == "" ||
|
|
||||||
ti.passphrase == (types as Array<string>).find((t) => t.includes(ti.type)).split(":")[1]
|
|
||||||
);
|
|
||||||
items = await CalendarService.getByTypes(typeIds.map((t) => t.id));
|
items = await CalendarService.getByTypes(typeIds.map((t) => t.id));
|
||||||
} else {
|
} else {
|
||||||
items = await CalendarService.getByTypeNSCDR();
|
items = await CalendarService.getByTypeNSCDR();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (output == "json") {
|
let events = createEvents(
|
||||||
res.json(CalendarFactory.mapToBase(items));
|
items.map((i) => ({
|
||||||
} else {
|
calName: process.env.CLUB_NAME,
|
||||||
let events = createEvents(
|
uid: i.id,
|
||||||
items.map((i) => ({
|
sequence: 1,
|
||||||
calName: process.env.CLUB_NAME,
|
start: moment(i.starttime)
|
||||||
uid: i.id,
|
.format("YYYY-M-D-H-m")
|
||||||
sequence: 1,
|
.split("-")
|
||||||
...(i.allDay
|
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
||||||
? {
|
end: moment(i.endtime)
|
||||||
start: moment(i.starttime)
|
.format("YYYY-M-D-H-m")
|
||||||
.format("YYYY-M-D")
|
.split("-")
|
||||||
.split("-")
|
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
||||||
.map((a) => parseInt(a)) as [number, number, number],
|
title: i.title,
|
||||||
end: moment(i.endtime)
|
description: i.content,
|
||||||
.format("YYYY-M-D")
|
location: i.location,
|
||||||
.split("-")
|
categories: [i.type.type],
|
||||||
.map((a) => parseInt(a)) as [number, number, number],
|
created: moment(i.createdAt)
|
||||||
}
|
.format("YYYY-M-D-H-m")
|
||||||
: {
|
.split("-")
|
||||||
start: moment(i.starttime)
|
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
||||||
.format("YYYY-M-D-H-m")
|
lastModified: moment(i.updatedAt)
|
||||||
.split("-")
|
.format("YYYY-M-D-H-m")
|
||||||
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
.split("-")
|
||||||
end: moment(i.endtime)
|
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
||||||
.format("YYYY-M-D-H-m")
|
transp: "OPAQUE" as "OPAQUE",
|
||||||
.split("-")
|
url: "https://www.ff-merching.de",
|
||||||
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
alarms: [
|
||||||
}),
|
{
|
||||||
title: i.title,
|
action: "display",
|
||||||
description: i.content,
|
description: "Erinnerung",
|
||||||
location: i.location,
|
trigger: {
|
||||||
categories: [i.type.type],
|
minutes: 30,
|
||||||
created: moment(i.createdAt)
|
before: true,
|
||||||
.format("YYYY-M-D-H-m")
|
|
||||||
.split("-")
|
|
||||||
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
|
||||||
lastModified: moment(i.updatedAt)
|
|
||||||
.format("YYYY-M-D-H-m")
|
|
||||||
.split("-")
|
|
||||||
.map((a) => parseInt(a)) as [number, number, number, number, number],
|
|
||||||
transp: "OPAQUE" as "OPAQUE",
|
|
||||||
url: "https://www.ff-merching.de",
|
|
||||||
alarms: [
|
|
||||||
{
|
|
||||||
action: "display",
|
|
||||||
description: "Erinnerung",
|
|
||||||
trigger: {
|
|
||||||
minutes: 30,
|
|
||||||
before: true,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
],
|
},
|
||||||
}))
|
],
|
||||||
);
|
}))
|
||||||
|
);
|
||||||
|
|
||||||
res.type("ics").send(events.value);
|
res.type("ics").send(events.value);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,6 @@ import { Calendar1729947763295 } from "./migrations/1729947763295-calendar";
|
||||||
import { reset } from "./entity/reset";
|
import { reset } from "./entity/reset";
|
||||||
import { ResetToken1732358596823 } from "./migrations/1732358596823-resetToken";
|
import { ResetToken1732358596823 } from "./migrations/1732358596823-resetToken";
|
||||||
import { SMSAlarming1732696919191 } from "./migrations/1732696919191-SMSAlarming";
|
import { SMSAlarming1732696919191 } from "./migrations/1732696919191-SMSAlarming";
|
||||||
import { SecuringCalendarType1733249553766 } from "./migrations/1733249553766-securingCalendarType";
|
|
||||||
|
|
||||||
const dataSource = new DataSource({
|
const dataSource = new DataSource({
|
||||||
type: DB_TYPE as any,
|
type: DB_TYPE as any,
|
||||||
|
@ -97,7 +96,6 @@ const dataSource = new DataSource({
|
||||||
Calendar1729947763295,
|
Calendar1729947763295,
|
||||||
ResetToken1732358596823,
|
ResetToken1732358596823,
|
||||||
SMSAlarming1732696919191,
|
SMSAlarming1732696919191,
|
||||||
SecuringCalendarType1733249553766,
|
|
||||||
],
|
],
|
||||||
migrationsRun: true,
|
migrationsRun: true,
|
||||||
migrationsTransactionMode: "each",
|
migrationsTransactionMode: "each",
|
||||||
|
|
|
@ -15,9 +15,6 @@ export class calendarType {
|
||||||
@Column({ type: "varchar", length: 255 })
|
@Column({ type: "varchar", length: 255 })
|
||||||
color: string;
|
color: string;
|
||||||
|
|
||||||
@Column({ type: "varchar", length: 255, nullable: true, default: null })
|
|
||||||
passphrase: string | null;
|
|
||||||
|
|
||||||
@OneToMany(() => calendar, (c) => c.type, {
|
@OneToMany(() => calendar, (c) => c.type, {
|
||||||
nullable: false,
|
nullable: false,
|
||||||
onDelete: "RESTRICT",
|
onDelete: "RESTRICT",
|
||||||
|
|
|
@ -13,7 +13,6 @@ export default abstract class CalendarTypeFactory {
|
||||||
type: record.type,
|
type: record.type,
|
||||||
nscdr: record.nscdr,
|
nscdr: record.nscdr,
|
||||||
color: record.color,
|
color: record.color,
|
||||||
passphrase: record.passphrase,
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
import { MigrationInterface, QueryRunner, TableColumn } from "typeorm";
|
|
||||||
|
|
||||||
export class SecuringCalendarType1733249553766 implements MigrationInterface {
|
|
||||||
name = "SecuringCalendarType1733249553766";
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<void> {
|
|
||||||
await queryRunner.addColumns("calendar_type", [
|
|
||||||
new TableColumn({
|
|
||||||
name: "passphrase",
|
|
||||||
type: "varchar",
|
|
||||||
length: "255",
|
|
||||||
isNullable: true,
|
|
||||||
}),
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<void> {
|
|
||||||
await queryRunner.dropColumn("calendar_type", "passphrase");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -3,5 +3,4 @@ export interface CalendarTypeViewModel {
|
||||||
type: string;
|
type: string;
|
||||||
nscdr: boolean;
|
nscdr: boolean;
|
||||||
color: string;
|
color: string;
|
||||||
passphrase: string | null;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue