All notable changes to this project will be documented in this file. See standard-version for commit guidelines.
4.0.3 (2019-06-14)
- api: return 503 to npm/yarn on uplink connection timeout (#1331) (eb7a8e3), closes #1328 #720 #1328 #720
4.0.2 (2019-06-13)
- correctly check if the proxy setting evaluates to false (#1336) (df834f4)
- update dependencies (e581634), closes #1339
- update security policy details (#1342) (ddcd89d)
- api: force authenticate on login (#1347) (85c1bd1)
- ui: failed to load all packages after login (192fb77)
4.0.1 (2019-05-28)
4.0.0 (2019-05-26)
- add missing pkg version and name on start up (8cf3966)
- update @verdaccio/ui-theme:0.1.7 (8e48eea)
- warning text is hard to read when running under root (3ac038f)
- create security policy (#1322) (0e9f23d)
- prepare release v4 (#1307) (b9506d6)
- update readme v4 (#1312) (7686417)
4.0.0-beta.10 (2019-05-20)
- add missing pkg version and name on start up (8cf3966)
4.0.0-beta.9 (2019-05-20)
- update @verdaccio/ui-theme:0.1.7 (8e48eea)
4.0.0-beta.8 (2019-05-07)
- update lock file (3c69132)
4.0.0-beta.7 (2019-05-07)
4.0.0-beta.6 (2019-05-07)
4.0.0-beta.5 (2019-04-30)
- add some security headers for web UI (#1295) @juanpicado (615db0a)
4.0.0-beta.4 (2019-04-29)
4.0.0-beta.3 (2019-04-28)
- logo field in configuration cannot use the local file (56c70d4)
- ui: version rendering issue (40679aa)
4.0.0-beta.2 (2019-04-26)
4.0.0-beta.1 (2019-04-16)
- all static files are captured by the router (86a6e5e)
4.0.0-beta.0 (2019-04-15)
- package.json to reduce vulnerabilities (#1276) (fbe9409)
- update @verdaccio/[email protected] (8760e18)
- update docker node to latest lts version (a5be22b)
4.0.0-alpha.7 (2019-04-06)
- package.json to reduce vulnerabilities (d99053e)
4.0.0-alpha.6 (2019-03-30)
- add new enpoind that allow download tarballs according the standard (87203f2)
- add not found if package is missing (4da21c1)
- husky commitlint not work, replace invalid test (84be869)
- potential issue on sign new jwt tokens (265849e), closes /github.com/auth0/node-jsonwebtoken/issues/326#issuecomment-288124020
- add star and unstar api for 4.x (1ab7c50)
- add stars api (75c0e1e)
- engines and npm upgraded to v8 and v5 (89b0efe)
4.0.0-alpha.5 (2019-03-04)
- #1191 overrides existing package to 0 bytes file (783fbce)
- applied jsx-max-depth (d940da4)
- applied prefer-const (4962e36)
- applied valid-describe (2b48958)
- applied valid-describe (3bda0cf)
- applied valid-expect-in-promise (c7034e7)
- broken home page (4f41fc9)
- click on logo break ui (#1071) (5b34dc8)
- fixed container size (039a94d)
- issue on refactor router (19b0f47)
- logo on header (158666f)
- remove online fonts (29c6e56)
- remove unused dependency (3ed7a86)
- update [email protected] (009bb98)
- v4 compatible helpers (7279662)
- ability to restrict unpublish action to certain users #492 (ef50325)
- add dependencies navigation (adfcbc2)
- add dist-tags on ui (4f4720d)
- add support for profile cli command #392 (change password) (#1034) (f1416ed)
- added uplinks component (6c32769)
- added versions. wip (5573ff5)
- allow apiJWTmiddleware to be managed by Auth plugin (049917a)
- allow disable gravatar #1172 (c338f46)
- allow order packages via on web #1163 (49c6f03)
- disable node9 on circleci (9e4e8be)
- endpoints change password on ui (#1068) (712db31)
- migrate react router from hash to history api #1013 (1a456fb)
- not found page (#1208) (752b870)
- package version gets sent to plugins (3943863)
- register info selector (6d96007)
- stop hit proxies on search web UI (#1126) (2362310)
- update verdaccio author (9efd1e2)
- use verdaccio babel preset (d37fe5c)
- use verdaccio babel preset (c3af3cb)
4.0.0-alpha.1 (2018-09-27)
4.0.0-alpha.0 (2018-09-27)
- fix docker python issue #883 (611aeb4)
- load package list undefined (#993) (4431c47)
- Make systemd unit more production-like (#929) (ffc9410)
- add support for jwt on api (#896) (a68d247), closes #168
- add support for multiple protocol on protocol header (#1014) (40e2b10)
- added prettier (#921) (43bd622)
- check for minimum node.js version on start (#968) (ba9dc35)
- rename database file name (#954) (dd72120)
- replaced element-react by Material-UI (#950) (#985) (3639557)
- replaced lunr by lunr-mutable (#915) (1602840)
- verdaccio update notification on CLI (#988) (#998) (bc04703)
4.0.0-alpha.4 (2019-01-09)
- applied jsx-max-depth (d940da4)
- applied prefer-const (4962e36)
- applied valid-describe (3bda0cf)
- applied valid-describe (2b48958)
- applied valid-expect-in-promise (c7034e7)
- broken home page (4f41fc9)
- click on logo break ui (#1071) (5b34dc8)
- issue on refactor router (19b0f47)
- add support for profile cli command #392 (change password) (#1034) (f1416ed)
- endpoints change password on ui (#1068) (712db31)
- stop hit proxies on search web UI (#1126) (2362310)
4.0.0-alpha.3 (2018-10-12)
4.0.0-alpha.2 (2018-10-12)
4.0.0-alpha.1 (2018-09-27)
- fix docker python issue #883 (611aeb4)
- load package list undefined (#993) (4431c47)
- Make systemd unit more production-like (#929) (ffc9410)
- add support for jwt on api (#896) (a68d247), closes #168
- add support for multiple protocol on protocol header (#1014) (40e2b10)
- added prettier (#921) (43bd622)
- check for minimum node.js version on start (#968) (ba9dc35)
- rename database file name (#954) (dd72120)
- replaced element-react by Material-UI (#950) (#985) (3639557)
- replaced lunr by lunr-mutable (#915) (1602840)
- verdaccio update notification on CLI (#988) (#998) (bc04703)
3.11.6 (2019-02-25)
3.11.5 (2019-02-21)
3.11.4 (2019-02-11)
- update dependencies due to security vulnerabilities (f6f014a)
3.11.3 (2019-02-07)
- server keepAliveTimeout is in milliseconds, config value in seconds. (7f79c77)
3.11.2 (2019-02-05)
- lodash vulnerability (c35486d)
3.11.1 (2019-01-31)
- don’t make change if
time
fields match (#1167) (e62ef8d) - don’t packages that have no uplinks after reading (#1204) (95686be)
3.11.0 (2019-01-27)
- introduce server keepAliveTimeout into config files (a359055)
3.10.2 (2019-01-22)
- add logic to catch clause (#1183) (056d396)
- adds _id to normalise metadata (#1194) (e2fa581)
- remove some unneeded checks (#1182) (ab56d75)
- remove unused object (#1185) (e9b3907)
- remove unused parameters from processBody method invocation (#1184) (064f7cf)
- remove use of comma separator (#1186) (f20fefa)
- remove useless assignment to local variable emailCopy (#1181) (13b8347)
3.10.1 (2018-12-20)
3.10.0 (2018-12-06)
3.9.0 (2018-12-04)
3.8.6 (2018-11-15)
3.8.5 (2018-10-18)
3.8.4 (2018-10-13)
- click on logo break ui (#1073) (9a3c8bc)
- click on logo when using url_prefix was not working (#996) (3ac9646)
3.8.3 (2018-10-07)
3.8.2 (2018-09-27)
3.8.1 (2018-09-10)
3.8.0 (2018-09-05)
3.7.1 (2018-08-28)
- login modal validation (#958) (9f78c31)
- ui change details issue in props update (#959) (#960) (431e760)
3.7.0 (2018-08-25)
- bugs related to logging with type json (#893) (cd231ba)
- login without reload (#678) (#679) (#914) (9cd3ccb)
- path to static directory could be changed (#942) (5557ce5)
- removes asciidoctor.js support (#884) (#947) (cf05938)
3.6.0 (2018-08-13)
- abort the stream to prevent overwriting existing tarbal (2e5a409)
- webui: search crash on ' ' as a value #898 (#902) (fd67698)
- translations: enable Chinese Simplified on website (88b29e0)
3.5.1 (2018-08-02)
- remove version page (8a0e8ab)
3.5.0 (2018-08-02)
- adds gravatar support for maintainers (4df6b3b)
- adds option to set scope in webui instructions header (f9e9383), closes #593
3.4.1 (2018-07-27)
3.4.0 (2018-07-27)
- Authentication Plugins / plugin[method] is not a function (0a3870e)
3.3.0 (2018-07-22)
- add RemoteUser type for auth (2f4dbe8)
- adds webpack banner plugin to tag bundles with version (#784) (dac28d3)
- dynamic date generation for component test (e5ea0c2)
- ignores http_proxy and https_proxy (d04dc8d)
- improves regex for ascii and test (#461) (be3968f)
- license field alignment on web ui (#761) (9fa523a)
- open external tabs in new tabs (25e8e60)
- package.json to reduce vulnerabilities (389e306)
- solve seo issue #760 (62d3033)
- wrong auth plugin signature (5c2c414)
- adds support for ascii-doc preview in readme (#464) (29bb57a)
- adds support for external plugin directory (#532) (11dcf79)
- capitalises logged in username (#752) (0e21e35)
3.2.0 (2018-06-15)
- allowing to allow replace static enpoint in case of reverse proxy (90803c7)
- fixed linebreaks lint issue (9e3ab09)
- normalize package was broken #758 (3717ad4)
- Add basic package infos and resource links to sidebar. (7bd3a4f)
- add published package support to template (4245636)
- added information about package publisher for notifications (1ca5298)
3.1.2 (2018-06-11)
- configure fetch to send cookies (98ac855)
- search implementation depends now of each plugin (8f0508f)
3.1.1 (2018-06-07)
3.1.0 (2018-06-05)
3.0.2 (2018-05-31)
3.0.1 (2018-05-31)
- ui fails to render whether time is missing (f575b48)
3.0.0 (2018-05-30)
- favicon refers to .png while only .ico exists #681 (11e6f9f)
- web-ui css were not being minimized (3168a76)
- new verdaccio skin to webui (b8b2612)
3.0.0-beta.12 (2018-05-23)
3.0.0-beta.11 (2018-05-20)
3.0.0-beta.10 (2018-05-14)
- return latest dis-tag readme whether main metadata readme is emtpy (e75376b)
3.0.0-beta.9 (2018-05-13)
- update dependencies #691 (d07bfc5)
- vulnerabilities dependencies (d4722d6)
- vulnerabilities with lodash (bcf128e)
3.0.0-beta.8 (2018-05-09)
- allow do not include storage if uses a storage plugin (4332ffc)
- disable autocomplete on search so it doesn't default to username (2e41d9f)
- make enter key submit the login modal form (f89b498)
3.0.0-beta.7 (2018-04-30)
- beta header (102fa22)
- enforce maximum amount of users for new users only (4d19d7d)
- package command build:webui breaks on non-unix platforms (4ec81d4)
- restore plugin loader (3c1c3ca)
- should fix flow performance issues (453891b)
- update memory plugin (a7aa77a)
- update memory plugin for e2e (df418a8)
- update memory storage plugin (a75b7bd)
- update types (4d5e8aa)
- update uplinks auth header (3f6eeb4), closes #670
- upgrade webpack to v4. fixes [#544] (b1c631c)
3.0.0-beta.6 (2018-04-03)
- api login use case when user already exist (6491db4)
- update verdaccio-htpasswd plugin (3a9c994)
3.0.0-beta.5 (2018-03-26)
- adds debounce to search api call (aa60e1d)
- test: replaces LocaleString with date-nfs/format (0d3cf84)
- correct linter errors and warnings (5c5af27)
- display logo (cbf4b9c)
- login with fetch (f338ee4)
- unit test and better error handling (2022a30)
- remove web logout endpoint (badc707)
3.0.0-beta.4 (2018-03-18)
- add teardown for unit test (036120b)
3.0.0-alpha.0 (2018-01-07)
2.7.2 (2018-01-05)
- marked dependency to latest (75bf2a8)
2.7.1 (2017-12-20)
- notification for multiple endpoints (b605d1e)
2.7.0 (2017-12-05)
- Add middleware plugins from fl4re/sinopia (374a5e8)
- Log-rotation used to require a full restart of the application (baa4763
- Add Kubernetes instructions (ef1bd34
- Match shell title with web title (ddcc493
2.6.6 (2017-11-08)
- 🐛 incorrect logo url with slash at the end of
url_prefix
(859eccb)
2.6.5 (2017-11-05)
- upgrade node to fix long standing socket timeout issue (bcc13ac)
2.6.4 (2017-10-31)
- 🐛 incorrect resource and registry url while install on sub directory (67e97a1)
2.6.3 (2017-10-21)
- Check if socket exists before removing (e916a0f)
2.6.2 (2017-10-21)
- Remove unix socket before listen (d42a41e)
2.6.1 (2017-10-19)
2.6.0 (2017-10-18)
- plugin loader with logs (d6ed202)
- add pfx support for https (c84d567)
2.5.1 (2017-10-01)
- fix docker build failure due breaking changes in yarn (c62e90f)
2.5.0 (2017-10-01)
- 🐛 check error code to prevent data loss (5d73dca) fix #329
- Fix #334 UI failure on IE 11, add suppor for old browsers. (f1f15be)
- header authorization uplink (7baf7cb)
2.4.0 (2017-09-23)
- 🐛 check error code to prevent data loss (5d73dca)
- 🐛 check error code to prevent data loss (93aae05)
- 🐛 Package metadata cache not work (4d6a447)
- Fixed bug with Maximum call stack size exceeded on packages web API (#326)
- fix: 🐛 Package metadata cache does not work (#317)
- Debug log color in terminal is too dark (#311)
- docs: Add new sections to documentation (#308)
- Remove from web section not longer valid properties (#307) (#309)
- Fix possible data loss upstream (#306) (#300)
- Update node alpine version to 8.4.0 (3f96ce3)
2.3.6 (2017-08-17)
- link was broken (a9481cc)
- Correct accept header set for registry requests (#295)
- Update SSL documentation (#296)
- Fix auth process to check against username also and not just groups (#293)
2.3.5 (2017-08-14)
- configuration files inconsistencies, add unit test (644c098)
- Remove accept header that seems cause issues #285 #289 and npm search fails (fab8391)
2.3.4 (2017-07-29)
- Docker image fails due lock file localhost references (901a7be)
2.3.3 (2017-07-29)
2.3.2 (2017-07-28)
- 🐛 detail page can't handle scoped package (1c9fbfc)
- #268 remove the accept header that avoids request with some regiestries (e7dcf3c)
- #78 add new setting to allow publish when uplinks are offline (430425c)
- broken link (9fb0e14)
- lint warning (d0afe78)
- Param web.title from config.yaml does not work on docker image #265 (b1a396d)
- undefined check (ff96d2e)
- bug: Detail page can't handle scoped package - #261
- bug: can't publish a private package to verdaccio while offline - #223
- refactor: use light version of syntax highlighter - #260
- feature: Refactor User Interface - #220
- bug: fix running behind of loadbalancer with TLS termination - #254
- build: update node version due security update announcement - #251
- Fixed adding the verdaccio user into the group - #241
- Updated Dockerfile & added proper signal handling - #239
- Improve Docker Build - #181
- Bugfix #73
npm-latest
support - #228 - Add documentation - #229
- config section moved up, some keywords added - #211
- docs: update docs with behind reverse proxy - #214
- Add remote ip to request log - #216
- Allow url_prefix to be only the path - (@BartDubois ) in #197
- Apache reverse proxy configuration - (@mysiar ) in #198
- don't blindly clobber local dist-tags - (@rmg ) in #206
- Adds cache option to uplinks - (@silkentrance ) in #132
- Fixed publish fail in YARN - (@W1U02 in #183
- Fix https certificates safety check - (@juanpicado) in #189
- Fix upstream search not work with gzip - (@Meeeeow in #170)
- Add additional requirement to output message - (@marnel in #184)
- Implement npm ping endpoint - (@juanpicado) in #179
- Add support for multiple notification endpoints to existing webhook - (@ryan-codingintrigue) in #108
- fix upstream search - (@Meeeeow in #166)
- Fix search feature - (@Meeeeow in #163)
- add docs about run behind proxy - (@Meeeeow in #160)
- Added Nexus Repository OSS as similar existing software - (@nedelenbos030 in #147)
- Increase verbose on notify request - (@juanpicado in #153)
- Add fallback support to previous config files - (@juanpicado in #155)
- Allows retrieval of all local package contents via http://server/-/search/* - (@Verikon in #152)
- [GH-83] create systemd service - (@030 in #89)
- optional scope in the readme package name. - (@psychocode in #136)
- Added docker image for rpi - (@danielo515 in #137)
- Allow configuring a tagline that is displayed on the webpage between. (@jachstet-sea in #143)
- Contribute guidelines - (@juanpicado in #133)
- fix(plugin-loader): plugins verdaccio-* overwrite by sinopia- (@Alexandre-io in #129)
- [GH-86] updated readme to point to new chef cookbook (@kgrubb in #117)
- [GH-88] rename to Verdaccio instead of Sinopia (@kgrubb in #93)
- Unit testing coverage (@juanpicado in #116)
- Allow htpasswd-created users to log in @imsnif in #112)
- remove travis io.js support (@juanpicado in #115)
- rename clean up (@juanpicado in #114)
- _npmUser / author not showing up (@juanpicado in #65)
- Docs: correct config attribute
proxy_access
(@robertgroh in #96) - Problem with docker.yaml (@josedepaz in #72)
- Prevent logging of user and password (@tlvince in #94)
- Updated README.md to reflect the availability of the docker image (@jmwilkinson) in #71)
- Use __dirname to resolve local plugins (@aledbf in #25)
- Fix npm cli logout (@plitex in #47)
- Add log format: pretty-timestamped (@jachstet-sea in #68)
- Allow adding/overriding HTTP headers of uplinks via config (@jachstet-sea in #67)
- Update Dockerfile to fix failed start (@denisbabineau in #62)
- Update the configs to fully support proxying scoped packages (@ChadKillingsworth in #60)
- Prevent the server from crashing if a repo is accessed that the user does not have access to (@crowebird in #58)
- Hook system, for integration into things like slack
- Register entry partial even if custom template is provided (@plitex in #46)
- Rename process to verdaccio (@juanpicado in #57)
- avoid sending X-Forwarded-For through proxies (issues #19, #254)
- fix multiple issues in search (issues #239, #253)
- fix "maximum stack trace exceeded" errors in auth (issue #258)
- add dist-tags endpoints (issue #211)
- fix access control regression in
1.2.1
(issue #238) - add a possibility to bind on unix sockets (issue #237)
- added more precise authorization control to auth plugins (issue #207)
- add a possibility to listen on multiple ports (issue #172)
- added https support (issues #71, #166)
- added an option to use a custom template for web UI (issue #208)
- remove "from" and "resolved" fields from shrinkwrap (issue #204)
- fix hanging when rendering readme (issue #206)
- fix logger-related crash when using sinopia as a library
- all requests to uplinks should now have proper headers
- fixed issue with
max_users
option (issue #184) - fixed issue with not being able to disable the web interface (issue #195)
- fixed 500 error while logging in with npm (issue #200)
- switch markdown parser from
remarkable
tomarkdown-it
- update
npm-shrinkwrap.json
- now downloading tarballs from upstream using the same protocol as for metadata (issue #166)
- fix windows behavior when
$HOME
isn't set (issue #177) - fix sanitization for highlighted code blocks in readme (issue render-readme/#1)
- Markdown rendering is now a lot safer (switched to remarkable+sanitizer).
- Header in web interface is now static instead of fixed.
GET /-/all?local
now returns list of all local packages (issue #179)
- Fixed an issue with scoped packages in tarballs
-
Config file is now created in
$XDG_CONFIG_HOME
instead of current directory.It is printed to stdout each time sinopia starts, so you hopefully won't have any trouble locating it.
The change is made so sinopia will pick up the same config no matter which directory it is started from.
-
Default config file is now a lot shorter, and it is very permissive by default. You could use sinopia without modifying it on your own computer, but definitely should change it on production.
-
Added auth tokens. For now, auth token is just a username+password encrypted for security reasons, so it isn't much different from basic auth, but allows to avoid "always-auth" npm setting.
-
Added scoped packages.
Please note that default
*
mask won't apply to them. You have to use masks like@scope/*
to match scoped packages, or**
to match everything. -
Enabled web interface by default. Wow, it looks almost ready now!
-
All dependencies are bundled now, so uncompatible changes in 3rd party stuff in the future won't ruin the day.
- fix
EPERM
-related crashes on windows (issue #67)
- web interface:
-
web interface:
-
bugfixes:
- fix "offset out of bounds" issues (issue sinopia-htpasswd/#2)
- "max_users" in htpasswd plugin now work correctly (issue sinopia-htpasswd/#3)
- fix
ENOTDIR, open '.sinopia-db.json'
error in npm search (issue #122)
-
set process title to
sinopia
-
web interface bugfixes:
- fix 500 error in adduser function in sinopia-htpasswd (issue #121)
- fix fd leak in authenticate function in sinopia-htpasswd (issue #116)
- mark crypt3 as optional (issue #119)
-
Added auth plugins (issue #99)
Now you can create your own auth plugin based on sinopia-htpasswd package.
-
WIP: web interface (issue #73)
It is disabled by default, and not ready for production yet. Use at your own risk. We will enable it in the next major release.
-
Some modules are now bundled by default, so users won't have to install stuff from git. We'll see what issues it causes, maybe all modules will be bundled in the future like in npm.
A bunch of development releases that are broken in various ways. Please use 0.11.x instead.
- fix several bugs that could cause "can't set headers" exception
- allow "pretty" format for logging into files (issue #88)
- remove outdated user existence check (issue #115)
-
new features:
-
bugfixes:
- avoid crashing when res.socket is null (issue #89)
- "latest" tag is now always present in any package (issue #63)
- tags created with new npm versions (>= 1.3.19) can now be published correctly
- use gzip compression whenever possible (issue #54)
- set
ignore_latest_tag
to false, it should now be more compatible with npm registry - make
fs-ext
optional (issue #61)
-
config changes:
- breaking change: all time intervals are now specified in seconds instead of milliseconds for the sake of consistency. Change
timeout
if you have one! - all time intervals now can be specified in nginx notation, for example
1m 30s
will specify a 90 seconds timeout - added
maxage
option to avoid asking public registry for the same data too often (issue #47) - added
max_fails
andfail_timeout
options to reduce amount of requests to public registry when it's down (issue #7)
- breaking change: all time intervals are now specified in seconds instead of milliseconds for the sake of consistency. Change
-
bug fixes:
-
other changes:
- 404 errors are returned in couchdb-like manner (issue #56)
- pin down express@3 version, since sinopia doesn't yet work with express@4
- old SSL keys for npm are removed, solves
SELF_SIGNED_CERT_IN_CHAIN
error
- adding config param to specify upload limits (issue #39)
- making loose semver versions work (issue #38)
- support setting different storage paths for different packages (issue #35)
- tag support (issue #8)
- adding support for npm 1.3.19+ behaviour (issue #31)
- removing all support for proxying publish requests to uplink (too complex)
- fixing bug with bad Accept header (issue #32)
- fixed a warning from js-yaml
- don't color multiline strings in logs output
- better error messages in various cases
- test format changed
- try to fetch package from uplinks if user requested a tarball we don't know about (issue #29)
- security fix: set express.js to production mode so we won't return stack traces to the user in case of errors
- fixing a few crashes related to tags
- latest tag always shows highest version available (issue #8)
- added a configurable timeout for requests to uplinks (issue #18)
- users with bad authentication header are considered not logged in (issue #17)
- added proxy support for requests to uplinks (issue #13)
- changed license from default BSD to WTFPL
- server now supports unpublishing local packages
- added fs-ext dependency (flock)
- fixed a few face conditions
- fixed a few errors related to logging
- using bunyan as a log engine
- pretty-formatting colored logs to stdout by default
- ask user before creating any config files
- basic tags support for npm (read-only)
- npm star/unstar calls now return proper error
- using mocha for tests now
- making use of streams2 api, doesn't work on 0.8 anymore
- basic support for uploading packages to other registries
- basic test suite
- storage path in config is now relative to config file location, not cwd
- proper cleanup for temporary files
- using ETag header for all json output, based on md5
- compression for http responses
- requests for files to uplinks are now streams (no buffering)
- tarballs are now cached locally
- config file changed, packages is now specified with minimatch
- ability to retrieve all packages from another registry (i.e. npmjs)
- config is now autogenerated
- tarballs are now read/written from fs using streams (no buffering)
- first npm version
- ability to publish packages and retrieve them locally
- basic authentication/access control
- first commits �