mirror of
https://github.com/nasa/openmct.git
synced 2025-01-14 08:49:58 +00:00
Change RoleChannel to ActiveRoleSynchronizer and update method calls to match
This commit is contained in:
parent
5a6755c3fb
commit
a7e10a9cd5
41
src/api/user/ActiveRoleSynchronizer.js
Normal file
41
src/api/user/ActiveRoleSynchronizer.js
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
import { ACTIVE_ROLE_BROADCAST_CHANNEL_NAME } from './constants';
|
||||||
|
|
||||||
|
class ActiveRoleSynchronizer {
|
||||||
|
#roleChannel;
|
||||||
|
|
||||||
|
constructor(openmct) {
|
||||||
|
this.openmct = openmct;
|
||||||
|
this.#roleChannel = new BroadcastChannel(ACTIVE_ROLE_BROADCAST_CHANNEL_NAME);
|
||||||
|
this.setActiveRoleFromChannelMessage = this.setActiveRoleFromChannelMessage.bind(this);
|
||||||
|
|
||||||
|
this.subscribeToRoleChanges(this.setActiveRoleFromChannelMessage);
|
||||||
|
}
|
||||||
|
extractRoleFromEvent(callback) {
|
||||||
|
return function (event) {
|
||||||
|
callback(event.data);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
subscribeToRoleChanges(callback) {
|
||||||
|
this.#roleChannel.addEventListener('message', this.extractRoleFromEvent(callback));
|
||||||
|
}
|
||||||
|
unsubscribeFromRoleChanges(callback) {
|
||||||
|
this.#roleChannel.removeEventListener('message', this.extractRoleFromEvent(callback));
|
||||||
|
}
|
||||||
|
|
||||||
|
setActiveRoleFromChannelMessage(role) {
|
||||||
|
this.openmct.user.setActiveRole(role);
|
||||||
|
}
|
||||||
|
broadcastNewRole(role) {
|
||||||
|
if (!this.#roleChannel.name) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.#roleChannel.postMessage(role);
|
||||||
|
}
|
||||||
|
destroy() {
|
||||||
|
this.unsubscribeFromRoleChanges(this.setActiveRoleFromChannelMessage);
|
||||||
|
this.#roleChannel.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ActiveRoleSynchronizer;
|
@ -1,52 +0,0 @@
|
|||||||
import { BROADCAST_CHANNEL_NAME } from './constants';
|
|
||||||
|
|
||||||
class RoleChannel {
|
|
||||||
#roleChannel;
|
|
||||||
|
|
||||||
constructor(openmct, channelName = BROADCAST_CHANNEL_NAME) {
|
|
||||||
this.openmct = openmct;
|
|
||||||
this.channelName = channelName;
|
|
||||||
}
|
|
||||||
|
|
||||||
createRoleChannel() {
|
|
||||||
this.#roleChannel = new BroadcastChannel(this.channelName);
|
|
||||||
}
|
|
||||||
subscribeToRole(cb) {
|
|
||||||
this.#roleChannel.onmessage = (event) => {
|
|
||||||
const role = event.data;
|
|
||||||
this.openmct.user.setActiveRole(role);
|
|
||||||
if (cb) {
|
|
||||||
cb(role);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
unsubscribeToRole() {
|
|
||||||
this.#roleChannel.close();
|
|
||||||
}
|
|
||||||
reconnect() {
|
|
||||||
this.#roleChannel.close();
|
|
||||||
this.createRoleChannel();
|
|
||||||
}
|
|
||||||
|
|
||||||
broadcastNewRole(role) {
|
|
||||||
if (!this.#roleChannel.name) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
this.#roleChannel.postMessage(role);
|
|
||||||
} catch (e) {
|
|
||||||
console.error(e);
|
|
||||||
this.reconnect();
|
|
||||||
this.broadcastNewRole(role);
|
|
||||||
/** FIXME: there doesn't seem to be a reliable way to test for open/closed
|
|
||||||
* status of a broadcast channel; channel.name exists even after the
|
|
||||||
* channel is closed. Failure to update the subscribed tabs, should
|
|
||||||
* not block the focused tab's selection and so it is caught here.
|
|
||||||
* An error will often be thrown if the dialog remains open during HMR.
|
|
||||||
**/
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default RoleChannel;
|
|
@ -23,5 +23,5 @@
|
|||||||
export const MULTIPLE_PROVIDER_ERROR = 'Only one user provider may be set at a time.';
|
export const MULTIPLE_PROVIDER_ERROR = 'Only one user provider may be set at a time.';
|
||||||
export const NO_PROVIDER_ERROR = 'No user provider has been set.';
|
export const NO_PROVIDER_ERROR = 'No user provider has been set.';
|
||||||
|
|
||||||
export const SESSION_STORAGE_KEY = 'USER_ROLE';
|
export const SESSION_STORAGE_KEY = 'ACTIVE_USER_ROLE';
|
||||||
export const BROADCAST_CHANNEL_NAME = 'USER_ROLE';
|
export const ACTIVE_ROLE_BROADCAST_CHANNEL_NAME = 'ActiveRoleChannel';
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import RoleChannel from '../../../api/user/RoleChannel';
|
import ActiveRoleSynchronizer from '../../../api/user/ActiveRoleSynchronizer';
|
||||||
export default {
|
export default {
|
||||||
inject: ['openmct'],
|
inject: ['openmct'],
|
||||||
data() {
|
data() {
|
||||||
@ -45,13 +45,12 @@ export default {
|
|||||||
|
|
||||||
async mounted() {
|
async mounted() {
|
||||||
this.getUserInfo();
|
this.getUserInfo();
|
||||||
this.roleChannel = new RoleChannel(this.openmct);
|
this.roleChannel = new ActiveRoleSynchronizer(this.openmct);
|
||||||
this.roleChannel.createRoleChannel();
|
this.roleChannel.subscribeToRoleChanges(this.setRoleSelection);
|
||||||
this.roleChannel.subscribeToRole(this.setRoleSelection);
|
|
||||||
await this.fetchOrPromptForRole();
|
await this.fetchOrPromptForRole();
|
||||||
},
|
},
|
||||||
beforeDestroy() {
|
beforeDestroy() {
|
||||||
this.roleChannel.unsubscribeToRole();
|
this.roleChannel.unsubscribeFromRoleChanges(this.setRoleSelection);
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
async getUserInfo() {
|
async getUserInfo() {
|
||||||
|
Loading…
Reference in New Issue
Block a user