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:
parent
aff5cae56b
commit
70c8ccb435
@ -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 {
|
||||
|
6
scripts/testdata/satellite-config.yaml.lock
vendored
6
scripts/testdata/satellite-config.yaml.lock
vendored
@ -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
|
||||
|
||||
|
@ -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">
|
||||
|
@ -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>
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user