
Product
Rubygems Ecosystem Support Now Generally Available
Socket's Rubygems ecosystem support is moving from beta to GA, featuring enhanced security scanning to detect supply chain threats beyond traditional CVEs in your Ruby dependencies.
Asynchronously, recursively copy directories and files.
npm install cprf
To copy ./my_source
to ./my_destination
:
var cprf = require('cprf');
cprf('./my_source', './my_destination', function (err) {
if (err) throw err;
});
You can also completely customize the copy procedure by listening to the copy
event. This allows you to do things like changing destination file names and modifying file contents on copy.
var cprf = require('cprf');
var stream = require('stream');
var makeUpperCase = new stream.Transform();
makeUpperCase._transform = function (chunk, enc, cb) {
cb(null, chunk.toString().toUpperCase());
};
cprf('./my_source', './my_destination', function (err) {
if (err) throw err;
}).on('copy', function (stats, src, dest, copy) {
copy(src, dest, makeUpperCase);
});
The copy
event emits the following data:
stats
- the fs.Stat
object resulting from running fs.lstat()
on the source;src
- the absolute source path;dest
- the absolute destination path;copy
- a function of signature copy(src, dest, transform)
. You must call it if you wish to actually perform a copy operation. It takes the following arguments:
src
- the absolute source path;dest
- the absolute destination path;transform
- a stream.Transform instance through which the source file contents will be piped before being written to the destination. If the source is not a file, it will be ignored.Copyright (c) 2014, Aleksey Smolenchuk lxe@lxe.co
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
FAQs
Recursively copy files and directories
The npm package cprf receives a total of 0 weekly downloads. As such, cprf popularity was classified as not popular.
We found that cprf demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.
Product
Socket's Rubygems ecosystem support is moving from beta to GA, featuring enhanced security scanning to detect supply chain threats beyond traditional CVEs in your Ruby dependencies.
Research
The Socket Research Team investigates a malicious npm package that appears to be an Advcash integration but triggers a reverse shell during payment success, targeting servers handling transactions.
Security Fundamentals
The Socket Threat Research Team uncovers how threat actors weaponize shell techniques across npm, PyPI, and Go ecosystems to maintain persistence and exfiltrate data.