Changelog
v2.16.0, 2024-05-14
Highlights
- Support observeChangesAsync and observeAsync. PR
- New mongo package options to optimize Oplog tailing performance to include/exclude certain collections PR
Migration Steps
To update from 2.15 to this one, you can run:
meteor update --release 2.16
If you're coming from an older version, please check our Migration Guides.
Breaking Changes
N/A
Internal API changes
- Add method name to MethodInvocation in DDP messages
Meteor Version Release
Meteor tool
- Updated Svelte skeleton
- Update tsconfig.json for Svelte skeleton
- Updated Solid skeleton NPM dependencies
Blaze
accounts-base@2.2.11accounts-oauth@1.4.4- Remove config checking as it is done in
accounts-base
- Remove config checking as it is done in
accounts-ui-unstyled@1.7.1Connect with Twitteris nowConnect with X/Twitter
check@1.4.1:- Added an optional flag to immediately throw error when all checks failed. PR
ddp-common@1.4.1- Add method name to MethodInvocation
ddp-client@2.6.2- Add method name to MethodInvocation
ddp-server@2.7.1- Add method name to MethodInvocation
twitter-config-ui@1.0.2- Update setup instructions
email@2.2.6- Nodemailer update to v6.9.10
@types/nodemailerupdated to v6.4.14- Adds the ability to encrypt your emails using PGP PR
logging@1.3.4- Type update
minimongo@1.9.4- Support observeChangesAsync and observeAsync PR
- Report and extend test cases for the old async behaviors
minifier-js@2.8.0- Update terser to v5.31.0
mongo@1.16.10- Support a new option to include/exclude certain collections for oplog tailing PR
reload-safetybelt@1.0.13- Remove underscore dependency
service-configuration@1.3.4- Type update
Independent releases
mongo@1.16.9:- Set
minPoolSizefor oplog
- Set
underscore@1.6.1- Fix bug in
_.intersection
- Fix bug in
Contributors
Thanks for making this great framework even better!
v2.15.0, 2024-02-05
Highlights
- Bumps embedded MongoDB to 7.0.5.
Breaking Changes
N/A
Internal API changes
N/A
Migration Steps
In development, if you're using Linux, you might get an error like version GLIBCXX_3.4.26 not found or something related to g++.
This is related to your g++ version. With MongoDB 7, you need to have g++ 11 or higher. So make sure to have this updated.
This will happen only if you are trying to run your Meteor application with a MongoDB 7 version. If you run your app with a MONGO_URL pointing to a different MongoDB version, you won't have this issue.
meteor update --release 2.15
Meteor Version Release
Command line:- The bundle version was changed to include embedded MongoDB to 7.0.5.
- Fix cordova launch screen warnings on 2.15 PR
underscore@1.6.0:service-configuration@1.3.3:- added new types* PR
meteor@1.11.5:- added new types PR
accounts-base@2.2.10:- Added missing type for createUserVerifyingEmail PR
Special thanks to
For making this great framework even better!
v2.14.0, 2023-12-12
Highlights
Hacktoberfest release! 🎉
MongoDB driver has been updated to v4.17.2.
You can now set
DISABLE_SOCKJS_CORS=1if you want to prevent SockJS from setting CORS headers. Do not set this option if you will have DDP clients from other origins connecting to the DDP server. PRAdded guide on how to prepare for Meteor 3.0 migration.
New DDP merge strategy
NO_MERGE_MULTI, which is similar toNO_MERGE, but it does track whether a document is used by multiple publications. PRAppcache has been further deprecated and moved to the deprecated packages folder.
Added
Accounts.createUserAsyncinto the client.Many packages had their underscore dependency removed.
Cordova has been updated to v12.0.1 for Android and v7.0.1 for iOS, being able to build to SDK 33.
meteor createcommand is now interactive!Added
firstRunPromiseproperty toTrackerautorun blocks, that forces autorun blocks to be executed in synchronous-looking order by storing the value autorun promise thus making it awaitable.
Migration Steps
Android splash screen
If you have been using splash-screen for Cordova, you need to update your code as Android changed their splash screen API,
the cordova-plugin-splashscreen is now on cordova-android core, so we have removed the dependency from the splash-screen
package. As a result we are dropping the support for dark mode splash screen on Android.
To create this now you need to create two themes on your config.xml file.
Note that it's still possible to have it by adding the according themes with App.appendToConfig and App.addResourceFile - but this is not something Meteor will do automatically right now.
For more information you can check our Migration Guide
Breaking Changes
splash-screenpackage has removed thecordova-plugin-splashscreendependency. See migration steps for more info.
Docs
- Added guide on how to prepare for Meteor 3.0 migration.
- Added guide on performance improvements.
- Added FAQ about Meteor 3.
Internal API changes
- Tool
- Rename
EACCESStoEACCESto follow the Windows spelling - Fixed links in skeletons
- Fixed build issue in Vue skeleton
- Updated
source-map-support - Fixed bugs in negated “in” and “instanceof” expressions
- Updated
semverto v7.5.4 - Updated
@meteorjs/babelto v7.18.4 - Cordova has been updated to v12.0.1 for Android and v7.0.1 for iOS, being able to build to SDK 33.
meteor createcommand was re-made to be more interactive
- Rename
Meteor Version Release
accounts-base@2.2.10- Ensure that
onLogincallback fires properly - Indexes are now created asynchronously
- Ensure that
accounts-oauth@1.4.3- Indexes are now created asynchronously
accounts-password@2.4.0- Add
Accounts.createUserAsyncto the client, a promise-based version ofAccounts.createUser - Indexes are now created asynchronously
- Add
accounts-passwordless@2.1.4- Fix #12401, ensure that user is found with ID
- Indexes are now created asynchronously
babel-compiler@7.10.5- Updated
@meteorjs/babelto v7.18.4
- Updated
boilerplate-generator@1.7.2- Removed Underscore dependency
browser-policy-content@1.1.3- Removed Underscore dependency
constraint-solver@1.2.1- Removed Underscore dependency
crosswalk@1.7.2- Updated
cordova-plugin-crosswalk-webviewto v2.4.0 - Deprecated the package
- Updated
ddp-rate-limiter@1.2.1- Removed Underscore dependency
ddp-server@2.7.0:- Allow setting
DISABLE_SOCKJS_CORSto prevent SockJS from setting CORS headers - Added new publication strategy
NO_MERGE_MULTI
- Allow setting
ecmascript@0.16.8:- Bumped to get latest version of
@babel/compiler
- Bumped to get latest version of
facebook-oauth@1.11.3:- Updated default version of Facebook GraphAPI to v17
launch-screen@2.0.0- Removed
cordova-plugin-splashscreendependency
- Removed
fetch@0.1.4:- Update
node-fetchto version 1.6.12 - Update
whatwg-fetchto version 3.6.17
- Update
logging@1.3.3:- Added TS types
- Updated
chalkto v4.1.2
logic-solver@2.0.9- Removed Underscore dependency
meteor@1.11.5:- Improve TS types
mobile-experience@1.1.1:- Bumped to get latests version of
cordovadependencies
- Bumped to get latests version of
modern-browsers@0.1.10- Added
appleMailuser agent to allow modern bundle on iPads
- Added
modules@0.20.0- Updated version of reify to v0.24.1
mongo@1.16.8- Added deprecation messages into type definitions
- Fix ObjectIDs handling in oplogV2V1Converter
npm-mongo@4.17.2:- Bumped MongoDB driver to version 4.17.2
oauth@2.2.1- Indexes are now created asynchronously
removeDB calls migrated toremoveAsync
package-version-parser@3.2.2- Updated
semverto v7.5.4
- Updated
react-fast-refresh@0.2.8:- Updated
semverto version 7.5.4
- Updated
service-configuration@1.3.3- Indexes are now created asynchronously
- Add types for ConfigError
socket-stream-client@0.5.2- Removed Underscore dependency
standard-minifier-css@1.9.2- Updated
@babel/runtimeto v7.23.5 - Updated
minifier-cssto v1.6.4 - Updated
loggingpackage to v1.3.2
- Updated
test-server-tests-in-console-once@1.0.12- Removed Underscore dependency
tinytest@1.2.3- Removed Underscore dependency
tracker@1.3.3- Added
firstRunPromiseproperty, that forces autorun blocks to be executed in synchronous-looking order by storing the value autorun promise thus making it awaitable
- Added
typescript@4.9.5:- Updated to 4.9.5
webapp@1.13.8- Updated
cordova-plugin-meteor-webappto v2.0.3 - Updated
cookie-parserto v1.4.6 - Updated
sendto v0.18.0 - Updated
stream-to-stringto v1.2.1 - Updated
qsto v6.11.2 - Updated
@types/connectto v3.4.38
- Updated
Independent releases
google-oauth@1.4.4:- Remove logging request/response in google_server
NPM
@meteorjs/babel@7.18.4- Updated
@meteorjs/reifyto v0.24.1
- Updated
NPM
@meteorjs/babel-preset-meteor@7.10.1- Add Facebook in-app browser
NPM
cordova-plugin-meteor-webapp@2.0.2- Fixed Android hot code push failing
NPM
cordova-plugin-meteor-webapp@2.0.3- Fix pull manifest from correct url if parameter are used in baseurl
NPM
meteor-node-stubs@1.2.6- Update dependencies
- Deep update dependencies that were highlighted by
npm audit
Contributors
- @StorytellerCZ
- @Grubba27
- @vit0rr
- @realyze
- @jamauro
- @Torgen
- @brucejo75
- @zodern
- @alisnic
- @ebroder
- @BANSAL-NISHU
- @salmanhasni
- @jdgjsag67251
- @guncebektas
- @harryadel
- @dd137
- @matheusccastroo
- @mr-loop-1
For making this great framework even better!
v2.13.3, 2023-09-08
Highlights
- Solves the issue #12771: Version 2.13.1 suddenly requires a newer glibc version.
Breaking Changes
N/A
Internal API changes
N/A
Migration Steps
Please run the following command to update your project:
meteor update --release 2.13.3
Meteor Version Release
Command line:- The bundle version was changed to 14.21.4.3 to use another compiled version of the ESM Node.js. The previous version was generated using a different unix distribution (Ubuntu) while we should use CentOS.
Special thanks to
For making this great framework even better!
v2.13.1, 2023-09-04
Highlights
- Solved zlib issue with Meteor.js and ESM Node.js 14.21.4 PR by (GH Grubba27).
Breaking Changes
N/A
Internal API changes
N/A
Migration Steps
Please run the following command to update your project:
meteor update --release 2.13.1
Meteor Version Release
Command line:- The bundle version was changed to 14.21.4.1 to use another compiled version of the ESM Node.js.
Special thanks to
For making this great framework even better!
v2.13.0, 2023-07-26
Highlights
- Handled implicit collection creation oplog message by radekmie PR.
- Fix upsert logs when using WARNWHENUSINGOLDAPI flag by Grubba27 PR.
- Updating mongo types by Grubba27 PR.
- Fix solid skeleton by fredmaiaarantes PR.
- Setting The Viewport meta tag on skeletons fredmaiaarantes PR.
- Update mongo.d.ts with projection StorytellerCZ PR.
- Update guide code for GraphQL StorytellerCZ PR.
- Twitter Whitelist issue resolved Atharshoyeb PR.
- Node security patch (14.21.4) PR. Thanks a lot denihs for your contribuiton.
- Updated deprecated reference in mongo package by StorytellerCZ PR.
- Updated BlazeJS git ref in core meteor to 2.7.1 by Grubba27 PR.
- Added
Meteor.applyAsynctypes by Julusian PR.
Breaking Changes
If you are running Meteor with docker you will need to update your docker file to use our new docker image that contains Nodejs v14.21.4.
Known issues
Please, check our known issues page for more information about the problems and issues you might find while migrating.
Internal changes
ddp-server@2.7.0:- Updated livedata server test to be more easily debbuged.
mongo@1.16.8:- Updated deprecated reference in Mongo package.
Migration Steps
Please, follow our migration guide to understand what's needed to upgrade to Meteor 2.13.
Meteor Version Release
Command line:- Updated metatags for skeletons.
- Updated solidjs skeleton to be more idiomatic.
meteor@1.11.3:- Added types for applyAsync and added more documentation for applyAsync options.
mongo@1.16.7:- Updated types with projection.
- Fixed wrong upsert logs when using WARNWHENUSINGOLDAPI flag.
- Handled implicit collection creation oplog message.
test-in-console@1.2.5:- Adjusted log indentation.
- All errors will be logged to console.
- Will always use puppeteer@20.4.0
twitter-oauth@1.3.3:- Fixed twitter whitelist issue.
Special thanks to
v2.12.0, 2023-04-28
Highlights
- Document main function in webapp by harryadel PR
- Add undocument properties to docs by harryadel PR
- Bump NPM versions for css minifiers by wreiske PR
- Updated Email and Mongo package types by ebroder PR
- Updated security.md by jamauro PR
- Added addHtmlAttributeHook type on WebApp by DblK PR
- Added loginServiceConfiguration type on Accounts by DblK PR
- Add TS types for Mongo Collection countDocuments and estimatedDocumentCount by ArthurHoaro PR
- Allow setting a custom ddp-rate-limit message per rule by wreiske PR
- Updated MongoDB driver to 4.15 by Grubba27 PR
- Adding warn with env variable when using old apis vy Grubba27 PR
- Fix syntax for legacy client by zodern PR
- Updating MongoDB driver to 4.16 by Grubba27 PR
- Update sockjs-client by harryadel PR
- [Accounts] set custom collection by dmromanov PR
- Wrappers to help in the async migration by matheusccastroo PR
- Mongo query hangs all clients subscribed to a query/collection by KoenLav PR
- Blaze to 2.6.2 by StorytellerCZ PR
Breaking Changes
N/A
Internal API changes
N/A
Migration Steps
Now if you want to check where do you call old-style api methods
you can use WARN_WHEN_USING_OLD_API before starting your meteor process.
Meteor Version Release
accounts-base@2.2.8:- Added
loginServiceConfigurationtype. - Added the
collectionoption property, in order to be able to set the collection for Accounts, more can be seen in the discussion and in the related issue. onCreateUserHooknow accept promises and wait if necessary.
- Added
babel-compiler@7.10.4:- Added
es5compatible syntax.
- Added
browser-policy-content@1.1.2:- Added
es5compatible syntax.
- Added
browser-policy-framing@1.1.2:- Added
es5compatible syntax.
- Added
browser-policy@1.1.2:- Updated test name.
callback-hook@1.5.1:- Added async hooks possibility to make async migrations easier.
context@0.5.1:- Added
es5compatible syntax.
- Added
ddp-rate-limiter@1.2.0:- Allow setting a custom ddp-rate-limit message per rule.
ddp-server@2.6.1:- Updated sockjs version.
dev-error-overlay@0.1.2:- Added
es5compatible syntax by adding theecmascriptpackage.
- Added
dynamic-import@0.7.3:- Added
es5compatible syntax.
- Added
ecmascript@0.16.7:- Updated tests location.
ecmascript-runtime@0.8.1:- Updated npm dependencies.
email@2.2.5:- Updated type
CustomEmailOptionsto be a type instead of an interface.
- Updated type
hot-module-replacement@0.5.3:- Added
es5compatible syntax.
- Added
meteor@1.11.2:- Added documentation for
isTest,isAppTestandisPackageTestmethods. - Added possibility to add async hooks to make async migrations easier. PR
- Added documentation for
minifier-css@1.6.4:- Bump NPM versions for css minifiers.
minimongo@1.9.3:- Updated to be able to track old api usage.
modules-runtime-hot@0.14.2:- Added
es5compatible syntax.
- Added
mongo@1.16.6:- Added
countDocumentsandestimatedDocumentCounttypes. - Added warning for when old style apis are being used, to use this feature,
use the variable
WARN_WHEN_USING_OLD_API=truebefore starting the Meteor process. - Oplog driver updated to not throw error when MongoDB server and Meteor client mismatch. issue
- Added
non-core:- Blaze to version 2.6.2.
npm-mongo@4.16.0:- Updated MongoDB driver to 4.15.
- Updated MongoDB driver to 4.16.
rate-limit@1.1.1:- Added
ruleIdproperty that will be used for setting messages.
- Added
react-fast-refresh@0.2.7:- Added
es5compatible syntax.
- Added
socket-stream-client@0.5.0:- Updated sockjs version.
standard-minifier-css@1.9.2:- Bump NPM versions for css minifiers.
tracker@1.3.2:- Updated types and updated JSDocs for
Tracker.withComputation.
- Updated types and updated JSDocs for
underscore@1.0.13:- Updated npm dependencies.
webapp@1.13.5:- Added
addHtmlAttributeHooktype.
- Added
Special thanks to
- @harryadel.
- @wreiske.
- @ebroder.
- @jamauro.
- @DblK.
- @ArthurHoaro.
- @Grubba27.
- @zodern.
- @dmromanov.
- @matheusccastroo.
v2.11.0, 2023-03-02
Highlights
MongoDB Server 6.x Support
Embedded Mongo now uses MongoDB 6.0.3
In async wrappers, catch exceptions and reject by ebroder PR
Ensure the meteor.loginServiceConfiguration subscription always becomes ready by Torgen PR
Deprecate appcache package by StorytellerCZ PR
Made standard-minifier-css debuggable by softwarecreations PR.
Remove Blaze dependency and types that live in blaze.d.ts by perbergland PR
Switch typescript skeleton to zodern:types and test that it works by ebroder PR
Remove packages/*/.npm from gitignore and add missing .npm folders by ebroder PR
Add type definitions for async methods from Meteor 2.9 by ebroder PR
Fix TypeScript type dependencies for mongo, webapp, and underscore by ebroder PR
Improve specificity of types previously declared as "Object" by ebroder PR
Bump to Node 14.21.3 by StorytellerCZ PR
Breaking Changes
meteor mongo command was removed due compatibility with MongoDB v6.x of `mongosh
for more information about MongoDB migration
read our Migration Guide for this version.
Internal API changes
App cache is now deprecated.
Migration Steps
Read our Migration Guide for this version.
Meteor Version Release
accounts-2fa@2.0.2:- removed .npm/package contents and added .gitignore
accounts-base@2.2.7:- Updated types to match async methods added in newer versions.
- Ensured the meteor.loginServiceConfiguration subscription always becomes ready, by adding a this.ready() call.
- Specified that previously were declared as "Object" types. More context can be seen in PR.
accounts-password@2.3.4:- Updated
Accounts.changePasswordandAccounts.resetPasswordto be correctly verify if the new password is valid. - removed .npm/package contents and added .gitignore
- Updated
appcache@1.2.8- Deprecated appcache package. applicationCache, which this package relies on, has been deprecated and is not available on the latest browsers.
babel-compiler@7.10.3:- Updated typescript to version 4.9.4.
ecmascript@0.16.6:- Updated typescript to version 4.9.4.
email@2.2.4:- Updated types to match async methods added in newer versions.
- Specified that previously were declared as "Object" types. More context can be seen in PR.
logging@1.3.2:- removed .npm/package contents and added .gitignore
Command line:- Corrected typo in vue skeleton.
- Command
meteor mongowas removed due compatibility with MongoDB v6.x ofmongosh
meteor@1.11.1:- updated types to removed unused Blaze types
- Specified that previously were declared as "Object" types. More context can be seen in PR.
minimongo@1.9.2:- Updated performance of makeLookupFunction
- In async wrappers, catch exceptions and reject
mongo@1.16.5:- In async wrappers, catch exceptions and reject
- Updated MongoDB types to match driver version 4.13.0 and MongoDB server version 6.0.3
- Specified that previously were declared as "Object" types. More context can be seen in PR.
- Now uses MongoDB v6.0.3
- Now uses Node v14.21.3
npm-mongo@4.14.0:- Updated MongoDB driver to version 4.14.0
oauth@2.2.0:- bumped cordova-plugin-inappbrowser to 5.0.0
react-fast-refresh@0.2.6:- removed .npm/package contents and added .gitignore
standard-minifier-css@1.9.0:- standard-minifier-css is now debuggable
tracker@1.3.1:- Added missing withComputation method in types
typescript@4.9.4- Updated typescript to version 4.9.4.
underscore@1.0.12:- Added dependency in types to underscore
webapp@1.13.4:- Added dependency in types to webapp(to connect)
- removed .npm/package contents and added .gitignore
@meteorjs/babel@7.18.0-beta.6- Updated typescript to version 4.9.4.
Special thanks to
For making this great framework even better!
v2.10.0, 2023-01-13
Highlights
- Update skeletons to use React 18 PR by StorytellerCZ.
- Use MongoDB types instead of the homebuilt PR by perbergland.
- Fixing wrong type definitions in MongoDB package PR by ebroder.
- Typescript to version v4.7.4 PR by StorytellerCZ.
- Update test-in-browser dependencies PR by harryadel.
- Update boilerplate-generator-tests PR by harryadel.
- Replace double-ended-queue with denque PR by harryadel.
- Allow multiple runtime config and updated runtime hooks PR by ebroder.
- Added async forEach and clear for method Hooks PR by Grubba27.
- Implemented async Tracker with explicit values PR by radekmie.
- Improved eslint config PR by afrokick.
Breaking Changes
N/A
Internal API changes
N/A
Migration Steps
N/A
Meteor Version Release
babel-compiler@7.10.2:- Updated @meteorjs/babel to version 7.18.0.
- Updated to typescript to version v4.7.4.
boilerplate-generator-tests@1.5.1:- Updated parse5 and turned streamToString into a local function.
callback-hook@1.5.0- Added forEachAsync.
ecmascript@0.16.5- Updated typescript to version 4.7.4.
Command line:- Updated React skeletons to use React 18
Meteor@1.11.0:- Replaced double-ended-queue with denque
mongo@1.16.4:- Fixed wrong type definitions.
- switch to using MongoDB types instead of the homebuilt.
- Fixed wrong type definitions in MongoDB package related to dropIndexAsync
react-fast-refresh@0.2.5:- Updated react-refresh dependency.
test-in-browser@1.3.3:- Updated dependencies and removed unused libs.
Tracker@1.3.0:- Implemented async Tracker with explicit values
typescript@4.7.4- Updated typescript to version 4.7.4.
webapp@1.13.3- The forEach method on Hook will stop iterating unless the iterator function returns a truthy value. Previously, this meant that only the first registered runtime config hook would be called.
@meteorjs/babel@7.18.0-beta.5- Updated typescript to version 4.7.4.
Special thanks to
For making this great framework even better!
v2.9.1, 2022-12-27
Highlights
- Reverted missing types PR by Grubba27.
- Fix fetch() type declaration PR by zarvox.
- update svelte skeleton PR by tosinek.
- Bump to node 14.21.2.0 PR by Grubba27.
- resetPassword and verifyEmail to no longer sign in the user automatically PR by denihs.
- Added missing vue2 declaration for skeletons PR by Grubba27 & mlanning.
Breaking Changes
accounts-password@2.3.3- The methods
resetPasswordandverifyEmailno longer logs the user if they have 2FA enabled. Now, the functions work as before, but instead of automatically logging in the user at the end, an error with the code2fa-enabledwill be thrown.
- The methods
Internal API changes
N/A
Migration Steps
N/A
Meteor Version Release
fetch@0.1.3:- Updated fetch type definition.
meteor@1.10.4:- Added back meteor type definitions that were removed by mistake in earlier version.
accounts-password@2.3.3- The methods
resetPasswordandverifyEmailno longer logs the user if they have 2FA enabled. Now, the functions work as before, but instead of automatically logging in the user at the end, an error with the code2fa-enabledwill be thrown.
- The methods
Command line:
Special thanks to
For making this great framework even better!
v2.9, 2022-12-12
Highlights
- TypeScript update to v4.6.4 PR by @StorytellerCZ.
- Create Email.sendAsync method without using Fibers PR by edimarlnx.
- Create async method CssTools.minifyCssAsync PR by edimarlnx.
- Change Accounts and Oauth to use Async methods PR by edimarlnx.
- TinyTest package without Future PR by matheusccastroo.
- Feat: user accounts base async PR by Grubba27.
- Move somed methods from OAuth of out of accounts-base PR by StorytellerCZ.
- Feat: not using insecure & autopublish PR by Grubba27.
- Don't apply babel async-await plugin when not running on Fibers PR. by matheusccastroo.
- Implemented Fibers-less MongoDB count methods PR by radekmie.
- Feat: Generate scaffold in cli PR by Grubba27.
- Update types PR by piotrpospiech.
- Remove underscore from package-version-parser PR by harryadel.
- Update MongoDB driver version PR by Grubba27.
- New Vue3 Skeleton PR by henriquealbert.
Breaking Changes
Accounts.createUserVerifyingEmailis now async
Internal API changes
- Internal methods from
OAuththat are now async:- _attemptLogin
- _loginMethod
- _runLoginHandlers
- OAuth.registerService now accepts async functions
OAuth related code has been moved from accounts-base to accounts-oauth, removing the dependency on service-configuration
more can be seen in this discussion and in the PR.
This means that if you don’t use third-party login on your project, you don’t need to add the package service-configuration anymore.
Migration Steps
You can follow in here.
Meteor Version Release
eslint-plugin-meteor@7.4.0:- updated Typescript deps and meteor babel.
eslint-plugin-meteor@7.4.0:- updated Typescript deps and meteor babel.
accounts-base@2.2.6- Moved some functions to accounts-oauth.
accounts-oauth@1.4.2- Received functions from accounts-base.
accounts-password@2.3.2- Asyncfied functions such as
changePassword,forgotPassword,resetPassword,verifyEmail,setPasswordAsync.
- Asyncfied functions such as
babel-compiler@7.10.1- Updated babel to 7.17.1.
email@2.2.3- Create Email.sendAsync method without using Fibers.
facebook-oauth@1.11.2- Updated facebook-oauth to use async functions.
github-oauth@1.4.1- Updated github-oauth to use async functions.
google-oauth@1.4.3- Updated google-oauth to use async functions.
meetup-oauth@1.1.2- Updated meetup-oauth to use async functions.
meteor-developer-oauth@1.3.2- Updated meteor-developer-oauth to use async functions.
meteor@1.10.3- Added Async Local Storage helpers.
minifier-css@1.6.2- Asyncfied
minifyCssfunction.
- Asyncfied
minimongo@1.9.1- Implemented Fibers-less MongoDB count methods.
mongo@1.16.2- Implemented Fibers-less MongoDB count methods.
npm-mongo@4.12.1- Updated npm-mongo to 4.12.
oauth@2.1.3- Asyncfied methods.
oauth1@1.5.1- Asyncfied methods.
oauth2@1.3.2- Asyncfied methods.
package-version-parser@3.2.1- Removed underscore.
promise@0.12.2- Added DISABLE_FIBERS flag.
standard-minifier-css@1.8.3- Asyncfied minify method.
test-helpers@1.3.1- added runAndThrowIfNeeded function.
test-in-browser@1.3.2- Adjusted e[type] to e.type
tinytest@1.2.2- TinyTest package without Future.
twitter-oauth@1.3.2- Asyncfied methods.
typescript@4.6.4- updated typescript to 4.6.4.
weibo-oauth@1.3.2- Asyncfied methods.
Special thanks to
- @henriquealbert;
- @edimarlnx;
- @matheusccastroo;
- @Grubba27;
- @StorytellerCZ;
- @radekmie;
- @piotrpospiech;
- @harryadel;
For making this great framework even better!
v2.8.2, 2022-11-29
Highlights
mongo@1.16.2:- Make count NOT create a cursor. PR.
meteorjs/babel@7.16.1-beta.0- Adjusted config to Auto import React on jsx,tsx files PR.
- needs to use directly from npm the meteorjs/babel@7.16.1-beta.0.
Breaking Changes
N/A
Migration Steps
Meteor Version Release
mongo@1.16.2:- Make count NOT create a cursor. PR.
Special thanks to
For making this great framework even better!
v2.8.1, 2022-11-14
Highlights
- modernize tools/run-updater.js by afrokick
- feat(error message): Especifing error message when cross-boundary by Grubba27
- Type definitions for core packages by piotrpospiech
- Add https proxy support to meteor-installer by heschong
- Fix case insensitive lookup resource overuse by ToyboxZach
- Update default Facebook API to v15 and fix local changelog by StorytellerCZ
- Bump to Node v14.21.1 by StorytellerCZ
- Use true mongo binary types by znewsham
- Add docs for Accounts.registerLoginHandler by shivam1646
- Updated MongoDB driver to 4.11 by radekmie
- Show port in restart message by harryadel
- In the client, don't wait if the stub doesn't return a promise by denihs
- The rest of type definitions for core packages by piotrpospiech
- Removing underscore in packages by harryadel:
- [twitter-oauth] Remove underscore
- [test-in-browser] Remove underscore
- [webapp-hashing] Remove underscore
- [browser-policy] Remove underscore
- [ecmascript] Remove underscore
- [browser-policy-framing] Remove underscore
- [diff-sequence] Remove underscore
- [facts-ui] Remove underscore
- [geojson-utils] Remove underscore
Breaking Changes
N/A
Migration Steps
In case you want types in your app using the core packages types/zodern:types (now you do have the option)
- Remove
@types/meteorpackage - Install
zodern:typespackage - Follow installation guide for the Meteor Apps to update
Meteor Version Release
accounts-base@2.2.5- added types for package.
browser-policy@1.1.1- adjusted package tests.
browser-policy-common@1.0.12- added types for package.
browser-policy-framing@1.1.1- removed underscore.
check@1.3.2- added types for package.
ddp@1.4.0- added types for package.
ddp-client@2.6.1- In the client, don't wait if the stub doesn't return a promise.
ddp-rate-limiter@1.1.1- added types for package.
diff-sequence@1.1.2- removed underscore.
ecmascript@0.16.3- removed underscore.
ejson@1.1.3- added types for package.
ejson@2.2.2- added types for package.
facebook-oauth@1.12.0- Updated default version of Facebook GraphAPI to v15
facts-ui@1.0.1- removed underscore.
fetch@0.1.2- added types for package.
geojson-utils@1.0.11- removed underscore.
hot-module-replacement@0.5.2- added types for package.
meteor@1.10.2- added types for package.
modern-browsers@0.1.9- added types for package.
modules-runtime@0.13.2- added accurate error messages.
modules-runtime-hot@0.14.1- added accurate error messages.
mongo@1.16.1- added types for package.
- added true mongo binary
npm-mongo@4.11.0- updated npm mongo version to match npm one.
promise@0.13.0- added types for package.
random@1.2.1- added types for package.
reactive-dict@1.3.1- added types for package.
reactive-dict@1.0.12- added types for package.
server-render@0.4.1- added types for package.
service-configuration@1.3.1- added types for package.
session@1.2.1- added types for package.
test-in-browser@1.3.1- removed underscore.
tracker@1.2.1- added types for package.
twitter-oauth@1.3.1- removed underscore.
underscore@1.0.11- added types for package.
webapp@1.13.2- added types for package.
webapp-hashing@1.1.1- added types for package.
v2.8, 2022-10-19
Highlights
- New MongoDB Package Async API. PR
- Node update to v14.20.1 as part of the September 22nd security release
- Update MongoDB driver to 4.9. PR
- Meteor.callAsync method. PR
- Added new Chakra-ui Skeleton. PR
- Added new Solid Skeleton. PR
Breaking Changes
N/A
Migration Steps
Read our Migration Guide for this version.
Meteor Version Release
modules@0.19.0:- Updating reify version. PR.
minimongo@1.9.0:mongo@1.16.0:meteor@1.10.1:- Create method to check if Fibers is enabled by flag DISABLE_FIBERS. PR.
- Fix bugs for linter build plugins. PR.
- Document meteor show METEOR. PR.
- Update Cordova Android to 10.1.2. PR.
- Fixed flaky test. PR.
- Refactoring/Remove unused imports from tools folder. PR.
- Fix problem when publishing async methods. PR.
- Update skeletons ApolloPR and other skeletons PR
- Added callAsync method for calling async methods PR.
meteor-installer@2.7.5:- Validates required Node.js version. PR.
npm-mongo@4.9.0:- Updated MongoDB driver to 4.9. PR.
@meteorjs/babel@7.17.0- Upgrade TypeScript to
4.6.4
- Upgrade TypeScript to
babel-compiler@7.10.0- Upgrade TypeScript to
4.6.4
- Upgrade TypeScript to
ecmascript@0.16.3- Upgrade TypeScript to
4.6.4
- Upgrade TypeScript to
typescript@4.6.4- Upgrade TypeScript to
4.6.4
- Upgrade TypeScript to
eslint-plugin-meteor@7.4.0- Upgrade TypeScript to
4.6.4
- Upgrade TypeScript to
Independent Releases
accounts-passwordless@2.1.3:- Fixing bug where tokens where never expiring. PR.
accounts-base@2.2.4:- Adding new options to the
Accounts.config()method:loginTokenExpirationHoursandtokenSequenceLength. PR.
- Adding new options to the
Meteor Repo:minifier-css@1.6.1:- Update postcss package to avoid issues with
Browserslistandcaniuse-lite. PR.
- Update postcss package to avoid issues with
minifier-js@2.7.5:- Update terser package due to security fixes and to take advantage of terser improvements. PR.
standard-minifier-css@1.8.2:- Update dependencies to avoid issues with
Browserslistandcaniuse-lite. PR.
- Update dependencies to avoid issues with
standard-minifier-js@2.8.1:- Update dependencies to avoid issues with
Browserslistandcaniuse-lite. PR.
- Update dependencies to avoid issues with
ddp-server@2.5.1:- Rename setPublicationStrategy and getPublicationStrategy arguments. PR.
Special thanks to
- @fredmaiaarantes
- @radekmie
- @naveensrinivasan
- @zodern
- @brucejo75
- @matheusccastroo
- @victoriaquasar
- @StorytellerCZ
- @Grubba27
- @denihs
- @edimarlnx
For making this great framework even better!
v2.7.3, 2022-05-3
Highlights
accounts-passwordless@2.1.2:- Throwing an error when the login tokens are not generated well calling requestLoginTokenForUser. PR.
- Node updated to v14.19.3
- npm update to v6.14.17
- Fix recompiling npm packages for web arch. PR.
Breaking Changes
N/A
Migration Steps
Meteor Version Release
accounts-passwordless@2.1.2:- Throwing an error when the login tokens are not generated well calling requestLoginTokenForUser. PR.
babel-runtime@1.5.1:- Make client 25kb smaller. PR.
- Node updated to v14.19.3
- npm update to v6.14.17
- Fix win style paths being added to watch sets.
- Fix recompiling npm packages for web arch. PR.
v2.7.2, 2022-05-10
Highlights
Breaking Changes
N/A
Migration Steps
Meteor Version Release
mongo@1.15.0- New option
Meteor.settings.packages.mongo.reCreateIndexOnOptionMismatchfor case when an index with the same name, but different options exists it will be re-created. - If there is an error on index creation Meteor will output a better message naming the collection and index where the error occurred. PR.
- New option
modern-browsers@0.1.8- New api
getMinimumBrowserVersionsto access theminimumBrowserVersions. PR.
- New api
socket-stream-client@0.5.0- Ability to disable sockjs on client side. PR.
meteor-node-stubs@1.2.3:- Fix using meteor-node-stubs in IE. PR.
- New ARCH environment variable that permit users to set uname info. PR.
- Skeleton dependencies updated.
- New Tailwind skeleton. PR.
Independent Releases
v2.7.1, 2022-03-31
Highlights
Breaking Changes
accounts-2fa@2.0.0- The method
has2faEnabledno longer takes a selector as an argument, just the callback. generate2faActivationQrCodenow throws an error if it's being called when the user already has 2FA enabled.
- The method
Migration Steps
Meteor Version Release
accounts-2fa@2.0.0- Reduce one DB call on 2FA login. PR
- Throw error when user is not found on
Accounts._is2faEnabledForUser - Remove vulnerability from the method
has2faEnabled - Now the package auto-publish the field
services.twoFactorAuthentication.typefor logged in users.
accounts-password@2.3.1- Use method
Accounts._check2faEnabledwhen validating 2FA
- Use method
accounts-passwordless@2.1.1- Use method
Accounts._check2faEnabledwhen validating 2FA
- Use method
oauth@2.1.2- Check effectively if popup was blocked by browser. PR
standard-minifier-css@1.8.1- PostCSS bug fixes. PR
Independent Releases
v2.7, 2022-03-24
Highlights
- Bump node version to 14.19.1
- TailwindCSS 3.x support
- Typescript
4.5.4upgrade - New core package:
accounts-2fa - Support for 2FA in
accounts-passwordandaccounts-passwordless - PostCSS's plugins are run by
standard-minifier-cssif the app has PostCSS configured - App skeletons and test packages were updated to
meteor-node-stubs@1.2.1
Breaking Changes
N/A
Migration Steps
Read our Migration Guide for this version.
Meteor Version Release
standard-minifier-css@1.8.0react-fast-refresh@0.2.3- Fix tracking states with circular dependencies. PR
accounts-2fa@1.0.0- New package to provide 2FA support
accounts-password@2.3.0- 2FA support
accounts-passwordless@2.1.0- 2FA support
@meteorjs/babel@7.16.0- Upgrade TypeScript to
4.5.4
- Upgrade TypeScript to
babel-compiler@7.9.0- Upgrade TypeScript to
4.5.4
- Upgrade TypeScript to
ecmascript@0.16.2- Upgrade TypeScript to
4.5.4
- Upgrade TypeScript to
typescript@4.5.4- Upgrade TypeScript to
4.5.4PR
- Upgrade TypeScript to
accounts-ui-unstyled@1.6.0Accounts.ui.configcan now be set viaMeteor.settings.public.packages.accounts-ui-unstyled.
meteor-tool@2.7- CSS minifiers must now handle any caching themselves PR
- CSS minifiers are always given lazy css resources instead of only during production builds PR
- Files passed to CSS minifiers now have
file.readAndWatchFileWithHash, same as for compilers PR - If a minifier has a
beforeMinifyfunction, it will be called once during each build before the minifier is run the first time PR - Add
Plugin.fs.readdirWithTypesSyncPR
ejson@1.1.2oauth@1.4.1- If OAuth._retrieveCredentialSecret() fails trying to get credentials inside Accounts.oauth.tryLoginAfterPopupClosed(), we call it again once more.
accounts-base@2.2.2- Fix an issue where an extra field defined in
defaultFieldSelectorwould not get published to the client - Proving the login results to the
_onLoginHookwhen finishing login insidecallLoginMethod. PR.
- Fix an issue where an extra field defined in
github-oauth@1.4.0- More data will be retrieved and saved under
services.githubon the user account. - Add option to disallow sign-up on GitHub using
allow_signupparameter, this will be activated based on your Accounts settings, specifically if the optionforbidClientAccountCreationis set totrue.
- More data will be retrieved and saved under
email@2.2.1facebook-oauth@1.11.0- Updated Facebook API to version 12.0
google-oauth@1.4.2- Migrate from
httptofetch
- Migrate from
modules-runtime@0.13.0meteor-node-stubs@1.2.1- Adds support for node: imports.
minifier-jss@2.8.0
Independent Releases
v2.6.1, 2022-02-18
Highlights
- Fix regression on build speed by updating babel dependencies to 7.17.x
- We have removed IE 9 from our browser test list
- We are changing the device used for testing, Samsung Galaxy S7, as browserstack is having issues provisioning it. We will be using now Samsung Galaxy Note 10.
- Fix issue when generating tarballs from Windows systems related to execute permissions
- Fix issues with HMR and meteor build --debug PR
Breaking Changes
- IE 9 might not be compatible from now on, although, we will still consider PR's fixing it.
Migration Steps
Meteor Version Release
meteor-tool@2.6.1- Use latest @meteor/babel dependency with @babel@7.17.x
@meteorjs/babel@7.15.1- Use babel@7.17.x
babel-compiler@7.8.1- Use latest @meteor/babel dependency with @babel@7.17.x
hot-module-replacement@0.5.1- Fix issues with HMR and meteor build --debug PR
webapp@1.13.1- Fix issues with HMR and meteor build --debug PR
Independent Releases
mongo@1.14.6at 2022-02-18- Remove false-positive warning for supported operation a.0.b:{}
mongo@1.14.5at 2022-02-16- Fix multiple array operators bug and add support for debug messages
- Fix isArrayOperator function regexp false-positive
mongo@1.14.4at 2022-02-11mongo@1.14.3at 2022-02-08- Remove throw on _id exclusion inside mongo collection finds. PR.
mongo@1.14.2at 2022-02-06- Fix flatten object issue when internal object value is an array on oplog converter. PR.
mongo@1.14.1at 2022-02-04
v2.6, 2022-02-01
Highlights
- MongoDB Node.js driver Upgrade from 3.6.10 to 4.3.1
- MongoDB Server 5.x Support
- Embedded Mongo now uses MongoDB 5.0.5
- You are now able to use dark theme specific splash screens for both iOS and Android by passing an object
{src: 'light-image-src-here.png', srcDarkMode: 'dark-mode-src-here.png'}to the corresponding key inApp.launchScreens
Breaking Changes
mongo@1.14.0- This is not a breaking change in Meteor itself but as this is a major upgrade in the MongoDB Node.js driver you should read the Migration Guide, especially if you are using rawCollection.
meteor-tool@2.6- Legacy launch screens keys for iOS on
App.launchScreensare now deprecated in favor of new storyboard compliant keys PR #11797. This will drop the following keys we have:['iphone5','iphone6','iphone6p_portrait','iphone6p_landscape','iphoneX_portrait','iphoneX_landscape','ipad_portrait_2x','ipad_landscape_2x','iphone','iphone_2x','ipad_portrait','ipad_landscape']. Read the Migration Guide for more details.
- Legacy launch screens keys for iOS on
Migration Steps
Read our Migration Guide for this version.
Meteor Version Release
mongo@1.14.0applySkipLimitoption for count() on find cursors is no longer supported. Read more about it here, in theCursor.count()section.- internal result of operations inside Node.js MongoDB driver have changed. If you are depending on rawCollection results (not only the effect inside the DB), please review the expected format as we have done here
- useUnifiedTopology is not an option anymore, it defaults to true.
- native parser is not an option anymore, it defaults to false in the mongo connection.
- poolSize not an option anymore, we are using max/minPoolSize for the same behavior on mongo connection.
- fields option is deprecated, we are maintaining a translation layer to "projection" field (now preferred) until the next minor version, where we will start showing alerts.
- _ensureIndex is now showing a deprecation message
- we are maintaining a translation layer for the new oplog format, so if you read or rely on any behavior of it please read our oplogv2converter.js code
- update/insert/remove behavior is maintained in the Meteor way, documented in our docs, but we are now using replaceOne/updateOne/updateMany internally. This is subject to changes in the API rewrite of MongoDB without Fibers AND if you are using rawCollection directly you have to review your methods otherwise you will see deprecation messages if you are still using the old mongodb style directly.
- waitForStepDownOnNonCommandShutdown=false is not needed anymore when spawning the mongodb process
- synchronousCursor.dbCursor.operation is not an option anymore in the raw cursor from nodejs mongodb driver. If you want to access the options, use synchronousCursor.dbCursor.(GETTERS) - for example, synchronousCursor.dbCursor.readPreference.
- the default write preference for replica sets on mongo v5 is w:majority
- If you are using MongoDB inside a Docker container in your dev environment, you might need to append directConnection=true in your mongouri to avoid the new mongo driver Service Discovery feature
allow-deny@1.1.1- Handle
MongoBulkWriteErrorasBulkWriteErrorwas already handled.
- Handle
meteor-tool@2.6.0- Cordova changes to support new Launch Screens.
- Mongo changes to support new embedded version, 5.0.5.
- Fix resolving npm deps of local packages when on different drive. PR
minimongo@1.8.0- Changes to keep everything compatible with MongoDB Server 5.x and MongoDB Node.js driver 4.x.
npm-mongo@4.3.1- Upgraded MongoDB Node.js driver to 4.3.1
tinytest@1.2.1- Custom message support for
throws
- Custom message support for
Independent Releases
v2.5.8, 2022-05-31
Highlights
- Fixed 2.5.7 MongoDB error
- Patch release to update Node to version 14.19.3 and npm version to 6.14.17.
Breaking Changes
- N/A
Migration Steps
- N/A
v2.5.7, 2022-05-31
Highlights
- Patch release to update Node and npm versions.
Breaking Changes
- N/A
Migration Steps
- N/A
Meteor Version Release
meteor-tool@2.5.7- Patch release to update Node and npm versions.
v2.5.6, 2022-01-25
Highlights
- Go back to using node-fibers mainline dependency instead of a fork. Also ships fibers binaries.
Breaking Changes
- N/A
Migration Steps
- N/A
Meteor Version Release
meteor-tool@2.5.6- Go back to using node-fibers mainline dependency instead of a fork. Also ships fibers binaries.
v2.5.5, 2022-01-18
Highlights
- Bump node version to 14.18.3 - security patch
- Change the tar implementation for streams, used on deploying and unpacking packages. Reduced "upload bundle" time when deploying is expected.
Breaking Changes
- N/A
Migration Steps
- N/A
Meteor Version Release
meteor-tool@2.5.5- Bump node version to 14.18.3 - security patch
- Change the tar implementation for streams, used on deploying and unpacking packages. Reduced "upload bundle" time when deploying is expected.
accounts-base@2.2.1
Independent Releases
v2.5.4, 2022-01-14
This version should be ignored. Proceed to 2.5.5 above.
v2.5.3, 2022-01-04
Highlights
- Fixes invalid package.json error with
resolve
Breaking Changes
- N/A
Migration Steps
- N/A
Meteor Version Release
Independent Releases
v2.5.2, 2021-12-21
Highlights
- Reify performance improvements
- Node.js update to 14.18.2
- HMR Fixes
Breaking Changes
- If a module calls
module.hot.decline(), callingmodule.hot.accept()later now does nothing instead of overridingmodule.hot.decline().
Migration Steps
- N/A
Meteor Version Release
meteor-tool@2.5.2- Changes @meteorjs/babel and @meteorjs/reify to improve Reify performance.
- Upgrades Node.js to 14.18.2
- Fixes isopacket load failure on Windows. PR
hot-module-replacement@0.5.0@meteorjs/babel@7.15.0- Updates @meteorjs/reify to improve Reify performance.
@meteorjs/reify@0.23.0standard-minifier-js@2.8.0- Bump to apply improvements from Reify
typescript@4.4.1- Bump to apply improvements from Reify
babel-compiler@7.8.0- Bump to apply improvements from Reify
ecmascript@0.16.1- Bump to apply improvements from Reify
modules@0.18.0- Bump to apply improvements from Reify
Independent Releases
react-fast-refresh@0.2.2accounts-ui@1.4.2- Update usage of
accounts-passwordlessto be compatible with 2.0.0.
- Update usage of
minifier-js@2.7.3- Revert
evaluateoption that was set to false in 2.7.2.
- Revert
standard-minifier-js@2.7.3- Using
minifier-js@2.7.3
- Using
npm-mongo@4.2.1- Update MongoDB driver version to 4.2.1
v2.5.1, 2021-11-17
Highlights
- Mac M1 Support - darwin arm64. Read more.
Breaking Changes
Meteor.loginWithTokenfrom the new packageaccounts-passwordlesswas conflicting with another method with the same name onaccounts-baseso we had to rename the method ofaccounts-passwordlesspackage toMeteor.passwordlessLoginWithToken.
Meteor Version Release
meteor-tool@2.5.1- Meteor supports now Mac M1 chips (darwin arm64)
accounts-passwordless@2.0.0Meteor.loginWithTokenfrom the new packageaccounts-passwordlesswas conflicting with another method with the same name onaccounts-baseso we had to rename the method ofaccounts-passwordlesspackage toMeteor.passwordlessLoginWithToken.
Independent Releases
minifier-js@2.7.2standard-minifier-js@2.7.2- Using
minifier-js@2.7.2
- Using
github-oauth@1.3.2- Migrate from
httptofetch - Fix GitHub login params to adhere to changes in GitHub API
- Migrate from
v2.5, 2021-10-21
Highlights
- New package:
accounts-passwordless - Cordova Android v10
- HMR now works on all architectures and legacy browsers
Accounts.config()and third-party login services can now be configured from Meteor settings
Breaking Changes
- Cordova Android v10 now enables AndroidX. If you use any cordova-plugin that depends or uses any old support library, you need to include the cordova-plugin-androidx-adapter cordova-plugin, otherwise you will get build errors.
Meteor Version Release
CircleCI testing image was updated to include Android 30 and Node 14
meteor-tool@2.5- Cordova Android upgraded to v10
- HMR improvements related to
hot-module-replacement@0.4.0 - Fix finding local packages on Windows located on drives other than C
- Fix infinite loop in import scanner when file is on a different drive than source root
- Fix Meteor sometimes not detecting changes to a file after the first time it is modified
- Fixes Meteor sometimes hanging on Windows. Reverts the temporary fix in Meteor 2.4 of disabling native file watchers for some commands
- Uses recursive file watchers on Windows and macOS. In most situations removes the up to 5 seconds delay before detecting the first change to a file, and is more efficient.
- Node updated to v14.18.1, following October 12th 2021 security release
- Skeletons had their dependencies updated
accounts-passwordless@1.0.0- New accounts package to provide passwordless authentication.
accounts-password@2.2.0- Changes to reuse code between passwordless and password packages.
accounts-base@2.2.0- You can now apply all the settings for
Accounts.configinMeteor.settings.packages.accounts-base. They will be applied automatically at the start of your app. Given the limitations ofjsonformat you can only apply configuration that can be applied via types supported byjson(ie. booleans, strings, numbers, arrays). If you need a function in any of the config options the current approach will still work. The options should have the same name as inAccounts.config, check them out in docs.. - Changes to reuse code between passwordless and password packages.
- You can now apply all the settings for
accounts-ui-unstyled@1.6.0- Add support for
accounts-passwordless.
- Add support for
service-configuration@1.3.0- You can now define services configuration via
Meteor.settings.packages.service-configurationby adding keys as service names and their objects being the service settings. You will need to refer to the specific service for the settings that are expected, most commonly those will besecretandappId.
- You can now define services configuration via
autoupdate@1.8.0- Enable HMR for all web arch's
ecmascript@0.16.0- Enable HMR for all web arch's
hot-module-replacement@0.4.0- Provides polyfills needed by Meteor.absoluteUrl in legacy browsers
- Improvements for HMR to work in all architectures and legacy browsers
module-runtime@0.14.0- Improvements for legacy browsers
react-fast-refrest@0.2.0- Enable HMR for all web arch's
typescript@4.4.0- Enable HMR for all web arch's
webapp@1.13.0- Update
cordova-plugin-meteor-webappto v2 - Removed dependency on
cordova-plugin-whitelistas it is now included in core - Cordova Meteor plugin is now using AndroidX
- Added new settings option
Meteor.settings.packages.webapp.alwaysReturnContentthat will always return content on requests likePOST, essentially enabling behavior prior to Meteor 2.3.1.
- Update
Independent Releases
modern-browsers@0.1.6- Added
mobileSafariUIas an alias for Mobile Safari
- Added
minifier-js@2.7.1- Updated
terserto v5.8.0 to fix various bugs
- Updated
standard-minifier-js@2.7.1- Updated
@babel/runtimeto v7.15.4
- Updated
accounts-ui@1.4.1- Update compatibility range with
lessfrom 3.0.2 to 4.0.0
- Update compatibility range with
accounts-ui-unstyled@1.5.1- Update compatibility range with
lessfrom 3.0.2 to 4.0.0
- Update compatibility range with
google-config-ui@1.0.3- Deliver siteUrl in the same way as other config-ui packages
ecmascript-runtime-client@0.12.1- Revert
core-jsto v3.15.2 due to issues in legacy build with arrays, see issue for more details
- Revert
modern-browsers@0.1.7- Added
firefoxMobileas an alias forfirefox
- Added
dynamic-import@0.7.2- Fixes 404 in dynamic-import/fetch when ROOT_URL is set with a custom path. see issue
v2.4.1, 2021-10-12
Meteor Version Release
meteor-tool@2.4.1- Patch to make 2.4.1 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v2.4, 2021-09-15
Highlights
- Typescript updated to v4.3.5
- Email package now allows setting
Email.customTransportto override sending method. - Use
createIndexinstead of_ensureIndexto align with new MongoDB naming. - Apollo skeleton has been upgraded for Apollo server v3
reifyhas been updated to v0.22.2 which reduces the overhead ofimportstatements and some uses ofexport ... from, especially when a module is imported a large number of times or re-exports a large number of exports from other modules. PRs 1, 2- Meteor NPM installer is now available for all platforms.
- DDP server now allows you to set publication strategies for your publications to control mergebox behavior
- On Windows Meteor should no longer be hanging on commands
Migration steps
- Replace all usage of
collection._ensureIndexwithcollection.createIndex. You only need to rename the method as the functionality is the same. - If you are using a well known service for the email package switch to using
Meteor.settings.packages.emailsettings instead ofMAIL_URLenv variable. Alternatively you can utilize the newEmail.customTransportfunction to override the default package behavior and use your own. Read the email docs for implementation details.
Meteor Version Release
Skeletons dependencies updated
meteor-tool@2.4meteor shownow reports if a package is deprecatedreifyupdate to v0.22.2 which bring optimizations for imports. PRs 1, 2- Apollo skeleton now uses Apollo server v3 - migration guide
- Upgraded
chalkto v4.1.1 - Typescript updated to v4.3.5
METEOR_SETTINGSis now accepted an all modes- Native file watchers are now disabled on Windows for many file-intensive actions (like,
create,update,buildetc.), this solves an issue with hanging Meteor commands on Windows
webapp@1.12logging@1.3.0- Switch from
cli-colortochalkto have the same dependency as meteor-tool - Fix detecting eval
- Copy over code from
Meteor._debugtoLog.debugwhich will be deprecated in the future
- Switch from
email@2.2- Modernized package code
- Add alternative API function that you can hook into to utilize your own sending method:
Email.customTransport. Read the docs - Use
Meteor.settingsfor easy setup to sending email via known providers. Read the docs
ddp-server@2.5.0- One of three different publication strategies can be selected for any Meteor publication - SERVERMERGE, NOMERGE and NOMERGENO_HISTORY. These control the behaviour of the Meteor mergebox, providing a compromise between client-server bandwidth usage and server side memory usage. See PR or the documentation for more details.
mongo@1.13.0- Add
createIndexas a collection function (in MongoDB since MongoDB v3). This is a new name for_ensureIndexwhich MongoDB has deprecated and removed in MongoDB 5.0. Use of_ensureIndexwill show a deprecation warning on development.
- Add
accounts-base@2.1.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
accounts-oauth@1.4.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
accounts-password@2.1.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
oauth@2.1.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
oauth1@1.5.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
facebook-oauth@1.10.0- Added login handler hook, like in the Google package for easier management in React Native and similar apps. PR
service-configuration@1.5.0- Migrated usage of
_ensureIndextocreateIndex
- Migrated usage of
ecmascript-runtime-client@0.12.0core-js@3.16.0
ecmascript-runtime-server@0.11.0core-js@3.16.0
ecmascript-runtime@0.8.0- Version bump to ensure changes from server & client runtime get propagated.
tinytest@1.2.0- Add option to temporarily replace
Tinytest.addorTinytest.addAsyncbyTinytest.onlyorTinytest.onlyAsyncso only the tests added usingonly*are going to be executed.
- Add option to temporarily replace
test-helpers@1.3.0- Support for
Tinytest.onlyandTinytest.onlyAsync
- Support for
modules@0.17.0- Update
reifyto0.22.2
- Update
standard-minifier-js@2.7.0@babel/runtime@7.15.3- Code modernization
- Improved error handling
minifier-js@2.7.0- Added tests
- Code modernization
standard-minifier-css@1.7.4@babel/runtime@7.15.3
minifier-css@1.6.0- Updated dependencies
postcss@8.3.5cssnano@4.1.11
- Updated dependencies
callback-hook@1.4.0- Added
forEachiterator to be more in-line with the ES use for iterations.eachis now deprecated, but will remain supported.
- Added
v2.3.7, 2021-10-12
Meteor Version Release
meteor-tool@2.3.7- Patch to make 2.3.7 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v2.3.6, 2021-09-02
Highlights
- Updated Node.js per August 31st security release
Meteor Version Release
meteor-tool@2.3.6- Node.js updated to v14.17.6
Independent Releases
minifier-js@2.6.1- Terser updated to 4.8.0
routepolicy@1.1.1- Removed
underscoredependency since it was not used in the package
- Removed
email@2.1.1- Updated
nodemailerto v6.6.3
- Updated
callback-hook@1.3.1- Modernized the code
- Fixed a variable assignment bug in
dontBindEnvironmentfunction
less@4.0.0- Updated
lessto v4.1.1 - Fixed tests
- Updated
npm-mongo@3.9.1mongodb@3.6.10
accounts-base@2.0.1- Create index on
services.password.enroll.when - Blaze weak dependency updated to v2.5.0
- Create index on
facebook-oauth@1.9.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
github-oauth@1.3.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
google-oauth@1.3.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
meetup-oauth@1.1.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
meteor-developer-oauth@1.3.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
weibo-oauth@1.3.1- Allow usage of
httppackage both v1 and v2 for backward compatibility
- Allow usage of
oauth1@1.4.1- Allow usage of
httppackage both v1 and v2 for backward compatibility - Blaze weak dependency updated to v2.5.0
- Allow usage of
ddp-server@2.4.1- Fix a bug where
testMessageOnConnecthas always been sent
- Fix a bug where
accounts-password@2.0.1- Fix use of
isEnrollin reset password
- Fix use of
mdg:geolocation@1.3.1- Fixed API to work with Meteor 2.3+
mdg:reload-on-resume@1.0.5- Fixed API to work with Meteor 2.3+
v2.3.5, 2021-08-12
Highlights
- Updated Node.js per the August security release
- Includes same improvements as in Meteor v2.2.3
- Typescript updated to v4.3.5
@meteorjs/babel@7.12.0
Meteor Version Release
meteor-tool@2.3.5
v2.3.4, 2021-08-03
- Fix an issue in
bareandvueskeletons
v2.3.3, 2021-08-02
- Security patch of Node.js to 14.17.4
- App skeletons had the following dependencies updated:
meteor-node-stubs@1.1.0@babel/runtime@7.14.8
babel/parser@7.14.9for server dev bundle
v2.3.2, 2021-07-13
Meteor Version Release
meteor-tool@2.3.2- fixes a bug that makes
meteor run androidrun with the new aab package flag
- fixes a bug that makes
v2.3.1, 2021-07-08
Highlights
- Fix windows issue when running webapp package.
- Node.js updated to 14.17.3, following security release
Breaking Changes
- Meteor will now generate ".aab" (bundle files) by default when building for Android. This is the new default format for Android apps. Use the new build flag
--packageType=apkif you still need to generate APK.
Meteor Version Release
Updated travis CI environment to use Node.js 14.17.3
meteor-tool@2.3.1- Node.js updated to 14.17.2 and 14.17.3
@babel/runtimedependency updated to v7.14.6 across the tool and testing apps- Skeletons dependencies updated
- Apollo skeleton removed
apollo-boostdependency which is no longer needed - New build flag
--packageTypeto choose between apk/bundle for android builds (defaults to bundle).
Independent Releases
webapp@1.11.1- Remove
posixfrom npm shrinkwrap, to fix a bug it causes on Windows.
- Remove
less@3.0.2- Updated
@babel/runtimeto v7.14.6 - Updated
lessto v3.11.3
- Updated
standard-minifiers-css@1.7.3- Updated
@babel/runtimeto v7.14.6
- Updated
standard-minifiers-js@2.6.1- Updated
@babel/runtimeto v7.14.6
- Updated
dynamic-import@0.7.1- Fix Safari 14 bug with indexedDB
v2.3, 2021-06-24
Highlights
Node.js update to 14.17.1 from 12.22.1 🎉
Typescript update to 4.3.2
Packages had their backward compatibility to before Meteor 1.0 removed. See below for more details.
Improved tracking of which files are used by build plugins to know when it should do a full rebuild, a faster client-only rebuild, or can completely skip rebuilding after a file is modified. This should work with any type of file in any directory, and for both files in the app and files in packages. The most noticeable improvement is when modifying a file only used on the client Meteor will only rebuild the client, even if the file is not inside
importsor aclientfolder.
Summary of breaking changes
As Node.js version was upgraded to a new major version we recommend that you review if your npm dependencies are compatible with Node.js 14.
- If we receive reports from breaking changes we are going to list them here but so far we are not aware of any.
- We recommend that you read Node.js release notes though.
Accounts have undergone some major changes including major version bump. See below for more details.
All official packages that have been deprecated have now the deprecated flag and will inform you about that if you install or update them.
If you are working with enrollments in user accounts, do note that the enrollment token handling is now separate from reset password token. The token is now under
services.password.enroll, so adjust your code accordingly if you use it.
Migration steps
As Node.js version was upgraded we recommend that you remove your
node_modulesfolder (rm -rf node_modules) and runmeteor npm ito be sure you compile all the binary dependencies again using the new Node.js version.- Maybe you also want to recreate your lock file.
- If you get an error try
meteor resetwhich will clear caches, beware that this will also remove your local DB for your app.
If you are maintaining a package that depends on one of the accounts packages which had a major version bump you will either need to set the new version manually or set
api.versionsFrom('2.3'). You can also have it reference its current version and 2.3 like this:api.versionsFrom(['1.12', '2.3']), for specific package it can be like this:api.use('accounts-base@1.0.1 || 2.0.0').Old API for packages definitions has been removed. The old underscore method names (e.g.
api.add_files()) will no longer work, please use the camel case method names (e.g.api.addFiles()).
Breaking changes
Removed deprecated
mobile-portflagRemoved deprecated
rawname fromisobuildRemoved deprecated package API method names
Package.on_use,Package.on_test,Package._transitional_registerBuildPluginandapi.add_files, if you haven't till now, please use the current camel case versions.accounts-base@2.0.0- Deprecated backward compatibility function
logoutOtherClientshas been removed.
- Deprecated backward compatibility function
accounts-password@2.0.0- Deprecated backward compatibility functionality for
SRPpasswords from pre-Meteor 1.0 days has been removed. - Enroll account workflow has been separated from reset password workflow (the enrollment token records are now stored in a separate db field
services.password.enroll).
- Deprecated backward compatibility functionality for
ddp-client@2.5.0- Removed deprecated backward compatibility method names for Meteor before 1.0
ddp-server@2.4.0- Removed deprecated backward compatibility method names for Meteor before 1.0
meteor-base@1.5.0- Removed
livedatadependency which was there for packages build for 0.9.0
- Removed
minimongo@1.7.0- Removed the
rewindmethod that was noop for compatibility with Meteor 0.8.1
- Removed the
mongo@1.12.0- Removed the
rewindmethod that was noop for compatibility with Meteor 0.8.1
- Removed the
oauth@2.0.0- Removed deprecated
OAuth.initiateLoginand other functionality like the addition of?closein return URI for deprecated OAuth flow pre Meteor 1.0
- Removed deprecated
markdown@2.0.0- Use lazy imports to prevent it from being added to the initial bundle
- This package is now deprecated
http@2.0.0- Internally http has been replaced by fetch, should still work as previous version, but edge cases might be different. This is to aid you in transition to fetch. Note that this means that the
npmRequestOptionsparameter toHTTP.callhas been removed, asrequestis no longer used internally.
- Internally http has been replaced by fetch, should still work as previous version, but edge cases might be different. This is to aid you in transition to fetch. Note that this means that the
socket-stream-client@0.4.0- Remove IE8 checks
Meteor Version Release
meteor-tool@2.3- Node.js update to 14.17.1 from 12.22.1 🎉
- This is a major upgrade in Node.js. See the release notes for more details.
npmupdate to 6.14.13.fibershas been updated to v5.0.0.promisehas been updated to v8.1.0.node-gyphas been updated to v8.0.0.node-pre-gyphas been updated to v0.15.0.@babel/runtimehas been updated to v7.14.0.requesthas been updated to v2.88.2.uuidhas been updated to v3.4.0.graceful-fshas been updated to v4.2.6.tarhas been updated to v2.2.2.sqlite3has been updated to v5.0.2.http-proxyhas been updated to v1.18.1.wordwraphas been updated to v1.0.0.momenthas been updated to v2.29.1.globhas been updated to v7.1.6.split2has been updated to v3.2.2.lru-cachehas been updated to v4.1.5.anserhas been updated to v2.0.1.xmlbuilder2has been updated to v1.8.1.wshas been updated to v7.4.5.underscorehas been updated to v1.13.1optimismhas been updated to v0.16.1@wry/contexthas been update to v0.6.0- Reduced time spent by server (re)start in development by adding a cache for Reify. This optimization is on by default in development. Set the new
METEOR_TOOL_ENABLE_REIFY_RUNTIME_CACHEandMETEOR_REIFY_CACHE_DIRenvironment variables to adjust it or turn it on for production read more in the PR. - New flag
--platformshas been added to thebuildcommand to specify the platform you want to build for.meteor build . --platforms=android. This is useful for example when you are not using a MacOS and you want to build your app only for Android. Also to save time on CI not building all the platforms all the time. See PR for details. - The undocumented environment variable
DDP_DEFAULT_CONNECTION_URLbehavior has changed. SettingDDP_DEFAULT_CONNECTION_URLwhen running the server (development:meteor runor production:node main.js) sets the default DDP server value for meteor. But this did not work forcordovaapps. Now you can define thecordovaapp default DDP server value by settingDDP_DEFAULT_CONNECTION_URLwhen building (meteor build). - Skeletons dependencies updated to latest version
- Svelte skeleton now has HMR
- New deploy option:
--build-only. Helpful if you want to build first and after some validations proceeding with the upload and deploy. Read more - Improved watched system to properly rebuild
clienteven when a file is outside ofclientorimportsfolders. See PR for details. - Fix an issue when
App.appendToConfigcrashed Cordova build. - Reify compiler now uses cache in runtime. Read more
- Node.js update to 14.17.1 from 12.22.1 🎉
launch-screen@1.3.0- Removes LaunchScreen from web clients.
meteor-babel@7.11.0 (@meteorjs/babel)- Fixes for Samsung Internet v6.2+ to be considered modern browser and addition of logical assignment operators via
babel-presets-meteor. - This package was renamed to
@meteorjs/babel.
- Fixes for Samsung Internet v6.2+ to be considered modern browser and addition of logical assignment operators via
hot-module-replacement@0.3.0- Fixes various HMR bugs and edge cases see PR for more.
email@2.1.0- Updates
nodemailerto6.6.0and it now addscharset=utf-8totext/plainmessages by default.
- Updates
server-render@0.4.0- Updated npm dependencies
accounts-base@2.0.0- New hook
setAdditionalFindUserOnExternalLoginhas been added which allows you to customize user selection on external logins if you want to, for example, login a user who has the same e-mail as the external account.
- New hook
ddp-server@2.4.0- Added support for
this.unblock()inMeteor.publish()context. See PR for more details. - Add support in
Meteor.publish()for async functions
- Added support for
webapp@1.11.0- Webapp will respond appropriately to unsupported requests instead of sending content, including handling for new HTTP verbs. See PR for more details.
Independent Releases
ddp-server@2.3.3- Updates dependencies which removes Node's HTTP deprecation warning.
socket-stream-client@0.3.2- Updates dependencies which removes Node's HTTP deprecation warning.
ddp-client@2.4.1- Re-ordering fields in DDP message for better client readability.
mongo@1.11.1- Fixes a
Timestamp.ONE is undefinedbug.
- Fixes a
mongo-id@1.0.8- Removes unused dependency
id-map.
- Removes unused dependency
accounts-server@1.7.1- To better test password format & limit password to 256 characters, you can change this limit by setting
Meteor.settings.packages.accounts.passwordMaxLength.
- To better test password format & limit password to 256 characters, you can change this limit by setting
static-html@1.3.1- Removes
underscoredependency.
- Removes
dev-error-overlay@0.1.1- Fixes sometimes page content being on top of error overlay.
id-map@1.1.1- Removes unused dependencies and modernizing the code.
http@1.4.4- Used the new deprecation package flag instead of loud console warning.
logic-solver@2.0.8- Fixed
package.jsto use currentapimethod calls.
- Fixed
socket-stream-client@0.3.3- Update
faye-websocketdependency to v0.11.4.
- Update
jshint@1.1.8- The package has been deprecated.
npm-bcrypt@0.9.4- The package has been deprecated.
ecmascript-runtime-client@0.11.1- Updated
core-jsto v3.14.0
- Updated
ecmascript-runtime-server@0.11.1- Updated
core-jsto v3.14.0
- Updated
url@1.3.2- Updated
core-jsto v3.14.0
- Updated
hot-module-replacement@0.2.1- Add missing dependency.
observe-sequence@1.0.17- Updated dependencies
observe-sequence@1.0.18- When
#eachargument is unsupported it will be shown - Moving package under Blaze repository
- When
react-fast-refresh@0.1.1- Fixed the package to work in IE11
v2.2.4, 2021-10-12
Meteor Version Release
meteor-tool@2.2.4- Patch to make 2.2.4 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v2.2.3, 2021-08-12
Highlights
Meteor Version Release
meteor-tool@2.3.3- Updated Node.js to 12.22.5 per Node security update
- Typescript updated to v4.3.5
@meteorjs/babel@7.12.0
@meteorjs/babel@7.12.0&&@meteorjs/babel@7.13.0- Dependencies updated to their latest versions
babel-compile@7.7.0@meteorjs/babel@7.12.0
ecmascript@0.15.3- Typescript and Babel version bump
typescript@4.3.5
v2.2.2, 2021-08-02
Highlights
- Security update to Node.js 12.22.4
v2.2.1, 2021-06-02
Highlights
- Node.js updated to 12.22.2
- npm updated to 6.14.13
Meteor Version Release
meteor-tool@2.2.1- Updated Node.js to 12.22.2 per Node security update
v2.2, 2021-04-15
Highlights
- MongoDB Update to 4.4.4
- Cordova Update to 10
- Typescript Update to 4.2.2
- New skeleton:
meteor create myapp --svelte
Breaking changes
- N/A
Migration steps
meteor-toolmaybe you need to install the new Visual C++ Redistributable for Visual Studio 2019 to run MongoDB 4.4.4 on Windows. read moremongopackage is now using useUnifiedTopology astrueby default otherwise the new driver was producing a warning (see details below). It's important to test your app with this change.cordovaplugins and main libraries were updated from 9 to 10. It's important to test your app with these changes.typescriptwas updated to 4.2.2, make sure your read the breaking changes.
Meteor Version Release
meteor-tool@2.2- Update embedded MongoDB version to 4.4.4 #11341
- Maybe you need to install the new Visual C++ Redistributable for Visual Studio 2019 to run on Windows. read more
- Fix WindowsLikeFilesystem true when release string includes case insensitive word microsoft. #11321
- Fix absoluteFilePath on Windows. #11346
- New skeleton:
meteor create myapp --svelte - Update Blaze skeleton to use HMR
- Update embedded MongoDB version to 4.4.4 #11341
npm-mongo@3.9.0- Update MongoDB driver version to 3.6.6
mongo@1.11.0- Using useUnifiedTopology as
trueby default to avoid the warning:(node:59240) [MONGODB DRIVER] Warning: Current Server Discovery and Monitoring engine is deprecated, and will be removed in a future version. To use the new Server Discover and Monitoring engine, pass option { useUnifiedTopology: true } to the MongoClient constructor. You can still use it as false withMongo._connectionOptionsorMeteor.settings?.packages?.mongo?.options`.
- Using useUnifiedTopology as
cordova@10- Update Cordova to 10.0.0 #11208
typescript@4.2.2- Update Typescript to 4.2.2, make sure your read the breaking changes #11329
accounts-base@1.9.0- Allow to set token expiration to be set in milliseconds. #11366
facebook-oauth@1.9.0- Upgrade default Facebook API to v10 & allow overriding this value. #11362
minimongo@1.6.2webapp@1.10.1- Fix for UNIX sockets with node cluster. #11369
v2.1.2, 2021-10-12
Meteor Version Release
meteor-tool@2.1.2- Patch to make 2.1.2 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v2.1.1, 2021-04-06
Changes
Highlights
- Node.js security update to 12.22.1
Meteor Version Release
meteor-tool@2.1.1- Node.js security update to 12.22.1
- npm update to 6.14.12
Breaking changes
- N/A
Migration steps
- N/A
v2.1, 2021-02-24
Changes
Highlights
- Node.js security update to 12.21.0
Meteor Version Release
meteor-tool@2.1- Node.js security update to 12.21.0
meteor create my-app --plan professionalnew flagplanto enable you to choose a plan from the deploy command.
Breaking changes
- N/A
Migration steps
- N/A
v2.0.1, 2021-10-12
Meteor Version Release
meteor-tool@2.0.1- Patch to make 2.0.1 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v2.0, 2021-01-20
Changes
Highlights
Free deploy on Cloud: Deploy for free to Cloud with one command:
meteor deploy myapp.meteorapp.com --free. (docs)Deploy including MongoDB on Cloud: Deploy including MongoDB in a shared instance for free to Cloud with one command:
meteor deploy myapp.meteorapp.com --free --mongo. (docs)Hot Module Replacement (HMR): Updates the javascript modules in a running app that were modified during a rebuild. Reduces the feedback cycle while developing so you can view and test changes quicker (it even updates the app before the build has finished). Enabled by adding the
hot-module-replacementpackage to an app. React components are automatically updated by default using React Fast Refresh. Integrations with other libraries and view layers can be provided by third party packages. Support for Blaze is coming soon. This first version supports app code in the modern web architecture. (docs) #11117
Meteor Version Release
meteor-tool@2.0meteor create my-appnow creates by default a project using React. If you want to create a new project using Blaze you should use the new option--blaze.meteor create --react my-appis still going to create a React project.
meteor create --freedeploy for free to Cloud with one command:meteor deploy myapp.meteorapp.com --free. (docs).meteor create --free --mongodeploy including MongoDB in a shared instance for free to Cloud with one command:meteor deploy myapp.meteorapp.com --free --mongo. (docs)isobuildfixes a regression on recompiling node modules in different architectures. #11290isobuildconverts npm-discards.js to TypeScript. #10663cordovaensures the pathname of the rootUrl is used in the mobile URL. #11053- Add
file.hmrAvailable()for compiler plugins to check if a file meets the minimum requirements to be updated with HMR #11117
hot-module-replacement@1.0.0- New package that enables Hot Module Replacement for the Meteor app and provides an API to configure how updates are applied. HMR reduces the feedback cycle while developing by updating modified javascript modules within the running application. (docs) #11117
- These packages have been updated to support HMR:
autoupdate@1.7.0,babel-compiler@7.6.0,ddp-client@2.4.0,dynamic-import@0.6.0,ecmascript@0.15.0,modules@0.16.0,modules-runtime-hot@0.13.0,standard-minifier-css@1.7.2,webapp@1.10.0,webapp-hashing@1.1.0
react-fast-refresh@0.1.0dev-error-overlay@0.1.0- New package that allows you to see build errors and server crashes in your browser during development. Requires the app to have HMR enabled. #11117
accounts-base@1.8.0andaccounts-password@1.7.0- Extra parameters can now be added to reset password, verify e-mail and enroll account links that are generated for account e-mails. By default, these are added as search parameters to the generated url. You can pass them as an object in the appropriate functions. E.g.
Accounts.sendEnrollmentEmail(userId, email, null, extraParams);. #11288
- Extra parameters can now be added to reset password, verify e-mail and enroll account links that are generated for account e-mails. By default, these are added as search parameters to the generated url. You can pass them as an object in the appropriate functions. E.g.
logging@1.2.0- Updates dependencies and make debug available for use in non production environments. #11068
Independent Releases
react-meteor-data@2.2.0http- It has been deprecated. #11068
Breaking changes
httppackage has been deprecated. Please start on migrating towards the fetch package instead.
Migration steps
Simple run meteor update in your app.
Great new features and no breaking changes (except one package deprecation). You can always check our Roadmap to understand what is next.
v1.12.2, 2021-10-12
Meteor Version Release
meteor-tool@1.12.2- Patch to make 1.12.2 compatible with Push to Deploy feature in Galaxy (Meteor Cloud)
v1.12.1, 2021-01-06
Breaking changes
N/A
Migration steps
N/A
Changes
Highlights
- Node.js 12.20.1 release notes
- Fixes problem on IE because of modern syntax on
dynamic-importpackage.
Meteor Version Release
dynamic-import@0.5.5- Fixes problem on IE because of modern syntax (arrow function).
meteor-babel@7.10.6- Allows to disable sourceMap generation #36
babel-compiler@7.5.5- Allows to disable sourceMap generation #36
v1.12, 2020-12-04
Breaking changes
- When importing types, you might need to use the "type" qualifier, like so:
import { Point } from 'react-easy-crop/types';
to
import type { Point } from 'react-easy-crop/types';
Because now emitDecoratorsMetadata is enabled.
- Refer to typescript breaking changes before migrating your existing project, from 3.7.6 to 4.1.2: https://github.com/Microsoft/TypeScript/wiki/Breaking-Changes
Migration steps
N/A
Changes
Highlights
- TypeScript update from 3.7.6 to 4.1.2.
- enables decorators and metadata reflection. Important: these are stage 2 features so be aware that breaking changes could be introduced before they reach stage 3.
Meteor Version Release
meteor-tool@1.12- updates TypeScript to 4.1.2. #11225 and #11255
- adds new options for
meteor listcommand (TODO pending link to updated doc). #11165 - supports Cordova add plugin command working again with plugin id or plugin name in the git URL as it was before Meteor 1.11. #11202
- avoids MiTM by downloading through https. #11188
meteor-babel@7.10.5minimongo@1.6.1- fixes a null reference exception, if an array contains null values while compiling a fields projection. #10499.
accounts-password@1.6.3browser-content-policy@1.1.1- adds support to nonce
BrowserPolicy.content.allowScriptOrigin(`nonce-${nonce}`);
accounts-ui@1.3.2- follow accounts-ui-unstyled release
accounts-ui-unstyled@1.4.3- fixes the login form would send the server two login requests
- fixes the "forgot password" form would not only send the email but also refresh the page
dynamic-import@0.5.4mongo-decimal@0.1.2- updates npm dependency
decimal.jsto v10.2.1
- updates npm dependency
accounts-base@1.7.1- adds the ability to define default user fields published on login. #11118
standard-minifier-css@1.7.0- modernize and update dependencies. #11196
Independent Releases
facebook-oauth@1.7.3- is now using Facebook GraphAPI v8. #11160
v1.11.1, 2020-09-16
Breaking changes
N/A
Migration steps
N/A
Changes
--apolloskeleton was missing client cache setup more--vueskeleton was updated to use proper folder structure moreAll skeletons got their
npmdependencies updated. moreNode.js has been updated to version 12.18.4, this is a security release
Updated npm to version 6.14.8 more
npm-mongoversion 3.8.1 was published, updatingmongodbto 3.6.2 moreUpdated PostCSS from 7.0.31 to 7.0.32 more
Allow android-webview-video-poster more
v1.11, 2020-08-18
Breaking changes
emailpackage dependencies have been update and package version has been bumped to 2.0.0 There is a potential breaking change as the underlying package started to usedns.resolve()instead ofdns.lookup()which might be breaking on some environments. See nodemailer changelog for more information.(Added later) Cordova add plugin is not working with plugin name in the git URL when the plugin id was different than the name in the config.xml. Fixed on #11202
Migration steps
N/A
Changes
meteor create --apollois now available thanks to @StorytellerCZ. PR #11119meteor create --vueis now available thanks to @chris-visser. PR #11086--cache-buildoption is now available onmeteor deploycommand and you can use it safely all the time if you are using a Git repository to run your deploy. This is helpful if your upload is failing then you can retry just the upload and also if you deploy the same bundle to multiple environments. Read moreMultiple optimizations in build performance, many of them for Windows thanks to @zodern. PRs #10838, #11114, #11115, #11102, #10839
Fixes error when removing cordova plugin that depends on cli variables. PR #10976
emailpackage now exposeshookSendthat runs before emails are send.Node.js has been updated to version 12.18.3
Updated npm to version 6.14.5
mongodbdriver npm dependency has been updated to 3.6.0The version of MongoDB used by Meteor in development has been updated from 4.2.5 to 4.2.8
v1.10.2, 2020-04-21
Breaking changes
- The
babel-compilerpackage, used by bothecmascriptandtypescript, no longer supports stripping Flow type annotations by default, which may be a breaking change if your application (or Meteor package) relied on Flow syntax.
Migration steps
- If you still need Babel's Flow plugins, you can install them with npm
and then enable them with a custom
.babelrcfile in your application's (or package's) root directory:
{
"plugins": [
"@babel/plugin-syntax-flow",
"@babel/plugin-transform-flow-strip-types"
]
}
Changes
Adds support to override MongoDB options via Meteor settings. Code PR #10976, Docs PR #662
The
meteor-babelnpm package has been updated to version 7.9.0.The
typescriptnpm package has been updated to version 3.8.3.To pass Node command line flags to the server node instance, now it is recommended to use
SERVER_NODE_OPTIONSinstead ofNODE_OPTIONS. Since Meteor 0.5.3, Meteor allowed to pass node command line flags via theNODE_OPTIONSenvironment variable. However, since Node version 8 / Meteor 1.6 this has become a default node envar with the same behavior. The side effect is that this now also affects Meteor tool. The command line parameters could already be set separately via theTOOL_NODE_FLAGSenvar. This is now also possible (again) for the server.The version of MongoDB used by Meteor in development has been updated from 4.2.1 to 4.2.5. PR #11020
The
urlpackage now provides an isomorphic implementation of the WHATWGurl()API. While remaining backwards compatible, you can now also importURLandURLSearchParamsfrommeteor/url. These will work for both modern and legacy browsers as well as node.
v1.10.1, 2020-03-12
Breaking changes
Cordova has been updated from version 7 to 9. We recommend that you test your features that are taking advantage of Cordova plugins to be sure they are still working as expected.
- WKWebViewOnly is set by default now as true so if you are relying on
UIWebView or plugins that are using UIWebView APIs you probably want to
set it as false, you can do this by calling
App.setPreference('WKWebViewOnly', false);in your mobile-config.js. But we don't recommend turning this into false because Apple have said they are going to reject apps using UIWebView.
- WKWebViewOnly is set by default now as true so if you are relying on
UIWebView or plugins that are using UIWebView APIs you probably want to
set it as false, you can do this by calling
Because MongoDB since 3.4 no longer supports 32-bit Windows, Meteor 1.10 has also dropped support for 32-bit Windows. In other words, Meteor 1.10 supports 64-bit Mac, Windows 64-bit, and Linux 64-bit.
Migration Steps
If you get
Unexpected mongo exit code 62. Restarting.when starting your local MongoDB, you can either reset your project (meteor reset) (if you don't care about your local data) or you will need to update the feature compatibility version of your local MongoDB:- Downgrade your app to earlier version of Meteor
meteor update --release 1.9.2 - Start your application
- While your application is running open a new terminal window, navigate to the
app directory and open
mongoshell:meteor mongo - Use:
db.adminCommand({ getParameter: 1, featureCompatibilityVersion: 1 })to check the current feature compatibility. - If the returned version is less than 4.0 update like this:
db.adminCommand({ setFeatureCompatibilityVersion: "4.2" }) - You can now stop your app and update to Meteor 1.10.
For more information about this, check out MongoDB documentation.
- Downgrade your app to earlier version of Meteor
Changes
The version of MongoDB used by Meteor in development has been updated from 4.0.6 to 4.2.1, and the
mongodbdriver package has been updated from 3.2.7 to 3.5.4, thanks to @klaussner. Feature #361 PR #10723The
npmcommand-line tool used by themeteor npmcommand (and by Meteor internally) has been updated to version 6.14.0, and our fork of itspacotedependency has been updated to version 9.5.12.Cordova was updated from version 7 to 9
- cordova-lib from 7.1.0 to 9.0.1 release notes
- cordova-common from 2.1.1 to 3.2.1 release notes
- cordova-android from 7.1.4 to 8.1.0 release notes
- cordova-ios from 4.5.5 to 5.1.1 release notes
- cordova-plugin-wkwebview-engine from 1.1.4 to 1.2.1 release notes
- cordova-plugin-whitelist from 1.3.3 to 1.3.4 release notes
- cordova-plugin-splashscreen (included by mobile-experience > launch-screen) from 4.1.0 to 5.0.3 release notes
- cordova-plugin-statusbar (included by mobile-experience > mobile-status-bar) from 2.3.0 to 2.4.3 release notes
- On iOS WKWebViewOnly is set by default now as true.
- On iOS the Swift version is now set by default to
5this change can make your app to produce some warnings if your plugins are using old Swift code. You can override the Swift version usingApp.setPreference('SwiftVersion', 4.2);but we don't recommend that.
New command to ensure that Cordova dependencies are installed. Usage:
meteor ensure-cordova-dependencies. Meteor handles this automatically but in some cases, like running in a CI, is useful to install them in advance.You can now pass an
--exclude-archsoption to themeteor runandmeteor testcommands to temporarily disable building certain web architectures. For example,meteor run --exclude-archs web.browser.legacy. Multiple architectures should be separated by commas. This option can be used to improve (re)build times if you're not actively testing the excluded architectures during development. Feature #333, PR #10824meteor create --react appand--typescriptnow useuseTrackerhook instead ofwithTrackerHOC, it also usesfunctioncomponents instead ofclasses.
v1.9.3, 2020-03-09
Breaking changes
- The MongoDB
retryWritesoption now defaults totrue(it previously defaulted to false). Users of database services that don't support retryWrites will experience a fatal error due to this.
Migration Steps
- If you get the error
MongoError: This MongoDB deployment does not support retryable writes. Please add retryWrites=false to your connection string., appendretryWrites=falseto your MongoDB connection string.
Changes
mongodbdriver package has been updated from 3.2.7 to 3.5.4 #10961
v1.9.2, 2020-02-20
Breaking changes
N/A
Migration Steps
N/A
Changes
Node.js has been updated to version 12.16.1, fixing several unintended regressions introduced in 12.16.0.
The
meteor-babelnpm package has been updated to version 7.8.2.The
typescriptnpm package has been updated to version 3.7.5.
v1.9.1, 2020-02-18
Breaking changes
N/A
Migration Steps
N/A
Changes
Node.js has been updated to version 12.16.0 from 12.14.0, which includes security updates and small changes:
- 12.16.0
- Updated V8 to release v7.8 which includes improvements in performance, for example, object destructuring now is as fast as the equivalent variable assignment.
- 12.15.0
- 12.16.0
cursor.observeChangesnow accepts a second options argument. If your observer functions do not mutate the passed arguments, you can specify{ nonMutatingCallbacks: true }, which improves performance by reducing the amount of data copies.
v1.9, 2020-01-09
Breaking changes
- Because Node.js 12 no longer supports 32-bit Linux, Meteor 1.9 has also dropped support for 32-bit Linux. In other words, Meteor 1.9 supports 64-bit Mac, Windows, and Linux, as well as 32-bit Windows.
Migration Steps
N/A
Changes
Node.js has been updated to version 12.14.0, which includes several major Node.js versions since 8.17.0 (used by Meteor 1.8.3):
The
fibersnpm package has been updated to version 4.0.3, which includes changes that may drastically reduce garbage collection pressure resulting from heavyFiberusage.The
pathwatchernpm package has been updated to use a fork of version 8.0.2, with PR #128 applied.The
sqlite3npm package has been updated to version 4.1.0.The
node-gypnpm package has been updated to version 6.0.1, andnode-pre-gyphas been updated to version 0.14.0.The feature that restarts the application up to two times if it crashes on startup has been removed. Feature #335 PR #10345
Facebook OAuth has been updated to call v5 API endpoints. PR #10738
Meteor.user(),Meteor.findUserByEmail()andMeteor.findUserByUserName()can take a newoptionsparameter which can be used to limit the returned fields. Useful for minimizing DB bandwidth on the server and avoiding unnecessary reactive UI updates on the client. Issue #10469Accounts.config()has a new optiondefaultFieldSelectorwhich will apply to allMeteor.user()andMeteor.findUserBy...()functions without explicit field selectors, and also to allonLogin,onLogoutandonLoginFailurecallbacks. This is useful if you store large data on the user document (e.g. a growing list of transactions) which do no need to be retrieved from the DB whenever you or a package author callMeteor.user()without limiting the fields. Issue #10469Lots of internal calls to
Meteor.user()without field specifiers inaccounts-baseandaccounts-passwordpackages have been optimized with explicit field selectors to only the fields needed by the functions they are in. Issue #10469
v1.8.3, 2019-12-19
Migration Steps
- If your application uses
blaze-html-templates, the Meteorjquerypackage will be automatically installed in your.meteor/packagesfile when you update to Meteor 1.8.3. However, this new version of the Meteorjquerypackage no longer bundles its own copy of thejquerynpm implementation, so you may need to installjqueryfrom npm by running
meteor npm i jquery
in your application directory. Symptoms of not installing jquery include a blank browser window, with helpful error messages in the console.
Changes
Node has been updated to version 8.17.0.
The
npmnpm package has been updated to version 6.13.4, and our fork of itspacotedependency has been updated to version 9.5.11, an important security release.Prior to Meteor 1.8.3, installing the
jquerypackage from npm along with the Meteorjquerypackage could result in bundling jQuery twice. Thanks to PR #10498, the Meteorjquerypackage will no longer provide its own copy of jQuery, but will simply display a warning in the console if thejquerynpm package cannot be found in yournode_modulesdirectory. If you are usingblazein your application, updating to Meteor 1.8.3 will automatically add this new version of the Meteorjquerypackage to your application if you were not already using it (thanks to PR #10801), but you might need to runmeteor npm i jquerymanually, so thatblazecan importjqueryfrom yournode_modulesdirectory.The
meteor-babelnpm package has been updated to version 7.7.5.The
typescriptnpm package has been updated to version 3.7.3.
v1.8.2, 2019-11-14
Breaking changes
Module-level variable declarations named
requireorexportsare no longer automatically renamed, so they may collide with module function parameters of the same name, leading to errors likeUncaught SyntaxError: Identifier 'exports' has already been declared. See this comment by @SimonSimCity.Plugin.fsmethods are now always sync and no longer accept a callback.
Migration Steps
- Be sure to update the
@babel/runtimenpm package to its latest version (currently 7.7.2):
meteor npm install @babel/runtime@latest
- New Meteor applications now depend on
meteor-node-stubs@1.0.0, so it may be a good idea to update to the same major version:
meteor npm install meteor-node-stubs@next
- If you are the author of any Meteor packages, and you encounter errors
when using those packages in a Meteor 1.8.2 application (for example,
module.watchbeing undefined), we recommend that you bump the minor version of your package and republish it using Meteor 1.8.2, so Meteor 1.8.2 applications will automatically use the new version of the package, as compiled by Meteor 1.8.2:
cd path/to/your/package
# Add api.versionsFrom("1.8.2") to Package.onUse in package.js...
meteor --release 1.8.2 publish
This may not be necessary for all packages, especially those that have
been recently republished using Meteor 1.8.1, or local packages in the
packages/ directory (which are always recompiled from source).
However, republishing packages is a general solution to a wide variety
of package versioning and compilation problems, and package authors can
make their users' lives easier by handling these issues proactively.
Changes
Node has been updated to version 8.16.2.
The
npmnpm package has been updated to version 6.13.0, and our fork of itspacotedependency has been updated to version 9.5.9.New Meteor applications now include an official
typescriptpackage, supporting TypeScript compilation of.tsand.tsxmodules, which can be added to existing apps by runningmeteor add typescript.New TypeScript-based Meteor applications can be created by running
meteor create --typescript new-typescript-app
This app skeleton contains a recommended tsconfig.json file, and should serve as a reference for how to make TypeScript and Meteor work together (to the best of our current knowledge). PR #10695
When bundling modern client code, the Meteor module system now prefers the
"module"field inpackage.json(if defined) over the"main"field, which should unlock variousimport/export-based optimizations such as tree shaking in future versions of Meteor. As before, server code uses only the"main"field, like Node.js, and legacy client code prefers"browser","main", and then"module". PR #10541, PR #10765.ECMAScript module syntax (
import,export, and dynamicimport()) is now supported by default everywhere, including in modules imported fromnode_modules, thanks to the Reify compiler.If you need to import code from
node_modulesthat uses modern syntax beyond module syntax, it is now possible to enable recompilation for specific npm packages using themeteor.nodeModules.recompileoption in your application'spackage.jsonfile. See PR #10603 for further explanation.The Meteor build process is now able to detect whether files changed in development were actually used by the server bundle, so that a full server restart can be avoided when no files used by the server bundle have changed. Client-only refreshes are typically much faster than server restarts. Run
meteor add autoupdateto enable client refreshes, if you are not already using theautoupdatepackage. Issue #10449 PR #10686The
mongodbnpm package used by thenpm-mongoMeteor package has been updated to version 3.2.7.The
meteor-babelnpm package has been updated to version 7.7.0, enabling compilation of themeteor/toolscodebase with TypeScript (specifically, version 3.7.2 of thetypescriptnpm package).The
reifynpm package has been updated to version 0.20.12.The
core-jsnpm package used byecmascript-runtime-clientandecmascript-runtime-serverhas been updated to version 3.2.1.The
tersernpm package used byminifier-js(and indirectly bystandard-minifier-js) has been updated to version 4.3.1.The
node-gypnpm package has been updated to version 5.0.1, andnode-pre-gyphas been updated to 0.13.0.The
optimismnpm package has been updated to version 0.11.3, which enables caching of thrown exceptions as well as ordinary results, in addition to performance improvements.The
pathwatchernpm package has been updated to version 8.1.0.The
underscorenpm package installed in the Meteor dev bundle (for use by themeteor/toolscodebase) has been updated from version 1.5.2 to version 1.9.1, and@types/underscorehas been installed for better TypeScript support.In addition to the
.jsand.jsxfile extensions, theecmascriptcompiler plugin now automatically handles JavaScript modules with the.mjsfile extension.Add
--cordova-server-portoption to override local port where Cordova will serve static resources, which is useful when multiple Cordova apps are built from the same application source code, since by default the port is generated using the ID from the application's.meteor/.idfile.The
--test-app-path <directory>option formeteor test-packagesandmeteor testnow accepts relative paths as well as absolute paths.
v1.8.1, 2019-04-03
Breaking changes
- Although we are not aware of any specific backwards incompatibilities,
the major upgrade of
cordova-androidfrom 6.4.0 to 7.1.4 likely deserves extra attention, if you use Cordova to build Android apps.
Migration Steps
N/A
Changes
- Node has been updated from version 8.11.4 to version
8.15.1, an important
security release,
which includes the changes from four other minor releases:
- 8.15.0
- 8.14.0, an important security release
- 8.12.0
- 8.13.0
Note: While Node 8.12.0 included changes that may improve the performance of Meteor apps, there have been reports of CPU usage spikes in production due to excessive garbage collection, so this version of Meteor should be considered experimental until those problems have been fixed. Issue #10216
The
npmtool has been upgraded to version 6.9.0, and our fork of itspacotedependency has been updated to version 9.5.0.Mongo has been upgraded to version 4.0.6 for 64-bit systems (was 4.0.2), and 3.2.22 for 32-bit systems (was 3.2.19). The
mongodbnpm package used bynpm-mongohas been updated to version 3.1.13 (was 3.1.6).The
fibersnpm package has been updated to version 3.1.1, a major update from version 2.0.0. Building this version offibersrequires a C++11 compiler, unlike previous versions. If you deploy your Meteor app manually (without using Galaxy), you may need to update the version ofg++used when runningnpm installin thebundle/programs/serverdirectory.The
meteor-babelnpm package has been updated to version 7.3.4.Cordova Hot Code Push mechanism is now switching versions explicitly with call to
WebAppLocalServer.switchToPendingVersioninstead of trying to switch every time a browser reload is detected. If you use any third party package or have your own HCP routines implemented be sure to call it before forcing a browser reload. If you use the automatic reload from theReloadmeteor package you do not need to do anything. cordova-plugin-meteor-webapp PR #62Multiple Cordova-related bugs have been fixed, including Xcode 10 build incompatibilities and hot code push errors due to duplicated images/assets. PR #10339
The
cordova-androidandcordova-iosnpm dependencies have been updated to 7.1.4 (from 6.4.0) and 4.5.5 (from 4.5.4), respectively.Build performance has improved (especially on Windows) thanks to additional caching implemented by @zodern in PRs #10399, #10452, #10453, and #10454.
The
meteor mongocommand no longer uses the--quietoption, so the normal startup text will be displayed, albeit without the banner about Mongo's free monitoring service. See this MongoDB Jira issue for more details.In Meteor packages,
client/andserver/directories no longer have any special meaning. In application code,client/directories are ignored during the server build, andserver/directories are ignored during the client build, as before. This special behavior previously applied to packages as well, but has now been removed. Issue #10393 PR #10414If your application is using Git for version control, the current Git commit hash will now be exposed via the
Meteor.gitCommitHashproperty while the app is running (in both server and client code), and also via the"gitCommitHash"property in thestar.jsonfile located in the root directory of builds produced bymeteor build, for consumption by deployment tools. If you are not using Git, neither property will be defined. PR #10442The Meteor Tool now uses a more reliable method (the MongoDB
isMastercommand) to detect when the local development database has started and is ready to accept read and write operations. PR #10500Setting the
x-no-compressionrequest header will prevent thewebapppackage from compressing responses withgzip, which may be useful if your Meteor app is behind a proxy that compresses resources with another compression algorithm, such as brotli. PR #10378
v1.8.0.2, 2019-01-07
Breaking changes
N/A
Migration steps
N/A
Changes
The React tutorial has been updated to address a number of inaccuracies due to changes in recent Meteor releases that were not fully incorporated back into the tutorial. As a reminder, Meteor now supports a
meteor create --reactcommand that can be used to create a new React-based app quickly.Fixed a bug where modules named with
*.app-tests.js(or*.tests.js) file extensions sometimes could not be imported by themeteor.testModuleentry point when running themeteor testcommand (ormeteor test --full-app). PR #10402The
meteor-promisepackage has been updated to version 0.8.7, which includes a commit that should prevent memory leaks when excess fibers are discarded from theFiberpool.The
meteor-babelnpm package has been updated to version 7.2.0, improving source maps for applications with custom.babelrcfiles.
v1.8.0.1, 2018-11-23
Breaking changes
N/A
Migration steps
N/A
Changes
The
useragentnpm package used bywebappand (indirectly) by themodern-browserspackage has been updated from 2.2.1 to 2.3.0. Thechromiumbrowser name has been aliased to use the same minimum modern version aschrome, and browser names are now processed case-insensitively by themodern-browserspackage. PR #10334Fixed a module caching bug that allowed
findImportedModuleIdentifiersto return the same identifiers for the modern and legacy versions of a given module, even if the set of imported modules is different (for example, because Babel injects fewer@babel/runtime/...imports into modern code). Now the caching is always based on the SHA-1 hash of the generated code, rather than trusting the hash provided by compiler plugins. PR #10330
v1.8, 2018-10-08
Breaking changes
N/A
Migration Steps
- Update the
@babel/runtimenpm package to version 7.0.0 or later:
meteor npm install @babel/runtime@latest
Changes
- Although Node 8.12.0 has been released, Meteor 1.8 still uses Node 8.11.4, due to concerns about excessive garbage collection and CPU usage in production. To enable Galaxy customers to use Node 8.12.0, we are planning a quick follow-up Meteor 1.8.1 release, which can be obtained by running the command
meteor update --release 1.8.1-beta.n
where -beta.n is the latest beta release according to the
releases page (currently
-beta.6).
Issue #10216
PR #10248
Meteor 1.7 introduced a new client bundle called
web.browser.legacyin addition to theweb.browser(modern) andweb.cordovabundles. Naturally, this extra bundle increased client (re)build times. Since developers spend most of their time testing the modern bundle in development, and the legacy bundle mostly provides a safe fallback in production, Meteor 1.8 cleverly postpones building the legacy bundle until just after the development server restarts, so that development can continue as soon as the modern bundle has finished building. Since the legacy build happens during a time when the build process would otherwise be completely idle, the impact of the legacy build on server performance is minimal. Nevertheless, the legacy bundle still gets rebuilt regularly, so any legacy build errors will be surfaced in a timely fashion, and legacy clients can test the new legacy bundle by waiting a bit longer than modern clients. Applications using theautoupdateorhot-code-pushpackages will reload modern and legacy clients independently, once each new bundle becomes available. Issue #9948 PR #10055Compiler plugins that call
inputFile.addJavaScriptorinputFile.addStylesheetmay now delay expensive compilation work by passing partial options ({ path, hash }) as the first argument, followed by a callback function as the second argument, which will be called by the build system once it knows the module will actually be included in the bundle. For example, here's the old implementation ofBabelCompiler#processFilesForTarget:
processFilesForTarget(inputFiles) {
inputFiles.forEach(inputFile => {
var toBeAdded = this.processOneFileForTarget(inputFile);
if (toBeAdded) {
inputFile.addJavaScript(toBeAdded);
}
});
}
and here's the new version:
processFilesForTarget(inputFiles) {
inputFiles.forEach(inputFile => {
if (inputFile.supportsLazyCompilation) {
inputFile.addJavaScript({
path: inputFile.getPathInPackage(),
hash: inputFile.getSourceHash(),
}, function () {
return this.processOneFileForTarget(inputFile);
});
} else {
var toBeAdded = this.processOneFileForTarget(inputFile);
if (toBeAdded) {
inputFile.addJavaScript(toBeAdded);
}
}
});
}
If you are an author of a compiler plugin, we strongly recommend using
this new API, since unnecessary compilation of files that are not
included in the bundle can be a major source of performance problems for
compiler plugins. Although this new API is only available in Meteor 1.8,
you can use inputFile.supportsLazyCompilation to determine dynamically
whether the new API is available, so you can support older versions of
Meteor without having to publish multiple versions of your package. PR
#9983
- New React-based Meteor applications can now be created using the command
meteor create --react new-react-app
Though relatively simple, this application template reflects the ideas of many contributors, especially @dmihal and @alexsicart, and it will no doubt continue to evolve in future Meteor releases. Feature #182 PR #10149
The
.meteor/packagesfile supports a new syntax for overriding problematic version constraints from packages you do not control.If a package version constraint in
.meteor/packagesends with a!character, any other (non-!) constraints on that package elsewhere in the application will be weakened to allow any version greater than or equal to the constraint, even if the major/minor versions do not match.For example, using both CoffeeScript 2 and
practicalmeteor:mochaused to be impossible (or at least very difficult) because of thisapi.versionsFrom("1.3")statement, which unfortunately constrained thecoffeescriptpackage to version 1.x. In Meteor 1.8, if you want to updatecoffeescriptto 2.x, you can relax thepracticalmeteor:mochaconstraint by putting
coffeescript@2.2.1_1! # note the !
in your .meteor/packages file. The coffeescript version still needs
to be at least 1.x, so that practicalmeteor:mocha can count on that
minimum. However, practicalmeteor:mocha will no longer constrain the
major version of coffeescript, so coffeescript@2.2.1_1 will work.
Feature #208 Commit 4a70b12e Commit 9872a3a7
The
npmpackage has been upgraded to version 6.4.1, and our fork of itspacotedependency has been rebased against version 8.1.6.The
node-gypnpm package has been updated to version 3.7.0, and thenode-pre-gypnpm package has been updated to version 0.10.3.Scripts run via
meteor npm ...can now use themeteorcommand more safely, since thePATHenvironment variable will now be set so thatmeteoralways refers to the samemeteorused to runmeteor npm. PR #9941Minimongo's behavior for sorting fields containing an array is now compatible with the behavior of Mongo 3.6+. Note that this means it is now incompatible with the behavior of earlier MongoDB versions. PR #10214
Meteor's
self-testhas been updated to use "headless" Chrome rather than PhantomJS for browser tests. PhantomJS can still be forced by passing the--phantomflag to themeteor self-testcommand. PR #9814Importing a directory containing an
index.*file now works for non-.jsfile extensions. As before, the list of possible extensions is defined by which compiler plugins you have enabled. PR #10027Any client (modern or legacy) may now request any static JS or CSS
web.browserorweb.browser.legacyresource, even if it was built for a different architecture, which greatly simplifies CDN setup if your CDN does not forward theUser-Agentheader to the origin. Issue #9953 PR #9965Cross-origin dynamic
import()requests will now succeed in more cases. PR #9954Dynamic CSS modules (which are compiled to JS and handled like any other JS module) will now be properly minified in production and source mapped in development. PR #9998
While CSS is only minified in production, CSS files must be merged together into a single stylesheet in both development and production. This merging is cached by
standard-minifier-cssso that it does not happen on every rebuild in development, but not all CSS minifier packages use the same caching techniques. Thanks to 1ed095c36d, this caching is now performed within the Meteor build tool, so it works the same way for all CSS minifier packages, which may eliminate a few seconds of rebuild time for projects with lots of CSS.The
meteor-babelnpm package used bybabel-compilerhas been updated to version 7.1.0. Note: This change requires also updating the@babel/runtimenpm package to version 7.0.0-beta.56 or later:
meteor npm install @babel/runtime@latest
The
@babel/preset-envand@babel/preset-reactpresets will be ignored by Meteor if included in a.babelrcfile, since Meteor already provides equivalent/superior functionality without them. However, you should feel free to leave these plugins in your.babelrcfile if they are needed by external tools.The
installnpm package used bymodules-runtimehas been updated to version 0.12.0.The
reifynpm package has been updated to version 0.17.3, which introduces themodule.link(id, {...})runtime method as a replacement formodule.watch(require(id), {...}). Note: in future versions ofreifyand Meteor, themodule.watchruntime API will be removed, but for now it still exists (and is used to implementmodule.link), so that existing code will continue to work without recompilation.The
uglify-esnpm package used byminifier-jshas been replaced withterser@3.9.2, a fork ofuglify-esthat appears to be (more actively) maintained. Issue #10042Mongo has been updated to version 4.0.2 and the
mongodbnpm package used bynpm-mongohas been updated to version 3.1.6. PR #10058 Feature Request #269When a Meteor application uses a compiler plugin to process files with a particular file extension (other than
.jsor.json), those file extensions should be automatically appended to imports that do not resolve as written. However, this behavior was not previously enabled for modules insidenode_modules. Thanks to 8b04c25390, the same file extensions that are applied to modules outside thenode_modulesdirectory will now be applied to those within it, though.jsand.jsonwill always be tried first.As foreshadowed in this talk about Meteor 1.7's modern/legacy bundling system (slides), Meteor now provides an isomorphic implementation of the WHATWG
fetch()API, which can be installed by running
meteor add fetch
This package is a great demonstration of the modern/legacy bundling system, since it has very different implementations in modern browsers, legacy browsers, and Node. PR #10029
The
bundle-visualizerpackage has received a number of UI improvements thanks to work by @jamesmillerburgess in PR #10025. Feature #310Sub-resource integrity hashes (sha512) can now be enabled for static CSS and JS assets by calling
WebAppInternals.enableSubresourceIntegrity(). PR #9933 PR #10050The environment variable
METEOR_PROFILE=millisecondsnow works for the build portion of themeteor buildandmeteor deploycommands. Feature #239Babel compiler plugins will now receive a
calleroption of the following form:
{ name: "meteor", arch }
where arch is the target architecture, e.g. os.*, web.browser,
web.cordova, or web.browser.legacy.
PR #10211
v1.7.0.5, 2018-08-16
Breaking changes
N/A
Migration Steps
N/A
Changes
- Node has been updated to version 8.11.4, an important security release.
v1.7.0.4, 2018-08-07
Breaking changes
N/A
Migration Steps
N/A
Changes
The npm package
@babel/runtime, which is depended on by most Meteor apps, introduced a breaking change in version7.0.0-beta.56with the removal of the@babel/runtime/helpers/builtindirectory. While this change has clear benefits in the long term, in the short term it has been disruptive for Meteor 1.7.0.x applications that accidentally updated to the latest version of@babel/runtime. Meteor 1.7.0.4 is a patch release that provides better warnings about this problem, and ensures newly created Meteor applications do not use7.0.0-beta.56. PR #10134The
npmpackage has been upgraded to version 6.3.0, and our fork of itspacotedependency has been rebased against version 8.1.6. Issue #9940The
reifynpm package has been updated to version 0.16.4.
v1.7.0.3, 2018-06-13
Breaking changes
N/A
Migration Steps
N/A
Changes
- Fixed Issue #9991, introduced in Meteor 1.7.0.2 by PR #9977.
v1.7.0.2, 2018-06-13
Breaking changes
N/A
Migration Steps
N/A
Changes
Node has been updated to version 8.11.3, an important security release.
The
meteor-babelnpm package has been updated to version 7.0.0-beta.51.Meteor apps created with
meteor createormeteor create --minimalwill now have a directory calledtests/rather thantest/, so that test code will not be eagerly loaded if you decide to remove themeteor.mainModuleconfiguration frompackage.json, thanks to PR #9977 by @robfallows. Issue #9961
v1.7.0.1, 2018-05-29
Breaking changes
- The
aggregatemethod of raw Mongo collections now returns anAggregationCursorrather than returning the aggregation result directly. To obtain an array of aggregation results, you will need to call the.toArray()method of the cursor:
// With MongoDB 2.x, callback style:
rawCollection.aggregate(
pipeline,
(error, results) => {...}
);
// With MongoDB 2.x, wrapAsync style:
const results = Meteor.wrapAsync(
rawCollection.aggregate,
rawCollection
)(pipeline);
// With MongoDB 3.x, callback style:
rawCollection.aggregate(
pipeline,
(error, aggregationCursor) => {
...
const results = aggregationCursor.toArray();
...
}
);
// With MongoDB 3.x, wrapAsync style:
const results = Meteor.wrapAsync(
rawCollection.aggregate,
rawCollection
)(pipeline).toArray();
Migration Steps
- Update
@babel/runtime(as well as other Babel-related packages) andmeteor-node-stubsto their latest versions:
meteor npm install @babel/runtime@latest meteor-node-stubs@latest
Changes
Reverted an optimization introduced in Meteor 1.7 to stop scanning
node_modulesfor files that might be of interest to compiler plugins, since the intended workarounds (creating symlinks) did not satisfy all existing use cases. We will revisit this optimization in Meteor 1.8. mozfet/meteor-autoform-materialize#43After updating to Meteor 1.7 or 1.7.0.1, you should update the
@babel/runtimenpm package (as well as other Babel-related packages) to their latest versions, along with themeteor-node-stubspackage, by running the following command:
meteor npm install @babel/runtime@latest meteor-node-stubs@latest
v1.7, 2018-05-28
Breaking changes
N/A
Migration Steps
N/A
Changes
More than 80% of internet users worldwide have access to a web browser that natively supports the latest ECMAScript features and keeps itself updated automatically, which means new features become available almost as soon as they ship. In other words, the future we envisioned when we first began compiling code with Babel is finally here, yet most web frameworks and applications still compile a single client-side JavaScript bundle that must function simultaneously in the oldest and the newest browsers the application developer wishes to support.
That choice is understandable, because the alternative is daunting: not only must you build multiple JavaScript and CSS bundles for different browsers, with different dependency graphs and compilation rules and webpack configurations, but your server must also be able to detect the capabilities of each visiting client, so that it can deliver the appropriate assets at runtime. Testing a matrix of different browsers and application versions gets cumbersome quickly, so it's no surprise that responsible web developers would rather ship a single, well-tested bundle, and forget about taking advantage of modern features until legacy browsers have disappeared completely.
With Meteor 1.7, this awkward balancing act is no longer necessary, because Meteor now automatically builds two sets of client-side assets, one tailored to the capabilities of modern browsers, and the other designed to work in all supported browsers, thus keeping legacy browsers working exactly as they did before. Best of all, the entire Meteor community relies on the same system, so any bugs or differences in behavior can be identified and fixed quickly.
In this system, a "modern" browser can be loosely defined as one with full native support for
asyncfunctions andawaitexpressions, which includes more than 80% of the world market, and 85% of the US market (source). This standard may seem extremely strict, sinceasync/awaitwas just finalized in ECMAScript 2017, but the statistics clearly justify it. As another example, any modern browser can handle nativeclasssyntax, though newer syntax like class fields may still need to be compiled for now, whereas a legacy browser will need compilation for both advanced and basicclasssyntax. And of course you can safely assume that any modern browser has a nativePromiseimplementation, becauseasyncfunctions must returnPromises. The list goes on and on.This boundary between modern and legacy browsers is designed to be tuned over time, not only by the Meteor framework itself but also by each individual Meteor application. For example, here's how the minimum versions for native ECMAScript
classsupport might be expressed:
import { setMinimumBrowserVersions } from "meteor/modern-browsers";
setMinimumBrowserVersions({
chrome: 49,
firefox: 45,
edge: 12,
ie: Infinity, // Sorry, IE11.
mobile_safari: [9, 2], // 9.2.0+
opera: 36,
safari: 9,
electron: 1,
}, "classes");
The minimum modern version for each browser is simply the maximum of all
versions passed to setMinimumBrowserVersions for that browser. The
Meteor development server decides which assets to deliver to each client
based on the User-Agent string of the HTTP request. In production,
different bundles are named with unique hashes, which prevents cache
collisions, though Meteor also sets the Vary: User-Agent HTTP response
header to let well-behaved clients know they should cache modern and
legacy resources separately.
For the most part, the modern/legacy system will transparently determine
how your code is compiled, bundled, and delivered—and yes, it
works with every existing part of Meteor, including dynamic import()
and even the old appcache
package. However, if you're
writing dynamic code that depends on modern features, you can use the
boolean Meteor.isModern flag to detect the status of the current
environment (Node 8 is modern, too, of course). If you're writing a
Meteor package, you can call api.addFiles(files, "legacy") in your
package.js configuration file to add extra files to the legacy bundle,
or api.addFiles(files, "client") to add files to all client bundles,
or api.addFiles(files, "web.browser") to add files only to the modern
bundle, and the same rules apply to api.mainModule. Just be sure to
call setMinimumBrowserVersions (in server startup code) to enforce
your assumptions about ECMAScript feature support.
We think this modern/legacy system is one of the most powerful features
we've added since we first introduced the ecmascript package in Meteor
1.2, and we look forward to other frameworks attempting to catch up.
Although Meteor does not recompile packages installed in
node_modulesby default, compilation of specific npm packages (for example, to support older browsers that the package author neglected) can now be enabled in one of two ways:- Clone the package repository into your application's
importsdirectory, make any modifications necessary, then usenpm installto linkthe-packageintonode_modules:
meteor npm install imports/the-packageMeteor will compile the contents of the package exposed via
imports/the-package, and this compiled code will be used when you importthe-packagein any of the usual ways:import stuff from "the-package" require("the-package") === require("/imports/the-package") import("the-package").then(...)This reuse of compiled code is the critical new feature that was added in Meteor 1.7.
- Install the package normally with
meteor npm install the-package, then create a symbolic link to the installed package elsewhere in your application, outside ofnode_modules:
meteor npm install the-package cd imports ln -s ../node_modules/the-package .Again, Meteor will compile the contents of the package because they are exposed outside of
node_modules, and the compiled code will be used wheneverthe-packageis imported fromnode_modules.Note: this technique also works if you create symbolic links to individual files, rather than linking the entire package directory.
In both cases, Meteor will compile the exposed code as if it was part of your application, using whatever compiler plugins you have installed. You can influence this compilation using
.babelrcfiles or any other techniques you would normally use to configure compilation of application code. PR #9771 Feature #6- Clone the package repository into your application's
~Note: since compilation of npm packages can now be enabled using the techniques described above, Meteor will no longer automatically scan
node_modulesdirectories for modules that can be compiled by compiler plugins. If you have been using that functionality to import compiled-to-JS modules fromnode_modules, you should start using the symlinking strategy instead.~ Follow-up note: this optimization was reverted in Meteor 1.7.0.1 (see above).
Node has been updated to version 8.11.2, officially fixing a cause of frequent segmentation faults in Meteor applications that was introduced in Node 8.10.0. Meteor 1.6.1.1 shipped with a custom build of Node that patched this problem, but that approach was never intended to be permanent.
The
npmpackage has been upgraded to version 5.10.0, and our fork of itspacotedependency has been rebased against version 7.6.1.Applications may now specify client and server entry point modules in a newly-supported
"meteor"section ofpackage.json:
"meteor": {
"mainModule": {
"client": "client/main.js",
"server": "server/main.js"
}
}
When specified, these entry points override Meteor's default module
loading semantics, rendering imports directories unnecessary. If
mainModule is left unspecified for either client or server, the
default rules will apply for that architecture, as before. To disable
eager loading of modules on a given architecture, simply provide a
mainModule value of false:
"meteor": {
"mainModule": {
"client": false,
"server": "server/main.js"
}
}
- In addition to
meteor.mainModule, the"meteor"section ofpackage.jsonmay also specifymeteor.testModuleto control which test modules are loaded bymeteor testormeteor test --full-app:
"meteor": {
"mainModule": {...},
"testModule": "tests.js"
}
If your client and server test files are different, you can expand the
testModule configuration using the same syntax as mainModule:
"meteor": {
"testModule": {
"client": "client/tests.js",
"server": "server/tests.js"
}
}
The same test module will be loaded whether or not you use the
--full-app option. Any tests that need to detect --full-app should
check Meteor.isAppTest. The module(s) specified by meteor.testModule
can import other test modules at runtime, so you can still distribute
test files across your codebase; just make sure you import the ones you
want to run. PR #9714
The
meteor createcommand now supports a--minimaloption, which creates an app with as few Meteor packages as possible, in order to minimize client bundle size while still demonstrating advanced features such as server-side rendering. This starter application is a solid foundation for any application that doesn't need Mongo or DDP.The
meteor-babelnpm package has been updated to version 7.0.0-beta.49-1. Note: while Babel has recently implemented support for a new kind ofbabel.config.jsconfiguration file (see this PR), and future versions of Meteor will no doubt embrace this functionality, Meteor 1.7 supports only.babelrcfiles as a means of customizing the default Babel configuration provided by Meteor. In other words, if your project contains ababel.config.jsfile, it will be ignored by Meteor 1.7.The
reifynpm package has been updated to version 0.16.2.The
meteor-node-stubspackage, which provides stub implementations for any Node built-in modules used by the client (such aspathandhttp), has a new minor version (0.4.1) that may help with Windows installation problems. To install the new version, run
meteor npm install meteor-node-stubs@latest
The
optimismnpm package has been updated to version 0.6.3.The
minifier-jspackage has been updated to useuglify-es3.3.9.Individual Meteor
self-test's can now be skipped by adjusting theirdefinecall to be prefixed byskip. For example,selftest.skip.define('some test', ...will skip running "some test". PR #9579Mongo has been upgraded to version 3.6.4 for 64-bit systems, and 3.2.19 for 32-bit systems. PR #9632
NOTE: After upgrading an application to use Mongo 3.6.4, it has been observed (#9591) that attempting to run that application with an older version of Meteor (via
meteor --release X), that uses an older version of Mongo, can prevent the application from starting. This can be fixed by either runningmeteor reset, or by repairing the Mongo database. To repair the database, find themongodbinary on your system that lines up with the Meteor release you're jumping back to, and runmongodb --dbpath your-apps-db --repair. For example:
~/.meteor/packages/meteor-tool/1.6.0_1/mt-os.osx.x86_64/dev_bundle/mongodb/bin/mongod --dbpath /my-app/.meteor/local/db --repair
The
mongodbdriver package has been updated from version 2.2.34 to version 3.0.7. PR #9790 PR #9831 Feature #268The
cordova-plugin-meteor-webapppackage depended on by the Meteorwebapppackage has been updated to version 1.6.0. PR #9761Any settings read from a JSON file passed with the
--settingsoption during Cordova run/build/deploy will be exposed inmobile-config.jsvia theApp.settingsproperty, similar toMeteor.settings. PR #9873The
@babel/plugin-proposal-class-propertiesplugin provided bymeteor-babelnow runs with theloose:trueoption, as required by other (optional) plugins like@babel/plugin-proposal-decorators. Issue #9628The
underscorepackage has been removed as a dependency frommeteor-base. This opens up the possibility of removing 14.4 kb from production bundles. Since this would be a breaking change for any apps that may have been using_without having any packages that depend onunderscorebesidesmeteor-base, we have added an upgrader that will automatically addunderscoreto the.meteor/packagesfile of any project which listsmeteor-base, but notunderscore. Apps which do not require this package can safely remove it usingmeteor remove underscore. PR #9596Meteor's
promisepackage has been updated to supportPromise.prototype.finally. Issue 9639 PR #9663Assets made available via symlinks in the
publicandprivatedirectories of an application are now copied into Meteor application bundles when usingmeteor build. This means npm package assets that need to be made available publicly can now be symlinked from theirnode_moduleslocation, in thepublicdirectory, and remain available in production bundles. Issue #7013 PR #9666The
factspackage has been split intofacts-baseandfacts-ui. The originalfactspackage has been deprecated. PR #9629If the new pseudo tag
<meteor-bundled-css />is used anywhere in the<head />of an app, it will be replaced by thelinkto Meteor's bundled CSS. If the new tag isn't used, the bundle will be placed at the top of the<head />section as before (for backwards compatibility). Feature #24 PR #9657
v1.6.1.4, 2018-08-16
Breaking changes
N/A
Migration Steps
N/A
Changes
- Node has been updated to version 8.11.4, an important security release.
v1.6.1.3, 2018-06-16
Breaking changes
N/A
Migration Steps
N/A
Changes
- Node has been updated to version 8.11.3, an important security release.
v1.6.1.2, 2018-05-28
Breaking changes
N/A
Migration Steps
N/A
Changes
- Meteor 1.6.1.2 is a very small release intended to fix #9863 by making #9887 available to Windows users without forcing them to update to Meteor 1.7 (yet). Thanks very much to @zodern for identifying a solution to this problem. PR #9910
v1.6.1.1, 2018-04-02
Breaking changes
N/A
Migration Steps
- Update
@babel/runtimenpm package and any custom Babel plugin enabled in.babelrc
meteor npm install @babel/runtime@latest
Changes
Node has been updated to version 8.11.1, an important security release, with a critical patch applied to solve a segmentation fault problem that was introduced in Node 8.10.0.
The
meteor-babelnpm package has been updated to version 7.0.0-beta.42, which may require updating any custom Babel plugins you've enabled in a.babelrcfile, and/or running the following command to update@babel/runtime:
meteor npm install @babel/runtime@latest
v1.6.1, 2018-01-19
Breaking changes
Meteor's Node Mongo driver is now configured with the
ignoreUndefinedconnection option set totrue, to make sure fields withundefinedvalues are not first converted tonull, when inserted/updated.undefinedvalues are now removed from all Mongo queries and insert/update documents.This is a potentially breaking change if you are upgrading an existing app from an earlier version of Meteor.
For example:
// return data pertaining to the current user
db.privateUserData.find({
userId: currentUser._id // undefined
});
Assuming there are no documents in the privateUserData collection with
userId: null, in Meteor versions prior to 1.6.1 this query will return
zero documents. From Meteor 1.6.1 onwards, this query will now return
every document in the collection. It is highly recommend you review all
your existing queries to ensure that any potential usage of undefined in
query objects won't lead to problems.
Migration Steps
N/A
Changes
Node has been updated to version 8.9.4.
The
meteor-babelnpm package (along with its Babel-related dependencies) has been updated to version 7.0.0-beta.38, a major update from Babel 6. Thanks to the strong abstraction of themeteor-babelpackage, the most noticeable consequence of the Babel 7 upgrade is that thebabel-runtimenpm package has been replaced by@babel/runtime, which can be installed by running
meteor npm install @babel/runtime
in your application directory. There's a good chance that the old
babel-runtime package can be removed from your package.json
dependencies, though there's no harm in leaving it there. Please see
this blog post
for general information about updating to Babel 7 (note especially any
changes to plugins you've been using in any .babelrc files).
PR #9440
Because
babel-compiler@7.0.0is a major version bump for a core package, any package that explicitly depends onbabel-compilerwithapi.useorapi.implywill need to be updated and republished in order to remain compatible with Meteor 1.6.1. One notable example is thepracticalmeteor:mochapackage. If you have been using this test-driver package, we strongly recommend switching tometeortesting:mochainstead. If you are the author of a package that depends onbabel-compiler, we recommend publishing your updated version using a new major or minor version, so that you can continue releasing patch updates compatible with older versions of Meteor, if necessary.Meteor's Node Mongo driver is now configured with the
ignoreUndefinedconnection option set totrue, to make sure fields withundefinedvalues are not first converted tonull, when inserted/updated.undefinedvalues are now removed from all Mongo queries and insert/update documents. Issue #6051 PR #9444The
server-renderpackage now supports passing aStreamobject toServerSinkmethods that previously expected a string, which enables streaming server-side rendering with React 16:
import React from "react";
import { renderToNodeStream } from "react-dom/server";
import { onPageLoad } from "meteor/server-render";
import App from "/imports/Server.js";
onPageLoad(sink => {
sink.renderIntoElementById("app", renderToNodeStream(
<App location={sink.request.url} />
));
});
The
cordova-libpackage has been updated to version 7.1.0,cordova-androidhas been updated to version 6.4.0 (plus one additional commit), andcordova-ioshas been updated to version 4.5.4. The cordova pluginscordova-plugin-console,cordova-plugin-device-motion, andcordova-plugin-device-orientationhave been deprecated and will likely be removed in a future Meteor release. Feature Request #196 PR #9213 Issue #9447 PR #9448The previously-served
/manifest.jsonapplication metadata file is now served from/__browser/manifest.jsonfor web browsers, to avoid confusion with other kinds ofmanifest.jsonfiles. Cordova clients will continue to load the manifest file from/__cordova/manifest.json, as before. Issue #6674 PR #9424The bundled version of MongoDB used by
meteor runin development on 64-bit architectures has been updated to 3.4.10. 32-bit architectures will continue to use MongoDB 3.2.x versions since MongoDB is no longer producing 32-bit versions of MongoDB for newer release tracks. PR #9396Meteor's internal
minifier-csspackage has been updated to usepostcssfor CSS parsing and minifying, instead of the abandonedcss-parseandcss-stringifypackages. Changes made to theCssToolsAPI exposed by theminifier-csspackage are mostly backwards compatible (thestandard-minifier-csspackage that uses it didn't have to change for example), but now that we're usingpostcssthe AST accepted and returned from certain functions is different. This could impact developers who are tying into Meteor's internalminifier-csspackage directly. The AST based function changes are:CssTools.parseCssnow returns a PostCSSRootobject.CssTools.stringifyCssexpects a PostCSSRootobject as its first parameter.CssTools.mergeCssAstsexpects an array of PostCSSRootobjects as its first parameter.CssTools.rewriteCssUrlsexpects a PostCSSRootobject as its first parameter.
The
_variable will once again remain bound tounderscore(if installed) inmeteor shell, fixing a regression introduced by Node 8. PR #9406Dynamically
import()ed modules will now be fetched from the application server using an HTTP POST request, rather than a WebSocket message. This strategy has all the benefits of the previous strategy, except that it does not require establishing a WebSocket connection before fetching dynamic modules, in exchange for slightly higher latency per request. PR #9384To reduce the total number of HTTP requests for dynamic modules, rapid sequences of
import()calls within the same tick of the event loop will now be automatically batched into a single HTTP request. In other words, the following code will result in only one HTTP request:
const [
React,
ReactDOM
] = await Promise.all([
import("react"),
import("react-dom")
]);
Thanks to a feature request and pull request from @CaptainN, all available dynamic modules will be automatically prefetched after page load and permanently cached in IndexedDB when the
appcachepackage is in use, ensuring that dynamicimport()will work for offline apps. Although the HTML5 Application Cache was deliberately not used for this prefetching, the new behavior matches the spirit/intention of theappcachepackage. Feature Request #236 PR #9482 PR #9434The
es5-shimlibrary is no longer included in the initial JavaScript bundle, but is instead injected using a<script>tag in older browsers that may be missing full support for ECMAScript 5. For the vast majority of modern browsers that do not needes5-shim, this change will reduce the bundle size by about 10KB (minified, pre-gzip). For testing purposes, the<script>tag injection can be triggered in any browser by appending?force_es5_shim=1to the application URL. PR #9360The
Tinytest.addAsyncAPI now accepts test functions that returnPromiseobjects, making theonCompletecallback unnecessary:
Tinytest.addAsync("some async stuff", async function (test) {
test.equal(shouldReturnFoo(), "foo");
const bar = await shouldReturnBarAsync();
test.equal(bar, "bar");
});
- Line number comments are no longer added to bundled JavaScript files on the client or the server. Several years ago, before all major browsers supported source maps, we felt it was important to provide line number information in generated files using end-of-line comments like
some.code(1234); // 123
more.code(5, 6); // 124
Adding all these comments was always slower than leaving the code unmodified, but recently the comments have begun interacting badly with certain newer ECMAScript syntax, such as multi-line template strings. Since source maps are well supported in most browsers that developers are likely to be using for development, and the line number comments are now causing substantive problems beyond the performance cost, we concluded it was time to stop using them. PR #9323 Issue #9160
Since Meteor 1.3, Meteor has supported string-valued
"browser"fields inpackage.jsonfiles, to enable alternate entry points for packages in client JavaScript bundles. In Meteor 1.6.1, we are expanding support to include object-valued"browser"fields, according to this unofficial and woefully incomplete (but widely-implemented) "spec document." We are only supporting the "relative style" of browser replacements, however, and not the "package style" (as detailed in this comment), because supporting the package style would have imposed an unacceptable runtime cost on all imports (not just those overridden by a"browser"field). PR #9311 Issue #6890The
Boilerplate#toHTMLmethod from theboilerplate-generatorpackage has been deprecated in favor oftoHTMLAsync(which returns aPromisethat resolves to a string of HTML) ortoHTMLStream(which returns aStreamof HTML). Although direct usage oftoHTMLis unlikely, please update any code that calls this method if you see deprecation warnings in development. Issue #9521.The
npmpackage has been upgraded to version 5.6.0, and our fork of itspacotedependency has been rebased against version 7.0.2.The
reifynpm package has been updated to version 0.13.7.The
minifier-jspackage has been updated to useuglify-es3.2.2.The
requestnpm package used by both thehttppackage and themeteorcommand-line tool has been upgraded to version 2.83.0.The
kexecnpm package has been updated to version 3.0.0.The
momentnpm package has been updated to version 2.20.1.The
rimrafnpm package has been updated to version 2.6.2.The
globnpm package has been updated to version 7.1.2.The
ignorenpm package has been updated to version 3.3.7.The
escopenpm package has been updated to version 3.6.0.The
split2npm package has been updated to version 2.2.0.The
multipipenpm package has been updated to version 2.0.1.The
pathwatchernpm package has been updated to version 7.1.1.The
lru-cachenpm package has been updated to version 4.1.1.The deprecated
Meteor.httpobject has been removed. If your application is still usingMeteor.http, you should now useHTTPinstead:
import { HTTP } from "meteor/http";
HTTP.call("GET", url, ...);
- The deprecated
Meteor.uuidfunction has been removed. If your application is still usingMeteor.uuid, you should run
meteor npm install uuid
to install the widely used uuid
package from npm. Example usage:
import uuid from "uuid";
console.log(uuid());
The log-suppressing flags on errors in
ddp-clientandddp-serverhave been changed fromexpectedto_expectedByTestin order to avoid inadvertently silencing errors in production. Issue #6912 PR #9515Provide basic support for iPhone X status bar and launch screens, which includes updates to
cordova-plugin-statusbar@2.3.0andcordova-plugin-splashscreen@4.1.0. Issue #9041 PR #9375Fixed an issue preventing the installation of scoped Cordova packages. For example,
meteor add cordova:@somescope/some-cordova-plugin@1.0.0
will now work properly. Issue #7336 PR #9334
iOS icons and launch screens have been updated to support iOS 11 Issue #9196 PR #9198
Enables passing
falsetocursor.count()on the client to prevent skip and limit from having an effect on the result. Issue #1201 PR #9205An
onExternalLoginhook has been added to the accounts system, to allow the customization of OAuth user profile updates. PR #9042Accounts.confignow supports abcryptRoundsoption that overrides the default 10 rounds currently used to secure passwords. PR #9044Developers running Meteor from an interactive shell within Emacs should notice a substantial performance improvement thanks to automatic disabling of the progress spinner, which otherwise reacts slowly. PR #9341
Npm.dependscan now specify anyhttporhttpsURL. Issue #9236 PR #9237Byte order marks included in
--settingsfiles will no longer crash the Meteor Tool. Issue #5180 PR #9459The
accounts-ui-unstyledpackage has been updated to use<form />and<button />tags with its login/signup form, instead of<div />'s. This change helps browser's notice login/signup requests, allowing them to trigger their "remember your login/password" functionality.
Note: If your application is styling the login/signup form using a CSS path that includes the replaced
divelements (e.g.div.login-form { ...ordiv.login-button { ...), your styles will break. You can either update your CSS to useform./button.or adjust your CSS specificity by styling onclass/idattributes only.
The
styluspackage has been deprecated and will no longer be supported/maintained. PR #9445Support for the
meteor admin get-machinecommand has been removed, and the build farm has been discontinued. Ever since Meteor 1.4, packages with binary dependencies have been automatically (re)compiled when they are installed in an application, assuming the target machine has a basic compiler toolchain. To see the requirements for this compilation step, consult the platform requirements fornode-gyp.Client side
Accounts.onLogincallbacks now receive a login details object, with the attempted login type (e.g.{ type: password }after a successful password based login,{ type: resume }after a DDP reconnect, etc.). Issue #5127 PR #9512
v1.6.0.1, 2017-12-08
Node has been upgraded to version 8.9.3, an important security release.
The
npmpackage has been upgraded to version 5.5.1, which supports several new features, including two-factor authentication, as described in the release notes.
v1.6, 2017-10-30
Important note for package maintainers:
With the jump to Node 8, some packages published using Meteor 1.6 may no longer be compatible with older Meteor versions. In order to maintain compatibility with Meteor 1.5 apps when publishing your package, you can specify a release version with the meteor publish command:
meteor --release 1.5.3 publish
If you're interested in taking advantage of Meteor 1.6 while still supporting older Meteor versions, you can consider publishing for Meteor 1.6 from a new branch, with your package's minor or major version bumped. You can then continue to publish for Meteor 1.5 from the original branch. Note that the 1.6 branch version bump is important so that you can continue publishing patch updates for Meteor 1.5 from the original branch.
Node.js has been upgraded to version 8.8.1, which will be entering long-term support (LTS) coverage on 31 October 2017, lasting through December 2019 (full schedule). This is a major upgrade from the previous version of Node.js used by Meteor, 4.8.4.
The
npmnpm package has been upgraded to version 5.4.2, a major upgrade from 4.6.1. While this update should be backwards-compatible for existing Meteor apps and packages, if you are the maintainer of any Meteor packages, pay close attention to yournpm-shrinkwrap.jsonfiles when first using this version ofnpm. For normal Meteor application development, this upgrade primarily affects the version ofnpmused bymeteor npm ...commands. A functional installation ofgitmay be required to support GitHub repository and/or tarball URLs. Troubleshooting. PR #8835In addition to
meteor nodeandmeteor npm, which are convenient shorthands fornodeandnpm,meteor npx <command>can be used to execute commands from a localnode_modules/.bindirectory or from thenpmcache. Any packages necessary to run the command will be automatically downloaded. Read about it, or just try some commands:
meteor npx cowsay mooooo
meteor npx uuid
meteor npx nyancat
meteor npx yarn
The
meteor debugcommand has been superseded by the more flexible--inspectand--inspect-brkcommand-line flags, which work for anyrun,test, ortest-packagescommand.The syntax of these flags is the same as the equivalent Node.js flags, with two notable differences:
The flags affect the server process spawned by the build process, rather than affecting the build process itself.
The
--inspect-brkflag causes the server process to pause just after server code has loaded but before it begins to execute, giving the developer a chance to set breakpoints in server code.
On Windows, Meteor can now be installed or reinstalled from scratch using the command
choco install meteor, using the Chocolatey package manager. This method of installation replaces the oldInstallMeteor.exeinstaller, which had a number of shortcomings, and will no longer be supported.Fresh installs of Meteor 1.6 on 64-bit Windows machines will now use native 64-bit Node.js binaries, rather than a 32-bit version of Node.js. In addition to being faster, native 64-bit support will enable Windows developers to debug asynchronous stack traces more easily in the new Node.js inspector, which is only fully supported by native 64-bit architectures. Note that merely running
meteor updatefrom a 32-bit version of Meteor will still install a 32-bit version of Meteor 1.6, so you should usechoco install meteorto get a fresh 64-bit version. PR #9218To support developers running on a 32-bit OS, Meteor now supports both 32- and 64-bit versions of Mongo. Mongo 3.2 is the last 32-bit version available from Mongo. Meteor running on a 32-bit OS will use a 32-bit version of Mongo 3.2 and 64-bit platforms will receive newer Mongo versions in future releases. PR #9173
After several reliability improvements, native file watching has been un-disabled on Windows. Though native file change notifications will probably never work with network or shared virtual file systems (e.g., NTFS or Vagrant-mounted disks), Meteor uses an efficient prioritized polling system as a fallback for those file systems.
Various optimizations have reduced the on-disk size of the
meteor-toolpackage from 545MB (1.5.2.2) to 219MB.The
meteor-babelpackage has been upgraded to version 0.24.6, to take better advantage of native language features in Node 8.The
reifynpm package has been upgraded to version 0.12.3.The
meteor-promisepackage has been upgraded to version 0.8.6, to enable better handling ofUnhandledPromiseRejectionWarnings.The
node-gypnpm package has been upgraded to version 3.6.2.The
node-pre-gypnpm package has been updated to version 0.6.36.The
fibersnpm package has been upgraded to version 2.0.0.The
pathwatchernpm package has been upgraded to version 7.1.0.The
http-proxynpm package has been upgraded to version 1.16.2.The
semvernpm package has been upgraded to version 5.4.1.When running Meteor tool tests (i.e.
./meteor self-test) during the course of developing Meteor itself, it is no longer necessary to./meteor npm install -g phantomjs-prebuilt browserstack-webdriver. These will now be installed automatically upon their use.You can now run
meteor test --driver-package user:packagewithout first runningmeteor add user:package.iOS icons and launch screens have been updated to support iOS 11 Issue #9196 PR #9198
v1.5.4.2, 2018-04-02
- Node has been upgraded to version 4.9.0, an important security release.
v1.5.4.1, 2017-12-08
- Node has been upgraded to version 4.8.7, an important security release.
v1.5.4, 2017-11-08
- Node has been updated to version 4.8.6. This release officially includes our fix of a faulty backport of garbage collection-related logic in V8 and ends Meteor's use of a custom Node with that patch. In addition, it includes small OpenSSL updates as announced on the Node blog: https://nodejs.org/en/blog/release/v4.8.6/. Issue #8648
v1.5.3, 2017-11-04
Node has been upgraded to version 4.8.5, a recommended security release: https://nodejs.org/en/blog/release/v4.8.5/. While it was expected that Node 4.8.5 would also include our fix of a faulty backport of garbage collection-related logic in V8, the timing of this security release has caused that to be delayed until 4.8.6. Therefore, this Node still includes our patch for this issue. Issue #8648
Various backports from Meteor 1.6, as detailed in the PR for Meteor 1.5.3. Briefly, these involve fixes for:
v1.5.2.2, 2017-10-02
Fixes a regression in 1.5.2.1 which resulted in the macOS firewall repeatedly asking to "accept incoming network connections". While the
nodebinary in 1.5.2.1 was functionally the same as 1.5.2, it had been recompiled on our build farm (which re-compiles all architectures at the same time) to ensure compatibility with older (but still supported) Linux distributions. Unfortunately, macOS took issue with the binary having a different 'signature' (but same 'identifier') as one it had already seen, and refused to permanently "allow" it in the firewall. Our macOSnodebinaries are now signed with a certificate, hopefully preventing this from occurring again. Issue #9139Fixes a regression in
accounts-basecaused by changes to the (now deprecated)connection.onReconnectfunction which caused users to be logged out shortly after logging in. Issue #9140 PR #cordova-ioshas been updated to version 4.5.1, to add in iOS 11 / Xcode 9 compatibility. Issue #9098 Issue #9126 PR #9137Includes a follow-up change to the (not commonly necessary)
Npm.requirewhich ensures built-in modules are loaded first, which was necessary after a change in 1.5.2.1 which reduced its scope. This resolves "Cannot find module crypto" and similar errors. Issue #9136A bug that prevented building some binary npm packages on Windows has been fixed. Issue #9153
v1.5.2.1, 2017-09-26
- Updating to Meteor 1.5.2.1 will automatically patch a security
vulnerability in the
allow-denypackage, sincemeteor-tool@1.5.2_1requiresallow-deny@1.0.9or later. If for any reason you are not ready or able to update to Meteor 1.5.2.1 by runningmeteor update, please at least run
meteor update allow-deny
instead. More details about the security vulnerability can be found on the Meteor forums.
The command-line
meteortool no longer invokesnodewith the--expose-gcflag. Although this flag allowed the build process to be more aggressive about collecting garbage, it was also a source of problems in Meteor 1.5.2 and Node 4.8.4, from increased segmentation faults during (the more frequent) garbage collections to occasional slowness in rebuilding local packages. The flag is likely to return in Meteor 1.6, where it has not exhibited any of the same problems.Meteor now supports
.meteorignorefiles, which cause the build system to ignore certain files and directories using the same pattern syntax as.gitignorefiles. These files may appear in any directory of your app or package, specifying rules for the directory tree below them. Of course,.meteorignorefiles are also fully integrated with Meteor's file watching system, so they can be added, removed, or modified during development. Feature request #5DDP's
connection.onReconnect = funcfeature has been deprecated. This functionality was previously supported as a way to set a function to be called as the first step of reconnecting. This approach has proven to be inflexible as only one function can be defined to be called when reconnecting. Meteor's accounts system was already setting anonReconnectcallback to be used internally, which means anyone setting their ownonReconnectcallback was inadvertently overwriting code used internally. Moving forward theDDP.onReconnect(callback)method should be used to register callbacks to call when a connection reconnects. The connection that is reconnecting is passed as the only argument tocallback. This is used by the accounts system to re-login on reconnects without interfering with other code that usesconnection.onReconnect. Issue #5665 PR #9092reactive-dictnow supportsdestroy.destroywill clear theReactiveDicts data and unregister theReactiveDictfrom data migration. i.e. When aReactiveDictis instantiated with a name on the client and thereloadpackage is present in the project. Feature Request #76 PR #9063The
webapppackage has been updated to support UNIX domain sockets. If aUNIX_SOCKET_PATHenvironment variable is set with a valid UNIX socket file path (e.g.UNIX_SOCKET_PATH=/tmp/socktest.sock), Meteor's HTTP server will use that socket file for inter-process communication, instead of TCP. This can be useful in cases like using Nginx to proxy requests back to an internal Meteor application. Leveraging UNIX domain sockets for inter-process communication reduces the sometimes unnecessary overhead required by TCP based communication. Issue #7392 PR #8702The
fastclickpackage (previously included by default in Cordova applications through themobile-experiencepackage) has been deprecated. This package is no longer maintained and has years of outstanding unresolved issues, some of which are impacting Meteor users. Most modern mobile web browsers have removed the 300ms tap delay thatfastclickworked around, as long as the following<head />metaelement is set (which is generally considered a mobile best practice regardless, and which the Meteor boilerplate generator already sets by default for Cordova apps):<meta name="viewport" content="width=device-width">If anyone is still interested in usingfastclickwith their application, it can be installed from npm directly (meteor npm install --save fastclick). Reference: Mobile Chrome Mobile Safari PR #9039Minimongo cursors are now JavaScript iterable objects and can now be iterated over using
for...ofloops, spread operator,yield*, and destructuring assignments. PR #8888
v1.5.2, 2017-09-05
Node 4.8.4 has been patched to include https://github.com/nodejs/node/pull/14829, an important PR implemented by our own @abernix (:tada:), which fixes a faulty backport of garbage collection-related logic in V8 that was causing occasional segmentation faults during Meteor development and testing, ever since Node 4.6.2 (Meteor 1.4.2.3). When Node 4.8.5 is officially released with these changes, we will immediately publish a small follow-up release. Issue #8648
When Meteor writes to watched files during the build process, it no longer relies on file watchers to detect the change and invalidate the optimistic file system cache, which should fix a number of problems related by the symptom of endless rebuilding. Issue #8988 Issue #8942 PR #9007
The
cordova-libnpm package has been updated to 7.0.1, along with cordova-android (6.2.3) and cordova-ios (4.4.0), and various plugins. PR #8919 resolves the umbrella issue #8686, as well as several Android build issues: #8408, #8424, and #8464.The
boilerplate-generatorpackage responsible for generating initial HTML documents for Meteor apps has been refactored by @stevenhao to avoid using thespacebars-related packages, which means it is now possible to remove Blaze as a dependency from the server as well as the client. PR #8820The
meteor-babelpackage has been upgraded to version 0.23.1.The
reifynpm package has been upgraded to version 0.12.0, which includes a minor breaking change that correctly skips exports nameddefaultinexport * from "module"declarations. If you have any wrapper modules that re-export another module's exports usingexport * from "./wrapped/module", and the wrapped module has adefaultexport that you want to be included, you should now explicitly re-exportdefaultusing a second declaration:
export * from "./wrapped/module";
export { default } "./wrapped/module";
The
meteor-promisepackage has been upgraded to version 0.8.5, and thepromisepolyfill package has been upgraded to 8.0.1.The
semvernpm package has been upgraded to version 5.3.0. PR #8859The
faye-websocketnpm package has been upgraded to version 0.11.1, and its dependencywebsocket-driverhas been upgraded to a version containing this fix, thanks to @sdarnell. meteor-feature-requests#160The
uglify-jsnpm package has been upgraded to version 3.0.28.Thanks to PRs #8960 and #9018 by @GeoffreyBooth, a
coffeescript-compilerpackage has been extracted from thecoffeescriptpackage, similar to how thebabel-compilerpackage is separate from theecmascriptpackage, so that other packages (such asvue-coffee) can make use ofcoffeescript-compiler. Allcoffeescript-related packages have been moved topackages/non-core, so that they can be published independently from Meteor releases.meteor list --treecan now be used to list all transitive package dependencies (and versions) in an application. Weakly referenced dependencies can also be listed by using the--weakoption. For more information, runmeteor help list. PR #8936The
star.jsonmanifest created within the root of ameteor buildbundle will now containnodeVersionandnpmVersionwhich will specify the exact versions of Node.js and npm (respectively) which the Meteor release was bundled with. The.node_version.txtfile will still be written into the root of the bundle, but it may be deprecated in a future version of Meteor. PR #8956A new package called
mongo-dev-serverhas been created and wired intomongoas a dependency. As long as this package is included in a Meteor application (which it is by default since all new Meteor apps havemongoas a dependency), a local development MongoDB server is started alongside the application. This package was created to provide a way to disable the local development Mongo server, whenmongoisn't needed (e.g. when using Meteor as a build system only). If an application has no dependency onmongo, themongo-dev-serverpackage is not added, which means no local development Mongo server is started. Feature Request #31 PR #8853Accounts.configno longer mistakenly allows tokens to expire when theloginExpirationInDaysoption is set tonull. Issue #5121 PR #8917The
"env"field is now supported in.babelrcfiles. PR #8963Files contained by
client/compatibility/directories or added withapi.addFiles(files, ..., { bare: true })are now evaluated before importing modules withrequire, which may be a breaking change if you depend on the interleaving ofbarefiles with eager module evaluation. PR #8972When
meteor test-packagesruns in a browser, uncaught exceptions will now be displayed above the test results, along with the usual summary of test failures, in case those uncaught errors have something to do with later test failures. Issue #4979 PR #9034
v1.5.1, 2017-07-12
Node has been upgraded to version 4.8.4.
A new core Meteor package called
server-renderprovides generic support for server-side rendering of HTML, as described in the package'sREADME.md. PR #8841To reduce the total number of file descriptors held open by the Meteor build system, native file watchers will now be started only for files that have changed at least once. This new policy means you may have to wait up to 5000ms for changes to be detected when you first edit a file, but thereafter changes will be detected instantaneously. In return for that small initial waiting time, the number of open file descriptors will now be bounded roughly by the number of files you are actively editing, rather than the number of files involved in the build (often thousands), which should help with issues like #8648. If you need to disable the new behavior for any reason, simply set the
METEOR_WATCH_PRIORITIZE_CHANGEDenvironment variable to"false", as explained in PR #8866.All
observeandobserveChangescallbacks are now bound usingMeteor.bindEnvironment. The sameEnvironmentVariables that were present whenobserveorobserveChangeswas called are now available inside the callbacks. PR #8734A subscription's
onReadyis now fired again during a re-subscription, even if the subscription has the same arguments. Previously, when subscribing to a publication theonReadywould have only been called if the arguments were different, creating a confusing difference in functionality. This may be breaking behavior if an app uses the firing ofonReadyas an assumption that the data was just received from the server. If such functionality is still necessary, consider usingobserveorobserveChangesPR #8754 Issue #1173The
minimongoandmongopackages are now compliant with the upsert behavior of MongoDB 2.6 and higher. As a result support for MongoDB 2.4 has been dropped. This mainly changes the effect of the selector on newly inserted documents. PR #8815reactive-dictnow supports setting initial data when defining a namedReactiveDict. No longer run migration logic when used on the server, this is to prevent duplicate name error on reloads. Initial data is now properly serialized.accounts-passwordnow usesexample.comas a default "from" address instead ofmeteor.com. This change could break account-related e-mail notifications (forgot password, activation, etc.) for applications which do not properly configure a "from" domain since e-mail providers will often reject mail sent fromexample.com. Ensure thatAccounts.emailTemplates.fromis set to a proper domain in all applications. PR #8760The
accounts-facebookandfacebook-oauthpackages have been updated to use the v2.9 of the Facebook Graph API for the Login Dialog since the v2.2 version will be deprecated by Facebook in July. There shouldn't be a problem regardless since Facebook simply rolls over to the next active version (v2.3, in this case) however this should assist in avoiding deprecation warnings and should enable any new functionality which has become available. PR #8858Add
DDP._CurrentPublicationInvocationandDDP._CurrentMethodInvocation.DDP._CurrentInvocationremains for backwards-compatibility. This change allows method calls from publications to inherit theconnectionfrom the the publication which called the method. PR #8629
Note: If you're calling methods from publications that are using
this.connectionto see if the method was called from server code or not. These checks will now be more restrictive becausethis.connectionwill now be available when a method is called from a publication.
Fix issue with publications temporarily having
DDP._CurrentInvocationset on re-run after a user logged in. This is now provided throughDDP._CurrentPublicationInvocationat all times inside a publication, as described above. PR #8031 PR #8629Meteor.userId()andMeteor.user()can now be used in both method calls and publications. PR #8629this.onStopcallbacks in publications are now run with the publication's context and with itsEnvironmentVariables bound. PR #8629The
minifier-jspackage will now replaceprocess.env.NODE_ENVwith its string value (or"development"if unspecified).The
meteor-babelnpm package has been upgraded to version 0.22.0.The
reifynpm package has been upgraded to version 0.11.24.The
uglify-jsnpm package has been upgraded to version 3.0.18.Illegal characters in paths written in build output directories will now be replaced with
_s rather than removed, so that file and directory names consisting of only illegal characters do not become empty strings. PR #8765.Additional "extra" packages (packages that aren't saved in
.meteor/packages) can be included temporarily using the--extra-packagesoption. For example:meteor run --extra-packages bundle-visualizer. Bothmeteor testandmeteor test-packagesalso support the--extra-packagesoption and commas separate multiple package names. PR #8769
Note: Packages specified using the
--extra-packagesoption override version constraints from.meteor/packages.
The
coffeescriptpackage has been updated to use CoffeeScript version 1.12.6. PR #8777It's now possible to pipe a series of statements to
meteor shell, whereas previously the input had to be an expression; for example:
> echo 'import pkg from "babel-runtime/package.json";
quote> pkg.version' |
pipe> meteor shell
"6.23.0"
- Any
Errorthrown by a DDP method with theerror.isClientSafeproperty set totruewill now be serialized and displayed to the client, whereas previously onlyMeteor.Errorobjects were considered client-safe. PR #8756
v1.5, 2017-05-30
The
meteor-basepackage implies a newdynamic-importpackage, which provides runtime support for the proposed ECMAScript dynamicimport(...)syntax, enabling asynchronous module fetching or "code splitting." If your app does not use themeteor-basepackage, you can use the package by simply runningmeteor add dynamic-import. See this blog post and PR #8327 for more information about how dynamicimport(...)works in Meteor, and how to use it in your applications.The
ecmascript-runtimepackage, which provides polyfills for various new ECMAScript runtime APIs and language features, has been split intoecmascript-runtime-clientandecmascript-runtime-server, to reflect the different needs of browsers versus Node 4. The client runtime now relies on thecore-jslibrary found in thenode_modulesdirectory of the application, rather than a private duplicate installed viaNpm.depends. This is unlikely to be a disruptive change for most developers, since thebabel-runtimenpm package is expected to be installed, andcore-jsis a dependency ofbabel-runtime, sonode_modules/core-jsshould already be present. If that's not the case, just runmeteor npm install --save core-jsto install it.The
npmnpm package has been upgraded to version 4.6.1.The
meteor-babelnpm package has been upgraded to version 0.21.4, enabling the latest Reify compiler and the transform-class-properties plugin, among other improvements.The
reifynpm package has been upgraded to version 0.11.21, fixing issue #8595 and improving compilation and runtime performance.
Note: With this version of Reify,
importdeclarations are compiled tomodule.watch(require(id), ...)instead ofmodule.importSync(id, ...)or the oldermodule.import(id, ...). The behavior of the compiled code should be the same as before, but the details seemed different enough to warrant a note.
The
installnpm package has been upgraded to version 0.10.1.The
meteor-promisenpm package has been upgraded to version 0.8.4.The
uglify-jsnpm package has been upgraded to version 3.0.13, fixing #8704.If you're using the
standard-minifier-jsMeteor package, as most Meteor developers do, it will now produce a detailed analysis of package and module sizes within your production.jsbundle whenever you runmeteor buildormeteor run --production. These data are served by the application web server at the same URL as the minified.jsbundle, except with a.stats.jsonfile extension instead of.js. If you're using a different minifier plugin, and would like to support similar functionality, refer to these commits for inspiration.To visualize the bundle size data produced by
standard-minifier-js, runmeteor add bundle-visualizerand then start your development server in production mode withmeteor run --production. Be sure to remove thebundle-visualizerpackage before actually deploying your app, or the visualization will be displayed to your users.If you've been developing an app with multiple versions of Meteor, or testing with beta versions, and you haven't recently run
meteor reset, your.meteor/local/bundler-cachedirectory may have become quite large. This is just a friendly reminder that this directory is perfectly safe to delete, and Meteor will repopulate it with only the most recent cached bundles.Apps created with
meteor create --barenow use thestatic-htmlpackage for processing.htmlfiles instead ofblaze-html-templates, to avoid large unnecessary dependencies like thejquerypackage.Babel plugins now receive file paths without leading
/characters, which should prevent confusion about whether the path should be treated as absolute. PR #8610It is now possible to override the Cordova iOS and/or Android compatibility version by setting the
METEOR_CORDOVA_COMPAT_VERSION_IOSand/orMETEOR_CORDOVA_COMPAT_VERSION_ANDROIDenvironment variables. PR #8581Modules in
node_modulesdirectories will no longer automatically have access to theBufferpolyfill on the client, since that polyfill contributed more than 22KB of minified JavaScript to the client bundle, and was rarely used. If you really need the Buffer API on the client, you should now obtain it explicitly withrequire("buffer").Buffer. Issue #8645.Packages in
node_modulesdirectories are now considered non-portable (and thus may be automatically rebuilt for the current architecture), if theirpackage.jsonfiles contain any of the following install hooks:install,preinstall, orpostinstall. Previously, a package was considered non-portable only if it contained any.nodebinary modules. Issue #8225
v1.4.4.6, 2018-04-02
Node has been upgraded to version 4.9.0, an important security release. The Node v4.x release line will exit the Node.js Foundation's long-term support (LTS) status on April 30,
- We strongly advise updating to a version of Meteor using a newer version of Node which is still under LTS status, such as Meteor 1.6.x which uses Node 8.x.
The
npmpackage has been upgraded to version 4.6.1.
v1.4.4.5, 2017-12-08
- Node has been upgraded to version 4.8.7, an important security release.
v1.4.4.4, 2017-09-26
- Updating to Meteor 1.4.4.4 will automatically patch a security
vulnerability in the
allow-denypackage, sincemeteor-tool@1.4.4_4requiresallow-deny@1.0.9or later. If for any reason you are not ready or able to update to Meteor 1.4.4.4 by runningmeteor update, please at least run
meteor update allow-deny
instead. More details about the security vulnerability can be found on the Meteor forums.
v1.4.4.3, 2017-05-22
Node has been upgraded to version 4.8.3.
A bug in checking body lengths of HTTP responses that was affecting Galaxy deploys has been fixed. PR #8709.
v1.4.4.2, 2017-05-02
Node has been upgraded to version 4.8.2.
The
npmnpm package has been upgraded to version 4.5.0. Note that when using npmscriptsthere has been a change regarding what happens whenSIGINT(Ctrl-C) is received. Read more here.Fix a regression which prevented us from displaying a helpful banner when running
meteor debugbecause of a change in Node.js.Update
node-inspectornpm to 1.1.1, fixing a problem encountered when trying to press "Enter" in the inspector console. Issue #8469The
emailpackage has had itsmailcomposernpm package swapped with a Node 4 fork ofnodemailerdue to its ability to support connection pooling in a similar fashion as the originalmailcomposer. Issue #8591 PR #8605
Note: The
MAIL_URLshould be configured with a scheme which matches the protocol desired by your e-mail vendor/mail-transport agent. For encrypted connections (typically listening on port 465), this means usingsmtps://. Unencrypted connections or those secured through aSTARTTLSconnection upgrade (typically using port 587 and sometimes port 25) should continue to usesmtp://. TLS/SSL will be automatically enabled if the mail provider supports it.
A new
Tracker.inFlush()has been added to provide a global Tracker "flushing" state. PR #8565.The
meteor-babelnpm package has been upgraded to version 0.20.1, and thereifynpm package has been upgraded to version 0.7.4, fixing issue #8595. (This was fixed between full Meteor releases, but is being mentioned here.)
v1.4.4.1, 2017-04-07
- A change in Meteor 1.4.4 to remove "garbage" directories asynchronously
in
files.renameDirAlmostAtomicallyhad unintended consequences for rebuilding some npm packages, so that change was reverted, and those directories are now removed beforefiles.renameDirAlmostAtomicallyreturns. PR #8574
v1.4.4, 2017-04-07
Node has been upgraded to version 4.8.1.
The
npmnpm package has been upgraded to version 4.4.4. It should be noted that this version reduces extra noise previously included in some npm errors.The
node-gypnpm package has been upgraded to 3.6.0 which adds support for VS2017 on Windows.The
node-pre-gypnpm package has been updated to 0.6.34.Thanks to the outstanding efforts of @sethmurphy18, the
minifier-jspackage now uses Babili instead of UglifyJS, resolving numerous long-standing bugs due to UglifyJS's poor support for ES2015+ syntax. Issue #8378 PR #8397The
meteor-babelnpm package has been upgraded to version 0.19.1, andreifyhas been upgraded to version 0.6.6, fixing several subtle bugs introduced by Meteor 1.4.3 (see below), including issue #8461.The Reify module compiler is now a Babel plugin, making it possible for other custom Babel plugins configured in
.babelrcorpackage.jsonfiles to run before Reify, fixing bugs that resulted from running Reify before other plugins in Meteor 1.4.3. Issue #8399 Issue #8422meteor-babelissue #13Two new
export ... from ...syntax extensions are now supported:
export * as namespace from "./module"
export def from "./module"
Read the ECMA262 proposals here: * https://github.com/leebyron/ecmascript-export-ns-from * https://github.com/leebyron/ecmascript-export-default-from
- When
Meteor.callis used on the server to invoke a method that returns aPromiseobject, the result will no longer be thePromiseobject, but the resolved value of thePromise. Issue #8367
Note: if you actually want a
Promisewhen callingMeteor.callorMeteor.applyon the server, useMeteor.callAsyncand/orMeteor.applyAsyncinstead. Issue #8367, https://github.com/meteor/meteor/commit/0cbd25111d1249a61ca7adce23fad5215408c821
The
mailcomposerandsmtp-connectionnpms have been updated to resolve an issue with the encoding of long header lines. Issue #8425 PR #8495Accounts.confignow supports anambiguousErrorMessagesoption which enabled generalization of messages produced by theaccounts-*packages. PR #8520A bug which caused account enrollment tokens to be deleted too soon was fixed. Issue #8218 PR #8474
On Windows, bundles built during
meteor buildormeteor deploywill maintain the executable bit for commands installed in thenode_modules\.bindirectory. PR #8503On Windows, the upgrades to Node.js,
npmandmongodbare now in-sync with other archs again after being mistakenly overlooked in 1.4.3.2. An admin script enhancement has been applied to prevent this from happening again. PR #8505
v1.4.3.2, 2017-03-14
Node has been upgraded to version 4.8.0.
The
npmnpm package has been upgraded to version 4.3.0.The
node-gypnpm package has been upgraded to 3.5.0.The
node-pre-gypnpm package has been updated to 0.6.33.The bundled version of MongoDB used by
meteor runin development has been upgraded to 3.2.12.The
mongodbnpm package used by thenpm-mongoMeteor package has been updated to version 2.2.24. PR #8453 Issue #8449The
checkpackage has had its copy ofjQuery.isPlainObjectupdated to a newer implementation to resolve an issue where thenodeTypeproperty of an object couldn't be checked, fixing #7354.The
standard-minifier-jsandminifier-jspackages now have improved error capturing to provide more information on otherwise unhelpful errors thrown when UglifyJS encounters ECMAScript grammar it is not familiar with. #8414Similar in behavior to
Meteor.loggingIn(),accounts-basenow offers a reactiveMeteor.loggingOut()method (and related Blaze helpers,loggingOutandloggingInOrOut). PR #8271 Issue #1331 Issue #769Using
lengthas a selector field name and with aNumberas a value in aMongo.Collectiontransformation will no longer cause odd results. #8329.observe-sequence(and thus Blaze) now properly supportsArrays which were created in a vm or across frame boundaries, even if they were sub-classed. Issue #8160 PR #8401Minimongo now supports
$bitsAllClear,$bitsAllSet,$bitsAnySetand$bitsAnyClear. #8350A new Development.md document has been created to provide an easier path for developers looking to make contributions to Meteor Core (that is, the
meteortool itself) along with plenty of helpful reminders for those that have already done so! #8267The suggestion to add a
{oauth-service}-config-uipackage will no longer be made on the console ifservice-configurationpackage is already installed. Issue #8366 PR #8429Meteor.apply'sthrowStubExceptionsoption is now properly documented in the documentation whereas it was previously only mentioned in the Guide. Issue #8435 PR #8443DDPRateLimiter.addRulenow accepts a callback which will be executed after a rule is executed, allowing additional actions to be taken if necessary. Issue #5541 PR #8237jqueryis no longer a dependency of thehttppackage. #8389jqueryis no longer in the default package list after runningmeteor create, however is still available thanks toblaze-html-templates. If you still require jQuery, the recommended approach is to install it from npm withmeteor npm install --save jqueryand thenimport-ing it into your application. #8388The
shell-serverpackage (i.e.meteor shell) has been updated to more gracefully handle recoverable errors (such asSyntaxErrors) in the same fashion as the Node REPL. Issue #8290 PR #8446The
webapppackage now reveals aWebApp.connectAppto make it easier to provide custom error middleware. #8403The
meteor update --all-packagescommand has been properly documented in command-line help (i.e.meteor update --help). PR #8431 Issue #8154Syntax errors encountered while scanning
package.jsonfiles for binary dependencies are now safely and silently ignored. Issue #8427 PR #8468
v1.4.3.1, 2017-02-14
The
meteor-babelnpm package has been upgraded to version 0.14.4, fixing #8349.The
reifynpm package has been upgraded to version 0.4.9.Partial
npm-shrinkwrap.jsonfiles are now disregarded when (re)installing npm dependencies of Meteor packages, fixing #8349. Further discussion of the newnpmbehavior can be found here.
v1.4.3, 2017-02-13
- Versions of Meteor core packages are once again constrained by the current Meteor release.
Before Meteor 1.4, the current release dictated the exact version of every installed core package, which meant newer core packages could not be installed without publishing a new Meteor release. In order to support incremental development of core packages, Meteor 1.4 removed all release-based constraints on core package versions (#7084). Now, in Meteor 1.4.3, core package versions must remain patch-compatible with the versions they had when the Meteor release was published. This middle ground restores meaning to Meteor releases, yet still permits patch updates to core packages.
The
cordova-libnpm package has been updated to 6.4.0, along with cordova-android (6.1.1) and cordova-ios (4.3.0), and various plugins. #8239The
coffeescriptMeteor package has been moved frompackages/coffeescripttopackages/non-core/coffeescript, so that it will not be subject to the constraints described above.CoffeeScript source maps should be now be working properly in development. #8298
The individual account "service" packages (
facebook,google,twitter,github,meteor-developer,meetupandweibo) have been split into:<service>-oauth(which interfaces with the<service>directly) and<service>-config-ui(the Blaze configuration templates foraccounts-ui)
This means you can now use
accounts-<service>without needing Blaze.If you are using
accounts-uiandaccounts-<service>, you will probably need to install the<service>-config-uipackage if you want to configure it using the Accounts UI.The
urlandhttppackages now encode to a less error-prone format which more closely resembles that used by PHP, Ruby,jQuery.paramand others.Objects andArrays can now be encoded, however, if you have previously relied onArrays passed asparamsbeing simplyjoin-ed with commas, you may need to adjust yourHTTP.callimplementations. #8261 and #8342.The
npmnpm package is still at version 4.1.2 (as it was when Meteor 1.4.3 was originally published), even thoughnpmwas downgraded to 3.10.9 in Meteor 1.4.2.7.The
meteor-babelnpm package has been upgraded to version 0.14.3, fixing #8021 and #7662.The
reifynpm package has been upgraded to 0.4.7.Added support for frame-ancestors CSP option in browser-policy. #7970
You can now use autoprefixer with stylus files added via packages. #7727
Restored #8213 after those changes were reverted in v1.4.2.5.
npm dependencies of Meteor packages will now be automatically rebuilt if the npm package's
package.jsonfile has "scripts" section containing apreinstall,install, orpostinstallcommand, as well as when the npm package contains any.nodefiles. Discussion here.The
meteor createcommand now runsmeteor npm installautomatically to install dependencies specified in the defaultpackage.jsonfile. #8108
v1.4.2.7, 2017-02-13
- The
npmnpm package has been downgraded from version 4.1.2 back to version 3.10.9, reverting the upgrade in Meteor 1.4.2.4.
v1.4.2.6, 2017-02-08
- Fixed a critical bug
that was introduced by the fix for
Issue #8136, which
caused some npm packages in nested
node_modulesdirectories to be omitted from bundles produced bymeteor buildandmeteor deploy.
v1.4.2.5, 2017-02-03
- Reverted #8213 as the change was deemed too significant for this release.
Note: The decision to revert the above change was made late in the Meteor 1.4.2.4 release process, before it was ever recommended but too late in the process to avoid the additional increment of the version number. See #8311 for additional information. This change will still be released in an upcoming version of Meteor with a more seamless upgrade.
v1.4.2.4, 2017-02-02
Node has been upgraded to version 4.7.3.
The
npmnpm package has been upgraded from version 3.10.9 to 4.1.2.
Note: This change was later deemed too substantial for a point release and was reverted in Meteor 1.4.2.7.
Fix for Issue #8136.
Fix for Issue #8222.
Fix for Issue #7849.
The version of 7-zip included in the Windows dev bundle has been upgraded from 1602 to 1604 in an attempt to mitigate Issue #7688.
The
"main"field ofpackage.jsonmodules will no longer be overwritten with the value of the optional"browser"field, now that theinstallnpm package can make sense of the"browser"field at runtime. If you experience module resolution failures on the client after updating Meteor, make sure you've updated themodules-runtimeMeteor package to at least version 0.7.8. #8213
v1.4.2.3, 2016-11-17
- Style improvements for
meteor create --full. #8045
Note: Meteor 1.4.2.2 was finalized before #8045 was merged, but those changes were deemed important enough to skip recommending 1.4.2.2 and instead immediately release 1.4.2.3.
v1.4.2.2, 2016-11-15
Node has been upgraded to version 4.6.2.
meteor createnow has a new--fulloption, which generates an larger app, demonstrating development techniques highlighted in the Meteor GuideMinimongo now supports
$min,$maxand partially supports$currentDate.Fix for Issue #5676 PR #7968
It is now possible for packages to specify a lazy main module:
Package.onUse(function (api) {
api.mainModule("client.js", "client", { lazy: true });
});
This means the client.js module will not be evaluated during app
startup unless/until another module imports it, and will not even be
included in the client bundle if no importing code is found. Note 1:
packages with lazy main modules cannot use api.export to export global
symbols to other packages/apps. Note 2: packages with lazy main
modules should be restricted to Meteor 1.4.2.2 or later via
api.versionsFrom("1.4.2.2"), since older versions of Meteor cannot
import lazy main modules using import "meteor/<package name>" but must
explicitly name the module: import "meteor/<package name>/client.js".
v1.4.2.1, 2016-11-08
- Installing the
babel-runtimenpm package in your applicationnode_modulesdirectory is now required for most Babel-transformed code to work, as the Meteorbabel-runtimepackage no longer attempts to provide custom implementations of Babel helper functions. To install thebabel-runtimepackage, simply run the command
meteor npm install --save babel-runtime
in any Meteor application directory. The Meteor babel-runtime package
version has been bumped to 1.0.0 to reflect this major change.
#7995
File system operations performed by the command-line tool no longer use fibers unless the
METEOR_DISABLE_FS_FIBERSenvironment variable is explicitly set to a falsy value. For larger apps, this change results in significant build performance improvements due to the creation of fewer fibers and the avoidance of unnecessary asynchronous delays. https://github.com/meteor/meteor/pull/7975/commits/ca4baed90ae0675e55c93976411d4ed91f12dd63Running Meteor as
rootis still discouraged, and results in a fatal error by default, but the--allow-superuserflag now works as claimed. #7959The
dev_bundle\python\python.exeexecutable has been restored to the Windows dev bundle, which may help withmeteor npm rebuildcommands. #7960Changes within linked npm packages now trigger a partial rebuild, whereas previously (in 1.4.2) they were ignored. #7978
Miscellaneous fixed bugs: #2876 #7154 #7956 #7974 #7999 #8005 #8007
v1.4.2, 2016-10-25
- This release implements a number of rebuild performance optimizations.
As you edit files in development, the server should restart and rebuild
much more quickly, especially if you have many
node_modulesfiles. See https://github.com/meteor/meteor/pull/7668 for more details.
Note: the
METEOR_PROFILEenvironment variable now provides data for server startup time as well as build time, which should make it easier to tell which of your packages are responsible for slow startup times. Please include the output ofMETEOR_PROFILE=10 meteor runwith any GitHub issue about rebuild performance.
npmhas been upgraded to version 3.10.9.The
cordova-libnpm package has been updated to 6.3.1, along with cordova-android (5.2.2) and cordova-ios (4.2.1), and various plugins.The
node-pre-gypnpm package has been updated to 0.6.30.The
lru-cachenpm package has been updated to 4.0.1.The
meteor-promisenpm package has been updated to 0.8.0 for better asynchronous stack traces.The
meteortool is now prevented from running asrootas this is not recommended and can cause issues with permissions. In some environments, (e.g. Docker), it may still be desired to run asrootand this can be permitted by passing--unsafe-permto themeteorcommand. #7821Blaze-related packages have been extracted to
meteor/blaze, and the mainmeteor/meteorrepository now refers to them via git submodules (see #7633). When runningmeteorfrom a checkout, you must now update these submodules by running
git submodule update --init --recursive
in the root directory of your meteor checkout.
Accounts.forgotPassword and .verifyEmail no longer throw errors if callback is provided. Issue #5664 Origin PR #5681 Merged PR
The default content security policy (CSP) for Cordova now includes
ws:andwss:WebSocket protocols. #7774meteor npmcommands are now configured to usedev_bundle/.npmas the npm cache directory by default, which should make npm commands less sensitive to non-reproducible factors in the external environment. https://github.com/meteor/meteor/pull/7668/commits/3313180a6ff33ee63602f7592a9506012029e919The
meteor testcommand now supports the--no-release-checkflag. https://github.com/meteor/meteor/pull/7668/commits/7097f78926f331fb9e70a06300ce1711adae2850JavaScript module bundles on the server no longer include transitive
node_modulesdependencies, since those dependencies can be evaluated directly by Node. This optimization should improve server rebuild times for apps and packages with largenode_modulesdirectories. https://github.com/meteor/meteor/pull/7668/commits/03c5346873849151cecc3e00606c6e5aa13b3bbcThe
standard-minifier-csspackage now does basic caching for the expensivemergeCssfunction. https://github.com/meteor/meteor/pull/7668/commits/bfa67337dda1e90610830611fd99dcb1bd44846aThe
coffeescriptpackage now natively supportsimportandexportdeclarations. #7818Due to changes in how Cordova generates version numbers for iOS and Android apps, you may experience issues with apps updating on user devices. To avoid this, consider managing the
buildNumbermanually usingApp.info('buildNumber', 'XXX');inmobile-config.js. There are additional considerations if you have been settingandroid:versionCodeorios-CFBundleVersion. See #7205 and #6978 for more information.
v1.4.1.3, 2016-10-21
Node has been updated to version 4.6.1: https://nodejs.org/en/blog/release/v4.6.1/
The
mongodbnpm package used by thenpm-mongoMeteor package has been updated to version 2.2.11. #7780The
fibersnpm package has been upgraded to version 1.0.15.Running Meteor with a different
--portwill now automatically reconfigure the Mongo replica set when using the WiredTiger storage engine, instead of failing to start Mongo. #7840.When the Meteor development server shuts down, it now attempts to kill the
mongodprocess it spawned, in addition to killing any runningmongodprocesses when the server first starts up. https://github.com/meteor/meteor/pull/7668/commits/295d3d5678228f06ee0ab6c0d60139849a0ea192The
meteor <command> ...syntax will now work for any command installed indev_bundle/bin, except for Meteor's own commands.Incomplete package downloads will now fail (and be retried several times) instead of silently succeeding, which was the cause of the dreaded
Error: ENOENT: no such file or directory, open... os.jsonerror. #7806
v1.4.1.2, 2016-10-04
Node has been upgraded to version 4.6.0, a recommended security release: https://nodejs.org/en/blog/release/v4.6.0/
npmhas been upgraded to version 3.10.8.
v1.4.1.1, 2016-08-24
- Update the version of our Node MongoDB driver to 2.2.8 to fix a bug in
reconnection logic, leading to some
updateandremovecommands being treated asinserts. #7594
v1.4.1, 2016-08-18
Node has been upgraded to 4.5.0.
npmhas been upgraded to 3.10.6.The
meteor publish-for-archcommand is no longer necessary when publishing Meteor packages with binary npm dependencies. Instead, binary dependencies will be rebuilt automatically on the installation side. Meteor package authors are not responsible for failures due to compiler toolchain misconfiguration, and any compilation problems with the underlying npm packages should be taken up with the authors of those packages. That said, if a Meteor package author really needs or wants to continue usingmeteor publish-for-arch, she should publish her package using an older release: e.g.meteor --release 1.4 publish. #7608The
.meteor-last-rebuild-version.jsonfiles that determine if a binary npm package needs to be rebuilt now include more information from theprocessobject, namelyprocess.{platform,arch,versions}instead of justprocess.versions. Note also that the comparison of versions now ignores differences in patch versions, to avoid needless rebuilds.The
npm-bcryptpackage now uses a pure-JavaScript implementation by default, but will prefer the nativebcryptimplementation if it is installed in the application'snode_modulesdirectory. In other words, runmeteor install --save bcryptin your application if you need or want to use the native implementation ofbcrypt. #7595After Meteor packages are downloaded from Atmosphere, they will now be extracted using native
taror7z.exeon Windows, instead of the https://www.npmjs.com/package/tar library, for a significant performance improvement. #7457The npm
tarpackage has been upgraded to 2.2.1, though it is now only used as a fallback after nativetarand/or7z.exe.The progress indicator now distinguishes between downloading, extracting, and loading newly-installed Meteor packages, instead of lumping all of that work into a "downloading" status message.
Background Meteor updates will no longer modify the
~/.meteor/meteorsymbolic link (orAppData\Local\.meteor\meteor.baton Windows). Instead, developers must explicitly typemeteor updateto begin using a new version of themeteorscript.Password Reset tokens now expire (after 3 days by default -- can be modified via
Accounts.config({ passwordResetTokenExpirationInDays: ...}). PR #7534The
googlepackage now uses theemailscope as a mandatory field instead of theprofilescope. Theprofilescope is still added by default if therequestPermissionsoption is not specified to maintain backward compatibility, but it is now possible to pass an empty array torequestPermissionsin order to only request theemailscope, which reduces the amount of permissions requested from the user in the Google popup. PR #6975Added
Facebook.handleAuthFromAccessTokenin the case where you get the FB accessToken in some out-of-band way. PR #7550Accounts.onLogoutgets{ user, connection }context in a similar fashion toAccounts.onLogin. Issue #7397 PR #7433The
node-gypandnode-pre-gyptools will now be installed inbundle/programs/server/node_modules, to assist with rebuilding binary npm packages when deploying an app to Galaxy or elsewhere. #7571The
standard-minifier-{js,css}packages no longer minify .js or .css files on the server. #7572Multi-line input to
meteor shell, which was broken by changes to thereplmodule in Node 4, works again. #7562The implementation of the command-line
meteortool now forbids misbehaving polyfill libraries from overwritingglobal.Promise. #7569The
oauth-encryptionpackage no longer depends on thenpm-node-aes-gcmpackage (or any special npm packages), because the Node 4cryptolibrary natively supports theaes-128-gcmalgorithm. #7548The server-side component of the
meteor shellcommand has been moved into a Meteor package, so that it can be developed independently from the Meteor release process, thanks to version unpinning. #7624The
meteor shellcommand now works when runningmeteor test.The
meteor debugcommand no longer pauses at the first statement in the Node process, yet still reliably stops at custom breakpoints it encounters later.The
meteor-babelpackage has been upgraded to 0.12.0.The
meteor-ecmascript-runtimepackage has been upgraded to 0.2.9, to support several additional stage 4 proposals.A bug that prevented @-scoped npm packages from getting bundled for deployed apps has been fixed. #7609.
The
meteor updatecommand now supports an--all-packagesflag to update all packages (including indirect dependencies) to their latest compatible versions, similar to passing the names of all your packages to themeteor updatecommand. #7653Background release updates can now be disabled by invoking either
meteor --no-release-checkorMETEOR_NO_RELEASE_CHECK=1 meteor. #7445
v1.4.0.1, 2016-07-29
Fix issue with the 1.4 tool springboarding to older releases (see Issue #7491)
Fix issue with running in development on Linux 32bit Issue #7511
v1.4, 2016-07-25
Node has been upgraded to 4.4.7.
The
meteor-babelnpm package has been upgraded to 0.11.7.The
reifynpm package has been upgraded to 0.3.6.The
bcryptnpm package has been upgraded to 0.8.7.Nested
importdeclarations are now enabled for package code as well as application code. 699cf1f38e9b2a074169515d23983f74148c7223Meteor has been upgraded to support Mongo 3.2 by default (the bundled version used by
meteor runhas been upgraded). Internally it now uses the 2.2.4 version of themongodbnpm driver, and has been tested against at Mongo 3.2 server. Issue #6957Mongo 3.2 defaults to the new WiredTiger storage engine. You can update your database following the instructions here: https://docs.mongodb.com/v3.0/release-notes/3.0-upgrade/. In development, you can also just use
meteor resetto remove your old database, and Meteor will create a new WiredTiger database for you. The Mongo driver will continue to work with the old MMAPv1 storage engine however.The new version of the Mongo driver has been tested with MongoDB versions from 2.6 up. Mongo 2.4 has now reached end-of-life (https://www.mongodb.com/support-policy), and is no longer supported.
If you are setting
MONGO_OPLOG_URL, especially in production, ensure you are passing in thereplicaSetargument (see [#7450] (https://github.com/meteor/meteor/issues/7450))Custom Mongo options can now be specified using the
Mongo.setConnectionOptions(options)API. #7277On the server, cursor.count() now takes a single argument
applySkipLimit(see the corresponding [Mongo documentation] (http://mongodb.github.io/node-mongodb-native/2.1/api/Cursor.html#count))Fix for regression caused by #5837 which incorrectly rewrote network-path references (e.g.
//domain.com/image.gif) in CSS URLs. #7416Added Angular2 boilerplate example #7364
v1.3.5.1, 2016-07-18
- This release fixed a small bug in 1.3.5 that prevented updating apps
whose
.meteor/releasefiles refer to releases no longer installed in~/.meteor/packages/meteor-tool. 576468eae8d8dd7c1fe2fa381ac51dee5cb792cd
v1.3.5, 2016-07-16
Failed Meteor package downloads are now automatically resumed from the point of failure, up to ten times, with a five-second delay between attempts. #7399
If an app has no
package.jsonfile, all packages innode_moduleswill be built into the production bundle. In other words, make sure you have apackage.jsonfile if you want to benefit fromdevDependenciespruning. 7b2193188fc9e297eefc841ce6035825164f0684Binary npm dependencies of compiler plugins are now automatically rebuilt when Node/V8 versions change. #7297
Because
.meteor/localis where purely local information should be stored, the.meteor/dev_bundlelink has been renamed to.meteor/local/dev_bundle.The
.meteor/local/dev_bundlelink now corresponds exactly to.meteor/releaseeven when an app is using an older version of Meteor. d732c2e649794f350238d515153f7fb71969c526When recompiling binary npm packages, the
npm rebuildcommand now receives the flags--update-binaryand--no-bin-links, in addition to respecting the$METEOR_NPM_REBUILD_FLAGSenvironment variable. #7401The last solution found by the package version constraint solver is now stored in
.meteor/local/resolver-result-cache.jsonso that it need not be recomputed every time Meteor starts up.If the
$GYP_MSVS_VERSIONenvironment variable is not explicitly provided tometeor {node,npm}, thenode-gyptool will infer the appropriate version (though it still defaults to "2015").
v1.3.4.4, 2016-07-10
Fixed #7374.
The default loglevel for internal
npmcommands (e.g., those related toNpm.depends) has been set to "error" instead of "warn". Note that this change does not affectmeteor npm ...commands, which can be easily configured using.npmrcfiles or command-line flags. 0689cae25a3e0da3615a402cdd0bec94ce8455c8
v1.3.4.3, 2016-07-08
Node has been upgraded to 0.10.46.
npmhas been upgraded to 3.10.5.The
node-gypnpm package has been upgraded to 3.4.0.The
node-pre-gypnpm package has been upgraded to 0.6.29.The
~/.meteor/meteorsymlink (orAppData\Local\.meteor\meteor.baton Windows) will now be updated properly aftermeteor updatesucceeds. This was promised in v1.3.4.2 but not fully delivered.The
.meteor/dev_bundlesymbolic link introduced in v1.3.4.2 is now updated whenever.meteor/releaseis read.The
.meteor/dev_bundlesymbolic link is now ignored by.meteor/.gitignore.
v1.3.4.2, 2016-07-07
The
meteor nodeandmeteor npmcommands now respect.meteor/releasewhen resolving which versions ofnodeandnpmto invoke. Note that you mustmeteor updateto 1.3.4.2 before this logic will take effect, but it will work in all app directories after updating, even those pinned to older versions. #7338The Meteor installer now has the ability to resume downloads, so installing Meteor on a spotty internet connection should be more reliable. #7348
When running
meteor test, shared directories are symlinked (or junction-linked on Windows) into the temporary test directory, not copied, leading to much faster test start times after the initial build. The directories:.meteor/local/{bundler-cache,isopacks,plugin-cache}App.appendToConfigallows adding custom tags to config.xml. #7307When using
ROOT_URLwith a path, relative CSS URLs are rewritten accordingly. #5837
v1.3.4.1, 2016-06-23
Increased the default HTTP timeout for requests made by the
meteorcommand-line tool to 60 seconds (previously 30), and disabled the timeout completely for Galaxy deploys.
v1.3.4, 2016-06-22
The version of
npmused bymeteor npmand when installingNpm.dependsdependencies of Meteor packages has been upgraded from 2.15.1 to 3.9.6, which should lead to much flatter node_modules dependency trees.The
meteor-babelnpm package has been upgraded to 0.11.6, and is now installed usingnpm@3.9.6, fixing bugs arising from Windows path limits, such as #7247.The
reifynpm package has been upgraded to 0.3.4, fixing #7250.Thanks to caching improvements for the
files.{stat,lstat,readdir,realpath}methods andPackageSource#_findSources, development server restart times are no longer proportional to the number of files innode_modulesdirectories. #7253 #7008When installed via
InstallMeteor.exeon Windows, Meteor can now be easily uninstalled through the "Programs and Features" control panel.HTTP requests made by the
meteorcommand-line tool now have a timeout of 30 seconds, which can be adjusted by the$TIMEOUT_SCALE_FACTORenvironment variable. #7143The
requestnpm dependency of thehttppackage has been upgraded from 2.53.0 to 2.72.0.The
--headlessoption is now supported bymeteor testandmeteor test-packages, in addition tometeor self-test. #7245
v1.3.3.1, 2016-06-17
The
node-aes-gcmnpm package used byoauth-encryptionhas been upgraded to 0.1.5. #7217The
reifymodule compiler has been upgraded to 0.3.3.The
meteor-babelpackage has been upgraded to 0.11.4.The
pathwatchernpm package has been upgraded to 6.7.0.In CoffeeScript files with raw JavaScript enclosed by backticks, the compiled JS will no longer contain
requirecalls inserted by Babel. #7226Code related to the Velocity testing system has been removed. #7235
Allow smtps:// in MAIL_URL #7043
Adds
Accounts.onLogout()a hook directly analogous toAccounts.onLogin(). PR #6889
v1.3.3, 2016-06-10
Node has been upgraded from 0.10.43 to 0.10.45.
npmhas been upgraded from 2.14.22 to 2.15.1.The
fiberspackage has been upgraded to 1.0.13.The
meteor-babelpackage has been upgraded to 0.10.9.The
meteor-promisepackage has been upgraded to 0.7.1, a breaking change for code that usesPromise.denodeify,Promise.nodeify,Function.prototype.async, orFunction.prototype.asyncApply, since those APIs have been removed.Meteor packages with binary npm dependencies are now automatically rebuilt using
npm rebuildwhenever the version of Node or V8 changes, making it much simpler to use Meteor with different versions of Node. 5dc51d39ecc9e8e342884f3b4f8a489f734b4352*.min.jsfiles are no longer minified during the build process. PR #6986 Issue #5363You can now pick where the
.meteor/localdirectory is created by setting theMETEOR_LOCAL_DIRenvironment variable. This lets you run multiple instances of the same Meteor app. PR #6760 Issue #6532Allow using authType in Facebook login PR #5694
Adds flush() method to Tracker to force recomputation PR #4710
Adds
defineMutationMethodsoption (default: true) tonew Mongo.Collectionto override default behavior that sets up mutation methods (/collection/[insert|update…]) PR #5778Allow overriding the default warehouse url by specifying
METEOR_WAREHOUSE_URLBASEPR #7054Allow
_idin$setOnInsertin Minimongo: https://github.com/meteor/meteor/pull/7066Added support for
$eqto Minimongo: https://github.com/meteor/meteor/pull/4235Insert a
Dateheader into emails by default: https://github.com/meteor/meteor/pull/6916/filesmeteor testnow supports setting the bind address using--port IP:PORTthe same asmeteor runPR #6964 Issue #6961Meteor.applynow takes anoRetryoption to opt-out of automatically retrying non-idempotent methods on connection blips: PR #6180DDP callbacks are now batched on the client side. This means that after a DDP message arrives, the local DDP client will batch changes for a minimum of 5ms (configurable via
bufferedWritesInterval) and a maximum of 500ms (configurable viabufferedWritesMaxAge) before calling any callbacks (such as cursor observe callbacks).PhantomJS is no longer included in the Meteor dev bundle (#6905). If you previously relied on PhantomJS for local testing, the
spiderablepackage, Velocity tests, or testing Meteor from a checkout, you should now install PhantomJS yourself, by running the following command:meteor npm install -g phantomjs-prebuiltThe
babel-compilerpackage now looks for.babelrcfiles andpackage.jsonfiles with a "babel" section. If found, these files may contribute additional Babel transforms that run before the usualbabel-preset-meteorset of transforms. In other words, if you don't like the waybabel-preset-meteorhandles a particular kind of syntax, you can add your preferred transform plugins to the "presets" or "plugins" section of your.babelrcorpackage.jsonfile. #6351When
BabelCompilercannot resolve a Babel plugin or preset package in.babelrcorpackage.json, it now merely warns instead of crashing. #7179Compiler plugins can now import npm packages that are visible to their input files using
inputFile.require(id). b16e8d50194b37d3511889b316345f31d689b020importstatements in application modules now declare normal variables for the symbols that are imported, making it significantly easier to inspect imported variables when debugging in the browser console or inmeteor shell.importstatements in application modules are no longer restricted to the top level, and may now appear inside conditional statements (e.g.if (Meteor.isServer) { import ... }) or in nested scopes.importstatements now work as expected inmeteor shell. #6271Commands installed in
dev_bundle/lib/node_modules/.bin(such asnode-gypandnode-pre-gyp) are now available to scripts run bymeteor npm. e95dfe410e1b43e8131bc2df9d2c29decdd1eaf6When building an application using
meteor build, "devDependencies" listed inpackage.jsonare no longer copied into the bundle. #6750Packages tested with
meteor test-packagesnow have access to localnode_modulesdirectories installed in the parent application or in the package directory itself. #6827You no longer need to specify
DEPLOY_HOSTNAME=galaxy.meteor.comto runmeteor deploy(and similar commands) against Galaxy. The AWS us-east-1 Galaxy is now the default forDEPLOY_HOSTNAME. If your app's DNS points to another Galaxy region,meteor deploywill detect that automatically as well. #7055The
coffeescriptplugin now passes raw JavaScript code enclosed by back-ticks toBabelCompiler, enabling all ECMAScript features (includingimportandexport) within CoffeeScript. #6000 #6691The
coffeescriptpackage now implies the same runtime environment asecmascript(ecmascript-runtime,babel-runtime, andpromise, but notmodules). #7184When Meteor packages install
npmdependencies, theprocess.env.NPM_CONFIG_REGISTRYenvironment variable is now respected. #7162files.renamenow always executes synchronously. 9856d1d418a4d19c0adf22ec9a92f7ce81a23b05"Bare" files contained by
client/compatibility/directories or added withapi.addFiles(path, ..., { bare: true })are no longer compiled by Babel. https://github.com/meteor/meteor/pull/7033#issuecomment-225126778Miscellaneous fixed bugs: #6877 #6843 #6881
v1.3.2.4, 2016-04-20
Meteor 1.3.2.4 was published because publishing 1.3.2.3 failed in an unrecoverable way. Meteor 1.3.2.4 contains no additional changes beyond the changes in 1.3.2.3.
v1.3.2.3, 2016-04-20
- Reverted accidental changes included in 1.3.2.1 and 1.3.2.2 that improved DDP performance by batching updates, but broke some packages that relied on private methods of the DDP client Connection class. See https://github.com/meteor/meteor/pull/5680 for more details. These changes will be reinstated in 1.3.3.
v1.3.2.2, 2016-04-18
- Fixed bugs #6819 and #6831.
v1.3.2.1, 2016-04-15
- Fixed faulty comparison of
.sourcePathand.targetPathproperties of files scanned by theImportScanner, which caused problems for apps using thetap:i18npackage. 6e792a7cf25847b8cd5d5664a0ff45c9fffd9e57
v1.3.2, 2016-04-15
The
meteor/meteorrepository now includes aRoadmap.mdfile: https://github.com/meteor/meteor/blob/devel/Roadmap.mdRunning
npm installinbundle/programs/serverwhen deploying an app also rebuilds any binary npm dependencies, fixing #6537. Set METEORSKIPNPM_REBUILD=1 to disable this behavior if necessary.Non-.js(on) files in
node_modules(such as.lessand.scss) are now processed by compiler plugins and may be imported by JS. #6037The
jquerypackage can now be completely removed from any app (#6563), and uses<app>/node_modules/jqueryif available (#6626).Source maps are once again generated for all bundled JS files, even if they are merely identity mappings, so that the files appear distinct in the browser, and stack traces make more sense. #6639
All application files in
importsdirectories are now considered lazy, regardless of whether the app is using themodulespackage. This could be a breaking change for 1.3.2 apps that do not usemodulesorecmascriptbut containimportsdirectories. Workaround: move files out ofimports, or renameimportsto something else.The
npm-bcryptpackage has been upgraded to use the latest version (0.8.5) of thebcryptnpm package.Compiler plugins can call
addJavaScript({ path })multiple times with different paths for the same source file, andmodule.idwill reflect thispathinstead of the source path, if they are different. #6806Fixed bugs: https://github.com/meteor/meteor/milestones/Release%201.3.2
Fixed unintended change to
Match.Optionalwhich caused it to behave the same as the newMatch.Maybeand incorrectly matchingnullwhere it previously would not have allowed it. #6735
v1.3.1, 2016-04-03
Long isopacket node_modules paths have been shortened, fixing upgrade problems on Windows. #6609
Version 1.3.1 of Meteor can now publish packages for earlier versions of Meteor, provided those packages do not rely on modules. #6484 #6618
The meteor-babel npm package used by babel-compiler has been upgraded to version 0.8.4. c8d12aed4e725217efbe86fa35de5d5e56d73c83
The
meteor nodeandmeteor npmcommands now return the same exit codes as their child processes. #6673 #6675Missing module warnings are no longer printed for Meteor packages, or for
requirecalls whenrequireis not a free variable, fixing https://github.com/practicalmeteor/meteor-mocha/issues/19.Cordova iOS builds are no longer built by Meteor, but merely prepared for building. 88d43a0f16a484a5716050cb7de8066b126c7b28
Compiler plugin errors were formerly silenced for files not explicitly added in package.js. Now those errors are reported when/if the files are imported by the ImportScanner. be986fd70926c9dd8eff6d8866205f236c8562c4
v1.3, 2016-03-27
ES2015/Modules
Enable ES2015 and CommonJS modules in Meteor apps and packages, on both client and server. Also let you install modules in apps and package by running
npm install. See: https://github.com/meteor/meteor/blob/master/packages/modules/README.mdEnable ES2015 generators and ES2016 async/await in the
ecmascriptpackage.Inherit static getters and setters in subclasses, when using the
ecmascriptpackage. #5624Report full file paths on compiler errors when using the
ecmascriptpackage. #5551Now possible to
importorrequirefiles with a.jsonfile extension. #5810process.env.NODE_ENVis now defined on both client and server as eitherdevelopmentorproduction, which also determines the boolean flagsMeteor.isDevelopmentandMeteor.isProduction.Absolute identifiers for app modules no longer have the
/app/prefix, and absolute identifiers for Meteor packages now have the prefix/node_modules/meteor/instead of just/node_modules/, meaning you shouldimport {Blaze} from "meteor/blaze"instead offrom "blaze".Package variables imported by application code are once again exposed globally, allowing them to be accessed from the browser console or from
meteor shell. #5868Fixed global variable assignment analysis during linking. #5870 #5819
Changes to files in node_modules will now trigger a restart of the development server, just like any other file changes. #5815
The meteor package now exports a
globalvariable (a la Node) that provides a reliable reference to the global object for all Meteor code.Packages in local node_modules directories now take precedence over Meteor packages of the same name. #5933
Upgraded
babel-compilerto Babel 6, with the following set of plugins: https://github.com/meteor/babel-preset-meteor/blob/master/index.jsLazy CSS modules may now be imported by JS: 12c946ee651a93725f243f790c7919de3d445a19
Packages in the top-level node_modules directory of an app can now be imported by Meteor packages: c631d3ac35f5ca418b93c454f521989855b8ec72
Added support for wildcard import and export statements. #5872 #5897
Client-side stubs for built-in Node modules are now provided automatically if the
meteor-node-stubsnpm package is installed. #6056Imported file extensions are now optional for file types handled by compiler plugins. #6151
Upgraded Babel packages to ~6.5.0: 292824da3f8449afd1cd39fcd71acd415c809c0f Note: .babelrc files are now ignored (#6016), but may be reenabled (#6351).
Polyfills now provided for
process.nextTickandprocess.platform. #6167 #6198 #6055 efe53de492da6df785f1cbef2799d1d2b492a939The
meteor test-appcommand is nowmeteor test [--full-app]: ab5ab15768136d55c76d51072e746d80b45ec181New apps now include a
package.jsonfile. c51b8cf7ffd8e7c9ca93768a2df93e4b552c199crequire.resolveis now supported. https://github.com/benjamn/install/commit/ff6b25d6b5511d8a92930da41db73b93eb1d6cf8JSX now enabled in
.jsfiles processed by theecmascriptcompiler plugin. #6151On the server, modules contained within
node_modulesdirectories are now loaded using the native Noderequirefunction. #6398All
<script>tag(s) for application and package code now appear at the end of the<body>rather than in the<head>. #6375The client-side version of
process.env.NODE_ENV(and other environment variables) now matches the corresponding server-side values. #6399
Performance
Don't reload package catalog from disk on rebuilds unless package dependencies changed. #5747
Improve minimongo performance on updating documents when there are many active observes. #5627
Platform
Upgrade to Node v0.10.41.
Allow all types of URLs that npm supports in
Npm.dependsdeclarations.Split up
standard-minifiersin separate CSS (standard-minifiers-css) and JS minifiers (standard-minifiers-js).standard-minifiersnow acts as an umbrella package for these 2 minifiers.Allow piping commands to
meteor shellvia STDIN. #5575Let users set the CAFILE environment variable to override the SSL root certificate list. #4757 #5523
force-sslis now marked production only.
Cordova
Cordova dependencies have been upgraded to the latest versions (
cordova-lib6.0.0,cordova-ios4.0.1, andcordova-android5.1.0).iOS apps now require iOS 8 or higher, and building for iOS requires Xcode 7.2 to be installed.
Building for Android now requires Android SDK 23 to be installed. You may also need to create a new AVD for the emulator.
Building Cordova Android apps on Windows is now supported. #4155
The Crosswalk plugin has been updated to 1.4.0.
Cordova core plugins are now pinned to minimal versions known to be compatible with the included platforms. A warning is printed asking people to upgrade their dependencies if they specify an older version, but we'll always use the pinned version regardless.
The plugin used for file serving and hot code push has been completely rewritten. Among many other improvements, it downloads updates incrementally, can recover from downloading faulty JavaScript code, and is much more reliable and performant. See
cordova-plugin-meteor-webappfor more a more detailed description of the new design.If the callbacks added with
Meteor.startup()do not complete within a set time, we consider a downloaded version faulty and will fallback to the last known good version. The default timeout is 20 seconds, but this can be configured by settingApp.setPreference("WebAppStartupTimeout", "10000");(in milliseconds) inmobile-config.js.We now use
WKWebViewon iOS by default, even on iOS 8 (which works because we do not usefile://URLs).We now use
localhostinstead ofmeteor.localto serve files from. Sincelocalhostis considered a secure origin, this means the web view won't disable web platform features that it otherwise would.The local server port now lies between 12000-13000 and is chosen based on the
appId, to both be consistent and lessen the chance of collisions between multiple Meteor Cordova apps installed on the same device.The plugin now allows for local file access on both iOS and Android, using a special URL prefix (
http://localhost:<port>/local-filesystem/<path>).App icon and launch image sizes have been updated. Low resolution sizes for now unsupported devices have been deprecated, and higher resolution versions have been added.
We now support the modern Cordova whitelist mechanism.
App.accessRulehas been updated with new options.meteor buildnow supports a--server-onlyoption to avoid building the mobile apps wheniosorandroidplatforms have been added. It still builds theweb.cordovaarchitecture in the server bundle however, so it can be served for hot code pushes.meteor runnow always tries to use an autodetected IP address as the mobileROOT_URL, even if we're not running on a device. This avoids a situation where an app already installed on a device connects to a restarted development server and receives alocalhostROOT_URL. #5973Fixed a discrepancy between the way we calculated client hashes during a mobile build and on the server, which meant a Cordova app would always download a new version the first time it started up.
In Cordova apps,
Meteor.startup()now correctly waits for the device to be ready before firing the callback.
Accounts
- Make
Accounts.forgotPasswordtreat emails as case insensitive, as the rest of the accounts system does.
Blaze
Don't throw in certain cases when calling a template helper with an empty data context. #5411 #5736
Improve automatic blocking of URLs in attribute values to also include
vbscript:URLs.
Check
- Introduced new matcher
Match.Maybe(type)which will also match (permit)nullin addition toundefined. This is a suggested replacement (where appropriate) forMatch.Optionalwhich did not permitnull. This prevents the need to useMatch.OneOf(null, undefined, type). #6220
Testing
- Packages can now be marked as
testOnlyto only run as part of app testing withmeteor test. This is achieved by settingtestOnly: truetoPackage.describe.
Uncategorized
Remove warning in the
simple-todos-reactexample app. #5716Fix interaction between
browser-policyandoauthpackages. #5628Add README.md to the
tinytestpackage. #5750Don't crash when calling
ReactiveDict.prototype.clearif a property with a value wasn't previously accessed. #5530 #5602Move
DDPRateLimiterto the server only, since it won't work if it is called from the client. It will now error if referenced from the client at all.Don't call function more than once when passing a
Match.Whereargument tocheck. #5630 #5651Fix empty object argument check in
this.subscribein templates. #5620Make
HTTP.callnot crash on undefined content. #5565 #5601Return observe handle from
Mongo.Collection.prototype._publishCursor. #4983 #5615Add 'Did you mean?' reminders for some CLI commands to help Rails developers. #5593
Make internal shell scripts compatible with other Unix-like systems. #5585
Add a
_pollingIntervaloption tocoll.find()that can be used in conjunction with_disableOplog: true. #5586Expose Tinytest internals which can be used to extend it. #3541
Improve error message from
checkwhen passing in null. #5545Split up
standard-minifiersin separate CSS (standard-minifier-css) and JS minifiers(standard-minifier-js).standard-minifiersnow acts as an umbrella package for these 2 minifiers.Detect new Facebook user-agent in the
spiderablepackage. #5516Match.ObjectIncludingnow really requires plain objects. #6140Allow
git+URL schemes for npm dependencies. #844Expose options
disableOplog,pollingIntervalMs, andpollingThrottleMstoCursor.findfor tuning observe parameters on the server.Expose
dynamicHeadanddynamicBodyhooks in boilerplate generation allowing code to inject content into the body and head tags from the server. #3860Add methods of the form
BrowserPolicy.content.allow<ContentType>BlobUrl()to BrowserPolicy #5141Move
<script>tags to end of<body>to enable 'loading' UI to be inserted into the boilerplate #6375Adds WebAppInternals.setBundledJsCssUrlRewriteHook allowing apps to supply a hook function that can create a dynamic bundledJsCssPrefix at runtime. This is useful if you're using a CDN by giving you a way to ensure the CDN won't cache broken js/css resources during an app upgrade.
Patches contributed by GitHub users vereed, mitar, nathan-muir, robfallows, skishore, okland, Primigenus, zimme, welelay, rgoomar, bySabi, mbrookes, TomFreudenberg, TechPlexEngineer, zacharydenton, AlexeyMK, gwendall, dandv, devgrok, brianlukoff.
v.1.2.1, 2015-10-26
coll.insert()now uses a faster (but cryptographically insecure) algorithm to generate document IDs when called outside of a method and an_idfield is not explicitly passed. With this change, there are no longer two algorithms used to generate document IDs.Random.id()can still be used to generate cryptographically secure document IDs. #5161The
ecmascript-collectionspackage has been renamed toecmascript-runtimeand now includes a more complete selection of ES2015 polyfills and shims fromcore-js. The complete list can be found here.Check type of
onExceptionargument tobindEnvironment. #5271WebApp's
PORTenvironment variable can now be a named pipe to better support deployment on IIS on Windows. 4413Template.dynamiccan be now used as a block helper:{{#Template.dynamic}} ... {{/Template.dynamic}}#4756Collection#allow/denynow throw errors when passed falsy values. #5442source-maphas been updated to a newer patch version, which fixes major bugs in particular around loading bundles generated by Webpack. #5411checknow returns instead of throwing errors internally, which should make it much faster.checkis used in many core Meteor packages, so this should result in small performance improvements across the framework. #4584The
userEmailoption toMeteor.loginWithMeteorDeveloperAccounthas been renamed tologinHint, and now supports Google accounts as well. The old option still works for backwards compatibility. #2422 #5313The old
addFilesAPI for adding package assets no longer throws an error, making it easier to share packages between pre- and post-1.2 versions of Meteor. #5458Normally, you can't deploy to free meteor.com hosting or Galaxy from a non-Linux machine if you have local non-published packages with binary dependencies, nor can you run
meteor build --architecture SomeOtherArch. As a temporary workaround, if you set theMETEOR_BINARY_DEP_WORKAROUNDvariable, you will be able to deploy to Galaxy (but not free meteor.com hosting), and tarballs built withmeteor buildwill contain aprograms/server/setup.shshell script which should be run on the server to install those packages.
v1.2.0.2, 2015-09-28
Update Crosswalk plugin for Cordova to 1.3.1. #5267
Fix
meteor addfor a Cordova plugin using a Git URL with SHA.Upgraded the
promisepackage to usemeteor-promise@0.5.0, which uses the globalPromiseconstructor in browsers that define it natively.Fix error in assigning attributes to
<body>tag when using Blaze templates orstatic-html. #5232
v1.2.0.1, 2015-09-22
- Fix incorrect publishing of packages with exports but no source. #5228
v1.2, 2015-09-21
There are quite a lot of changes in Meteor 1.2. See the Wiki for a shorter list of breaking changes you should be aware of when upgrading.
Core Packages
meteor-platformhas been deprecated in favor of the smallermeteor-base, with apps listing their other dependencies explicitly. The v1.2 upgrader will rewritemeteor-platformin existing apps.meteor-baseputs fewer symbols in the global namespace, so it's no longer true that all apps have symbols likeRandomandEJSONin the global namespace.New packages:
ecmascript,es5-shim,ecmascript-collections,promise,static-html,jshint,babel-compilerNo longer include the
jsonpackage by default, which contains code forJSON.parseandJSON.stringify. (The last browser to not support JSON natively was Internet Explorer 7.)autoupdatehas been renamedhot-code-push
Meteor Accounts
Login attempts are now rate-limited by default. This can be turned off using
Accounts.removeDefaultRateLimit().loginWithPasswordnow matches username or email in a case insensitive manner. If there are multiple users with a username or email only differing in case, a case sensitive match is required. #550loginWithGithubnow requestsuser:emailscope by default, and attempts to fetch the user's emails. If no public email has been set, we use the primary email instead. We also store the complete list of emails. #4545When an account's email address is verified, deactivate other verification tokens. #4626
Fix bug where blank page is shown when an expired login token is present. #4825
Fix
OAuth1Binding.prototype.callwhen making requests to Twitter with a large parameter set.Directions for setting up Google OAuth in accounts-ui have been updated to match Google's new requirements.
Add
Accounts.oauth.unregisterServicemethod, and ensure that users can only log in with currently registered services. #4014The
accounts-basenow defines reusableAccountsClientandAccountsServerconstructors, so that users can create multiple independent instances of theAccountsnamespace. #4233Create an index for
Meteor.usersonservices.email.verificationTokens.token(instead ofemails.validationTokens.token, which never was used for anything). #4482Remove an IE7-specific workaround from accounts-ui. #4485
Livequery
- Improved server performance by reducing overhead of processing oplog after database writes. Improvements are most noticeable in case when a method is doing a lot of writes on collections with plenty of active observers. #4694
Mobile
The included Cordova tools have been updated to the latest version 5.2.0. This includes Cordova Android 4.1 and Cordova iOS 3.9. These updates may require you to make changes to your app. For details, see the Cordova release notes for for the different versions.
Thanks to Cordova Android's support for pluggable web views, it is now possible to install the [Crosswalk plugin] (https://crosswalk-project.org/documentation/cordova/cordova_4.html), which offers a hugely improved web view on older Android versions. You can add the plugin to your app with
meteor add crosswalk.The bundled Android tools have been removed and a system-wide install of the Android SDK is now required. This should make it easier to keep the development toolchain up to date and helps avoid some difficult to diagnose failures. If you don't have your own Android tools installed already, you can find more information about installing the Android SDK for Mac or [Linux] (https://github.com/meteor/meteor/wiki/Mobile-Dev-Install:-Android-on-Linux).
As part of moving to npm, many Cordova plugins have been renamed. Meteor should perform conversions automatically, but you may want to be aware of this to avoid surprises. See [here] (https://cordova.apache.org/announcements/2015/04/21/plugins-release-and-move-to-npm.html) for more information.
Installing plugins from the local filesystem is now supported using
file://URLs, which should make developing your own plugins more convenient. It is also needed as a temporary workaround for using the Facebook plugin. Relative references are interpreted relative to the Meteor project directory. (As an example,meteor add cordova:phonegap-facebook-plugin@file://../phonegap-facebook-pluginwould attempt to install the plugin from the same directory you Meteor project directory is located in.)Meteor no longer supports installing Cordova plugins from tarball URLs, but does support Git URLs with a SHA reference (like
https://github.com/apache/cordova-plugin-file#c452f1a67f41cb1165c92555f0e721fbb07329cc). Existing GitHub tarball URLs are converted automatically.Allow specifying a
buildNumberinApp.info, which is used to set theandroid-versionCodeandios-CFBundleVersionin theconfig.xmlof the Cordova project. The build number is used to differentiate between different versions of the app, and should be incremented before distributing a built app to stores or testing services. #4048Other changes include performance enhancements when building and running, and improved requirements checking and error reporting.
Known issue: we do not currently show logging output when running on the iOS Simulator. As a workaround, you can
meteor run ios-deviceto open the project in Xcode and watch the output there.
Templates/Blaze
New syntax: Handlebars sub-expressions are now supported -- as in,
{{helper (anotherHelper arg1 arg2)}}-- as well as new block helper forms#each .. in ..and#let x=y. See https://github.com/meteor/meteor/tree/devel/packages/spacebarsAdd a special case for the new
react-template-helperpackage -- don't let templates use {{> React}} with siblings sinceReact.renderassumes it's being rendered into an empty container element. (This lets us throw the error when compiling templates rather than when the app runs.)Improve parsing of
<script>and<style>tags. #3797Fix a bug in
observe-sequence. The bug was causing unnecessary rerenderings in an instance of#eachblock helper followed by false "duplicate ids" warnings. #4049TemplateInstance#subscribenow has a newconnectionoption, which specifies which connection should be used when making the subscription. The default isMeteor.connection, which is the connection used when callingMeteor.subscribe.Fix external
<script>tags in body or templates. #4415Fix memory leak. #4289
Avoid recursion when materializing DOM elements, to avoid stack overflow errors in certain browsers. #3028
Blaze and Meteor's built-in templating are now removable using
meteor remove blaze-html-templates. You can add back support for staticheadandbodytags in.htmlfiles by using thestatic-htmlpackage.
DDP
Websockets now support the
permessage-deflateextension, which compresses data on the wire. It is enabled by default on the server. To disable it, set$SERVER_WEBSOCKET_COMPRESSIONto0. To configure compression options, set$SERVER_WEBSOCKET_COMPRESSIONto a JSON object that will be used as an argument todeflate.configure. Compression is supported on the client side by Meteor's Node DDP client and by browsers including Chrome, Safari, and Firefox 37.The
ddppackage has been split intoddp-clientandddp-serverpackages; usingddpis equivalent to using both. This allows you to use the Node DDP client without adding the DDP server to your app. #4191 #3452On the client,
Meteor.callnow takes athrowStubExceptionsoption; if set, exceptions thrown by method stubs will be thrown instead of logged, and the method will not be invoked on the server. #4202sub.ready()should return true inside that subscription'sonReadycallback. #4614Fix method calls causing broken state when socket is reconnecting. #5104
Isobuild
Build plugins will no longer process files whose names match the extension exactly (with no extra dot). If your build plugin needs to match filenames exactly, you should use the new build plugin API in this release which supplies a special
filenamesoption. #3985Adding the same file twice in the same package is now an error. Previously, this could either lead to the file being included multiple times, or to a build time crash.
You may now specify the
bareoption for JavaScript files on the server. Previous versions only allowed this on the client. #3681Ignore
node_modulesdirectories in apps instead of processing them as Meteor source code. #4457 #4452Backwards-incompatible change for package authors: Static assets in package.js files must now be explicitly declared by using
addAssetsinstead ofaddFiles. Previously, any file that didn't have a source handler was automatically registered as a server-side asset. TheisAssetoption toaddFilesis also deprecated in favor ofaddAssets.Built files are now always annotated with line number comments, to improve the debugging experience in browsers that don't support source maps.
There is a completely new API for defining build plugins that cache their output. There are now special APIs for defining linters and minifiers in addition to compilers. The core Meteor packages for
less,coffee,stylusandhtmlfiles have been updated to use this new API. Read more on the Wiki page.
CSS
LESS and Stylus now support cross-package imports.
CSS concatenation and minification is delegated to the
standard-minifierspackage, which is present by default (and added to existing apps by the v1.2 upgrader).CSS output is now split into multiple stylesheets to avoid hitting limits on rules per stylesheet in certain versions of Internet Explorer. #1876
Mongo
The oplog observe driver now properly updates queries when you drop a database. #3847
MongoID logic has been moved out of
minimongointo a new package calledmongo-id.Fix Mongo upserts with dotted keys in selector. #4522
meteor command-line tool
- You can now create three new example apps with the command line tool. These are the apps from the official tutorials at http://meteor.com/tutorials, which demonstrate building the same app with Blaze, Angular, and React. Try these apps with:
meteor create --example simple-todos
meteor create --example simple-todos-react
meteor create --example simple-todos-angular
meteor shellno longer crashes when piped from another command.Avoid a race condition in
meteor --testand work with newer versions of the Velocity package. #3957Improve error handling when publishing packages. #3977
Improve messaging around publishing binary packages. #3961
Preserve the value of
_inmeteor shell. #4010meteor mongonow works on OS X when certain non-ASCII characters are in the pathname, as long as thepgreputility is installed (it ships standard with OS X 10.8 and newer). #3999meteor runno longer ignores (and often reverts) external changes to.meteor/versionswhich occur while the process is running. #3582Fix crash when downloading two builds of the same package version simultaneously. #4163
Improve messages printed by
meteor update, displaying list of packages that are not at the latest version available.When determining file load order, split file paths on path separator before comparing path components alphabetically. #4300
Fix inability to run
mongoddue to lack of locale configuration on some platforms, and improve error message if the failure still occurs. #4019New
meteor lintcommand.
Minimongo
The
$pushquery modifier now supports a$positionargument. #4312c.update(selector, replacementDoc)no longer shares mutable state between replacementDoc and Minimongo internals. #4377
Email.sendnow has a new option,attachments, in the same style asmailcomposer. Details here.
Tracker
New
Tracker.Computation#onStopmethod. #3915ReactiveDicthas two new methods,clearandall.clearresets the dictionary as if no items had been added, meaning all calls togetwill returnundefined.allconverts the dictionary into a regular JavaScript object with a snapshot of the keys and values. Inside an autorun,allregisters a dependency on any changes to the dictionary. #3135
Utilities
New
beforeSendoption toHTTP.callon the client allows you to directly access theXMLHttpRequestobject and abort the call. #4419 #3243 #3266Parse
application/javascriptandapplication/x-javascriptHTTP replies as JSON too. #4595Match.testfrom thecheckpackage now properly compares boolean literals, just like it does with Numbers and Strings. This applies to thecheckfunction as well.Provide direct access to the
mailcomposernpm module used by theemailpackage onEmailInternals.NpmModules. Allow specifying aMailComposerobject toEmail.sendinstead of individual options. #4209Expose
Spiderable.requestTimeoutMsfromspiderablepackage to allow apps to set the timeout for running phantomjs.The
spiderablepackage now reports the URL it's trying to fetch on failure.
Other bug fixes and improvements
Upgraded dependencies:
- Node: 0.10.40 (from 0.10.36)
- uglify-js: 2.4.20 (from 2.4.17)
- http-proxy: 1.11.1 (from 1.6.0)
Meteor.loginWithGooglenow supportsprompt. Choose a prompt to always be displayed on Google login.Upgraded
coffeescriptpackage to depend on NPM packages coffeescript@1.9.2 and source-map@0.4.2. #4302Upgraded
fastclickto 1.0.6 to fix an issue in iOS Safari. #4393Fix
Error: Can't render headers after they are sent to the client. #4253 #4750Meteor.settings.publicis always available on client and server, and modifications made on the server (for example, during app initialization) affect the value seen by connecting clients. #4704
Windows
Increase the buffer size for
netstatwhen looking for running Mongo servers. #4125The Windows installer now always fetches the latest available version of Meteor at runtime, so that it doesn't need to be recompiled for every release.
Fix crash in
meteor mongoon Windows. #4711
v1.1.0.3, 2015-08-03
Accounts
- When using Facebook API version 2.4, properly fetch
emailand other fields. Facebook recently forced all new apps to use version 2.4 of their API. #4743
v1.1.0.2, 2015-04-06
meteor command-line tool
- Revert a change in 1.1.0.1 that caused
meteor mongoto fail on some Linux systems. #4115, #4124, #4134
v1.1.0.1, 2015-04-02
Blaze
- Fix a regression in 1.1 in Blaze Templates: an error happening when View is
invalidated immediately, causing a client-side crash (accessing
destroyMembersofundefined). #4097
v1.1, 2015-03-31
Windows Support
The Meteor command line tool now officially supports Windows 7, Windows 8.1, Windows Server 2008, and Windows Server 2012. It can run from PowerShell or Command Prompt.
There is a native Windows installer that will be available for download from https://www.meteor.com/install starting with this release.
In this release, Meteor on Windows supports all features available on Linux and Mac except building mobile apps with PhoneGap/Cordova.
The
meteor admin get-machinecommand now supports an additional architecture,os.windows.x86_32, which can be used to build binary packages for Windows.
Version Solver
The code that selects compatible package versions for
meteor updateand resolves conflicts onmeteor addhas been rewritten from the ground up. The core solver algorithm is now based on MiniSat, an open-source SAT solver, improving performance and maintainability.Refresh the catalog instead of downgrading packages when the versions in
.meteor/versionsaren't in the cache. #3653Don't downgrade packages listed in
.meteor/packages, or upgrade to a new major version, unless the new flag--allow-incompatible-updateis passed as an override.Error messages are more detailed when constraints are unsatisfiable.
Prefer "patched" versions of new indirect dependencies, and take patches to them on
meteor update(for example,1.0.1or1.0.0_1over1.0.0).Version Solver is instrumented for profiling (
METEOR_PROFILE=1in the environment).Setting the
METEOR_PRINT_CONSTRAINT_SOLVER_INPUTenvironment variable prints information useful for diagnosing constraint solver bugs.
Tracker
Schedule the flush cycle using a better technique than
setTimeoutwhen available. #3889Yield to the event loop during the flush cycle, unless we're executing a synchronous
Tracker.flush(). #3901Fix error reporting not being source-mapped properly. #3655
Introduce a new option for
Tracker.autorun-onError. This callback can be used to handle errors caught in the reactive computations. #3822
Blaze
- Fix stack overflow from nested templates and helpers by avoiding recursion during rendering. #3028
meteor command-line tool
- Don't fail if
npmprints more than 200K. #3887
Other bug fixes and improvements
Upgraded dependencies:
- uglify-js: 2.4.17 (from 2.4.13)
Patches contributed by GitHub users hwillson, mitar, murillo128, Primigenus, rjakobsson, and tmeasday.
v1.0.5, 2015-03-25
This version of Meteor now uses version 2.2 of the Facebook API for authentication, instead of 1.0. If you use additional Facebook API methods beyond login, you may need to request new permissions.
Facebook will automatically switch all apps to API version 2.0 on April 30th, 2015. Please make sure to update your application's permissions and API calls by that date.
For more details, see https://github.com/meteor/meteor/wiki/Facebook-Graph-API-Upgrade
v1.0.4.2, 2015-03-20
- Fix regression in 1.0.4 where using Cordova for the first time in a project with hyphens in its directory name would fail. #3950
v1.0.4.1, 2015-03-18
- Fix regression in 1.0.4 where
meteor publish-for-archonly worked for packages without colons in their name. #3951
v1.0.4, 2015-03-17
Mongo Driver
Meteor is now tested against MongoDB 2.6 by default (and the bundled version used by
meteor runhas been upgraded). It should still work fine with MongoDB 2.4. Previous versions of Meteor mostly worked with MongoDB 2.6, with a few caveats:- Some upsert invocations did not work with MongoDB in previous versions of Meteor.
- Previous versions of Meteor required setting up a special "user-defined
role" with access to the
system.replsettable to use the oplog observe driver with MongoDB 2.6. These extra permissions are not required with this version of Meteor.
The MongoDB command needed to set up user permissions for the oplog observe driver is slightly different in MongoDB 2.6; see https://github.com/meteor/meteor/wiki/Oplog-Observe-Driver for details.
We have also tested Meteor against the recently-released MongoDB 3.0.0. While we are not shipping MongoDB 3.0 with Meteor in this release (preferring to wait until its deployment is more widespread), we believe that Meteor 1.0.4 apps will work fine when used with MongoDB 3.0.0 servers.
Fix 0.8.1 regression where failure to connect to Mongo at startup would log a message but otherwise be ignored. Now it crashes the process, as it did before 0.8.1. #3038
Use correct transform for allow/deny rules in
updatewhen different rules have different transforms. #3108Provide direct access to the collection and database objects from the npm Mongo driver via new
rawCollectionandrawDatabasemethods onMongo.Collection. #3640Observing or publishing an invalid query now throws an error instead of effectively hanging the server. #2534
Livequery
If the oplog observe driver gets too far behind in processing the oplog, skip entries and re-poll queries instead of trying to keep up. #2668
Optimize common cases faced by the "crossbar" data structure (used by oplog tailing and DDP method write tracking). #3697
The oplog observe driver recovers from failed attempts to apply the modifier from the oplog (eg, because of empty field names).
Minimongo
When acting as an insert,
c.upsert({_id: 'x'}, {foo: 1})now uses the_idof'x'rather than a random_idin the Minimongo implementation ofupsert, just like it does forc.upsert({_id: 'x'}, {$set: {foo: 1}}). (The previous behavior matched a bug in the MongoDB 2.4 implementation of upsert that is fixed in MongoDB 2.6.) #2278Avoid unnecessary work while paused in minimongo.
Fix bugs related to observing queries with field filters:
changedcallbacks should not trigger unless a field in the filter has changed, andchangedcallbacks need to trigger when a parent of an included field is unset. #2254 #3571Disallow setting fields with empty names in minimongo, to match MongoDB 2.6 semantics.
DDP
Subscription handles returned from
Meteor.subscribeandTemplateInstance#subscribenow have asubscriptionIdproperty to identify which subscription the handle is for.The
onErrorcallback toMeteor.subscribehas been replaced with a more generalonStopcallback that has an error as an optional first argument. TheonStopcallback is called when the subscription is terminated for any reason.onErroris still supported for backwards compatibility. #1461The return value from a server-side
Meteor.callorMeteor.applyis now a clone of what the function returned rather than sharing mutable state. #3201Make it easier to use the Node DDP client implementation without running a web server too. #3452
Blaze
Template instances now have a
subscribemethod that functions exactly likeMeteor.subscribe, but stops the subscription when the template is destroyed. There is a new method on Template instances calledsubscriptionsReady()which is a reactive function that returns true when all of the subscriptions made withTemplateInstance#subscribeare ready. There is also a built-in helper that returns the same thing and can be accessed withTemplate.subscriptionsReadyinside any template.Add
onRendered,onCreated, andonDestroyedmethods toTemplate. Assignments toTemplate.foo.renderedand so forth are deprecated but are still supported for backwards compatibility.Fix bug where, when a helper or event handler was called from inside a custom block helper,
Template.instance()returned theTemplate.contentBlocktemplate instead of the actual user-defined template, making it difficult to useTemplate.instance()for local template state.Template.instance()now works insideTemplate.body. #3631Allow specifying attributes on
<body>tags in templates.Improve performance of rendering large arrays. #3596
Isobuild
In
package.jsfiles,Npm.requirecan only require built-in Node modules (and dev bundle modules, though you shouldn't depend on that), not the modules from its ownNpm.depends. Previously, such code would work but only on the second time apackage.jswas executed.Ignore vim swap files in the
publicandprivatedirectories. #3322Fix regression in 1.0.2 where packages might not be rebuilt when the compiler version changes.
Meteor Accounts
The
accounts-passwordAccounts.emailTemplatescan now specify arbitrary emailheaders. Thefromaddress can now be set separately on the individual templates, and is a function there rather than a static string. #2858 #2854Add login hooks on the client:
Accounts.onLoginandAccounts.onLoginFailure. #3572Add a unique index to the collection that stores OAuth login configuration to ensure that only one configuration exists per service. #3514
On the server, a new option
Accounts.setPassword(user, password, { logout: false })overrides the default behavior of logging out all logged-in connections for the user. #3846
Webapp
spiderablenow supports escaped#!fragments. #2938Disable
appcacheon Firefox by default. #3248Don't overly escape
Meteor.settings.publicand other parts of__meteor_runtime_config__. #3730Reload the client program on
SIGHUPor Node-specific IPC messages, notSIGUSR2.
meteor command-line tool
Enable tab-completion of global variables in
meteor shell. #3227meteor login --emailno longer takes an ignored argument. #3532Fix regression in 1.0.2 where
meteor run --settings swould ignore errors reading or parsing the settings file. #3757Fix crash in
meteor publishin some cases when the package is inside an app. #3676Fix crashes in
meteor search --show-allandmeteor search --maintainer. #3636Kill PhantomJS processes after
meteor --test, and only run the app once. #3205 #3793Give a better error when Mongo fails to start up due to a full disk. #2378
After killing existing
mongodservers, also clear themongod.lockfile.Stricter validation for package names: they cannot begin with a hyphen, end with a dot, contain two consecutive dots, or start or end with a colon. (No packages on Atmosphere fail this validation.) Additionally,
meteor create --packageapplies the same validation asmeteor publishand disallows packages with multiple colons. (Packages with multiple colons likelocal-test:iron:routerare used internally bymeteor test-packagesso that is not a strict validation rule.)meteor create --packagenow no longer creates a directory with the full name of the package, since Windows file systems cannot have colon characters in file paths. Instead, the command now creates a directory named the same as the second part of the package name after the colon (without the username prefix).
Meteor Mobile
Upgrade the Cordova CLI dependency from 3.5.1 to 4.2.0. See the release notes for the 4.x series of the Cordova CLI on Apache Cordova.
Related to the recently discovered attack vectors in Android Cordova apps, Meteor Cordova apps no longer allow access to all domains by default. If your app access external resources over XHR, you need to add them to the whitelist of allowed domains with the newly added
App.accessRulemethod in yourmobile-config.jsfile.Upgrade Cordova Plugins dependencies in Meteor Core packages:
org.apache.cordova.file: from 1.3.0 to 1.3.3org.apache.cordova.file-transfer: from 0.4.4 to 0.5.0org.apache.cordova.splashscreen: from 0.3.3 to 1.0.0org.apache.cordova.console: from 0.2.10 to 0.2.13org.apache.cordova.device: from 0.2.11 to 0.3.0org.apache.cordova.statusbar: from 0.1.7 to 0.1.10org.apache.cordova.inappbrowser: from 0.5.1 to 0.6.0org.apache.cordova.inappbrowser: from 0.5.1 to 0.6.0
Use the newer
ios-simbinary, compiled with Xcode 6 on OS X Mavericks.
Tracker
- Use
Session.set({k1: v1, k2: v2})to set multiple values at once.
Utilities
- Provide direct access to all options supported by the
requestnpm module via the new server-onlynpmRequestOptionsoption toHTTP.call. #1703
Other bug fixes and improvements
Many internal refactorings towards supporting Meteor on Windows are in this release.
Remove some packages used internally to support legacy MDG systems (
application-configuration,ctl,ctl-helper,follower-livedata,dev-bundle-fetcher, andstar-translate).Provide direct access to some npm modules used by core packages on the
NpmModulesfield ofWebAppInternals,MongoInternals, andHTTPInternals.Upgraded dependencies:
- node: 0.10.36 (from 0.10.33)
- Fibers: 1.0.5 (from 1.0.1)
- MongoDB: 2.6.7 (from 2.4.12)
- openssl in mongo: 1.0.2 (from 1.0.1j)
- MongoDB driver: 1.4.32 (from 1.4.1)
- bson: 0.2.18 (from 0.2.7)
- request: 2.53.0 (from 2.47.0)
Patches contributed by GitHub users 0a-, awatson1978, awwx, bwhitty, christianbundy, d4nyll, dandv, DanielDent, DenisGorbachev, fay-jai, gsuess, hwillson, jakozaur, meonkeys, mitar, netanelgilad, queso, rbabayoff, RobertLowe, romanzolotarev, Siilwyn, and tmeasday.
v.1.0.3.2, 2015-02-25
- Fix regression in 1.0.3 where the
meteortool could crash when downloading the second build of a given package version; for example, when runningmeteor deployon an OSX or 32-bit Linux system for an app containing a binary package. #3761
v.1.0.3.1, 2015-01-20
Rewrite
meteor showandmeteor searchto show package information for local packages and to show if the package is installed for non-local packages. Introduce the--show-allflag, and deprecate the--show-unmigratedand--show-old flags. Introduce the--ejsonflag to output an EJSON object.Support README.md files in
meteor publish. Take in the documentation file inpackage.js(set toREADME.mdby default) and upload it to the server at publication time. Excerpt the first non-header Markdown section for use inmeteor show.Support updates of package version metadata after that version has been published by running
meteor publish --updatefrom the package directory.Add
meteor test-packages --velocity(similar tometeor run --test). #3330Fix
meteor update <packageName>to update<packageName>even if it's an indirect dependency of your app. #3282Fix stack trace when a browser tries to use the server like a proxy. #1212
Fix inaccurate session statistics and possible multiple invocation of Connection.onClose callbacks.
Switch CLI tool filesystem calls from synchronous to yielding (pro: more concurrency, more responsive to signals; con: could introduce concurrency bugs)
Don't try to refresh client app in the runner unless the app actually has the autoupdate package. #3365
Fix custom release banner logic. #3353
Apply HTTP followRedirects option to non-GET requests. #2808
Clean up temporary directories used by package downloads sooner. #3324
If the tool knows about the requested release but doesn't know about the build of its tool for the platform, refresh the catalog rather than failing immediately. #3317
Fix
meteor --get-readyto not add packages to your app.Fix some corner cases in cleaning up app processes in the runner. Drop undocumented
--keepalivesupport. #3315Fix CSS autoupdate when
$ROOT_URLhas a non-trivial path. #3111Save Google OAuth idToken to the User service info object.
Add git info to
meteor --version.Correctly catch a case of illegal
Tracker.flushduringTracker.autorun. #3037Upgraded dependencies:
- jquery: 1.11.2 (from 1.11.0)
Patches by GitHub users DanielDent, DanielDornhardt, PooMaster, Primigenus, Tarang, TomFreudenberg, adnissen, dandv, fay-jai, knownasilya, mquandalle, ogourment, restebanez, rissem, smallhelm and tmeasday.
v1.0.2.1, 2014-12-22
Fix crash in file change watcher. #3336
Allow
meteor test-packages packages/*even if not all package directories have tests. #3334Fix typo in
meteor shelloutput. #3326
v1.0.2, 2014-12-19
Improvements to the meteor command-line tool
A new command called
meteor shellattaches an interactive terminal to an already-running server process, enabling inspection and execution of server-side data and code, with dynamic tab completion of variable names and properties. To seemeteor shellin action, typemeteor runin an app directory, then (in another terminal) typemeteor shellin the same app directory. You do not have to wait for the app to start before typingmeteor shell, as it will automatically connect when the server is ready. Note thatmeteor shellcurrently works for local development only, and is not yet supported for apps running on remote hosts.We've done a major internal overhaul of the
meteorcommand-line tool with an eye to correctness, maintainability, and performance. Some details include:- Refresh the package catalog for build commands only when an error occurs that could be fixed by a refresh, not for every build command.
- Never run the constraint solver to select package versions more than once per build.
- Built packages ("isopacks") are now cached inside individual app directories instead of inside their source directories.
meteor runstarts Mongo in parallel with building the application.- The constraint solver no longer leaves a
versions.jsonfile in your packages source directories; when publishing a package that is not inside an app, it will leave a.versionsfile (with the same format as.meteor/versions) which you should check into source control. - The constraint solver's model has been simplified so that plugins must use the same version of packages as their surrounding package when built from local source.
Using
meteor debugno longer requires manually continuing the debugger when your app restarts, and it no longer overwrites the symbol_inside your app.Output from the command-line tool is now word-wrapped to the width of your terminal.
Remove support for the undocumented earliestCompatibleVersion feature of the package system.
Reduce CPU usage and disk I/O bandwidth by using kernel file-system change notification events where possible. On file systems that do not support these events (NFS, Vagrant Virtualbox shared folders, etc), file changes will only be detected every 5 seconds; to detect changes more often in these cases (but use more CPU), set the
METEOR_WATCH_FORCE_POLLINGenvironment variable. #2135Reduce CPU usage by fixing a check for a parent process in
meteor runthat was happening constantly instead of every few seconds. #3252Fix crash when two plugins defined source handlers for the same extension. #3015 #3180
Fix bug (introduced in 0.9.3) where the warning about using experimental versions of packages was printed too often.
Fix bug (introduced in 1.0) where
meteor update --patchcrashed.Fix bug (introduced in 0.9.4) where banners about new releases could be printed too many times.
Fix crash when a package version contained a dot-separated pre-release part with both digits and non-digits. #3147
Corporate HTTP proxy support is now implemented using our websocket library's new built-in implementation instead of a custom implementation. #2515
Blaze
Add default behavior for
Template.parentDatawith no arguments. This selects the first parent. #2861Fix
Blaze.removeon a template's view to correctly remove the DOM elements when the template was inserted usingBlaze.renderWithData. #3130Allow curly braces to be escaped in Spacebars. Use the special sequences
{{|and{{{|to insert a literal{{or{{{.
Meteor Accounts
Allow integration with OAuth1 servers that require additional query parameters to be passed with the access token. #2894
Expire a user's password reset and login tokens in all circumstances when their password is changed.
Other bug fixes and improvements
Some packages are no longer released as part of the core release process: amplify, backbone, bootstrap, d3, jquery-history, and jquery-layout. This means that new versions of these packages can be published outside of the full Meteor release cycle.
Require plain objects as the update parameter when doing replacements in server-side collections.
Fix audit-argument-checks spurious failure when an argument is NaN. #2914
Upgraded dependencies
- node: 0.10.33 (from 0.10.29)
- source-map-support: 0.2.8 (from 0.2.5)
- semver: 4.1.0 (from 2.2.1)
- request: 2.47.0 (from 2.33.0)
- tar: 1.0.2 (from 1.0.1)
- source-map: 0.1.40 (from 0.1.32)
- sqlite3: 3.0.2 (from 3.0.0)
- phantomjs npm module: 1.9.12 (from 1.8.1-1)
- http-proxy: 1.6.0 (from a fork of 1.0.2)
- esprima: 1.2.2 (from an unreleased 1.1-era commit)
- escope: 1.0.1 (from 1.0.0)
- openssl in mongo: 1.0.1j (from 1.0.1g)
- faye-websocket: 0.8.1 (from using websocket-driver instead)
- MongoDB: 2.4.12 (from 2.4.9)
Patches by GitHub users andylash, anstarovoyt, benweissmann, chrisbridgett, colllin, dandv, ecwyne, graemian, JamesLefrere, kevinchiu, LyuGGang, matteodem, mitar, mquandalle, musically-ut, ograycode, pcjpcj2, physiocoder, rgoomar, timhaines, trusktr, Urigo, and zol.
v1.0.1, 2014-12-09
- Fix a security issue in allow/deny rules that could result in data loss. If your app uses allow/deny rules, or uses packages that use allow/deny rules, we recommend that you update immediately.
v1.0, 2014-10-28
New Features
Add the
meteor admin get-machinecommand to make it easier to publish packages with binary dependencies for all architectures.meteor publishno longer publishes builds automatically if your package has binary NPM dependencies.New
localmarketexample, highlighting Meteor's support for mobile app development.Restyle the
leaderboardexample, and optimize it for both desktop and mobile.
Performance
Reduce unnecessary syncs with the package server, which speeds up startup times for many commands.
Speed up
meteor deployby not bundling unnecessary files and programs.To make Meteor easier to use on slow or unreliable network connections, increase timeouts for DDP connections that the Meteor tool uses to communicate with the package server. #2777, #2789.
Mobile App Support
Implemented reasonable default behavior for launch screens on mobile apps.
Don't build for Android when only the iOS build is required, and vice versa.
Fix bug that could cause mobile apps to stop being able to receive hot code push updates.
Fix bug where Cordova clients connected to http://example.com instead of https://example.com when https:// was specified in the --mobile-server option. #2880
Fix stack traces when attempting to build or run iOS apps on Linux.
Print a warning when building an app with mobile platforms and outputting the build into the source tree. Outputting a build into the source tree can cause subsequent builds to fail because they will treat the build output as source files.
Exit from
meteor runwhen new Cordova plugins or platforms are added, since we don't support hot code push for new plugins or platforms.Fix quoting of arguments to Cordova plugins.
The
accounts-twitterpackage now works in Cordova apps in local development. For workarounds for other login providers in local development mode, see https://github.com/meteor/meteor/wiki/OAuth-for-mobile-Meteor-clients.
Packaging
meteor publish-for-archcan publish packages built with different Meteor releases.Fix default
api.versionsFromfield in packages created withmeteor create --package.Fix bug where changes in an app's .meteor/versions file would not cause the app to be rebuilt.
Other bug fixes and improvements
Use TLSv1 in the
spiderablepackage, for compatibility with servers that have disabled SSLv3 in response to the POODLE bug.Work around the
meteor runproxy occasionally running out of sockets.Fix bug with regular expressions in minimongo. #2817
Add READMEs for several core packages.
Include protocols in URLs printed by
meteor deploy.Improve error message for limited ordered observe. #1643
Fix missing dependency on
randomin theautoupdatepackage. #2892Fix bug where all CSS would be removed from connected clients if a CSS-only change is made between local development server restarts or when deploying with
meteor deploy.Increase height of the Google OAuth popup to the Google-recommended value.
Fix the layout of the OAuth configuration dialog when used with Bootstrap.
Allow build plugins to override the 'bare' option on added source files. #2834
Patches by GitHub users DenisGorbachev, ecwyne, mitar, mquandalle, Primigenus, svda, yauh, and zol.
v0.9.4.1, 2014-12-09 (backport)
- Fix a security issue in allow/deny rules that could result in data loss. If your app uses allow/deny rules, or uses packages that use allow/deny rules, we recommend that you update immediately. Backport from 1.0.1.
v0.9.4, 2014-10-13
New Features
The new
meteor debugcommand and--debug-portcommand line option tometeor runallow you to easily use node-inspector to debug your server-side code. Add adebuggerstatement to your code to create a breakpoint.Add new a
meteor run --testcommand that runs Velocity tests in your app .Add new callbacks
Accounts.onResetPasswordLink,Accounts.onEnrollmentLink, andAccounts.onEmailVerificationLinkthat make it easier to build custom user interfaces on top of the accounts system. These callbacks should be registered beforeMeteor.startupfires, and will be called if the URL matches a link in an email sent byAccounts.resetPassword, etc. See https://docs.meteor.com/#Accounts-onResetPasswordLink.A new configuration file for mobile apps,
<APP>/mobile-config.js. This allows you to set app metadata, icons, splash screens, preferences, and PhoneGap/Cordova plugin settings without needing acordova_build_overridedirectory. See https://docs.meteor.com/#mobileconfigjs.
API Changes
Rename
{{> UI.dynamic}}to{{> Template.dynamic}}, and likewise withUI.contentBlockandUI.elseBlock. The UI namespace is no longer used anywhere except for backwards compatibility.Deprecate the
Template.someTemplate.myHelper = ...syntax in favor ofTemplate.someTemplate.helpers(...). Using the older syntax still works, but prints a deprecation warning to the console.Package.registerBuildPluginits associated functions have been added to the public API, cleaned up, and documented. The new function is identical to the earlier transitionalregisterBuildPlugin except for minor backwards-compatible API changes. See https://docs.meteor.com/#Package-registerBuildPluginRename the
showdownpackage tomarkdown.Deprecate the
amplify,backbone,bootstrap, andd3integration packages in favor of community alternatives. These packages will no longer be maintained by MDG.
Tool Changes
Improved output from
meteor buildto make it easier to publish mobile apps to the App Store and Play Store. See the wiki pages for instructions on how to publish your iOS and Android apps.Packages can now be marked as debug-mode only by adding
debugOnly: truetoPackage.describe. Debug-only packages are not included in the app when it is bundled for production (meteor buildormeteor run --production). This allows package authors to build packages specifically for testing and debugging without increasing the size of the resulting app bundle or causing apps to ship with debug functionality built in.Rework the process for installing mobile development SDKs. There is now a
meteor install-sdkcommand that automatically install what software it can and points to documentation for the parts that require manual installation.The
.meteor/cordova-platformsfile has been renamed to.meteor/platformsand now includes the defaultserverandbrowserplatforms. The default platforms can't currently be removed from a project, though this will be possible in the future. The old file will be automatically migrated to the new one when the app is run with Meteor 0.9.4 or above.The
unipackage.jsonfile inside downloaded packages has been renamed toisopack.jsonand has an improved forwards-compatible format. To maintain backwards compatibility with previous releases, packages will be built with both files.The local package metadata cache now uses SQLite, which is much faster than the previous implementation. This improves
meteorcommand line tool startup time.The constraint solver used by the client to find compatible versions of packages is now much faster.
The
--portoption tometeor runnow requires a numeric port (e.g.meteor run --port example.comis no longer valid).The
--mobile-portoptionmeteor runhas been reworked. The option is now--mobile-serverinmeteor runand--serverinmeteor build.--serveris required formeteor buildin apps with mobile platforms installed.--mobile-serverdefaults to an automatically detected IP address on port 3000, and--serverrequires a hostname but defaults to port 80 if a port is not specified.Operations that take longer than a few seconds (e.g. downloading packages, installing the Android SDK, etc) now show a progress bar.
Complete support for using an HTTP proxy in the
meteorcommand line tool. Now all DDP connections can work through a proxy. Use the standardhttp_proxyenvironment variable to specify your proxy endpoint. #2515
Bug Fixes
Fix behavior of ROOT_URL with path ending in
/.Fix source maps when using a ROOT_URL with a path. #2627
Change the mechanism that the Meteor tool uses to clean up app server processes. The new mechanism is more resilient to slow app bundles and other CPU-intensive tasks. #2536, #2588.
Patches by GitHub users cryptoquick, Gaelan, jperl, meonkeys, mitar, mquandalle, prapicault, pscanf, richguan, rick-golden-healthagen, rissem, rosh93, rzymek, and timoabend
v0.9.3.1, 2014-09-30
Don't crash when failing to contact the package server. #2713
Allow more than one dash in package versions. #2715
v0.9.3, 2014-09-25
More Package Version Number Flexibility
Packages now support relying on multiple major versions of their dependencies (eg
blaze@1.0.0 || 2.0.0). Additionally, you can now callapi.versionsFrom(<release>)multiple times, or with an array (egapi.versionsFrom([<release1>, <release2>]). Meteor will interpret this to mean that the package will work with packages from all the listed releases.Support for "wrapped package" version numbers. There is now a
_field in version numbers. The_field must be an integer, and versions with the_are sorted after versions without. This allows using the upstream version number as the Meteor package version number and being able to publish multiple version of the Meteor package (e.g.jquery@1.11.1_2).
Note: packages using the || operator or the _ symbol in their
versions or dependencies will be invisible to pre-0.9.3 users. Meteor
versions 0.9.2 and before do not understand the new version formats and
will not be able to use versions of packages that use the new features.
Other Command-line Tool Improvements
More detailed constraint solver output. Meteor now tells you which constraints prevent upgrading or adding new packages. This will make it much easier to update your app to new versions.
Better handling of pre-release versions (e.g. versions with
-). Pre-release packages will now be included in an app if and only if there is no way to meet the app's constraints without using a pre-release package.Add
meteor admin set-unmigratedto allow maintainers to hide pre-0.9.0 packages inmeteor searchandmeteor show. This will not stop users from continuing to use the package, but it helps prevent new users from finding old non-functional packages.Progress bars for time-intensive operations, like downloading large packages.
Other Changes
Officially support
Meteor.wrapAsync(renamed fromMeteor._wrapAsync). Additionally,Meteor.wrapAsyncnow lets you pass an object to bind asthisin the wrapped call. See https://docs.meteor.com/#meteor_wrapasync.The
reactive-dictpackage now allows an optional name argument to enable data persistence during hot code push.
Patches by GitHub users evliu, meonkeys, mitar, mizzao, mquandalle, prapicault, waitingkuo, wulfmeister.
v0.9.2.2, 2014-09-17
- Fix regression in 0.9.2 that prevented some users from accessing the Meteor development server in their browser. Specifically, 0.9.2 unintentionally changed the development mode server's default bind host to localhost instead of 0.0.0.0. #2596
v0.9.2.1, 2014-09-15
- Fix versions of packages that were published with
-cordovaversions in 0.9.2 (appcache, fastclick, htmljs, logging, mobile-status-bar, routepolicy, webapp-hashing).
v0.9.2, 2014-09-15
This release contains our first support for building mobile apps in Meteor, for both iOS and Android. This support comes via an integration with Apache's Cordova/PhoneGap project.
You can use Cordova/PhoneGap packages in your application or inside a Meteor package to access a device's native functions directly from JavaScript code.
The
meteor add-platformandmeteor runcommands now let you launch the app in the iOS or Android simulator or run it on an attached hardware device.This release extends hot code push to support live updates into installed native apps.
The
meteor bundlecommand has been renamed tometeor buildand now outputs build projects for the mobile version of the targeted app.See https://github.com/meteor/meteor/wiki/Meteor-Cordova-Phonegap-integration for more information about how to get started building mobile apps with Meteor.
Better mobile support for OAuth login: you can now use a redirect-based flow inside UIWebViews, and the existing popup-based flow has been adapted to work in Cordova/PhoneGap apps.
Bug fixes and minor improvements
Fix sorting on non-trivial keys in Minimongo. #2439
Bug fixes and performance improvements for the package system's constraint solver.
Improved error reporting for misbehaving oplog observe driver. #2033 #2244
Drop deprecated source map linking format used for older versions of Firefox. #2385
Allow Meteor tool to run from a symlink. #2462
Assets added via a plugin are no longer considered source files. #2488
Remove support for long deprecated
SERVER_IDenvironment variable. UseAUTOUPDATE_VERSIONinstead.Fix bug in reload-safetybelt package that resulted in reload loops in Chrome with cookies disabled.
Change the paths for static assets served from packages. The
:character is replaced with the_character in package names so as to allow serving on mobile devices and ease operation on Windows. For example, assets from theabc:bootstrappackage are now served at/packages/abc_bootstrapinstead of/packages/abc:bootstrap.Also change the paths within a bundled Meteor app to allow for different client architectures (eg mobile). For example,
bundle/programs/clientis nowbundle/programs/web.browser.
Patches by GitHub users awwx, mizzao, and mquandalle.
v0.9.1.1, 2014-09-06
Fix backwards compatibility for packages that had weak dependencies on packages renamed in 0.9.1 (
ui,deps,livedata). #2521Fix error when using the
reactive-dictpackage without themongopackage.
v0.9.1, 2014-09-04
Organizations in Meteor developer accounts
Meteor 0.9.1 ships with organizations support in Meteor developer accounts. Organizations are teams of users that make it easy to collaborate on apps and packages.
Create an organization at
https://www.meteor.com/account-settings/organizations. Run the meteor
authorized command in your terminal to give an organization
permissions to your apps. To add an organization as a maintainer of
your packages, use the meteor admin maintainers command. You can
also publish packages with an organization's name in the package name
prefix instead of your own username.
One backwards incompatible change for templates
- Templates can no longer be named "body" or "instance".
Backwards compatible Blaze API changes
New public and documented APIs:
Blaze.toHTMLWithData()Template.currentData()Blaze.getView()Template.parentData()(previouslyUI._parentData())Template.instance()(previouslyUI._templateInstance())Template.body(previouslyUI.body)new Template(previouslyTemplate.__create__)Blaze.getData()(previouslyUI.getElementData, orBlaze.getCurrentDatawith no arguments)
Deprecate the
uipackage. Instead, use theblazepackage. TheUIandBlazesymbols are now the same.Deprecate
UI.insert.UI.renderandUI.renderWithDatanow render a template and place it in the DOM.Add an underscore to some undocumented Blaze APIs to make them internal. Notably:
Blaze._materializeView,Blaze._createView,Blaze._toText,Blaze._destroyView,Blaze._destroyNode,Blaze._withCurrentView,Blaze._DOMBackend,Blaze._TemplateWithDocument Views. Views are the machinery powering DOM updates in Blaze.
Expose
viewproperty on template instances.
Backwards compatible renames
- Package renames
livedata->ddpmongo-livedata->mongostandard-app-packages->meteor-platform
- Symbol renames
Meteor.Collection->Mongo.CollectionMeteor.Collection.Cursor->Mongo.CursorMeteor.Collection.ObjectID->Mongo.ObjectIDDeps->Tracker
Other
Add
reactive-varpackage. Lets you define a single reactive variable, like a single key inSession.Don't throw an exception in Chrome when cookies and local storage are blocked.
Bump DDP version to "1". Clients connecting with version "pre1" or "pre2" should still work.
Allow query parameters in OAuth1 URLs. #2404
Fix
meteor listif not all packages on server. Fixes #2468
Patch by GitHub user mitar.
v0.9.0.1, 2014-08-27
Fix issues preventing hot code reload from automatically reloading webapps in two cases: when the old app was a pre-0.9.0 app, and when the app used appcache. (In both cases, an explicit reload still worked.)
Fix publishing packages containing a plugin with platform-specific code but no platform-specific code in the main package.
Fix
meteor add package@versionwhen the package was already added with a different version constraint.Improve treatment of pre-release packages (packages with a dash in their version). Guarantee that they will not be chosen by the constraint solver unless explicitly requested.
meteor listwon't suggest that you update to them.Fix slow spiderable executions.
Fix dev-mode client-only restart when client files changed very soon after server restart.
Fix stack trace on
meteor addconstraint solver failure.Fix "access-denied" stack trace when publishing packages.
v0.9.0, 2014-08-26
Meteor 0.9.0 introduces the Meteor Package Server. Incorporating lessons from
our community's Meteorite tool, Meteor 0.9.0 allows users to develop and publish
Meteor packages to a central repository. The meteor publish command is used to
publish packages. Non-core packages can now be added with meteor add, and you
can specify version constraints on the packages you use. Binary packages can be
published for additional architectures with meteor publish-for-arch, which
allows cross-platform deploys and bundling. You can search for packages with
meteor search and display information on them with meteor show, or you can
use the Atmosphere web interface developed by Percolate Studio at
https://atmospherejs.com/
See https://docs.meteor.com/#writingpackages and https://docs.meteor.com/#packagejs for more details.
Other packaging-related changes:
meteor listnow lists the packages your app is using, which was formerly the behavior ofmeteor list --using. To search for packages you are not currently using, usemeteor search. The concept of an "internal" package (which did not show up inmeteor list) no longer exists.To prepare a bundle created with
meteor bundlefor execution on a server, you now runnpm installwith no arguments instead of having to specify a few specific npm modules and their versions explicitly. See the README in the generated bundle for more details.All
under_score-stylepackage.jsAPIs (Package.on_use,api.add_files, etc) have been replaced withcamelCasenames (Package.onUse,api.addFiles, etc). The old names continue to work for now.There's a new
archMatchingoption toPlugin.registerSourceHandler, which should be used by any plugin whose output is only for the client or only for the server (eg, CSS and HTML templating packages); this allows Meteor to avoid restarting the server when files processed by these plugins change.
Other changes:
When running your app with the local development server, changes that only affect the client no longer require restarting the server. Changes that only affect CSS no longer require the browser to refresh the page, both in local development and in some production environments. #490
When a call to
matchfails in a method or subscription, log the failure on the server. (This matches the behavior described in our docs)The
appcachepackage now defaults to functioning on all browsers that support the AppCache API, rather than a whitelist of browsers. The main effect of this change is thatappcacheis now enabled by default on Firefox, because Firefox no longer makes a confusing popup. You can still disable individual browsers withAppCache.config. #2241The
forceApprovalPromptoption can now be specified inAccounts.ui.configin addition toMeteor.loginWithGoogle. #2149Don't leak websocket clients in server-to-server DDP in some cases (and fix "Got open from inactive client" error). https://github.com/faye/websocket-driver-node/pull/8
Updated OAuth url for login with Meetup.
Allow minimongo
changedcallbacks to mutate theiroldDocumentargument. #2231Fix upsert called from client with no callback. #2413
Avoid a few harmless exceptions in OplogObserveDriver.
Refactor
observe-sequencepackage.Fix
spiderablerace condition.Re-apply our fix of NPM bug https://github.com/npm/npm/issues/3265 which got accidentally reverted upstream.
Workaround for a crash in recent Safari versions. https://github.com/meteor/meteor/commit/e897539adb
Upgraded dependencies:
- less: 1.7.4 (from 1.7.1)
- tar: 1.0.1 (from 0.1.19)
- fstream: 1.0.2 (from 0.1.25)
Patches by GitHub users Cangit, dandv, ImtiazMajeed, MaximDubrovin, mitar, mquandalle, rcy, RichardLitt, thatneat, and twhy.
v0.8.3.1, 2014-12-09 (backport)
- Fix a security issue in allow/deny rules that could result in data loss. If your app uses allow/deny rules, or uses packages that use allow/deny rules, we recommend that you update immediately. Backport from 1.0.1.
v0.8.3, 2014-07-29
Blaze
Refactor Blaze to simplify internals while preserving the public API.
UI.Componenthas been replaced withBlaze.View.Fix performance issues and memory leaks concerning event handlers.
Add
UI.remove, which removes a template afterUI.render/UI.insert.Add
this.autorunto the template instance, which is likeDeps.autorunbut is automatically stopped when the template is destroyed.Create
<a>tags as SVG elements when they havexlink:hrefattributes. (Previously,<a>tags inside SVGs were never created as SVG elements.) #2178Throw an error in
{{foo bar}}iffoois missing or not a function.Cursors returned from template helpers for #each should implement the
observeChangesmethod and don't have to be Minimongo cursors (allowing new custom data stores for Blaze like Miniredis).Remove warnings when {{#each}} iterates over a list of strings, numbers, or other items that contains duplicates. #1980
Meteor Accounts
Fix regression in 0.8.2 where an exception would be thrown if
Meteor.loginWithPassworddidn't have a callback. Callbacks toMeteor.loginWithPasswordare now optional again. #2255Fix OAuth popup flow in mobile apps that don't support
window.opener. #2302Fix "Email already exists" error with MongoDB 2.6. #2238
mongo-livedata and minimongo
Fix performance issue where a large batch of oplog updates could block the node event loop for long periods. #2299.
Fix oplog bug resulting in error message "Buffer inexplicably empty". #2274
Fix regression from 0.8.2 that caused collections to appear empty in reactive
findOne()orfetchqueries that run before a mutator returns. #2275
Miscellaneous
Stop including code by default that automatically refreshes the page if JavaScript and CSS don't load correctly. While this code is useful in some multi-server deployments, it can cause infinite refresh loops if there are errors on the page. Add the
reload-safetybeltpackage to your app if you want to include this code.On the server,
Meteor.startup(c)now callscimmediately if the server has already started up, matching the client behavior. #2239Add support for server-side source maps when debugging with
node-inspector.Add
WebAppInternals.addStaticJs()for adding static JavaScript code to be served in the app, inline if allowed bybrowser-policy.Make the
tinytest/runmethod return immediately, so thatwaitmethod calls from client tests don't block on server tests completing.Log errors from method invocations on the client if there is no callback provided.
Upgraded dependencies:
- node: 0.10.29 (from 0.10.28)
- less: 1.7.1 (from 1.6.1)
Patches contributed by GitHub users Cangit, cmather, duckspeaker, zol.
v0.8.2, 2014-06-23
Meteor Accounts
Switch
accounts-passwordto use bcrypt to store passwords on the server. (Previous versions of Meteor used a protocol called SRP.) Users will be transparently transitioned when they log in. This transition is one-way, so you cannot downgrade a production app once you upgrade to 0.8.2. If you are maintaining an authenticating DDP client:- Clients that use the plaintext password login handler (i.e. call
the
loginmethod with argument{ password: <plaintext password> }) will continue to work, but users will not be transitioned from SRP to bcrypt when logging in with this login handler. - Clients that use SRP will no longer work. These clients should
instead directly call the
loginmethod, as inMeteor.loginWithPassword. The argument to theloginmethod can be either:{ password: <plaintext password> }, or{ password: { digest: <password hash>, algorithm: "sha-256" } }, where the password hash is the hex-encoded SHA256 hash of the plaintext password.
- Clients that use the plaintext password login handler (i.e. call
the
Show the display name of the currently logged-in user after following an email verification link or a password reset link in
accounts-ui.Add a
userEmailoption toMeteor.loginWithMeteorDeveloperAccountto pre-fill the user's email address in the OAuth popup.Ensure that the user object has updated token information before it is passed to email template functions. #2210
Export the function that serves the HTTP response at the end of an OAuth flow as
OAuth._endOfLoginResponse. This function can be overridden to make the OAuth popup flow work in certain mobile environments wherewindow.openeris not supported.Remove support for OAuth redirect URLs with a
redirectquery parameter. This OAuth flow was never documented and never fully worked.
Blaze
Blaze now tracks individual CSS rules in
styleattributes and won't overwrite changes to them made by other JavaScript libraries.Add
{{> UI.dynamic}}to make it easier to dynamically render a template with a data context.Add
UI._templateInstance()for accessing the current template instance from within a block helper.Add
UI._parentData(n)for accessing parent data contexts from within a block helper.Add preliminary API for registering hooks to run when Blaze intends to insert, move, or remove DOM elements. For example, you can use these hooks to animate nodes as they are inserted, moved, or removed. To use them, you can set the
_uihooksproperty on a container DOM element._uihooksis an object that can have any subset of the following three properties:insertElement: function (node, next): called when Blaze intends to insert the DOM elementnodebefore the elementnextmoveElement: function (node, next): called when Blaze intends to move the DOM elementnodebefore the elementnextremoveElement: function (node): called when Blaze intends to remove the DOM elementnode
Note that when you set one of these functions on a container element, Blaze will not do the actual operation; it's your responsibility to actually insert, move, or remove the node (by calling
$(node).remove(), for example).The
findAllmethod on template instances now returns a vanilla array, not a jQuery object. The$method continues to return a jQuery object. #2039Fix a Blaze memory leak by cleaning up event handlers when a template instance is destroyed. #1997
Fix a bug where helpers used by {{#with}} were still re-running when their reactive data sources changed after they had been removed from the DOM.
Stop not updating form controls if they're focused. If a field is edited by one user while another user is focused on it, it will just lose its value but maintain its focus. #1965
Add
_nestInCurrentComputationoption toUI.render, fixing a bug in {{#each}} when an item is added inside a computation that subsequently gets invalidated. #2156Fix bug where "=" was not allowed in helper arguments. #2157
Fix bug when a template tag immediately follows a Spacebars block comment. #2175
Command-line tool
Add --directory flag to
meteor bundle. Setting this flag outputs a directory rather than a tarball.Speed up updates of NPM modules by upgrading Node to include our fix for https://github.com/npm/npm/issues/3265 instead of passing
--forcetonpm install.Always rebuild on changes to npm-shrinkwrap.json files. #1648
Fix uninformative error message when deploying to long hostnames. #1208
Increase a buffer size to avoid failing when running MongoDB due to a large number of processes running on the machine, and fix the error message when the failure does occur. #2158
Clarify a
meteor mongoerror message when using the MONGO_URL environment variable. #1256
Testing
- Run server tests from multiple clients serially instead of in parallel. This allows testing features that modify global server state. #2088
Security
Add Content-Type headers on JavaScript and CSS resources.
Add
X-Content-Type-Options: nosniffheader tobrowser-policy-content's default policy. If you are usingbrowser-policy-contentand you don't want your app to send this header, then callBrowserPolicy.content.allowContentTypeSniffing().Use
Meteor.absoluteUrl()to compute the redirect URL in theforce-sslpackage (instead of the host header).
Miscellaneous
Allow
checkto work on the server outside of a Fiber. #2136EJSON custom type conversion functions should not be permitted to yield. #2136
The legacy polling observe driver handles errors communicating with MongoDB better and no longer gets "stuck" in some circumstances.
Automatically rewind cursors before calls to
fetch,forEach, ormap. On the client, don't cache the return value ofcursor.count()(consistently with the server behavior).cursor.rewind()is now a no-op. #2114Remove an obsolete hack in reporting line numbers for LESS errors. #2216
Avoid exceptions when accessing localStorage in certain Internet Explorer configurations. #1291, #1688.
Make
handle.ready()reactively stop, wherehandleis a subscription handle.Fix an error message from
audit-argument-checksafter login.Make the DDP server send an error if the client sends a connect message with a missing or malformed
supportfield. #2125Fix missing
jquerydependency in theamplifypackage. #2113Ban inserting EJSON custom types as documents. #2095
Fix incorrect URL rewrites in stylesheets. #2106
Upgraded dependencies:
- node: 0.10.28 (from 0.10.26)
- uglify-js: 2.4.13 (from 2.4.7)
- sockjs server: 0.3.9 (from 0.3.8)
- websocket-driver: 0.3.4 (from 0.3.2)
- stylus: 0.46.3 (from 0.42.3)
Patches contributed by GitHub users awwx, babenzele, Cangit, dandv, ducdigital, emgee3, felixrabe, FredericoC, jbruni, kentonv, mizzao, mquandalle, subhog, tbjers, tmeasday.
v0.8.1.3, 2014-05-22
Fix a security issue in the
spiderablepackage.spiderablenow uses the ROOT_URL environment variable instead of the Host header to determine which page to snapshot.Fix hardcoded Twitter URL in
oauth1package. This fixes a regression in 0.8.0.1 that broke Atmosphere packages that do OAuth1 logins. #2154.Add
credentialSecretargument toGoogle.retrieveCredential, which was forgotten in a previous release.Remove nonexistent
-aand-raliases for--addand--removeinmeteor help authorized. #2155Add missing
underscoredependency in theoauth-encryptionpackage. #2165Work around IE8 bug that caused some apps to fail to render when minified. #2037.
v0.8.1.2, 2014-05-12
Fix memory leak (introduced in 0.8.1) by making sure to unregister sessions at the server when they are closed due to heartbeat timeout.
Add
credentialSecretargument toGoogle.retrieveCredential,Facebook.retrieveCredential, etc., which is needed to use them as of 0.8.1. #2118Fix 0.8.1 regression that broke apps using a
ROOT_URLwith a path prefix. #2109
v0.8.1.1, 2014-05-01
Fix 0.8.1 regression preventing clients from specifying
_idon insert. #2097Fix handling of malformed URLs when merging CSS files. #2103, #2093
Loosen the checks on the
optionsargument toCollection.findto allow undefined values.
v0.8.1, 2014-04-30
Meteor Accounts
Fix a security flaw in OAuth1 and OAuth2 implementations. If you are using any OAuth accounts packages (such as
accounts-googleoraccounts-twitter), we recommend that you update immediately and log out your users' current sessions with the following MongoDB command:$ db.users.update({}, { $set: { 'services.resume.loginTokens': [] } }, { multi: true });
OAuth redirect URLs are now required to be on the same origin as your app.
Log out a user's other sessions when they change their password.
Store pending OAuth login results in the database instead of in-memory, so that an OAuth flow succeeds even if different requests go to different server processes.
When validateLoginAttempt callbacks return false, don't override a more specific error message.
Add
Random.secret()for generating security-critical secrets like login tokens.Meteor.logoutOtherClientsnow calls the user callback when other login tokens have actually been removed from the database, not when they have been marked for eventual removal. #1915Rename
OauthtoOAuth.Oauthis now an alias for backwards compatibility.Add
oauth-encryptionpackage for encrypting sensitive account credentials in the database.A validate login hook can now override the exception thrown from
beginPasswordExchangelike it can for other login methods.Remove an expensive observe over all users in the
accounts-basepackage.
Blaze
Disallow
javascript:URLs in URL attribute values by default, to help prevent cross-site scripting bugs. CallUI._allowJavascriptUrls()to allow them.Fix
UI.toHTMLon templates containing{{#with}}.Fix
{{#with}}over a data context that is mutated. #2046Clean up autoruns when calling
UI.toHTML.Properly clean up event listeners when removing templates.
Add support for
{{!-- block comments --}}in Spacebars. Block comments may contain}}, so they are more useful than{{! normal comments}}for commenting out sections of Spacebars templates.Don't dynamically insert
<tbody>tags in reactive tablesWhen handling a custom jQuery event, additional arguments are no longer lost -- they now come after the template instance argument. #1988
DDP and MongoDB
Extend latency compensation to support an arbitrary sequence of inserts in methods. Previously, documents created inside a method stub on the client would eventually be replaced by new documents from the server, causing the screen to flicker. Calling
insertinside a method body now generates the same ID on the client (inside the method stub) and on the server. A sequence of inserts also generates the same sequence of IDs. Code that wants a random stream that is consistent between method stub and real method execution can get one withDDP.randomStream. https://trello.com/c/moiiS2rP/57-pattern-for-creating-multiple-database-records-from-a-methodThe document passed to the
insertcallback ofallowanddenynow only has a_idfield if the client explicitly specified one; this allows you to useallow/denyrules to prevent clients from specifying their own_id. As an exception,allow/denyrules with atransformalways have an_id.DDP now has an implementation of bidirectional heartbeats which is consistent across SockJS and websocket transports. This enables connection keepalive and allows servers and clients to more consistently and efficiently detect disconnection.
The DDP protocol version number has been incremented to "pre2" (adding randomSeed and heartbeats).
The oplog observe driver handles errors communicating with MongoDB better and knows to re-poll all queries after a MongoDB failover.
Fix bugs involving mutating DDP method arguments.
meteor command-line tool
Move boilerplate HTML from tools to webapp. Change internal
Webapp.addHtmlAttributeHookAPI.Add
meteor list-sitescommand for listing the sites that you have deployed to meteor.com with your Meteor developer account.Third-party template languages can request that their generated source loads before other JavaScript files, just like *.html files, by passing the isTemplate option to Plugin.registerSourceHandler.
You can specify a particular interface for the dev mode runner to bind to with
meteor -p host:port.Don't include proprietary tar tags in bundle tarballs.
Convert relative URLs to absolute URLs when merging CSS files.
Upgraded dependencies
- Node.js from 0.10.25 to 0.10.26.
- MongoDB driver from 1.3.19 to 1.4.1
- stylus: 0.42.3 (from 0.42.2)
- showdown: 0.3.1
- css-parse: an unreleased version (from 1.7.0)
- css-stringify: an unreleased version (from 1.4.1)
Patches contributed by GitHub users aldeed, apendua, arbesfeld, awwx, dandv, davegonzalez, emgee3, justinsb, mquandalle, Neftedollar, Pent, sdarnell, and timhaines.
v0.8.0.1, 2014-04-21
- Fix security flaw in OAuth1 implementation. Clients can no longer choose the callback_url for OAuth1 logins.
v0.8.0, 2014-03-27
Meteor 0.8.0 introduces Blaze, a total rewrite of our live templating engine, replacing Spark. Advantages of Blaze include:
- Better interoperability with jQuery plugins and other techniques which directly manipulate the DOM
- More fine-grained updates: only the specific elements or attributes that change are touched rather than the entire template
- A fully documented templating language
- No need for the confusing
{{#constant}},{{#isolate}}, andpreservedirectives - Uses standard jQuery delegation (
.on) instead of our custom implementation - Blaze supports live SVG templates that work just like HTML templates
See the Using Blaze wiki page for full details on upgrading your app to 0.8.0. This includes:
The
Template.foo.renderedcallback is now only called once when the template is rendered, rather than repeatedly as it is "re-rendered", because templates now directly update changed data instead of fully re-rendering.The
accounts-uilogin buttons are now invoked as a{{> loginButtons}}rather than as{{loginButtons}}.Previous versions of Meteor used a heavily modified version of the Handlebars templating language. In 0.8.0, we've given it its own name: Spacebars! Spacebars has an explicit specification instead of being defined as a series of changes to Handlebars. There are some incompatibilities with our previous Handlebars fork, such as a different way of specifying dynamic element attributes and a new way of defining custom block helpers.
Your template files must consist of well-formed HTML. Invalid HTML is now a compilation failure. (There is a current limitation in our HTML parser such that it does not support omitting end tags on elements such as
<P>and<LI>.)Template.foois no longer a function. It is instead a "component". Components render to an intermediate representation of an HTML tree, not a string, so there is no longer an easy way to render a component to a static HTML string.Meteor.renderandSpark.renderhave been removed. UseUI.renderandUI.insertinstead.The
<body>tag now defines a template just like the<template>tag, which can have helpers and event handlers. Define them directly on the objectUI.body.Previous versions of Meteor shipped with a synthesized
tapevent, implementing a zero-delay click event on mobile browsers. Unfortunately, this event never worked very well. We're eliminating it. Instead, use one of the excellent third party solutions.The
madewithpackage (which supported adding a badge to your website displaying its score from http://madewith.meteor.com/) has been removed, as it is not compatible with the new version of that site.The internal
spark,liverange,universal-events, anddomutilspackages have been removed.The
Handlebarsnamespace has been deprecated.Handlebars.SafeStringis nowSpacebars.SafeString, andHandlebars.registerHelperis nowUI.registerHelper.
Patches contributed by GitHub users cmather and mart-jansink.
v0.7.2.3, 2014-12-09 (backport)
- Fix a security issue in allow/deny rules that could result in data loss. If your app uses allow/deny rules, or uses packages that use allow/deny rules, we recommend that you update immediately. Backport from 1.0.1.
v0.7.2.2, 2014-04-21 (backport)
- Fix a security flaw in OAuth1 and OAuth2 implementations. Backport from 0.8.1; see its entry for recommended actions to take.
v0.7.2.1, 2014-04-30 (backport)
- Fix security flaw in OAuth1 implementation. Clients can no longer choose the callback_url for OAuth1 logins. Backport from 0.8.0.1.
v0.7.2, 2014-03-18
Support oplog tailing on queries with the
limitoption. All queries except those containing$nearor$whereselectors or theskipoption can now be used with the oplog driver.Add hooks to login process:
Accounts.onLogin,Accounts.onLoginFailure, andAccounts.validateLoginAttempt. These functions allow for rate limiting login attempts, logging an audit trail, account lockout flags, and more. See: http://docs.meteor.com/#accounts_validateloginattempt #1815Change the
Accounts.registerLoginHandlerAPI for custom login methods. Login handlers now require a name and no longer have to deal with generating resume tokens. See https://github.com/meteor/meteor/blob/devel/packages/accounts-base/accounts_server.js for details. OAuth based login handlers using theOauth.registerServicepackages are not affected.Add support for HTML email in
Accounts.emailTemplates. #1785minimongo: Support
{a: {$elemMatch: {x: 1, $or: [{a: 1}, {b: 1}]}}}#1875minimongo: Support
{a: {$regex: '', $options: 'i'}}#1874minimongo: Fix sort implementation with multiple sort fields which each look inside an array. eg, ensure that with sort key
{'a.x': 1, 'a.y': 1}, the document{a: [{x: 0, y: 4}]}sorts before{a: [{x: 0, y: 5}, {x: 1, y: 3}]}, because the 3 should not be used as a tie-breaker because it is not "next to" the tied 0s.minimongo: Fix sort implementation when selector and sort key share a field, that field matches an array in the document, and only some values of the array match the selector. eg, ensure that with sort key
{a: 1}and selector{a: {$gt: 3}}, the document{a: [4, 6]}sorts before{a: [1, 5]}, because the 1 should not be used as a sort key because it does not match the selector. (We only approximate the MongoDB behavior here by only supporting relatively selectors.)Use
faye-websocket(0.7.2) npm module instead ofwebsocket(1.0.8) for server-to-server DDP.Update Google OAuth package to use new
profileandemailscopes instead of deprecated URL-based scopes. #1887Add
_throwFirstErroroption toDeps.flush.Make
factspackage data available on the server asFacts._factsByPackage.Fix issue where
LESScompilation error could crash themeteor runprocess. #1877Fix crash caused by empty HTTP host header in
meteor rundevelopment server. #1871Fix hot code reload in private browsing mode in Safari.
Fix appcache size calculation to avoid erronious warnings. #1847
Remove unused
Deps._makeNonReactivewrapper function. CallDeps.nonreactivedirectly instead.Avoid setting the
oplogReplayon non-oplog collections. Doing so caused mongod to crash.Add startup message to
test-in-consoleto ease automation. #1884Upgraded dependencies
- amplify: 1.1.2 (from 1.1.0)
Patches contributed by GitHub users awwx, dandv, queso, rgould, timhaines, zol
v0.7.1.2, 2014-02-27
Fix bug in tool error handling that caused
meteorto crash on Mac OSX when no computer name is set.Work around a bug that caused MongoDB to fail an assertion when using tailable cursors on non-oplog collections.
v0.7.1.1, 2014-02-24
Integrate with Meteor developer accounts, a new way of managing your meteor.com deployed sites. When you use
meteor deploy, you will be prompted to create a developer account.- Once you've created a developer account, you can log in and out
from the command line with
meteor loginandmeteor logout. - You can claim legacy sites with
meteor claim. This command will prompt you for your site password if you are claiming a password-protected site; after claiming it, you will not need to enter the site password again. - You can add or remove authorized users, and view the list of
authorized users, for a site with
meteor authorized. - You can view your current username with
meteor whoami. - This release also includes the
accounts-meteor-developerpackage for building Meteor apps that allow users to log in with their own developer accounts.
- Once you've created a developer account, you can log in and out
from the command line with
Improve the oplog tailing implementation for getting real-time database updates from MongoDB.
- Add support for all operators except
$whereand$near. Limit and skip are not supported yet. - Add optimizations to avoid needless data fetches from MongoDB.
- Fix an error ("Cannot call method 'has' of null") in an oplog callback. #1767
- Add support for all operators except
Add and improve support for minimongo operators.
- Support
$comment. - Support
objname in$where. $regexmatches actual regexps properly.- Improve support for
$nin,$ne,$not. - Support using
{ $in: [/foo/, /bar/] }. #1707 - Support
{$exists: false}. - Improve type-checking for selectors.
- Support
{x: {$elemMatch: {$gt: 5}}}. - Match Mongo's behavior better when there are arrays in the document.
- Support
$nearwith sort. - Implement updates with
{ $set: { 'a.$.b': 5 } }. - Support
{$type: 4}queries. - Optimize
remove({})when observers are paused. - Make update-by-id constant time.
- Allow
{$set: {'x._id': 1}}. #1794
- Support
Upgraded dependencies
- node: 0.10.25 (from 0.10.22). The workaround for specific Node versions from 0.7.0 is now removed; 0.10.25+ is supported.
- jquery: 1.11.0 (from 1.8.2). See http://jquery.com/upgrade-guide/1.9/ for upgrade instructions.
- jquery-waypoints: 2.0.4 (from 1.1.7). Contains backwards-incompatible changes.
- source-map: 0.3.2 (from 0.3.30) #1782
- websocket-driver: 0.3.2 (from 0.3.1)
- http-proxy: 1.0.2 (from a pre-release fork of 1.0)
- semver: 2.2.1 (from 2.1.0)
- request: 2.33.0 (from 2.27.0)
- fstream: 0.1.25 (from 0.1.24)
- tar: 0.1.19 (from 0.1.18)
- eachline: a fork of 2.4.0 (from 2.3.3)
- source-map: 0.1.31 (from 0.1.30)
- source-map-support: 0.2.5 (from 0.2.3)
- mongo: 2.4.9 (from 2.4.8)
- openssl in mongo: 1.0.1f (from 1.0.1e)
- kexec: 0.2.0 (from 0.1.1)
- less: 1.6.1 (from 1.3.3)
- stylus: 0.42.2 (from 0.37.0)
- nib: 1.0.2 (from 1.0.0)
- coffeescript: 1.7.1 (from 1.6.3)
CSS preprocessing and sourcemaps:
- Add sourcemap support for CSS stylesheet preprocessors. Use sourcemaps for stylesheets compiled with LESS.
- Improve CSS minification to deal with
@importstatements correctly. - Lint CSS files for invalid
@directives. - Change the recommended suffix for imported LESS files from
.lessimportto.import.less. Add.import.stylto allowstylusimports..lessimportcontinues to work but is deprecated.
Add
clientAddressandhttpHeaderstothis.connectionin method calls and publish functions.Hash login tokens before storing them in the database. Legacy unhashed tokens are upgraded to hashed tokens in the database as they are used in login requests.
Change default accounts-ui styling and add more CSS classes.
Refactor command-line tool. Add test harness and better tests. Run
meteor self-test --helpfor info on running the tools test suite.Speed up application re-build in development mode by re-using file hash computation between file change watching code and application build code..
Fix issues with documents containing a key named
lengthwith a numeric value. Underscore treated these as arrays instead of objects, leading to exceptions when . Patch Underscore to not treat plain objects (x.constructor === Object) with numericlengthfields as arrays. #594 #1737Deprecate
Accounts.loginServiceConfigurationin favor ofServiceConfiguration.configurations, exported by theservice-configurationpackage.Accounts.loginServiceConfigurationis maintained for backwards-compatibility, but it is defined in aMeteor.startupblock and so cannot be used from top-level code.Cursors with a field specifier containing
{_id: 0}can no longer be used withobserveChangesorobserve. This includes the implicit calls to these functions that are done when returning a cursor from a publish function or using{{#each}}.Transform functions must return objects and may not change the
_idfield, though they may leave it out.Remove broken IE7 support from the
localstoragepackage. Meteor accounts logins no longer persist in IE7.Fix the
localstoragepackage when used with Safari in private browsing mode. This fixes a problem with login token storage and account login. #1291Types added with
EJSON.addTypenow have defaultcloneandequalsimplementations. Users may still specifycloneorequalsfunctions to override the default behavior. #1745Add
frame-srctobrowser-policy-contentand account for cross-browser CSP disparities.Deprecate
Oauth.initiateLoginin favor ofOauth.showPopup.Add
WebApp.rawConnectHandlersfor adding connect handlers that run before any other Meteor handlers, exceptconnect.compress(). Raw connect handlers see the URL's full path (even if ROOT_URL contains a non-empty path) and they run before static assets are served.Add
Accounts.connectionto allow using Meteor accounts packages with a non-default DDP connection.Detect and reload if minified CSS files fail to load at startup. This prevents the application from running unstyled if the page load occurs while the server is switching versions.
Allow Npm.depends to specify any http or https URL containing a full 40-hex-digit SHA. #1686
Add
retrypackage for connection retry with exponential backoff.Pass
updateandremovereturn values correctly when using collections validated withallowanddenyrules. #1759If you're using Deps on the server, computations and invalidation functions are not allowed to yield. Throw an error instead of behaving unpredictably.
Fix namespacing in coffeescript files added to a package with the
bare: trueoption. #1668Fix races when calling login and/or logoutOtherClients from multiple tabs. #1616
Include oauth_verifier as a header rather than a parameter in the
oauth1package. #1825Fix
force-sslto allow local development withmeteor runin IPv6 environments. #1751`Allow cursors on named local collections to be returned from a publish function in an array. #1820
Fix build failure caused by a directory in
programs/without a package.js file.Do a better job of handling shrinkwrap files when an npm module depends on something that isn't a semver. #1684
Fix failures updating npm dependencies when a node_modules directory exists above the project directory. #1761
Preserve permissions (eg, executable bit) on npm files. #1808
SockJS tweak to support relative base URLs.
Don't leak sockets on error in dev-mode proxy.
Clone arguments to
addedandchangedmethods in publish functions. This allows callers to reuse objects and prevents already published data from changing after the fact. #1750Ensure springboarding to a different meteor tools version always uses
execto run the old version. This simplifies process management for wrapper scripts.
Patches contributed by GitHub users DenisGorbachev, EOT, OyoKooN, awwx, dandv, icellan, jfhamlin, marcandre, michaelbishop, mitar, mizzao, mquandalle, paulswartz, rdickert, rzymek, timhaines, and yeputons.
v0.7.0.1, 2013-12-20
Two fixes to
meteor runMongo startup bugs that could lead to hangs with the message "Initializing mongo database… this may take a moment.". #1696Apply the Node patch to 0.10.24 as well (see the 0.7.0 section for details).
Fix gratuitous IE7 incompatibility. #1690
v0.7.0, 2013-12-17
This version of Meteor contains a patch for a bug in Node 0.10 which most commonly affects websockets. The patch is against Node version 0.10.22 and 0.10.23. We strongly recommend using one of these precise versions of Node in production so that the patch will be applied. If you use a newer version of Node with this version of Meteor, Meteor will not apply the patch and will instead disable websockets.
Rework how Meteor gets realtime database updates from MongoDB. Meteor now reads the MongoDB "oplog" -- a special collection that records all the write operations as they are applied to your database. This means changes to the database are instantly noticed and reflected in Meteor, whether they originated from Meteor or from an external database client. Oplog tailing is automatically enabled in development mode with
meteor run, and can be enabled in production with theMONGO_OPLOG_URLenvironment variable. Currently the only supported selectors are equality checks;$-operators,limitandskipqueries fall back to the original poll-and-diff algorithm. See https://github.com/meteor/meteor/wiki/Oplog-Observe-Driver for details.Add
Meteor.onConnectionand addthis.connectionto method invocations and publish functions. These can be used to store data associated with individual clients between subscriptions and method calls. See http://docs.meteor.com/#meteor_onconnection for details. #1611Bundler failures cause non-zero exit code in
meteor run. #1515Fix error when publish function callbacks are called during session shutdown.
Rework hot code push. The new
autoupdatepackage drives automatic reloads on update using standard DDP messages instead of a hardcoded message at DDP startup. Now the hot code push only triggers when client code changes; server-only code changes will not cause the page to reload.New
factspackage publishes internal statistics about Meteor.Add an explicit check that publish functions return a cursor, an array of cursors, or a falsey value. This is a safety check to to prevent users from accidentally returning Collection.findOne() or some other value and expecting it to be published.
Implement
$each,$sort, and$sliceoptions for minimongo's$pushmodifier. #1492Introduce
--raw-logsoption tometeor runto disable log coloring and timestamps.Add
WebAppInternals.setBundledJsCssPrefix()to control where the client loads bundled JavaScript and CSS files. This allows serving files from a CDN to decrease page load times and reduce server load.Attempt to exit cleanly on
SIGHUP. Stop accepting incoming connections, kill DDP connections, and finish all outstanding requests for static assets.In the HTTP server, only keep sockets with no active HTTP requests alive for 5 seconds.
Fix handling of
fieldsoption in minimongo when only_idis present. #1651Fix issue where setting
process.env.MAIL_URLin app code would not alter where mail was sent. This was a regression in 0.6.6 from 0.6.5. #1649Use stderr instead of stdout (for easier automation in shell scripts) when prompting for passwords and when downloading the dev bundle. #1600
Ensure more downtime during file watching. #1506
Fix
meteor runwith settings files containing non-ASCII characters. #1497Support
EJSON.cloneforMeteor.Error. As a result, they are properly stringified in DDP even if thrown through aFuture. #1482Fix passing
transform: nulloption tocollection.allow()to disable transformation in validators. #1659Fix livedata error on
this.removedduring session shutdown. #1540 #1553Fix incompatibility with Phusion Passenger by removing an unused line. #1613
Ensure install script creates /usr/local on machines where it does not exist (eg. fresh install of OSX Mavericks).
Set x-forwarded-* headers in
meteor run.Clean up package dirs containing only ".build".
Check for matching hostname before doing end-of-oauth redirect.
Only count files that actually go in the cache towards the
appcachesize check. #1653.Increase the maximum size spiderable will return for a page from 200kB to 5MB.
Upgraded dependencies:
- SockJS server from 0.3.7 to 0.3.8, including new faye-websocket module.
- Node from 0.10.21 to 0.10.22
- MongoDB from 2.4.6 to 2.4.8
- clean-css from 1.1.2 to 2.0.2
- uglify-js from a fork of 2.4.0 to 2.4.7
- handlebars npm module no longer available outside of handlebars package
Patches contributed by GitHub users AlexeyMK, awwx, dandv, DenisGorbachev, emgee3, FooBarWidget, mitar, mcbain, rzymek, and sdarnell.
v0.6.6.3, 2013-11-04
Fix error when publish function callbacks are called during session shutdown. #1540 #1553
Improve
meteor runCPU usage in projects with many directories. #1506
v0.6.6.2, 2013-10-21
- Upgrade Node from 0.10.20 to 0.10.21 (security update).
v0.6.6.1, 2013-10-12
v0.6.6, 2013-10-10
Security
Add
browser-policypackage for configuring and sending Content-Security-Policy and X-Frame-Options HTTP headers. See the docs for more.Use cryptographically strong pseudorandom number generators when available.
MongoDB
Add upsert support.
Collection.updatenow supports the{upsert: true}option. Additionally, add aCollection.upsertmethod which returns the newly inserted object id if applicable.updateandremovenow return the number of documents affected. #1046$nearoperator for2dand2dsphereindices.The
fieldsoption to the collection methodsfindandfindOnenow works on the client as well. (Operators such as$elemMatchand$are not yet supported infieldsprojections.) #1287Pass an index and the cursor itself to the callbacks in
cursor.forEachandcursor.map, just like the correspondingArraymethods. #63Support
c.find(query, {limit: N}).count()on the client. #654Improve behavior of
$ne,$nin, and$notselectors with objects containing arrays. #1451Fix various bugs if you had two documents with the same _id field in String and ObjectID form.
Accounts
[Behavior Change] Expire login tokens periodically. Defaults to 90 days. Use
Accounts.config({loginExpirationInDays: null})to disable token expiration.[Behavior Change] Write dates generated by Meteor Accounts to Mongo as Date instead of number; existing data can be converted by passing it through
new Date(). #1228Log out and close connections for users if they are deleted from the database.
Add Meteor.logoutOtherClients() for logging out other connections logged in as the current user.
restrictCreationByEmailDomainoption inAccounts.configto restrict new users to emails of specific domain (eg. only users with @meteor.com emails) or a custom validator. #1332Support OAuth1 services that require request token secrets as well as authentication token secrets. #1253
Warn if
Accounts.configis only called on the client. #828Fix bug where callbacks to login functions could be called multiple times when the client reconnects.
DDP
Fix infinite loop if a client disconnects while a long yielding method is running.
Unfinished code to support DDP session resumption has been removed. Meteor servers now stop processing messages from clients and reclaim memory associated with them as soon as they are disconnected instead of a few minutes later.
Tools
The pre-0.6.5
Package.register_extensionAPI has been removed. UsePackage._transitional_registerBuildPlugininstead, which was introduced in 0.6.5. (A bug prevented the 0.6.5 reimplementation ofregister_extensionfrom working properly anyway.)Support using an HTTP proxy in the
meteorcommand line tool. This allows theupdate,deploy,logs, andmongocommands to work behind a proxy. Use the standardhttp_proxyenvironment variable to specify your proxy endpoint. #429, #689, #1338Build Linux binaries on an older Linux machine. Meteor now supports running on Linux machines with glibc 2.9 or newer (Ubuntu 10.04+, RHEL and CentOS 6+, Fedora 10+, Debian 6+). Improve error message when running on Linux with unsupported glibc, and include Mongo stderr if it fails to start.
Install NPM modules with
--forceto avoid corrupted local caches.Rebuild NPM modules in packages when upgrading to a version of Meteor that uses a different version of Node.
Disable the Mongo http interface. This lets you run meteor on two ports differing by 1000 at the same time.
Misc
[Known issue] Breaks support for pre-release OSX 10.9 'Mavericks'. Will be addressed shortly. See issues: https://github.com/joyent/node/issues/6251 https://github.com/joyent/node/issues/6296
EJSON.stringifynow takes options:canonicalcauses objects keys to be stringified in sorted orderindentallows formatting control over the EJSON stringification
EJSON now supports
Infinity,-InfinityandNaN.Check that the argument to
EJSON.parseis a string. #1401Better error from functions that use
Meteor._wrapAsync(eg collection write methods andHTTPmethods) and in DDP server message processing. #1387Support
appcacheon Chrome for iOS.Support literate CoffeeScript files with the extension
.coffee.md(in addition to the already-supported.litcoffeeextension). #1407Make
madewithpackage work again (broken in 0.6.5). #1448Better error when passing a string to
{{#each}}. #722Add support for JSESSIONID cookies for sticky sessions. Set the
USE_JSESSIONIDenvironment variable to enable placing a JSESSIONID cookie on sockjs requests.Simplify the static analysis used to detect package-scope variables.
Upgraded dependencies:
- Node from 0.8.24 to 0.10.20
- MongoDB from 2.4.4 to 2.4.6
- MongoDB driver from 1.3.17 to 1.3.19
- http-proxy from 0.10.1 to a pre-release of 1.0.0
- stylus from 0.30.1 to 0.37.0
- nib from 0.8.2 to 1.0.0
- optimist from 0.3.5 to 0.6.0
- semver from 1.1.0 to 2.1.0
- request from 2.12.0 to 2.27.0
- keypress from 0.1.0 to 0.2.1
- underscore from 1.5.1 to 1.5.2
- fstream from 0.1.21 to 0.1.24
- tar from 0.1.14 to 0.1.18
- source-map from 0.1.26 to 0.1.30
- source-map-support from a fork of 0.1.8 to 0.2.3
- escope from a fork of 0.0.15 to 1.0.0
- estraverse from 1.1.2-1 to 1.3.1
- simplesmtp from 0.1.25 to 0.3.10
- stream-buffers from 0.2.3 to 0.2.5
- websocket from 1.0.7 to 1.0.8
- cli-color from 0.2.2 to 0.2.3
- clean-css from 1.0.11 to 1.1.2
- UglifyJS2 from a fork of 2.3.6 to a different fork of 2.4.0
- connect from 2.7.10 to 2.9.0
- send from 0.1.0 to 0.1.4
- useragent from 2.0.1 to 2.0.7
- replaced byline with eachline 2.3.3
Patches contributed by GitHub users ansman, awwx, codeinthehole, jacott, Maxhodges, meawoppl, mitar, mizzao, mquandalle, nathan-muir, RobertLowe, ryw, sdarnell, and timhaines.
v0.6.5.3, 2014-12-09 (backport)
- Fix a security issue in allow/deny rules that could result in data loss. If your app uses allow/deny rules, or uses packages that use allow/deny rules, we recommend that you update immediately. Backport from 1.0.1.
v0.6.5.2, 2013-10-21
- Upgrade Node from 0.8.24 to 0.8.26 (security patch)
v0.6.5.1, 2013-08-28
Fix syntax errors on lines that end with a backslash. #1326
Fix serving static files with special characters in their name. #1339
Upgrade
esprimaJavaScript parser to fix bug parsing complex regexps.Export
Spiderablefromspiderablepackage to allow users to setSpiderable.userAgentRegExpsto control what user agents are treated as spiders.Add EJSON to standard-app-packages. #1343
Fix bug in d3 tab character parsing.
Fix regression when using Mongo ObjectIDs in Spark templates.
v0.6.5, 2013-08-14
New package system with package compiler and linker:
Each package now has it own namespace for variable declarations. Global variables used in a package are limited to package scope.
Packages must explicitly declare which symbols they export with
api.exportinpackage.js.Apps and packages only see the exported symbols from packages they explicitly use. For example, if your app uses package A which in turn depends on package B, only package A's symbols will be available in the app.
Package names can only contain alphanumeric characters, dashes, and dots. Packages with spaces and underscores must be renamed.
Remove hardcoded list of required packages. New default
standard-app-packagespackage adds dependencies on the core Meteor stack. This package can be removed to make an app with only parts of the Meteor stack.standard-app-packageswill be automatically added to a project when it is updated to Meteor 0.6.5.Custom app packages in the
packagesdirectory are no longer automatically used. They must be explicitly added to the app withmeteor add <packagename>. To help with the transition, all packages in thepackagesdirectory will be automatically added to the project when it is updated to Meteor 0.6.5.New "unipackage" on-disk format for built packages. Compiled packages are cached and rebuilt only when their source or dependencies change.
Add "unordered" and "weak" package dependency modes to allow circular package dependencies and conditional code inclusion.
New API (
_transitional_registerBuildPlugin) for declaring compilers, preprocessors, and file extension handlers. These new build plugins are full compilation targets in their own right, and have their own namespace, source files, NPM requirements, and package dependencies. The oldregister_extensionAPI is deprecated. Please note that thepackage.jsformat and especially_transitional_registerBuildPluginare not frozen interfaces and are subject to change in future releases.Add
api.imply, which allows one package to "imply" another. If package A implies package B, then anything that depends on package A automatically depends on package B as well (and receives package B's imports). This is useful for creating umbrella packages (standard-app-packages) or sometimes for factoring common code out of related packages (accounts-base).
Move HTTP serving out of the server bootstrap and into the
webapppackage. This allows building Meteor apps that are not web servers (eg. command line tools, DDP clients, etc.). Connect middlewares can now be registered on the newWebApp.connectHandlersinstead of the old__meteor_bootstrap__.app.The entire Meteor build process now has first-class source map support. A source map is maintained for every source file as it passes through the build pipeline. Currently, the source maps are only served in development mode. Not all web browsers support source maps yet and for those that do, you may have to turn on an option to enable them. Source maps will always be used when reporting exceptions on the server.
Update the
coffeescriptpackage to generate source maps.Add new
AssetsAPI andprivatesubdirectory for including and accessing static assets on the server. http://docs.meteor.com/#assetsAdd
Meteor.disconnect. Call this to disconnect from the server and stop all live data updates. #1151Add
Match.Integertocheckfor 32-bit signed integers.Meteor.connecthas been renamed toDDP.connectand is now fully supported on the server. Server-to-server DDP connections use websockets, and can be used for both method calls and subscriptions.Rename
Meteor.default_connectiontoMeteor.connectionandMeteor.default_servertoMeteor.server.Rename
Meteor.httptoHTTP.ROOT_URLmay now have a path part. This allows serving multiple Meteor apps on the same domain.Support creating named unmanaged collections with
new Meteor.Collection("name", {connection: null}).New
Logfunction in theloggingpackage which prints with timestamps, color, filenames and linenumbers.Include http response in errors from oauth providers. #1246
The
observecallbackmovedTonow has a fourth argumentbefore.Move NPM control files for packages from
.npmto.npm/package. This is to allow build plugins such ascoffeescriptto depend on NPM packages. Also, when removing the last NPM dependency, clean up the.npmdir.Remove deprecated
Meteor.is_clientandMeteor.is_servervariables.Implement "meteor bundle --debug" #748
Add
forceApprovalPromptoption toMeteor.loginWithGoogle. #1226Make server-side Mongo
inserts,updates, andremoves run asynchronously when a callback is passed.Improve memory usage when calling
findOne()on the server.Delete login tokens from server when user logs out.
Rename package compatibility mode option to
add_filesfromrawtobare.Fix Mongo selectors of the form: {$regex: /foo/}.
Fix Spark memory leak. #1157
Fix EPIPEs during dev mode hot code reload.
Fix bug where we would never quiesce if we tried to revive subs that errored out (5e7138d)
Fix bug where
this.fieldnamein handlebars template might refer to a helper instead of a property of the current data context. #1143Fix submit events on IE8. #1191
Handle
Meteor.loginWithXbeing called with a callback but no options. #1181Work around a Chrome bug where hitting reload could cause a tab to lose the DDP connection and never recover. #1244
Upgraded dependencies:
- Node from 0.8.18 to 0.8.24
- MongoDB from 2.4.3 to 2.4.4, now with SSL support
- CleanCSS from 0.8.3 to 1.0.11
- Underscore from 1.4.4 to 1.5.1
- Fibers from 1.0.0 to 1.0.1
- MongoDB Driver from 1.3.7 to 1.3.17
Patches contributed by GitHub users btipling, mizzao, timhaines and zol.
v0.6.4.1, 2013-07-19
- Update mongodb driver to use version 0.2.1 of the bson module.
v0.6.4, 2013-06-10
Separate OAuth flow logic from Accounts into separate packages. The
facebook,github,google,meetup,twitter, andweibopackages can be used to perform an OAuth exchange without creating an account and logging in. #1024If you set the
DISABLE_WEBSOCKETSenvironment variable, browsers will not attempt to connect to your app using Websockets. Use this if you know your server environment does not properly proxy Websockets to reduce connection startup time.Make
Meteor.deferwork in an inactive tab in iOS. #1023Allow new
Randominstances to be constructed with specified seed. This can be used to create repeatable test cases for code that picks random values. #1033Fix CoffeeScript error reporting to include source file and line number again. #1052
Fix Mongo queries which nested JavaScript RegExp objects inside
$or. #1089Upgraded dependencies:
Patches contributed by GitHub users awwx, johnston, and timhaines.
v0.6.3, 2013-05-15
Add new
checkpackage for ensuring that a value matches a required type and structure. This is used to validate untrusted input from the client. See http://docs.meteor.com/#match for details.Use Websockets by default on supported browsers. This reduces latency and eliminates the constant network spinner on iOS devices.
With
autopublishon, publish many useful fields onMeteor.users.Files in the
client/compatibility/subdirectory of a Meteor app do not get wrapped in a new variable scope. This is useful for third-party libraries which expectvarstatements at the outermost level to be global.Add synthetic
tapevent for use on touch enabled devices. This is a replacement forclickthat fires immediately.When using the
httppackage synchronously on the server, errors are thrown rather than passed inresult.errorThe
manageroption to theMeteor.Collectionconstructor is now calledconnection. The old name still works for now. #987The
localstorage-polyfillsmart package has been replaced by alocalstoragepackage, which defines aMeteor._localStorageAPI instead of trying to replace the DOMwindow.localStoragefacility. (Now, apps can use the existence ofwindow.localStorageto detect if the full localStorage API is supported.) #979Upgrade MongoDB from 2.2.1 to 2.4.3.
Upgrade CoffeeScript from 1.5.0 to 1.6.2. #972
Faster reconnects when regaining connectivity. #696
Email.sendhas a newheadersoption to set arbitrary headers. #963Cursor transform functions on the server no longer are required to return objects with correct
_idfields. #974Rework
observe()callback ordering in minimongo to improve fiber safety on the server. This makes subscriptions on server to server DDP more usable.Use binary search in minimongo when updating ordered queries. #969
Fix EJSON base64 decoding bug. #1001
Support
appcacheon Chromium. #958
Patches contributed by GitHub users awwx, jagill, spang, and timhaines.
v0.6.2.1, 2013-04-24
- When authenticating with GitHub, include a user agent string. This unbreaks "Sign in with GitHub"
Patch contributed by GitHub user pmark.
v0.6.2, 2013-04-16
Better error reporting:
- Capture real stack traces for
Meteor.Error. - Report better errors with misconfigured OAuth services.
- Capture real stack traces for
Add per-package upgrade notices to
meteor update.Experimental server-to-server DDP support:
Meteor.connecton the server will connect to a remote DDP endpoint via WebSockets. Method calls should work fine, but subscriptions and minimongo on the server are still a work in progress.Upgrade d3 from 2.x to 3.1.4. See https://github.com/mbostock/d3/wiki/Upgrading-to-3.0 for compatibility notes.
Allow CoffeeScript to set global variables when using
use strict. #933Return the inserted documented ID from
LocalCollection.insert. #908Add Weibo token expiration time to
services.weibo.expiresAt.Spiderable.userAgentRegExpscan now be modified to change what user agents are treated as spiders by thespiderablepackage.Prevent observe callbacks from affecting the arguments to identical observes. #855
Fix meteor command line tool when run from a home directory with spaces in its name. If you previously installed meteor release 0.6.0 or 0.6.1 you'll need to uninstall and reinstall meteor to support users with spaces in their usernames (see https://github.com/meteor/meteor/blob/master/README.md#uninstalling-meteor)
Patches contributed by GitHub users andreas-karlsson, awwx, jacott, joshuaconner, and timhaines.
v0.6.1, 2013-04-08
Correct NPM behavior in packages in case there is a
node_modulesdirectory somewhere above the app directory. #927Small bug fix in the low-level
routepolicypackage.
Patches contributed by GitHub users andreas-karlsson and awwx.
v0.6.0, 2013-04-04
Meteor has a brand new distribution system! In this new system, code-named Engine, packages are downloaded individually and on demand. All of the packages in each official Meteor release are prefetched and cached so you can still use Meteor while offline. You can have multiple releases of Meteor installed simultaneously; apps are pinned to specific Meteor releases. All
meteorcommands accept a--releaseargument to specify which release to use;meteor updatechanges what release the app is pinned to. Inside an app, the name of the release is available atMeteor.release. When running Meteor directly from a git checkout, the release is ignored.Variables declared with
varat the outermost level of a JavaScript source file are now private to that file. Remove thevarto share a value between files.Meteor now supports any x86 (32- or 64-bit) Linux system, not just those which use Debian or RedHat package management.
Apps may contain packages inside a top-level directory named
packages.Packages may depend on NPM modules, using the new
Npm.dependsdirective in theirpackage.jsfile. (Note: if the NPM module has architecture-specific binary components, bundles built withmeteor bundleormeteor deploywill contain the components as built for the developer's platform and may not run on other platforms.)Meteor's internal package tests (as well as tests you add to your app's packages with the unsupported
Tinytestframework) are now run with the new commandmeteor test-packages.{{#each}}helper can now iterate over falsey values without throwing an exception. #815, #801{{#with}}helper now only includes its block if its argument is not falsey, and runs an{{else}}block if provided if the argument is falsey. #770, #866Twitter login now stores
profile_image_urlandprofile_image_url_httpsattributes in theuser.services.twitternamespace. #788Allow packages to register file extensions with dots in the filename.
When calling
this.changedin a publish function, it is no longer an error to clear a field which was never set. #850Deps API
- Add
dep.depend(), deprecateDeps.depend(dep)anddep.addDependent(). - If first run of
Deps.autorunthrows an exception, stop it and don't rerun. This prevents a Spark exception when template rendering fails ("Can't call 'firstNode' of undefined"). - If an exception is thrown during
Deps.flushwith no stack, the message is logged instead. #822
- Add
When connecting to MongoDB, use the JavaScript BSON parser unless specifically requested in
MONGO_URL; the native BSON parser sometimes segfaults. (Meteor only started using the native parser in 0.5.8.)Calls to the
updatecollection function in untrusted code may only use a whitelisted list of modifier operators.
Patches contributed by GitHub users awwx, blackcoat, cmather, estark37, mquandalle, Primigenus, raix, reustle, and timhaines.
v0.5.9, 2013-03-14
Fix regression in 0.5.8 that prevented users from editing their own profile. #809
Fix regression in 0.5.8 where
Meteor.loggingIn()would not update reactively. #811
v0.5.8, 2013-03-13
Calls to the
updateandremovecollection functions in untrusted code may no longer use arbitrary selectors. You must specify a single document ID when invoking these functions from the client (other than in a method stub).You may still use other selectors when calling
updateandremoveon the server and from client method stubs, so you can replace calls that are no longer supported (eg, in event handlers) with custom method calls.The corresponding
updateandremovecallbacks passed toallowanddenynow take a single document instead of an array.Add new
appcachepackage. Add this package to your project to speed up page load and make hot code reload smoother using the HTML5 AppCache API. See http://docs.meteor.com/#appcache for details.Rewrite reactivity library.
Meteor.depsis nowDepsand has a new API.Meteor.autorunandMeteor.flushare now calledDeps.autorunandDeps.flush(the old names still work for now). The other names underMeteor.depssuch asContextno longer exist. The new API is documented at http://docs.meteor.com/#depsYou can now provide a
transformoption to collections, which is a function that documents coming out of that collection are passed through.find,findOne,allow, anddenynow taketransformoptions, which may override the Collection'stransform. Specifying atransformofnullcauses you to receive the documents unmodified.Publish functions may now return an array of cursors to publish. Currently, the cursors must all be from different collections. #716
User documents have id's when
onCreateUserandvalidateNewUserhooks run.Encode and store custom EJSON types in MongoDB.
Support literate CoffeeScript files with the extension
.litcoffee. #766Add new login service provider for Meetup.com in
accounts-meetuppackage.If you call
observeorobserveChangeson a cursor created with thereactive: falseoption, it now only calls initial add callbacks and does not continue watching the query. #771In an event handler, if the data context is falsey, default it to
{}rather than to the global object. #777Allow specifying multiple event handlers for the same selector. #753
Revert caching header change from 0.5.5. This fixes image flicker on redraw.
Stop making
Sessionavailable on the server; it's not useful there. #751Force URLs in stack traces in browser consoles to be hyperlinks. #725
Suppress spurious
changedcallbacks with emptyfieldsfromCursor.observeChanges.Fix logic bug in template branch matching. #724
Make
spiderableuser-agent test case insensitive. #721Fix several bugs in EJSON type support:
- Fix
{$type: 5}selectors for binary values on browsers that do not supportUint8Array. - Fix EJSON equality on falsey values.
- Fix for returning a scalar EJSON type from a method. #731
- Fix
Upgraded dependencies:
- mongodb driver to version 1.2.13 (from 0.1.11)
- mime module removed (it was unused)
Patches contributed by GitHub users awwx, cmather, graemian, jagill, jmhredsox, kevinxucs, krizka, mitar, raix, and rasmuserik.
v0.5.7, 2013-02-21
The DDP wire protocol has been redesigned.
The handshake message is now versioned. This breaks backwards compatibility between sites with
Meteor.connect(). Older meteor apps can not talk to new apps and vice versa. This includes themadewithpackage, apps usingmadewithmust upgrade.New EJSON package allows you to use Dates, Mongo ObjectIDs, and binary data in your collections and Session variables. You can also add your own custom datatypes.
Meteor now correctly represents empty documents in Collections.
There is an informal specification in
packages/livedata/DDP.md.
Breaking API changes
Changed the API for
observe. Observing withadded,changedandremovedcallbacks is now unordered; for ordering information useaddedAt,changedAt,removedAt, andmovedTo. Full documentation is in theobservedocs. All callers ofobserveneed to be updated.Changed the API for publish functions that do not return a cursor (ie functions that call
this.setandthis.unset). See thepublishdocs for the new API.
New Features
Added new
observeChangesAPI for keeping track of the contents of a cursor more efficiently.There is a new reactive function on subscription handles:
ready()returns true when the subscription has received all of its initial documents.Added
Session.setDefault(key, value)so you can easily provide initial values for session variables that will not be clobbered on hot code push.You can specify that a collection should use MongoDB ObjectIDs as its
_idfields for inserts instead of strings. This allows you to use Meteor with existing MongoDB databases that have ObjectID_ids. If you do this, you must useEJSON.equals()for comparing equality instead of===. See http://docs.meteor.com/#meteor_collection.New
randompackage provides several functions for generating random values. The newRandom.id()function is used to provide shorter string IDs for MongoDB documents.Meteor.uuid()is deprecated.Meteor.status()can return the statusfailedif DDP version negotiation fails.
Major Performance Enhancements
Rewrote subscription duplication detection logic to use a more efficient algorithm. This significantly reduces CPU usage on the server during initial page load and when dealing with large amounts of data.
Reduced unnecessary MongoDB re-polling of live queries. Meteor no longer polls for changes on queries that specify
_idwhen updates for a different specific_idare processed. This drastically improves performance when dealing with many subscriptions and updates to individual objects, such as those generated by theaccounts-basepackage on theMeteor.userscollection.
Upgraded UglifyJS2 to version 2.2.5
Patches contributed by GitHub users awwx and michaelglenadams.
v0.5.6, 2013-02-15
Fix 0.5.5 regression: Minimongo selectors matching subdocuments under arrays did not work correctly.
Some Bootstrap icons should have appeared white.
Patches contributed by GitHub user benjaminchelli.
v0.5.5, 2013-02-13
Deprecate
Meteor.autosubscribe.Meteor.subscribenow works withinMeteor.autorun.Allow access to
Meteor.settings.publicon the client. If the JSON file you gave tometeor --settingsincludes a field calledpublic, that field will be available on the client as well as the server.@importworks inless. Use the.lessimportfile extension to make a less file that is ignored by preprocessor so as to avoid double processing. #203Upgrade Fibers to version 1.0.0. The
FiberandFuturesymbols are no longer exposed globally. To use fibers directly you can use:var Fiber = __meteor_bootstrap__.require('fibers');andvar Future = __meteor_bootstrap__.require('fibers/future');Call version 1.1 of the Twitter API when authenticating with OAuth.
accounts-twitterusers have until March 5th, 2013 to upgrade before Twitter disables the old API. #527Treat Twitter ids as strings, not numbers, as recommended by Twitter. #629
You can now specify the
_idfield of a document passed toinsert. Meteor still auto-generates_idif it is not present.Expose an
invalidatedflag onMeteor.deps.Context.Populate user record with additional data from Facebook and Google. #664
Add Facebook token expiration time to
services.facebook.expiresAt. #576Allow piping a password to
meteor deployonstdin. #623Correctly type cast arguments to handlebars helper. #617
Fix leaked global
userIdsymbol.Terminate
phantomjsproperly on error when using thespiderablepackage. #571Stop serving non-cachable files with caching headers. #631
Fix race condition if server restarted between page load and initial DDP connection. #653
Resolve issue where login methods sometimes blocked future methods. #555
Fix
Meteor.httpparsing of JSON responses on Firefox. #553Minimongo no longer uses
eval. #480Serve 404 for
/app.manifest. This allows experimenting with the upcomingappcachesmart package. #628Upgraded many dependencies, including:
- node.js to version 0.8.18
- jquery-layout to version 1.3.0RC
- Twitter Bootstrap to version 2.3.0
- Less to version 1.3.3
- Uglify to version 2.2.3
- useragent to version 2.0.1
Patches contributed by GitHub users awwx, bminer, bramp, crunchie84, danawoodman, dbimmler, Ed-von-Schleck, geoffd123, jperl, kevee, milesmatthias, Primigenus, raix, timhaines, and xenolf.
v0.5.4, 2013-01-08
- Fix 0.5.3 regression:
meteor runcould fail on OSX 10.8 if environment variables such asDYLD_LIBRARY_PATHare set.
v0.5.3, 2013-01-07
Add
--settingsargument tometeor deployandmeteor run. This allows you to specify deployment-specific information made available to server code in the variableMeteor.settings.Support unlimited open tabs in a single browser. Work around the browser per-hostname connection limit by using randomized hostnames for deployed apps. #131
minimongo improvements:
Re-rendering a template with Spark no longer reverts changes made by users to a
preserved form element. Instead, the newly rendered value is only applied if it is different from the previously rendered value. Additionally,<INPUT>elements with type other than TEXT can now have reactive values (eg, the labels on submit buttons can now be reactive). #510 #514 #523 #537 #558Support JavaScript RegExp objects in selectors in Collection write methods on the client, eg
myCollection.remove({foo: /bar/}). #346meteorcommand-line improvements:- Improve error message when mongod fails to start.
- The
NODE_OPTIONSenvironment variable can be used to pass command-line flags to node (eg,--debugor--debug-brkto enable the debugger). - Die with error if an app name is mistakenly passed to
meteor reset.
Add support for "offline" access tokens with Google login. #464 #525
Don't remove
serviceDatafields from previous logins when logging in with an external service.Improve
OAuth1Bindingto allow making authenticated API calls to OAuth1 providers (eg Twitter). #539New login providers automatically work with
{{loginButtons}}without needing to edit theaccounts-ui-unstyledpackage. #572Use
Content-Type: application/jsonby default when sending JSON data withMeteor.http.Improvements to
jsparse: hex literals, keywords as property names, ES5 line continuations, trailing commas in object literals, line numbers in error messages, decimal literals starting with., regex character classes with slashes.Spark improvements:
Always use the
autoReconnectflag when connecting to Mongo. #425Fix server-side
observewith noaddedcallback. #589Fix re-sending method calls on reconnect. #538
Remove deprecated
/sockjsURL support fromMeteor.connect.Avoid losing a few bits of randomness in UUID v4 creation. #519
Update clean-css package from 0.8.2 to 0.8.3, fixing minification of
0%values inhslcolors. #515
Patches contributed by GitHub users Ed-von-Schleck, egtann, jwulf, lvbreda, martin-naumann, meawoppl, nwmartin, timhaines, and zealoushacker.
v0.5.2, 2012-11-27
- Fix 0.5.1 regression: Cursor
observeworks during server startup. #507
v0.5.1, 2012-11-20
Speed up server-side subscription handling by avoiding redundant work when the same Mongo query is observed multiple times concurrently (eg, by multiple users subscribing to the same subscription), and by using a simpler "unordered" algorithm.
Meteor now waits to invoke method callbacks until all the data written by the method is available in the local cache. This way, method callbacks can see the full effects of their writes. This includes the callbacks passed to
Meteor.callandMeteor.apply, as well as to theMeteor.Collectioninsert/update/removemethods.If you want to process the method's result as soon as it arrives from the server, even if the method's writes are not available yet, you can now specify an
onResultReceivedcallback toMeteor.apply.Rework latency compensation to show server data changes sooner. Previously, as long as any method calls were in progress, Meteor would buffer all data changes sent from the server until all methods finished. Meteor now only buffers writes to documents written by client stubs, and applies the writes as soon as all methods that wrote that document have finished.
Meteor.userLoaded()and{{currentUserLoaded}}have been removed. Previously, during the login process on the client,Meteor.userId()could be set but the document atMeteor.user()could be incomplete. Meteor provided the functionMeteor.userLoaded()to differentiate between these states. Now, this in-between state does not occur: when a user logs in,Meteor.userId()only is set onceMeteor.user()is fully loaded.New reactive function
Meteor.loggingIn()and template helper{{loggingIn}}; they are true whenever some login method is in progress.accounts-uinow uses this to show an animation during login.The
sassCSS preprocessor package has been removed. It was based on an unmaintained NPM module which did not implement recent versions of the Sass language and had no error handling. Consider using thelessorstyluspackages instead. #143Meteor.setPasswordis now calledAccounts.setPassword, matching the documentation and original intention. #454Passing the
waitoption toMeteor.applynow waits for all in-progress method calls to finish before sending the method, instead of only guaranteeing that its callback occurs after the callbacks of in-progress methods.New function
Accounts.callLoginMethodwhich should be used to call custom login handlers (such as those registered withAccounts.registerLoginHandler).The callbacks for
Meteor.loginWithTokenandAccounts.createUsernow match the other login callbacks: they are called with error on error or with no arguments on success.Fix bug where method calls could be dropped during a brief disconnection. #339
Prevent running the
meteorcommand-line tool and server on unsupported Node versions.Fix Minimongo query bug with nested objects. #455
In
accounts-ui, stop page layout from changing during login.Use
path.joininstead of/in paths (helpful for the unofficial Windows port) #303The
spiderablepackage serves pages tofacebookexternalhit#411Fix error on Firefox with DOM Storage disabled.
Avoid invalidating listeners if setUserId is called with current value.
Upgrade many dependencies, including:
- MongoDB 2.2.1 (from 2.2.0)
- underscore 1.4.2 (from 1.3.3)
- bootstrap 2.2.1 (from 2.1.1)
- jQuery 1.8.2 (from 1.7.2)
- less 1.3.1 (from 1.3.0)
- stylus 0.30.1 (from 0.29.0)
- coffee-script 1.4.0 (from 1.3.3)
Patches contributed by GitHub users ayal, dandv, possibilities, TomWij, tmeasday, and workmad3.
v0.5.0, 2012-10-17
This release introduces Meteor Accounts, a full-featured auth system that supports
- fine-grained user-based control over database reads and writes
- federated login with any OAuth provider (with built-in support for Facebook, GitHub, Google, Twitter, and Weibo)
- secure password login
- email validation and password recovery
- an optional set of UI widgets implementing standard login/signup/password change/logout flows
When you upgrade to Meteor 0.5.0, existing apps will lose the ability to write to the database from the client. To restore this, either:
- configure each of your collections with
collection.allowandcollection.denycalls to specify which users can perform which write operations, or - add the
insecuresmart package (which is included in new apps by default) to restore the old behavior where anyone can write to any collection which has not been configured withallowordeny
For more information on Meteor Accounts, see http://docs.meteor.com/#dataandsecurity and http://docs.meteor.com/#accounts_api
The new function
Meteor.autorunallows you run any code in a reactive context. See http://docs.meteor.com/#meteor_autorunArrays and objects can now be stored in the
Session; mutating the value you retrieve withSession.getdoes not affect the value in the session.On the client,
Meteor.applytakes a newwaitoption, which ensures that no further method calls are sent to the server until this method is finished; it is used for login and logout methods in order to keep the user ID well-defined. You can also specify anonReconnecthandler which is run when re-establishing a connection; Meteor Accounts uses this to log back in on reconnect.Meteor now provides a compatible replacement for the DOM
localStoragefacility that works in IE7, in thelocalstorage-polyfillsmart package.Meteor now packages the D3 library for manipulating documents based on data in a smart package called
d3.Meteor.Collectionnow takes its optionalmanagerargument (used to associate a collection with a server you've connected to withMeteor.connect) as a named option. (The old call syntax continues to work for now.)Fix a bug where trying to immediately resubscribe to a record set after unsubscribing could fail silently.
Better error handling for failed Mongo writes from inside methods; previously, errors here could cause clients to stop processing data from the server.
Patches contributed by GitHub users bradens, dandv, dybskiy, possibilities, zhangcheng, and 75lb.
v0.4.2, 2012-10-02
Fix connection failure on iOS6. SockJS 0.3.3 includes this fix.
The new
preserve-inputspackage, included by default in new Meteor apps, restores the pre-v0.4.0 behavior of "preserving" all form input elements by ID and name during re-rendering; users who want more precise control over preservation can still use the APIs added in v0.4.0.A few changes to the
Meteor.absoluteUrlfunction:- Added a
replaceLocalhostoption. - The
ROOT_URLenvironment variable is respected bymeteor run. - It is now included in all apps via the
meteorpackage. Apps that explicitly added the now-deprecatedabsolute-urlsmart package will log a deprecation warning.
- Added a
Upgrade Node from 0.8.8 to 0.8.11.
If a Handlebars helper function
fooreturns null, you can now run do{{foo.bar}}without error, just like whenfoois a non-existent property.If you pass a non-scalar object to
Session.set, an error will now be thrown (matching the behavior ofSession.equals). #215HTML pages are now served with a
charset=utf-8Content-Type header. #264The contents of
<select>tags can now be reactive even in IE 7 and 8.The
meteortool no longer gets confused if a parent directory of your project is namedpublic. #352Fix a race condition in the
spiderablepackage which could include garbage in the spidered page.The REPL run by
admin/node.shno longer crashes Emacs M-x shell on exit.Refactor internal
reloadAPI.New internal
jsparsesmart package. Not yet exposed publicly.
Patch contributed by GitHub user yanivoliver.
v0.4.1, 2012-09-24
New
emailsmart package, withEmail.sendAPI.Upgrade Node from 0.6.17 to 0.8.8, as well as many Node modules in the dev bundle; those that are user-exposed are:
- coffee-script: 1.3.3 (from 1.3.1)
- stylus: 0.29.0 (from 0.28.1)
- nib: 0.8.2 (from 0.7.0)
All publicly documented APIs now use
camelCaserather thanunder_scores. The old spellings continue to work for now. New names are:Meteor.isClient/isServerthis.isSimulationinside a method invocationMeteor.deps.Context.onInvalidateMeteor.status().retryCount/retryTime
Spark improvements
- Optimize selector matching for event maps.
- Fix
Spark._currentRendererbehavior in timer callbacks. - Fix bug caused by interaction between
Template.foo.preserveand{{#constant}}. #323 - Allow
{{#each}}over a collection of objects without_id. #281 - Spark now supports Firefox 3.6.
- Added a script to build a standalone spark.js that does not depend on Meteor (it depends on jQuery or Sizzle if you need IE7 support, and otherwise is fully standalone).
Database writes from within
Meteor.setTimeout/setInterval/deferwill be batched with other writes from the current method invocation if they start before the method completes.Make
Meteor.Cursor.forEachfully synchronous even if the user's callback yields. #321.Recover from exceptions thrown in
Meteor.publishhandlers.Change the implementation of the
meteor deploypassword prompt to not crash Emacs M-x shell.Optimize
LocalCollection.remove(id)to be O(1) rather than O(n).Optimize client-side database performance when receiving updated data from the server outside of method calls.
Better error reporting when a package in
.meteor/packagesdoes not exist.Better error reporting for coffeescript. #331
Better error handling in
Handlebars.Exception.
Patches contributed by GitHub users fivethirty, tmeasday, and xenolf.
v0.4.0, 2012-08-30
Merge Spark, a new live page update engine
- Breaking API changes
- Input elements no longer preserved based on
idandnameattributes. Usepreserveinstead. - All
Meteor.uifunctions removed. UseMeteor.render,Meteor.renderList, and Spark functions instead. - New template functions (eg.
created,rendered, etc) may collide with existing helpers. UseTemplate.foo.helpers()to avoid conflicts. - New syntax for declaring event maps. Use
Template.foo.events({...}). For backwards compatibility, both syntaxes are allowed for now.
- Input elements no longer preserved based on
- New Template features
- Allow embedding non-Meteor widgets (eg. Google Maps) using
{{#constant}} - Callbacks when templates are rendered. See http://docs.meteor.com/#template_rendered
- Explicit control of which nodes are preserved during re-rendering. See http://docs.meteor.com/#template_preserve
- Easily find nodes within a template in event handlers and callbacks. See http://docs.meteor.com/#template_find
- Allow parts of a template to be independently reactive with the
{{#isolate}}block helper.
- Allow embedding non-Meteor widgets (eg. Google Maps) using
- Breaking API changes
Use PACKAGE_DIRS environment variable to override package location. #227
Add
absolute-urlpackage to construct URLs pointing to the application.Allow modifying documents returned by
observecallbacks. #209Fix periodic crash after client disconnect. #212
Fix minimingo crash on dotted queries with undefined keys. #126
v0.3.9, 2012-08-07
Add
spiderablepackage to allow web crawlers to index Meteor apps.meteor deployuses SSL to protect application deployment.Fix
stopImmediatePropagation(). #205
v0.3.8, 2012-07-12
HTTPS support
- Add
force-sslpackage to require site to load over HTTPS. - Use HTTPS for install script and
meteor update. - Allow runtime configuration of default DDP endpoint.
- Add
Handlebars improvements
- Implement dotted path traversal for helpers and methods.
- Allow functions in helper arguments.
- Change helper nesting rules to allow functions as arguments.
- Fix
{{this.foo}}to never invoke helperfoo. - Make event handler
thisreflect the node that matched the selector instead of the event target node. - Fix keyword arguments to helpers.
Add
nibsupport to stylus package. #175Upgrade bootstrap to version 2.0.4. #173
Print changelog after
meteor update.Fix mouseenter and mouseleave events. #224
Fix issue with spurious heartbeat failures on busy connections.
Fix exception in minimongo when matching non-arrays using
$all. #183Fix serving an empty file when no cacheable assets exist. #179
v0.3.7, 2012-06-06
Better parsing of
.htmltemplate files- Allow HTML comments (
<!-- -->) at top level - Allow whitespace anywhere in open/close tag
- Provide names and line numbers on error
- More helpful error messages
- Allow HTML comments (
Form control improvements
- Fix reactive radio buttons in Internet Explorer.
- Fix reactive textareas to update consistently across browsers, matching text field behavior.
httppackage bug fixes:- Send correct Content-Type when POSTing
paramsfrom the server. #172 - Correctly detect JSON response Content-Type when a charset is present.
- Send correct Content-Type when POSTing
Support
Handlebars.SafeString. #160Fix intermittent "Cursor is closed" mongo error.
Fix "Cannot read property 'nextSibling' of null" error in certain nested templates. #142
Add heartbeat timer on the client to notice when the server silently goes away.
v0.3.6, 2012-05-16
Rewrite event handling.
thisin event handlers now refers to the data context of the element that generated the event, not the top-level data context of the template where the event is declared.Add /websocket endpoint for raw websockets. Pass websockets through development mode proxy.
Simplified API for Meteor.connect, which now receives a URL to a Meteor app rather than to a sockjs endpoint.
Fix livedata to support subscriptions with overlapping documents.
Update node.js to 0.6.17 to fix potential security issue.
v0.3.5, 2012-04-28
- Fix 0.3.4 regression: Call event map handlers on bubbled events. #107
v0.3.4, 2012-04-27
Add Twitter
bootstrappackage. #84Add packages for
sassandstylusCSS pre-processors. #40, #50Bind events correctly on top level elements in a template.
Fix dotted path selectors in minimongo. #88
Make
backbonepackage also run on the server.Add
bareoption to coffee-script compilation so variables can be shared between multiple coffee-script file. #85Upgrade many dependency versions. User visible highlights:
node.js 0.6.15
coffee-script 1.3.1
less 1.3.0
sockjs 0.3.1
underscore 1.3.3
backbone 0.9.2
Several documentation fixes and test coverage improvements.
v0.3.3, 2012-04-20
Add
httppackage for making HTTP requests to remote servers.Add
madewithpackage to put a live-updating Made with Meteor badge on apps.Reduce size of mongo database on disk (--smallfiles).
Prevent unnecessary hot-code pushes on deployed apps during server migration.
Fix issue with spaces in directory names. #39
Workaround browser caching issues in development mode by using query parameters on all JavaScript and CSS requests.
Many documentation and test fixups.
v0.3.2, 2012-04-10
- Initial public launch