summaryrefslogtreecommitdiff
path: root/pse-dashboard/src/api
diff options
context:
space:
mode:
Diffstat (limited to 'pse-dashboard/src/api')
-rw-r--r--pse-dashboard/src/api/gpodder.js97
-rw-r--r--pse-dashboard/src/api/gpodder.test.js29
-rw-r--r--pse-dashboard/src/api/pse-squared.js61
3 files changed, 187 insertions, 0 deletions
diff --git a/pse-dashboard/src/api/gpodder.js b/pse-dashboard/src/api/gpodder.js
new file mode 100644
index 0000000..057e5a7
--- /dev/null
+++ b/pse-dashboard/src/api/gpodder.js
@@ -0,0 +1,97 @@
+import axios from 'axios';
+
+// export default function useGpodder({
+export default function useGPodder({
+ baseURL,
+ throwHandler = (err) => err,
+ gPodderUser,
+ useCredentials
+ }) {
+
+ const gpodder = axios.create({
+ baseURL,
+ credentials: useCredentials ? "include" : "omit",
+ headers: {
+ 'Content-Type': 'application/json',
+ }
+ });
+
+ let auth = {
+ username: gPodderUser?.username || "",
+ password: gPodderUser?.password || ""
+ };
+
+ gpodder.interceptors.response.use((response) => response, (error) => {
+ // whatever you want to do with the error
+ throwHandler(error);
+ throw error;
+ });
+
+ return {
+
+ /******************************************************************************/
+ /* Authentication API */
+ /******************************************************************************/
+
+ async register(gPodderUser) {
+ return gpodder.post(`/api/2/auth/register.json`, gPodderUser);
+ },
+
+ async login(gPodderUserData) {
+ auth = gPodderUserData;
+ gPodderUser = gPodderUserData
+
+ return gpodder.post(`/api/2/auth/${gPodderUser.username}/login.json`, {}, {auth});
+ },
+
+ async logout() {
+ return gpodder.post(`/api/2/auth/${gPodderUser.username}/logout.json`, {}, {auth});
+ },
+
+ async changePassword(passwordChange) {
+ return gpodder.put(`/api/2/auth/${gPodderUser.username}/changepassword.json`, passwordChange, {auth});
+ },
+
+ async forgotPassword({email}) {
+ return gpodder.post(`/api/2/auth/${email}/forgot.json`, {});
+ },
+
+ // no auth!
+ async resetPassword({username, password, token}) {
+ return gpodder.put(`/api/2/auth/${username}/resetpassword.json?token=${token}`, {password});
+ },
+
+ async deleteAccount(passwordData) {
+ return gpodder.delete(`/api/2/auth/${gPodderUser.username}/delete.json`, {auth, data: passwordData});
+ },
+
+ /******************************************************************************/
+ /* Subscription API */
+ /******************************************************************************/
+
+ async getTitles() {
+ return gpodder.get(`/subscriptions/titles/${gPodderUser.username}.json`, {auth});
+ },
+
+ async putSubscriptions(subscriptions) {
+ return gpodder.put(`/subscriptions/${gPodderUser.username}/device.json`, subscriptions, {auth});
+ },
+
+ async postSubscriptions(subscriptions) {
+ return gpodder.post(`/api/2/subscriptions/${gPodderUser.username}/device.json`, subscriptions, {auth});
+ },
+
+ /******************************************************************************/
+ /* EpisodeActions API */
+ /******************************************************************************/
+
+ async getEpisodeActions() {
+ return gpodder.get(`/api/2/episodes/${gPodderUser.username}.json`, {auth});
+ },
+
+ async postEpisodeActions(episodeActions) {
+ return gpodder.post(`/api/2/episodes/${gPodderUser.username}.json`, episodeActions, {auth});
+ },
+ }
+}
+
diff --git a/pse-dashboard/src/api/gpodder.test.js b/pse-dashboard/src/api/gpodder.test.js
new file mode 100644
index 0000000..bf88ddd
--- /dev/null
+++ b/pse-dashboard/src/api/gpodder.test.js
@@ -0,0 +1,29 @@
+import * as GPodder from './gpodder.js'
+
+const user = new GPodder.GPodderUser({
+ username: "iam@not.real",
+ password: "12345678aB@"
+});
+
+console.log(user)
+console.log(user.username, user.password);
+
+GPodder.init({
+ baseURL: "http://localhost:8080",
+ throwHandler: err => err
+})
+
+async function testGPodder() {
+ const register = await GPodder.register(user);
+ console.log(register.status);
+
+ const login = await GPodder.login(user)
+ console.log(login.status, login.headers);
+
+ const response = await GPodder.getTitles();
+ const json = await response.text();
+ console.log(`${response.status} "${json}"`);
+
+}
+testGPodder();
+
diff --git a/pse-dashboard/src/api/pse-squared.js b/pse-dashboard/src/api/pse-squared.js
new file mode 100644
index 0000000..641542b
--- /dev/null
+++ b/pse-dashboard/src/api/pse-squared.js
@@ -0,0 +1,61 @@
+import useGPodder from '@/api/gpodder.js'
+import { useLogger } from '@/logger.js'
+
+const logger = useLogger();
+
+function errorHandler(error) {
+ if (error.response) {
+ // The request was made and the server responded with a status code
+ // that falls out of the range of 2xx
+ console.log(error.response.data);
+ console.log(error.response.status);
+ console.log(error.response.headers);
+
+ switch (error.response.status) {
+ case 400: logger.badRequestError(); break;
+ case 401: logger.unauthorizedError(); break;
+ case 404: logger.notFoundError(); break;
+ }
+
+ } else if (error.request) {
+ // The request was made but no response was received
+ // `error.request` is an instance of XMLHttpRequest in the browser and an instance of
+ // http.ClientRequest in node.js
+ logger.connectionLostError()
+
+ console.log(error.request);
+ } else {
+ // Something happened in setting up the request that triggered an Error
+ console.log('Error', error.message);
+ logger.append({
+ type: "danger",
+ message: err.message
+ });
+ }
+}
+
+const backendURL = import.meta.env.VITE_BACKEND_URL || "http://localhost:8080";
+console.log("Backend-URL", backendURL);
+
+const pseSquared = useGPodder({
+ // baseURL: process.env.VUE_APP_BASE_URL || "http://localhost:8080",
+ // baseURL: "http://api.pse-squared.de",
+ baseURL: backendURL,
+ throwHandler: error => errorHandler(error)
+});
+
+export const {
+ changePassword,
+ deleteAccount,
+ forgotPassword,
+ getEpisodeActions,
+ getTitles,
+ login,
+ logout,
+ postEpisodeActions,
+ postSubscriptions,
+ putSubscriptions,
+ register,
+ resetPassword,
+} = pseSquared;
+