/* GoToSocial Copyright (C) GoToSocial Authors admin@gotosocial.org SPDX-License-Identifier: AGPL-3.0-or-later This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ import type { PayloadAction} from "@reduxjs/toolkit"; import { createSlice } from "@reduxjs/toolkit"; /** * OAuthToken represents a response * to an OAuth token request. */ export interface OAuthToken { /** * Most likely to be 'Bearer' * but may be something else. */ token_type: string; /** * The actual token. Can be passed in to * authenticate further requests using the * Authorization header and the token type. */ access_token: string; } export interface OAuthApp { client_id: string; client_secret: string; } export interface OAuthState { instanceUrl?: string; loginState: "none" | "callback" | "login" | "logout"; expectingRedirect: boolean; /** * Token stored in easy-to-use format. * Will look something like: * "Authorization: Bearer BLAHBLAHBLAH" */ token?: string; app?: OAuthApp; } const initialState: OAuthState = { loginState: 'none', expectingRedirect: false, }; export const oauthSlice = createSlice({ name: "oauth", initialState: initialState, reducers: { authorize: (_state, action: PayloadAction) => { // Overrides state with payload. return action.payload; }, setToken: (state, action: PayloadAction) => { // Mark us as logged in by storing token. state.token = `${action.payload.token_type} ${action.payload.access_token}`; state.loginState = "login"; }, remove: (state) => { // Mark us as logged out by clearing auth. delete state.token; delete state.app; state.loginState = "logout"; }, }, }); export const { authorize, setToken, remove, } = oauthSlice.actions;