Research
Security News
Malicious PyPI Package ‘pycord-self’ Targets Discord Developers with Token Theft and Backdoor Exploit
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
create-foxglove-extension
Advanced tools
Foxglove allows developers to create
extensions, or custom code
that is loaded and executed inside the Foxglove application. Extensions are authored in TypeScript
using the @foxglove/extension
SDK.
Make sure you have Node.js 14 or newer installed. In a terminal, go
into the directory where you keep source code (ex: cd ~/Code
) and run the following
command:
npm init foxglove-extension@latest helloworld
Feel free to choose an extension name other than helloworld. Otherwise, this will create a folder named helloworld containing your extension. Run a one-time initialization step:
cd helloworld
npm install
This installs all of the dependencies needed to edit and build the extension. You can use
any editor to work on this project, although VSCode is
the best supported IDE for authoring Foxglove extensions. Look at the files
src/index.ts
and src/ExamplePanel.tsx
for a simple example of creating a React element
and registering it as a custom panel. To build and install this extension into your local
Foxglove extensions folder, run:
npm run local-install
This should create a folder under your home directory such as
~/.foxglove-studio/extensions/unknown.helloworld-0.0.0
containing your compiled
extension. Start Foxglove. If everything succeeded, you should be able to add a new
panel in Foxglove named "ExamplePanel". Each time you make a change to your
extension, you will need to run npm run local-install
again to build it and copy the
build output to the Foxglove extensions folder in your home directory. You can
either reload Foxglove or close and reopen it to load your latest extension code.
If you just want to confirm your code compiles without installing it locally, run npm run build
.
You can customize the build and install process by editing your ./config.ts
file. The
config file should look something like this:
module.exports = {
webpack: (config) => {
config.module.rules.push({
test: /\.css$/i,
use: ["style-loader", "css-loader"],
});
return config;
},
};
All of the metadata for your extension is contained in the package.json file. Before
publishing, make sure you have set name
, publisher
, version
, and description
. When
you are ready to distribute your extension, run:
npm run package
This will produce a .foxe file such as helloworld-0.0.0.foxe
. This is essentially a
ZIP archive containing your extension manifest and compiled code that can be opened by the
Foxglove application, which will unpack it and install it to the
~/.foxglove-studio/extensions
folder. Stay tuned for future instructions on how to
publish Foxglove extensions to a registry so other users can easily search for and
install your extension.
You can find examples of different kinds of extensions in the ./examples
directory.
Join our Slack channel to ask questions, share feedback, and stay up to date on what our team is working on.
FAQs
Create and package Foxglove extensions
The npm package create-foxglove-extension receives a total of 185 weekly downloads. As such, create-foxglove-extension popularity was classified as not popular.
We found that create-foxglove-extension demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.