{"id":2175836,"name":"plotter","ecosystem":"npm","description":"Turns an array of data into a graph in a pdf document.","homepage":"https://github.com/richardeoin/nodejs-plotter","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/richardeoin/nodejs-plotter","keywords_array":["plotting","graph","pdf","gnuplot"],"namespace":null,"versions_count":12,"first_release_published_at":"2013-01-18T17:02:18.317Z","latest_release_published_at":"2014-03-18T02:07:47.480Z","latest_release_number":"0.5.0","last_synced_at":"2026-06-01T06:13:56.909Z","created_at":"2022-04-09T22:03:31.809Z","updated_at":"2026-06-01T06:13:56.909Z","registry_url":"https://www.npmjs.com/package/plotter","install_command":"npm install plotter","documentation_url":null,"metadata":{"funding":null,"dist-tags":{"latest":"0.5.0"}},"repo_metadata":{"id":6179918,"uuid":"7410120","full_name":"richardeoin/nodejs-plotter","owner":"richardeoin","description":"A node.js module that turns an array of data into a graph in a pdf document. Uses gnuplot and ps2pdf.","archived":false,"fork":false,"pushed_at":"2020-11-01T17:24:13.000Z","size":35,"stargazers_count":31,"open_issues_count":7,"forks_count":18,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-11-04T22:17:51.264Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/richardeoin.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2013-01-02T17:01:34.000Z","updated_at":"2024-08-08T15:17:24.000Z","dependencies_parsed_at":"2022-09-21T01:50:54.185Z","dependency_job_id":null,"html_url":"https://github.com/richardeoin/nodejs-plotter","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/richardeoin/nodejs-plotter","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/richardeoin","download_url":"https://codeload.github.com/richardeoin/nodejs-plotter/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter/sbom","scorecard":{"id":775296,"data":{"date":"2025-08-11","repo":{"name":"github.com/richardeoin/nodejs-plotter","commit":"f2dc132c57b8eab03156287ec90b9e388621d27c"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.2,"checks":[{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":1,"reason":"Found 4/29 approved changesets -- score normalized to 1","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE.txt:0","Info: FSF or OSI recognized license: MIT License: LICENSE.txt:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 5 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}}]},"last_synced_at":"2025-08-23T03:24:51.669Z","repository_id":6179918,"created_at":"2025-08-23T03:24:51.669Z","updated_at":"2025-08-23T03:24:51.669Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32894220,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-10T13:40:02.631Z","status":"online","status_checked_at":"2026-05-11T02:00:05.975Z","response_time":120,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"},"owner_record":{"login":"richardeoin","name":"Richard Meadows","uuid":"962920","kind":"user","description":"","email":"","website":"https://www.richard.fish","location":null,"twitter":null,"company":null,"icon_url":"https://avatars.githubusercontent.com/u/962920?u=d37564e5ebea213903cbe9ee6cc51ff4d799ea2e\u0026v=4","repositories_count":31,"last_synced_at":"2023-04-05T00:06:14.052Z","metadata":{"has_sponsors_listing":false},"html_url":"https://github.com/richardeoin","funding_links":[],"total_stars":null,"followers":null,"following":null,"created_at":"2022-11-04T15:30:10.169Z","updated_at":"2023-04-05T00:06:14.216Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/richardeoin","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/richardeoin/repositories"},"tags":[]},"repo_metadata_updated_at":"2026-05-30T05:13:52.863Z","dependent_packages_count":12,"downloads":394,"downloads_period":"last-month","dependent_repos_count":23,"rankings":{"downloads":6.849479826089102,"dependent_repos_count":2.576190480195648,"dependent_packages_count":1.7801137545680426,"stargazers_count":6.836075331659883,"forks_count":5.356301729358724,"docker_downloads_count":null,"average":4.67963222437428},"purl":"pkg:npm/plotter","advisories":[{"uuid":"MDE2OlNlY3VyaXR5QWR2aXNvcnlHSFNBLTY1eHgtYzg1eC13Zzc2","url":"https://github.com/advisories/GHSA-65xx-c85x-wg76","title":"Command Injection in plotter","description":"All versions of `plotter` are vulnerable to Command Injection. The package fails to sanitize plot titles, which may allow attackers to execute arbitrary code in the system if the title value is supplied by a user. The following proof-of-concept creates a `testing` file in the current directory:\n\n```\nvar plot = require('plotter').plot;\n\nconst title = 'Example \"\\nset title system(\"touch testing\")#';\n\nplot({\ndata: [ 3, 1, 2, 3, 4 ],\nfilename: 'output.pdf',\nstyle: 'linespoints',\ntitle: title,\nlogscale: true,\nxlabel: 'time',\nylabel: 'length of string',\nformat: 'pdf'\n});\n\n```\n\n\n## Recommendation\n\nNo fix is currently available. Consider using an alternative package until a fix is made available.","origin":"UNSPECIFIED","severity":"CRITICAL","published_at":"2020-09-04T17:20:52.000Z","withdrawn_at":null,"classification":"GENERAL","cvss_score":0.0,"cvss_vector":null,"references":["https://www.npmjs.com/advisories/1441","https://github.com/advisories/GHSA-65xx-c85x-wg76"],"source_kind":"github","identifiers":["GHSA-65xx-c85x-wg76"],"repository_url":null,"blast_radius":0.0,"created_at":"2022-12-21T16:13:14.629Z","updated_at":"2026-05-31T13:10:37.968Z","epss_percentage":null,"epss_percentile":null,"api_url":"https://advisories.ecosyste.ms/api/v1/advisories/MDE2OlNlY3VyaXR5QWR2aXNvcnlHSFNBLTY1eHgtYzg1eC13Zzc2","html_url":"https://advisories.ecosyste.ms/advisories/MDE2OlNlY3VyaXR5QWR2aXNvcnlHSFNBLTY1eHgtYzg1eC13Zzc2","packages":[{"ecosystem":"npm","package_name":"plotter","versions":[{"first_patched_version":null,"vulnerable_version_range":"\u003e= 0.0.0"}],"purl":"pkg:npm/plotter","statistics":{"dependent_packages_count":12,"dependent_repos_count":23,"downloads":394,"downloads_period":"last-month"},"affected_versions":["0.1.3","0.1.4","0.1.5","0.2.0","0.2.1","0.2.2","0.3.0","0.4.0","0.4.1","0.4.2","0.4.3","0.5.0"],"unaffected_versions":[]}],"related_packages_url":"https://advisories.ecosyste.ms/api/v1/advisories/MDE2OlNlY3VyaXR5QWR2aXNvcnlHSFNBLTY1eHgtYzg1eC13Zzc2/related_packages","related_advisories":[]}],"docker_usage_url":"https://docker.ecosyste.ms/usage/npm/plotter","docker_dependents_count":null,"docker_downloads_count":null,"usage_url":"https://repos.ecosyste.ms/usage/npm/plotter","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/npm/plotter/dependencies","status":null,"funding_links":[],"critical":null,"issue_metadata":{"last_synced_at":"2025-08-16T01:14:59.767Z","issues_count":9,"pull_requests_count":7,"avg_time_to_close_issue":84806699.5,"avg_time_to_close_pull_request":55326888.2,"issues_closed_count":4,"pull_requests_closed_count":5,"pull_request_authors_count":7,"issue_authors_count":9,"avg_comments_per_issue":0.5555555555555556,"avg_comments_per_pull_request":0.5714285714285714,"merged_pull_requests_count":4,"bot_issues_count":0,"bot_pull_requests_count":0,"past_year_issues_count":0,"past_year_pull_requests_count":0,"past_year_avg_time_to_close_issue":null,"past_year_avg_time_to_close_pull_request":null,"past_year_issues_closed_count":0,"past_year_pull_requests_closed_count":0,"past_year_pull_request_authors_count":0,"past_year_issue_authors_count":0,"past_year_avg_comments_per_issue":null,"past_year_avg_comments_per_pull_request":null,"past_year_bot_issues_count":0,"past_year_bot_pull_requests_count":0,"past_year_merged_pull_requests_count":0,"issues_url":"https://issues.ecosyste.ms/api/v1/hosts/GitHub/repositories/richardeoin%2Fnodejs-plotter/issues","maintainers":[],"active_maintainers":[]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/version_numbers","latest_version_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/latest_version","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/related_packages","codemeta_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/plotter/codemeta","maintainers":[{"uuid":"richardeoin","login":"richardeoin","name":null,"email":"richardeoin@gmail.com","url":null,"packages_count":3,"html_url":"https://www.npmjs.com/~richardeoin","role":null,"created_at":"2022-11-13T19:39:10.553Z","updated_at":"2022-11-13T19:39:10.553Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/maintainers/richardeoin/packages"}]}