data:image/s3,"s3://crabby-images/7e228/7e2287ba60e21dee87416ea9983ec241b5307ec2" alt="vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance"
Security News
vlt Launches "reproduce": A New Tool Challenging the Limits of Package Provenance
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
Anvil started as a way to build a single javascript module from several source files. Build tools that require a lot of explicit/declarative instructions distract from getting work on the project done.
Anvil has been rewritten as an extensible tool that uses a plugin architecture to allow developers to change pretty much everything about how it works.
The new version of anvil is not entirely backwards compatible. If you want to continue using the old version, you can still install it from npm by specifying the version number ( 0.7.9 ). If you need help converting your project to the new version, please send me an e-mail or submit an issue to the project and I'll help as I have time.
All parts of the build process are implemented as plugins. Some plugins ship along with anvil's source so that it can do something out of the box. Most of the interesting features will likely be plugins that you install.
A baseline install can do the following:
npm install anvil.js -g
Without a build file, anvil will use its default conventions to attempt to build your project.
{
"source": "src",
"spec": "spec"
"output": [ "build" ]
"dependencies": [ "anvil.mocha" ]
}
If you don't specify your own build file, anvil assumes you intend to use a build.json file. If one isn't present, it will use its own conventions to build your project. If that's all you need, great! Chances are you'll want a build.json that's configured for your specific project.
Keeping up with all the plugin defaults can be difficult. To see what's available by default for each plugin, you can write a new build file for customization.
anvil --write {name}
This command creates a build file in the current directory at {name}.json. It will include all the default settings for all the installed and built-in plugins.
Anvil allows you to combine source files by using a commented command
Javascript
// import("dependency.{ext}");
Coffeescript
### import "dependency.{ext}" ###
Stylus, LESS, CSS
CSS: /* import "dependency.{ext}" */
LESS, Stylus: // import "dependency.{ext}
When you use anvil to compile your project, it will traverse all the files in your source directory and combine them so that your top level files are what get output.
Warning Currently, anvil is not clever enough to detect circular dependencies created via import statements and it will shatter your world if you do this.
Anvil provides you with two ways to drive concatenation: yaml lists or individual yaml files
Anvil allows you to combine source files by listing the order of concatenation in a JSON or YAML format. Note: the paths must all be absolute OR relative to the top level of your source folder.
{
"./file1.js": [ "./file1a.js", "./file1b.js", "./file1c.js" ],
"./file2.js": [ "./file2a.js", "./file2b.js", "./file2c.js" ],
}
./file1.js:
- ./file1a.js
- ./file1b.js
- ./file1c.js
file2.js:
- ./file2a.js
- ./file2b.js
- ./file2c.js
Anvi will create file1.js and file2.js by concatenating the corresponding list of files in the order they appear.
This approach allows you to create a list of files to concatenate to create the final outcome. The name and location of the file will be identical to the original but anvil will strip the .json or .yaml extension off.
{ "imports": [ "./file1a.js", "./file1c.js", "./file1c.js" ] }
file1.js.yaml's contents:
- ./file1a.js
- ./file1b.js
- ./file1c.js
Each example would produce file1.js and concat each of the three listed files together to create its contents. NOTE: The paths in an individual concat file must be relative to the concat file itself.
To build with a specific build file
anvil -b <buildfile>
Anvil will watch your source directory for changes and incrementally rebuild changed files ( and any affected files ).
anvil --ci
You can configure a build to always run in this mode by adding the following JSON snippet to your build.json file:
"fileLoader": {
"continuous": "true"
}
Anvil uses color-coded messages to let you see what's happening during the build. Here's the color key:
magenta - debug
default - events
blue - build steps
green - success
yellow - warning
red - error
By default anvil will print everything but debug and warning messages unless you provide a --verbose argument or add this to your build.json :
"log": {
"debug": true
}
You can tell anvil to run in quiet mode (it will still print errors (red) and step completions (green) )
anvil -q
Special thanks to the following individuals who have contributed source code or ideas to help make anvil less buggy and more useful:
FAQs
an extensible build system
The npm package anvil.js receives a total of 5 weekly downloads. As such, anvil.js popularity was classified as not popular.
We found that anvil.js demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 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
vlt's new "reproduce" tool verifies npm packages against their source code, outperforming traditional provenance adoption in the JavaScript ecosystem.
Research
Security News
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.