Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
@deephaven/code-studio
Advanced tools
Code Studio is a web application that connects to a running deephaven-core instance. A few notes to get developers quickly up and running.
To start the Code Studio, run npm install
and npm start
in the root directory of this repository. See the Getting Started section for more details.
Project specific settings are stored in the .env
file. There is also an .env.development
file which is only
loaded in development builds, and .env.development.local
which is only for local builds. For local development,
you should be modifying .env.development.local
.
For more information on .env
, see https://create-react-app.dev/docs/adding-custom-environment-variables#adding-development-environment-variables-in-env
Below are some of the common properties which are configurable in the .env
file.
One common setup is to override the API server URL to point to another server. For example, add the following block to .env.development.local
to have npm start
point to a remote server for the API:
REACT_APP_CORE_API_URL=https://www.myserver.com/jsapi
One common setup is to override the API server URL to point to another server. For example, add the following block to .env.development.local
to have npm start
point to a remote server for the API:
REACT_APP_CORE_API_URL=https://www.myserver.com/notebooks
Printing detailed logs when debugging can be handy. To enable the highest level of logging, set the log level in your .env.development.local
file:
DEEPHAVEN_LOG_LEVEL=4
When running the unit tests, you often do not want any logs to be printed out. To disable the logs while running the unit tests, set the log level in your .env.test.local
file:
DEEPHAVEN_LOG_LEVEL=-1
See @deephaven/log for more details on the logger.
Set to true
or false
Turns on the logger proxy which captures log messages so users can easily export debug info for us. Enabling this will affect the line numbers shown in the console. Defaults to false in development and true in production.
In development, DHLogProxy
and DHLogHistory
are added to the window so they can be manipulated directly from the console if needed. DHLogProxy.enable()
will capture and emit events for all logging events. DHLogHistory.enable()
will attach event listeners to the DHLogProxy
events. Both also have a disable
method.
Visual Studio Code is recommended for code editing. We use some extensions to help our development:
formatOnSave
option to auto format when saving. Also set the Editor:Default Formatter to ebsenp.prettier-vscode
Use Chrome for debugging, install the React and Redux extensions.
VSCode Typescript Version Settings
There is the data for the current session stored in the local redux state (Redux Data), and data persisted between sessions is stored in browser storage.
The application stores data locally for the current session using Redux. Take a look in the src/redux/reducers/index.js
file for comments on the general structure and what's stored, and go into individual reducers to get the details about the data being stored.
You can also use the Chrome Redux DevTools to inspect live in a development or production environment: https://chrome.google.com/webstore/detail/redux-devtools/lmhkpmbekcpmknklioeibfkpmmfibljd?hl=en
The state transitions are also logged in the browser developer console in develop builds.
Workspace data is stored in the browsers localStorage. See LocalWorkspaceStorage for implementation details.
While developing, you may want to test specific cases that can be cumbersome to test against a real stack. You can run the mock API implementation in public/__mocks__/dh-core.js
by executing npm run mock
command. This mock is also used for unit tests.
When new functions are added to the API, ideally stubs returning a generic success case should be added to the mock API as well to avoid breakage when running the mock.
The styleguide uses Storybook and can be accessed using npm run storybook
. This runs independently of the dev server. Storybook can be used to develop components in isolation. The styleguide displays many common components and how to use them. When creating a new component, it should be added to the styleguide to show usage using a component.stories.jsx
file.
When running in development mode (npm run start
), a style guide is served up at http://localhost:4000/styleguide. This is for legacy purposes now while everything is ported over to Storybook. Do NOT add new components to this styleguide, only use it for reference if things are missing in Storybook.
For more details on the sockets and ports used, see Network Services and Web API in our docs.
The main layout of the app is based on Dashboards, which is essentially a top level tab the user has open. Before a Dashboard is loaded, it is simply a LazyDashboard. Once activated, it will load it's layout into Golden Layout. It's layout is composed of numerous Panels (see below). Each DashboardContainer listens for TabEvents from the higher level app, and for panel events emitted on the Golden Layout EventHub.
Each Dashboard is composed of panels. There are many different kinds of panels, such as IrisGridPanel, ChartPanel, MarkdownPanel, and ConsolePanel. Each panel should save a dehydrated state that can be serialized and saved in the database, then deserialized and hydrated when opening a dashboard. The dehydration/hydration step is defined in DashboardContainer with makeHydrateComponentPropsMap
and dehydrateClosedComponentConfigMap
.
This project was bootstrapped with Create React App.
You can learn more in the Create React App documentation.
To learn React, check out the React documentation.
This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting
This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size
This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app
This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration
This section has moved here: https://facebook.github.io/create-react-app/docs/deployment
yarn build
fails to minifyThis section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify
Deephaven Data Labs and any contributors grant you a license to the content of this repository under the Apache 2.0 License, see the LICENSE file.
FAQs
Deephaven Code Studio
The npm package @deephaven/code-studio receives a total of 1,384 weekly downloads. As such, @deephaven/code-studio popularity was classified as popular.
We found that @deephaven/code-studio demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 8 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.