npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

request-to-curl

v0.1.6

Published

Adds a .toCurl() method to http.ClientRequest to generate output equivalent to the 'Copy as Curl' option in the WebKit debugger

Downloads

25,859

Readme

node-request-to-curl

Adds a .toCurl() method to http.ClientRequests to generate output equivalent to the 'Copy as Curl' option in the WebKit debugger.

Features

  • Based from the WebKit code that Chrome uses in its debugger to generate curl commands
  • Hooks into Node.js at a low-level and is compatible with helper libraries (tested with request)
  • Parses the outgoing request to get what was sent over the wire (compatible with streams)

Use in production

All outgoing HTTP requests are parsed using Node's own HTTP library in a manner similar to how an incoming request is handled. This will incur a minor performance penalty.

Headers

The code from WebKit removes headers that curl calculates for us (namely content-length).

How to use

request

var request = require('request');
require('request-to-curl');

request('http://www.google.com', function (error, response, body) {
    console.log(response.request.req.toCurl());
});

Output:

curl 'http://www.google.com/' --compressed

http

var http = require('http'),
    querystring = require('querystring');

require('request-to-curl');

var postData = querystring.stringify({
    'msg': 'Hello World!'
});

var options = {
    hostname: 'www.google.com',
    port: 80,
    path: '/upload',
    method: 'POST',
    headers: {
        'Content-Type': 'application/x-www-form-urlencoded',
        'Content-Length': postData.length
    }
};

var req = http.request(options, (res) => {
    console.log(req.toCurl());
});

req.on('error', (e) => {
    console.log(`problem with request: ${e.message}`);
});

// write data to request body
req.write(postData);
req.end();

Output:

curl 'http://www.google.com/upload' -H 'content-type: application/x-www-form-urlencoded' --data 'msg=Hello%20World!' --compressed

Alternatives

request-as-curl is a similar module, however, it does not parse the request over the wire and is not compatible with streams. request-as-curl requires you to pass in your request body (which should be doable in most cases) and write code for each request. Global error handling is complicated by needing to keep the request body in scope.

request-to-curl favors over-the-wire accuracy for all outgoing requests.

request-as-curl does not need to parse outgoing requests over the wire and is ideal if you want to debug a handful of requests and do not use streams. request-to-curl is what you want if you want to be log the curl command to reproduce any failed outgoing HTTP requests anywhere in your app (which is very helpful for working with third party HTTP APIs).