New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

xhprof-viewer

Package Overview
Dependencies
Maintainers
1
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

xhprof-viewer

allows retrieval and processing of PHP XHProf data (reading only, does not write XHProf data)

  • 1.1.4
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Weekly downloads
 
Created
Source

Introduction

This is a port of facebook/xhprof to nodejs

It is intended to promote the creation of better UI's for XHProf data.

Writing of XHProf data is not supported.

Dependencies


if you need to genarate image,node-xhprof requires that graphviz be installed on your system (specifically the dot command)

RHEL/Centos/etc:

yum install graphviz

Debian/Ubuntu/etc: (need to confirm package name)

apt-get install graphviz

Install


npm install xhprof

Usage

Generate Dot Script
var fs = require('fs');
var xhprof = new (require('xhprof'))({
    adapter: {
        type: 'file',
        options: {
            rootDir: __dirname,
            //file extension name
            type: 'json',
        }
    }
});

var runId = '53235ace524be';
var threshold = 0.01;
var func = null;
var source = null;
var criticalPath = true;

xhprof.callgraph.renderDotScript(runId, threshold, func, source, criticalPath, function (err, dotScript) {
    if (err) {
        console.log(err.track || err);
        process.exit();
    }

    console.log(dotScript);
});
Generate Image

Basic generation of a report from XHProf data saved in a file:

var fs = require('fs');
var xhprof = new (require('xhprof'))({adapter: {type: 'file'}, report: 'default'});

xhprof.report.getXHProfReport({run: 'abc1234', params: {}}, function (html) {
  fs.writeFileSync('./report.html', html);
  process.exit();
});

Generate a callgraph from XHProf data saved in a file:

var fs = require('fs');
var xhprof = new (require('xhprof'))({adapter: {type: 'file'}});

var runId = '53235ace524be';
var type = 'jpg';
var threshold = 0.01;
var func = null;
var source = null;
var criticalPath = true;

xhprof.callgraph.renderImage(runId, type, threshold, func, source, criticalPath, function (err, imageStream) {
  if (err) {
    console.log(err.track || err);
    process.exit();
  }

  var outStream = fs.createWriteStream(__dirname + '/callgraph.' + type, {flags: 'w'});

  imageStream.pipe(outStream);

  outStream.on('close', function () {
    process.exit();
  });

  //
  // error handling
  //
  outStream.on('error', function (err) {
    console.log('outStream.error');
    console.log(err);
    process.exit();
  });

  imageStream.on('error', function (err) {
    console.log('imageStream.error');
    console.log(err);
    process.exit();
  });
});

See tests for more examples.

Licence


Copyright (c) 2014 Sazze, Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.`

Keywords

FAQs

Package last updated on 10 Apr 2020

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc