web/satellite: inactivity timer to dashboard added

added InactivityTimerEnabled flag to enable/disable feature
added InactivityTimerDelay to configure delay time in seconds
default timer set up to 10 minutes
reset dom events: keypress, mouseover, mousedown, touchmove

Change-Id: Idb66067c2902b2cdbe1a972225319c8abff97927
This commit is contained in:
NickolaiYurchenko 2022-01-30 15:49:21 +02:00 committed by Nikolay Yurchenko
parent aff5cae56b
commit 70c8ccb435
4 changed files with 69 additions and 0 deletions

View File

@ -94,6 +94,8 @@ type Config struct {
NewProjectDashboard bool `help:"indicates if new project dashboard should be used" default:"false"`
NewNavigation bool `help:"indicates if new navigation structure should be rendered" default:"true"`
NewObjectsFlow bool `help:"indicates if new objects flow should be used" default:"true"`
InactivityTimerEnabled bool `help:"indicates if session can be timed out due inactivity" default:"false"`
InactivityTimerDelay int `help:"inactivity timer delay in seconds" default:"600"`
// RateLimit defines the configuration for the IP and userID rate limiters.
RateLimit web.RateLimiterConfig
@ -386,6 +388,8 @@ func (server *Server) appHandler(w http.ResponseWriter, r *http.Request) {
DefaultPaidBandwidthLimit memory.Size
NewNavigation bool
NewObjectsFlow bool
InactivityTimerEnabled bool
InactivityTimerDelay int
}
data.ExternalAddress = server.config.ExternalAddress
@ -416,6 +420,8 @@ func (server *Server) appHandler(w http.ResponseWriter, r *http.Request) {
data.NewProjectDashboard = server.config.NewProjectDashboard
data.NewNavigation = server.config.NewNavigation
data.NewObjectsFlow = server.config.NewObjectsFlow
data.InactivityTimerEnabled = server.config.InactivityTimerEnabled
data.InactivityTimerDelay = server.config.InactivityTimerDelay
templates, err := server.loadTemplates()
if err != nil || templates.index == nil {

View File

@ -178,6 +178,12 @@ compensation.withheld-percents: 75,75,75,50,50,50,25,25,25,0,0,0,0,0,0
# url link to general request page
# console.general-request-url: https://supportdcs.storj.io/hc/en-us/requests/new?ticket_form_id=360000379291
# inactivity timer delay in seconds
# console.inactivity-timer-delay: 600
# indicates if session can be timed out due inactivity
# console.inactivity-timer-enabled: false
# indicates if satellite is in beta
# console.is-beta-satellite: false

View File

@ -30,6 +30,8 @@
<meta name="default-paid-bandwidth-limit" content="{{ .DefaultPaidBandwidthLimit }}">
<meta name="new-navigation-structure" content="{{ .NewNavigation }}">
<meta name="new-objects-flow" content="{{ .NewObjectsFlow }}">
<meta name="inactivity-timer-enabled" content="{{ .InactivityTimerEnabled }}">
<meta name="inactivity-timer-delay" content="{{ .InactivityTimerDelay }}">
<title>{{ .SatelliteName }}</title>
<link rel="shortcut icon" href="" type="image/x-icon">
<link rel="dns-prefetch" href="https://js.stripe.com">

View File

@ -82,6 +82,8 @@ import { APP_STATE_ACTIONS } from '@/utils/constants/actionNames';
import { AppState } from '@/utils/constants/appStateEnum';
import { LocalData } from '@/utils/localData';
import { User } from "@/types/users";
import { AuthHttpApi } from "@/api/auth";
import { MetaUtils } from "@/utils/meta";
const {
SETUP_ACCOUNT,
@ -104,6 +106,10 @@ const {
},
})
export default class DashboardArea extends Vue {
// List of DOM events that resets inactivity timer.
private readonly resetActivityEvents: string[] = ['keypress', 'mousemove', 'mousedown', 'touchmove'];
private readonly auth: AuthHttpApi = new AuthHttpApi();
private inactivityTimerId: ReturnType<typeof setTimeout>;
// Minimum number of recovery codes before the recovery code warning bar is shown.
public recoveryCodeWarningThreshold = 4;
@ -114,6 +120,7 @@ export default class DashboardArea extends Vue {
* Pre fetches user`s and project information.
*/
public async mounted(): Promise<void> {
this.setupInactivityTimers();
try {
await this.$store.dispatch(USER_ACTIONS.GET);
} catch (error) {
@ -318,6 +325,54 @@ export default class DashboardArea extends Vue {
private get isCreateProjectPage(): boolean {
return this.$route.name === RouteConfig.CreateProject.name;
}
/**
* Sets up timer id with given delay.
*/
private startInactivityTimer(): void {
const inactivityTimerDelayInSeconds = MetaUtils.getMetaContent('inactivity-timer-delay');
this.inactivityTimerId = setTimeout(this.handleInactive, parseInt(inactivityTimerDelayInSeconds) * 1000);
}
/**
* Performs logout and cleans event listeners.
*/
private async handleInactive(): Promise<void> {
try {
await this.auth.logout();
this.resetActivityEvents.forEach((eventName: string) => {
document.removeEventListener(eventName, this.resetInactivityTimer);
});
await this.$router.push(RouteConfig.Login.path);
await this.$notify.notify('Your session was timed out.');
} catch (error) {
await this.$notify.error(error.message);
}
}
/**
* Resets inactivity timer.
*/
private resetInactivityTimer(): void {
clearTimeout(this.inactivityTimerId);
this.startInactivityTimer();
}
/**
* Adds DOM event listeners and starts timer.
*/
private setupInactivityTimers(): void {
const isInactivityTimerEnabled = MetaUtils.getMetaContent('inactivity-timer-enabled');
if (isInactivityTimerEnabled === 'false') return;
this.resetActivityEvents.forEach((eventName: string) => {
document.addEventListener(eventName, this.resetInactivityTimer, false);
});
this.startInactivityTimer();
}
}
</script>