Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Keeping JavaScript safe
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
C J Silverio
October 04, 2017
Programming
480
3
Share
Keeping JavaScript safe
Security & the npm registry. Presented at Node Interactive 2017 in Vancouver.
C J Silverio
October 04, 2017
More Decks by C J Silverio
See All by C J Silverio
The economics of package management
ceejbot
4
1.6k
The future of (javascript) modules (in node)
ceejbot
1
310
ceej's how to solve it
ceejbot
6
780
work-life balance at npm
ceejbot
5
800
hash functions and you!
ceejbot
2
370
The accidental noder
ceejbot
2
170
Design Patterns & Modularity in the npm Registry
ceejbot
3
200
Monitoring on a budget
ceejbot
2
300
Cheating Gall's Law: MediterraneaJS edition
ceejbot
4
350
Other Decks in Programming
See All in Programming
Coding as Prompting Since 2025
ragingwind
0
840
GitHubCopilotCLIをはじめよう.pdf
htkym
0
210
ルールルルルルRubyの中身の予備知識 ── RubyKaigiの前に予習しなイカ?
ydah
1
210
(Re)make Regexp in Ruby: Democratizing internals for the JIT
makenowjust
2
550
一度始めたらやめられない開発効率向上術 / Findy あなたのdotfilesを教えて!
k0kubun
4
3k
セグメントとターゲットを意識するプロポーザルの書き方 〜採択の鍵は、誰に刺すかを見極めるマーケティング戦略にある〜
m3m0r7
PRO
0
570
瑠璃の宝石に学ぶ技術の声の聴き方 / 【劇場版】アニメから得た学びを発表会2026 #エンジニアニメ
mazrean
0
270
「話せることがない」を乗り越える 〜日常業務から登壇テーマをつくる思考法〜
shoheimitani
4
840
JOAI2026 1st solution - heron0519 -
heron0519
0
140
AIと共に生きる技術選定 2026
sgash708
0
100
実用!Hono RPC2026
yodaka
2
250
PicoRuby for IoT: Connecting to the Cloud with MQTT
yuuu
2
640
Featured
See All Featured
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.1k
Visualization
eitanlees
150
17k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
270
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Claude Code のすすめ
schroneko
67
220k
Paper Plane
katiecoart
PRO
1
49k
Raft: Consensus for Rubyists
vanstee
141
7.4k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.2k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
320
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
260
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1k
Transcript
keeping javascript safe
keeping javascript safe security & the npm registry
C J Silverio CTO @ npm, @ceejbot
using node since 2011 node has grown up!
running npm's registry since 2014 npm has grown up too!
the story of the npm registry mirrors the story of
node
npm is infrastructure for millions of developers
npm dependably serves node packages 24/7 around the world
Fortune 100 companies depend on npm & node
3 billion downloads/week 9 million users 156K package authors (1.7%)
npm has as many users as the New York City
it didn't start that way
in 2009, node & npm's users knew each other by
name
the npm registry is now too large to depend on
community policing
but you need that policing
you rely on the packages you install
questions you ask 1. Is the registry secure? 2. Does
this package have vulnerabilities? 3. Is this package malware? 4. Who published this package?
1. Is the registry secure?
What does secure mean? registry systems can't be broken into
data can't be tampered with
we don't try to do this alone ongoing contract with
^Li!
this guy, Adam Baldwin (he'll come up again) & his
colleagues
periodic pen testing ongoing code reviews
good security practices are on-going work
2. Does this package have vulnerabilities?
our friends at ^Li! again as the Node Security Platform
NSP reviews popular packages, reports vulnerabilities, & handles reports
h!ps://nodesecurity.io
early access NSP data is integrated into npm enterprise
newsflash! npm is a company that sells services!
npm enterprise is a registry inside your firewall
NSP keeps us informed we keep them informed in turn
3. Is this package malware?
malware doesn't advertise
malware comes in flavors: spam & poison
spammers found the registry in 2016
two kinds of spam: spam content & js spam support
npm + cdns built on top == trivial hosting for
GA clickjacking
now using machine learning to catch spam thanks to the
Smyte service
spam speedbumps: validated email to publish disallow throwaway addresses
we seem to have made a dent but this war
will never end
poison-flavored malware: typosqua!ing
publishing packages with names that are very close to real
names
Historically this was competitive: authors would try to steal traffic
to pump their download numbers
somebody typosqua!ed moment.js with another date-forma!ing package
also accidental JSONStream vs jsonstream
recently it's been nefarious: typosquat of cross-env as crossenv with
a env var stealer
typosquat of bluebird wrapping bluebird with a cryptocoin miner
Adam Baldwin typosqua!ed coffee-script early on
it took days for the community to notice
now it takes weeks if the community notices at all
as spiderman said, with great popularity comes great annoyance
automated similarity checker
None
this war will never end so long as there is
$ to be made
4. Who published this package?
What happens if somebody steals JDD's auth token & posts
malware as lodash?
Well, that's scary. npm auth tokens are sensitive.
new! tools in the npm cli to help you control
auth tokens
new command: npm token control your auth tokens
npm token create --readonly
read-only auth tokens the principle of least power
give your CI system a read-only token
npm token create --cidr=[10.0.0.1/32]
CIDR-bound tokens bind tokens to IP ranges
further limit your tokens by controlling where they can be
used
npm token list npm token delete <tokenKey>
None
new command: npm profile
set your profile data like your email or ...
None
well that's boring
None
that's not boring
npm profile enable-2fa two-factor authentication is here
require regular password plus a one-time password
npm profile enable-2fa auth-only
auth-only: any time you log in or manipulate tokens
npm profile enable-2fa auth-and-writes
None
writes: your package publications pass the --otp flag
npm publish --otp=123456 pass it on the command line!
use a TOTP code generation app Google Authenticator, Authy, etc
npm install -g npm@next try it now!
code: github.com/npm/npm-profile api docs: github.com/npm/registry
one more thing
coming a!raction! protect a package with 2FA
require an OTP any time that package is published by
anybody
protect packages with many maintainers next cli minor release 5.6.0
coming soon! 2fa for your npm organization
coming soon! npm ci 3x speed for your CI installs
but what about package signing? we think we've figured out
how
coming soon! even more
questions? help se!ing this up? come see me & puppies
at the npm booth
npm wants you to develop in confidence
npm loves you