{"id":1878626,"name":"is-arrayish","ecosystem":"npm","description":"Determines if an object can be used as an array","homepage":"https://github.com/qix-/node-is-arrayish#readme","licenses":"MIT","normalized_licenses":["MIT"],"repository_url":"https://github.com/qix-/node-is-arrayish","keywords_array":["is","array","duck","type","arrayish","similar","proto","prototype","type"],"namespace":null,"versions_count":9,"first_release_published_at":"2015-08-25T17:08:51.805Z","latest_release_published_at":"2025-09-13T16:44:23.359Z","latest_release_number":"0.3.4","last_synced_at":"2026-06-24T01:13:27.692Z","created_at":"2022-04-09T17:48:16.184Z","updated_at":"2026-06-24T01:14:08.897Z","registry_url":"https://www.npmjs.com/package/is-arrayish","install_command":"npm install is-arrayish","documentation_url":null,"metadata":{"funding":null,"dist-tags":{"latest":"0.3.4"}},"repo_metadata":{"id":47622211,"uuid":"41376759","full_name":"Qix-/node-is-arrayish","owner":"Qix-","description":"Check if an object can be used like an Array","archived":false,"fork":false,"pushed_at":"2021-08-19T13:17:08.000Z","size":11,"stargazers_count":16,"open_issues_count":0,"forks_count":11,"subscribers_count":3,"default_branch":"master","last_synced_at":"2024-09-04T21:42:55.527Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"CoffeeScript","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/Qix-.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2015-08-25T17:06:38.000Z","updated_at":"2023-05-10T22:22:37.000Z","dependencies_parsed_at":"2022-09-06T05:21:16.477Z","dependency_job_id":null,"html_url":"https://github.com/Qix-/node-is-arrayish","commit_stats":null,"previous_names":[],"tags_count":7,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Qix-","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":219004270,"owners_count":16422833,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":"Qix-","name":"Josh Junon","uuid":"885648","kind":"user","description":"Working on @oro-os. Currently @gitbutlerapp. Moderator alumni @bellingcat. Member of @chalk, @debug-js. Formerly @uber, @vercel. Thank you sponsors ❤","email":"","website":null,"location":null,"twitter":"bad_at_computer","company":"@oro-os, @gitbutlerapp","icon_url":"https://avatars.githubusercontent.com/u/885648?u=c3355eab0ebf62e02afb1ae027fc8d8edba7b212\u0026v=4","repositories_count":436,"last_synced_at":"2024-05-20T14:11:15.738Z","metadata":{"has_sponsors_listing":true},"html_url":"https://github.com/Qix-","funding_links":["https://github.com/sponsors/Qix-"],"total_stars":10829,"followers":1318,"following":331,"created_at":"2022-11-02T16:19:02.297Z","updated_at":"2024-05-20T14:11:19.709Z","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Qix-","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Qix-/repositories"},"tags":[{"name":"0.3.1","sha":"524a7d9ccd6ddab8495d5eb4bf56d587dec22ffe","kind":"tag","published_at":"2018-10-31T16:29:14.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.3.1","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.3.1","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.1","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.1/manifests"},{"name":"0.3.2","sha":"8ef97ff99d606e911aeaf003b86318b882b4fba1","kind":"tag","published_at":"2018-06-19T08:09:27.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.3.2","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.3.2","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.2","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.2/manifests"},{"name":"0.3.0","sha":"1e1d1710b5d8b2ee6ea9ecccbbae0657a59382b5","kind":"tag","published_at":"2016-01-23T17:57:24.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.3.0","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.3.0","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.0","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.3.0/manifests"},{"name":"0.2.1","sha":"53f22aa6ce557d7d31a3d1152a590a2df220df9d","kind":"tag","published_at":"2015-08-31T23:02:34.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.2.1","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.2.1","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.2.1","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.2.1/manifests"},{"name":"0.2.0","sha":"7b0be35df6c842532938000d2352ca506b0797e1","kind":"tag","published_at":"2015-08-25T23:58:24.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.2.0","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.2.0","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.2.0","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.2.0/manifests"},{"name":"0.1.1","sha":"0ca0100bf72ace8660600d3107a3a9d10a48cb19","kind":"tag","published_at":"2015-08-25T17:09:59.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.1.1","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.1.1","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.1.1","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.1.1/manifests"},{"name":"0.1.0","sha":"0a6d011135dd6242ef91eb06e3e2260d50ed3112","kind":"tag","published_at":"2015-08-25T17:07:44.000Z","download_url":"https://codeload.github.com/Qix-/node-is-arrayish/tar.gz/0.1.0","html_url":"https://github.com/Qix-/node-is-arrayish/releases/tag/0.1.0","dependencies_parsed_at":null,"dependency_job_id":null,"tag_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.1.0","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Qix-%2Fnode-is-arrayish/tags/0.1.0/manifests"}]},"repo_metadata_updated_at":"2024-09-30T06:40:38.067Z","dependent_packages_count":1534,"downloads":436957423,"downloads_period":"last-month","dependent_repos_count":5599,"rankings":{"downloads":0.004271253043267793,"dependent_repos_count":0.3095563263281133,"dependent_packages_count":0.04873609241677354,"stargazers_count":8.174057989942291,"forks_count":6.113643289490004,"docker_downloads_count":0.007912770060925592,"average":2.443029620213563},"purl":"pkg:npm/is-arrayish","advisories":[{"uuid":"GSA_kwCzR0hTQS1mcmg3LTJmODQtdjltd84ABMJr","url":"https://github.com/advisories/GHSA-frh7-2f84-v9mw","title":"is-arrayish@0.3.3 contains malware after npm account takeover","description":"### Impact\nOn 8 September 2025, an npm publishing account for `is-arrayish` was taken over after a phishing attack. Version `0.3.3` was published, functionally identical to the previous patch version, but with a malware payload added attempting to redirect cryptocurrency transactions to the attacker's own addresses from within browser environments.\n\nLocal environments, server environments, command line applications, etc. are not affected. If the package was used in a browser context (e.g. a direct `\u003cscript\u003e` inclusion, or via a bundling tool such as Babel, Rollup, Vite, Next.js, etc.) there is a chance the malware still exists and such bundles will need to be rebuilt.\n\nThe malware seemingly only targets cryptocurrency transactions and wallets such as MetaMask. See references below for more information on the payload.\n\n### Patches\nnpm removed the offending package from the registry over the course of the day on 8 September, preventing further downloads from npm proper.\n\nOn 13 September, the package owner published new patch versions to help cache-bust those using private registries who might still have the compromised version cached. This version is functionally identical to the previously known-good version, published as a patch version bump above the compromised version.\n\nUsers should update to the latest patch version, completely remove their `node_modules` directory, clean their package manager's global cache, and rebuild any browser bundles from scratch.\n\nThose operating private registries or registry mirrors should purge the offending versions from any caches.\n\n### References\n- https://www.aikido.dev/blog/npm-debug-and-chalk-packages-compromised\n- https://socket.dev/blog/npm-author-qix-compromised-in-major-supply-chain-attack\n- https://www.ox.security/blog/npm-packages-compromised/\n\n### Point of Contact\nIn the event suspicious behavior is still observed for the package listed in this security advisory after performing all of the above cleaning operations (see _Patches_ above), please reach out via one of the following channels of communication:\n\n- Bluesky, compromised publishing account owner: https://bsky.app/profile/bad-at-computer.bsky.social\n- `debug` repository, tracking issue (applies to all packages affected in the breach): https://github.com/debug-js/debug/issues/1005","origin":"UNSPECIFIED","severity":"HIGH","published_at":"2025-09-15T23:58:46.000Z","withdrawn_at":null,"classification":"GENERAL","cvss_score":8.8,"cvss_vector":"CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:L/VI:H/VA:N/SC:N/SI:N/SA:N/E:A/U:Red","references":["https://github.com/Qix-/node-is-arrayish/security/advisories/GHSA-frh7-2f84-v9mw","https://nvd.nist.gov/vuln/detail/CVE-2025-59331","https://github.com/debug-js/debug/issues/1005","https://socket.dev/blog/npm-author-qix-compromised-in-major-supply-chain-attack","https://www.aikido.dev/blog/npm-debug-and-chalk-packages-compromised","https://www.ox.security/blog/npm-packages-compromised","https://github.com/advisories/GHSA-frh7-2f84-v9mw"],"source_kind":"github","identifiers":["GHSA-frh7-2f84-v9mw","CVE-2025-59331"],"repository_url":"https://github.com/Qix-/node-is-arrayish","blast_radius":32.98337211395586,"created_at":"2025-09-16T00:10:44.910Z","updated_at":"2026-06-24T01:03:30.634Z","epss_percentage":0.00378,"epss_percentile":0.29507,"api_url":"https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS1mcmg3LTJmODQtdjltd84ABMJr","html_url":"https://advisories.ecosyste.ms/advisories/GSA_kwCzR0hTQS1mcmg3LTJmODQtdjltd84ABMJr","packages":[{"ecosystem":"npm","package_name":"is-arrayish","versions":[{"first_patched_version":"0.3.4","vulnerable_version_range":"= 0.3.3"}],"purl":"pkg:npm/is-arrayish"}],"related_packages_url":"https://advisories.ecosyste.ms/api/v1/advisories/GSA_kwCzR0hTQS1mcmg3LTJmODQtdjltd84ABMJr/related_packages","related_advisories":[]}],"docker_usage_url":"https://docker.ecosyste.ms/usage/npm/is-arrayish","docker_dependents_count":35364,"docker_downloads_count":9983755263,"usage_url":"https://repos.ecosyste.ms/usage/npm/is-arrayish","dependent_repositories_url":"https://repos.ecosyste.ms/api/v1/usage/npm/is-arrayish/dependencies","status":null,"funding_links":["https://github.com/sponsors/Qix-"],"critical":true,"issue_metadata":{"last_synced_at":"2024-09-30T05:01:49.606Z","issues_count":3,"pull_requests_count":5,"avg_time_to_close_issue":10631396.666666666,"avg_time_to_close_pull_request":120367.0,"issues_closed_count":3,"pull_requests_closed_count":5,"pull_request_authors_count":5,"issue_authors_count":3,"avg_comments_per_issue":1.6666666666666667,"avg_comments_per_pull_request":1.6,"merged_pull_requests_count":3,"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/Qix-%2Fnode-is-arrayish/issues","maintainers":[],"active_maintainers":[]},"versions_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/versions","version_numbers_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/version_numbers","latest_version_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/latest_version","dependent_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/dependent_packages","related_packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/related_packages","codemeta_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/packages/is-arrayish/codemeta","maintainers":[{"uuid":"qix","login":"qix","name":null,"email":"npm@josh.junon.me","url":null,"packages_count":81,"html_url":"https://www.npmjs.com/~qix","role":null,"created_at":"2022-11-12T20:48:14.239Z","updated_at":"2022-11-12T20:48:14.239Z","packages_url":"https://packages.ecosyste.ms/api/v1/registries/npmjs.org/maintainers/qix/packages"}]}