🏗 WIP fixes for AirDCPP socket connection Part Deux
This commit is contained in:
@@ -10,19 +10,18 @@ import {
|
|||||||
SETTINGS_SERVICE_BASE_URI,
|
SETTINGS_SERVICE_BASE_URI,
|
||||||
} from "../constants/endpoints";
|
} from "../constants/endpoints";
|
||||||
|
|
||||||
export const saveSettings =
|
export const saveSettings = (settingsPayload) => async (dispatch) => {
|
||||||
(settingsPayload, settingsObjectId?) => async (dispatch) => {
|
const result = await axios({
|
||||||
const result = await axios({
|
url: `${SETTINGS_SERVICE_BASE_URI}/saveSettings`,
|
||||||
url: `${SETTINGS_SERVICE_BASE_URI}/saveSettings`,
|
method: "POST",
|
||||||
method: "POST",
|
data: { settingsPayload },
|
||||||
data: { settingsPayload, settingsObjectId },
|
});
|
||||||
});
|
console.log(result.data);
|
||||||
console.log(result.data);
|
dispatch({
|
||||||
dispatch({
|
type: SETTINGS_OBJECT_FETCHED,
|
||||||
type: SETTINGS_OBJECT_FETCHED,
|
data: result.data,
|
||||||
data: result.data,
|
});
|
||||||
});
|
};
|
||||||
};
|
|
||||||
|
|
||||||
export const getSettings = (settingsKey?) => async (dispatch) => {
|
export const getSettings = (settingsKey?) => async (dispatch) => {
|
||||||
const result = await axios({
|
const result = await axios({
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import React, { ReactElement } from "react";
|
|||||||
|
|
||||||
export const AirDCPPSettingsConfirmation = (settingsObject): ReactElement => {
|
export const AirDCPPSettingsConfirmation = (settingsObject): ReactElement => {
|
||||||
const { settings } = settingsObject;
|
const { settings } = settingsObject;
|
||||||
|
console.log(settings);
|
||||||
return (
|
return (
|
||||||
<div className="mt-4 is-clearfix">
|
<div className="mt-4 is-clearfix">
|
||||||
<div className="card">
|
<div className="card">
|
||||||
@@ -11,52 +11,17 @@ export const AirDCPPSettingsConfirmation = (settingsObject): ReactElement => {
|
|||||||
<div className="content is-size-7">
|
<div className="content is-size-7">
|
||||||
<dl>
|
<dl>
|
||||||
<dt>{settings._id}</dt>
|
<dt>{settings._id}</dt>
|
||||||
<dt>
|
<dt>Client version: {settings.system_info.client_version}</dt>
|
||||||
Client version:{" "}
|
<dt>Hostname: {settings.system_info.hostname}</dt>
|
||||||
{
|
<dt>Platform: {settings.system_info.platform}</dt>
|
||||||
settings.directConnect.client.airDCPPUserSettings.system_info
|
|
||||||
.client_version
|
|
||||||
}
|
|
||||||
</dt>
|
|
||||||
<dt>
|
|
||||||
Hostname:{" "}
|
|
||||||
{
|
|
||||||
settings.directConnect.client.airDCPPUserSettings.system_info
|
|
||||||
.hostname
|
|
||||||
}
|
|
||||||
</dt>
|
|
||||||
<dt>
|
|
||||||
Platform:{" "}
|
|
||||||
{
|
|
||||||
settings.directConnect.client.airDCPPUserSettings.system_info
|
|
||||||
.platform
|
|
||||||
}
|
|
||||||
</dt>
|
|
||||||
|
|
||||||
<dt>
|
<dt>Username: {settings.user.username}</dt>
|
||||||
Username:{" "}
|
|
||||||
{
|
|
||||||
settings.directConnect.client.airDCPPUserSettings.user
|
|
||||||
.username
|
|
||||||
}
|
|
||||||
</dt>
|
|
||||||
|
|
||||||
<dt>
|
<dt>Active Sessions: {settings.user.active_sessions}</dt>
|
||||||
Active Sessions:{" "}
|
|
||||||
{
|
|
||||||
settings.directConnect.client.airDCPPUserSettings.user
|
|
||||||
.active_sessions
|
|
||||||
}
|
|
||||||
</dt>
|
|
||||||
<dt>
|
<dt>
|
||||||
Permissions:{" "}
|
Permissions:{" "}
|
||||||
<pre>
|
<pre>
|
||||||
{JSON.stringify(
|
{JSON.stringify(settings.user.permissions, undefined, 2)}
|
||||||
settings.directConnect.client.airDCPPUserSettings.user
|
|
||||||
.permissions,
|
|
||||||
undefined,
|
|
||||||
2,
|
|
||||||
)}
|
|
||||||
</pre>
|
</pre>
|
||||||
</dt>
|
</dt>
|
||||||
</dl>
|
</dl>
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
import React, { ReactElement, useCallback, useContext } from "react";
|
import React, { ReactElement, useCallback, useContext, useEffect } from "react";
|
||||||
import { Form, Field } from "react-final-form";
|
import { Form, Field } from "react-final-form";
|
||||||
import { useDispatch } from "react-redux";
|
import { useDispatch } from "react-redux";
|
||||||
import { saveSettings, deleteSettings } from "../../actions/settings.actions";
|
import { saveSettings, deleteSettings } from "../../actions/settings.actions";
|
||||||
@@ -8,33 +8,29 @@ import { isUndefined, isEmpty, isNil } from "lodash";
|
|||||||
|
|
||||||
export const AirDCPPSettingsForm = (): ReactElement => {
|
export const AirDCPPSettingsForm = (): ReactElement => {
|
||||||
const dispatch = useDispatch();
|
const dispatch = useDispatch();
|
||||||
const airDCPPConfiguration = useContext(AirDCPPSocketContext);
|
const airDCPPSettings = useContext(AirDCPPSocketContext);
|
||||||
const { AirDCPPSocket, settings } = airDCPPConfiguration;
|
const onSubmit = useCallback(async (values) => {
|
||||||
|
|
||||||
const onSubmit = async (values) => {
|
|
||||||
try {
|
try {
|
||||||
if (!isNil(AirDCPPSocket.session_id)) {
|
airDCPPSettings.setSettings(values);
|
||||||
dispatch(
|
dispatch(
|
||||||
saveSettings({
|
saveSettings({
|
||||||
host: values,
|
host: values,
|
||||||
airDCPPUserSettings: settings,
|
}),
|
||||||
}),
|
);
|
||||||
);
|
|
||||||
}
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.log(error);
|
console.log(error);
|
||||||
}
|
}
|
||||||
};
|
}, []);
|
||||||
|
|
||||||
const removeSettings = useCallback(async () => {
|
const removeSettings = useCallback(async () => {
|
||||||
dispatch(deleteSettings());
|
dispatch(deleteSettings());
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
const validate = async () => {};
|
const validate = async () => {};
|
||||||
const initFormData =
|
|
||||||
!isEmpty(settings.directConnect) || !isUndefined(settings.directConnect)
|
// const initFormData = !isUndefined(airDCPPSettings)
|
||||||
? settings.directConnect.client.host
|
// ? airDCPPSettings.airDCPPState.settings.directConnect.client.host
|
||||||
: {};
|
// : {};
|
||||||
|
const initFormData = {};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Form
|
<Form
|
||||||
@@ -111,17 +107,20 @@ export const AirDCPPSettingsForm = (): ReactElement => {
|
|||||||
</form>
|
</form>
|
||||||
)}
|
)}
|
||||||
/>
|
/>
|
||||||
{!isEmpty(settings) ? (
|
{!isUndefined(airDCPPSettings.airDCPPState.socketConnectionInformation) ? (
|
||||||
<AirDCPPSettingsConfirmation settings={settings} />
|
<AirDCPPSettingsConfirmation
|
||||||
|
settings={airDCPPSettings.airDCPPState.socketConnectionInformation}
|
||||||
|
/>
|
||||||
) : null}
|
) : null}
|
||||||
|
|
||||||
{!isEmpty(settings) ? (
|
{/* {!isUndefined(settings) &&
|
||||||
|
!isEmpty(settings.directConnect.client.airDCPPUserSettings) ? (
|
||||||
<p className="control mt-4">
|
<p className="control mt-4">
|
||||||
<button className="button is-danger" onClick={removeSettings}>
|
<button className="button is-danger" onClick={removeSettings}>
|
||||||
Delete
|
Delete
|
||||||
</button>
|
</button>
|
||||||
</p>
|
</p>
|
||||||
) : null}
|
) : null} */}
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -25,10 +25,14 @@ import { isEmpty, isNil, isUndefined } from "lodash";
|
|||||||
|
|
||||||
const AirDCPPSocketComponent = (): ReactElement => {
|
const AirDCPPSocketComponent = (): ReactElement => {
|
||||||
const airDCPPConfiguration = useContext(AirDCPPSocketContext);
|
const airDCPPConfiguration = useContext(AirDCPPSocketContext);
|
||||||
const { AirDCPPSocket, settings } = airDCPPConfiguration;
|
console.log(airDCPPConfiguration);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const foo = async () => {
|
const foo = async () => {
|
||||||
if (!isUndefined(AirDCPPSocket)) {
|
if (
|
||||||
|
!isUndefined(airDCPPConfiguration.airDCPPState) &&
|
||||||
|
!isEmpty(airDCPPConfiguration.airDCPPState.settings)
|
||||||
|
) {
|
||||||
await AirDCPPSocket.addListener(
|
await AirDCPPSocket.addListener(
|
||||||
"queue",
|
"queue",
|
||||||
"queue_bundle_added",
|
"queue_bundle_added",
|
||||||
@@ -40,7 +44,7 @@ const AirDCPPSocketComponent = (): ReactElement => {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
foo();
|
foo();
|
||||||
}, [settings]);
|
}, []);
|
||||||
return <></>;
|
return <></>;
|
||||||
};
|
};
|
||||||
export const App = (): ReactElement => {
|
export const App = (): ReactElement => {
|
||||||
|
|||||||
@@ -2,8 +2,7 @@ import React, { ReactElement, useCallback } from "react";
|
|||||||
import { flushDb } from "../../actions/settings.actions";
|
import { flushDb } from "../../actions/settings.actions";
|
||||||
import { useDispatch, useSelector } from "react-redux";
|
import { useDispatch, useSelector } from "react-redux";
|
||||||
|
|
||||||
export const SystemSettingsForm = (settingsObject): ReactElement => {
|
export const SystemSettingsForm = (): ReactElement => {
|
||||||
|
|
||||||
const dispatch = useDispatch();
|
const dispatch = useDispatch();
|
||||||
const isSettingsCallInProgress = useSelector(
|
const isSettingsCallInProgress = useSelector(
|
||||||
(state: RootState) => state.settings.inProgress,
|
(state: RootState) => state.settings.inProgress,
|
||||||
|
|||||||
@@ -1,46 +1,81 @@
|
|||||||
import axios from "axios";
|
import { isEmpty, isUndefined } from "lodash";
|
||||||
import React, { createContext, useEffect, useMemo, useState } from "react";
|
import React, { createContext, useEffect, useMemo, useState } from "react";
|
||||||
import { SETTINGS_SERVICE_BASE_URI } from "../constants/endpoints";
|
import { useDispatch, useSelector } from "react-redux";
|
||||||
|
import { getSettings } from "../actions/settings.actions";
|
||||||
import AirDCPPSocket from "../services/DcppSearchService";
|
import AirDCPPSocket from "../services/DcppSearchService";
|
||||||
|
|
||||||
const AirDCPPSocketContext = createContext({});
|
|
||||||
const AirDCPPSocketContextProvider = ({ children }) => {
|
const AirDCPPSocketContextProvider = ({ children }) => {
|
||||||
const [airDCPPConfiguration, setValue] = useState({});
|
// setter for settings for use in the context consumer
|
||||||
|
const setSettings = (settingsObject) => {
|
||||||
|
persistSettings({
|
||||||
|
...airDCPPState,
|
||||||
|
airDCPPState: {
|
||||||
|
settings: settingsObject,
|
||||||
|
socket: {},
|
||||||
|
socketConnectionInformation: {},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
};
|
||||||
|
// 1. default zero-state for AirDC++ configuration
|
||||||
|
const initState = {
|
||||||
|
airDCPPState: { settings: {}, socket: {}, socketConnectionInformation: {} },
|
||||||
|
setSettings: setSettings,
|
||||||
|
};
|
||||||
|
const dispatch = useDispatch();
|
||||||
|
const [airDCPPState, persistSettings] = useState(initState);
|
||||||
|
const airDCPPSettings = useSelector(
|
||||||
|
(state: RootState) => state.settings.data,
|
||||||
|
);
|
||||||
|
|
||||||
|
// 1. get settings from mongo
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const initializeAirDCPPSocket = () => {
|
dispatch(getSettings());
|
||||||
axios({
|
|
||||||
url: `${SETTINGS_SERVICE_BASE_URI}/getSettings`,
|
|
||||||
method: "POST",
|
|
||||||
data: "",
|
|
||||||
})
|
|
||||||
.then(async (data) => {
|
|
||||||
const { directConnect } = data.data;
|
|
||||||
const initializedAirDCPPSocket = new AirDCPPSocket({
|
|
||||||
protocol: `${directConnect.client.host.protocol}`,
|
|
||||||
hostname: `${directConnect.client.host.hostname}`,
|
|
||||||
});
|
|
||||||
|
|
||||||
await initializedAirDCPPSocket.connect(
|
|
||||||
`${directConnect.client.host.username}`,
|
|
||||||
`${directConnect.client.host.password}`,
|
|
||||||
true,
|
|
||||||
);
|
|
||||||
setValue({
|
|
||||||
AirDCPPSocket: initializedAirDCPPSocket,
|
|
||||||
settings: data.data,
|
|
||||||
});
|
|
||||||
})
|
|
||||||
.catch((error) => console.log(error));
|
|
||||||
};
|
|
||||||
initializeAirDCPPSocket();
|
|
||||||
}, []);
|
}, []);
|
||||||
|
|
||||||
|
// 2. If available, init AirDC++ Socket with those settings
|
||||||
|
useEffect(() => {
|
||||||
|
if (!isEmpty(airDCPPSettings)) {
|
||||||
|
initializeAirDCPPSocket(airDCPPSettings);
|
||||||
|
}
|
||||||
|
}, [airDCPPSettings]);
|
||||||
|
|
||||||
|
// Method to init AirDC++ Socket with supplied settings
|
||||||
|
const initializeAirDCPPSocket = async (configuration) => {
|
||||||
|
const {
|
||||||
|
directConnect: {
|
||||||
|
client: { host },
|
||||||
|
},
|
||||||
|
} = configuration;
|
||||||
|
const initializedAirDCPPSocket = new AirDCPPSocket({
|
||||||
|
protocol: `${host.protocol}`,
|
||||||
|
hostname: `${host.hostname}`,
|
||||||
|
});
|
||||||
|
|
||||||
|
const socketConnectionInformation = await initializedAirDCPPSocket.connect(
|
||||||
|
`${host.username}`,
|
||||||
|
`${host.password}`,
|
||||||
|
true,
|
||||||
|
);
|
||||||
|
persistSettings({
|
||||||
|
...airDCPPState,
|
||||||
|
airDCPPState: {
|
||||||
|
settings: configuration,
|
||||||
|
socket: initializedAirDCPPSocket,
|
||||||
|
socketConnectionInformation,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
// the Provider gives access to the context to its children
|
// the Provider gives access to the context to its children
|
||||||
return (
|
return (
|
||||||
<AirDCPPSocketContext.Provider value={airDCPPConfiguration}>
|
<AirDCPPSocketContext.Provider value={airDCPPState}>
|
||||||
{children}
|
{children}
|
||||||
</AirDCPPSocketContext.Provider>
|
</AirDCPPSocketContext.Provider>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
const AirDCPPSocketContext = createContext({
|
||||||
|
airDCPPState: {},
|
||||||
|
saveSettings: () => {},
|
||||||
|
});
|
||||||
|
|
||||||
export { AirDCPPSocketContext, AirDCPPSocketContextProvider };
|
export { AirDCPPSocketContext, AirDCPPSocketContextProvider };
|
||||||
|
|||||||
Reference in New Issue
Block a user