-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #88 from Giveth/staging
Release 2024-04-29 Recurring donations improvements
- Loading branch information
Showing
3 changed files
with
92 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
import { MigrationInterface, QueryRunner } from "typeorm" | ||
import { NOTIFICATION_CATEGORY } from '../src/types/general'; | ||
import { NotificationType } from '../src/entities/notificationType'; | ||
import { MICRO_SERVICES } from '../src/utils/utils'; | ||
import { NOTIFICATION_CATEGORY_GROUPS } from '../src/entities/notificationSetting'; | ||
|
||
export const superFluidNotificationTypes = [ | ||
{ | ||
isGlobal: false, | ||
isGroupParent: true, | ||
showOnSettingPage: true, | ||
webDefaultValue: true, | ||
emailDefaultValue: true, | ||
isEmailEditable: true, | ||
isWebEditable: true, | ||
name: 'Stream balance warnings', | ||
description: 'Notify me when any of my Stream Balances are running low', | ||
microService: MICRO_SERVICES.givethio, | ||
category: NOTIFICATION_CATEGORY.SUPPORTED_PROJECTS, | ||
schemaValidator: null, | ||
emailNotifierService: null, | ||
emailNotificationId: null, | ||
pushNotifierService: null, | ||
categoryGroup: NOTIFICATION_CATEGORY_GROUPS.SUPERFLUID, | ||
title: 'Stream balance warnings', | ||
}, | ||
] | ||
|
||
export class addGroupParentSuperFluid1713834025817 implements MigrationInterface { | ||
public async up(queryRunner: QueryRunner): Promise<void> { | ||
// Fetch the notificationTypeIds for the "superfluid" categoryGroup | ||
const notificationTypeIds = (await queryRunner.query(` | ||
SELECT "id" FROM "notification_type" WHERE "categoryGroup" = 'superfluid'; | ||
`)).map((i: any) => i.id); | ||
await queryRunner.query( | ||
`UPDATE notification_type | ||
SET "showOnSettingPage" = false, "emailDefaultValue" = true, "category" = '${NOTIFICATION_CATEGORY.SUPPORTED_PROJECTS}' | ||
WHERE id IN (${notificationTypeIds.join(", ")})` | ||
); | ||
await queryRunner.manager.save( | ||
NotificationType, | ||
superFluidNotificationTypes, | ||
); | ||
} | ||
|
||
public async down(queryRunner: QueryRunner): Promise<void> { | ||
await queryRunner.query( | ||
`DELETE FROM notification_type WHERE "categoryGroup" = 'superfluid' AND "name" = 'Stream Balance Warnings';`, | ||
); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
import { MigrationInterface, QueryRunner } from "typeorm" | ||
|
||
export class addSuperFluidParentToAllUsers1713883053900 implements MigrationInterface { | ||
public async up(queryRunner: QueryRunner): Promise<void> { | ||
// Fetch the notificationTypeIds for the "superfluid" parent | ||
const notificationTypeId = (await queryRunner.query(` | ||
SELECT "id" FROM "notification_type" WHERE "categoryGroup" = 'superfluid' AND "isGroupParent" = true; | ||
`)).map((i: any) => i.id)[0]; | ||
|
||
// Fetch all unique userAddressIds | ||
const userAddressIds = await queryRunner.query(` | ||
SELECT "id" FROM "user_address"; | ||
`); | ||
|
||
// For each userAddressId, insert a new row | ||
for (const { id } of userAddressIds) { | ||
await queryRunner.query(` | ||
INSERT INTO "notification_setting" ( | ||
"allowNotifications", | ||
"allowEmailNotification", | ||
"allowDappPushNotification", | ||
"notificationTypeId", | ||
"userAddressId" | ||
) VALUES (true, true, true, ${notificationTypeId}, ${id}); | ||
`); | ||
} | ||
} | ||
|
||
public async down(queryRunner: QueryRunner): Promise<void> { | ||
// Fetch the notificationTypeIds for the "superfluid" categoryGroup | ||
const notificationTypeId = await queryRunner.query(` | ||
SELECT "id" FROM "notification_type" WHERE "categoryGroup" = 'superfluid' AND "isGroupParent" = true; | ||
`); | ||
const id = notificationTypeId.map((nt: { id: number; }) => nt.id)[0] | ||
// Delete the rows with the fetched notificationTypeId for all userAddressIds | ||
await queryRunner.query(` | ||
DELETE FROM "notification_setting" WHERE "notificationTypeId" = ${id}; | ||
`); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters