mirror of
https://github.com/ZeppelinBot/Zeppelin.git
synced 2025-03-16 14:11:50 +00:00

* update pkgs
Signed-off-by: GitHub <noreply@github.com>
* new knub typings
Signed-off-by: GitHub <noreply@github.com>
* more pkg updates
Signed-off-by: GitHub <noreply@github.com>
* more fixes
Signed-off-by: GitHub <noreply@github.com>
* channel typings
Signed-off-by: GitHub <noreply@github.com>
* more message utils typings fixes
Signed-off-by: GitHub <noreply@github.com>
* migrate permissions
Signed-off-by: GitHub <noreply@github.com>
* fix: InternalPoster webhookables
Signed-off-by: GitHub <noreply@github.com>
* djs typings: Attachment & Util
Signed-off-by: GitHub <noreply@github.com>
* more typings
Signed-off-by: GitHub <noreply@github.com>
* fix: rename permissionNames
Signed-off-by: GitHub <noreply@github.com>
* more fixes
Signed-off-by: GitHub <noreply@github.com>
* half the number of errors
* knub commands => messageCommands
Signed-off-by: GitHub <noreply@github.com>
* configPreprocessor => configParser
Signed-off-by: GitHub <noreply@github.com>
* fix channel.messages
Signed-off-by: GitHub <noreply@github.com>
* revert automod any typing
Signed-off-by: GitHub <noreply@github.com>
* more configParser typings
Signed-off-by: GitHub <noreply@github.com>
* revert
Signed-off-by: GitHub <noreply@github.com>
* remove knub type params
Signed-off-by: GitHub <noreply@github.com>
* fix more MessageEmbed / MessageOptions
Signed-off-by: GitHub <noreply@github.com>
* dumb commit for @almeidx to see why this is stupid
Signed-off-by: GitHub <noreply@github.com>
* temp disable custom_events
Signed-off-by: GitHub <noreply@github.com>
* more minor typings fixes - 23 err left
Signed-off-by: GitHub <noreply@github.com>
* update djs dep
* +debug build method (revert this)
Signed-off-by: GitHub <noreply@github.com>
* Revert "+debug build method (revert this)"
This reverts commit a80af1e729
.
* Redo +debug build (Revert this)
Signed-off-by: GitHub <noreply@github.com>
* uniform before/after Load shorthands
Signed-off-by: GitHub <noreply@github.com>
* remove unused imports & add prettier plugin
Signed-off-by: GitHub <noreply@github.com>
* env fixes for web platform hosting
Signed-off-by: GitHub <noreply@github.com>
* feat: knub v32-next; related fixes
* fix: allow legacy keys in change_perms action
* fix: request Message Content intent
* fix: use Knub's config validation logic in API
* fix(dashboard): fix error when there are no message and/or slash commands in a plugin
* fix(automod): start_thread action thread options
* fix(CustomEvents): message command types
* chore: remove unneeded type annotation
* feat: add forum channel icon; use thread icon for news threads
* chore: make tslint happy
* chore: fix formatting
---------
Signed-off-by: GitHub <noreply@github.com>
Co-authored-by: almeidx <almeidx@pm.me>
Co-authored-by: Dragory <2606411+Dragory@users.noreply.github.com>
96 lines
2.6 KiB
TypeScript
96 lines
2.6 KiB
TypeScript
import { Module } from "vuex";
|
|
import { post } from "../api";
|
|
import { AuthState, IntervalType, RootState } from "./types";
|
|
|
|
// Refresh auth every 15 minutes
|
|
const AUTH_REFRESH_INTERVAL = 1000 * 60 * 15;
|
|
|
|
export const AuthStore: Module<AuthState, RootState> = {
|
|
namespaced: true,
|
|
|
|
state: {
|
|
apiKey: null,
|
|
loadedInitialAuth: false,
|
|
authRefreshInterval: null,
|
|
userId: null,
|
|
},
|
|
|
|
actions: {
|
|
async loadInitialAuth({ dispatch, commit, state }) {
|
|
if (state.loadedInitialAuth) return;
|
|
|
|
const storedKey = localStorage.getItem("apiKey");
|
|
if (storedKey) {
|
|
try {
|
|
const result = await post("auth/validate-key", { key: storedKey });
|
|
if (result.valid) {
|
|
await dispatch("setApiKey", { key: storedKey, userId: result.userId });
|
|
return;
|
|
}
|
|
} catch {} // tslint:disable-line
|
|
|
|
console.log("Unable to validate key, removing from localStorage"); // tslint:disable-line
|
|
localStorage.removeItem("apiKey");
|
|
}
|
|
|
|
commit("markInitialAuthLoaded");
|
|
},
|
|
|
|
setApiKey({ commit, state, dispatch }, { key, userId }) {
|
|
localStorage.setItem("apiKey", key);
|
|
commit("setApiKey", { key, userId });
|
|
|
|
dispatch("startAuthAutoRefresh");
|
|
},
|
|
|
|
async startAuthAutoRefresh({ commit, state, dispatch }) {
|
|
// End a previously active auto-refresh, if any
|
|
await dispatch("endAuthAutoRefresh");
|
|
|
|
// Start new auto-refresh
|
|
const refreshInterval = setInterval(async () => {
|
|
await post("auth/refresh", { key: state.apiKey });
|
|
}, AUTH_REFRESH_INTERVAL);
|
|
commit("setAuthRefreshInterval", refreshInterval);
|
|
},
|
|
|
|
endAuthAutoRefresh({ commit, state }) {
|
|
if (state.authRefreshInterval) {
|
|
window.clearInterval(state.authRefreshInterval);
|
|
}
|
|
commit("setAuthRefreshInterval", null);
|
|
},
|
|
|
|
async clearApiKey({ commit, dispatch }) {
|
|
await dispatch("endAuthAutoRefresh");
|
|
|
|
localStorage.removeItem("apiKey");
|
|
commit("setApiKey", { key: null, userId: null });
|
|
},
|
|
|
|
async logout({ dispatch }) {
|
|
await post("auth/logout");
|
|
await dispatch("clearApiKey");
|
|
},
|
|
|
|
async expiredLogin({ dispatch }) {
|
|
await dispatch("clearApiKey");
|
|
window.location.assign("/?error=expiredLogin");
|
|
},
|
|
},
|
|
|
|
mutations: {
|
|
setApiKey(state: AuthState, { key, userId }) {
|
|
state.apiKey = key;
|
|
state.userId = userId;
|
|
},
|
|
|
|
setAuthRefreshInterval(state: AuthState, interval: IntervalType | null) {
|
|
state.authRefreshInterval = interval;
|
|
},
|
|
|
|
markInitialAuthLoaded(state: AuthState) {
|
|
state.loadedInitialAuth = true;
|
|
},
|
|
},
|
|
};
|