mirror of
https://github.com/turt2live/matrix-dimension.git
synced 2024-09-14 13:04:59 +00:00
Prevent unauthorized people from editing integrations
This commit is contained in:
parent
a6dae219a5
commit
ca8c6b1d95
@ -10,6 +10,7 @@ import { AdminApiService } from "../../shared/services/admin/admin-api.service";
|
|||||||
import { IntegrationsApiService } from "../../shared/services/integrations/integrations-api.service";
|
import { IntegrationsApiService } from "../../shared/services/integrations/integrations-api.service";
|
||||||
import { Modal, overlayConfigFactory } from "ngx-modialog";
|
import { Modal, overlayConfigFactory } from "ngx-modialog";
|
||||||
import { ConfigSimpleBotComponent, SimpleBotConfigDialogContext } from "../../configs/simple-bot/simple-bot.component";
|
import { ConfigSimpleBotComponent, SimpleBotConfigDialogContext } from "../../configs/simple-bot/simple-bot.component";
|
||||||
|
import { ToasterService } from "angular2-toaster";
|
||||||
|
|
||||||
const CATEGORY_MAP = {
|
const CATEGORY_MAP = {
|
||||||
"Widgets": ["widget"],
|
"Widgets": ["widget"],
|
||||||
@ -41,7 +42,8 @@ export class RiotHomeComponent {
|
|||||||
private integrationsApi: IntegrationsApiService,
|
private integrationsApi: IntegrationsApiService,
|
||||||
private adminApi: AdminApiService,
|
private adminApi: AdminApiService,
|
||||||
private router: Router,
|
private router: Router,
|
||||||
private modal: Modal) {
|
private modal: Modal,
|
||||||
|
private toaster: ToasterService) {
|
||||||
let params: any = this.activatedRoute.snapshot.queryParams;
|
let params: any = this.activatedRoute.snapshot.queryParams;
|
||||||
|
|
||||||
this.requestedScreen = params.screen;
|
this.requestedScreen = params.screen;
|
||||||
@ -124,6 +126,13 @@ export class RiotHomeComponent {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public modifyIntegration(integration: FE_Integration) {
|
public modifyIntegration(integration: FE_Integration) {
|
||||||
|
if (!integration._isSupported) {
|
||||||
|
console.log(this.userId + " tried to modify " + integration.displayName + " with error: " + integration._notSupportedReason);
|
||||||
|
const reason = integration.category === "widget" ? "You do not appear to have permission to modify widgets in this room" : integration._notSupportedReason;
|
||||||
|
this.toaster.pop("error", reason);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SessionStorage.editIntegration = integration;
|
SessionStorage.editIntegration = integration;
|
||||||
SessionStorage.editsRequested++;
|
SessionStorage.editsRequested++;
|
||||||
console.log(this.userId + " is trying to modify " + integration.displayName);
|
console.log(this.userId + " is trying to modify " + integration.displayName);
|
||||||
@ -260,7 +269,7 @@ export class RiotHomeComponent {
|
|||||||
if (requirement.expectedValue) return Promise.reject("Expected to be able to send specific event types");
|
if (requirement.expectedValue) return Promise.reject("Expected to be able to send specific event types");
|
||||||
});
|
});
|
||||||
case "userInRoom":
|
case "userInRoom":
|
||||||
// TODO: Implement
|
// TODO: Implement
|
||||||
default:
|
default:
|
||||||
return Promise.reject("Requirement '" + requirement.condition + "' not found");
|
return Promise.reject("Requirement '" + requirement.condition + "' not found");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user