Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/8raven #705

Merged
merged 48 commits into from
Dec 6, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
c86a444
Title not editable in standalone mode
8Rav3n Aug 24, 2023
f17cc9a
standalone load v1 (working)
8Rav3n Aug 25, 2023
94dc1f8
load from database refinements with new conf var
8Rav3n Aug 28, 2023
9e5e109
config.json reset to defaults
8Rav3n Aug 28, 2023
ceda481
first implementation - needs few refinements
8Rav3n Aug 29, 2023
bdfeaca
index on feature/log: ceda481c first implementation - needs few refin…
8Rav3n Aug 30, 2023
7ca55af
On feature/log: temp stash
8Rav3n Aug 30, 2023
3551f2e
added Tooltip for Save button in standalone mode
8Rav3n Aug 30, 2023
a826d1a
polished
8Rav3n Aug 30, 2023
15fac3e
fix on error notification
8Rav3n Aug 31, 2023
7b88f4e
minor refinement in documentation
8Rav3n Aug 31, 2023
f6f4471
Merge pull request #1 from 8Rav3n/feature/readonly
8Rav3n Aug 31, 2023
8204105
Merge branch 'fork-release' into feature/log
8Rav3n Aug 31, 2023
fdb38c7
Merge pull request #2 from 8Rav3n/feature/log
8Rav3n Aug 31, 2023
7f97533
hide logout button in standalone mode
8Rav3n Aug 31, 2023
f6e1a3a
man merge d137081cfde4b2d5dcf1192b8a9be675e953bd0b
8Rav3n Aug 31, 2023
ff6b05a
man chg 0484e44ed345e8a9008fcebc8753ddf881f038f1
8Rav3n Sep 1, 2023
bccc090
added configuration to allow multiple data DBs
8Rav3n Sep 8, 2023
5f1c206
standalone connect to multiple DBs
8Rav3n Sep 8, 2023
67e5921
fix on config-entrypoint and reorder parameters
8Rav3n Sep 8, 2023
610af3c
bugfix on config-entrypoint.sh
8Rav3n Sep 20, 2023
aaa6bbd
fix to update standaloneDB for standaloneMultiDB
8Rav3n Sep 27, 2023
a0f06e4
added useffect in card.tsx to save DB
8Rav3n Oct 13, 2023
d930e38
query modified in saveDashboardThunks
8Rav3n Oct 13, 2023
118d21a
updated config-entrypoint
8Rav3n Oct 13, 2023
e57d8aa
added config parameter to set cusom Header
8Rav3n Oct 13, 2023
f5f6546
Merge branch 'feature/persistLabels' into fork-release
8Rav3n Oct 13, 2023
061f0f4
Merge branch 'feature/styleConfigInDocker' into fork-release
8Rav3n Oct 13, 2023
b642bbe
Merge branch 'feature/graphDatabase' into fork-release
8Rav3n Oct 13, 2023
2dc5484
documentation
8Rav3n Oct 13, 2023
f6eb901
Documenttion update merge
8Rav3n Oct 13, 2023
13af4c6
fix dirt in style.config
8Rav3n Oct 13, 2023
7a02432
merge fix
8Rav3n Oct 13, 2023
821c06f
fix dirt in config.json
8Rav3n Oct 13, 2023
f7dfa85
fix merge
8Rav3n Oct 13, 2023
f3a234d
Update ApplicationConfig.ts fix dirt
8Rav3n Oct 13, 2023
5d30622
moving logging logic to its own reducer
alfredorubin96 Nov 14, 2023
6c21e5a
fixing new selector and small refactorings
alfredorubin96 Nov 20, 2023
3a43fab
cleaning code and testing standalone
alfredorubin96 Nov 20, 2023
06c0ba7
adding database list check
alfredorubin96 Nov 21, 2023
46a15ba
changing version to 3.18 to address address Cve-2023-4863 and cve-202…
alfredorubin96 Nov 21, 2023
0e865fd
Merge branch 'fork-release' of https://github.com/8Rav3n/neodash into…
alfredorubin96 Nov 21, 2023
7f9e5a8
removing unused imports
alfredorubin96 Nov 21, 2023
710294b
working on final release
alfredorubin96 Nov 21, 2023
cf1c1a4
fixed dashboards sidebar error when the db doesn't contain any dashbo…
alfredorubin96 Nov 21, 2023
5a95e1d
removing useless import
alfredorubin96 Nov 21, 2023
172dd1c
removing change in runCypherQuery and reusing the status of the query…
alfredorubin96 Nov 24, 2023
bdb5711
removing change in runCypherQuery and reusing the status of the query…
alfredorubin96 Nov 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
added configuration to allow multiple data DBs
  • Loading branch information
8Rav3n committed Sep 8, 2023
commit bccc09064a569d3ec93e56f6c2ab2332e8ec197a
50 changes: 40 additions & 10 deletions docs/modules/ROOT/pages/developer-guide/configuration.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,10 @@ will look like this:
"standaloneDashboardName": "My Dashboard",
"standaloneDashboardDatabase": "dashboards",
"standaloneDashboardURL": "",
"standaloneAllowLoad": true,
"standaloneLoadFromOtherDatabases": false
"standaloneAllowLoad": false,
"standaloneLoadFromOtherDatabases": false,
"standaloneMultiDatabase": false,
"standaloneDatabaseList": "neo4j"
}
....

Expand Down Expand Up @@ -87,16 +89,32 @@ inside Neo4j and would like to run a standalone mode deployment with a
dashboard from a URL, set this parameter to the complete URL pointing to
the dashboard JSON.

|standaloneAllowLoad |boolean |false |If set t yes the "Load Dashboard"
button will be enabled in standalone mode, allowing users to load
additional dashboards from Neo4J.
|standaloneAllowLoad |boolean |false |If set to yes the "Load Dashboard"
button will be enabled in standalone mode, allowing users to load
additional dashboards from Neo4J. This parameter is false by default
_unless you are using Neo4j Enterprise Edition_, which lets you use multiple
databases.
*NOTE*: when Load is enabled in standalone mode, only Database is available
as a source, not file.

|standaloneLoadFromOtherDatabases|boolean |false |If standaloneAllowLoad is
set to true, this parmeter enables or not users to load dashboards from
other databases than the one deifned in standaloneDashboardDatabase. If
standaloneAllowLoad is set to false this parameters has no effect.
|standaloneLoadFromOtherDatabases |boolean |false |If _standaloneAllowLoad_ is
set to true, this parmeter enables or not users to load dashboards from
other databases than the one deifned in _standaloneDashboardDatabase_. If
_standaloneAllowLoad_ is set to false this parameters has no effect.

|standaloneMultiDatabase |boolean |false |If this parameter set to true, the
standalone configuration will ignore the _standaloneDatabase_ parameter and
allow users to choose which database to connect to in the login screen, among
the ones provided in _standaloneDatabaseList_, with a dropdown list. This
parameter is false by default _unless you are using Neo4j Enterprise Edition_,
which lets you use multiple databases.

|standaloneDatabaseList |string |neo4j |If _standaloneMultiDatabase_ is
set to true, this parmeter must contain a comma separated list of database
names that will be displayed as options in the Database dropdown at user
login (e.g. 'neo4j,database1,database2' will populate the database dropdown
with the values 'neo4j','database1' and 'database2' in the connection screen).
If _standaloneMultiDatabase_ is set to false this parameters has no effect.
|===

== Configuring SSO
Expand Down Expand Up @@ -139,11 +157,23 @@ be enabled by changing the `standalone` config parameter:
* If standalone mode is `false`, all other configuration parameters are
ignored. NeoDash will run in Editor mode, and require a manual sign-in.
* If standalone mode is `true`, NeoDash will read all configuration
parameters. A *fixed dashboard* will be auto-loaded, and no changes to
parameters. A *predefined dashboard* will be auto-loaded, and no changes to
the dashboard can be made. There are two types of valid standalone
deployments:
** A standalone deployment that *reads the fixed dashboard from Neo4j*.
The `standaloneDashboardName` and `standaloneDashboardDatabase` config
parameters are used to define these.
** A standalone deployment that *reads the fixed dashboard from a URL*.
The `standaloneDashboardURL` config parameter is used to define this.

* Standalone mode can also be configured to allow users load a different
dashboard after the predefined one is loaded (a `Load Dashboard` button
will be displayed on the right side of dashboard title).
The `standaloneAllowLoad` and `standaloneLoadFromOtherDatabases` are used
to define this.
* When allowing users to load dashboards dyamically in standalone mode,
they may also need to connect to different databases, depending on the
specific dashboard bing loaded. this can be enabled setting
`standaloneMultiDatabase` to true and providing a comma separated list
of the allowed database names in the`standaloneDatabaseList` parameter.

5 changes: 5 additions & 0 deletions docs/modules/ROOT/pages/developer-guide/standalone-mode.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,11 @@ docker run -it --rm -p 5005:5005 \
-e standaloneDatabase="neo4j" \
-e standaloneDashboardName="My Dashboard" \
-e standaloneDashboardDatabase="dashboards" \
-e standaloneDashboardURL="dashboards" \
-e standaloneAllowLoad=false \
-e standaloneLoadFromOtherDatabases=false \
-e standaloneMultiDatabase=false \
-e standaloneDatabaseList="neo4j" \
neo4jlabs/neodash
....

Expand Down
3 changes: 3 additions & 0 deletions docs/modules/ROOT/pages/developer-guide/state-management.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -134,8 +134,11 @@ standalone mode.
"standaloneDatabase": "neo4j",
"standaloneDashboardName": "My Dashboard",
"standaloneDashboardDatabase": "dashboards",
"standaloneDashboardURL": "dashboards",
"standaloneAllowLoad": false,
"standaloneLoadFromOtherDatabases ": false,
"standaloneMultiDatabase": false,
"standaloneDatabaseList": "neo4j",
"notificationIsDismissable": null
}
....
5 changes: 4 additions & 1 deletion public/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,5 +10,8 @@
"standaloneDashboardDatabase": "dashboards",
"standaloneDashboardURL": "",
"standaloneAllowLoad": false,
"standaloneLoadFromOtherDatabases": false
"standaloneLoadFromOtherDatabases": false,
"standaloneMultiDatabase": false,
"standaloneDatabaseList": "neo4j"

}
4 changes: 3 additions & 1 deletion scripts/config-entrypoint.sh
Original file line number Diff line number Diff line change
Expand Up @@ -17,5 +17,7 @@ echo " \
\"standaloneDashboardDatabase\": \"${standaloneDashboardDatabase:='neo4j'}\", \
\"standaloneDashboardURL\": \"${standaloneDashboardURL:=}\", \
\"standaloneAllowLoad\": \"${standaloneAllowLoad:=false}\", \
\"standaloneLoadFromOtherDatabases\": \"${standaloneLoadFromOtherDatabases:=false}\" \
\"standaloneLoadFromOtherDatabases\": \"${standaloneLoadFromOtherDatabases:=false}\", \
\"standaloneMultiDatabase\": ${standaloneMultiDatabase:=false}\", \
\"standaloneDatabaseList\": ${standaloneDatabaseList:='neo4j'}\" \
}" > /usr/share/nginx/html/config.json
6 changes: 5 additions & 1 deletion src/application/ApplicationActions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,9 @@ export const setStandaloneEnabled = (
standaloneUsername: string,
standalonePassword: string,
standaloneAllowLoad: boolean,
standaloneLoadFromOtherDatabases: boolean
standaloneLoadFromOtherDatabases: boolean,
standaloneMultiDatabase: boolean,
standaloneDatabaseList: string
) => ({
type: SET_STANDALONE_ENABLED,
payload: {
Expand All @@ -161,6 +163,8 @@ export const setStandaloneEnabled = (
standalonePassword,
standaloneAllowLoad,
standaloneLoadFromOtherDatabases,
standaloneMultiDatabase,
standaloneDatabaseList,
},
});

Expand Down
6 changes: 5 additions & 1 deletion src/application/ApplicationReducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,9 @@ export const applicationReducer = (state = initialState, action: { type: any; pa
standaloneUsername,
standalonePassword,
standaloneAllowLoad,
standaloneLoadFromOtherDatabases
standaloneLoadFromOtherDatabases,
standaloneMultiDatabase,
standaloneDatabaseList,
} = payload;
state = update(state, {
standalone: standalone,
Expand All @@ -150,6 +152,8 @@ export const applicationReducer = (state = initialState, action: { type: any; pa
standalonePassword: standalonePassword,
standaloneAllowLoad: standaloneAllowLoad,
standaloneLoadFromOtherDatabases: standaloneLoadFromOtherDatabases,
standaloneMultiDatabase: standaloneMultiDatabase,
standaloneDatabaseList: standaloneDatabaseList,
});
return state;
}
Expand Down
2 changes: 2 additions & 0 deletions src/application/ApplicationSelectors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,8 @@ export const applicationGetStandaloneSettings = (state: any) => {
standalonePassword: state.application.standalonePassword,
standaloneAllowLoad: state.application.standaloneAllowLoad,
standaloneLoadFromOtherDatabases: state.application.standaloneLoadFromOtherDatabases,
standaloneMultiDatabase: state.application.standaloneMultiDatabase,
standaloneDatabaseList: state.application.standaloneDatabaseList,
};
};

Expand Down
4 changes: 4 additions & 0 deletions src/application/ApplicationThunks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -351,6 +351,8 @@ export const loadApplicationConfigThunk = () => async (dispatch: any, getState:
standaloneDashboardURL: '',
standaloneAllowLoad: false,
standaloneLoadFromOtherDatabases: false,
standaloneMultiDatabase: false,
standaloneDatabaseList: 'neo4j',
};
try {
config = await (await fetch('config.json')).json();
Expand Down Expand Up @@ -395,6 +397,8 @@ export const loadApplicationConfigThunk = () => async (dispatch: any, getState:
config.standalonePassword,
config.standaloneAllowLoad,
config.standaloneLoadFromOtherDatabases,
config.standaloneMultiDatabase,
config.standaloneDatabaseList,
)
);
dispatch(setConnectionModalOpen(false));
Expand Down
9 changes: 4 additions & 5 deletions src/dashboard/header/DashboardHeader.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { connect } from 'react-redux';
import { setDashboardTitle } from '../DashboardActions';
import { getDashboardSettings, getDashboardTheme, getDashboardTitle, getPages } from '../DashboardSelectors';
import { setConnectionModalOpen } from '../../application/ApplicationActions';
import { applicationIsStandalone } from '../../application/ApplicationSelectors';
import { applicationGetStandaloneSettings } from '../../application/ApplicationSelectors';
import { getDashboardIsEditable, getPageNumber } from '../../settings/SettingsSelectors';
import { NeoDashboardHeaderLogo } from './DashboardHeaderLogo';
import NeoAboutButton from './DashboardHeaderAboutButton';
Expand All @@ -15,7 +15,7 @@ import { DASHBOARD_HEADER_BUTTON_COLOR } from '../../config/ApplicationConfig';
import { Tooltip } from '@mui/material';

export const NeoDashboardHeader = ({
standalone,
standaloneSettings,
dashboardTitle,
connection,
settings,
Expand Down Expand Up @@ -45,7 +45,6 @@ export const NeoDashboardHeader = ({
useEffect(() => {
setTheme(isDarkMode ? 'dark' : 'light');
}, [isDarkMode]);

const content = (
<div className='n-relative n-bg-neutral-bg-weak n-w-full'>
<div className='n-min-w-full'>
Expand All @@ -72,7 +71,7 @@ export const NeoDashboardHeader = ({

{downloadImageEnabled && <NeoDashboardHeaderDownloadImageButton onDownloadImage={onDownloadImage} />}
<NeoAboutButton connection={connection} onAboutModalOpen={onAboutModalOpen} />
<NeoLogoutButton standalone={standalone} onConnectionModalOpen={onConnectionModalOpen} />
<NeoLogoutButton standaloneSettings={standaloneSettings} onConnectionModalOpen={onConnectionModalOpen} />
</div>
</div>
</div>
Expand All @@ -84,7 +83,7 @@ export const NeoDashboardHeader = ({

const mapStateToProps = (state) => ({
dashboardTitle: getDashboardTitle(state),
standalone: applicationIsStandalone(state),
standaloneSettings: applicationGetStandaloneSettings(state),
pages: getPages(state),
settings: getDashboardSettings(state),
editable: getDashboardIsEditable(state),
Expand Down
34 changes: 17 additions & 17 deletions src/dashboard/header/DashboardHeaderLogoutButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,24 +9,24 @@ import { ArrowRightOnRectangleIconOutline } from '@neo4j-ndl/react/icons';

await StyleConfig.getInstance();

export const NeoLogoutButton = ({ standalone, onConnectionModalOpen }) => {
export const NeoLogoutButton = ({ standaloneSettings, onConnectionModalOpen }) => {
return (
<Tooltip title={'Log out'} disableInteractive>
<IconButton
className='logo-btn n-p-1'
aria-label={'connection '}
style={DASHBOARD_HEADER_BUTTON_COLOR ? { color: DASHBOARD_HEADER_BUTTON_COLOR } : {}}
onClick={() => {
if (!standalone) {
onConnectionModalOpen();
}
}}
size='large'
clean
>
<ArrowRightOnRectangleIconOutline className='header-icon' type='outline' />
</IconButton>
</Tooltip>
(standaloneSettings.standalone && !standaloneSettings.standaloneMultiDatabase) ?
(<></>) :
(
<Tooltip title={'Log out'} disableInteractive>
<IconButton
className='logo-btn n-p-1'
aria-label={'connection '}
style={DASHBOARD_HEADER_BUTTON_COLOR ? { color: DASHBOARD_HEADER_BUTTON_COLOR } : {}}
onClick={() => { onConnectionModalOpen(); }}
size='large'
clean
>
<ArrowRightOnRectangleIconOutline className='header-icon' type='outline' />
</IconButton>
</Tooltip>
)
);
};

Expand Down
49 changes: 39 additions & 10 deletions src/modal/ConnectionModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export default function NeoConnectionModal({
const [username, setUsername] = React.useState(connection.username);
const [password, setPassword] = React.useState(connection.password);
const [database, setDatabase] = React.useState(connection.database);

// Make sure local vars are updated on external connection updates.
useEffect(() => {
setProtocol(connection.protocol);
Expand All @@ -41,6 +41,14 @@ export default function NeoConnectionModal({
}, [JSON.stringify(ssoSettings)]);

const discoveryAPIUrl = ssoSettings && ssoSettings.ssoDiscoveryUrl;

//sice config is loaded asynchronously, value may not be yet defined when this runs for first time
let databaseList = ['neo4j']
try{
databaseList = standaloneSettings.standaloneDatabaseList.split(',')
}
catch(e){
}

return (
<>
Expand Down Expand Up @@ -126,15 +134,36 @@ export default function NeoConnectionModal({
Neo4j Aura databases require a <code>neo4j+s</code> protocol. Your current configuration may not work.
</div>
) : null}
<TextInput
id='database'
value={database}
disabled={standalone}
onChange={(e) => setDatabase(e.target.value)}
label='Database (optional)'
placeholder='neo4j'
fluid
/>
{
!standalone ? (
<TextInput
id='database'
value={database}
disabled={standalone}
onChange={(e) => setDatabase(e.target.value)}
label='Database (optional)'
placeholder='neo4j'
fluid
/>
) : (
<Dropdown
id='database'
label='Database'
type='select'
selectProps={{
onChange: (newValue) => {setDatabase(newValue.value);},
//if application is running standalone and standaloneLoadFromOtherDatabases is not enabled, we do not allow changing database
options: databaseList.map((option) => ({
label: option,
value: option,
})),
value: { label: database, value: database },
menuPlacement: 'auto',
}}
fluid
></Dropdown>
)
}

{!ssoVisible ? (
<TextInput
Expand Down