Installations
npm install custom-sandpack-react
Developer Guide
Typescript
Yes
Module System
CommonJS
Node Version
14.18.1
NPM Version
lerna/4.0.0/node@v14.18.1+x64 (darwin)
Score
67.6
Supply Chain
86.8
Quality
72.1
Maintenance
100
Vulnerability
75.5
License
Releases
Contributors
Languages
TypeScript (83.86%)
MDX (9.19%)
JavaScript (4.22%)
CSS (1.95%)
SCSS (0.78%)
Love this project? Help keep it running — sponsor us today! 🚀
Developer
Download Statistics
Total Downloads
750
Last Day
1
Last Week
2
Last Month
19
Last Year
126
GitHub Statistics
Apache-2.0 License
5,208 Stars
1,142 Commits
390 Forks
26 Watchers
23 Branches
87 Contributors
Updated on Feb 23, 2025
Bundle Size
410.27 kB
Minified
139.67 kB
Minified + Gzipped
Package Meta Information
Latest Version
0.1.26
Package Id
custom-sandpack-react@0.1.26
Unpacked Size
840.12 kB
Size
200.78 kB
File Count
60
NPM Version
lerna/4.0.0/node@v14.18.1+x64 (darwin)
Node Version
14.18.1
Total Downloads
Cumulative downloads
Total Downloads
750
Last Day
0%
1
Compared to previous day
Last Week
100%
2
Compared to previous week
Last Month
26.7%
19
Compared to previous month
Last Year
-11.3%
126
Compared to previous year
Daily Downloads
Weekly Downloads
Monthly Downloads
Yearly Downloads
Dependencies
17
Dev Dependencies
22
sandpack-react
data:image/s3,"s3://crabby-images/cbe9a/cbe9a40b324fad1f927707647e1278f8c6e1efdb" alt="Demo of a React component that edits the code while the bundler executes the changes"
React components that give you the power of editable sandboxes that run in the
browser. Powered by Sandpack
, the online bundler used by
CodeSandbox.
Sandpack is an open ecosystem of components and utilities that allow you to
compile and run modern frameworks in the browser. You can either use one of our
predefined components
for embedding the CodeSandbox experience into your
projects, or you can build your own version of sandpack
, on top of our
standard components and utilities. As you walk through this guide, you will get
deeper into our ecosystem.
Getting Started
You can install this package by running
1npm i @jd/sandpack-react
or
1yarn add @jd/sandpack-react
The package contains multiple components, utilities and typings for diving into
the sandpack
ecosystem.
Using the Sandpack Component
We packed all the components and the bundler inside the <Sandpack>
component.
There's also a small stylesheet you should bring into your css pipeline.
1import { Sandpack } from "@jd/sandpack-react"; 2import "@jd/sandpack-react/dist/index.css"; 3 4<Sandpack />;
This will render a code editor and a preview component with some predefined settings. By default, this loads up a vanilla js sandbox, with no other framework dependency.
Templates, Files and Custom Setup
Your Sandpack
can start with a predefined template
. A template is a
collection of files and dependencies, a basic starter for a project if you want.
The react
template in this instance, has the starter files of a
create-react-app project.
1<Sandpack template="react" />
In most of the cases, you will want to pass custom code/files to the sandpack
instance. For this, you can use the files
prop.
The code
you pass should be pre-formatted:
1const code = `export default function App() { 2 return <h1>Hello World</h1> 3} 4`; 5 6<Sandpack 7 template="react" 8 files={{ 9 "/App.js": code, 10 }} 11/>;
The key
of each file is the relative path of the file in the project folder
structure. With this in mind, you can overwrite any of the template/sandbox
files (eg: /index.js
, /index.css
, etc.)
With the customSetup
prop, you can also pass instance specific files
,
dependencies
or specify the project entry
file. If both template
and
customSetup
are provided, the two are merged, with the customSetup
values
having higher priority. If you don't want to start from a template, you can
specify your entire sandbox structure with the customSetup
.
1const code = `import ReactMarkdown from 'react-markdown' 2 3export default function App() { 4 return <ReactMarkdown># Hello, *world*!</ReactMarkdown> 5}`; 6 7<Sandpack 8 template="react" 9 files={{ 10 "/App.js": code, 11 }} 12 customSetup={{ 13 dependencies: { 14 "react-markdown": "latest", 15 }, 16 entry: "/index.js", 17 }} 18/>;
Theming
Sandpack comes with some predefined themes:
1<Sandpack theme="codesandbox-dark" /> 2<Sandpack theme="codesandbox-light" /> 3<Sandpack theme="night-owl" /> 4<Sandpack theme="monokai-pro" />
You can also pass a partial theme object that overrides properties in the default theme
1<Sandpack 2 theme={{ 3 palette: { 4 accent: "#fc0e34", 5 inactiveText: "#aaa", 6 }, 7 syntax: { 8 keyword: "#6700ff", 9 }, 10 }} 11/>
Or you can import an existing theme object and change it or compose your own theme from scratch
1import { Sandpack, codesandboxDarkTheme } from "@jd/sandpack-react"; 2 3<Sandpack 4 theme={{ 5 ...codesandboxDarkTheme, 6 typography: { 7 fontSize: "16px", 8 bodyFont: "Arial", 9 }, 10 }} 11/>;
Customizing what is editable
By default, the Sandpack
component shows all the files you pass through
files
. If not files are passed and you use the customSetup
, all project
files will be visible as tab buttons.
The files
prop also accepts an object. When the object is used, the file
content is set with the code
property. With this notation, additional flags
you can use to customize the sandpack experience. For example, you can pass a
hidden
flag for files that you don't want to show to the user:
1<Sandpack 2 files={{ 3 "/App.js": reactCode, 4 "/button.js": buttonCode, 5 "/link.js": { 6 code: linkCode, 7 hidden: true, 8 }, 9 }} 10 template="react" 11/>
You can also specify the active
file, which is open in the code editor
initially. If no active
flag is set, the first file will be visible by
default:
1<Sandpack 2 files={{ 3 '/App.js': reactCode, 4 '/button.js': { 5 code: buttonCode, 6 active: true, 7 } 8 '/link.js': { 9 code: linkCode, 10 hidden: true, 11 }, 12 }} 13 template="react" 14/>
You can override the entire hidden/active system with two settings inside the
options
prop, but this requires you to set the relative paths in multiple
places and can be error prone, so use this with caution:
1<Sandpack 2 template="react" 3 files={{ 4 "/App.js": reactButtonCode, 5 "/button.js": buttonCode, 6 }} 7 options={{ 8 openPaths: ["/App.js", "/button.js", "/index.js"], 9 activePath: "/index.js", 10 }} 11/>
When openPaths
or activePath
are set, the hidden
and active
flags on the
files
prop are ignored.
Customizing the UI Elements
By default, Sandpack
will show the file tabs if more than one file is open and
will show a small refresh button on top of the Preview
. But you can customize
some of the parts of the component via flags set on the options
prop.
1<Sandpack 2 options={{ 3 showNavigator: true, // this will show a top navigator bar instead of the refresh button 4 showTabs: false, // you can toggle the tabs on/off manually 5 showLineNumbers: true, // this is off by default, but you can show line numbers for the editor 6 wrapContent: true, // also off by default, this wraps the code instead of creating horizontal overflow 7 editorWidthPercentage: 60, // by default the split is 50/50 between the editor and the preview 8 }} 9/>
One useful configuration is the height of the component. We recommend fixed
heights, to avoid any layout shift while the bundler is running or as you type
in the editor or switch the tab. By default, the height is set to 300px
, but
you can adjust that with the options.editorHeight
prop:
1<Sandpack 2 options={{ 3 editorHeight: 350, 4 }} 5/>
Furthermore, we implemented our css classes with a handy utility package called
classer
.
Execution Options
By default, the bundling process will start as soon as the component is getting closer to the viewport, or when the page loads if the component is already in the viewport. But you can allow users to trigger the process manually.
1<Sandpack options={{ autorun: false }} template="react" />
When a sandpack
instance is not set on autorun
, which is the default
setting, it will show a Run button that initializes the process.
The options
also allow you to customize the recompile mode, or what happens
you type inside the code editor.
1<Sandpack options={{ recompileMode: "immediate" }} template="react" />
By default, the mode is set to delayed
and there's a 500ms
debounce timeout
that ensures the bundler doesn't run on each keystroke. You can customize this
experience by modifying the recompileDelay
value or by setting the
recompileMode
to immediate
.
1<Sandpack 2 options={{ 3 recompileMode: "delayed", 4 recompileDelay: 300, 5 }} 6 template="react" 7/>
Sandpack Runner
In all the examples above we used Sandpack
, which, in our internal kitchen, we
call a preset. In other words, it is a fixed configuration of sandpack
components and default settings that make up an instance of sandpack.
In case you want to have the bundler running and you don't want the code editing
component, you can use a SandpackRunner
preset.
The SandpackRunner
has some of the props we already described above:
template
, customSetup
and theme
. They work exactly the same on this
preset.
However, your input will be sent through the code
prop. This is a single
string that will replace the main file of the project.
1import { SandpackRunner } from "@jd/sandpack-react"; 2 3<SandpackRunner code={`...`} template="vue" />;
In this example, code
will replace the App.vue
file, because that is the
main file in the vue template. For react
, this would be the App.js
file.
The main file can be specified in the customSetup. You can use any of your files to override with the code prop.
Getting deeper
If you open a preset file from the sandpack repository, you'll see it is made up of smaller sandpack components and has limited logic for passing props to those smaller components.
If you need a more custom solution, you can opt in to use these smaller components that we export from the main package.
It all starts with the SandpackProvider
, which is the central point of our
architecture. The provider abstracts the functionality of sandpack
and places
the relevant state values and functions on a context
object. The React
components that are exported by the main package (eg: SandpackCodeEditor,
SandpackPreview) use that context
object to communicate with sandpack
.
Build your custom Sandpack
Let's start from the SandpackProvider
. This becomes the root node of our new
Sandpack
component.
1import { SandpackProvider, SandpackPreview } from "@jd/sandpack-react"; 2 3const CustomSandpack = () => ( 4 <SandpackProvider> 5 <SandpackPreview /> 6 </SandpackProvider> 7);
The SandpackProvider
has the same style of parameters for the input:
template
and customSetup
. Additionally you can pass options for the bundler
and execution mode. So even if you run this basic snippet above, you will see a
default vanilla template preview, because the sandpack logic is running behind
the scenes through the context object.
However, you will notice that the buttons on the Preview look off. This is because there is no root node to set the styling and the theme variables.
You can fix that with the SandpackThemeProvider
:
1import { 2 SandpackProvider, 3 SandpackThemeProvider, 4 SandpackPreview, 5} from "@jd/sandpack-react"; 6 7const CustomSandpack = () => ( 8 <SandpackProvider> 9 <SandpackThemeProvider> 10 <SandpackPreview /> 11 </SandpackThemeProvider> 12 </SandpackProvider> 13);
The theme provider component will also render a wrapper div around your sandpack components. That div ensures the theme variables and styling is specific to this instance of sandpack.
SandpackLayout component
Let's add a code editor and introduce the SandpackLayout
component.
1import { 2 SandpackProvider, 3 SandpackLayout, 4 SandpackCodeEditor, 5 SandpackPreview, 6} from "@jd/sandpack-react"; 7 8const CustomSandpack = () => ( 9 <SandpackProvider template="react"> 10 <SandpackLayout> 11 <SandpackCodeEditor /> 12 <SandpackPreview /> 13 </SandpackLayout> 14 </SandpackProvider> 15);
And now we have pretty much the same component as the preset, minus the prop passing, which you can decide based on your specific needs.
SandpackLayout
gives you the left-right split between two components and also breaks the columns when the component is under 700px wide, so you have some responsiveness built-in. It also renders the SandpackThemeProvider.
You can also bring other components in the mix: SandpackCodeViewer
,
SandpackTranspiledCode
, FileTabs
, Navigator
and so on.
For example, you can create an editor instance that gives you the transpiled code of your active component instead of the preview page:
1import { 2 SandpackProvider, 3 SandpackLayout, 4 SandpackCodeEditor, 5 SandpackTranspiledCode, 6} from "@jd/sandpack-react"; 7 8const CustomSandpack = () => ( 9 <SandpackProvider template="react"> 10 <SandpackLayout> 11 <SandpackCodeEditor /> 12 <SandpackTranspiledCode /> 13 </SandpackLayout> 14 </SandpackProvider> 15);
You will notice that the theming applies to all components in the same way, as the theme object is also distributed by the context.
Some of the components have configuration props that toggle subparts on/off or that configure behavior/look. All of them comunicate with sandpack through the shared context.
SandpackCodeEditor props
name | type | default | description |
---|---|---|---|
showTabs | boolean | computed based on number of files | The FileTabs component is shown on top of the editor based on this flag |
showLineNumbers | boolean | false | Adds a column with line numbers on the left side of the code editor |
showInlineErrors | boolean | false | Highlights the syntax errors and parse errors from the bundler in the code editor |
showRunButton | boolean | true | Shows a Run button when the sandpack is not set to autorun |
wrapContent | boolean | false | Wraps the code lines that don't fit horizontally |
closableTabs | boolean | false | Adds a close file action to open files |
SandpackCodeViewer props
It is a Codemirror instance in a read-only and is used to syntax-highlight code.
name | type | default | description |
---|---|---|---|
showTabs | boolean | computed based on number of files | The FileTabs component is shown on top of the editor based on this flag |
showLineNumbers | boolean | false | Adds a column with line numbers on the left side of the code editor |
code | string | undefined | The code to display in the editor |
decorators | type Decorators | undefined | An array of Codemirror decorations to apply to the code |
1type Decorators = Array<{ 2 className?: string; 3 line: number; 4 startColumn?: number; 5 endColumn?: number; 6 elementAttributes?: Record<string, string>; 7}>;
SandpackPreview props
name | type | default | description |
---|---|---|---|
showNavigator | boolean | false | Shows the Navigator component on top of the Preview. When this is true, the refresh button is not shown independently on top of the Preview. |
showRefreshButton | boolean | true | Shows a refresh button positioned absolutely on top of the Preview (lower right corner) |
showOpenInCodeSandbox | boolean | true | Shows a link that creates a new codesandbox based on the current state of the sandpack instance (lower right corner). |
showSandpackErrorOverlay | boolean | true | Shows a custom overlay screen covering the preview in case of an error, with relevant information about the error |
viewportSize | ViewportSize | "auto" | On auto, the preview will scale to the size of the iframe. You can also pass presets like: "iPhone X", "Pixel 2", "iPad", "Moto G4", "Surface Duo", Or you can pass a custom size { width: number, height: number } |
viewportOrientation | "portrait" | "landscape" | "portrait" | When using a preset viewport size, you can flip the width/height with this setting |
Create a custom sandpack-aware component
If you want to build a new component or you want to re-implement the code editor, for example, you can still rely on the sandpack state and create your UI from scratch.
We added a set of hooks in the main package, with which you can connect your own components to the sandpack context.
useSandpack
To access the sandpack state in any of your components, you can use the
useSandpack
hook, as long as the component that uses that hook is mounted
inside the <SandpackProvider>
.
Let's build a simple code viewer:
1import { useSandpack } from "@jd/sandpack-react"; 2 3const SimpleCodeViewer = () => { 4 const { sandpack } = useSandpack(); 5 const { files, activePath } = sandpack; 6 7 const code = files[activePath].code; 8 return <pre>{code}</pre>; 9};
The sandpack
object is available in any component and exposes all the internal
state:
- the
files
including all the setup/template files - the
activePath
/openPaths
fields - the
error
object, if any - multiple functions for changing the state of sandpack:
updateCurrentFile
,setActiveFile
, etc.
In the component above, you get the active code string by calling
files[activePath].code
, so any change of state will trigger a re-render of the
component and an update of the code.
We can test this with the CustomSandpack
we implemented at the previous step.
1const CustomSandpack = () => ( 2 <SandpackProvider template="react"> 3 <SandpackLayout> 4 <SandpackCodeEditor /> 5 <SimpleCodeViewer /> {/* This will render the pre on the right side of your sandpack component */} 6 </SandpackLayout> 7 </SandpackProvider> 8);
useSandpack
also exports dispatch
and listen
, two functions with which you
can directly communicate with the bundler. However, at this point, you'd have to
understand all the different types of messages and payloads that are passed from
the sandpack manager to the iframe and back.
1import { useSandpack } from "@jd/sandpack-react"; 2 3const CustomRefreshButton = () => { 4 const { dispatch, listen } = useSandpack(); 5 6 const handleRefresh = () => { 7 // listens for any message dispatched between sandpack and the bundler 8 const stopListening = listen((message) => console.log(message)); 9 10 // sends the refresh message to the bundler, should be logged by the listener 11 dispatch({ type: "refresh" }); 12 13 // unsubscribe 14 stopListening(); 15 }; 16 17 return ( 18 <button type="button" onClick={handleRefresh}> 19 Refresh 20 </button> 21 ); 22};
All methods
Plus, useSandpack
exposes a bunch of methods that you can use to manage the current state of the Sandpack instance:
Method | Description |
---|---|
closeFile | Close the given path in the editor |
deleteFile | Delete the given path in the editor |
dispatch | Sends a message to the bundler |
listen | Listens for messages from the bundler |
openFile | Open the given path in the editor |
resetAllFiles | Reset all files for all paths |
resetFile | Reset the code for a given path |
setActiveFile | Set a specific file as active in a given path |
updateFile | Update the content of a file in a given path |
useActiveCode, useCodeSandboxLink, useSandpackNavigation
Some of the common functionalities of sandpack are also extracted into
specialized hooks. These all use useSandpack
under the hood, but abstract away
the shape of the state object and the dispatch/listen functions.
The refresh button can be built with the useSandpackNavigation
hook:
1import { useSandpackNavigation } from "@jd/sandpack-react"; 2 3const CustomRefreshButton = () => { 4 const { refresh } = useSandpackNavigation(); 5 return ( 6 <button type="button" onClick={() => refresh()}> 7 Refresh Sandpack 8 </button> 9 ); 10};
Similarly, we can build a custom link that opens the sandpack files in a new tab
on https://codesandbox.io. Let's the use useCodeSandboxLink
for that:
1import { useCodeSandboxLink } from "@jd/sandpack-react"; 2 3const CustomOpenInCSB = () => { 4 const url = useCodeSandboxLink(); 5 return ( 6 <a href={url} target="_blank" rel="noopener noreferrer"> 7 Open in CodeSandbox 8 </a> 9 ); 10};
We implemented the SandpackCodeEditor
on top of
codemirror/next, but it is super easy to switch to
your favorite code editor. Let's connect the sandpack state to an instance of
AceEditor. We can use the
useActiveCode
hook, which gives us the code
and the updateCode
callback.
1import { useActiveCode } from "@jd/sandpack-react"; 2import AceEditor from "react-ace"; 3import "ace-builds/src-noconflict/mode-javascript"; 4import "ace-builds/src-noconflict/theme-textmate"; 5 6const CustomAceEditor = () => { 7 const { code, updateCode } = useActiveCode(); 8 9 return ( 10 <AceEditor 11 mode="javascript" 12 defaultValue={code} 13 onChange={updateCode} 14 fontSize={14} 15 height="300px" 16 width="100%" 17 /> 18 ); 19};
Now, let's put all of these custom components together:
1export const CustomSandpack = () => ( 2 <SandpackProvider template="react"> 3 <CustomAceEditor /> 4 <SandpackPreview showRefreshButton={false} showOpenInCodeSandbox={false} /> 5 <CustomRefreshButton /> 6 <CustomOpenInCSB /> 7 </SandpackProvider> 8);
It's not pretty, but with just a few lines of code, you can create a whole new component that uses the power of sandpack, but has all the UI and functionality you need for your specific use case.
Development
If you want to contribute, fork the main repo:
https://github.com/codesandbox/sandpack
1yarn 2yarn build 3cd sandpack-react 4yarn storybook
data:image/s3,"s3://crabby-images/abe77/abe7774a394a64c3f0ed2ab877fffad0af3bf42b" alt="Empty State"
No vulnerabilities found.
Reason
8 commit(s) and 11 issue activity found in the last 90 days -- score normalized to 10
Reason
no dangerous workflow patterns detected
Reason
no binaries found in the repo
Reason
license file detected
Details
- Info: project has a license file: LICENSE:0
- Info: FSF or OSI recognized license: Apache License 2.0: LICENSE:0
Reason
SAST tool is not run on all commits -- score normalized to 7
Details
- Warn: 14 commits out of 19 are checked with a SAST tool
Reason
branch protection is not maximal on development and all release branches
Details
- Info: 'allow deletion' disabled on branch 'main'
- Info: 'force pushes' disabled on branch 'main'
- Warn: 'branch protection settings apply to administrators' is disabled on branch 'main'
- Info: 'stale review dismissal' is required to merge on branch 'main'
- Warn: required approving review count is 1 on branch 'main'
- Warn: codeowners review is not required on branch 'main'
- Info: 'last push approval' is required to merge on branch 'main'
- Warn: no status checks found to merge onto branch 'main'
- Info: PRs are required in order to make changes on branch 'main'
Reason
Found 8/25 approved changesets -- score normalized to 3
Reason
detected GitHub workflow tokens with excessive permissions
Details
- Warn: no topLevel permission defined: .github/workflows/check-pr.yml:1
- Warn: no topLevel permission defined: .github/workflows/checks.yml:1
- Warn: no topLevel permission defined: .github/workflows/release-canary.yml:1
- Warn: topLevel permissions set to 'write-all': .github/workflows/release.yml:8
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
- Warn: no security policy file detected
- Warn: no security file to analyze
- Warn: no security file to analyze
- Warn: no security file to analyze
Reason
project is not fuzzed
Details
- Warn: no fuzzer integrations found
Reason
dependency not pinned by hash detected -- score normalized to 0
Details
- Warn: third-party GitHubAction not pinned by hash: .github/workflows/check-pr.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/check-pr.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:14: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:17: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:37: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:54: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:57: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:74: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checks.yml:77: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/checks.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release-canary.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release-canary.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release-canary.yml:25: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release-canary.yml/main?enable=pin
- Warn: third-party GitHubAction not pinned by hash: .github/workflows/release-canary.yml:40: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release-canary.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:23: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:28: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:39: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:55: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:70: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:80: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:85: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/release.yml/main?enable=pin
- Warn: third-party GitHubAction not pinned by hash: .github/workflows/util-csb-projects.yml:9: update your workflow using https://app.stepsecurity.io/secureworkflow/codesandbox/sandpack/util-csb-projects.yml/main?enable=pin
- Info: 0 out of 16 GitHub-owned GitHubAction dependencies pinned
- Info: 0 out of 5 third-party GitHubAction dependencies pinned
Reason
19 existing vulnerabilities detected
Details
- Warn: Project is vulnerable to: GHSA-h5c3-5r3r-rr8q
- Warn: Project is vulnerable to: GHSA-rmvr-2pp2-xj38
- Warn: Project is vulnerable to: GHSA-xx4v-prfh-6cgc
- Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg
- Warn: Project is vulnerable to: GHSA-pxg6-pf52-xh8x
- Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275
- Warn: Project is vulnerable to: GHSA-vhxf-7vqr-mrjg
- Warn: Project is vulnerable to: GHSA-67mh-4wv8-2f99
- Warn: Project is vulnerable to: GHSA-2p57-rm9w-gvfp
- Warn: Project is vulnerable to: GHSA-cg87-wmx4-v546
- Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv
- Warn: Project is vulnerable to: GHSA-mwcw-c2x4-8c55
- Warn: Project is vulnerable to: GHSA-7gfc-8cq8-jh5f
- Warn: Project is vulnerable to: GHSA-7m27-7ghc-44w9
- Warn: Project is vulnerable to: GHSA-rhx6-c78j-4q9w
- Warn: Project is vulnerable to: GHSA-gcx4-mw62-g8wm
- Warn: Project is vulnerable to: GHSA-76p7-773f-r4q5
- Warn: Project is vulnerable to: GHSA-f5x3-32g6-xq36
- Warn: Project is vulnerable to: GHSA-vg6x-rcgg-rjx6
Score
4.7
/10
Last Scanned on 2025-02-17
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More