Compare commits

...

1899 Commits

Author SHA1 Message Date
Steven
1211ee4fb3 Publish
- now@16.1.4-canary.6
 - @now/go@0.5.11-canary.4
 - @now/node@1.0.0-canary.5
 - @now/ruby@0.1.5-canary.3
2019-09-12 19:29:03 -04:00
Steven
a42bdefe1a [now-node] Add support for AWS Gateway Event (#3010)
* [now-node] Add support for AWS Gateway Event

* Fix funcName

* Fix makeAwsLauncher export

* Add missing return
2019-09-12 23:26:11 +00:00
Steven
f025f1007b Add release notes script to PUBLISHING.md (#3006) 2019-09-12 18:26:21 +00:00
Andy
1c11a57371 [now-cli] Default to empty string for undefined env var when checking (#3008) 2019-09-12 17:48:32 +00:00
Andy
db2d033484 [now-cli] Add changelog link to update message (#3001) 2019-09-12 16:15:33 +00:00
Max
40537c9eba [now-cli] Fix links output during deployment (#2966)
* Fix links output during deployment

* Move "synced" log to `total-fileds` event

* Pluralize synced messages

* Update packages/now-cli/src/util/deploy/process-deployment.ts

Co-Authored-By: Steven <steven@ceriously.com>

* Fix failing tests due to stdout mismatch
2019-09-12 14:40:46 +00:00
Steven
5cabcb7a27 [now-ruby] Use pre-installed ruby 2.5 (#2991)
* [now-ruby] Use pre-installed ruby 2.5

* Change GEM_HOME

* Add polyfill for Node 8
2019-09-12 13:34:54 +00:00
Nathan Rajlich
1be9ac59f0 [now-cli] Show a warning for invalid env vars in now dev (#3002)
* [now-cli] Show a warning for invalid env vars in `now dev`

Closes #2982.

* Add "validate env var names" integration test
2019-09-12 00:12:29 +00:00
Andy
64356baed3 [now-cli] Add tests for alias rules (#3003) 2019-09-11 23:32:20 +00:00
Sophearak Tha
c944706a0f [now-go] Improve test for custom build flags (#2999) 2019-09-11 16:23:54 +00:00
Nathan Rajlich
f15deaa51e [now-cli] Render correct command for now ls $path_alias_url (#2988)
Previously, if you ran `now ls` with a URL for a path alias, then an
error message `Cannot read property 'replace' of undefined` would occur.

Now, a message is logged saying to instead run `now alias ls $url` which
is the correct command to get path rules relevant to a path alias URL.

> Found matching path alias: rules.domain.com
> Please run `now alias ls rules.domain.com` instead

Fixes #2987.
2019-09-11 15:47:56 +00:00
Steven
61c3b94460 Publish
- @now/build-utils@1.0.0-canary.5
 - @now/static-build@0.9.9-canary.5
2019-09-11 10:32:20 -04:00
Steven
89b018240f [now-static-build] Run bundle install when Gemfile is found (#2980)
* [now-static-build] Run `bundle install` for Gemfile

* Add logs

* Add timeout in case proc hangs

* Rename test

* Remove console.log()

* Hide warnings

* Use runBundleInstall()

* [now-build-utils] Remove --deployment flag

* Run tests for build-utils
2019-09-11 10:28:24 -04:00
Steven
0124dc9969 Publish
- now@16.1.4-canary.5
 - @now/next@1.0.0-canary.5
 - @now/node@1.0.0-canary.4
2019-09-10 12:38:03 -04:00
Steven
936441c8a6 [now-node][now-next] Bump node-file-trace to 0.3.1 (#2990) 2019-09-10 16:12:24 +00:00
Sophearak Tha
c80570e096 [now-cli] Hide Init Duration and XRAY TraceId by default (#2984) 2019-09-10 14:22:08 +00:00
Steven
11c67e1c4c Publish
- @now/build-utils@1.0.0-canary.4
2019-09-10 09:18:57 -04:00
Steven
0d1c0e0f30 [now-build-utils] Add function runBundleInstall() (#2986)
* [now-build-utils] Add function `runBundleInstall`

* Add additional flags

* Set jobs to number of cpus

* Format

* Fix formatting

* Add BUNDLE_APP_CONFIG
2019-09-09 21:51:46 +00:00
Steven
f50572813e Publish
- gatsby-plugin-now@1.2.1-canary.1
 - @now/build-utils@1.0.0-canary.3
 - now@16.1.4-canary.4
 - now-client@5.1.1-canary.3
 - @now/next@1.0.0-canary.4
 - @now/node@1.0.0-canary.3
 - @now/static-build@0.9.9-canary.4
2019-09-09 13:09:08 -04:00
Steven
648b3a4ae2 [now-node] Bump node-file-trace to 0.3.0 and print warnings (#2985)
* Bump node-file-trace to 0.3.0

* [now-node] Print warnings from node-file-trace
2019-09-09 16:39:40 +00:00
Joe Haddad
efe114fa86 [now-next] Add monorepo autosetup support (#2961)
* [now-next] Add monorepo autosetup support

* Add actual tests

* Remove invalid test

* Correct contents directory

* Update tests

* Support new Next.js canaries
2019-09-09 14:42:26 +00:00
Max
4445d5e00f [now-client] Fix windows paths handling (#2974)
* Fix windows paths handling in now-client

* Tweak windows paths  handling
2019-09-09 04:05:20 +00:00
Clément ALLAIN
96b3c1ee7f [now-static-build] Fix dev server port detection (#2879)
* [now-static-build] Fix dev server detection

* Code review

* Remove unused dependency

* Fix the checking by really waiting until the port is reachable
2019-09-06 23:38:49 +00:00
Andy
e1a770ac29 [now-build-utils][now-cli] Warn instead of throwing on api and pages/api (#2976)
* [now-build-utils][now-cli] Warn instead of throwing on `api` and `pages/api`

* Remove slash and adjust tests

* Remove @now/build-utils

* Hardcode builders

* Add build-utils

* Change default flag

* More logging

* Add static-build

* Remove other packages from package.json

* New file for bundled function
2019-09-06 22:02:33 +00:00
Andy
db1a2e6482 [now-cli] Display warning when changing the secret name (#2975) 2019-09-06 10:45:57 +00:00
Nathan Rajlich
ecdde7c367 [now-cli] Use PackageJson and Builder types from @now/build-utils (#2971)
No functionality change here, this just removes the `Package` and
`BuildConfig` types from `src/util/dev/types.ts` in favor of the
matching types from `@now/build-utils`.

Also a lot of prettier formatting…
2019-09-06 00:35:49 +00:00
Nathan Rajlich
4d31291ea4 [now-build-utils] Add env and buildEnv to Meta type (#2970)
* [now-build-utils] Add `env` and `buildEnv` to `Meta` type

`now dev` passes in these variables to the "meta" object.

* Fix build
2019-09-05 15:19:17 -07:00
Andy
b70bd670fd [now-build-utils] Throw error on Next.js pages/api and api/ (#2964) 2019-09-05 19:21:59 +00:00
Sophearak Tha
d3017649e0 [now-cli] Add platform in Sentry report (#2960) 2019-09-05 18:57:15 +00:00
Luc
e970584219 [gatsby-plugin-now] Add keywords in package.json (#2965)
* add keywords to gatsby-plugin-now

* add #readme in homepage url
2019-09-05 18:04:32 +00:00
Sophearak Tha
c6205293a9 [now-build-utils] Use debug() on installing to and missing engines (#2954)
* Use debug() on `installing to` output

* Use debug() on `getSupportedNodeVersion` output
2019-09-05 13:19:32 +00:00
Max Rovensky
cb47f7bf4b Publish
- now@16.1.4-canary.3
 - @now/python@0.2.17-canary.2
2019-09-05 17:07:52 +08:00
Nathan Rajlich
a60f107e4b [now-cli] Fix now alias with no arguments (#2959)
Fixes #2941.
2019-09-05 00:09:17 +00:00
Nathan Rajlich
6e43c322cc [CircleCI] Remove publish-stable and publish-canary steps (#2957)
Publishing to npm is now handled by GitHub Actions.

Aside from that, the Circle publishing was broken.
See: https://circleci.com/gh/zeit/now/7213
2019-09-04 20:33:19 +00:00
Steven
4b6387bdb5 [now-python] Use system python with now dev (#2956) 2019-09-04 18:35:33 +00:00
Steven
bcd770c0fe [now-cli] Bump @zeit/fun to 0.10.0 (#2955) 2019-09-04 18:10:33 +00:00
Max Rovensky
bb8c7e9f3b Publish
- now@16.1.4-canary.2
 - now-client@5.1.1-canary.2
2019-09-05 01:03:31 +08:00
Max
6e469272c3 [now-cli] Implement now-client deployments in Now CLI (#2875)
* Imlement `now-client` deployments in Now CLI

* Move now-client to dev dependencies

* Fix missing config for legacy deployments

* Restore no files warning

* Improve error handling

* Port over `--prod`

* Handle single files and warnings better

* Fix legacy deployment env config

* Handle build errors in events

* Don't use ncc for now-client

* Extract `for...await` logic into a `.ts` file

* Revert "Don't use ncc for now-client"

This reverts commit e481a04058952f7011bf5523445256f1b8882dda.

* Add `typings` field to `now-client`

* Regenerate yarn.lock

* Add bootstrap step to CircleCI

* Add bootstrap step before build

* Revert "Add bootstrap step before build"

This reverts commit db9e1113937f113cca8c7c05d5c800fd5d61e84b.

* Revert "Add bootstrap step to CircleCI"

This reverts commit 02c0006a073614814fd174ccbaf1e4e0d8dd3dbf.

* Build `now-client` before CLI

* Sort build scripts

* Tweak empty deployment detection

* Add bootstrap step before build

* Remove now-client dependency from now-client

* Use local dependencies

* Fix paths and regenerate lockfile

* Bypass broken linting rule

* Remove lint ignore

* Use `tsc` instead of `ncc` for `now-client`

Co-Authored-By: Steven <steven@ceriously.com>

* Fix output path for tsc build

* [test] Supress TS warning

* Update packages/now-cli/src/commands/deploy/latest.js

Co-Authored-By: Steven <steven@ceriously.com>

* Update packages/now-cli/src/commands/deploy/latest.js

Co-Authored-By: Steven <steven@ceriously.com>

* Update packages/now-client/package.json

Co-Authored-By: Steven <steven@ceriously.com>

* Change `now-client` output to `dist`

* Implement file events in now-client and bring back progressbar

* Update build script sorting

* Add new logic tests for `now-client`

* Remove redundant target check

* Remove now-client dependency and use local code

* Set exact dependency versions

* Revert "Set exact dependency versions"

This reverts commit e0a31eaf10e498271c9253439d4bbd650738c694.

* Revert local now-client import

* Revert `now-client` dependency to local path

* Implement feedback

* Fix formatting

* Only handle alias errors if `readyState` is `READY`

* Update packages/now-cli/src/commands/deploy/latest.js

Co-Authored-By: Andy <AndyBitz@users.noreply.github.com>

* Update packages/now-cli/src/commands/deploy/latest.js

Co-Authored-By: Andy <AndyBitz@users.noreply.github.com>
2019-09-04 16:50:09 +00:00
Andy Bitz
5e7fa71148 Publish
- now@16.1.4-canary.1
 - @now/next@1.0.0-canary.3
2019-09-04 12:44:04 +02:00
Andy Bitz
12d9a4b4f4 [now-cli] Bump version 2019-09-04 12:42:50 +02:00
Andy
084ab2d0e5 [now-cli] Handle now certs ls for users and teams without certificates (#2945)
* [now-cli] Fix `now certs ls` when the user or team has no certs

* Add tests and move to typescript

* Move index and add to typescript

* Fix reduce function in ls

* Added linebreak

* Update packages/now-cli/src/commands/certs/add.ts

Co-Authored-By: Naoyuki Kanezawa <naoyuki.kanezawa@gmail.com>
2019-09-04 10:35:20 +00:00
Naoyuki Kanezawa
4ca0d936aa Add the nameservers verification check and improve messages (#2943)
* add the nameservers verification check and improve messages

* fix verify message condition
2019-09-04 15:44:49 +09:00
Nathan Rajlich
5d5a55e7e1 [now-cli] Remove now update from --help output (#2951)
Fixes #2940.
2019-09-04 03:30:25 +00:00
Nathan Rajlich
e033e5e0ca [now-cli] Remove scale subcommand from --help (#2923)
Fixes #1998.
2019-09-03 20:08:41 +00:00
Andy
7cb36ef1dd Fix the prettier config (#2946)
* Fix the prettier config

* Try prettier
2019-09-03 18:56:34 +00:00
Andy
9aafb168e9 [now-cli] Install dependencies before running now dev in tests (#2948)
* [now-cli] Install dependencies before running `now dev` in tests

* Check install exit code

* Add more logging

* Add more logging

* More logging

* Include yarn.lock file

* Add lock files to dev fixtures

* Ignore test

* Ignore another test

* Ignore another test

* Whitespace

* Install deps for unit tests

* Whitespace
2019-09-03 18:05:21 +00:00
Andy Bitz
fbb5caf955 Publish
- gatsby-plugin-now@1.2.1-canary.0
 - @now/build-utils@1.0.0-canary.2
 - now@16.1.3-canary.6
 - @now/go@0.5.11-canary.3
 - @now/next@1.0.0-canary.2
 - @now/node@1.0.0-canary.2
 - @now/static-build@0.9.9-canary.3
2019-09-03 09:57:03 +02:00
Andy
3f93da550b [now-build-utils][now-next][now-node] Bump version (#2942)
* [now-build-utils][now-next][now-node] Bump version

* Bump build-utils in @now-cli
2019-09-03 07:53:19 +00:00
Luc
a194e0cc6e [gatsby-plugin-now] Add new package w/support for Gatsby Redirects (#2897)
* add gatsby-plugin-now

* add test

* adjust with lerna

* fix test

* add tests to circleci

* add support for defaultRoutes functions

* add defaultRoutes to gatsby

* fix types

* add test case for gatsby redirects

* remove gatsby, react, react-dom from monorepo deps

* chmod +x build.sh

* add missing build script in fixtures

* do stuff during tests to avoid persistence issue

* move tests setup to build step

* copy gatsby plugin files in test case

* bring back ncc step

* prettier gatsby-plugin-now

* add missing semicolons

* remove eslint, prettier from plugin

* persist build step copied file

* fetch without following redirects

* add files in package.json

* remove force

* fix tests probes

* fetch location is not raw location

* fix test

* add readme

* fix type error

* adjust tests

* add support for `force`

* add tests for `force`

* adjust tests again

* gatsby-plugin-now@1.1.0

* `"` -> `'`

* tweak redirect names in test by precaution

* change file name and delete when consumed

* format files

* gatsby-plugin-now@1.2.0

* Apply suggestions from code review

Co-Authored-By: Steven <steven@ceriously.com>

* tests -> test

* add --verbose

* adjust circleci to persist fixtures

* trigger tests

* add repository and homepage in package.json

* glob files after `defaultRoute` invocation
2019-09-03 04:19:32 +00:00
Andy
b007200bcf [now-node][now-next] Skip installing user dependencies for now dev (#2926)
* Skip installing user dependencies for `now dev`

* Update type

* Install dependecies for test

* Add comma-dangle for @now/next

* Revert "Add comma-dangle for @now/next"

This reverts commit 720d5630f309ec44eb65e280af29db5b14bd50eb.

* Add trailing commas

* Reset typescript update

* Add trailing commas

* Bump @zeit/node-file-trace

* Readd trailing comma

* Bump @zeit/node-file-trace in @now/node
2019-09-02 19:35:48 +00:00
Sophearak Tha
05d88da887 [now-cli] Remove annotate from now logs (#2937)
* Remove annotate from `now logs`

* Filter out runtime logs to be consistency with dashboard logs

* Add integration test
2019-09-02 16:32:45 +00:00
Sophearak Tha
0a429bb2f3 [now-go] Add GO_BUILD_FLAGS support for go build custom flags (#2916)
* Add `GO_BUILD_FLAGS` support for go build custom flags

* Using string-argv package

* Simplify condition
2019-09-02 15:45:13 +00:00
Joe Haddad
468ccb7598 [now-next] Create default file with correct target (#2924) 2019-09-02 13:28:36 +00:00
Andy Bitz
e47f6f55dc Publish
- now@16.1.3-canary.5
2019-09-02 15:11:14 +02:00
Nathan Rajlich
17deed91b2 [now-cli] Update pcre-to-regexp to v1.0.0 (#2932)
No improvements, per say, but the module has been converted to
TypeScript so it supplies its own type definitions now, and we
can delete our hand-crafted typings from this repo.
2019-09-02 12:47:25 +00:00
Nathan Rajlich
cc0bd9f0a2 [now-cli] Use xdg-app-paths for now dev cache dir (#2921)
* [now-cli] Use `xdg-app-paths` for `now dev` cache dir

For consistency, because #2877 uses this module.
No need for multiple modules that do the same thing.

* Update `@zeit/fun` to v0.9.3
2019-09-01 14:25:26 +00:00
Steven
f6f99fef25 Publish
- now@16.1.3-canary.4
 - @now/go@0.5.11-canary.2
 - @now/node@0.12.8-canary.3
2019-08-30 14:36:09 -04:00
Nathan Rajlich
eb252edc7f [now-cli] Output --json to stdout for now alias ls <url> (#2922)
Fixes #1337.
2019-08-30 18:29:28 +00:00
Sophearak Tha
f3213dbcdc [now-node] Cleanup debug output (#2927)
* Ensure traced files have annotate present in all lines

* Remove traced file logs

* Remove `compiling es module file` log

* Cleanup debug output
2019-08-30 16:42:23 +00:00
Sophearak Tha
c637da7710 [now-go] Fix analyze.go fails to parse source file with comments (#2911)
* Fix `analyze.go` fails to parse source file with comments

* Add more tests

* Improve fallback

* Improve check for http.HandlerFunc signature`
2019-08-30 15:32:51 +00:00
Joe Haddad
ab05595582 Publish
- @now/build-utils@0.9.14-canary.2
 - @now/cgi@0.1.5-canary.1
 - now@16.1.3-canary.3
 - now-client@5.1.1-canary.1
 - @now/go@0.5.11-canary.1
 - @now/next@0.7.1-canary.3
 - @now/node-bridge@1.2.4-canary.2
 - @now/node@0.12.8-canary.2
 - @now/python@0.2.17-canary.1
 - @now/routing-utils@1.2.3-canary.1
 - @now/ruby@0.1.5-canary.2
 - @now/static-build@0.9.9-canary.2
2019-08-29 23:15:18 -04:00
JJ Kasper
ba8e714329 [now-next] Use patched version of yazl and trace API pages separate (#2919)
* Update to trace API files separately and use modified yazl

* Remove jszip dependency

* Pin yazl dependency and add types

* Update more types
2019-08-30 02:40:45 +00:00
Luc
ef86bb0bd9 [tests] Unify .editorconfig (#2920) 2019-08-29 23:56:10 +00:00
Andy
be18b54bfd [now-cli] Improve check for update command (#2915)
* [now-cli] Improve check for update command

* Use path.sep

* Fix build
2019-08-29 23:47:53 +00:00
Max Strübing
ed168db23c [now-cli] Use XDG standard instead of writing to home directory (#2877)
* Use XDG standard instead of writing to home directory

* Fix typos

* Use dependencies as dev dependencies

* Remove lodash dependency

* Use xdg-app-paths instead of xdg-portable

* use find instead of filter(...)[0]
2019-08-29 23:04:47 +00:00
Luc
236f5f4159 [tests] Unify linting and autoformatting (#2914)
* add prettier and eslint on root

* remove eslint from now-cli

* adjust root package.json

* adjust eslintignore

* adjust now-cli rules

* remove @zeit/git-hooks in packages

* adjust now-client eslint config

* add lint-staged and hook on pre-commit

* add pre-commit script

* replace @zeit/git-hooks with husky

* remove unnecessary script

* fix eslint errors

* trigger tests

* fix fixable errors

* fix fixable errors (bis)

* revert two changes
2019-08-29 19:17:40 +00:00
Steven
e44a91634e [now-cli] Update readme and links (#2886)
* Update readme and links

* Fix readme image

* Fix homepage

* Update banner image to v3
2019-08-29 16:47:36 +00:00
Naoyuki Kanezawa
8b9426eb6c [tests] Remove fixtures files for integration tests (#2910) 2019-08-29 13:57:26 +00:00
Nathan Rajlich
c62c57f122 [now-cli] Implement continue: true with dest (#2908)
Closes #2685.
2019-08-29 12:39:55 +00:00
Nathan Rajlich
c81db0c8d2 [now-cli] Use a Map for the valid sub-commands (#2913)
Otherwise, JavaScript Object built-ins such as `hasOwnProperty` are
incorrectly considered a valid subcommand, but fail afterwards with
a `require()` error and confusing error message.
2019-08-29 07:56:36 +00:00
Naoyuki Kanezawa
1c64990e9f [now-cli] fix login test (#2909) 2019-08-29 05:45:40 +00:00
Joe Haddad
f1dc7fd14a Publish
- now@16.1.3-canary.2
 - @now/next@0.7.1-canary.2
 - @now/node-bridge@1.2.4-canary.1
 - @now/node@0.12.8-canary.1
 - @now/ruby@0.1.5-canary.1
 - @now/static-build@0.9.9-canary.1
2019-08-28 21:18:57 -04:00
Nathan Rajlich
6079d4be25 [now-cli] Remove deprecated @now/php builder from bundled builders tarball (#2907)
`@now/php` has been deprecated in favor of community-maintained
`now-php`, so don't bundle the deprecated builder with Now CLI.
2019-08-29 00:42:06 +00:00
Andy
2c4b8335ce [now-cli] Allow to fetch more certificates with paging (#2905)
* [now-cli] Allow to fetch more certificates with paging

* Linting

* Update packages/now-cli/src/commands/certs/ls.js

Co-Authored-By: Nathan Rajlich <n@n8.io>
2019-08-28 23:51:10 +00:00
JJ Kasper
9bd2f22d5c [now-next] Optimize lambda creation (#2892)
* Optimize zipping lambdas for now-next

* Update to use jszip to get around bug in yazl

* Add pseudo layer utils

* Apply suggestions from code review

Co-Authored-By: Joe Haddad <joe.haddad@zeit.co>

* Update sema concurrency from tests

* Update packages/now-next/src/index.ts

* Use custom types to fix broken @types package

* Add license header

* Revert "Use custom types to fix broken @types package"

This reverts commit 82441285155f6e0899c43dffdd5e000ecbd7b1b6.

* Fix CI Yarn installation

* TypeScript types should never be hoisted

* Fix all typechecking
2019-08-28 22:43:26 +00:00
Andy
7c421f92e1 [now-cli] Validate inputs for alias, list and remove (#2903)
* [now-cli] Validate inputs for alias, list and remove

* Log test output

* Add more logging to test

* Change to execa

* Use `split`

* Only validate when it exists
2019-08-28 21:30:27 +00:00
Andy
0626db51bd [now-cli] Change success message after login (#2898)
* [now-cli] Change success message after login

* Linting

* Test now login

* Linting

* Revert "Test now login"

This reverts commit 690360db3f148552a456b4ee1bd2a59b8d09216c.

* Revert "Linting"

This reverts commit 3d5ebfaa76ecdcc2152c8344c8e1205b241abe09.

* Adjust test

* Remove binaryPath from args

* Fix loggin test
2019-08-28 22:41:56 +02:00
Kaito Sugimoto
dc29a8b816 [now-cli] Update now alias warning for --prod (#2902) 2019-08-28 18:27:21 +00:00
Joe Haddad
e00e5e18ea Publish
- @now/build-utils@0.9.14-canary.1
 - now@16.1.3-canary.1
 - @now/next@0.7.1-canary.1
2019-08-28 08:28:56 -04:00
Joe Haddad
d0999e7937 [now-build-utils] Add mutable option for backwards compatibility (#2895) 2019-08-28 05:29:34 +00:00
Joe Haddad
158cfad978 [now-next] Do not add initial files to lambda (#2894) 2019-08-28 02:14:02 +00:00
Andy
9145b43a62 [now alias] Improve alias support (#2787)
This enables https://github.com/zeit/now-cli/pull/2747 from @nkzawa again.

We had to revert the previous one, because we didn't want to include it in
the next stable release.

This further makes sure that we don't display `https://` in front of a
wildcard alias, since `https://*.mydomain.tld` is not a valid URL.
2019-08-28 00:47:39 +00:00
Steven
479d271356 Publish
- @now/build-utils@0.9.14-canary.0
 - @now/cgi@0.1.5-canary.0
 - now@16.1.3-canary.0
 - now-client@5.1.1-canary.0
 - @now/go@0.5.11-canary.0
 - @now/next@0.7.1-canary.0
 - @now/node-bridge@1.2.4-canary.0
 - @now/node@0.12.8-canary.0
 - @now/python@0.2.17-canary.0
 - @now/routing-utils@1.2.3-canary.0
 - @now/ruby@0.1.5-canary.0
 - @now/static-build@0.9.9-canary.0
2019-08-27 18:57:46 -04:00
Steven
8119f4cad2 Add GH Actions Publish Workflow (#2891) 2019-08-27 22:35:12 +00:00
Steven
e73b32e9cc [tests] Ignore fixtures in GitHub Languages & fix yarn.lock (#2890) 2019-08-27 17:55:43 +00:00
Sophearak Tha
45bd08e4e5 [now-next] Use debug() from build-utils (#2881)
* [now-next] Use `debug()` from build-utils (#909)

* Use `debug()` from build-utils

* Revert back to warning output

* Remove unnecessary debug check
2019-08-27 15:40:39 +00:00
Sophearak Tha
4528243b5c [now-go] Use debug() from build-utils (#2885)
* [now-go] Use `debug()` from build-utils (#923)

* Use `debug()` from build-utils

* Apply suggestions from code review

Co-Authored-By: Steven <steven@ceriously.com>

* Print errors

* Apply suggestions from code review

Co-Authored-By: Steven <steven@ceriously.com>
2019-08-27 15:25:31 +00:00
Sophearak Tha
bd741cfbeb [now-ruby] Use debug() from build-utils (#2883) 2019-08-27 15:05:13 +00:00
Sophearak Tha
b3b10f0fd7 [now-node] Use debug() from build-utils (#2880)
* Use `debug()` from build-utils

* Remove condition
2019-08-27 10:36:04 -04:00
Sophearak Tha
084c014fff [now-static-build] Use debug() from build-utils (#2884) 2019-08-27 14:15:11 +00:00
Andy
63614e5303 [now-cli] Validate builds and routes for now dev (#2871)
* [now-cli] Validate builds and routes for `now dev`

* Remove @ts-ignore

* Sort the matches such that `utils` modules are compiled first

Because other packages may rely on them

* Prettier

* Add `reject: false` to tests

* Prettier

* Make validation async

* Fix syntax

* Fix type

* Linting

* Fix error check
2019-08-27 13:29:23 +00:00
Sophearak Tha
099d2c8195 [now-cli] Make sure to have event action as string (#2870) 2019-08-27 13:11:09 +00:00
Sophearak Tha
ae813423d8 [now-python] Use debug() from build-utils (#2882)
* Use `debug()` from build-utils

* Apply suggestions from code review

Co-Authored-By: Steven <steven@ceriously.com>
2019-08-27 09:10:43 -04:00
Nathan Rajlich
2a5f3f779e [now dev] Update yarn to v1.17.3 (#2780)
* [now dev] Update `yarn` to v1.17.3

* Wait longer for angular integration test

It keeps on failing

* Only run angular test on Node 10.x

* Revert "Wait longer for angular integration test"

This reverts commit 19d70d4ba9aee49a5114b65f00ef97e2a88dc7ef.
2019-08-26 23:10:06 +00:00
Andy
89e1d83ad4 [now-static-build] Support ejected create-react-app (#2873) 2019-08-26 22:10:31 +00:00
Steven
ce23f9e204 [tests] Fix unit tests & coverage step (#2876)
* Fix unit tests & coverage

* Add missing compile-templates step
2019-08-26 21:17:57 +00:00
Nathan Rajlich
743eb21682 Update links to now-builders repo to now repo (#2862)
* Update links to `now-builders` repo to `now` repo

Also copies over the `.md` files from the now-builders' `errors`
directory so that the https://err.sh links work correctly.

Part of #2782.

* Update `err.sh` links that were formerly `now-cli`

* Empty commit for CI

* Make CircleCI `run.sh` script a bit better

Before it would fail with exit code 1 if there were no matching modified
files because of the `grep` call failing without any `packages` prefixed
files.
2019-08-26 15:13:08 -04:00
Steven
b9f5de2b7a [tests] Change run script from bash to node (#2874)
* [tests] Change run script from bash to node

* Fix loop for runScript

* Fix `all` script test

* Improve console.log() messages

* Use -l instead of -p

* Delete yarn.lock from now-python
2019-08-26 17:49:47 +00:00
Steven
229a62d8b6 Create monorepo (#2812)
* Move now-cli to /packages/now-cli

* Fix .gitignore paths

* Add now-client

* Add lerna to top level

* Add scripts

* Update codeowners

* Fix `/now-cli/build.ts` script

* Fix circleci path to artifacts

* Use relative paths

* Fix path to scripts

* Add test-lint script

* Add missing return type

* Fix typo in test-lint

* Fix string match in shell scripts

* Fix path to hugo

* Add package node_modules

* Delete lock files in packages, use root yarn.lock

* Add missing b.js file

* Add test-integration-now-dev script

* Add missing test files

* Add missing integration test script

* Add missing test files

* Delete travis.yml

* Fix ts-jest in now-client

* Add support for Node 8 (ES2015 target)

* Add support for Node 8

* Add polyfill for Node 8

* Fix polyfill for Node 8

* Only run coverage for now-cli

* Add packages from now-builders

* Run integration tests for builders

* Add node_modules to cache

* Add root readme.md

* Move readme to top level

* Add yarn bootstrap

* Add bootstrap step

* Add dist to `persist_to_workspace`

* Fix 08-yarn-npm integration test

* Remove duplicate path

* Change stdio to inherit

* Add back store_artifacts

* testing - remove bootstrap step

* Add back now-build-utils

* Remove bootstrap step

* Fix test again

* Add console.log()

* Fix lint

* Use local ncc version

* Install go

* Revert changes to stdio and console.log()

* Add missing now-go test

* Add missing integration tests

* Add --runInBand flag

* Fix now-node-bridge persistence

* Add missing symlinks

* Add codeowners

* Consolidate into single run.sh function

* Run uniq

* Fix typo

* Change now-routing-utils to test-unit

* Special case test for node 8

* Add docs from builders

* Only run script for modified packages

* Add test-integration-once which only runs once

* Fix set intersection
2019-08-23 17:00:31 -07:00
Andy Bitz
52a6e60f78 16.1.2-canary.7 2019-08-20 18:58:27 +02:00
Andy
a7cb747130 Use short-form for the update command (#2801)
* Use short-form for the update command

* Adjust test
2019-08-20 18:56:31 +02:00
Andy
918d60576f [now deploy] Fix builds output for failed deployments (#2799)
* [now deploy] Fix builds output for failed deployments

* Add test
2019-08-20 18:13:43 +02:00
Andy
62111977fd [now deploy] Fix --prod flag and adjust message for --target (#2797)
* [now deploy] Fix `--prod` flag and adjust message for `--target`

* Fix tests

* Fix fetch

* Change api version

* Fix url

* Fix test
2019-08-20 17:29:43 +02:00
Andy Bitz
00c05b95e4 16.1.2-canary.6 2019-08-20 00:12:56 +02:00
Andy
9ee83b858c [now deploy] Added --prod flag (#2789)
* [now deploy] Add `--production` and `--staging` flag

* Change message

* Fix tests

* Fix test

* Add another test

* Fix production test

* Update message and add `--prod`

* Update help

* Remove `--staging`

* Use only `--prod`

* Add test

* Add aliasError output

* Fix output
2019-08-20 00:12:14 +02:00
Andy Bitz
e4a181321a Revert "Add more alias support (#2747)"
This reverts commit 957fe9084a.
2019-08-19 11:34:42 +02:00
Andy Bitz
dd6f6aa418 16.1.2-canary.5 2019-08-19 09:55:17 +02:00
Andy
b37bfbc1ed Bump @now/build-utils to 0.9.13 (#2784) 2019-08-19 01:21:49 +02:00
Leo Lamprecht
dd06c4c63d 16.1.2-canary.4 2019-08-18 12:01:43 +00:00
Nathan Rajlich
a6174cde03 [now domain] Handle thrown API errors when purchasing domain fails (#2779)
Fixes #2759.
2019-08-16 02:43:30 +00:00
Nathan Rajlich
c85ab97321 Remove a couple unused import (#2777)
Fixes lint
2019-08-15 19:12:59 -07:00
Naoyuki Kanezawa
957fe9084a Add more alias support (#2747)
* add more alias support

* Update src/util/domains/setup-domain.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Update src/util/domains/setup-domain.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>

* add tests
2019-08-16 00:48:29 +00:00
Nathan Rajlich
70f72e5bb8 Sleep 2 seconds after the now rm integration test (#2776)
Sometimes it fails with a stale 200 status code.
This should make it less flaky.
2019-08-15 16:19:52 -07:00
Nathan Rajlich
4feb961091 16.1.2-canary.3 2019-08-15 11:59:08 -07:00
Nathan Rajlich
6ddc252978 Display rate limit errors message from API response (#2767)
* Display rate limit errors message from API response

Closes #2738.

* Update src/util/handle-error.ts

Co-Authored-By: Steven <steven@ceriously.com>
2019-08-15 07:39:12 +00:00
Naoyuki Kanezawa
5eca7cf5f7 add misssing defaultArgs (#2770) 2019-08-15 11:23:01 +09:00
Nathan Rajlich
76486246c5 Remove leftover console.log() in integration tests (#2768) 2019-08-15 01:17:38 +00:00
Nathan Rajlich
740a7c8886 [now rm] Use the proper client so that the process does not hang (#2762)
* [now rm] Use the proper `client` so that the process does not hang

The crux of this fix is that `getDeploymentByIdOrHost()` and
`getProjectByIdOrName()` were improperly being passed the `Now`
instance instead of the expected `Client` instance, and for some
reason that would cause the process to hang until the underlying
`http.Agent` timed out its connection to the API server.

Also ran `prettier` on this file.

Fixes #2760.

* Remove `console.error()`

* Add integration test

* Fix syntax error

* Add `now rm` 404 integration test

* Remove `.only`
2019-08-15 00:41:53 +00:00
Nathan Rajlich
40b69b4924 [now scale] Fix default max: auto value in --help output (#2763)
Fixes #2368.
Also related to zeit/docs#838.
2019-08-14 10:07:55 -07:00
Nathan Rajlich
c5ef4b1dc5 Fix "occured" -> "occurred" typos (#2761)
See: https://tinyurl.com/occured
2019-08-13 23:47:48 +00:00
Andy
ef793bf7e9 [now dev] Use canary builders for the canary version (#2753)
* Use canary builders for the canary version

* Use the `getDistTag` function instead

* Fix function call

* Add tests

* Remove unused code

* Remove logging
2019-08-13 19:30:48 +00:00
Nathan Rajlich
2be1dd4fcb Use the correct URL in the auth.json and config.json files (#2755)
Fixes #2754.
2019-08-13 17:40:48 +00:00
Nathan Rajlich
a734eb79d9 [now projects] Add subcommand alias for now project (#2750)
Fixes #2162.
2019-08-13 02:37:03 +00:00
Naoyuki Kanezawa
24dc2a36de remove unused HTTP/HTTPS Agent (#2749) 2019-08-13 11:05:45 +09:00
Naoyuki Kanezawa
12881c1b57 support to set api host for development (#2748) 2019-08-13 09:44:45 +09:00
Nathan Rajlich
c66188a6f2 Update clipboardy to v2.1.0 (#2737)
Fixes #564.

Related to #1924.
2019-08-10 12:15:36 +00:00
Andy
61457b532a Bump @now/build-utils to 0.9.12 (#2736) 2019-08-09 20:35:40 +00:00
Nathan Rajlich
d2ff3749ca [now dev] Remove leftover console.error() call (#2735)
Accidentally added in #2720.
2019-08-09 18:48:34 +00:00
Leo Lamprecht
38bc7cc6d6 [now dev] Add --listen / -l flag, deprecate --port / -p (#2720)
* [now dev] Add `--bind` / `-b` flag

This changes the default network interface that `now dev` binds to, in
order to prevent operating system firewalls from showing a confirmation
prompt in order to run.

Fixes #2704.

* Change to `--listen`

* Default port 3000

* Fix unit

* Fix `--port`

* Use `-l` for integration tests

* Add unit tests
2019-08-09 11:16:21 -07:00
Arunoda Susiripala
413fdd7c39 Update index.js (#2733) 2019-08-09 16:07:39 +02:00
Leo Lamprecht
f48bb493b0 [now update] Show correct global or local install command (#2719)
* [now update] Show correct global or local install command

* Remove `canRead` check

* Change bin to lib since the actual script will be there

* Use realpath

* Remove console.error
2019-08-09 01:05:44 +02:00
Nathan Rajlich
962c5db9fe Update serve-handler to v6.1.1 (#2731)
* Update `serve-handler` to v6.1.1

Fixes #2697.

* Fix unit test
2019-08-08 22:26:02 +00:00
Nathan Rajlich
9e961b479c Print HTTP status code upon API JSON parse errors (#2727)
Fixes #2681.
2019-08-08 20:51:23 +00:00
Nathan Rajlich
718100fafc Add accept: application/json header to API HTTP requests (#2726)
All of the APIs already support JSON by default, so this is a no-op for
our APIs, however the proxy layer _does_ respect the `Accept` header to
send JSON error responses, which is useful for more gracefully handling
outage responses (previously they were being returned as plain text,
which Now CLI blindfully tries to parse as JSON and fails with an
unhelpful error message).

Related to #2681.
2019-08-08 20:15:29 +00:00
Steven
2b38f545d0 Add automerge config (#2729) 2019-08-07 18:41:51 -07:00
Nathan Rajlich
55b1327119 [CircleCI] Fix test/dev-server.unit.js being run on CI (#2725)
For some reason, `ava` was silently skipping these tests on CI because
the process was crashing. According to sindre, this is a bug in `ava`,
but with some digging I was able to determine that the root cause of the
crash was that the `builders.tar.gz` file from the `assets` dir was not
being persisted from the previous `build` job in CI.

With the `assets` dir being persisted I now see the `dev-server` unit
tests being executed once again as expected.

Related to: https://twitter.com/sindresorhus/status/1157614353375551493
2019-08-07 12:17:55 -07:00
wtgtybhertgeghgtwtg
a75ec505ad Remove vestigial mkdirp packages (#2724) 2019-08-07 11:15:50 -07:00
Andy Bitz
36b1e129b4 16.1.2-canary.2 2019-08-07 17:32:01 +02:00
Andy
331b6e0a23 [now deploy] Use the project when checking the platform version (#2722)
* [now deploy] Use the project when checking the platform version

* Update src/util/prefer-v2-deployment.ts

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Update src/util/prefer-v2-deployment.ts

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Adjust message

* Fallback for local config
2019-08-07 17:31:02 +02:00
Andy Bitz
fc72ecb223 16.1.2-canary.1 2019-08-07 14:32:04 +02:00
Andy
ca51cbcc6b Fix colored text and remove version warning (#2721) 2019-08-07 14:30:30 +02:00
Andy Bitz
6ce8acc4db 16.0.1-canary.3 2019-08-07 11:57:55 +02:00
Andy
a9edec1619 [now deploy] Change the warning messages when the platform version is changed (#2717)
* [now deploy] Change warning message

* Change text

* Add link to message

* Change text
2019-08-07 11:55:44 +02:00
Leo Lamprecht
8638d17d87 Revert "[now dev] Add --bind / -b flag (#2705)"
This reverts commit efe0ca57f0.
2019-08-07 08:12:50 +00:00
Leo Lamprecht
db6ae2998b Revert "[now update] Show correct global or local install command (#2716)"
This reverts commit d667a83af5.
2019-08-07 08:12:32 +00:00
Andy
d667a83af5 [now update] Show correct global or local install command (#2716)
* [now update] Show correct global or local install command

* Remove `canRead` check

* Change bin to lib since the actual script will be there

* Use realpath

* Remove console.error
2019-08-06 22:59:07 +02:00
Andy Bitz
f2a1fb50da 16.0.1-canary.2 2019-08-06 20:10:48 +02:00
Andy
eb356a5d3d [now dev] Bump @now/build-utils to 0.9.10 (#2715) 2019-08-06 20:09:27 +02:00
Nathan Rajlich
efe0ca57f0 [now dev] Add --bind / -b flag (#2705)
This changes the default network interface that `now dev` binds to, in
order to prevent operating system firewalls from showing a confirmation
prompt in order to run.

Fixes #2704.
2019-08-06 14:55:04 +02:00
Andy Bitz
409b7099be 16.0.1-canary.1 2019-08-06 12:51:51 +02:00
Andy
e6653992a7 Bump @now/build-utils to 0.9.9 (#2713)
* Bump `@now/build-utils` to 0.9.9

* Log output

* Only log on error

* Fix tests
2019-08-06 12:50:46 +02:00
Nathan Rajlich
c133e81f6e Require Node.js >= 8.11 in "engines" (#2714)
Closes #2711.
2019-08-05 20:14:42 -07:00
Nathan Rajlich
28bfcb4c58 [now dev] Print warning upon empty cwd directory (#2702)
* [now dev] Render warning upon empty `cwd` directory

The warning matches the one that `now deploy` prints, and only
prints the warning once (rather then upon every HTTP request).

Closes #2696.

* Fix eslint warning

* Add "pipe"

* Debugging…

* Fix integration test

* Debugging…

* Add `--verbose` to "test-integration-now-dev" script

* Ignore `yarn.lock` and `node_modules` in test dir

* Ignore `hugo` binary

* Ignore `public` dir in hugo test fixture

* Add `.gitignore` to `empty` test fixture

* Revert "Debugging…"

This reverts commit 27c6d2e06fe7eff12077a0e88915cf46b39b00ea.

* Ignore `public` / `dist` dirs in fixtures
2019-08-05 19:54:19 -07:00
Nathan Rajlich
5cf8f8a70a Add unhandledRejection and uncaughtException handlers to scripts (#2709)
This is to prevent false-positives like this from occurring,
and fixes the warning from `node`:

```
$ ts-node ./scripts/build.ts
Creating builders tarball with: @now/build-utils@canary, @now/go@canary, @now/next@canary, @now/node@canary, @now/php@canary, @now/static-build@canary
(node:156) UnhandledPromiseRejectionWarning: Error: ENOENT: no such file or directory, open '/home/circleci/repo/assets/builders.tar.gz'
    at ReadStream.evt.error.err (/home/circleci/repo/node_modules/promisepipe/index.js:30:23)
    at ReadStream.emit (events.js:198:13)
    at ReadStream.EventEmitter.emit (domain.js:448:20)
    at /home/circleci/repo/node_modules/graceful-fs/graceful-fs.js:207:14
    at /home/circleci/repo/node_modules/graceful-fs/graceful-fs.js:258:16
    at FSReqWrap.args [as oncomplete] (fs.js:140:20)
(node:156) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
(node:156) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
```
2019-08-05 18:11:43 -07:00
Nathan Rajlich
b31ab033c2 Fix format-modified script (#2708)
Before it was only updating _non-staged_ files.

Now, it updates _all_ modified files, staged or not.
2019-08-05 15:50:04 -07:00
Nathan Rajlich
24a3b99ee3 Upgrade ava to v2.2.0 (#2703)
See: https://twitter.com/sindresorhus/status/1157614353375551493
2019-08-05 14:32:39 -07:00
Andy Bitz
9a6ad1ae43 15.9.0-canary.28 2019-08-05 17:36:13 +02:00
Andy
687ef375c8 [now update] Remove is-installed-globally (#2700)
* [now update] Remove `is-installed-globally`

* Only suggest global

* Adjust test
2019-08-05 17:26:45 +02:00
Andy Bitz
538525e639 15.9.0-canary.27 2019-08-05 15:22:56 +02:00
Andy
aff5a0cbed [now deploy] Check if builds are ready right away (#2699)
* [now deploy] Check if builds are ready right away

* Adjust tests

* Remove test

* Log more while testing

* Remove check in tests

* Adjust all tests

* Log more
2019-08-05 15:20:02 +02:00
Nathan Rajlich
b1b1529bd6 15.9.0-canary.26 2019-08-02 16:11:34 -07:00
Andy
bb934f0146 Update @now/build-utils to v0.9.8 (#2694)
* Bump `@now/build-utils` to 0.9.7

* Handle 404 status

* Revert "Handle 404 status"

This reverts commit 6aa25097beb96c8d56ab40c91319278da68d5851.

* Render 404 page

* Bump @now/build-utils
2019-08-02 15:59:00 -07:00
Nathan Rajlich
7d2c5dc39a Assert 200 response status on "deploy a dockerfile project" integration test (#2684)
* Assert 200 response status on "deploy a dockerfile project" integration test

* Fix
2019-08-02 12:42:09 -07:00
Nathan Rajlich
9894869427 [now dev] Support JSON and HTML redirect responses (#2690)
* [now dev] Support JSON and HTML redirect responses

Matches the production behavior.

* Set Now response headers during redirect

* Set `location` header

* Remove unused `matched_route` var
2019-08-02 12:01:55 -07:00
Nathan Rajlich
8e0c1da441 [now dev] Allow custom 404 pages via routes (#2689)
* [now dev] Allow custom 404 pages via `routes`

This matches the behavior in production, which allows a `dest` to be
provided when defining a `status: 404` in the routes configuration.

Related to #2638.

* Fix typo
2019-08-02 11:26:02 -07:00
Andy
6a165e8377 [preinstall/now update] Check if now is installed locally (#2688)
* [preinstall/now update] Check if now is installed locally and adjust messages

* Adjust test

* Add tests

* Wait for deployment to be ready

* Removed log

* Adjust prefix in test

* Adjust path

* Only wait 4 minutes

* More logging

* Change binPrefix to prefix

* Remove all linting warnings

* Adjust env vars for test

* Don't test on node 8

* Log more error information and fail right after 500

* Move docker test up
2019-08-02 20:10:32 +02:00
Nathan Rajlich
eeed5a8273 Fix routes definition in now-dev-static-routes test fixture (#2687)
This is the proper way to define this route because of the capture of
the initial `/`.

Matches how it works in production.
2019-08-01 17:56:34 -07:00
Nathan Rajlich
75d98c649a [now dev] Support JSON and HTML error responses (#2677)
* [now dev] Support JSON and HTML error responses

Closes #2609.

* Compile templates for unit tests in CircleCI

* Update `ts-node` to v8.3.0

* Convert doT.js compiled templates to TypeScript

* Compile templates for lint tests in CircleCI

* Print convert time

* Add 502 error template

* Remove `message` param from `sendError()`

* Prettier

* Add 404 tests

* Fix test
2019-08-01 17:56:06 -07:00
Andy Bitz
d54cc4df51 15.9.0-canary.25 2019-08-01 18:52:26 +02:00
Andy
f211f1fa70 [preinstall] Adjust the error messages (#2682)
* [preinstall] Adjust the error messages

* Remove dot
2019-08-01 18:40:55 +02:00
Nathan Rajlich
f60a373479 [now dev] Use a consistent "pod id" for x-now-id (#2679)
This matches the behavior in production.
2019-07-31 16:31:56 -07:00
Andy
80a82ba276 [now deploy] Change link for legacy warning (#2674)
* [now deploy] Change link for legacy warning

* Remove trailing slash

Co-Authored-By: Steven <steven@ceriously.com>

* Simplify `link` function

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Determine which link to show and add test

* Adjust link for configuration

Co-Authored-By: Steven <steven@ceriously.com>

* Adjust Package type
2019-08-01 00:14:18 +02:00
Andy
8a3d0fb370 [now dev] Bump @now/build-utils to 0.9.6 (#2672) 2019-07-31 18:22:45 +02:00
Andy Bitz
20c2930a90 15.9.0-canary.24 2019-07-31 16:47:00 +02:00
Andy
bccf602496 [now deploy] Check server.js file when detecting the platform version (#2664)
* [now deploy] Check `server.js` file when detecting the platform version

* Fix type
2019-07-31 16:01:15 +02:00
dependabot[bot]
ed92ef8952 Bump yarn to v1.17.3 (#2669)
Bumps [yarn](https://github.com/yarnpkg/yarn) from 1.13.0 to 1.17.3.
- [Release notes](https://github.com/yarnpkg/yarn/releases)
- [Changelog](https://github.com/yarnpkg/yarn/blob/v1.17.3/CHANGELOG.md)
- [Commits](https://github.com/yarnpkg/yarn/compare/v1.13.0...v1.17.3)

Signed-off-by: dependabot[bot] <support@github.com>
2019-07-30 22:05:59 -07:00
Andy
1b9c14bd30 [CircleCI] Add more test suites for macOS support (#2663)
* [CircleCI] Add more tests for macos support

* Change xcode version since node 8.9.x is required

* Log stderr and stdout

* Add custom start script

* Make tests use custom start script

* Made start script executable

* Use correct node path

* Fix script path

* Handle status code

* Use latest Node.js version for macos tests

* Include yarn.lock for ember test

* Only use start script in tests

* Change start script for macos

* Change start script for linux

* Change start script for linux
2019-07-31 03:03:14 +02:00
Sophearak Tha
c287cbeb22 [now dev] Update NOW_BUILDER_DEBUG base on --debug flag (#2655)
* Update `NOW_BUILDER_DEBUG` base on `--debug` flag

* No need to reset `NOW_BUILDER_DEBUG`

* Add comment for `NOW_BUILDER_DEBUG`

* Apply suggestions from code review

Co-Authored-By: Andy <AndyBitz@users.noreply.github.com>
2019-07-30 14:56:38 -07:00
Nathan Rajlich
d29b1b9cfa [now dev] Bundle canary builders for Now CLI canary (#2661)
* [now dev] Bundle `canary` builders for Now CLI canary

Closes #2641.

* Add unit tests

* More unit tests

* Use `semver.parse()` in `getDistTag()`

* Convert build script to TypeScript, DRY the `getDistTag()` function

* Prettier
2019-07-30 14:56:00 -07:00
Andy
49293ae44b [now dev] Update outdated dependencies in tests (#2666) 2019-07-30 11:47:38 -07:00
Andy Bitz
39103f5ae6 15.9.0-canary.23 2019-07-30 15:00:03 +02:00
Nathan Rajlich
af2c894fb9 [CircleCI] Add seperate jobs for now dev integration tests (#2662)
Run the `now dev` integration tests in parallel with the "standard"
integration tests, since they both take a long time. This should
cut the CI testing time in about half.
2019-07-30 11:25:55 +02:00
Andy Bitz
42f9745420 Revert "Revert "15.9.0-canary.22""
This reverts commit 35c3d87055.
2019-07-30 02:25:01 +02:00
Andy
f016f05c11 [now dev] Fix aurelia test (#2660)
* [now dev] Fix aurelia test

* Enable aurelia test again
2019-07-30 02:22:18 +02:00
Nathan Rajlich
257f5f293e Support Node 8 (#2648)
* Support Node 8

This changes the TypeScript compilation target to "es2015" so that
async generator functions are transpiled, which enables Node 8 to be
supported.

As a side-effect, any of the files that utilize `async function*` or
`for await` needed to be converted to TypeScript so that the
transpilation actually happens.

It was painful to do this process for `src/commands/deploy/legacy.ts`,
and since it is legacy code I did not want to make too many changes to
the code, so there's a log of `@ts-ignore` and `any` types being used.
But the behavior of the file should not have changed at all.

* Make `engines` field be ">= 8"

* Add Node 8 to CircleCI matrix

* Remove `console.error()`

* Remove `.ts` extension on import calls

* Use `Now` instead of `any`

* Use native `url` module instead of `whatwg-url`

* Debug integration test

* Skip `02-angular-node` test on Node 8

* Remove debugging

* Add "Downloading Hugo" step to Node 8 tests

* Skip `03-aurelia` test on Node 8

* Skip `03-aurelia` test for all

All node versions are failing with the same error:

https://circleci.com/gh/zeit/now-cli/29922

* Use `fs-extra` instead of `fs.promises` for Node 8
2019-07-29 16:29:15 -07:00
Andy Bitz
35c3d87055 Revert "15.9.0-canary.22"
This reverts commit a78813bd74.
2019-07-30 01:19:44 +02:00
Andy Bitz
a78813bd74 15.9.0-canary.22 2019-07-29 23:02:01 +02:00
Andy
05c2f69523 [now update] Change update notification and remove previous Now CLI installation on preinstall (#2659)
* [now update] Change update notification and remove previous Now CLI installation on `preinstall`

* Use plain js for preinstall script

* Removed unused `rename` import

* Simplified code
2019-07-29 13:22:13 -07:00
Andy
e389a836e1 [now deploy] Consider --npm and --docker for platform detection (#2640)
* [now deploy] Consider `--npm` and `--docker` for platform detection

* Change order

* Change prepare

* Await fixtures

* Remove check

* Revert "Remove check"

This reverts commit 7a5c1c901085d4e22c5a34cc48b5d929a9ee3b80.

* Use async-retry

* Fix fetch

* Log token

* Retry user creation

* Add async

* Add try-catch

* Decrease the retries

* Use original way to get context name
2019-07-29 21:44:37 +02:00
Nathan Rajlich
64c526fe1d [now dev] Redirect when request has multiple slashes (#2645)
* [now dev] Redirect when request has multiple slashes

Closes #2642.

* Add POST passthrough
2019-07-29 11:19:04 -07:00
Max Chehab
e132d74aa8 [now deploy] Fix variable name typo (#2649) 2019-07-29 10:26:56 -07:00
Andy
975c8dc5fc [now dev] Prevent recursive function call for handle: "filesystem" (#2630)
* [now dev] Prevent recursive function call for `handle: "filesystem"`

* Add test

* Update test/dev/integration.js

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Handle recursive `serveProjectAsNowV2` call

* Fix test
2019-07-29 19:09:37 +02:00
Sophearak Tha
3d2929b345 [now dev] Improve integration tests for now dev (#2597)
* Using `stdio` to resolve `now dev` Ready

* Update test/dev/integration.js

Co-Authored-By: Andy <AndyBitz@users.noreply.github.com>

* Improve `testFixtureStdio` and update aurelia fixture

* Remove duplicate test

* Update `create-react-app` and `gatsby` test fixture

* Update `gridsome` test fixture

* Update `hugo` test fixture

* Update `jekyll` test fixture

* Add `marko` test fixture

* Add `mithril` test fixture

* Add `riot` test fixture

* Add `charge` test fixture

* Add `brunch` test fixture

* Add `docusaurus` and `ember` test fixtures

* Install ruby for `jekyll`

* Update base on platform for `jekyll` and `hugo`

* Use `sudo` to when installing `gem`

* Remove `09-jekyll`

* Extract the right filename

* Remove `-L` flag from `curl` for macOS

* Use different version of `hugo`

* Remove `min_version` from `08-hugo` theme
2019-07-29 09:44:30 +07:00
Nathan Rajlich
c91e529782 [now dev] Add server: now response header (#2646)
Matches production.
2019-07-26 17:24:04 -07:00
Nathan Rajlich
495ba3bf98 Add information when team/user/args parsing fails to Sentry reports (#2635)
* Add information when team/user/args parsing fails to Sentry reports

This should give us some insight into #2627.

* Add `node` reporting
2019-07-26 16:41:16 -07:00
Nathan Rajlich
c799886f53 [now dev] Remove accidental test.only() (#2644)
This got committed by accident :(
2019-07-26 16:10:30 -07:00
Andy
bcbaad4371 [now deploy] Determine platform version through Dockerfile and package.json (#2633)
* [now deploy] Determine platform version through `Dockerfile` and
`packge.json`

* Update src/commands/deploy/index.js

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Change notification, add tests, consider `type`

* Change test

* Adjust test

* Adjust test

* Update src/util/prefer-v2-deployment.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>
2019-07-25 17:35:50 -07:00
Nathan Rajlich
91c80ca0a9 Remove leftover references to pkg (#2632)
* Remove leftover references to `pkg`

We are no longer compiling `now-cli` with `pkg` so this is dead code.

* Enable source maps
2019-07-25 17:03:21 -07:00
Andy
e7e0ab7d0d [now dev] Clean up before calling process.exit (#2629)
* [now dev] Clean up before calling `process.exit`

* Log error

* Update src/util/dev/server.ts

Co-Authored-By: Steven <steven@ceriously.com>
2019-07-25 22:04:29 +02:00
Nathan Rajlich
0b6b74938f [now dev] Fix routing catch-all with no slash prefix edge case (#2626)
Fixes #2622.
2019-07-25 11:33:57 -07:00
Andy Bitz
256ca8796f 15.9.0-canary.21 2019-07-25 13:56:20 +02:00
Nathan Rajlich
17c659124b [now deploy] Respect --debug flag for API Client (#2625)
While debugging #2606, I noticed that the `Client` instances for
`now deploy` were not being supplied the appropriate `debug` flag
based on the command line args.
2019-07-24 16:23:37 -07:00
Steven
bcac213114 15.9.0-canary.20 2019-07-24 18:43:07 -04:00
Steven
7f4b2bdc87 [now init] Download /v1 examples without suggestions (#2623) 2019-07-24 18:42:01 -04:00
Nathan Rajlich
94a958f460 [now deploy] Change "Aliases assigned" to "Deployment complete" (#2620)
* [now deploy] Change "Aliases assigned" to "Deployment complete"

Closes #2617.

* Change instances of "Aliased" to "Deployed"
2019-07-24 14:11:31 -07:00
Andy Bitz
7a02249f37 15.9.0-canary.19 2019-07-24 22:55:37 +02:00
Andy
94681f28c6 [now dev] Bump @now/build-utils to 0.9.4 (#2621) 2019-07-24 22:54:41 +02:00
Nathan Rajlich
9fd1cee6f0 [now dev] Fix creating duplicate blocking builds upon bootup (#2618)
PR #2562 caused an issue with blocking builds at bootup being built
twice, which is problematic when i.e. running `yarn` simultaneously
on the same directory causing cache corruption issues.
2019-07-24 12:39:42 -07:00
Nathan Rajlich
2054bb06f1 [now dev] Remove useless debug() call (#2619)
The `getNowConfig(false)` used to be within this `if` branch, so the
debug call made sense there at the time, but as of zero config it got
moved to always be invoked, so this `debug()` call doesn't make sense
anymore.
2019-07-24 12:39:26 -07:00
Sophearak Tha
c0b5a01cae 15.9.0-canary.18 2019-07-24 21:05:10 +07:00
Sophearak Tha
0bbe5f7806 Remove Buffer() deprecation message (#2604)
* Remove `Buffer()` deprecation message

* Switch `micro` back to `9.1.2`
2019-07-24 20:57:55 +07:00
Nathan Rajlich
9e25d8e11c 15.9.0-canary.17 2019-07-23 17:50:44 -07:00
Nathan Rajlich
8623c5201c Add "engines" field to package.json for Node 10 or newer (#2603)
`now-cli` does not work on Node 8 and below because generator
functions are not supported.
2019-07-23 17:50:13 -07:00
Andy
862728f889 Use fs-extra instead of fs.promises to prevent warnings on Node 10 (#2602) 2019-07-23 17:29:37 -07:00
Nathan Rajlich
ad4e20c7e6 [CircleCI] Run integration tests on multiple versions of Node.js (#2596)
* [CircleCI] Run integration tests on multiple versions of Node.js

* Test Node 10 and Node 12

* Remove `fs.promises` usage for Node 8

* More `fs.promises` removal

* Remove Node 8, it is unsupported due to `async` function usage
2019-07-23 16:16:12 -07:00
Andy Bitz
62d782255a Revert "Disable warnings (#2601)"
This reverts commit 23318d9fc9.
2019-07-24 00:10:52 +02:00
Nathan Rajlich
3f18d24915 [now dev] Wait for blocking builds to complete before handling requests (#2562)
* [now dev] Wait for blocking builds to complete before handling requests

After the `now dev` server has already booted, if you delete a build
match that previously required a build at bootup time (i.e. `@now/next`)
from the `builds` array in `now.json` (i.e. change the builder to
`@now/static`), and then change it back to `@now/next`, then previously
the build would never execute.

With this change, the blocking build occurs as expected, and any HTTP
requests that occur are blocked until that build has completed.

* Prettier

* Better diff

* Add test
2019-07-23 14:58:19 -07:00
Andy
23318d9fc9 Disable warnings (#2601)
* Disable warnings

* Fix execution bits

* Revert "Fix execution bits"

This reverts commit f054f6695fe015896a5f6aa8354ac61a57b3cf81.

* Revert "Disable warnings"

This reverts commit 9321cea2820857060db7275eda9c94d951908714.

* Add --no-warnings
2019-07-23 23:40:11 +02:00
Nathan Rajlich
c413cc7349 [now dev] Add warning when there are no build matches (#2594)
* [now dev] Add warning when there are no build matches

This matches the error in production, except it's just a non-fatal
warning when running in `now dev`. This is so that the user can fix
the warning without having to restart the `now dev` server.

* Add integration test
2019-07-23 11:12:34 -07:00
Andy
f268a1b390 [now update] Don't check for updates on now update (#2599) 2019-07-23 19:56:50 +02:00
Nathan Rajlich
19dd33b037 [now update] Render the proper tag and improve yarn detection logic (#2595)
* [now update] Render the proper tag and improve `yarn` detection logic

Before this the suggested command would always have you install the
stable version of `now`.

With this change the `@canary` tag will be suggested if the version of
`now` is from the canary release channel.

Also updates the `isYarn` detection logic to not consider the cwd, and
instead check the installed version of now's `package.json` for clues.

* Move `getUpdateCommand` to util

* Add a unit test

* Use integration test instead
2019-07-23 17:31:15 +02:00
Andy Bitz
a29890c8ee 15.9.0-canary.16 2019-07-22 19:33:20 +02:00
Andy
6e3a495914 [now dev] Fix directory listing race condition (#2591)
* [now dev] Fix directory listing race condition

* Resolve file names

* Check only matched files

* Log stdout and stderr

* Log expected

* Change test

* Revert "Change test"

This reverts commit 149723be0f2015bd400dd5f2d5cce523303a05cf.

* Add timeout to request

* Adjust retries

* Don't use unref

* Remove tests

* Revert "Remove tests"

This reverts commit 6159d657bfa978719ffb23153058b791b2ce8a2a.

* Adjusted test

* Make sure directory exists

* Fix tests

* Add yarn.lock

* Adjust timeout
2019-07-22 18:34:27 +02:00
Sophearak Tha
e1005deeb3 Remove pkg bundling (#2567)
* Remove `pkg` bundling

* Remove `(dev)` from `--version`

* Remove `test/dev-builder.unit.js`

* Temporary disable `update now to canary test`

* Update `now update` command

* Removed useless jobs

* Removed useless code

* Removed more useless code

* Use update command

* Only run publish upon tag

* Removed code

* No need bin, use dist directly

* Update test, using the right file

* Reslove `iconv-lite@0.5.0` version

* Removed useless file

* Added scripts directory

* Removed useless stuff

* Fixed build script

* Fix `now dev` integration test

* Also block coverage on linting
2019-07-22 15:04:51 +02:00
Andy
c61502e24c [now dev] Print Serving all files as static only once (#2590)
* [now dev] Print `Serving all files as static` only once

* Track the config state

* Revert "Track the config state"

This reverts commit 9766941ca8cd1ffeae5fb0729800f05f2547099c.

* Revert "[now dev] Print `Serving all files as static` only once"

This reverts commit 3e30c2440b6c4deed8a14f2359696e7bf8dcdcad.

* Add `isInitialLoad` param
2019-07-22 02:47:09 +02:00
Sophearak Tha
7674a4af4a Add configuration and basic integration tests for now dev (#2553)
* Add configuration and basic integration tests for `now dev`

* Add test fixtures from `now-examples`

* Add `include` to `tsconfig.json`

* Increase retries for 00-list-directory

* Increase retries for `03-aurelia-node`

* Enable test fixtures for hexo, hugo, next, polymer, preact, svelte, vue, and vuepress

* Increase retries for `08-hugo-node`

* Disable `08-hugo-node` fixture

* Enable `04-create-react-app-node` test

* Disable `04-create-react-app-node` test

* Better name for now dev test job
2019-07-22 01:48:23 +02:00
Andy
0245a04db9 Handle more errors when deploying (#2589) 2019-07-22 00:31:56 +02:00
Andy
340537bc0b [now dev] Bump @now/build-utils and throw errors (#2588)
* [now dev] Bump `@now/build-utils` and throw errors

* Fix error handling
2019-07-21 21:37:49 +02:00
Steven
c9383b2535 [now init] Add suggestions for old examples (#2584)
* [now init] Add suggestions for old examples

* Add support for selecting an old example

* Add message for selection

* Wait for user interaction

* Fix typo

* Use v2 api instead

* Move message label to first param

* Bump api url to latest, update download to v2

* Rename found to visible
2019-07-19 19:29:02 -04:00
Andy Bitz
eae9f9ed42 15.9.0-canary.15 2019-07-19 22:29:52 +02:00
Mark Glagola
dfa134e8e4 handle no-change domain transfer policy (#2570) 2019-07-19 13:59:11 -05:00
Sophearak Tha
bb7b99bcf9 15.9.0-canary.14 2019-07-19 22:54:44 +07:00
Andy
074e96e117 Fix update command message (#2581)
* Fix update command

* Update src/commands/update.ts

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>
2019-07-19 22:48:41 +07:00
Andy
0b82c74c58 [now dev] Bump @now/build-utils (#2582)
* [now dev] Bump @now/build-utils

* Replace `apollo` init example fixure with `angular`

* Update more tests

* Remove `now.json` from check
2019-07-19 22:15:39 +07:00
Andy Bitz
5cc4af257e 15.9.0-canary.13 2019-07-19 14:03:40 +02:00
Andy
1979e2074f [now init] Remove now dev suggestion from now init (#2580) 2019-07-19 14:01:45 +02:00
Andy
e788743f58 [now dev] Remove package.json message (#2576)
* [now dev] Remove package.json message

* Add message that all files are served as static
2019-07-19 11:53:29 +02:00
Sophearak Tha
dae525e56a Remove deprecation message from now alias with args (#2578) 2019-07-19 11:42:32 +02:00
Andy
0e32313395 Fix building indicator jittering (#2577) 2019-07-19 11:22:31 +02:00
Andy Bitz
2ea1b00fda 15.9.0-canary.12 2019-07-19 02:42:03 +02:00
Andy
398b371ded [now dev] Upgrade @now/build-utils and enable more support for static sites (#2575)
* [now dev] Upgrade `@now/build-utils` and enable more support for static sites

* Add tests

* Upgrade @now/build-utils
2019-07-19 02:40:17 +02:00
Andy Bitz
da89cecaab 15.9.0-canary.11 2019-07-18 15:11:41 +02:00
Matthew Sweeney
e821d28ccd Add hint when example not found (#2572)
* add hint when example not found

* update test

* update test
2019-07-18 13:29:43 +01:00
Andy Bitz
3cd2de7728 15.9.0-canary.10 2019-07-18 12:30:15 +02:00
Andy
8e32c66840 Bump mime-types to 2.1.24 (#2571) 2019-07-18 12:29:54 +02:00
Andy Bitz
7716bb5439 15.9.0-canary.9 2019-07-17 23:45:35 +02:00
Andy
42a8dc14b0 Change now update to display npm or yarn command (#2568)
* Change `now update` to display npm or yarn command

* Use `getUpgradeCommand`
2019-07-17 23:39:16 +02:00
Andy Bitz
97ff4515ae 15.9.0-canary.8 2019-07-17 19:32:07 +02:00
Andy
ad6c04b78d [now dev] Fix builder sorting when use is undefined (#2566)
* [now dev] Fix function sorting when `use` is undefined

* Update type

* Add filter

* Fix build
2019-07-17 17:31:37 +02:00
Andy Bitz
68c1f7163f 15.9.0-canary.7 2019-07-17 14:46:29 +02:00
Andy
b94e8a1563 Fix tests order (#2565) 2019-07-17 14:45:58 +02:00
Andy Bitz
60a5659dff Revert "15.9.0-canary.7"
This reverts commit 06b8ccb672.
2019-07-17 14:34:28 +02:00
Andy Bitz
06b8ccb672 15.9.0-canary.7 2019-07-17 12:04:58 +02:00
Andy
ca06186cfe [now dev] Fix builder sorting (#2563)
* [now dev] Fix builder sorting

* Add tests

* Fix path

* Add sleep

* Revert "Add sleep"

This reverts commit 86f0057808eab50f1c977d19989425d633488e23.

* Revert "Fix path"

This reverts commit 14327b83145c8cb24d5e45ac6e91534a7ef093ec.

* Revert "Add tests"

This reverts commit 76849a7a5ce79b54f102a11f66920dccaabeadb6.
2019-07-17 11:49:32 +02:00
Andy
b5349fe6a5 [now dev] Allow now dev as package.json script (#2559)
* [now dev] Allow `now dev` as package.json script

* Fix absolute path for now dev

* Fix directory issue

* Typo

* Update src/commands/dev/dev.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Whitespace

* Make code simpler

* Extend type

* Update errors/now-dev-as-dev-script.md

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Update errors/now-dev-as-dev-script.md

Co-Authored-By: Nathan Rajlich <n@n8.io>
2019-07-17 01:31:56 +02:00
Nathan Rajlich
7ac3c75ee8 15.9.0-canary.6 2019-07-16 14:44:46 -07:00
Nathan Rajlich
00437fe3f8 [now dev] Memoize the getNowConfig() promise (#2561)
The `getNowConfig()` function gets invoked frequently, and it is also
async and makes mutations to the cached now config object. This ends
up being a race condition when `getNowConfig()` is invoked concurrently,
since one of the invocations may end up with an incomplete `NowConfig`
object (namely, with missing `builds`/`routes` arrays due to the
zero-config processing).

This change makes it so that there's only one `getNowConfig()` invocation
being executed at a time, and other concurrent executions will await the
same promise that the original invocation is responsible for.
2019-07-16 14:27:35 -07:00
Nathan Rajlich
930648da13 [now dev] Rename nowJson variables to nowConfig (#2558)
This is only a cosmetic code change, but aligns more nicely with
the new zero-config approach (where there is no `now.json`).
2019-07-16 13:28:18 -07:00
Andy
4945218ea6 [now dev] Bump @now/build-utils to 0.8.8 (#2557) 2019-07-16 20:23:40 +02:00
Andy
12c3987e94 [now dev] Bump @now/build-utils (#2556) 2019-07-16 18:21:09 +02:00
Nathan Rajlich
18cedcb7e6 Update @sentry/node to v5.5.0 (#2542)
Because Sentry gives a big banner saying to update on the error reports.

Related: https://github.com/getsentry/sentry-javascript/blob/master/MIGRATION.md
2019-07-15 17:59:29 -07:00
Nathan Rajlich
925af8066d Update deps of deps in yarn.lock file (#2543)
* Update deps of deps in `yarn.lock` file

To fix #lodashgate:

 * Upgrade `lodash.merge` to version 4.6.2 or later.
 * Upgrade `lodash` to version 4.17.13 or later.

* Regenerate `yarn.lock`
2019-07-15 17:14:23 -07:00
Nathan Rajlich
5f46eb9dd7 [now dev] Wait for updateBuilders() to complete before stop() completes (#2551)
* [now dev] Wait for `updateBuilders()` to complete before `stop()` completes

Since #2477, the unit tests related to `now dev` have become flaky, and
need to be retried a couple of times before running successfully. My
theory is that this is related to having concurrent `yarn` processes
operating on the builders module directory, causing corruption with yarn's
cache. Waiting for the lazy updating `yarn` process to complete makes
sense to me, hopefully CircleCI agrees.

* Debugging "list the scopes" integration test

* Moar debug

* Use regular `require()` when not in a webpack build (ava tests)

* Remove debug
2019-07-15 16:45:05 -07:00
Andy Bitz
24245bd4bb 15.9.0-canary.5 2019-07-15 16:48:43 +02:00
Andy
005dd24b18 [now dev] Apply the ignore pattern to api files (#2548) 2019-07-15 15:32:05 +02:00
Nathan Rajlich
116ee34a10 15.9.0-canary.4 2019-07-12 13:40:03 -07:00
Nathan Rajlich
81cf441f66 Add builders.tar.gz to pkg "assets" configuration (#2541)
Fixes this error from the pkg'd binary:

```
Error: File or directory '/**/now-cli/dist/builders.tar.gz'
was not included into executable at compilation stage.
Please recompile adding it as asset or script.
```
2019-07-12 13:39:43 -07:00
Nathan Rajlich
c5a588744a 15.9.0-canary.3 2019-07-12 12:46:00 -07:00
Nathan Rajlich
48c126a911 [now dev] Bundle the most popular core builders into CLI binary with lazy builder updates (#2477)
* [now dev] Bundle the most popular core builders into CLI binary

Makes Now CLI bundle a tarball inside its snapshot filesystem that
includes the following builders:

 * @now/go
 * @now/next
 * @now/node
 * @now/php
 * @now/static-build

The tarball is generated by the `build.js` script and ensures the
"latest" version of the builders are included into the tarball.

When `now dev` is run, the tarball will be extracted upon the first
run to make these builders "pre-installed" to avoid the "Installing
builders" phase during boot-up.

Overall, this should make booting up `now dev` a lot faster, and help
with offline support.

* Don't install builders if they are bundled

* Persist `assets` dir to CircleCI workspace

* Delete build assets

* Fix installing builders from URL

* Finish builder installation filtering logic

* Still install `@now/build-utils`

* Implement builders installation "stale-while-revalidate"

* Remove `console.time()`

* Fix unit test

* Add `Readonly<>` to `BuilderWithPackage` type props

* Add debug log stack trace upon builder update failure
2019-07-12 12:33:06 -07:00
Sophearak Tha
18c295a88e 15.9.0-canary.2 2019-07-12 22:25:54 +07:00
Sophearak Tha
893871e043 [now dev] Improve max lambda size error message (#2539)
* Improve max lambda size error message

* Better wording
2019-07-12 22:24:49 +07:00
Andy
f2b1c89a53 Remove files from 15.7.0-canary.17 and 15.7.0-canary.14 (#2537) 2019-07-12 15:39:15 +02:00
Andy Bitz
271d7ffc29 15.9.0-canary.1 2019-07-12 15:13:02 +02:00
Andy
fd99217303 Bump @now/build-utils (#2535) 2019-07-12 14:50:14 +02:00
Max Rovensky
77d07f838f 15.7.0-canary.18 2019-07-12 16:38:06 +07:00
Max
1f81d80505 Disable automatic signup (#2530)
* Disable automatic signup

* Use shorter error message

* Update tests

* Update tests with user info

* Create tmpDir before tests

* Tweak fixtures and assertions for new login

* Don't pre-create the test directory in CI

* Use `os.homedir` instead of `~` in tests

* Pre-create auth directory conditionally
2019-07-12 15:34:26 +07:00
Sophearak Tha
7e950496ae 15.7.0-canary.17 2019-07-12 13:10:49 +07:00
Sophearak Tha
ec43780e1b Increase default maxLambdaSize (#2534) 2019-07-12 13:07:27 +07:00
Luc
66fe14d8e2 Remove "missing alias in now.json" warning (#2533) 2019-07-11 16:35:10 -07:00
Andy Bitz
a29abc7d45 15.7.0-canary.16 2019-07-11 13:06:54 +02:00
Nathan Rajlich
5d329e0bc3 [now dev] Render directory listing for Now v2 projects (#2528)
* [now dev] Render directory listing for Now v2 projects

Before directory listings only worked for "all static" deployments since
`now dev` would shell out to `serve-handler` to do the rendering.

Now the directory listing rendering logic is moved into `now dev` which
allows projects with Lambdas to also serve the directory listing
(previously they would just 404).

This removes the special-casing of "all static" deployments so that
there's only one code path.

Fixes #2161.
Fixes #2417.

* Move `serve-handler/src/directory` types to root

* Set `Content-Length` header for dir listing

* Add unit tests for directory listing

* Fix unit test
2019-07-10 19:34:16 -07:00
Andy Bitz
2de9edeed4 15.7.0-canary.15 2019-07-10 21:48:18 +02:00
Andy
954d433f6f [now dev] Update @now/build-utils and handle warnings (#2523)
* [now dev] Update @now/build-utils and handle warnings

* Display warnings from response headers for deployment creation

* Update src/util/dev/server.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>

* Apply routes only when there are no builds

* Updated the build utils
2019-07-10 18:14:08 +02:00
Nathan Rajlich
b18196b394 15.7.0-canary.14 2019-07-09 18:58:23 -07:00
Nathan Rajlich
926c14e0ef [now dev] Update serve-handler to v6.1.0 and enable etag option (#2525)
* [now dev] Update `serve-handler` to v6.1.0 and enable `etag` option

Sending the `ETag` response header matches how Now in production works.

* Test file contents as well
2019-07-09 18:49:38 -07:00
Nathan Rajlich
c2c986e780 Add .gitignore file to test/fixtures/unit/now-dev-default-builds-and-routes (#2524) 2019-07-09 17:50:33 -07:00
Nathan Rajlich
26e87093e1 Add @AndyBitz to now dev CODEOWNERS (#2522) 2019-07-09 14:43:35 -07:00
Nathan Rajlich
ba0323e434 [now dev] Revert "Add etag response header for Lambda invocations" (#2520)
* [now dev] Revert "Add `etag` response header for Lambda invocations"

This reverts commit f80f1f79a6 (#2502).

`ETag` header is only sent in production when the lambda function sets
the "stale-while-revalidate" cache-control header, which will be
implemented in a separate PR.

* Remove `etag` test assertion
2019-07-09 14:40:48 -07:00
Nathan Rajlich
55229e1ed7 Add /src/util/dev to CODEOWNERS file (#2521) 2019-07-09 14:37:12 -07:00
Andy
064213ce52 [now dev] Fix @now/static-build sorting (#2519)
* [now dev] Fix @now/static-build sorting

* Change tests

* Update src/util/dev/server.ts

Co-Authored-By: Nathan Rajlich <n@n8.io>
2019-07-09 23:03:37 +02:00
Andy
f0802c681c [now dev] Tests for routing and apply default frontend builder last (#2518) 2019-07-09 20:58:04 +02:00
Sophearak Tha
a6d2ab7d77 15.7.0-canary.13 2019-07-10 00:06:49 +07:00
Sophearak Tha
c5ced92978 [now-dev] Fix flickering and improve message (#2516)
* Fix flickering and improve message

* Pluralize builds

* Properly handle pluralize form
2019-07-10 00:05:40 +07:00
Andy Bitz
7efe32f9c8 15.7.0-canary.12 2019-07-09 18:16:10 +02:00
Andy
60f163d540 [now dev] Allow the default static build without an api (#2515) 2019-07-09 18:15:34 +02:00
Sophearak Tha
f507f28f30 15.7.0-canary.11 2019-07-09 22:11:57 +07:00
Sophearak Tha
54ae7001ec Handle 400 create alias error (#2514) 2019-07-09 22:04:48 +07:00
Sophearak Tha
d044cfe142 Simplify builds output message (#2512)
* Simplify builds output message

* Properly stop the spinner

* Handle stop spinning properly and remove unused import

* Update src/commands/deploy/latest.js

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Update src/commands/deploy/latest.js

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Properly handle stop spinning at build failed

* Update build failed message

* Remove unused variable

* Remove punctuation in error message

* Update integration test reflect latest change
2019-07-09 20:22:07 +07:00
Sophearak Tha
3a1c68b439 Improve now dev output message (#2506)
* Improve `now dev` output message

* Update src/util/dev/builder.ts

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>
2019-07-09 12:32:24 +02:00
Sophearak Tha
e0489dc171 Throw an error if dev scripts contain now dev in package.json (#2507)
* Throw an error if `dev` scripts contain `now dev` in package.json

* Use proper Package type

* Update src/commands/dev/index.ts
2019-07-09 17:10:57 +07:00
Nathan Rajlich
9919701e2d [now dev] Add test case for lazily installing builders (#2510)
This is a follow up for #2509 to add a unit/regression test ensuring
correct functionality.
2019-07-08 17:44:36 -07:00
Andy Bitz
9ed9ba472e 15.7.0-canary.10 2019-07-08 23:05:40 +02:00
Andy
8513ff260b [now dev] Add support for deployments without now.json (#2498)
* [now-dev] Add zero config

* Update @now/build-utils

* Update @now/build-utils

* Escape glob

* Fix windows and group globbing

* Made sure routes and builds get updated on file events

* Removed useless check

* Add unit tests

* Use fetch instead of get
2019-07-08 23:04:57 +02:00
Nathan Rajlich
900c2a11f7 [now dev] Set Now response headers when proxy passing in routes (#2500)
* [now dev] Set Now response headers when proxy passing in `routes`

* Fix unit test
2019-07-08 22:02:42 +02:00
Nathan Rajlich
00ffd8d46c [now dev] Install missing builders during runtime (#2509)
Before this change, the `installBuilders()` function was only run at
bootup, so if you modify `now.json` during runtime and add a builder
that's not installed, then a `MODULE_NOT_FOUND` error occurs.

Now the `installBuilders()` function is run with the missing builder
so that the builder can be properly loaded.
2019-07-08 11:33:54 -07:00
Leo Lamprecht
cfc326b1ce 15.7.0-canary.9 2019-07-07 16:10:51 +00:00
Olli Vanhoja
dab4c6bf66 Use v3 user tokens API (#2482) 2019-07-07 15:53:46 +02:00
Nathan Rajlich
e21ece1626 [now dev] Allow cache-control header to be overwritten (#2501)
* [now dev] Allow `cache-control` header to be overwritten

This matches the behavior in production.

* Add `now-dev-headers` unit test fixture

* Remove `console.error()` call
2019-07-07 15:43:14 +02:00
Nathan Rajlich
f80f1f79a6 [now dev] Add etag response header for Lambda invocations (#2502)
This matches the behavior in production.
2019-07-07 15:19:54 +02:00
Nathan Rajlich
2414767026 [now dev] Set "must-revalidate" cache-control response header (#2499)
This matches the production router behavior, and prevents running `now
dev` on a different project from serving stale content from a different
project.

Also update the `x-now-id` header to match the production behavior (it
changed at some point).
2019-07-06 00:22:38 +02:00
Nathan Rajlich
887b2ccc6b [now update] Add message saying that Windows is not supported (#2493)
* [now update] Add message saying that Windows is not supported

And direct the user back to the download page in order to re-install.

Closes #2492.

* Exit 1

Co-Authored-By: Steven <steven@ceriously.com>
2019-07-05 13:04:01 -07:00
Sophearak Tha
164d29ccbe 15.7.0-canary.8 2019-07-05 19:31:12 +07:00
Sophearak Tha
4eb46d0436 Bump serve-handler version (#2497) 2019-07-05 19:29:22 +07:00
Nathan Rajlich
e0c6bb4094 [now dev] Move the MissingDotenvVarsError handling to the correct place (#2489)
`validateEnvConfig()` used to be invoked inside of `validateNowConfig()`,
but now it is invoked separately.

Explicitly exiting the process avoids reports going to Sentry.
2019-07-02 11:42:33 -07:00
Steven
3926055a5e 15.7.0-canary.7 2019-07-01 17:55:31 -04:00
Nathan Rajlich
8c00134ad1 [now dev] Use system installed version of Node.js for builds (#2480)
* [now dev] Use system installed version of Node.js for builds

Rather than downloading the 8.10 Node.js binary, simply assume that the
user has their preferred version of `node` already installed onto the
system and use that version.

If there is no `node` binary in the $PATH, then `process.execPath` is
used instead, meaning that the pkg binary node version will be used.

* Simplify `getNodeBin()` using `nothrow` option

* Fix build
2019-07-01 17:54:29 -04:00
Andy Bitz
6a104004e0 15.7.0-canary.6 2019-07-01 19:40:41 +02:00
Sophearak Tha
52df58b7dc 15.7.0-canary.5 2019-07-01 21:21:50 +07:00
Sophearak Tha
983d58c5a6 Improve metrics (#2472)
* ignore metrics with environment variable

* collect exception and exit code

* add deprecated warning for `now alias [id] [url]`

* add exception in util error

* consistent format

* ensure no duplicate warning

* using the right error message

* refactor metrics util
2019-07-01 21:19:49 +07:00
Nathan Rajlich
ec46e616db Remove mkdirp-promise (#2478)
Use the implemention from `fs-extra` instead.
2019-06-28 17:26:02 -07:00
Nathan Rajlich
3758e57cb8 [now dev] Exit the process upon ERR_SERVER_NOT_RUNNING (#2479)
This error happens when Ctrl+C is pressed before the `http.Server`
instance is listening, meaning that the user attempted to quit very
quickly after starting `now dev`.

This change makes the process exit immediately instead of throwing,
which also causes the error to be sent to Sentry (which we do not want).
2019-06-28 17:25:21 -07:00
Mark Glagola
1eaa8f76ea 15.7.0-canary.4 2019-06-28 18:42:10 -05:00
Mark Glagola
8e64d0b5ef More cert error handling for deploy command (#2475)
* More cert errors handling for deploy command

* Apply suggestions from code review

Co-Authored-By: Andy <AndyBitz@users.noreply.github.com>

* Revisions based on review

* Minor revision

* Adds get-deployment-by-id which uses latest v9 endpoint

* Refactor to use apiVersion
2019-06-28 18:28:30 -05:00
Nathan Rajlich
baceee2ecf Update @now/build-utils to v0.7.0 (#2474) 2019-06-28 15:23:55 -07:00
Mark Glagola
a23b7dd2bc Adds --target to arg-common (#2473) 2019-06-28 09:55:43 -05:00
Andy Bitz
0225163353 15.7.0-canary.3 2019-06-28 12:10:34 +02:00
Andy
9dbe89f5aa Change url for revert-alias tests to make it more reliable (#2471)
* Change url for revert-alias tests to make it more reliable

* Use project name from now.json

* Remove unused import in tests
2019-06-28 01:45:52 +02:00
Andy
f89effaa66 Don't verify the user for now dev (#2470) 2019-06-28 00:26:54 +02:00
Andy Bitz
b7e37af8f1 15.7.0-canary.2 2019-06-27 18:32:30 +02:00
Andy
1436e636d3 Don't show warning (#2468) 2019-06-27 18:18:11 +02:00
Andy Bitz
d2c33bbb06 15.7.0-canary.1 2019-06-26 19:28:56 +02:00
Andy Bitz
c5c22620a6 15.6.0-canary.4 2019-06-26 19:02:32 +02:00
Andy
fb7b890e40 Make sure to call secrets API only once (#2464)
* Make sure to call secrets API only once

* Use const
2019-06-26 17:29:35 +02:00
Andy
4e8512e660 Handle deployments rate limit (#2463) 2019-06-26 02:11:30 +02:00
Andy
29de58b5a7 Upgrade esm (#2458)
* Upgrade esm

* Use version 3.1.0

* Use version 3.1.4
2019-06-25 15:04:07 +02:00
Mark Glagola
7a36b9c6a3 15.6.0-canary.3 2019-06-24 13:16:35 -05:00
Mark Glagola
85ba820b27 Handle cert errors in create-deployment (#2455)
* handle cert errors in create-deployment

* Capture challenge_error and txt_record_not_found in mapCertError
2019-06-24 13:02:16 -05:00
Mark Glagola
54ff8ca196 Prompt based DNS add command (#2450)
* Initial prompt based DNS add command

* Adds verify step to dns record prompts

* handle prompt abort
2019-06-24 05:51:59 -05:00
Andy Bitz
9f40a7cca6 15.6.0-canary.2 2019-06-21 18:35:02 +02:00
Andy
9be5970378 now rm improvements (#2449)
* Handle --safe

* Fix  option

* Slice deployments
2019-06-21 18:33:44 +02:00
Andy
2214516689 Handle --safe (#2448)
* Handle --safe

* Fix  option
2019-06-21 17:57:22 +02:00
Andy Bitz
b7f6d4a859 15.6.0-canary.1 2019-06-21 11:31:02 +02:00
Steven
03404e9858 15.4.0-canary.10 2019-06-20 18:11:04 -04:00
Steven
236edcc535 Bump @zeit/fun to 0.9.0 (#2445) 2019-06-20 18:09:06 -04:00
Steven
822b12cc96 [now dev] Improve tests for @now/build-utils@canary (#2444) 2019-06-20 14:38:07 -04:00
Mark Glagola
79d8157798 Move dns_error to generic CertError (#2443) 2019-06-20 09:25:18 -05:00
Mark Glagola
12795f7298 15.4.0-canary.9 2019-06-19 12:35:28 -05:00
Mark Glagola
86f6df6607 Cert error handling revisions/additions (#2437)
* Cert error handling revisions/additions

* Adds certs/add.js back + updated cert error handling to be pipeable

* remove //todo
2019-06-19 12:34:38 -05:00
Steven
b837aca0f8 [now dev] Use canary @now/build-utils or stable based on builders (#2441)
* [now dev] Use canary build utils or stable

* Fix version selection

* Fix test

* Fix typo

* Add tests for getBuildUtils

* Add `latest`
2019-06-18 19:01:16 -04:00
Steven
557ea38869 15.4.0-canary.8 2019-06-18 13:55:55 -04:00
Steven
6a78563b32 Bump @now/build-utils to 0.6.0 (#2440) 2019-06-18 13:49:05 -04:00
Andy Bitz
ec6f71aed9 15.4.0-canary.7 2019-06-18 19:32:09 +02:00
Andy
faccd7fb9e Update help (#2438)
* Update help

* Make whoami advanced

* Make init basic

* Moved update down
2019-06-18 19:19:58 +02:00
Andy Bitz
796bc0acee 15.4.0-canary.6 2019-06-17 23:29:46 +02:00
Andy
ae2638f7a9 Update now rm (#2412)
* Update now rm

* Fixed typo

* Don't use .flat() because of node 10

* Exit process

* Remove only the project instead of all deployments of it

* Changed output text

* Headlines for projects and deployments

* Typo and number prefix
2019-06-17 23:28:16 +02:00
Nathan Rajlich
51b7716cc7 [now update] Handle permissions errors in the file replacement method (#2430)
1. Handle permissions errors in both update mechanisms
 2. Handle `EBUSY` (Windows) as a file busy error
 3. Update permissions error prompt to say "Administrator Command Prompt" on Windows
 4. Add message about "unexpected end of file" error
2019-06-17 13:51:51 -07:00
Nathan Rajlich
c368f98ded 15.4.0-canary.5 2019-06-12 11:09:50 -07:00
Nathan Rajlich
5f1e77cd67 [now dev] Move helper modules to src/util/dev (#2422)
This organization is consistent with how other commands are structured.
2019-06-10 15:41:26 -07:00
Nathan Rajlich
a5b4f0bd87 Lowercase the x-forwarded-* and x-real-ip headers (#2420)
Fixes #2238.
2019-06-10 14:21:53 -07:00
Nathan Rajlich
aab2acf008 [now dev] Run prettier (#2419)
Run `prettier` on the `now dev` codebase since the formatting has
gotten out-of-sync over time.

Also removes a stale TODO comment.
2019-06-10 14:07:02 -07:00
Nathan Rajlich
d740df9600 [now dev] Show a warning when now.json contains a syntax error (#2418)
Rather then throwing which causes the process to exit.
Better to give the developer a chance to fix the syntax
error without having to restart the dev server afterwards.
2019-06-10 13:17:23 -07:00
Nathan Rajlich
cb464939a0 15.4.0-canary.4 2019-06-10 11:50:48 -07:00
Nathan Rajlich
0f2b35175c [now dev] Implement continue: true routes (#2413)
* [now dev] Implement `continue: true` routes

Fixes #2088.

* Add `continue: true` unit test

* Add a `continue: true` unit test that matches
2019-06-10 11:38:22 -07:00
JJ Kasper
33fe99ea43 15.4.0-canary.3 2019-06-08 14:02:45 -07:00
Nathan Rajlich
22344045b8 Add whoami command back (#2411)
* Add `whoami` command back

It was accidentally removed.

Fixes #2410.

* Add `whoami` regression test
2019-06-07 15:14:14 -07:00
JJ Kasper
a81ed47ebc [now-dev] Add checking of RegExp src with beginning slash (#2398)
* Add checking of RegExp src with beginning slash

* Move slash no slash check to same line

* Add unit test for dev-router
2019-06-07 12:40:04 -07:00
Nathan Rajlich
9d247a4fb6 15.4.0-canary.2 2019-06-05 14:55:30 -07:00
Luc
33f6db1daf [now update] Add integration test (#2405)
* add simple integration to test `now update`

* remove `.only`

* verify that `now --version` includes `canary`
2019-06-05 23:46:03 +02:00
Nathan Rajlich
cf7e0e14f5 [now update] No login required (#2406) 2019-06-05 14:12:11 -07:00
Andy Bitz
88a896684f 15.4.0-canary.1 2019-06-05 19:08:51 +02:00
Andy Bitz
55f5aa5b79 15.2.1-canary.7 2019-06-05 14:14:25 +02:00
Andy
a4be2eb79d Fix now rm and decrease total projects for now ls (#2404)
* Use v4 instead to prevent listing the same deployment multiple times

* Remove the latestDeployments since it is depracted and doesn't have the
`readyState` property and only get 35 projects instead of 50 to lower
the rate limit

* Fix tests
2019-06-05 14:13:38 +02:00
Andy Bitz
81c7705690 15.2.1-canary.6 2019-06-05 02:45:24 +02:00
Nathan Rajlich
4dda34fe28 Add now update command (#2388)
* Add `now update` command

Updates the `now` binary in-place.

* Tweaks

* Remove `.ts` suffix in `import` statement

* Remove unused imports

* Implement `getPlatform()`

* Add `ETXTBSY` error fallback method

* Remove `StreamError` import

* Add `chown()` logic

* Remove `console.error()`

* Add `now update` to --help

* Add beta message with feedback URL

* Deprecate `now upgrade` and `now downgrade` commands

* Mention `now upgrade` when a new version is available

* Add `now update` message to `now upgrade`

* Final tweaks
2019-06-05 02:43:43 +02:00
Andy
5a05f6896f Use the projects API for now ls (#2403)
* Use the projects API for `now ls`

* Use recentDeployments
2019-06-05 01:20:14 +02:00
Mark Glagola
e8f7158d52 15.2.1-canary.5 2019-06-04 15:39:04 -05:00
Mark Glagola
fa10b78b30 Handle transfer-in registration_failed (#2402) 2019-06-04 13:08:49 -05:00
Mark
b9be120b17 Update @zeit/ncc to v0.18.5 (#2389) 2019-05-29 17:19:50 -07:00
Nathan Rajlich
4020eb1254 Update @zeit/fun to v0.8.1 (#2391) 2019-05-29 11:16:32 -07:00
Nathan Rajlich
15178f0332 15.2.1-canary.4 2019-05-27 12:54:03 -07:00
Nathan Rajlich
04c11e266a [now dev] Strip prefixed / when doing routes matching (#2361)
* [now dev] Strip prefixed `/` when doing routes matching

The prefixed `/` is implicit when matching routes, so strip them
so that they are optional. This matches the behavior in production.

* Fix unit tests

* More readable

* Add unit test
2019-05-27 12:16:57 -07:00
Steven
7bd40f0aae [now-init] Check for dir existence prior to download (#2379) 2019-05-25 13:53:10 -04:00
Nathan Rajlich
ca17c6da36 [now dev] Use empty string for missing matches (#2376)
Rather than `undefined`. This matches the behavior in production.

Fixes #2375.
2019-05-22 13:04:03 -07:00
Sophearak Tha
16b99a6f72 Mimic browser user agent (#2372) 2019-05-22 09:37:39 +07:00
Sophearak Tha
88a4f52ccd 15.2.1-canary.3 2019-05-20 17:46:46 +07:00
Sophearak Tha
e975ddca8b Add .now ignore by default (#2365) 2019-05-20 17:44:07 +07:00
Leo Lamprecht
225afafe43 15.2.1-canary.2 2019-05-17 18:45:04 +00:00
Andy
1bafb4686f Increase the time we wait for the aliasing (#2360) 2019-05-17 20:43:25 +02:00
Sophearak Tha
2777ec3e2c Integrate universal metrics (#2346)
* integrate universal metrics

* Update src/index.js

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Add default `collectMetrics` config

* Remove flag, only using global config to disable metrics

* Add GA tracking ID

* Move constant to file

* Rename constant to constants

* Rename `dsn` to `SENTRY_DSN`

* Apply suggestions from code review

Co-Authored-By: Leo Lamprecht <mindrun@icloud.com>

* Remove extra space

* Update event category and action

* Remove usagestate to use universal-analytics

* Chain timing and event function

* Make sure to user are unique

* Ensure unique User ID

* Add extra User-Agent and move metrics into its own file

* Use default export
2019-05-17 19:15:56 +02:00
Samuel Hapák
6f817971d0 Help users to deal with secrets starting with dash (#2253)
People are often trying to store secrets starting with dashes such as 
private keys. These dashes get interpreted as command line options which
effectively prevents a storage of private keys.

Fortunately, this is easily resolved by using bash -- convention to mark
an end of options, such as:

`now secret add google-secret-key -- "-----BEGIN PRIVATE KEY-----
abcdefghijklmnopqrstuvwxyz1234567890ABCDEFGHIJKLMNOPQRSTUVXYZ+/a
-----END PRIVATE KEY-----"

The problem is also discussed in following issues: 
https://github.com/zeit/now-cli/issues/749
https://github.com/zeit/now-cli/issues/80
2019-05-17 18:42:42 +02:00
Nathan Rajlich
9358b01cac [now dev] Create yarn.cmd file on Windows (#2358)
The `yarn.cmd` file is necessary for `yarn` to be executable
when running `now dev` through cmd.exe
2019-05-17 18:41:02 +02:00
Nathan Rajlich
a8f8da9906 15.2.1-canary.1 2019-05-16 10:49:33 -07:00
Nathan Rajlich
b2d8550777 [now dev] Use chokidar for file watching (#2350)
* [now dev] Use `chokidar` for file watching

`nsfw` is not suitable for very large projects because it does not
have any "ignore" functionality implemented.

For macOS, the `useFsEvents` option is _disabled_, so that the
`fsevents.node` binary file does not need to be cached onto the
filesystem, which simplifies things for use with `pkg` binaries.

* Delete the `fsevents` module during build

* Add proper `.nowignore` logic to the chokidar watcher
2019-05-16 10:40:09 -07:00
Nathan Rajlich
51b6031eab [now dev] Consider devDependencies when looking up package name (#2352)
Alpha versions of `now dev` that used npm instead of yarn were
installing the packages to `devDependencies` rather than `dependencies`,
so this fixes package name lookup when a legacy cache like that is on
the user's machine.
2019-05-15 17:47:56 -07:00
Nathan Rajlich
370961e872 15.2.1-canary.0 2019-05-13 12:51:07 -07:00
Nathan Rajlich
43e2970620 15.1.1-canary.4 2019-05-10 20:05:15 -07:00
Nathan Rajlich
385c4e4a2f [now dev] Use the dev server cwd as builder's workPath (#2326)
* [now dev] Use the dev server `cwd` as builder's `workPath`

Rather than copying the source files into a temporary directory,
simply use the existing source files in the `cwd`. This will make
subsequent boots of `now dev` be faster (i.e. because the `node_modules`
directory will already be in place), as well as use much less space on
the filesystem because temporary directory are no longer being used.

This will require some changes to the builders and `@now/build-utils`,
to ensure that the `download()` function is always installing into
`workPath`, and that the `meta` object passed to the `build()` function
is also passed into the `download()` function.

For example:

 - https://github.com/zeit/now-builders/pull/474
 - https://github.com/zeit/now-builders/pull/475

* Update `@now/build-utils` to v0.5.5-canary.1

This makes `download()` be a no-op when running in `now dev`.

* Add test case for `@now/next`

* Fix debug log formatting
2019-05-10 17:13:51 -07:00
Nathan Rajlich
39591b4776 Re-enable "try to create a builds deployments with wrong config" integration test (#2337)
It was temporarily disabled due to server-side issues, but that has been
fixed now.
2019-05-10 11:08:39 -07:00
Mark Glagola
2f0218aaa5 Fix transfer in price for some TLDs (#2334) 2019-05-10 07:54:58 -05:00
Nathan Rajlich
9ed897c6be [now dev] Mix in routes query params when proxying to a URL (#2330)
* [now dev] Mix in routes query params when proxying to a URL

Fixes #2289.

* Refactor unit tests and add a unit test for proxy passing with query params

* Fix TypeScript compile error

* [DEBUG] Disable proxy pass unit test

* Run unit tests serially

* Remove `console.error()` in unit test

* Temporarily disable integration test "try to create a builds deployments with wrong config"
2019-05-10 13:09:28 +02:00
Nathan Rajlich
b53d907b74 Adjust now init and now dev to not require a login token (#2325)
* Adjust `now init` and `now dev` to not require a login token

These two commands should not require a login token because
they do not interact with the Now API.

* Remove `config` from `subcommandsWithoutToken` array

It's not an existing command.
2019-05-07 15:56:08 -07:00
Nathan Rajlich
7aa2a27fc9 15.1.1-canary.3 2019-05-06 16:39:44 -07:00
Nathan Rajlich
742be77cfb [now dev] Inherit env vars from now.json (#2321)
* [now dev] Inherit env vars from `now.json`

Before it was only using env vars defined in the `.env` and `.env.build`
dotenv files.

* Fix secrets validation
2019-05-06 14:38:11 -07:00
Andy Bitz
44946520ef 15.1.1-canary.2 2019-05-06 21:59:43 +02:00
Andy
35d45f7493 Fix Git Bash and make update/uninstall work on Windows (#2322)
* Update index.js

* Fix bash file
2019-05-06 21:58:11 +02:00
Nathan Rajlich
a6fa395822 [now dev] Add meta.env and meta.buildEnv for builders (#2320)
Some builders require access to the runtime env vars, i.e. `@now/next`
since it spawns a `next dev` subprocess and should be passing the
runtime env vars to that.
2019-05-06 11:06:38 -07:00
Leo Lamprecht
48ff96d9e7 15.1.1-canary.1 2019-05-06 12:03:36 +00:00
Spellar Bot
53e0f89311 Fix a few typos in err.sh pages (#2311) 2019-05-03 17:17:44 -07:00
Timothy
871a89bf50 Update missing-env-file.md (#2281)
* Update missing-env-file.md

* Update missing-env-file.md
2019-05-03 17:17:34 -07:00
Nathan Rajlich
648fb6f949 15.0.11-canary.3 2019-05-03 10:37:35 -07:00
Steven
709fd1bf12 Update Readme with now dev workflow (#2308) 2019-05-03 10:18:40 -07:00
Nathan Rajlich
cf51fdb026 [now dev] Implement methods in routes config (#2306)
Fixes #2148.
2019-05-03 14:21:26 +02:00
Nathan Rajlich
1e8a825e94 [now dev] Send all status codes if routes config contains one (#2307)
Before it was only respecting the status code for 301, 302 and 303
status codes. Now it handles any status code defined in the routes
config.

Fixes #2294.
2019-05-03 14:20:33 +02:00
Nathan Rajlich
2ab71798de 15.0.11-canary.2 2019-05-02 12:26:18 -07:00
Matthew Sweeney
683de6048e [now init] Add line breaks to success message (#2285)
* add line break to success message

* change to using original util

* Update src/commands/init/init.ts

Co-Authored-By: msweeneydev <26944716+msweeneydev@users.noreply.github.com>
2019-05-02 12:06:40 -07:00
Nathan Rajlich
49e619ce11 [now dev] Update @zeit/fun and @now/build-utils for Windows (#2302)
Not all builders will be working yet, but this adds minimal Windows
support for `now dev`.
2019-05-02 13:21:01 +02:00
Nathan Rajlich
fc5c8dd74f Convert the build script to Node.js (#2301)
Because, you know, Windows.
2019-05-02 00:11:07 -07:00
Nathan Rajlich
fb46cc7761 [now dev] Show build logs if a build fails during bootup (#2297)
* [now dev] Show build logs if a build fails during bootup

Before, the logs were never shown because `buildProcess` does not emit
an `error` event when the child process exits.

Also updates `ora` to the latest version.

* Remove `@types/ora`

`ora` includes its own TypeScript definitions now.
2019-05-01 23:43:07 -07:00
Nathan Rajlich
332867a9f5 [now dev] Set NOW_REGION: 'dev1' env on the builder processes (#2298) 2019-05-01 13:02:23 -07:00
Steven
dfea510e68 Add .next and .cache to default ignore (#2295) 2019-05-01 14:21:02 -04:00
Nathan Rajlich
baff58eecc Update pkg to v4.3.8 (#2293)
Which includes this fix: https://github.com/zeit/pkg/issues/671

Relevant to `now dev` invoking `yarn` when a package includes
a postinstall script that invokes `node`.
2019-05-01 10:01:59 -07:00
Steven
0db933b6a3 Create CODE_OF_CONDUCT.md (#2290) 2019-05-01 09:38:57 -04:00
Nathan Rajlich
4552ad9b36 [now dev] Use consistent cache directory for nsfw module download (#2280) 2019-04-30 10:08:21 -07:00
Shuying
78a04905f1 Update feedback url (#2278) 2019-04-30 18:49:26 +02:00
Nathan Rajlich
3caa922e76 [now dev] Convert path backslashes to forward slashes for Windows (#2279) 2019-04-30 09:48:12 -07:00
Leo Lamprecht
24572b554b 15.0.11-canary.1 2019-04-30 10:11:51 +00:00
Nathan Rajlich
35109800d5 [now dev] Enable cleanUrls option when deployment is all static (#2277)
So that rendering `index.html` as root works as expected.
2019-04-30 11:17:24 +02:00
Nathan Rajlich
1c009266cc 15.0.10-canary.2 2019-04-29 20:14:50 -07:00
Nathan Rajlich
5ec45459e5 [now dev] Install builders with yarn instead of npm (#2272)
* [now dev] Install builders with `yarn` instead of `npm`

Also invokes via `process.execPath` so that the pkg'd node is used
instead of a global one.

Depends on #2270.

* Install `yarn` to the builder cache dir

Not the `node_modules/.bin` dir, because `yarn` cleans up that directory
when installing modules, so it deletes itself.

* Remove unnecessary unit test

* Always install `yarn`

* Pass in the `yarnPath` to `installBuilders()`

* Restore unit test

* Remove unused `delimiter` import

Co-Authored-By: TooTallNate <n@n8.io>
2019-04-29 19:57:57 -07:00
Steven
37964c1e0f [now dev] Install yarn into builder cache (#2270)
Closes #2063.
2019-04-29 17:44:14 -07:00
Nathan Rajlich
ea8add7316 Update CODEOWNERS for dev, certs and domains commands (#2275)
* Update CODEOWNERS for `dev` command

Also added a fallback for @leo

* Remove `init`, add `domains` and `certs`
2019-04-29 16:38:00 -07:00
Nathan Rajlich
baed2da509 [now dev] Show build timestamps (#2273)
* [now dev] Show build timestamps

Except when running the initial builds

* Fix bad logic
2019-04-29 15:05:10 -07:00
Steven
7be66960b7 [now-dev] Fix .nowignore to match production (#2233)
* Fix now dev usage of .nowignore

* Fix now dev usage of .nowignore

* Move env before nowjson

* Remove console.log()

* Remove comments & unused imports

* Fix merge conflicts

* Fix merge conflicts

* Add docs

* Fix stat mode
2019-04-29 17:35:19 -04:00
Nathan Rajlich
ab6f72e44d [now dev] Don't render initial builds spinner when debug is enabled (#2271) 2019-04-29 13:58:22 -07:00
Leo Lamprecht
251083bf38 15.0.10-canary.1 2019-04-29 18:19:30 +00:00
Leo Lamprecht
6426b1e430 Revert "Enable cleanUrls for entirely static projects (#2268)"
This reverts commit c7ed5d7850.
2019-04-29 18:19:07 +00:00
Nathan Rajlich
635b20d4ab [now dev] Show builder logs, even after build completes (#2269)
This is important for builders like `@now/next` and `@now/static-build`
which launch a child process dev server, and we want those logs to be
visible from the `now dev` console output.
2019-04-29 18:41:01 +02:00
Leo Lamprecht
f38669576a 15.0.9-canary.3 2019-04-29 14:05:32 +00:00
Leo Lamprecht
c7ed5d7850 Enable cleanUrls for entirely static projects (#2268) 2019-04-29 15:25:33 +02:00
Leo Lamprecht
67a918401c Correctly log when setting up Builders (#2267)
* Correctly log when setting up Builders

* Added message about beta
2019-04-29 14:33:23 +02:00
Leo Lamprecht
08f0e02f42 Do not print installing builders for no builds (#2266)
* Do not print installing builders for no builds

* Added unit test
2019-04-29 13:46:18 +02:00
Andy
0748cb7698 Display handle in now inspect (#2265) 2019-04-29 11:47:12 +02:00
Leo Lamprecht
76c9a233b9 15.0.9-canary.2 2019-04-28 21:11:32 +00:00
Leo Lamprecht
b3f584686b Make the message for when the server is running shorter (#2262) 2019-04-28 23:01:24 +02:00
Leo Lamprecht
18f06fde2a Fixed error for .env and .env.build (#2261)
* Do not report env errors to Sentry

* Added guide for missing env file in dev mode

* Update errors/missing-env-file.md

Co-Authored-By: leo <mindrun@icloud.com>

* Update errors/missing-env-file.md

Co-Authored-By: leo <mindrun@icloud.com>
2019-04-28 21:45:35 +02:00
Nathan Rajlich
c13545d585 [now dev] Refactor builders installation logic (#2254)
* [now dev] Refactor builders installation logic

 - Don't run `npm update`, only `npm install`, so no more "Checking for
   builder updates".
 - Don't save `package-lock.json`, to allow builders with newer versions
   than already installed to be updated.
 - Properly supports non-npm-registry builders (i.e. an HTTP URL,
   `github:` syntax, etc.

* Use `Object.entries()`
2019-04-28 12:38:08 -07:00
Matthew Sweeney
112497d55e Adds 'to develop' to now init (#2260)
Adds 'to develop' to now init
2019-04-28 18:58:32 +02:00
Amio
91069f6d38 [now dev] fix directory listing (#2256) 2019-04-28 17:50:23 +02:00
Andy
2cf846ead3 Wait for aliases in tests (#2257) 2019-04-28 17:35:50 +02:00
Leo Lamprecht
310e1b4247 Revert "Add a logout test case" (#2258)
This reverts commit 5754360684c1e34b0351fadd9e2a6e5ef4b8b82f.
2019-04-28 17:22:52 +02:00
Olli Vanhoja
2f12b08616 Use the single request logout endpoint (#2201)
Logout by deleting the currently used auth token.
2019-04-28 10:58:56 +02:00
Nathan Rajlich
744ef92faa [now dev] Don't render building/built logging for @now/static
Since it's a built-in builder.
2019-04-27 18:55:14 -07:00
Leo Lamprecht
aa8d77e571 15.0.9-canary.1 2019-04-27 14:11:26 +00:00
Steven
6f8c9fe548 Add python virtual environment to default ignore (#2241) 2019-04-27 14:11:11 +00:00
Leo Lamprecht
b6ded9a7fe Do not check for @now/static Builder updates (#2251) 2019-04-27 16:10:31 +02:00
Leo Lamprecht
468fa88139 Print missing line when stopping server (#2250) 2019-04-27 15:49:33 +02:00
Leo Lamprecht
1aa46713c2 Only print stopping server if already printed URL (#2249) 2019-04-27 15:40:44 +02:00
JJ Kasper
9029a51707 Update to make sure query isn't stripped (#2246)
* Update to make sure query isn't stripped
before ProxyPass in dev-server

* Add test for stripping query

* normalize semis in test
2019-04-27 14:23:11 +02:00
Nathan Rajlich
6df363e2da [now dev] Better logging while building and error recovery (#2244)
- Have the builder exit if a rejection occurs
 - Respawn the builder upon next rebuild after the builder has exited
 - Log when builder is starting and completed with build time
 - Render build error in the HTTP response
2019-04-27 13:23:45 +02:00
Amio
36f5b265c8 Refine dev log layout (#2245) 2019-04-27 13:13:33 +02:00
Nathan Rajlich
929ea187ce [now dev] Lazily initialize the nodejs8.10 runtime for builds (#2243) 2019-04-26 22:23:43 +02:00
Leo Lamprecht
822f203f5a Bumped @zeit/nsfw to latest (#2242) 2019-04-26 22:20:15 +02:00
Leo Lamprecht
54d02b6ab2 Support Windows when downloading file watcher (#2240) 2019-04-26 21:59:06 +02:00
Andy
f9919fe854 Modify the gitbash file correctly (#2223) 2019-04-26 21:46:12 +02:00
Amio
73de0f228a [now dev] exit on MissingDotenvVarsError (#2237) 2019-04-26 20:09:06 +08:00
Steven
9d73f7735e Convert get-files from JS to TS (#2207)
* Convert get-files from JS to TS

* Bump @zeit/dockerignore to 0.0.5

* Fix types

* Fix typo

* Remove arr-flatten dependency
2019-04-25 16:47:21 -04:00
Leo Lamprecht
a0209f4667 15.0.8-canary.1 2019-04-25 19:29:01 +00:00
Nathan Rajlich
60b36cb3f8 [now dev] Supply empty default now.json if one does not exist (#2231)
This forces all the files to be served as static assets using
`@now/static`, rather than having a special branch that dishes
out to `serve-static`. This is better because it keeps the logic
consistent with when a `now.json` is supplied vs. when it is not,
and allows the code to be simplified by removing checks for if
`getNowJson()` returned anything (previously it could return `null`,
but now that is not the case). Also allows us to remove the now-unused
`serveProjectAsStatic()` function.
2019-04-25 11:56:20 -07:00
Nathan Rajlich
454ce02565 [now dev] Force @now/static to run in-memory (#2230)
* [now dev] Force `@now/static` to run in-memory

The logic for `@now/static` builder is bundled into the `pkg` binary,
and thus is not requireable, so it must instead be run in-memory.

* Also check for stdout TTY before doing the erase lines stuff
2019-04-25 11:13:14 -07:00
Leo Lamprecht
048434a564 15.0.7-canary.8 2019-04-25 14:29:38 +00:00
Nathan Rajlich
0334b75cfa [now dev] Invoke builders in a forked child process (#2227)
* Update `@zeit/fun` to v0.7.0

* Remove `builderCachePromise`

No longer used.

* Remove `intercept-stdout`

* WIP invoke the builder in a forked child process

* WIP Add `builder.js` file

* Remove `BuildResultV1 | BuildResultV2` distinction

Prefer normalizing the `build()` function result to `BuildResult` v2
shape so that we don't have to cast everywhere else.

* Apply build env vars to builder child process

* Copy the `builder.js` file from the pkg filesystem snapshot to the builder cache dir

* Map `FileFsRef` and `FileBlob` of the builder's output back into instances

* Fix `@now/next` :/

* Cleanup

* Print number of initial builds

* Add spinner for building process

* Refine logs

* Support none-tty

* Crop long lines

* Clean up imports

* Refine logs wording
2019-04-25 16:28:58 +02:00
Nathan Rajlich
ce0ed935c8 [now dev] Always watch the entrypoint for triggering rebuilds (#2226)
The `entrypoint` should always be watched, since we know that it was used
to produce the build output. This is for builders that don't implement
a fully featured `watch` return value.
2019-04-24 13:49:50 -07:00
Leo Lamprecht
ad89a63091 15.0.7-canary.7 2019-04-24 18:54:02 +00:00
Nathan Rajlich
d148edcb67 [now dev] Don't include a file in both filesChanged and filesRemoved list (#2225)
* [now dev] Don't include a file in both `filesChanged` and `filesRemoved` list

This makes it so that if a file is added to the "changed" array, then it
is also removed from the "deleted" array, and vice-versa.

* Only render the "files changed/remove" debug log if there are entries
2019-04-24 20:53:29 +02:00
Leo Lamprecht
36d2e29954 15.0.7-canary.6 2019-04-24 17:05:42 +00:00
Leo Lamprecht
76d3643e0f Bumped @now/build-utils to latest version (#2220) 2019-04-24 19:05:07 +02:00
Leo Lamprecht
a12e228cc4 15.0.7-canary.5 2019-04-24 12:21:56 +00:00
Amio
669ee6a65f [now-dev] Exit when incorrect cwd config (#2218)
* [now-dev] Exit when incorrect cwd config

* better wording
2019-04-24 13:25:20 +02:00
Nathan Rajlich
a7f734fadf [now dev] Use minimatch on the watch array to support globs (#2216)
This will be necessary for `@now/static-build` since it needs to watch
all files in the dir containing the entrypoint. For example:

```
watch: [ path.join(path.dirname(entrypoint), '**/*') ]
```
2019-04-24 10:21:43 +08:00
Nathan Rajlich
8405c2d6cd [now dev] Allow a builder watch array to contain "./" prefixed paths (#2217)
The file watcher logic expects that there is no `'./'` prefix on the
watched file paths/patterns, but `path.dirname('foo')` returns `'.'`
which turns into `'./foo'` with `path.join()`. So this allows those
file paths to be returned from the builder and `now dev` normalizes the
paths after the build has completed.
2019-04-23 19:17:02 -07:00
Leo Lamprecht
10316c871b 15.0.7-canary.4 2019-04-23 19:06:55 +00:00
Nathan Rajlich
3b94b105fe [now dev] Add xfwd option to http-proxy (#2215)
This makes the `http-proxy` module set the `X-Forwarded-*` HTTP request
headers to the destination endpoint.
2019-04-23 11:21:41 -07:00
Nathan Rajlich
d7abf96414 [now dev] Pass in the builder-specific workPath to shouldServe() (#2214)
The dev server `cwd` is not correct working path of a build match, so
pass in the correct one. This property will be used by
`@now/static-build`'s dev mode.
2019-04-23 10:49:53 -07:00
Steven
2c4d9d5af0 Ignore __pycache__ directories (#2213) 2019-04-23 11:38:12 -04:00
Mark
e14ddc11ee Update @zeit/ncc to v0.18.1 (#2210) 2019-04-23 17:31:17 +02:00
Leo Lamprecht
11eb122ecc 15.0.7-canary.3 2019-04-23 12:05:47 +00:00
Nathan Rajlich
40be8ef688 [now dev] Remove requiresInitialBuild and make shouldServe() optional for v2 Builders (#2209)
* [now dev] Remove `requiresInitialBuild` and make `shouldServe()` optional for v2 Builders

`@now/next` will be removing `shouldServe()` in favor of returning
a `routes` config array upon bootup. This makes now dev's
`shouldServe()` wrapper function support matching a `routes` config
entry when `shouldServe()` is not defined.

* Remove `console.error()` debugging calls

* Remove `mergeRoutes()` logic

This was incorrect behavior, and more like what `continue: true` is
supposed to do.

* Remove invalid test case

* Remove from the `files` array when ENOENT occurs in file watcher

* Prettier

* Pass workPath to builder.shouldServe() (#2211)
2019-04-23 13:14:19 +02:00
Amio
d7a72a92f2 Support env NOW_BUILDER_CACHE_DIR for debugging builders (#2212)
* Support env NOW_BUILDER_CACHE_DIR for debugging builders

* resolve NOW_BUILDER_CACHE_DIR
2019-04-23 15:25:05 +08:00
Nathan Rajlich
6338809487 [now dev] Resolve built routes after matching builder (#2208)
* [now dev] Resolve built routes after matching builder

This removes the `combineRoutes()` function since it was problematic and
triggered rebuilds upon every HTTP request, which is not necessary and
makes development slower.

Now, when an HTTP request comes in, the `now.json` routes are resolved
first, and then the matched build is checked if it defines any `routes`
in the build output. If it does, and a matching route is found then the
route is handled accordingly.

* Fix dev router unit tests

* Only try to match build routes if `.length > 0`

* Remove `routes` config from `@now/static` build results

This would cause an infinite loop of resolving `entrypoint` to
`entrypoint`, and is not necessary for this builder.
2019-04-22 15:39:25 -07:00
Leo Lamprecht
68408df4d6 Initial build should set requestPath to null (#2200)
* Initial build should set `requestPath` to `null`

* Fixed types

* Fixed type
2019-04-22 20:29:49 +02:00
Nathan Rajlich
7266a97b54 [now dev] Fix typo in debug log (#2206)
Also switch to present-tense wording.
2019-04-22 10:28:08 -07:00
Amio
808038160f [now-dev] make routes from v2 builders optional (#2204) 2019-04-22 15:49:41 +08:00
Leo Lamprecht
994b01719e Better name for continuous property (#2199) 2019-04-21 20:29:47 +02:00
Leo Lamprecht
6e6330bf07 Prevent exit if client closes proxy connection (#2198) 2019-04-21 18:46:57 +02:00
Leo Lamprecht
f8b4958986 15.0.7-canary.2 2019-04-20 00:19:11 +00:00
Leo Lamprecht
b7530d494c Match only the important part while routing (#2195) 2019-04-20 02:19:00 +02:00
Leo Lamprecht
e6aed4bd71 15.0.7-canary.1 2019-04-19 22:11:09 +00:00
Amio
57d6723adb Made sure support for routes works as expected (#2194)
* Fix lost concat result

* Made it work

* Fixed several tests

* Fixed more tests

* Fixed tests
2019-04-20 00:09:00 +02:00
Amio
c0ee3f071e Added support for routes (#2191)
* Add types for updated builder v2 api

* Fix type errors

* outputs => output

* Combine builder routes before routing

* Combine builder routes for all v2 builders

* [temporarily] reveal logs from builder

* Revert "[temporarily] reveal logs from builder"

This reverts commit 9dac764f33d96b5fd004e0839b41228786f83d14.
2019-04-19 16:28:39 +02:00
Amio
54cfe2e99e Reveal builder logs when --debug (#2193)
And added a `debug` flag to `DevServer` class
2019-04-19 21:57:01 +08:00
Andy Bitz
25f6cb7522 15.0.5-canary.5 2019-04-18 15:08:24 +02:00
Andy
0a69920b3f Show all aliases instead of just the first one (#2188) 2019-04-18 15:06:35 +02:00
Andy
adad86401f Now CLI gets a fixed alias (#2189) 2019-04-18 14:56:09 +02:00
Nathan Rajlich
6b3a5880b1 [now dev] Reuse the same workPath for subsequent builds (#2185)
* [now dev] Reuse the same `workPath` for subsequent builds

Reusing the same `workPath` for subsequent builds makes rebuilding
faster, as well as it's necessary for webpack's watcher to work
correctly as it relies on the full filesystem paths being intact.

`prepareCache()` also no longer needs to be invoked, since the
previous `workPath` directory will already contain the necessary files
that the cache would otherwise produce.

* Prettier
2019-04-18 11:57:23 +02:00
Nathan Rajlich
de4e340338 [now dev] Don't trigger a rebuild if an asset was deleted (#2184)
* [now dev] Don't trigger a rebuild if an asset was deleted

This handles the case where an asset was deleted and should no longer be
served after a filesystem watcher event. For example, if a Next.js page
was previously built and the files was deleted from the `pages`
directory, then the rebuild should not happen since it will fail in the
`build()` function anyways.

* Add `config` to `shouldServe()`

* Remove unused `builder` var
2019-04-17 21:25:08 -07:00
Andy Bitz
c10519acc2 15.0.5-canary.4 2019-04-17 23:36:33 +02:00
Andy
dfb4e8921a Show a upgrade message if the build limit is exceeded (#2182)
* Show a upgrade message if the build limit is exceeded

* Typo

* Update src/commands/deploy/latest.js

Co-Authored-By: AndyBitz <AndyBitz@users.noreply.github.com>
2019-04-17 23:34:00 +02:00
Andy Bitz
6e51e5db30 15.0.5-canary.3 2019-04-17 20:32:14 +02:00
Andy
7a9e12affa Show the domain purchase UI (#2168)
* Show the domain purchase UI

* Show the correct error message

* Exit after the domain purchase
2019-04-17 20:27:54 +02:00
Andy
011d41af57 Add tests for the new automatic aliasing in the v9 API (#2180)
* Add tests for the new automatic aliasing in the v9 API

* Show a more descriptive message

* Await sleep

* Add sleep to test

* Decrease sleep
2019-04-17 19:27:07 +02:00
Amio
469e8c0505 Add some debug logs for now-dev (#2181)
* Add some debug logs

* Fix eslint warnings
2019-04-17 18:06:21 +02:00
Duncan
d59bc07b89 Fix batch file command to work from paths with spaces. (#2144)
Fixes #2413.
2019-04-17 10:56:42 +02:00
Nathan Rajlich
e7d101c37e [now dev] Handle filesystem events where the file has already been deleted (#2179)
Editors like `vim` like to use temporary files in the file's working
directory and quickly rename / delete them. This makes `now dev` handle
that gracefully and not crash.
2019-04-16 21:22:42 -07:00
Andy Bitz
b0f83bd1a0 15.0.5-canary.2 2019-04-17 01:25:30 +02:00
Andy
9016f25504 Bump @zeit/nsfw to 2.0.2 (#2178) 2019-04-17 01:09:08 +02:00
Andy
02134807d8 Use the v9 deployments API (#2176) 2019-04-17 00:39:41 +02:00
Nathan Rajlich
fb4da34562 [now dev] Default the Content-Type to "application/octet-stream" (#2177)
This matches the behavior in production, so it is more correct.

This new common `getMimeType()` function also centralizes a place where
we can overwrite the `mime-types` return value to other values to match
production for other future discrepancies.
2019-04-17 00:14:47 +02:00
Leo Lamprecht
0da322560c 15.0.5-canary.1 2019-04-16 19:51:14 +00:00
William Li
4aece1395e [BUG-FIX] team invite ignored scope error (#2140)
* expose teams command to --scope change, fixes #2139
2019-04-16 19:51:00 +00:00
Leo Lamprecht
cc06b39905 15.0.4-canary.8 2019-04-16 19:09:17 +00:00
Amio
de9eebdf76 Mute install logs from @now/node builder (#2171)
* [wip] Mute install logs from @now/node builder

* Bumped build utils
2019-04-16 21:07:40 +02:00
Nathan Rajlich
db1af88681 Pass filesChanges and filesRemoved array to builder's build() (#2174)
This will be required to implement the `@now/node` ncc watcher logic.
2019-04-16 20:24:45 +02:00
Nathan Rajlich
7979110f2b Added file watcher to now dev (#2153)
* [now dev] Add `nsfw` file watcher

WIP for triggering background rebuilds. So far the `files` mapping is
now kept in sync via the events produced by `nsfw`.

* Add `now.json` caching and invalidation from nsfw events

* Add initial rebuilding logic from filesystem watching

* Remove previously built assets when a rebuild occurs

* Make `@now/static` not require a hard refresh

* Shut down the `nsfw` instance when stopping the DevServer

* Prettier and some minor tweaks

* Ship module

* Support private deps

* Fixed tests

* Fixed integration tests

* Revert "Support private deps"

This reverts commit 0b4991b87641d693fa61f81223e0efc2b7006f83.

* Support multiple platforms

* Typed

* Consider Alpine

* Bumped @zeit/nsfw to latest version

* Update src/commands/dev/lib/nsfw-module.ts

Co-Authored-By: leo <mindrun@icloud.com>

* Pass module path differently

* Bumped package

* Make binary executable

* Wait until piping is complete

* Added debug statements
2019-04-16 20:13:15 +02:00
Amio
9a81b5a598 Enable '@typescript-eslint/no-unused-vars': 'warn' (#2172)
* Enable '@typescript-eslint/no-unused-vars': 'warn'

* Clean comments
2019-04-16 20:07:37 +02:00
Nathan Rajlich
23d44347ac Enable source maps for development builds of now-cli (#2170)
If you run `yarn build-dev`, then now source maps are enabled, allowing
us to see the proper line of an error in the source code file instead of
the huge `dist/index.js` file.

Previously they were only enabled for production builds.
2019-04-15 18:27:59 -07:00
Ana Trajkovska
6f2526a75a 15.0.4-canary.7 2019-04-15 22:54:42 +02:00
Ana Trajkovska
2bd4341c07 Handle additional errors when issuing a certificate (#2165)
* Handle additional errors when issuing a certificate

* Rename errors

* Provide more context in CertsDNSError

* Fix CertsDNSError structure

* Display cns with join

* Fix CertsDNSError
2019-04-15 22:47:42 +02:00
Nathan Rajlich
2f3581fe1c [now dev] Add host property to the invoke payload (#2164)
Fixes https://github.com/zeit/now-builders/issues/390.
2019-04-14 15:40:07 -07:00
Nathan Rajlich
6ddb7246d8 [now dev] Use empty version string for @now/static (#2159)
This is just a cosmetic fix so that "vbuilt-in" isn't printed when
`--debug` is enabled.
2019-04-13 14:19:25 -07:00
Nathan Rajlich
ce2773491a 15.0.4-canary.6 2019-04-12 16:16:46 -07:00
Nathan Rajlich
614b9c412a [now dev] Don't run every build when a v1 builder is detected (#2151)
Before this, if a v1 builder was detected then every build match was
built instead of only the matches that use a v1 builder.
2019-04-12 12:00:51 -07:00
Nathan Rajlich
2dfd4e84e1 [now dev] Fix index-based asset lookup logic (#2138)
There was a bug in the index lookup logic such that `GET /404` would be
matching the `/index.*` file. Fixed in this commit.
2019-04-11 18:50:54 -07:00
Leo Lamprecht
0f74a0695c 15.0.4-canary.5 2019-04-11 11:10:37 +00:00
Nathan Rajlich
e85c416d01 [now dev] Refactor to support shouldServe() in Now Builders (#2134)
* WIP refactor to Now Builders v2 API

* More WIP

* Finish up refactor

* Remove `BuiltAsset` type

These properties are on the the `BuildMatch` interface now.

* Fix `handle: filesystem` route post-refactor

* Prettier

* Update src/commands/dev/lib/builder-cache.ts

Co-Authored-By: leo <mindrun@icloud.com>
2019-04-11 13:10:27 +02:00
Leo Lamprecht
6ac63baaa5 15.0.4-canary.4 2019-04-11 10:52:41 +00:00
Amio
96c630b27c Improve eslint config (#2042)
- Get `.ts` files covered 🎉
- Update eslint related dependencies
- Add typescript-eslint [recommended rules](3e26ab684a/packages/eslint-plugin/src/configs/recommended.json), but only enabled ones we already followed, commented ones causing errors.

Commented rules including:

```yaml
  # '@typescript-eslint/no-unused-vars': 1
  # '@typescript-eslint/indent': ['error', 2]
  # '@typescript-eslint/array-type': error
  # '@typescript-eslint/ban-types': error
  # '@typescript-eslint/explicit-member-accessibility': error
  # '@typescript-eslint/member-delimiter-style': error
  # '@typescript-eslint/no-angle-bracket-type-assertion': error
  # '@typescript-eslint/no-explicit-any': warn
  # '@typescript-eslint/no-object-literal-type-assertion': error
  # '@typescript-eslint/no-use-before-define': error
  # '@typescript-eslint/no-var-requires': error
  # '@typescript-eslint/prefer-interface': error
```

### TODO

Go through these commented rules one by one, enable & fix for it or confirm it's disabled. Since enabling some rules would cause massive code change (like `'@typescript-eslint/indent': ['error', 2]`), which might conflict with our ongoing development, we better do this in separated PRs.
2019-04-11 17:29:54 +08:00
Mark Glagola
ff353a264e Handle CAA cert conflict error (#2121)
* Handle CAA cert conflict error

* Fixed error description

* using output.success instead of console.log(...)

* Revert "using output.success instead of console.log(...)"

This reverts commit 2db9a834f3d22ec2da7c692b0e67ea2863078489.
2019-04-10 15:37:59 -05:00
Leo Lamprecht
45097563f0 15.0.4-canary.3 2019-04-10 20:24:31 +00:00
Leo Lamprecht
12370a8033 Add a note about the CDN always being enabled (#2133)
* Revert "Stop indicating whether CDN is enabled (#2132)"

This reverts commit 3dda3e84bf.

* Add a note about the CDN always being enabled

* Removed useless flag

* Added correct table heading
2019-04-10 22:24:14 +02:00
Leo Lamprecht
d1c67b013b 15.0.4-canary.2 2019-04-10 20:02:03 +00:00
Leo Lamprecht
3dda3e84bf Stop indicating whether CDN is enabled (#2132) 2019-04-10 20:47:42 +02:00
Leo Lamprecht
a1a85732d4 15.0.4-canary.1 2019-04-10 17:20:35 +00:00
Leo Lamprecht
bc4a2c8dce Print full validation error message (#2131)
* Print full validation error message

* Shortened second message

* Updated latest pipeline too
2019-04-10 19:19:40 +02:00
Mark Glagola
f22c288bf4 fixes certs rate limited cns arg (#2130) 2019-04-10 11:27:48 -05:00
Amio
37a63e1c70 Bump ava to 1.4.1 (#2128) 2019-04-10 23:55:12 +08:00
Mark Glagola
0c50c5a1a6 15.0.3-canary.6 2019-04-10 10:50:26 -05:00
Mark Glagola
f2c487162f Handle unsupported tld purchase (#2129) 2019-04-10 10:50:10 -05:00
Nathan Rajlich
430696f486 [now dev] Add logging of the builder package versions (#2125)
* [now dev] Add logging of the builder package versions

To aid in debugging errors reported by users.

* Remove bad
2019-04-09 18:50:11 -07:00
Mark Glagola
2426547762 15.0.3-canary.5 2019-04-09 17:21:11 -05:00
Mark Glagola
e877467a98 Fix getCertsById + handle cert not found by id error (#2101)
* fix certs delete + handle not found error

* Converted rm.js -> rm.ts
2019-04-09 17:17:57 -05:00
Nathan Rajlich
060c3de74e [now dev] Add build de-duping for the lazy initial builds case (#2124)
This is the same de-duping logic that occurs when you hard refresh,
but the unbuilt case was still not being considered. This fixes clicking
on an unbuilt link more than once from triggering multiple builds of the
same asset.
2019-04-09 10:07:56 -07:00
Nathan Rajlich
4c297d2ab4 15.0.3-canary.4 2019-04-07 21:59:44 -07:00
Nathan Rajlich
53ccc9e02b [now dev] Update @now/build-utils to v0.4.40 (#2119) 2019-04-07 21:50:45 -07:00
Nathan Rajlich
477b30583e [now dev] Update @now/build-utils to v0.4.40-canary.0 (#2118) 2019-04-07 19:58:35 -07:00
Nathan Rajlich
315bbbe25e 15.0.3-canary.3 2019-04-07 15:18:16 -07:00
Nathan Rajlich
62cc84fc9a [now dev] Add handle: filesystem support (#2116) 2019-04-07 15:17:54 -07:00
Nathan Rajlich
e28bf1152c [now dev] Run npm update to get builder updates (#2117) 2019-04-07 15:13:21 -07:00
Leo Lamprecht
9519b3b0e7 15.0.3-canary.2 2019-04-07 13:49:10 +00:00
Mark
b7462211e6 Update @zeit/ncc to v0.17.4 (#2107) 2019-04-07 15:47:56 +02:00
Nathan Rajlich
13d447a81b [now dev] Run prepareCache() asynchronous (#2105)
* [now dev] Run `prepareCache()` asynchronous

And also wait a few seconds before running the actual logic,
since the `prepareCache()` function may be computationally expensive,
and its run in the same process as `now dev` (for now), so allow
some time for the current HTTP request to complete.

* Add symlinks support to `glob()`, instrument prepareCache time
2019-04-07 15:47:40 +02:00
Nathan Rajlich
049d6e61df [now dev] Invoke prepareCache() from Builders (#2104)
If a builder defines the `prepareCache()` function, then it gets invoked
after `build()` has completed to set up the initial build state of the
next build for this same asset.

For example, the goal for `@now/node` if the package.json has not
changed is to have yarn produce the "Already up-to-date" message on the
next build, because installing dependencies ends up taking a long time
on bigger projects.
2019-04-05 20:26:44 -07:00
Andy Bitz
482aba0c45 15.0.3-canary.1 2019-04-05 23:57:37 +02:00
Andy
f9a931dbd2 Exit if assigning an alias failed while deploying (#2103)
* Error if aliasFinal is an empty array

* Return if alias assignment failed
2019-04-05 23:53:05 +02:00
Leo Lamprecht
ec376e272d 15.0.2-canary.5 2019-04-05 13:37:09 +00:00
William Li
c13d250577 Don't forget to do a yarn install before linking (#2094) 2019-04-05 13:37:04 +00:00
Joe Haddad
c372f1b66b 15.0.2-canary.4 2019-04-04 20:59:24 -04:00
Nathan Rajlich
bd1aa229e3 [now dev] Use a different workPath for every build (#2100)
This is more inline with how a fresh Now deployment works, where
is has to download fresh files each time. This will also fix the issue
with `@now/next` that deleted the `.next` output dir and deleting static
files upon subsequent builds.

This is still a bit unoptimized because `prepareCache()` from the
builder is not yet being invoked, but it's still more correct than
reusing the `workPath`.
2019-04-05 02:21:59 +02:00
Leo Lamprecht
1819c69de5 15.0.2-canary.3 2019-04-05 00:19:55 +00:00
Nathan Rajlich
4fb043c46a Ignore .env and .env.build for deployments by default (#2083)
Because `now dev` uses these dotenv files to define the Now secrets to
use, it would be bad practice to include them in the deployment files
since they will be using development values instead of production values.
2019-04-05 02:11:08 +02:00
Nathan Rajlich
4995318418 [now dev] Clean up dev-router a bit (#2099)
* [now dev] Clean up `dev-router` a bit

This is a follow up to #2095 to move the `resolveRouteParameters()`
funcrtion to the top-level and other slight optimizations like not
re-parsing the URL multiple times.

* Remove unused `qs` import
2019-04-04 15:05:18 -07:00
Nathan Rajlich
6eaf6ecd14 [now dev] Remove now dev cache clean (#2097) 2019-04-04 14:36:05 -07:00
William Li
822971fc7d [now dev] Apply route params to headers (#2095)
* version bump (canary)

* inject paramters into headers.Location fixes #2092

* refactored route parameter resolving function

* Revert "version bump (canary)"

This reverts commit 5857489ceffcbcce07eb6e5d6fcc20279d0ba5fd.

* Update src/commands/dev/lib/dev-router.ts

Co-Authored-By: williamli <email@williamli.dev>

* refactor headers resolution

* try to resolve all parameters inside each child of headers
2019-04-04 13:33:04 -07:00
Nathan Rajlich
fb48402f87 [now dev] Set the same MemorySize on the lambdas as production (#2096)
This should fix https://spectrum.chat/zeit/now/now-dev-javascript-heap-out-of-memory~3fd6e823-59de-426b-ade0-af48d18f3494
2019-04-04 12:25:07 -07:00
Nathan Rajlich
fd241c1e85 Remove 'output logs of a 1.0 deployment' integration test (#2085)
This test is very flaky causing us to constantly restart CircleCI jobs
in order to do releases of `now-cli`. Considering that it's testing the
1.0 pipeline, let's just remove this one to make life easier.
2019-04-04 12:14:42 -07:00
Nathan Rajlich
a3fc36e573 [now dev] Fix the requestPath for the hard-refresh case (#2086)
This passes in the resolved `assetKey` instead of `req.url` to the
builder `requestPath` when a hard-refresh is requested, allowing the
proper single-page rebuild to happen.
2019-04-03 18:37:47 -07:00
Nathan Rajlich
402b4d3457 15.0.2-canary.2 2019-04-03 17:41:19 -07:00
Nathan Rajlich
62625df203 [now dev] Fix subscription resolving logic (#2082)
* [now dev] Fix subscription resolving logic

Strip the leading `/` since the builder outputs don't have one, match
index routes, and pass the resulting subscription key to the builder.

* Fix `index` matching

* Update `@now/build-utils` to v0.4.39-canary.0

* Update `@now/build-utils` to v0.4.39
2019-04-03 17:39:14 -07:00
Leo Lamprecht
658c220c85 15.0.2-canary.1 2019-04-03 11:02:43 +00:00
Leo Lamprecht
4190a6bfbc Revert "[now dev] Less verbose "listening" message (#2062)"
This reverts commit a3f4c6290d.
2019-04-03 10:57:09 +00:00
Nathan Rajlich
7aea928a5a [now dev] Respond with 404 once the server is shutting down (#2070)
In the case of a keep-alive connection from the web browser, and a page
continuing to send HTTP requests to the dev server, sometimes the server
never shuts down. So send a 404 response with `Connection: close` to
force the web browser to close the connection.
2019-04-03 12:55:11 +02:00
Nathan Rajlich
58d4326511 [now dev] Add support for Builder "subscriptions" (#2071)
If the builder has a `subscribe()` function, then the initial
builds are not run and instead an array of "subscriptions" is
created. When an HTTP request comes in that matches one of the
subscription patterns, then this builder will be actually be
executed.
2019-04-03 12:53:35 +02:00
Nathan Rajlich
f7b782440a [now dev] Pass meta object to Builders' build() function (#2069)
This introduces a new object called `meta` that gets passed to the
Now Builders' `build()` function. The `isDev` property is moved to
this object, and a new property `requestPath` is also introduced.

`requestPath` represents the URL that was requested to trigger the
`build()` to be called. It may be used by builders to do incremental
compilation and only re-build the assets related to the URL that was
requested. For example, `@now/next` may use this property to only build
the page that was requested.
2019-04-02 18:53:06 -07:00
Nathan Rajlich
17422184e4 Update pcre-to-regexp to v0.0.5 (#2068)
For `now dev`, this fixes an edge case in named capture groups
in some `routes` definitions that would lead to an error being thrown:

```
Cannot read property '1' of null
```

Also ignoring "handler" routes for now.
2019-04-02 15:32:47 -07:00
Nathan Rajlich
c765e7efbb Update @zeit/ncc to v0.17.3 (#2058) 2019-04-01 15:55:02 -07:00
Nathan Rajlich
a3f4c6290d [now dev] Less verbose "listening" message (#2062)
* [now dev] Less verbose "listening" message

* Add "Listening on"

* Use "Running at"
2019-04-01 14:57:21 -07:00
Leo Lamprecht
c0cd13abcd 14.3.0-canary.27 2019-04-01 15:41:08 +00:00
Nathan Rajlich
6fab380cd9 [now dev] Update bootup message (#2056)
This looks a bit cleaner since the user just typed `now dev` into their
CLI so no need to print the same command again.
2019-04-01 08:18:00 -07:00
Nathan Rajlich
3732f89362 Update @now/build-utils to v0.4.38 (#2055) 2019-04-01 16:58:23 +02:00
Nathan Rajlich
e25388066d 14.3.0-canary.26 2019-03-31 23:56:49 -07:00
Nathan Rajlich
a7f823609d [now dev] Add support for .env and .env.build file to define Now secrets (#2048)
* [now dev] Add support for `.env` file to define Now secrets

If a `now.json` files relies on secret env vars, then they must be
defined in the user's local `.env` file otherwise `now dev` exits with
an error.

* Prettier

* Fix multi-line error output

* Use `code()` to format the dotenv file name

* Add "file" to error message for clarity

* Use `hasOwnProperty()` instead of `in`

* Apply `build.env` vars during builder `build()` invocations

Fixes #2046.
2019-03-31 23:54:12 -07:00
Nathan Rajlich
f9362a1e53 Update @zeit/fun to v0.6.0 (#2049) 2019-03-31 23:17:24 -07:00
Nathan Rajlich
7a9d5e646f 14.3.0-canary.25 2019-03-31 13:38:05 -07:00
Nathan Rajlich
1108daa8ed [now dev] Use cyan for link color
Blue is hard to read on terminals with a black background.
2019-03-31 13:29:21 -07:00
Nathan Rajlich
d59de91fd6 [now dev] Add build deduping (#2044)
Consider the scenario where an HTML asset is built and references other
files that were produced by the build (CSS/JS/img/etc. files). The build
will happen and then the HTML page will be served, and then the browser
will request the assets on the page also with the `no-cache` header,
which would cause a second build right after the first one completed,
which is bad DX and unnecessary.

This commit introduces "build deduping logic" so that this scenario is
avoided by doing two things:

1. Not allowing the same entrypoint to be built at the same time (so if
   a concurrent request happens for an asset that was produced by the same
   entrypoint, the subsequent requests will wait on the already running build
   instead of triggering a new one in parallel.

2. Not allowing an asset to be rebuilt if the previous build completed
   less than two seconds ago. This is to catch the scenario where the
   HTML page is served and the browser quickly requests the assets on
   the page to avoid triggering a second rebuild.
2019-03-31 13:28:26 -07:00
Nathan Rajlich
0cfc31f4ad [now dev] Set the Now proxy and response headers (#2041)
* [now dev] Set the Now proxy and response headers

* Add `X-Real-IP` proxy header

* Set any headers defined in the matched `route` config

* Apply @amio's suggestions
2019-03-31 12:56:40 -07:00
Nathan Rajlich
e1df47dedc [now dev] Send INTERNAL_LAMBDA_NOT_FOUND (#2039)
This is mostly to appease TypeScript since `fn` is an optional prop,
but this shouldn't really ever happen since we run the builds before
responding to HTTP requests.
2019-03-30 18:26:30 -07:00
Nathan Rajlich
b6e4e0d670 [now dev] Use the Output helper (#2038)
* [now dev] Use the `Output` helper

For more consistent logging / styling with the other `now` commands.

* Put `setStatusError()` back
2019-03-30 18:25:22 -07:00
Andy Bitz
5d0338a278 14.3.0-canary.24 2019-03-29 23:01:31 +01:00
Andy
57aad64c23 Group builds with similar paths together to reduce the output (#2015)
* Group builds with similar paths together to reduce the output

* Style the new output

* Ensure space between state and time

* Update src/util/output/builds.js

Co-Authored-By: AndyBitz <AndyBitz@users.noreply.github.com>

* Add comma between ready states

* Tell what is hidden

* Change builds and items
2019-03-29 22:59:27 +01:00
Amio
743db0d265 Refine test jobs (#2028)
- Include `.ts` extension
- Include all `test/*unit.js` (`test-unit` task)
- Make coverage reporting a separate job in circleci config
2019-03-29 20:13:38 +08:00
Nathan Rajlich
a96a3c6623 14.3.0-canary.23 2019-03-28 19:02:49 -07:00
Nathan Rajlich
60c17953c9 [now dev] Send the NO_STATUS_CODE_FROM_LAMBDA upon lambda error (#2037) 2019-03-28 18:01:56 -07:00
Nathan Rajlich
2068de722c [now dev] Fix the path provided to lambda invocations (#2036)
This matches how the Now proxy invokes the lambdas, where the route
`dest` query params are mixed-in to the provided `req.url`, with the
dest query params taking precedence over any conflicting user-provided
query params.
2019-03-28 15:55:02 -07:00
Leo Lamprecht
33d86505e8 14.3.0-canary.22 2019-03-28 22:11:03 +00:00
Leo Lamprecht
2a52d04064 Made aliases clickable after assigning (#2035)
* Made aliases clickable after assigning

* Set in correct place

* Fixed URL

* Attached alias

* Added missing https
2019-03-28 22:54:07 +01:00
Nathan Rajlich
7911bc6aea Add output to DevServer class (#2034) 2019-03-28 22:22:53 +01:00
Nathan Rajlich
733d908c89 [now dev] Listen on the next available port when requested port is taken (#2032)
Fixes #2024.
2019-03-28 21:53:58 +01:00
Leo Lamprecht
798ea44c60 Adjusted aliasing error message to match server (#2030)
* Adjusted aliasing error message to match server

* Correctly escape
2019-03-28 21:19:48 +01:00
Leo Lamprecht
08d4a3759b 14.3.0-canary.21 2019-03-28 13:06:13 +00:00
Nathan Rajlich
b29f602ce9 [now dev] Use pcre-to-regexp to match routes (#2027)
* [now dev] Use `pcre-to-regexp` to match `routes`

The now.json `routes` support PCRE syntax like named captures,
so use the `pcre-to-regexp` module to match the routes.

Fixes #2023.

* Pass the resolved router `dest` and query params to the Lambda
2019-03-27 18:37:43 -07:00
Nathan Rajlich
09c8144f31 [now dev] Centralize error responses logic (#2026)
This just DRYs up the code a bit and centralizes the error sending logic
so that we can more easily add the HTML and JSON versions of the
responses as well.
2019-03-27 17:29:11 -07:00
Nathan Rajlich
b3bd8c5929 [now dev] Don't add .gitignore to the ignore list (#2025)
`.gitignore` is not respected anymore for Now v2, so this was a bug.

Also removes `ncc` and `user` from the ignore list, since that issue was
fixed a while back as well.

Fixes #2021.
2019-03-27 12:32:50 -07:00
Julian Gruber
99790b1560 14.3.0-canary.19 2019-03-27 13:58:24 +01:00
Julian Gruber
31441e8890 Fix the handling of unexpected user errors (#2022)
* fix unexpected `DNSConflictingRecord`

* fix unexpected `EBADF`

* fix unexpected `InvalidDeploymentId`

* fix unexpected `InvalidDomain`

* fix unexpected `DomainNotFound`
2019-03-27 13:34:22 +01:00
Nathan Rajlich
f693acbaa9 14.3.0-canary.18 2019-03-26 18:12:38 -07:00
Amio
c1548a8cbb Add now dev (#1883)
* [WIP] now-dev

* try invoking lambda

* add error status to dev-server

* add basic routing

* add entry for custom @now/static builder

* honor .gitignore & .nowignore while collecting files

* add route for single static file

* add test fixtures for now-dev (nodejs)

* fix miss typed @now/statics

* import types from @now/build-utils

* fix typo @now/statics -> @now/static

* revamped router

* typescript-eslint-parser -> @typescript-eslint/parser

Eliminate error while running pre-commit hooks:

  SUPPORTED TYPESCRIPT VERSIONS: ~3.1.1
  YOUR TYPESCRIPT VERSION: 3.2.2

* send files from local @now/static builder

* use serve-handler when no now.json

* remove http-proxy

* add type def for serve-handler

* code cleanup

* move type declarations to types.ts

* dont rely on `this.cwd` while running builder

* more type definitions

* fix invoking error

* clean code

* better debug logging

* refined request handler logic

* handle /favicon.ico with serve-handler

* make builder-cache self contained

* move builder works to dev-builder.ts

* add proxy_pass handler

* support named groups in routes

* fix creating cache dir error

* add "--nodejs-preview" solely for nodejs

* clean require.cache after required user js

* fix router & header issue in nodejs preview

* [wip] add tests for dev-router

* add tests for dev-router

* lookup "/index.*" for indexes

* refine logging

* [WIP] `now dev` progress point

Actually invoking the `@zeit/fun` module at this point.

Still lots of work to be done…

* Update `@zeit/fun` to v0.0.4

* Remove `--nodejs-preview`

To be replaced by `@zeit/fun`.

* Remove `decache` and `import-fresh`

Leftover from the `--nodejs-preview`.

* Remove "declaration: true" from `tsconfig.json`

Otherwise the ncc `dist` dir ends up full of generated `.d.ts` files.

* Remove `ignore` dep, always use `@zeit/dockerignore`

* Use tarball URL for `@zeit/fun`

Because `@zeit/fun` is not yet public on npm.

* Regenerate `yarn.lock` to fix bad integrity check on fun tarball

* Upgrade to `@zeit/fun` v0.0.6

With re-written unzipping logic utilizing `yauzl`.

* Add lambda function handling logic for the HTTP response

* Match the lambda invoke shape that Now's proxy provides

* Move deps to devDependencies

* Update `@zeit/fun` to v0.0.8

* Update `@zeit/ncc` to v0.15.0

* Attempt to fix unit test for `wait()` helper function

* Add `build.sh` script to work around ncc issues

* Fix `build.sh` script for BSD's chmod

No `--changes` flag.

* Update `@zeit/fun` to v0.0.11

* Update `@zeit/fun` to v0.0.12

* Tweak some comments

* Update `@zeit/fun` to v0.0.13

* Add `now.json` env vars to lambda functions

* Finish removing `--nodejs-preview` flag

* Style tweaks

* Use `npm-package-arg` to parse the "use" builder

* Styling

* Use the parsed `pathname` when matching routes

The querystring portion needs to be removed to match properly.

* Update `@zeit/fun` to v0.1.1

* Support `-d` for debug flag

It was already listed as such in the `--help` output.

* List the `dist/runtimes` dir as pkg "assets"

* Update `@now/build-utils` to v0.4.37-canary.0

* Update `@zeit/fun` to v0.2.0

* Update `@zeit/fun` to v0.2.1

* Rewrite the `req.url` to fix serving FileFsRef assets

* Disable re-building, build all `builds` upon server bootup

* 404 is not a redirect

* warning on more than one argument

* Fix `index` without a file extension matching

* Update `@zeit/fun` to v0.2.2

* Use `async-listen`

* Add shutdown cleanup logic

* Rename `buildLambdas()` to `executeBuilds()`

* Rename `lambda` prop to `fn`

* Misc tweaks

* Pass `isDev: true` to the builder `build()` function

* Use `Object.assign()` instead of object spread

* Set `res.statusCode` instead of `writeHead()`

* Create Lambda functions during build-time

This way, the lambda instance is re-used for subsequent HTTP requests

* Wait for cleanup operations to complete in `stop()`

* Destructure `path` for join()

* Add some missing types

* Store the `buildConfig` on the assets for reverse lookup

* Remove `console.log()`

* Attempt to make globbing faster and ignore files more accurately

* Rewrite `installBuilders()` to be idempotent

So that npm is not executed for canary tags, for example.

This is done by comparing the contents of the package.json file rather
then the `node_modules` directory.

* Use `ignore` instead of `@zeit/dockerignore` for glob-gitignore

It seems that the object produced by `@zeit/dockerignore` is not
compatible with the `glob-gitignore` module, so use the vanilla
`ignore` module instead for now as a workaround.

* Implement a `GlobIgnore` class to replace `glob-gitignore`

This allows us to continue using `@zeit/dockerignore` for proper
consistency.

Closes #1899.

* Prettier

* Skip installing built-in builders (i.e. `@now/static`)

* Remove `console.error()` calls

* Use a deterministic `workPath` directory

So that the same one is re-used in-between subsequent boots of `now dev`

* Add `now.json` validation logic

* Fix serving static assets outside the project working directory

This fixes, for example, `@now/mdx-deck` which outputs static files
from its build process.

* Add comment

* Validate the `now.json` file before launching the dev server

* Respect `maxLambdaSize` config

Closes #1950.

* Add `@types/bytes` dependency

* Make `maxLambdaSize` be optional

Co-Authored-By: TooTallNate <n@n8.io>

* WIP force reload in browser = rebuild asset behavior

* Resolve the `asset` again after re-build

* Remove logging

* Update `@zeit/fun` to v0.3.0

* Update `@now/build-utils` to v0.4.37-canary.1

Sets `npm_config_target` to the proper Node.js version for native
modules.

* Update `@zeit/fun` to v0.3.1

* Fix "hard refresh to reload" after the first rebuild

The `buildConfig` and `buildEntry` proper were not being set on the
rebuilt assets, causing the rebuild to only work the first time.

Now fixed.

* Add logic for the `now dev cache clean` command (#1977)

* Added the cache-clean command

* censer code :)

* Fix non-route match `dest` param

This makes the `go-image-to-ascii` work, since the query param URL gets
properly routed to the `/` route.

* Add support for `FileBlob` outputs

Fixes `@now/optipng`, `@now/html-minifier` and `@now/md` builders.

* Remove `console.error()` call

* Add `now dev cache clean` command

* Use the `assetKey` to look up the Content-Type on FileBlobs

Instead of the `fsPath` of the entrypoint file.

This fixes `@now/md` to return `text/html` Content-Type instead of
`text/markdown` which does not render properly in the web browser.

* Update `@zeit/ncc` to v0.16.1

Co-Authored-By: TooTallNate <n@n8.io>

* Regenerate `yarn.lock` file

* Remove leading `/` on build `src` specifications

* Use `rsync` to copy over all of `fun`'s runtime files

* Update `@zeit/fun` to v0.5.0

* Update `@zeit/fun` to v0.5.1

* try/catch the lambda invoke and send 500 upon error

* Add `rsync` to CircleCI build

* Convert `errors.js` to TypeScript to fix compilation errors

* Also accept `Cache-Control: no-cache` for rebuilding

* Prettier

* Update `@now/build-utils` to v0.4.38-canary.1

* Update `@zeit/ncc` to v0.17.0 (#2017)

* Install `@zeit/fun` from npm

* Remove `console.error()` call

Co-Authored-By: TooTallNate <n@n8.io>

* Create `NowError` subclasses

* Add `LambdaSizeExceededError`

* Return early if there's no builds
2019-03-26 16:47:35 -07:00
Julian Gruber
fc7a75cae2 Fixed GET /v3/now/certs (#2005)
* Fixed `GET /v3/now/certs`

- Limit the response size to 20 because the endpoint doesn't have a default limit
- If the id in `/v3/now/certs/{id}` isn't a valid id the endpoint responds with a set or certs instead
- The route `/v3/now/certs/{idOrCn}` isn't supported any more

* removed limit of 20, the endpoint was updated
2019-03-26 19:55:13 +01:00
Julian Gruber
adced907c9 Fixed the handling of user errors in legacy deploy command (#2006)
* fix disconnected promise chain in legacy deploy
* fix `size_limit_exceeded` in legacy
2019-03-26 19:54:32 +01:00
Julian Gruber
49ae9d43ad Fixed the handling of unexpected DeploymentFailedAliasImpossible (#2020) 2019-03-26 19:53:32 +01:00
Joe Cohen
b40ae12e63 fix typo on domains inspect (#2016) 2019-03-26 10:25:04 +01:00
Leo Lamprecht
0ae9fa8342 14.3.0-canary.17 2019-03-22 00:40:24 +00:00
Leo Lamprecht
833d0b293f Make deployments without builds work (#2004)
* Make deployments without builds work

* Added integration test

* Fixed test
2019-03-22 01:39:58 +01:00
Leo Lamprecht
ea9a870604 14.3.0-canary.16 2019-03-21 02:55:30 +00:00
Leo Lamprecht
c7e5427200 Only block deployment exit if not error (#2000) 2019-03-21 03:53:18 +01:00
Leo Lamprecht
96ddda0009 14.3.0-canary.15 2019-03-20 22:54:26 +00:00
Leo Lamprecht
635115f94b Only announce deployment as ready if alias is set (#1997) 2019-03-20 23:54:01 +01:00
Julian Gruber
9bb1d799d8 14.3.0-canary.14 2019-03-20 22:37:10 +01:00
Julian Gruber
eabd15092c Fixed the handling of user errors (#1989)
* Fixed duplicate `--local-config` option
* Fixed uncaught `ERRORS.DomainPermissionDenied`
* Fixed uncaught `ERRORS.DeploymentNotFound`
* Added arguments parsing errors to Sentry scope
* Fixed stale stream in `cleanup()` of `promptOptions()`
* Fixed uncaught `USER_ABORT`
* Fixed uncaught `ENOENT`
2019-03-20 22:36:17 +01:00
Leo Lamprecht
5e85389792 14.3.0-canary.13 2019-03-19 09:27:59 +00:00
Leo Lamprecht
42eb69bb95 Made -S short flag work properly (#1988) 2019-03-19 10:27:44 +01:00
Julian Gruber
09c9ff5ecd 14.3.0-canary.12 2019-03-18 18:38:38 +01:00
Julian Gruber
2678656f12 Add always report stdarg to Sentry (#1982)
Before this change, only if `user` or `team` could be read from
the scope would stdarg be reported to Sentry, however it's
completely unrelated to the existence of the former and is always
useful debugging information.
2019-03-18 18:36:57 +01:00
Julian Gruber
eb2a7b56b0 Fix the handling of user errors (#1984)
* fix `ms(null)` in `certs rm`

* fix uncaught `InvalidDomain`
2019-03-18 18:15:45 +01:00
Julian Gruber
f33329d396 Fix null pointer access in error reporting (#1983)
* fix null pointer access in error reporting

* refactor
2019-03-18 18:08:38 +01:00
Leo Lamprecht
7d7340bbfc 14.3.0-canary.11 2019-03-18 13:05:36 +00:00
Leo Lamprecht
0bf2115701 Make --scope take priority over scope (#1985) 2019-03-18 14:04:10 +01:00
Leo Lamprecht
0357bfdbaa 14.3.0-canary.10 2019-03-18 09:38:07 +00:00
Amio
52a76299c5 Add hint about -f in now init error message (#1971) 2019-03-17 23:14:44 +08:00
Leo Lamprecht
8de3151b8f 14.3.0-canary.9 2019-03-16 18:04:31 +00:00
Andy
2b3ceba353 Handle the DomainNotVerified error for deployments (#1973) 2019-03-16 19:04:13 +01:00
Leo Lamprecht
378274bc3f Warn of now alias was used (#1972)
* Warn of `now alias` was used

* Mention deploy command
2019-03-16 18:58:14 +01:00
Leo Lamprecht
c3145b0801 14.3.0-canary.8 2019-03-15 23:05:31 +00:00
Leo Lamprecht
5aca7dafec Improved deployment output (#1968)
* Prefix all aliases that are printed

* Pass local config

* Print if --target production is defined, but not alias prop

* Moved warning message
2019-03-15 23:58:32 +01:00
Julian Gruber
803b1ae91b Fix the handling of user errors (#1959)
* fix unexpected `size_limit_exceeded`

* fix unexpected `deployment_type_unsupported`

* fix unexpected `JSONError`

* check if err.sizeLimit exists
2019-03-15 22:17:33 +01:00
Julian Gruber
402c4e75a2 Added back sending process args to Sentry (#1966)
* add `process.argv` to Sentry, without sensitive data

* refactor using `arg` parser

* add secret alias support
2019-03-15 18:54:49 +01:00
Mark Glagola
7a1859d1dd 14.3.0-canary.7 2019-03-14 17:56:15 -05:00
Mark Glagola
927117d5db adds prompt when moving domain to team user is not member of (#1965) 2019-03-14 23:53:41 +01:00
Leo Lamprecht
837f433b5c Revert "Warning w/ prompt when moving to a destination the user is not a member of (#1961)"
This reverts commit 48451e3f81.
2019-03-14 22:32:53 +00:00
Leo Lamprecht
b5b18ffefe 14.3.0-canary.6 2019-03-14 19:45:59 +00:00
Mark Glagola
48451e3f81 Warning w/ prompt when moving to a destination the user is not a member of (#1961) 2019-03-14 20:39:51 +01:00
Leo Lamprecht
ec9e334f9a Improved output for deploy command (#1962)
* Make alias links clickable

* Make output print Ready instead of Success

* Fixed missing export
2019-03-14 20:39:32 +01:00
Leo Lamprecht
f646ddfc0f 14.3.0-canary.5 2019-03-13 21:21:43 +00:00
Leo Lamprecht
2102441cd0 Added warning message about files with no deployments (#1960)
* Added warning message about files with no deployments

* Added integration test

* Fixed charset of test
2019-03-13 22:21:25 +01:00
Julian Gruber
95149c3fe4 14.3.0-canary.4 2019-03-13 20:36:48 +01:00
Julian Gruber
0bfbd40810 Fixed the handling of user errors (#1958) 2019-03-13 20:30:15 +01:00
Julian Gruber
b3a70e980e Refactored flow error checks (#1953) 2019-03-13 20:24:56 +01:00
Leo Lamprecht
952c369646 14.3.0-canary.3 2019-03-13 14:25:41 +00:00
Leo Lamprecht
3effec0dd5 Soft-deprecate the --team flag (#1956)
* Soft-deprecate the `--team` flag

* Check for warning message

* Removed useless error
2019-03-13 14:08:11 +01:00
Amio /
2d563e1694 Added a deploy hint after now init. (#1952)
* [now-init] add a deploy hint after init

* add CODEOWNERS
2019-03-13 10:45:49 +08:00
Leo Lamprecht
e9ceac13b8 14.3.0-canary.2 2019-03-12 23:09:58 +00:00
Leo Lamprecht
06a0607287 Added --scope flag and scope config property (#1939)
* Added basics for new --scope flag

* Fixed usage information

* Fixed integration test

* Fixed usage information about whoami

* Brought back missing whitespace

* Do not push scope property to API

* Ensure we're only reading local config in one place

* Fixed build

* Added test

* Made scope from config work

* Correctly handle error

* Handle Now errors too when loading local config

* Removed NowError

* Revert "Removed NowError"

This reverts commit cfeebc65251d3eb07f9aeb3e548af1d23c00a18e.

* Fixed CI

* Fixed final bug

* Do not consider switch command

* Made it work as expected

* Added test

* Added yet another test for the scope property

* Added space
2019-03-13 00:09:43 +01:00
Leo Lamprecht
7e159646fb 14.3.0-canary.1 2019-03-12 19:36:01 +00:00
Leo Lamprecht
d2781430d3 Allow --target to be set to staging (#1955)
* Allow `--target` to be set to `staging`

* Properly format output

* Added clipboard support

* Send target to server

* Make target optional
2019-03-12 20:35:18 +01:00
Mark Glagola
1bb8c80342 Fallback to descriptive api error message if we cannot resolve domain rm|move conflict (#1951)
* On domain conflict error, use api error message & check resolvable flag

* Updated domain rm w/ attempt precaution

* smaller domain removal conflict construction
2019-03-12 14:14:07 -05:00
Julian Gruber
01e83247ee 14.1.0-canary.7 2019-03-12 19:05:35 +01:00
Julian Gruber
12653f97ad Fixed the handling of user errors
* fix unexpected `payment_error`

* fix unexpected `deployment_not_found`

* fix unexpected `not_authorized` and `team_deleted`

* make id optional in DeploymentNotFound
2019-03-12 19:04:13 +01:00
Mark Glagola
6bcb8651a0 14.1.0-canary.6 2019-03-08 09:53:23 -06:00
Mark Glagola
0071ca68be Adds alias removal warning on domains move (#1933)
* fixes double caret for domains move

* using output.success

* Adds alias removal warning to domains move
2019-03-07 09:43:38 -06:00
Mark Glagola
a89bbdfdf9 14.1.0-canary.5 2019-03-05 20:32:34 -06:00
Mark Glagola
c7bd599e16 Revised domains move flow (#1928)
* Revised domains move flow (rm move-in & move-out for move)

* fixed integration tests for domains move api changes

* handle immediate domain moves

* fixed list scopes integration test

* more integration test fixes
2019-03-05 18:32:41 -06:00
Andy Bitz
c66a5b580d 14.1.0-canary.4 2019-03-03 16:53:39 +01:00
Andy
f145b6a7d2 Overwrite the default batch file on windows (#1922)
* Overwrite the default batch file on windows

* Suppress echoing of the command
2019-03-03 16:48:18 +01:00
Leo Lamprecht
4337f0bab0 14.1.0-canary.3 2019-02-28 19:35:14 +00:00
Javi Velasco
6b37797de9 Add --no-scale option (#1918)
* Add no-scale option

* Reword --no-scale warning
2019-02-28 20:34:44 +01:00
Mark Glagola
1843ac4d31 Added warning for domains-move token expiration (#1916) 2019-02-27 17:24:22 -06:00
Mark Glagola
6399253318 14.1.0-canary.2 2019-02-27 15:47:38 -06:00
Mark Glagola
f3638fb871 Domain move-in & move-out implementation (#1906)
* Initial domain move-in & move-out implementation

* adjusted move apis

* domains move revisions based on API changes

* root domain func fix

* Minor copy fixes + added some integration test for move-in/out

* Handling move in|out conflict

* rm random quotes
2019-02-27 15:46:35 -06:00
Andy Bitz
dc88a310cb 14.1.0-canary.1 2019-02-27 19:36:23 +01:00
Andy
aea9bd4882 Added support for the --target flag (#1893)
* Add support for the target flag

* Show the given alias at the end

* Use the proper naming for the alias properies and include arrays

* Use the correct output

* Make sure that aliasFinal has properties
2019-02-27 19:33:27 +01:00
Olli Vanhoja
b69bb4346c Set verify-deployment-scale timeout to 5 minutes (#1915)
The current client side timeout is shorter than the backend
timeout.
2019-02-27 11:40:22 +01:00
Leo Lamprecht
9af6aa4ba3 14.0.1-canary.1 2019-02-25 20:42:49 +00:00
Leo Lamprecht
dff2704662 Prevent error in now inspect if no dest (#1913) 2019-02-25 21:33:22 +01:00
Mark Glagola
4849352b34 Using @types/psl typings + handling all potential error cases with psl (#1911) 2019-02-25 20:59:43 +01:00
Javi Velasco
87700d9ab9 Fix wrong error message (#1904) 2019-02-25 20:58:37 +01:00
Javi Velasco
c69c0fd915 13.2.0-canary.6 2019-02-10 18:07:34 +01:00
Mark Glagola
4c4d5c7baa Revised the way conflicts are handled when removing a domain (#1884)
* Revised the way conflicts are handled when rm domain

* agent.ts accepts absolute urls

* "delete" copy -> "remove" for consistency

* Revert "agent.ts accepts absolute urls"

This reverts commit 200158d06fcb80417f197910c40e364f8ea5abb2.

* using proper set custom suffix endpoint

* Reuse InvalidDomain error
2019-02-10 17:21:54 +01:00
Sergii Paryzhskyi
1e9d2cf9a0 Add a hint to an error message about missing token (#1877) 2019-02-10 17:21:27 +01:00
Steve Kaliski
5579aba636 fix typo in alias command (#1870) 2019-02-10 17:20:30 +01:00
Olli Vanhoja
c66ad6a60f Handle dns add 400 errors properly (#1867)
Currently 400 errors are left unhandled.
2019-02-10 17:20:03 +01:00
Mark Glagola
8e7f087a68 Handle domain rm attempt for an in progress transfer (#1880) 2019-02-06 23:42:19 +01:00
Mark Glagola
72142c32a1 Catch SourceNotFound error for domains transfer-in (#1879) 2019-02-06 21:51:50 +01:00
Javi Velasco
5999ec7acd Update inspect copy (#1875) 2019-02-04 23:29:33 +01:00
Mark Glagola
af401cdc9b Added import help info to now-cli (now dns -h) (#1876) 2019-02-04 23:29:17 +01:00
Javi Velasco
f879e3ebdd 13.2.0-canary.5 2019-02-04 04:07:49 +01:00
Javi Velasco
a0b838c947 Enhance login (#1873)
* Enhance login

* Consume error from api
2019-02-04 01:05:30 -02:00
Leo Lamprecht
eb2fac75cd 13.2.0-canary.4 2019-02-01 23:11:00 +00:00
Leo Lamprecht
f0b1e57dcb Bumped fetch-h2 to latest version (#1869)
* Bumped `fetch-h2` to latest version

* Fixed code
2019-02-02 00:10:31 +01:00
Olli Vanhoja
f8f12b0596 Show builds rate limit message correctly (#1866) 2019-02-01 22:29:23 +01:00
Javi Velasco
de25859329 13.2.0-canary.3 2019-02-01 22:20:34 +01:00
Mark Glagola
b4430de8de Handle known domains rm errors (#1868) 2019-02-01 14:33:44 -06:00
Mark Glagola
6d6c4aa4b8 Added transferredAt and transferStartedAt (#1865) 2019-02-01 13:32:10 +01:00
Leo Lamprecht
baadff146e 13.2.0-canary.2 2019-01-31 22:47:33 +00:00
Javi Velasco
0b85490804 Remove cf cdn enabled flag (#1852)
* Remove CDN toggling

* Rename cdnEnabled to cfEnabled

* Rename cfEnabled to cloudfareEnabled

* Remove missing error
2019-01-31 23:38:23 +01:00
Andy
8d256228a0 Check if deploymentId exists (#1857)
* Check if deploymentId exists

* Make deploymentId optional for Alias
2019-01-31 13:37:09 +01:00
Arunoda Susiripala
5ad1af6d91 Check the existence of the project before we delete it (#1837) 2019-01-31 13:18:42 +01:00
Leo Lamprecht
38b3095b82 13.2.0-canary.1 2019-01-31 11:57:18 +00:00
Leo Lamprecht
9289d0cd43 Render validation errors for Now 1.0 (#1862) 2019-01-31 12:54:45 +01:00
Mark Glagola
d834c0fc0a Domain transfer in copy change (#1861) 2019-01-30 16:34:24 -06:00
Javi Velasco
7a995c3801 Add import zonefile copy (#1860) 2019-01-30 17:37:08 +01:00
Javi Velasco
2f41a2bc09 Add ability to import a zone file (#1851)
* Add ability to import a zone file

* Use an arg instead of an option for the zone file
2019-01-30 16:21:56 +01:00
Javi Velasco
e1a80c30be Add missing error: InvalidAuthCode (#1859) 2019-01-30 16:08:53 +01:00
Mark Glagola
19994ccf60 Add domain transfer in pricing (#1849)
* Display transfer renewal price for domain transfers

* Check domain transferable status immediately on transfer-in

* Transfer status endpoint change to .../registry

* spelling fix

* Enable transferable check

* Update dependencies
2019-01-30 14:56:38 +01:00
George Tsiolis
1a59b0605f Update legacy note structure (#1855) 2019-01-29 17:06:20 +01:00
Mark Glagola
1c9aeee901 13.1.2-canary.3 2019-01-22 18:44:01 -06:00
Mark Glagola
31bfaa0569 "now domains transfer-in" support (#1767) 2019-01-22 17:31:51 -06:00
Leo Lamprecht
b24182df5b 13.1.2-canary.2 2019-01-22 16:22:32 +00:00
Andy
38923e1f91 Added default script that will run if now fails to install (#1832)
* Added default script that will run if now fails to install

* Don't overwrite the default now script before publishing

* Copy the default now binary on publish instead of keeping it inside the dist folder

* Removed download/dist/now

* Changed text
2019-01-21 19:59:40 +01:00
Leo Lamprecht
aefee0fad2 13.1.2-canary.1 2019-01-17 12:15:18 +00:00
Leo Lamprecht
aa2f53f2d5 Ensure name in package.json works for Now 1.0 (#1835)
* Ensure `name` in `package.json` works for Now 1.0

* Fixed integration test
2019-01-17 13:13:32 +01:00
Leo Lamprecht
a0bce9b3c5 13.1.1-canary.1 2019-01-16 22:59:45 +00:00
Arunoda Susiripala
8e5b7fdc19 Fix formatting issues on project rm confirmation (#1834) 2019-01-16 23:56:16 +01:00
Leo Lamprecht
4ee63506f8 13.1.0-canary.4 2019-01-16 18:43:16 +00:00
Leo Lamprecht
1a239f92f4 Ensure project name is always defined (#1833) 2019-01-16 19:41:03 +01:00
Leo Lamprecht
4f15b724ac 13.1.0-canary.3 2019-01-16 14:20:55 +00:00
Max
1c68a24a70 Support new invite format (#1831)
* Support new invite format

* Use null as initial userInfo value

Co-Authored-By: rdev <8418866+rdev@users.noreply.github.com>

* Add missing semicolon

Co-Authored-By: rdev <8418866+rdev@users.noreply.github.com>

* Add missing semicolon

Co-Authored-By: rdev <8418866+rdev@users.noreply.github.com>
2019-01-16 15:20:24 +01:00
Leo Lamprecht
d863acbc65 13.1.0-canary.2 2019-01-16 10:51:37 +00:00
Leo Lamprecht
c736f2ccb4 Revert "Show deployment URL at the end too (#1827)"
This reverts commit 0f2c677035.
2019-01-16 10:51:10 +00:00
Arunoda Susiripala
3942b88565 Get back the --name property (#1828)
* Get back the --name property
This also removes --project and consider --name as the project name

* Fix unit tests.

* Fix integration tests
2019-01-15 16:15:38 -08:00
Leo Lamprecht
a5ac2aca10 13.1.0-canary.1 2019-01-15 21:21:53 +00:00
Arunoda Susiripala
55ced7a3e5 Added support for projects (#1719)
* Send project property to api-deployments.

* Allow to talk to local api-deployments temporarly.

* Introduce the getProjectName utility.

* Use getProjectName on both legacy and latest deploy commands.

* Add now projects ls support.

* Implement 'now project add' and 'now project rm'

* Show project id

* Add basic now ls support with projects.

* Add some cosmetics changes.

* Make the UI colorful.

* Set the name as project

* Notify the user about the project name

* Remove legacy list

* Make sure 'now projects xxx' possible

* Set the project name in the list header

* Remove unwanted package

* Use --project in tests

* Force --project instead of --name

* Force the use of project property inside now.json

* Update ncc to the latest

* Remove -w from ncc

* Deprecate --name and .name instead of throwing errors

* Use the built-in fetch client

* Fix tests

* Change the order of tests

* Reset integration tests

* Remove some debug logs
2019-01-15 22:11:21 +01:00
Leo Lamprecht
0f2c677035 Show deployment URL at the end too (#1827) 2019-01-15 20:31:07 +01:00
Leo Lamprecht
7493f7d485 Allow user to abort now init (#1826) 2019-01-15 16:49:52 +01:00
Javi Velasco
ccbe18b520 Move all dns commands and subcommands to typescript (#1825) 2019-01-15 11:18:51 +01:00
Andy Bitz
8bde0bc204 13.0.4-canary.2 2019-01-14 22:14:28 +01:00
Leo Lamprecht
28df25e804 Improved test suite (#1820)
* Bumped `@zeit/ncc` to latest

* Reverted lockfile

* Make linking build for dev

* Cover line 21 in util/config/local-path.js

* Heavily improved unit test coverage

* Fixed space

* Got to 90% coverage

* Removed useless code

* Made builds work

* Fixed a few lines

* Fully covered read-metadata.js

* Brought coverage to 95.38

* Removed code that was never executed

* Track everything

* Don't show badge for now
2019-01-14 21:53:13 +01:00
Andy
fa5cb50df9 Add the command to sentry (#1824)
Add the current command to sentry as extra
2019-01-14 21:40:58 +01:00
Timothy
b847e02ff8 Fix config file message (#1821) 2019-01-12 01:05:26 +01:00
Leo Lamprecht
3e7411440b 13.0.4-canary.1 2019-01-10 11:24:25 +00:00
Leo Lamprecht
52fa239ae1 Fixed now logs for 2.0 deployments (#1819)
* Fixed `now logs` for 2.0 deploymens

* Added log test for 2.0

* Make test work
2019-01-10 12:23:39 +01:00
Amio /
fdaed3fd8f better did-you-mean (#1817)
ensure 'node' => 'nodejs' insteadof 'node-server'
2019-01-09 19:43:26 -08:00
Leo Lamprecht
8a3235ce6f 13.0.3-canary.3 2019-01-09 22:01:56 +00:00
Leo Lamprecht
e054c17e31 Do not render that status was inferred (#1816) 2019-01-09 23:01:00 +01:00
Leo Lamprecht
c7b6b4fc3e 13.0.1-canary.3 2019-01-09 14:29:32 +00:00
Leo Lamprecht
4d60b96a75 Made now domains inspect match now inspect (#1815) 2019-01-09 15:29:15 +01:00
Leo Lamprecht
0f0b546fa6 13.0.1-canary.2 2019-01-09 10:54:39 +00:00
Leo Lamprecht
ed454218b6 Bumped update-check to latest version (#1814) 2019-01-09 10:54:18 +00:00
Leo Lamprecht
b2345de9cc Revert "Bumped update-check to latest version (#1813)"
This reverts commit 5dc393f397.
2019-01-09 10:29:22 +00:00
Leo Lamprecht
5dc393f397 Bumped update-check to latest version (#1813) 2019-01-09 11:06:56 +01:00
Leo Lamprecht
ca654d938b 13.0.1-canary.1 2019-01-08 20:24:59 +00:00
Leo Lamprecht
0b0fb6bf1f Fixed several errors (#1811)
* Fixed NOW-CLI-HB

* Fixed code
2019-01-08 15:45:27 +01:00
Leo Lamprecht
ce85bb0578 13.0.0-canary.39 2019-01-07 22:47:07 +00:00
Leo Lamprecht
4c9538d51f Fixed several errors and removed useless file (#1807)
* Fixed NOW-CLI-FK

* Fixed NOW-CLI-F0

* Fixed NOW-CLI-D2

* Fixed NOW-CLI-GK

* Do not render clipboard indicator if error occured

* Removed useless file

* Fixed NOW-CLI-GW

* Fixed NOW-CLI-H3
2019-01-07 23:46:48 +01:00
Timothy
dc5157a252 Add domain verification error document (#1806) 2019-01-07 23:36:10 +01:00
Leo Lamprecht
9cc6d7f4da Overhauled now inspect (#1804)
* Show routes in `now inspect`

* Removed whitespace

* Made UI gorgeous

* Use cyan for meta keys
2019-01-07 20:08:10 +01:00
Leo Lamprecht
18b301e2a6 13.0.0-canary.38 2019-01-04 21:04:30 +00:00
Javi Velasco
35f52410d9 Style fixes (#1796) 2019-01-04 12:57:35 -08:00
Amio /
cf55c05691 Add now-init (#1780)
* Add now-init

* fix ci error

* refactor: (now-init) js => ts, some improvements.

- now-init works like git-clone
  (create new directory / complain about overwritten / can be forced)

- Better guess user intention
  (use jaro-winkler algorithm with "-" awareness)

- Stricter on arguments

- Non-TTY frendly

* add now-init to main help message

* fix miss typed args in didYouMean

* clean console.log

* output a new-line after any response to promptBool

Fix the missing '\n' when promptBool get an negative input ("n"/"N"/Enter/Abort).

Before:

~/git » now init koa
> Did you mean nodejs-koa? [y|N] > No changes made.

After:

~/git » now init koa
> Did you mean nodejs-koa? [y|N]
> No changes made.

* refine now-init output messages

* prettier code format

* update tests for now-init

* put "init" before "help" in now-help message

* remove redundant semicolon
2019-01-04 09:55:00 -08:00
Leo Lamprecht
be9360fbf3 13.0.0-canary.37 2019-01-04 11:47:35 +00:00
Javi Velasco
3fc07738cb Domains improvements (#1795)
* More flexible response error

* Consider async domain purchases

* Jumpline for domains ls

* Jumpline in domains verify

* Remove not needed body performing verification

* Add orderedAt to domains inspect
2019-01-04 12:47:21 +01:00
Leo Lamprecht
299452eb8d Only run prettier for JS/TS files (#1791)
* Only pass modified js files

* Look for TS too
2019-01-03 20:06:57 +01:00
Leo Lamprecht
655bce7795 13.0.0-canary.36 2019-01-01 18:07:40 +00:00
Leo Lamprecht
0289b38e4e Improved performance when creating deployment (#1787) 2019-01-01 18:07:00 +00:00
Leo Lamprecht
bceb401d19 13.0.0-canary.35 2019-01-01 13:41:01 +00:00
Leo Lamprecht
cef74ff787 Moved docs about publishing a release to Wiki (#1786) 2019-01-01 14:40:49 +01:00
Leo Lamprecht
de3b1c896f 13.0.0-canary.34 2019-01-01 12:13:54 +00:00
Olli Vanhoja
c94bbbc3d3 Fix now dns ls misalignment when a domain is not found (#1777)
If a domain is not found the DNS record arrays are aligned
incorrectly and finally some records are shown under wrong domains.
It happens because the length of the domains array differs from the
length of array of record arrays.
2018-12-27 13:46:37 +02:00
Javi Velasco
877737d872 13.0.0-canary.33 2018-12-19 17:33:43 +01:00
Javi Velasco
2c47baeed4 Remove extra request when adding a domain (#1762) 2018-12-19 16:30:26 +01:00
Javi Velasco
0321a03e38 13.0.0-canary.32 2018-12-19 01:20:27 +01:00
Javi Velasco
ba28773dae Do not use certs and aliases in now domains rm (#1761)
* Update types to the new API contract

* Do not use aliases and certs from domain fetch

* Add a dash per row in ns table
2018-12-19 01:18:59 +01:00
Leo Lamprecht
fcb3f7fb4f 13.0.0-canary.31 2018-12-18 22:50:52 +00:00
Leo Lamprecht
1db52a9384 Wait for unhandled rejections to be reported before exiting (#1760) 2018-12-18 23:50:38 +01:00
Javi Velasco
47986470a3 13.0.0-canary.30 2018-12-18 00:40:53 +01:00
Javi Velasco
4ddafa700f Fix issue when we define aliases in now.json array (#1757) 2018-12-18 00:40:22 +01:00
Javi Velasco
2d90f1b02d 13.0.0-canary.29 2018-12-17 23:58:05 +01:00
Javi Velasco
19d67cb42b Domains enhancements (#1755)
* Show a dash where there are no nameservers

* Show actual serviceType in domains

* Format ns table with ticks

* More enhancements
2018-12-17 11:15:35 -08:00
Leo Lamprecht
df2e5c8ab0 13.0.0-canary.28 2018-12-16 16:31:20 +00:00
Leo Lamprecht
02d43366c7 Render better error when source missing (#1754)
* Render better error when source missing

* Added integration test

* Fixed missing
2018-12-16 17:31:08 +01:00
Leo Lamprecht
b51ceb26f8 13.0.0-canary.27 2018-12-13 15:28:41 +00:00
Leo Lamprecht
96f559c513 Ran prettier over the entire codebase (#1749)
* Use correct parser

* Ran prettier over the entire codebase
2018-12-13 16:28:21 +01:00
Javi Velasco
1ed613d5be Fix list DNS issue and migrate certs issue to Typescript (#1747)
* Migrate getDomainDNSRecords to Typescript

* Migrate getDNSRecords to Typescript and fix it

* Migrate cert functions to Typescript and fix issues

* Migrate certs issue to Typescript

* Minor fixes
2018-12-13 15:27:21 +01:00
Leo Lamprecht
2cba7cad2a Use our own @zeit/git-hooks package (#1748)
* Removed legacy dependencies

* Added @zeit/git-hooks

* Added scripts to run before commit

* Format only the modified files

* Revert "Format only the modified files"

This reverts commit 9f4a58d2b978fa286eb7fcf38186bd9d53a2cda1.

* Revert "Added scripts to run before commit"

This reverts commit 07636d945374e404161ad281feed4180801b3509.

* Revert "Added @zeit/git-hooks"

This reverts commit 3f44f401f36fa6965d36ef28b81907c137c08abc.

* Revert "Removed legacy dependencies"

This reverts commit bb02465c59d75bf6b32bd449a04832cf4e2f4bf4.

* Fixed setup

* Print important test parts

* Logged kind

* Added more logs

* No need to remove deployments, we will prune
2018-12-13 15:13:55 +01:00
Javi Velasco
57c684abf3 13.0.0-canary.26 2018-12-12 23:35:49 +01:00
Javi Velasco
eb3970d779 New domains API + Typescript migrations (#1728)
New domains API + Typescript migrations
2018-12-12 23:35:08 +01:00
Leo Lamprecht
39f09d1b4b 13.0.0-canary.25 2018-12-12 17:24:10 +00:00
Mudit Ameta
b876da60aa Update now alias error to mention potentially missing name config (#1742)
* Update `now alias` error to mention potentially missing name config

Running `now alias` in a project that has no `package.json` and doesn't
have a `name` property defined in `now.json` fails with a cryptic
error currently. This, in combination with
https://github.com/zeit/docs/pull/378 tries to better guide the user.

* Add a link to the `name` config property
2018-12-12 18:23:25 +01:00
Joe Cohen
48f85b4450 Use single domain call to remove add domains domains (#1743)
* use single domain call to remove add domains domains

* update sigle domain endpoint and error handling
2018-12-12 18:22:42 +01:00
Leo Lamprecht
6af4b9ecd5 13.0.0-canary.24 2018-12-10 14:26:40 +00:00
Leo Lamprecht
7441730b24 Hot fix for now teams ls (#1737)
* Hot fix for `now teams ls`

* Added integration test
2018-12-10 15:10:33 +01:00
Leo Lamprecht
f444350a4f Revert "Add husky"
This reverts commit 0892443104.
2018-12-10 11:14:02 +00:00
Javi Velasco
0892443104 Add husky 2018-12-10 00:30:16 +01:00
Leo Lamprecht
c97a0cffe1 13.0.0-canary.23 2018-12-07 23:07:06 +00:00
Leo Lamprecht
8ff7340eb2 Make download script work properly (#1729) 2018-12-08 00:06:40 +01:00
Leo Lamprecht
9dcf4d0264 13.0.0-canary.22 2018-12-07 22:37:31 +00:00
Leo Lamprecht
4a38798595 Re-enabled minification and source map reporting (#1727)
* Test tag logging

* Track source maps on Sentry

* Bumped @zeit/ncc to the latest version
2018-12-07 23:37:00 +01:00
Leo Lamprecht
b80804dae5 13.0.0-canary.21 2018-12-07 15:18:30 +00:00
Leo Lamprecht
8e4d885268 Fixed even more Sentry errors (#1726)
* Fixed NOW-CLI-A5

* Fixed NOW-CLI-AW

* Fixed NOW-CLI-B4

* Fixed NOW-CLI-8G

* Fixed NOW-CLI-BV

* Fixed NOW-CLI-6Z

* Fixed NOW-CLI-AV

* Fixed NOW-CLI-6A

* Fixed NOW-CLI-24
2018-12-07 16:18:11 +01:00
Leo Lamprecht
51f229b0bd 13.0.0-canary.20 2018-12-06 22:31:58 +00:00
Leo Lamprecht
c6a16a0279 Downgrade @zeit/ncc (#1725)
* Downgrade `@zeit/ncc`

* Fixed package.json
2018-12-06 23:31:49 +01:00
Leo Lamprecht
16c0a93d46 13.0.0-canary.19 2018-12-06 22:07:41 +00:00
Leo Lamprecht
857129c60f Fixed several errors (#1724)
* Handle EPERM errors when creating config files

* Catch errors when retrieving scope

* Added validation for the API URL

* Removed useless whitespace

* Removed useless file

* Cleaned up `setRawMode` mess

* Removed tests that are erroring on non-TTY

* Set environment based on release channel

* Fixed syntax
2018-12-06 23:07:08 +01:00
Leo Lamprecht
84e6a52834 Improved error reporting system (#1723)
* Configure releases and environment for Sentry

* Correctly send development errors away

* Report Sentry errors with metadata

* Report username and full name of user too

* Better release name
2018-12-06 15:23:46 +01:00
Leo Lamprecht
9a47c6c6d5 Added legacy preferGlobal flag (#1722) 2018-12-06 14:06:36 +01:00
Leo Lamprecht
17362c0cad 13.0.0-canary.18 2018-12-05 22:16:39 +00:00
Leo Lamprecht
e022bffe40 Improved Sentry error reporting (#1720)
* Bumped `@zeit/ncc` to latest version

* Do not report user errors

* Do not report mistyped arguments to Sentry

* Do not report when user aborts action

* Removed all occurances of user errors

* Do not report arg errors

* Correctly report teams and billing errors

* Prevent `setRawMode` from causing an error

* Do not report errors while developing

* Revert "Prevent `setRawMode` from causing an error"

This reverts commit 323296f30bfcca70ea5bb736db98357212f86a0a.

* Fixed whitespace
2018-12-05 23:16:20 +01:00
Leo Lamprecht
f3381e95ef 13.0.0-canary.17 2018-11-30 23:32:14 +00:00
Leo Lamprecht
294f1d7983 Made npm run link work (#1715) 2018-12-01 00:24:48 +01:00
Leo Lamprecht
9bfb33d88c Replaced webpack with ncc (#1710)
* Removed useless stuff

* Removed types

* Removed types file

* Made the build work

* Fixed bundling

* Fixed linting

* Fixed download compiler

* Try to fix bundling problem

* Ignored two things

* Upgraded pkg to stable

* Fixed syntax finally

* Fixed unit tests

* Removed shebangs

* Fixed integration tests

* Made download script work
2018-12-01 00:14:32 +01:00
Leo Lamprecht
12b874507f Changed default of sessionAffinity to random (#1713) 2018-11-30 21:48:43 +01:00
Leo Lamprecht
cee97582fc 13.0.0-canary.16 2018-11-29 18:33:49 +00:00
Gustaf Räntilä
c66b6843a4 Improved http2 stability (#1705) 2018-11-29 19:30:43 +01:00
Leo Lamprecht
9fc03bbc9a Correctly report code coverage (#1709) 2018-11-29 19:30:00 +01:00
Leo Lamprecht
36c875a7f7 Added code coverage report (#1708)
* Added code coverage report

* Correctly include everything

* Ignored useless stuff

* Combine all the coverages

* Corrected requiring

* Persist only what is needed
2018-11-29 19:03:32 +01:00
Leo Lamprecht
48b175fa43 13.0.0-canary.15 2018-11-29 16:01:04 +00:00
Leo Lamprecht
4d35ea9bf3 Ensured now -V 1 owner/repo continues working (#1707)
* Ensured `now -V 1 owner/repo` continues working

* Added newline

* Added tests
2018-11-29 17:00:49 +01:00
Leo Lamprecht
62368fda23 13.0.0-canary.14 2018-11-27 22:37:15 +00:00
Leo Lamprecht
6b89eca022 Render more accurate error when offline (#1704) 2018-11-27 23:36:02 +01:00
Leo Lamprecht
000c02247d 13.0.0-canary.13 2018-11-27 21:19:35 +01:00
Leo Lamprecht
6b899188c4 Render a proper error when offline (#1702)
* Made debugging entry file work

* Render proper error when offline

* Return proper exit code
2018-11-27 21:16:34 +01:00
Leo Lamprecht
24f0efc0e2 13.0.0-canary.12 2018-11-27 19:48:43 +01:00
Leo Lamprecht
b6bbb28757 Render more detailed error when files are not there (#1700) 2018-11-27 19:46:03 +01:00
Leo Lamprecht
8e1cd54c92 13.0.0-canary.11 2018-11-26 11:09:02 +01:00
Leo Lamprecht
8b3dff12e8 Do not render instance count for 2.0 deployments (#1697)
* Do not render instance count for 2.0 deployments

* Added integration test
2018-11-26 11:08:40 +01:00
Leo Lamprecht
c82b18f772 13.0.0-canary.10 2018-11-23 12:11:10 +01:00
Leo Lamprecht
2642e15aff Do not send github property to API (#1694) 2018-11-23 12:10:56 +01:00
Leo Lamprecht
bf4dac5c3b 13.0.0-canary.9 2018-11-22 16:47:53 +01:00
Leo Lamprecht
8729214f8b Do not send alias to the API (#1690) 2018-11-22 16:47:31 +01:00
Leo Lamprecht
ff6073a932 13.0.0-canary.8 2018-11-22 13:39:17 +01:00
Leo Lamprecht
2cfee720a3 Properly render schema validation errors (#1689)
* Properly render schema validation errors

* Added integration test

* Removed useless properties
2018-11-22 13:38:46 +01:00
Leo Lamprecht
061e3d212d 13.0.0-canary.7 2018-11-21 18:11:55 +01:00
Leo Lamprecht
04bb549e36 Make now teams add work (#1684)
* Make `now teams add` work

* Added integration test

* Added comment
2018-11-21 18:11:33 +01:00
Leo Lamprecht
68fcb587a9 13.0.0-canary.6 2018-11-19 13:23:03 +01:00
Leo Lamprecht
93165ef0b2 Do not store a backup of the binary (#1676) 2018-11-19 13:16:31 +01:00
Leo Lamprecht
a616124cc6 Build for dev and not for prod when linking (#1671) 2018-11-16 22:54:20 +01:00
Leo Lamprecht
2ccb8f9a17 13.0.0-canary.5 2018-11-16 00:16:29 +01:00
Leo Lamprecht
4b58fac608 Made publishing work (#1669) 2018-11-16 00:16:02 +01:00
Leo Lamprecht
a4a3d8a6eb 13.0.0-canary.4 2018-11-15 22:21:45 +01:00
Leo Lamprecht
dbcb18bffc Upgrade to Webpack 4.0 (#1667)
* Added support for Webpack 4

* Brought performance back

* Default output dir

* Made it take effect

* Made binary work
2018-11-15 22:19:51 +01:00
Leo Lamprecht
a499580b4d 13.0.0-canary.3 2018-11-15 01:26:16 +01:00
Leo Lamprecht
4fd952b0da Report server errors that are unhandled (#1658) 2018-11-15 01:26:02 +01:00
Evil Rabbit
234ed2718f Update repo banner (#1659) 2018-11-15 01:17:49 +01:00
Leo Lamprecht
77c1818572 13.0.0-canary.2 2018-11-15 01:07:06 +01:00
Leo Lamprecht
b704aca0fe Send unexpected errors away for inspection (#1657)
* Send errors away for inspection

* Allow Sentry to send them away

* Fixed dependency

* Fix credit card input

* Do not test for something that requires TTY

* Track properly

* Make it extra safe

* Added back test
2018-11-15 01:03:46 +01:00
Leo Lamprecht
8226f81026 Added new now upgrade and now downgrade commands (#1656)
* Handle cancelation

* Fixed imports

* Added support for old plans

* Removed test that does not apply anymore
2018-11-14 23:53:46 +01:00
Leo Lamprecht
1b062aa597 Fixed error message for minimum instance count (#1655) 2018-11-14 14:27:14 +01:00
Leo Lamprecht
3f863cace4 13.0.0-canary.1 2018-11-13 23:52:48 +01:00
Leo Lamprecht
737536297c Allow re-using aliases that point to deleted deployments (#1653)
* Allow re-using aliases that point to deleted deployments

* Removed
2018-11-13 23:48:40 +01:00
Leo Lamprecht
c9017b5bf9 12.0.0-canary.100 2018-11-13 20:10:39 +01:00
Leo Lamprecht
89dc51fab5 Log version when debugging (#1652) 2018-11-13 19:03:21 +01:00
Leo Lamprecht
78067113d7 Decrease amount of retries for download (#1651)
This fixes #1622.
2018-11-13 19:00:07 +01:00
Leo Lamprecht
bef3abbe2c Return code 0 if no deployments found when removing (#1650)
* Return code 0 if no deployments found when removing

This fixes #1605.

* Fixed integration test

* Fixed second example too

* Fixed all occurances
2018-11-13 18:54:18 +01:00
Leo Lamprecht
1255c24898 12.0.0-canary.99 2018-11-12 22:12:39 +01:00
Leo Lamprecht
4e0b923552 Made default value for --dotenv (v1) work again (#1649) 2018-11-12 22:12:18 +01:00
Leo Lamprecht
ef9a6ac6aa 12.0.0-canary.98 2018-11-12 13:07:56 +01:00
Leo Lamprecht
60c0d725c9 Added -V to the usage information (#1648) 2018-11-12 12:53:12 +01:00
Leo Lamprecht
59450f470a 12.0.0-canary.97 2018-11-12 12:48:21 +01:00
Leo Lamprecht
09dfd736db Added tests for -V option (#1647)
* Added tests for `-V` option

* Pushed for testing

* Correctly set it

* Revert "Correctly set it"

This reverts commit c76286082d90f091ecec4a317856e91b4558e781.

* Create a new deployment each time
2018-11-12 12:48:08 +01:00
Leo Lamprecht
3852c9bf3f 12.0.0-canary.96 2018-11-10 20:55:57 +01:00
Leo Lamprecht
f3d9208d08 Added support for -V option (#1644) 2018-11-10 20:55:35 +01:00
Leo Lamprecht
c62236791a 12.0.0-canary.95 2018-11-08 22:21:24 +01:00
Leo Lamprecht
bbe6ff820a Made --build-env, --meta and --dotenv work for v1 (#1637)
Made `--build-env`, `--meta` and `--dotenv` work for v1

* Locked multi static file test to v1

* Correct fix

* Final fix

* Config also adds to count

* Fixed single file test

* legacy => old

* Correctly set it
2018-11-08 22:20:33 +01:00
Bart Deslagmulder
47679469ac Updated error documentation about not nameservers (#1629) 2018-11-08 18:49:15 +01:00
Leo Lamprecht
f7e79a31a0 12.0.0-canary.94 2018-11-08 16:27:27 +01:00
Leo Lamprecht
2d8c995756 Added support for Now 2.0 (#1636)
* Removed external providers

* Renamed sh provider

* Removed serverless stuff

* Fixed paths

* Properly pass token

* Fixed paths

* Check for token correctly

* Remove useless properties

* Fixed unit tests

* Keep certain things

* Adjusted remaining parts

* Fixed login

* Remove user properties that are not needed

* Store `platformVersion` for teams

* Store `platformVersion` for users

* Delete team order when logging out

* Made team commands work with tiny config

* Load data dynamically

* Made billing command show correct context

* Fixed remaining occurences of context name

* Fixed remaining pieces

* Test CI

* Clean strings when testing

* Better error check

* Render correct information when asking for credit card

* Migrate from objects to strings

* Better migration message and keep tips

* Remove the old property

* Use note for migration message

* Don't show spinner for loading missing data

* Allow for current team or user to be deleted

* Two deploy files

* Consume context name correctly

* Removed deployment types from new deployer

* Also check for bigger than 1

* Better file names

* Added upgrade message for legacy deployer

* Make help work when logged out

* Error if sub command doesn't exist when requesting help

* Fixed wording

* Support for version property added

* Better handling

* Removed useless props from deploy help

* Don't show version warnings when rendering help

* Fixed wording in readme

* Migrate even if in the middleground

* Make `now whoami` work

* Deprecated support for deploying Git repo in latest deployer

* Added usage information

* Load config separately

* Don't need local config on root

* Correct status code for help test

* Show error only in correct case

* Properly error if path does not exist

* Fixed types

* Fixed remaining occurances of old config

* Don't show warning when rendering help

* Consider version when outputting help

* Only error if path does not exist if it's not help

* Remove testing logging

* Don't error for no-verify

* Stop logging

* Fixed last test

* Added missing semicolons

* Fix indent

* Fix indent again

* Ran prettier over everything

* Added missing types

* Brought test hashes back to normal

* Exit properly when deploying

* Show clipboard note in gray and remove Node.js version

* Completed usage information

* Ensure `now whoami` only outputs the user

* Don not save user data to config

* Removed last traces of `user` and `.api` and `--team` work

* Made `now upgrade` and `now downgrade` correctly render context

* Fixed upgrade/downgrade URL for teams

* Ability to load required data

* Better file name

* Corrected check for current scope

* Don't render version warning when showing help

* Keep polling for handlers

* Render handlers

* Removed useless file

* Much better transpilation setup

* Sweetened logging

* Shortened time it takes to render ready

* Support for error ready states

* Make sure table is not wobbling

* Show times for every handler

* Attach env and build env

* Don't pass useless stuff

* Re-structured pipeline

* Allow empty config

* Do not support package.json config for new pipeline

* Removed occurances of AWS

* Drop useless packages

* Removed useless file

* Ensure the legacy pipeline is working

* Test staging proxy with legacy pipeline

* Adjust test

* Stop testing staging proxy

* Allow for anything

* Pass `handlers` and `routes` to creation endpoint

* Fixed tests

* Revert "Fixed tests"

This reverts commit e0d18a61b9520728089cb2f9e6877c1b91016312.

* Running tests should not be optional

* Support for `-m` and `--meta` added

* Support reading `meta` in local config

* Allow reading `name` from local config

* The `public` prop in local config should be considered

* Handlers deployments should use `.nowignore` and nothing else

* Allow handlers deployments without `handlers` and `routes` in the config

* Locked legacy tests to legacy platform version

* Support aliasing handlers deployments

* Removed useless condition

* Don't allow scaling handlers deployments

* Don't show warning message when deploying single file

* Fixed tests

* Made `now inspect` work

* No type for handlers deployments in list

* Indicate whether a deployment is legacy in `now inspect`

* Made `--force` work for handlers deployments

* Do not document `--dotenv` for handlers (not supported)

* Do not strip `hdl_` from handler IDs

* Fixed for upgrading to latest platform

* Better error for when `version` property is missing

* Render platform version while deploying

* Strip `hdl_` from handler IDs

This reverts commit 750d38ba9074bdc3e63ad2dab8538e51dbba5f03.

* Removed `https://` from handler list

* Removed demo mock

* Cleaner errors

* Make times and erroring work properly

* Print final deployment error

* Removed useless promise

* Prettified code

* Put config utils into correct location

* Moved even more config files

* Removed useless directory

* Removed last useless file

* Fixed wrong paths

* Fixed unit tests

* Update deployment according to handler state, like the server-side loop

* More robust deployment mechanism

* Poll every 1.5 seconds

* Prevent many requests

* Show spinner while waiting for deployment to be ready

* Render how long the deployment took

* Avoid unnecessary repainting

* Automatically remove useless `user` property from config when migrating

* Fixed property names in `now inspect`

* Render platform version for legacy pipeline

* Shortened error messages

* Support `regions` in the local config

* Support for `--regions` added

* Add metadata support for legacy deployments (#2)

* Share handlers table between deploying and inspecting

* Make `now inspect` work nicely

* Renamed handlers to builds

* Stop sending away description

* Bare UI support for builds

* Simper logic for rendering builds

* Render output of builds

* Indicate lambdas in a better way

* Render size for build output

* Do not show type for version 2 deployments

* Fixed time output for `now inspect`

* Don't handle BUILDS type

* Allow for 100% non-config deployments

* Add metadata support for now ls (#3)

* Add metadata support for now ls
So, we can do things like this:
  now ls -m key1=value1 -m key2=value2

* Better description

* Fix wording

* Added final newline

* Add sentry (#4)

* Revert "Add sentry (#4)"

This reverts commit 851d1bdb0e1bbc8f329a45388865b2c41395d8c2.

* Only render build output if it was not copied

* Made `now alias` work with latest staging proxy

* Revert "Made `now alias` work with latest staging proxy"

This reverts commit 16e8998435ef03c50d2737f3ef17fa5c0c2dd33f.

* Bumped deployments API to the latest version

* Made `now rm` work

* Do not print `version` warning for single files

* Removed useless `fs-extra` dependency

* Removed useless dependencies

* Default binaries to Node 10

* Bumped Node.js in Circle CI to latest

* Bumped Xcode to get latest Node.js for integration tests

* Enabled HTTP/2 support

* Removed useless code

* Added integration test for builds

* Bumped `fetch-h2` to the latest version

* Avoid performing network request for rendering help

* Render note when viewing latest help

* Return status code `2` when exiting with help

* Fixed test for usage information

* Removed wrong text in usage info for Now 2.0

* Removed support for `--links` from v2 pipeline

* migrated => upgraded

* Added default routing for single files

* Make `--token` work as expected

* Better message for build errors

* Prevent update notification

* Prevent update notifications from showing

* Only show migration message in debug output

* Prevent flickering of state

* Improved output

* Removed useless assignment

* Corrected padding

* Less padding before state

* Corrected links for global configuration

* Fixed integration tests

* Render region for Lambdas

* Join regions in a better way

* Ensure `now.json` and `.nowignore` (the latter worked anyways) are uploaded

* Fix `build.env` in new deployment API call (#6)

* JSON log the deployment body when debugging (#8)

Otherwise it's just `[object Object]` which is useless.

* Retry to fetch on error on follow mode (#5)

* retry fetch on error on follow mode

* improve logging

* Fixed `--env` and `--build-env` CLI args (#7)

* Fix `--env` and `--build-env` CLI args

* Fall back to `undefined`

* Ensure `now switch` lists active scope in the beginning

* Removed useless code

* Error if `env` or `build.env` have wrong types

* Made `now inspect` look great

* Fixed wrong protocol in URL

* Made `now --team` work with users

* Leave PHP out of integration test for now

* Do not select PHP build

* Fixed integration tests

* Revert "12.0.0-canary.93"

This reverts commit 70a0a594b4.

* Revert "Revert "Add support for top-level "sh" auth""

This reverts commit 4273d62460.

* Revert "12.0.0-canary.92"

This reverts commit 847c71ecf2.

* Revert "Add support for top-level "sh" auth"

This reverts commit c493d651db.

* Revert "12.0.0-canary.91"

This reverts commit 06c954f8fe.

* Revert "Added metadata support for `now inspect` (#1634)"

This reverts commit 9567656b45.

* Revert "12.0.0-canary.90"

This reverts commit 966737be23.

* Revert "Added support for deployment metadata (#1604)"

This reverts commit 6c1188a787.
2018-11-08 16:24:31 +01:00
Leo Lamprecht
70a0a594b4 12.0.0-canary.93 2018-11-03 17:54:47 +01:00
Leo Lamprecht
4273d62460 Revert "Add support for top-level "sh" auth"
This reverts commit c493d651db.
2018-11-03 17:54:36 +01:00
Nathan Rajlich
847c71ecf2 12.0.0-canary.92 2018-11-02 21:01:32 -07:00
Nathan Rajlich
c493d651db Add support for top-level "sh" auth 2018-11-02 21:00:45 -07:00
Leo Lamprecht
06c954f8fe 12.0.0-canary.91 2018-11-02 21:26:13 +01:00
Arunoda Susiripala
9567656b45 Added metadata support for now inspect (#1634) 2018-11-02 21:25:50 +01:00
Leo Lamprecht
966737be23 12.0.0-canary.90 2018-11-02 21:14:24 +01:00
Arunoda Susiripala
6c1188a787 Added support for deployment metadata (#1604)
* Allow to add metadata in the now deploy command.
Use can add multiple items of metadata with:
  '-m key1=val1 -m key2=val2'

* Add a test case.

* Update to accept and send metadata as meta.

* Use correct fields in now.create

* Add now ls support.

* Add an integration tests for ls with metadata

* Added newline

* Removed semicolon
2018-11-02 21:05:47 +01:00
Leo Lamprecht
39fffe6874 12.0.0-canary.89 2018-09-23 17:32:13 +02:00
Evil Rabbit
a75ae8a1b1 Update repo banner 2018-09-23 12:04:53 -03:00
Leo Lamprecht
c1d49fe8aa 12.0.0-canary.88 2018-09-20 15:50:23 +02:00
Mark
577831f775 Suppress the warning of a dependency based on an expression (#1588) 2018-09-20 15:50:07 +02:00
Leo Lamprecht
098ad6e98c 12.0.0-canary.87 2018-09-18 23:07:21 +02:00
Javi Velasco
248fdbaddf Change copy for finish cert message (#1590) 2018-09-18 23:06:56 +02:00
Leo Lamprecht
417a1abcf7 12.0.0-canary.86 2018-09-14 20:43:13 +02:00
Javi Velasco
d36ecec9c4 Bring back now certs add (#1583) 2018-09-14 20:42:57 +02:00
Leo Lamprecht
7a2895d3a3 12.0.0-canary.85 2018-09-12 23:43:53 +02:00
Nathan Rajlich
58f156a491 Render Cloud v2 info about deployments in now inspect (#1577)
`slot` and `limits` are now rendered when it is a Cloud v2 deployment.

Also fixes an issue with static deployments always
rendering `affinity: undefined`.
2018-09-12 23:39:16 +02:00
Nathan Rajlich
02ee8602cd Add "all" pseudo-DC to the constants mapping (#1581) 2018-09-12 23:31:58 +02:00
Nathan Rajlich
e999f5dd72 Add now inspect to --help (#1578) 2018-09-12 23:31:29 +02:00
Leo Lamprecht
5e1b099285 12.0.0-canary.84 2018-09-11 18:34:26 +02:00
Matheus Fernandes
87b1f5a5fb Added new iad1 data center (#1575) 2018-09-11 18:34:08 +02:00
Leo Lamprecht
ae8cbdce0a 12.0.0-canary.83 2018-09-10 19:09:42 +02:00
Cygnusfear
95de48c03f Changed error to log to avoid breaking automatic deployments (#1572)
throwing an error re-opened this issue:
https://github.com/zeit/now-cli/issues/1044

breaks automation when no deployments are found or deployment name is changed
2018-09-10 19:09:36 +02:00
Nathan Rajlich
5ea4fd9a5e Add now whoami to --help (#1573) 2018-09-10 19:06:19 +02:00
Leo Lamprecht
1f3d9e7e0f 12.0.0-canary.82 2018-09-06 21:00:04 +02:00
Jaga Santagostino
05e4528b1c Add changelog link when new version is available (#1530)
* add changelog link if new version is available

* Linked directly
2018-09-06 20:59:24 +02:00
Jarmo Isotalo
40789776bc Prefer URL over deployment ID as the ID not shown in now ls (#1554) 2018-09-06 20:59:19 +02:00
Zeke Sikelianos
75759edd26 Use consistent wording in usage (#1541) 2018-09-06 20:39:53 +02:00
Nathan Rajlich
2a5dc1dba6 Update @zeit/dockerignore to v0.0.3 (#1560)
* Update `@zeit/dockerignore` to v0.0.2

To fix https://github.com/zeit/now-cli/issues/1441.

* Update `@zeit/dockerignore` to v0.0.3
2018-09-06 20:39:09 +02:00
Javi Velasco
0cbf50b7ff 12.0.0-canary.81 2018-09-05 18:00:07 +02:00
Javi Velasco
a3f5b805bb Restructure certs command (#1567)
* Restructure add command

* Remove cert start and finish

* Rename certs add to issue

* Better errors and add cant-solve-challenge

* Show err.sh for dns configuration errors generating certs

* Add err.sh to solve challenges manually

* Add deprecation message to certs add

* Improve grammar

* Minor fixes
2018-09-05 17:58:22 +02:00
Javi Velasco
c337877501 12.0.0-canary.80 2018-09-02 23:24:48 +02:00
Javi Velasco
a6e9dd850a Allow to generate certs solving challenges manually (#1566)
* Move getDomainNameservers function

* Don't show an error as unexpected if there is a code in the error payload

* Add start and finish cert order functions

* Integrate add wildcard cert for external domains

* Use a different endpoint to get a cert by id

* Add new command to download a certificate

* If there are no pending challenges, try to generate the cert right away

* Remove cert download

* Move DNS table options to an object

* Bugfix: cancel spinner message when finish order fails

* Restore add to work only with cert add

* Refactor obtaining cns

* Add start and finish order commands
2018-09-02 23:24:04 +02:00
Leo Lamprecht
a14d4057de 12.0.0-canary.79 2018-09-01 12:18:06 +02:00
Olli Vanhoja
210240ce66 Fix scaling v1 deployments to all DCs (#1556)
```
> Error! An unexpected error occurred in scale: Error: This region (gru1) only accepts Serverless Docker Deployments (400)
```

This is happening because `now-cli` is validating DC names and
expanding "all" locally. However not all DCs have same features but
the client can't be aware of that. Instead of making the client
aware of the differing capabilities of the available DCs we should
pass "all" as a special DC selector, and let the backend handle
scaling properly.
2018-08-28 18:51:52 -07:00
timothyis
d21f7fe75c 12.0.0-canary.78 2018-08-25 15:52:37 +01:00
Timothy
54805cd2a0 Add gru1 (#1545)
* Add gru1

* Add gru to errors

* Hard code sfo,bru scale

* Add --regions argument

* Push with console.log

* Scale to `bru`

* Scale down in bru only
2018-08-25 15:52:16 +01:00
Javi Velasco
c7da2e732a 12.0.0-canary.77 2018-08-24 02:41:01 +02:00
Javi Velasco
4b4beaa892 Pass domain to verify insted of alias when verifying on alias (#1548) 2018-08-24 02:40:35 +02:00
Javi Velasco
e13596acae 12.0.0-canary.76 2018-08-20 20:10:08 +02:00
Javi Velasco
8eb065181f Return scaling validation errors on alias (#1538)
* Return scaling errors on alias

* Join pattern match error in one expression
2018-08-20 19:52:29 +02:00
Javi Velasco
1d97219fef 12.0.0-canary.75 2018-08-20 05:13:55 +02:00
Javi Velasco
d312f94825 Fix updating scale (#1536) 2018-08-20 04:46:55 +02:00
Javi Velasco
478a6f7369 12.0.0-canary.74 2018-08-19 18:22:22 +02:00
Javi Velasco
e309123296 Try to verify against domain name instead of alias (#1534) 2018-08-19 18:21:46 +02:00
Leo Lamprecht
777646cb0e 12.0.0-canary.73 2018-08-13 19:23:27 +02:00
Arunoda Susiripala
39e23f7144 Remove @zeit/schemas (#1507)
We no longer use it inside this repository.
2018-08-13 18:52:58 +02:00
Leo Lamprecht
b68b5c0ea3 12.0.0-canary.72 2018-08-09 12:23:10 +02:00
Sean
46dfeb8ca9 Less cryptic invalid alias message (#1506)
* Less cryptic invalid alias message

* URL -> hostname
2018-08-09 12:23:05 +02:00
Leo Lamprecht
6771ad43af Point Spectrum badge to correct location (#1516) 2018-08-09 12:21:35 +02:00
Luciano Pellacani Franca
1881b9c6cb fixing typo (#1509) 2018-08-07 20:26:05 +01:00
Pranay Prakash
dae6b7a980 12.0.0-canary.71 2018-08-04 03:08:37 +00:00
Pranay Prakash
aed6209f6a Bugfixes and improvements for deployment READY status detection (#1501)
* Have returnify use generators and reinstantiate them upon error

* check for status not_ready instead of 412

* poll every 5s instead of 1s for ready state notification

* poll every 2s for scale verification
2018-08-03 19:31:23 -07:00
Leo Lamprecht
b44a590aa0 12.0.0-canary.70 2018-08-03 08:16:35 +02:00
Olli Vanhoja
936b5fc983 Show selected session affinity when inspecting a deployment (#1489) 2018-08-03 08:12:43 +02:00
yairhaimo
473d6617f2 Include correct help command in now domains (#1492) 2018-08-03 08:11:29 +02:00
Leo Lamprecht
fcf50b5aeb 12.0.0-canary.69 2018-08-02 10:55:58 +02:00
Pranay Prakash
a3835d2e8a Retry 412 errors (#1494)
* retry on 412

* add comment for returnify and exit when the iterator ends
2018-08-02 10:55:02 +02:00
Pranay Prakash
d89481966e poll every 5s (#1496) 2018-08-01 22:56:19 -07:00
Leo Lamprecht
3148ce0f31 12.0.0-canary.68 2018-08-02 07:29:37 +02:00
Leo Lamprecht
f65363856a Better error message for rate limiting deployments (#1495)
* Better error message for rate limiting deployments

* Fixed typo

* Show time until reset

* Removed logging
2018-08-02 07:28:31 +02:00
Leo Lamprecht
e205b57352 12.0.0-canary.67 2018-08-01 13:49:54 +02:00
Aria Malkani
f44a1dbf21 Checks if it is an npm deployment before getting the aliased name (#1490)
* checks it is a npm deployment before reading package.json

* checks if you have a config.type first

* checks if you have a config.type first

* fixed logic for config.type
2018-08-01 13:49:27 +02:00
Leo Lamprecht
b7fe2f606c 12.0.0-canary.66 2018-07-31 10:27:36 +02:00
Leo Lamprecht
6e81c1795c Bumped configuration schemas to the latest version (#1488) 2018-07-31 10:27:22 +02:00
Leo Lamprecht
141d8e4467 12.0.0-canary.65 2018-07-30 13:35:55 +02:00
Robin Millette
edbfeab75f Updated link about authentication file (#1483)
* Fix link to config help

* Update get-default-auth-cfg.js
2018-07-30 13:35:34 +02:00
Robin Millette
e48ea10ebb Updated link about global configuration file (#1482)
* Fix link to config help

* Update get-default-cfg.js
2018-07-30 13:34:52 +02:00
Leo Lamprecht
8565af5526 12.0.0-canary.64 2018-07-30 13:23:30 +02:00
Leo Lamprecht
511d3bae8f Added schema for static header configuration (#1486)
* Added schema for static header configuration

* Bumped yet again
2018-07-30 13:23:07 +02:00
Pranay Prakash
8df233fef1 12.0.0-canary.63 2018-07-29 22:07:06 +00:00
Pranay Prakash
4b97410cc0 Don't downscale previous slot deployment on alias (#1485)
* don't downscale

* use /now/v4/deployments/:id
2018-07-29 15:05:34 -07:00
Leo Lamprecht
aadf8097d1 12.0.0-canary.62 2018-07-24 23:48:57 +02:00
Leo Lamprecht
40d8b74b1b Fixed now billing and use new API (#1477)
* Use correct source when listing

* Use correct source when buying domains

* Replaced the rest too

* Make adding work nicely

* Make listing work for all scopes

* Don't require address

* Bumped lockfile

* Removed more useless code

* Renamed file

* Fixed weird zlib error

* Fixed output

* Added some tests
2018-07-24 23:48:00 +02:00
Leo Lamprecht
8c4d42891c 12.0.0-canary.61 2018-07-22 01:54:51 +02:00
Leo Lamprecht
3672374d23 Fixed integration tests (#1476) 2018-07-22 01:54:05 +02:00
Leo Lamprecht
9ff9d3f174 12.0.0-canary.60 2018-07-19 19:54:19 +02:00
Nathan Rajlich
86540fa7fd Add --build-env to now deploy command (#1459)
* Add `--build-env` to `now deploy` command

Build env vars are only visible during build-time, compared to
regular env vars which are only exposed during runtime.

This also removes the client-side validation of the deployment
schema, because it makes it difficult to keep the client and server
in sync, especially as new features are added. Instead `now-cli`
should be responsible for knowing how to render the server's error
message in an informative and future-proof way so that we can
update the server and even older clients would show the validation
error properly.

* Remove `only` dependency

* Add `--build-env` CLI flag integration test
2018-07-19 19:53:52 +02:00
Pranay Prakash
1538c80a7d 12.0.0-canary.59 2018-07-18 23:29:18 +00:00
Pranay Prakash
0225fcfe51 Improvements to the CLI to handle slot specific flows (#1475)
* Handle scale slots error

* generate and send a requestID when verifying instantiation

* Don't compy incompatible scale settings

* deprecate BinaryDeployment

* add err.sh link

* swap cuid for uuid
2018-07-18 16:26:07 -07:00
Leo Lamprecht
57f3861de6 12.0.0-canary.58 2018-07-17 09:50:26 +02:00
Arunoda Susiripala
04c365a251 Add more integration tests (#1466)
* Add more integration tests related to static builds and env
Here we are adding a few more integration tests for static builds and for using env vars in the build step.

* Add build-env related test case.
2018-07-17 09:47:21 +02:00
Nathan Rajlich
7dfe4690ce 12.0.0-canary.57 2018-07-17 00:10:17 -07:00
Nathan Rajlich
92bcf1b7c9 Remove shallow deployment verification (#1474)
Remove shallow deployment verification
2018-07-17 00:08:55 -07:00
Igor Klopov
8a15d5c65a retry createDeploy if files are missing. addresses #1463 (#1465) 2018-07-13 18:26:12 +03:00
Leo Lamprecht
f64374225d 12.0.0-canary.56 2018-07-11 15:37:44 +02:00
Javi Velasco
7537eac6a7 Control can't solve challenge errors (#1458) 2018-07-11 15:37:22 +02:00
Leo Lamprecht
e2880d2434 12.0.0-canary.55 2018-07-10 19:28:01 +02:00
Javi Velasco
8296de16ef Check domain after adding (#1455)
* Check domain info after adding it

* Add message spiner to show while adding a domain
2018-07-10 19:27:42 +02:00
Leo Lamprecht
5cff5e9dfd 12.0.0-canary.54 2018-07-10 12:16:13 +02:00
Javi Velasco
cb07a748c2 Refactor DNS and update domains with CDN improvements (#1438)
* Do not allow adding domains with subdomains

* Do not ask for confirmation when the domain exists

* Improve message when the domain is under a different account

* Fix flow errors

* Revamp domains add command

* Remove setting dns records when setting up the domain

* Refactor DNS commands

* Hide fields in system dns records and show creator

* Better formatting for dns ls

* Remove exhaustive check of dns record type

* Remove domain ids from responses in domain commands

* Change all `domains` API references to use `v3`

* Update to domains API v3

* Remove NeedUpgrade error and use CDNNeedsUpgrade where it proceeds

* Update copies when adding domains

* Remove extra blank line

* Fix flow errors
2018-07-10 12:13:45 +02:00
Nathan Rajlich
c7b985bdc6 Remove legacy atlas logic (#1451)
* Remove legacy `atlas` logic

No longer used for anything.

* Remove another `atlas`
2018-07-10 11:43:00 +02:00
Javi Velasco
bf32ca0e4a Dont try to generate always wildcard certs when aliasing (#1445)
* Change params order in createAlias

* Make setupDomain return domainInfo

* Do not try to get a wildcard cert for alias when domain is external

* Update setup-domain.js
2018-07-10 11:42:37 +02:00
Javi Velasco
a4e52de0e3 Add retryAfter info to rate limit errors (#1442) 2018-07-10 11:41:28 +02:00
Nathan Rajlich
e43e9b11a0 Wait for static builds to be ready and show logs (#1452)
Implicitly sets the `noVerify` option since there is nothing to verify.
2018-07-10 01:11:10 -07:00
Javi Velasco
847b9e97c4 12.0.0-canary.53 2018-07-09 13:05:01 +02:00
Javi Velasco
baad689286 Fix typo when checking NS during setup domain (#1450) 2018-07-09 12:53:11 +02:00
Arunoda Susiripala
5e7afc4385 12.0.0-canary.52 2018-07-09 09:40:37 +05:30
Matheus Fernandes
d724b7a631 Revert "Upgrade to webpack 4 and latest Babel" (#1448)
* Revert "12.0.0-canary.51"

This reverts commit 5e17fe5ad6.

* Revert "Update `@zeit/schemas` to v1.6.0"

This reverts commit b216adadc0.

* Revert "Upload the Dockerfile if it's a static deployment. (#1437)"

This reverts commit 5078c95667.

* Revert "Upgrade to webpack 4 and latest Babel (#1436)"

This reverts commit 7612d77647.
2018-07-08 20:48:55 -07:00
Nathan Rajlich
5e17fe5ad6 12.0.0-canary.51 2018-07-05 17:52:14 -07:00
Nathan Rajlich
b216adadc0 Update @zeit/schemas to v1.6.0 2018-07-05 17:39:38 -07:00
Arunoda Susiripala
5078c95667 Upload the Dockerfile if it's a static deployment. (#1437)
* Upload the Dockerfile if it's a static deployment.
This allows us to build the Dockerfile and upload static assets

* Allow to upload package.json as well for static deployments.
2018-07-05 22:32:19 +05:30
Javi Velasco
7612d77647 Upgrade to webpack 4 and latest Babel (#1436)
* Upgrade to webpack 4 and last latest

* Fix building commands

* Do not call yarn build when yarn link

* Use resolved paths in webpack config
2018-07-04 17:51:16 +01:00
Leo Lamprecht
0d76041c10 12.0.0-canary.50 2018-07-03 21:20:17 +02:00
Javi Velasco
59be596d24 Allow to deploy and alias when non essential APIs are down (#1435)
* Try to purchase a domain only when there is no other choice

* Allow eventsStream to fail during deployment

* Allow to verify instantiation without events API
2018-07-03 12:18:54 -07:00
Leo Lamprecht
63e51a3c98 12.0.0-canary.49 2018-07-02 11:31:15 +02:00
Leo Lamprecht
7f3128b3e5 Fixed the tests (#1430)
* Fixed the tests

* Wrapped up
2018-07-02 11:30:44 +02:00
Leo Lamprecht
c235813ae7 12.0.0-canary.48 2018-06-22 21:50:33 +02:00
Javi Velasco
3ee18e7051 Small fixes (#1418)
* Remove FlowFixMe in deploy command

* Show success message when creating a cert for alias based on response cns
2018-06-21 23:04:40 -07:00
Leo Lamprecht
14fc5d8796 12.0.0-canary.47 2018-06-21 12:53:44 +02:00
Leo Lamprecht
9fb0077385 Improved error message for schema validation (#1416)
* Bumped schema

* Improved error message for schema validation
2018-06-21 12:53:12 +02:00
Javi Velasco
2e9c7265b6 12.0.0-canary.46 2018-06-19 17:13:48 +02:00
Javi Velasco
d9e77b784a Allow to enable and disable CDN for domains and refactor domains (#1413)
* Move domains command to its own folder

* Refactor domains commands

* Add cdn to domain ls

* Add function to patch domains

* Support toggling cdnEnabled

* Better messages

* Add new cdn options to help command in domains
2018-06-19 17:12:55 +02:00
Javi Velasco
b5b296ad7f 12.0.0-canary.45 2018-06-15 17:35:53 +02:00
Javi Velasco
acdfde5aa2 Deeply nested wildcard certs (#1407)
* Better error when we can't verify a domain during alias

* Remove preferDNS option from CLI and allow wildcard certs for deeply nested
2018-06-15 12:04:10 +02:00
Pranay Prakash
0eddfbd28c Improve the progress bar during upload (#1406)
* use push instead of read

* don't auto-clear

* single progress bar that hangs till last chink

* print symmary beofre link

* print smmary faster

* print more discreet timestamps

* fix tests

* fix flow error
2018-06-13 23:21:39 -04:00
Javi Velasco
037f0610bc 12.0.0-canary.44 2018-06-13 15:39:27 +02:00
Javi Velasco
dd45f8f2ab Request normal cert for deeply nested alias (#1404)
* Request normal cert for deeply nested alias

* When is a deeply nested domain request a normal cert
2018-06-13 15:38:47 +02:00
Leo Lamprecht
d454c84f61 12.0.0-canary.43 2018-06-11 10:40:32 +02:00
Felix Yan
a4c98e07a5 Fix a typo in unique-strings.js (#1400) 2018-06-08 12:20:57 -07:00
Igor Klopov
85715630bd test-integration: test deployment logs output (#1398) 2018-06-08 04:31:36 -07:00
Nathan Rajlich
45d8d4a84f 12.0.0-canary.42 2018-06-07 14:48:16 -07:00
Nathan Rajlich
690882c97a Fix shallow verify (#1397) 2018-06-07 14:45:27 -07:00
Leo Lamprecht
e03836e4a1 12.0.0-canary.41 2018-06-07 11:00:32 +02:00
Leo Lamprecht
d4ec54135a Updated configuration schema (#1394) 2018-06-07 10:59:51 +02:00
Javi Velasco
b29785d851 Ensure there is scale rules before trying to apply (#1389) 2018-06-07 10:52:24 +02:00
Javi Velasco
148870d706 Fixed unexpected error while aliasing (#1387) 2018-06-07 10:50:49 +02:00
Nathan Rajlich
ed1f7e335d Add shallow deployment verification (#1367)
* Add shallow deployment verification

* Add Flow type for `now.retry()`

* Add 3 fetch retries to shallow verify

* Use generics

* Collapse

* Fix

* Add `X-Now-Shallow` verification
2018-06-06 13:08:19 -07:00
Matheus Fernandes
eaf4695194 12.0.0-canary.40 2018-06-01 15:59:43 -07:00
Igor Klopov
c312d42302 reuse getSafeAlias function for all callers of findAliasByAliasOrId (#1385) 2018-06-02 01:27:47 +03:00
Leo Lamprecht
a8a2a6c066 12.0.0-canary.39 2018-05-29 20:07:19 +02:00
Leo Lamprecht
8b3512cb07 Bumped configuration schemas to the latest version (#1379) 2018-05-29 20:06:57 +02:00
Leo Lamprecht
945facdd2c 12.0.0-canary.38 2018-05-29 18:36:15 +02:00
Javi Velasco
8676ed4cff Support for Custom Deployment Suffix (#1378)
* Allow to fallback to passed body parsing a response error

* Extract domain purchase from setup-domain

* Move getCertRequestSettings

* Add create method to Now interface

* Extract print dns table and zeit world table functions

* Add support to generate certificates during deploy

* Point to v5 in deploy endpoint

* Add feedback messages when creating a cert during deployment

* Remove hardcoded references to now.sh

* Dont bump create endpoint version

* Support empty reponses in fetch
2018-05-29 07:58:24 -07:00
Leo Lamprecht
e4d4afa840 12.0.0-canary.37 2018-05-28 13:16:13 +02:00
Leo Lamprecht
81cf286ea4 Bumped configuration schemas to the latest version (#1374) 2018-05-28 13:15:58 +02:00
Leo Lamprecht
e834625728 12.0.0-canary.36 2018-05-28 09:07:30 +02:00
Pranay Prakash
a7c22eb08c add @zeit/dockerignore (#1373) 2018-05-26 09:51:56 -07:00
Leo Lamprecht
837c358371 12.0.0-canary.35 2018-05-25 20:58:30 +02:00
Leo Lamprecht
9743db27e7 Updated configuration schemas to the latest version (#1372) 2018-05-25 11:54:27 -07:00
Tim Neutkens
ce725143e6 12.0.0-canary.34 2018-05-22 17:32:26 +02:00
Tim Neutkens
677805c33a Make sure subdomain is correctly typed / checked (#1364)
Fixes an error introduced in #1344 when running `now alias` on a naked domain like `example.com`.
2018-05-22 17:31:25 +02:00
Pranay Prakash
3d3f1fe39b Make the progress bar for uploads consider bytes, not number of files (#1335)
* use got and propogate uploadProgress

* Accept comma separated cns (#1336)

* use got and propogate uploadProgress

* hook into stream.read

* revert `got` stuff

* remove stray whitespace
2018-05-21 16:40:24 -07:00
Pranay Prakash
123c68ad2b fix clipboard arg parsing (#1358) 2018-05-21 16:39:40 -07:00
Timothy
86861c58af Fix error message via #1350 (#1361) 2018-05-21 16:39:22 -07:00
Pranay Prakash
d4ddb6b3f9 Strip quotes from Dockerfile labels (#1351)
* Strip quotes from Dockerfile labels

* remove console.log

* add test

* issue normal cert for nested subdomain (#1344)

* Prefer HTTP challenge for regular certs

* 12.0.0-canary.31

* Update non-existing team test

* 12.0.0-canary.32

* Bumped `update-check` to the latest version (#1354)

* 12.0.0-canary.33

* Strip quotes from Dockerfile labels

* remove console.log

* add test
2018-05-21 16:39:06 -07:00
Leo Lamprecht
0fc7de40d4 12.0.0-canary.33 2018-05-18 14:06:57 +02:00
Leo Lamprecht
3cb4a9c8dd Bumped update-check to the latest version (#1354) 2018-05-18 14:06:18 +02:00
Javi Velasco
d681289457 12.0.0-canary.32 2018-05-18 03:24:28 +02:00
Javi Velasco
bc1c3c3f5b Update non-existing team test 2018-05-18 03:24:08 +02:00
Javi Velasco
5ae4287c0f 12.0.0-canary.31 2018-05-18 03:02:00 +02:00
Javi Velasco
cde9f56886 Prefer HTTP challenge for regular certs 2018-05-18 03:01:26 +02:00
Pranay Prakash
2b6b006bbd issue normal cert for nested subdomain (#1344) 2018-05-18 02:32:12 +02:00
Leo Lamprecht
54e1bcafc0 12.0.0-canary.30 2018-05-16 21:28:21 +02:00
Leo Lamprecht
7e98d0a22b Store config on platform & load schema from package (#1349)
* Load schema from package

* Send config to deployment endpoint

* Upgraded @zeit/schemas to the latest version

* Removed type for now

* Added config correctly
2018-05-16 21:26:41 +02:00
Tim Neutkens
c27b4a6aaf 12.0.0-canary.29 2018-05-16 18:08:53 +02:00
Javi Velasco
8f17ffd817 Fix table import (#1348) 2018-05-16 18:07:58 +02:00
Leo Lamprecht
0a7d688d32 12.0.0-canary.28 2018-05-15 21:58:07 +02:00
Leo Lamprecht
8cb2fe1284 Account for npm being down (#1346)
* Corrected license file name

* Corrected readme name

* Added editorconfig

* Account for npm being down

* Print full error

* Only show full error while debugging
2018-05-15 21:57:40 +02:00
Leo Lamprecht
e6e375232e 12.0.0-canary.27 2018-05-15 10:07:03 +02:00
Guillermo Rauch
08c4ab8a0c Updated error message about verification timeout 2018-05-15 10:06:37 +02:00
Leo Lamprecht
f86647fc26 12.0.0-canary.26 2018-05-15 10:01:29 +02:00
Javi Velasco
f310f6a86f Accept comma separated cns (#1336) 2018-05-08 21:36:53 +02:00
Javi Velasco
58c6acd265 12.0.0-canary.25 2018-04-27 22:02:10 -07:00
Igor Klopov
c7d97e3866 ignore keep-alive packets for now logs -f (#1331) 2018-04-27 21:45:47 -07:00
Javi Velasco
0890144c61 12.0.0-canary.24 2018-04-26 11:13:14 -07:00
Javi Velasco
69a7d91b57 Safe deployment polling and other minor fixes (#1330)
* Initialize polling function from args

* Remove rule of having a mandatory dest field in path alias rules

* Wait 5 seconds after getting the deployment ready

* Ignore errors coming from events stream
2018-04-26 11:07:15 -07:00
Javi Velasco
a9016c88f6 Refactor scale and remove old alias and scale (#1321)
* Migrate to arg@2.0.0

* Refactor scale command

* Move alias.js to alias/index.js

* Move alias set to its own file

* Move alias ls to its own file

* Move alias rm to its own file

* Remove old alias and scale files

* Update alias integration test

* Fix scaling to 0

* Read scale params from now.json on deploy
2018-04-24 19:16:25 -07:00
Igor Klopov
e8990742cf handle keep-alive event in inspect command (#1326) 2018-04-22 20:16:02 -07:00
Javi Velasco
f51400a3a1 12.0.0-canary.23 2018-04-18 11:27:15 -07:00
Javi Velasco
e763ee5301 Handle ENOENT error when deploying unexistent path (#1320)
* Handle ENOENT error when deploying unexistent path

* Show success on dedupped deployments
2018-04-18 11:26:47 -07:00
Javi Velasco
fd978699e8 Migrate to arg@2.0.0 (#1316) 2018-04-17 19:28:45 -07:00
Javi Velasco
bbd9585829 Fix double ambiguous deploy prompt (#1318) 2018-04-17 19:20:27 -07:00
Javi Velasco
54cf1ebb31 12.0.0-canary.22 2018-04-17 18:07:07 -07:00
Javi Velasco
6fc77c6cfa Fix 0 min scale (#1317) 2018-04-17 18:05:04 -07:00
Javi Velasco
f8372e3bb9 12.0.0-canary.21 2018-04-17 10:49:33 -07:00
Naoyuki Kanezawa
6728be7b1a improve image upload (#1293) 2018-04-17 10:37:17 -07:00
Javi Velasco
65e1a1e731 Fix number of instances verification (#1315) 2018-04-17 10:32:32 -07:00
Javi Velasco
cd9478e853 12.0.0-canary.20 2018-04-16 17:46:47 -07:00
Javi Velasco
b9364ed4fc Improve instance verification for deploy (#1313)
* Refactor verify instances for deploy

* Don't rely on return

* Use new verify instances in alias

* Use new verify instances in alias
2018-04-16 17:45:19 -07:00
Leo Lamprecht
2715e8e9d8 12.0.0-canary.19 2018-04-13 23:23:44 -07:00
Javi Velasco
f987c93cf0 Replace combine-async-generators (#1305)
* Replace combine-asyng-generators

* Ignore empty objects from events stream

* Update type for alias event
2018-04-13 21:55:06 -07:00
Javi Velasco
5c254a7151 Print response in docker test (#1304)
* Print response when failing in docker test file

* Add line

* Parse response text as JSON, print if it fails
2018-04-13 19:49:18 -07:00
Leo Lamprecht
f253e29f33 12.0.0-canary.18 2018-04-13 19:05:49 -07:00
Leo Lamprecht
f37fa13eab Added missing dependencies (#1303) 2018-04-13 19:00:17 -07:00
Javi Velasco
64765b393a Refactor deploy events printing (#1302)
* Move deploy command to its own directory

* Do not show success on downscale message

* Move getDeploymentByIdOrHost to /util/deploy

* Remove unneeded parameter in getAppName

* Better types for copyToClipboard

* Update to babel 7

* Add generator utility functions

* Add function to get deployment events

* Finish  getDeploymentEvents after getting one state-change event

* Refactor deploy events and reduce verification timeout

* Reduce verification timeout for scale and alias

* Use output.log for success message in scale

* Fix integration tests
2018-04-13 18:33:27 -07:00
Leo Lamprecht
54c84b4ce0 12.0.0-canary.17 2018-04-11 12:23:06 -07:00
Javi Velasco
146bcba794 Remove old certs command (#1295) 2018-04-11 12:22:49 -07:00
Leo Lamprecht
d3dd1b731d 12.0.0-canary.16 2018-04-11 11:43:12 -07:00
Javi Velasco
d608ee7390 Remove old alias command (#1294) 2018-04-11 11:42:38 -07:00
Leo Lamprecht
4e2e0950c7 12.0.0-canary.15 2018-04-10 17:53:51 -07:00
Leo Lamprecht
ddc7e97ab6 Fixed typo in release instructions 2018-04-10 17:53:27 -07:00
Leo Lamprecht
a21759ee42 Resolved conflicts 2018-04-10 17:53:02 -07:00
Leo Lamprecht
cc4beb94cf Merge branch 'master' into canary 2018-04-10 17:47:11 -07:00
Leo Lamprecht
18c6822b67 11.1.1 2018-04-10 17:24:56 -07:00
Leo Lamprecht
9ced8b7e75 Moved documentation for releasing out 2018-04-10 16:53:01 -07:00
Leo Lamprecht
67c556f2e3 Make clear how a release works exactly 2018-04-10 16:52:56 -07:00
Leo Lamprecht
cea3072f1a Improved intro and contribution section 2018-04-10 16:52:51 -07:00
Leo Lamprecht
2e09ca0286 Made sure the integration tests work as expected 2018-04-10 16:52:45 -07:00
Leo Lamprecht
0bfafa9311 12.0.0-canary.14 2018-04-10 16:38:48 -07:00
Leo Lamprecht
4eefc34629 Moved documentation for releasing out 2018-04-10 16:26:44 -07:00
Leo Lamprecht
4d3f882dc0 Make clear how a release works exactly 2018-04-10 16:08:39 -07:00
Leo Lamprecht
3a802fbb70 Improved intro and contribution section 2018-04-10 16:07:31 -07:00
Leo Lamprecht
6f00b03d24 Made sure the integration tests work as expected 2018-04-10 15:46:41 -07:00
Tim Neutkens
dd77a721d6 11.1.0 2018-04-10 15:23:06 +02:00
Javi Velasco
b44bd7c2ca Merge canary and solve conflicts 2018-04-10 06:18:47 -07:00
Tim Neutkens
26e9922016 Bring back integration tests as part of releasing 2018-04-10 14:55:51 +02:00
Tim Neutkens
e7ffddb4ee 12.0.0-canary.13 2018-04-10 14:39:41 +02:00
Tim Neutkens
22c73ff5af Temporarily disable integration tests 2018-04-10 14:38:53 +02:00
Javi Velasco
934f8b8cc3 12.0.0-canary.12 2018-04-10 05:29:04 -07:00
Javi Velasco
66c726f3ee 12.0.0-canary.11 2018-04-10 04:36:53 -07:00
Javi Velasco
a49e6640a3 Remove setup domain message 2018-04-10 04:35:20 -07:00
Javi Velasco
88b935ba4f 12.0.0-canary.10 2018-04-10 03:20:43 -07:00
Javi Velasco
98744f5bdf Remove certs by cn (#1288)
* Allow to remove certs by cn and id

* Use getCerts in certs ls command
2018-04-10 03:18:51 -07:00
Javi Velasco
0e0855370e Certificates revamped (#1282)
* Certificates revamped

* Change copy of certs loading msg

* Be more specific when we generate a certificate from alias

* Better messages when creating certs

* Ensure TTY works for alias

* Check if DNS records are configured instead of checking resolved server

* Fallback to a normal cert when the DNS settings are not valid for wildcard

* Be explicit setting alias.zeit.co DNS records

* Check DNS records to request a certificate that will success for zeit.world
2018-04-10 01:51:03 -07:00
Leo Lamprecht
26b11b8939 11.0.7 2018-04-09 17:57:27 -07:00
Leo Lamprecht
e1f8c752c8 Don't render update message on non-TTY (#1281) 2018-04-09 17:42:31 -07:00
Leo Lamprecht
b68c631a5a 12.0.0-canary.9 2018-04-09 17:08:12 -07:00
Leo Lamprecht
91b691ba0a Don't render update message on non-TTY (#1281) 2018-04-09 17:07:41 -07:00
Leo Lamprecht
4aec88d4af 12.0.0-canary.8 2018-04-09 16:14:00 -07:00
Javi Velasco
9b0bdc3f13 Find instances count when listing an alias with deployment ls (#1280) 2018-04-09 16:03:29 -07:00
Leo Lamprecht
7f2e14061d 12.0.0-canary.7 2018-04-08 22:04:48 -07:00
Javi Velasco
7c96f2d08c Refactored now alias to be more bullet-proof (#1267) 2018-04-08 22:03:45 -07:00
Leo Lamprecht
e1c5af561d Replaced the update checker (#1275)
* Replaced update checker

* Moved to devDeps

* Removed prod dep entry
2018-04-08 21:07:58 -07:00
Leo Lamprecht
594c715943 12.0.0-canary.6 2018-04-08 20:35:34 -07:00
Leo Lamprecht
6ca2931de8 Replaced the update checker (#1275)
* Replaced update checker

* Moved to devDeps

* Removed prod dep entry
2018-04-08 20:33:29 -07:00
Leo Lamprecht
01363a5ef9 Re-added dependencies required for download (#1259) 2018-04-06 10:47:45 -07:00
Javi Velasco
0f1471fee4 Remove unused dependencies (#1258) 2018-04-06 10:47:39 -07:00
Sreeram Jayan
0e7ce49ad4 Validate now.json before parsing it (#1239) 2018-04-06 10:47:34 -07:00
Leo Lamprecht
1b9ece5137 11.0.6 2018-04-05 13:30:54 -07:00
Leo Lamprecht
27a7490585 Made sure now alias accepts URLs as targets (#1266) 2018-04-05 13:25:49 -07:00
Leo Lamprecht
885f5a8225 12.0.0-canary.5 2018-04-05 13:25:07 -07:00
Leo Lamprecht
6ba3e8d035 Made sure now alias accepts URLs as targets (#1266) 2018-04-05 13:23:25 -07:00
Leo Lamprecht
babe6f1a09 11.0.5 2018-04-05 00:24:44 -07:00
Leo Lamprecht
482754fc00 Make now ls work as expected (#1263)
* Made domains as app names work again

* Made it work as expected
2018-04-05 00:23:53 -07:00
Leo Lamprecht
a98539b1d3 12.0.0-canary.4 2018-04-05 00:16:49 -07:00
Leo Lamprecht
3224ce7e58 Make now ls work as expected (#1263)
* Made domains as app names work again

* Made it work as expected
2018-04-05 00:15:18 -07:00
Leo Lamprecht
9b325e55dd 11.0.4 2018-04-04 18:47:22 -07:00
Leo Lamprecht
105d68681a Ensure listing single deployments work (#1260)
* Only try to find more deployments if app name defined

* Made note util correct

* Added support for listing single deployments

* Reverted unnecessary change
2018-04-04 18:46:52 -07:00
Javi Velasco
d7a852af8b Corrected downscaling mechanism (#1256)
* Prevent downscaling the current deployment

* Only downscale a deployment after aliasing if it has no other alias
2018-04-04 18:46:43 -07:00
Leo Lamprecht
469b1e8989 Improved integration tests (#1257)
* Assert exit code properly

* Don't strip ANSI stuff
2018-04-04 18:46:36 -07:00
Javi Velasco
2c53007070 Enable ES6 modules (#1255) 2018-04-04 18:46:30 -07:00
Leo Lamprecht
86f9e8bb2f 12.0.0-canary.3 2018-04-04 18:37:35 -07:00
Leo Lamprecht
abdb261717 Ensure listing single deployments work (#1260)
* Only try to find more deployments if app name defined

* Made note util correct

* Added support for listing single deployments

* Reverted unnecessary change
2018-04-04 18:32:03 -07:00
Leo Lamprecht
f9cca94951 Re-added dependencies required for download (#1259) 2018-04-04 17:15:41 -07:00
Javi Velasco
029e5f8e0a Remove unused dependencies (#1258) 2018-04-04 15:49:53 -07:00
Javi Velasco
d278d517df Corrected downscaling mechanism (#1256)
* Prevent downscaling the current deployment

* Only downscale a deployment after aliasing if it has no other alias
2018-04-04 15:07:22 -07:00
Leo Lamprecht
41046531d5 Improved integration tests (#1257)
* Assert exit code properly

* Don't strip ANSI stuff
2018-04-04 14:50:00 -07:00
Sreeram Jayan
d039fb0bbe Validate now.json before parsing it (#1239) 2018-04-04 12:29:13 -07:00
Javi Velasco
baff437e69 Enable ES6 modules (#1255) 2018-04-04 12:22:37 -07:00
Leo Lamprecht
0b895845a1 11.0.3 2018-04-04 12:07:22 -07:00
Igor Klopov
d47fd0e10a Fixed static deployments on the OSS plan (#1253) 2018-04-04 12:07:14 -07:00
Leo Lamprecht
fc46bc077f 12.0.0-canary.2 2018-04-04 11:58:48 -07:00
Igor Klopov
16b7ff9a25 Fixed static deployments on the OSS plan (#1253) 2018-04-04 11:50:15 -07:00
Leo Lamprecht
ccb79a1096 11.0.2 2018-04-04 11:13:50 -07:00
Javi Velasco
fd557ac9fe Only write URL to stdout (#1245)
* Only write URL to stdout

* Update wait.js
2018-04-04 11:11:21 -07:00
Leo Lamprecht
f643f6c28a 12.0.0-canary.1 2018-04-04 11:07:34 -07:00
Javi Velasco
362fc0b3d8 Only write URL to stdout (#1245)
* Only write URL to stdout

* Update wait.js
2018-04-04 10:59:27 -07:00
Matheus Fernandes
3329bbf053 11.0.0-canary.37 2018-04-03 23:20:08 -03:00
Matheus Fernandes
3357a5de77 11.0.1 2018-04-03 23:17:49 -03:00
Javi Velasco
ad780bdcd8 Remove DNS extra check in alias for verified domains (#1242) 2018-04-03 23:08:41 -03:00
Javi Velasco
d1c3ac5015 Ensure deployment scale exists before the check on deploy (#1241) 2018-04-03 23:08:36 -03:00
Zander Martineau
91409f44b5 fix spelling (#1240) 2018-04-03 23:08:31 -03:00
Javi Velasco
f6eb444841 Bugfix: return array of targets of one item when config alias is a string (#1238) 2018-04-03 23:08:27 -03:00
Javi Velasco
f4cc42e25c Remove version trailin space (#1236) 2018-04-03 23:08:11 -03:00
Javi Velasco
570c6849ca Fallback appName to package.json for alias (#1235) 2018-04-03 23:07:56 -03:00
Javi Velasco
cc5d396758 Don't try to scale static deployments (#1232) 2018-04-03 23:07:42 -03:00
Javi Velasco
281c236945 Remove DNS extra check in alias for verified domains (#1242) 2018-04-03 17:49:29 -07:00
Javi Velasco
b90cfde7c0 Ensure deployment scale exists before the check on deploy (#1241) 2018-04-03 15:42:02 -07:00
Zander Martineau
c46d3dbd10 fix spelling (#1240) 2018-04-04 00:05:56 +02:00
Javi Velasco
d3fed8a717 Bugfix: return array of targets of one item when config alias is a string (#1238) 2018-04-03 14:38:54 -07:00
Javi Velasco
7cc55b6cb1 Remove version trailin space (#1236) 2018-04-03 13:54:03 -07:00
Javi Velasco
9847355983 11.0.0-canary.36 2018-04-03 13:41:50 -07:00
Javi Velasco
267b4c904c Fallback appName to package.json for alias (#1235) 2018-04-03 13:40:00 -07:00
Javi Velasco
859790da87 Don't try to scale static deployments (#1232) 2018-04-03 13:39:49 -07:00
Leo Lamprecht
214da9a221 11.0.0-canary.35 2018-04-03 09:29:44 -07:00
Leo Lamprecht
4579919077 Properly handle event polling (#1228) 2018-04-03 09:29:33 -07:00
Leo Lamprecht
d2509e45db 11.0.0 2018-04-03 09:13:21 -07:00
Leo Lamprecht
793e1b11da Properly handle event polling (#1228) 2018-04-03 09:09:17 -07:00
Guillermo Rauch
0e9a21a263 Support for globally distributed deployments (#1205)
* Introduce v3 deployment scaling API

* Less retries on setScale()

* now scale cmd v3

* Deployment id fixes

* bump `ecmaVersion` we lint against, to consider object rest spread

* move EPIPE workaround to the main file

* uniform exiting approach

* clean up list command to avoid globals, be simpler to read

* add ability to supply a custom API version to `now.list()` helper

* upgrade babel toolchain

* introduce `arg`, which will incrementally replace `mri`

* global args accepted by all subcommands

* update lock

* fix `>` to be red when rendering errors

* use new output helpers by @tootallnate

* make object spread work

* bump flow webpack plugin

* lock

* revert to ava 0.25.x

* deprecate `now ls help` since an app could be named `help`

* validate number of arguments

* Fixed integration tests to match downgraded AVA

* Trimmed newline

* WIP

* whitespace fix

* add source map support by @timneutkens

* fix source maps paths

* remove sort-deployments util. it only considers `package.json`

* created -> age for consistency

* remove sorting what wasn't working well

* multiple improvements and simplifications

* improve rendering of urls, fix filtering by app

* only attempt to fetch instances if we have a count > 0

* better check for no deployments

* add instance lists if --all is supplied

* prevent the `.map` file from being included by pkg

* Store artifacts in Circle CI

* adapt INITIALIZING display by suggestion of @tootallnate

* Nothing to return

* now scale: Args parsing and remove ls

* various code improvements, error link for deprecation of `now scale ls`

* improve help

* make error more specific to deployment

* use new error output utilities for `now deploy`

* make some requires conditional

* default command style fix

* add reusable dc validation and normalization utilities

* start doing dc / region validation in scale

* refactor deploy to use reusable dc / region utils

* add slug support for warn util

* add success helper

* improve `scale` command

* add `responseErrorMessage` helper

* add `now.fetch()` helper

* remove console.log

* tweak output

* draft of verification step

* better errors

* implement (customizable) verification timeout

* bump now-host api to v3

* finish verification

* improve verification and sanitization

* improve copy

* fix ctrl+c during scale

* fix max scale in the absense of max

* improved rules saving

* fix listing the context you're running `now list` under

* add context name to list commands from slots

* improve --no-verify

* add 'elapsed' utility to print out the elapsed time nicely

* add per-dc timers

* improve debug helper to save date, improve time helper to log eagerly

* log every request, automatically

* tweak

* general tweaks to `now deploy`

* pass additional now config fields

* refactor `now rm`

* begin `inspect` command

* bump fetch-h2

* nearly complete new inspect command

* add `(dev)` to --version while in development

* fix 404 error if app is not matched

* improve scaling

* pass event types to the events endpoint

* fix file uploads

* fix passing a deployment hostname with trailing `/`

* fetch events only for non-static

* include uid in inspect

* finish up events

* reduce one indent by recommendation of @leo

* fix debugging for `now ls`

* Always return and exit at top-level in now.js

* improved scale message

* more elegant way of exiting, allowing for resource cleanup & faster

* flowify

* fix strange error which happens when orderly cleanup is done

* flow

* flow fix

* invoke now.close()

* improve list indentation

* refactor alias

* exit clean

* improve fallthrough entry in path alias

* make scale exit properly

* fix closing agent for inspection

* add type of deployment to ls

* better error handling of 403

* improve list style

* various algorithmic improvements

* Certificates refactor to consume the new API (#1210)

* Adapt cert command to the new api

* Use the new certs api for cert command

* Console log certs table and point to the right endpoint

* Remove unused certs client file

* Refactor certs commands

* Fix access to args

* Always close client

* Refactor alias (#1216)

* remove unnecessary file

* reads events from /deployment/:id/events endpoint (#1219)

* add polling (#1220)

* add polling

* hack to prevent partial json to be unluckily parsed in _flush

* cleanupAndResolveCalled to prevent running twice

* call onOpen only of going to 'log'. also call from cleanup

* callOnOpenOnce, don't reject on stream error, polling to finish

* fix eraseLines, make cleanup routine reject

* remove build-logger.js

* restored printEvent from deleted build-logger.js

* print locations of instance events

* bump api versions

* Switch now logs to events endpoint (#1223)

* move eraseLines to onRetry. show error in onRetry

* move printEvents to 'sh/util/events.js'

* use printEvents in `now logs` command

* pass printEvent to events.js

* make both follow and non-follow modes work

* remove socket.io

* improve logs command

* clarify team context

* Refactor alias

* Use ellapsed util in stamp

* use v3

* Refactor alias (#1224)

* Refactor alias

* Use ellapsed util in stamp

* Improvements

* Fix unit tests

* Ensure body exists when copying error attrs

* Add hook to close socket and wait message on process exit

* More retries when verifying the DNS records in alias

* Remove nowExit event listener on close

* Add remaning DCs message right away on alias

* Consistent timestamp when creating a deployment + scale dcs

* Ignore flow error

* Remove not needed now.close from alias

* Remove not needed now.close from inspect

* Bugfix: bind context to close socket handler

* Better error handling for scale command

* Now logs limit (#1226)

* restored -n LIMIT cli arg

* show date in format usabe for since and until

* pass direction and limit to endpoint

* implement follow mode after backwards slice

* add query, fix linefeeds, strip term commands

* implement head argument

* better logs default

* logs: fix -o raw mode, fix all mode

* Add verification for deploy

* Run integration tests using random email address

* Fix flow errors

* Fix wrong scale check

* Finish deploy on state READY

* Correct URL parsing

* Bumped Node.js to the latest version

* Output node version

* fix url display

* Returned URLs

* Improve messages in scale

* Clear URLs

* Strip ANSI codes

* Better logging messages for deploy

* Print ls to console instead of stderr

* Add create certificate certificate and ensure verification is done for a domain

* Write success in alias to stdout

* clearURL in stdout for alias test

* Update scale integration test

* Use stdout for scale success message

* Write alias rm response to stdout

* Refactor alias rm to use fetch from now client

* Fix tests
2018-04-03 08:14:41 -07:00
Javi Velasco
c37d741cf2 Add expectedPrice check (#1215)
* Add expectedPrice check

* Add expectedPrice to domain buy method
2018-04-03 08:14:34 -07:00
Leo Lamprecht
893fbd899e 11.0.0-canary.34 2018-04-03 05:36:58 -07:00
Guillermo Rauch
6d14a1bbd4 Support for globally distributed deployments (#1205)
* Introduce v3 deployment scaling API

* Less retries on setScale()

* now scale cmd v3

* Deployment id fixes

* bump `ecmaVersion` we lint against, to consider object rest spread

* move EPIPE workaround to the main file

* uniform exiting approach

* clean up list command to avoid globals, be simpler to read

* add ability to supply a custom API version to `now.list()` helper

* upgrade babel toolchain

* introduce `arg`, which will incrementally replace `mri`

* global args accepted by all subcommands

* update lock

* fix `>` to be red when rendering errors

* use new output helpers by @tootallnate

* make object spread work

* bump flow webpack plugin

* lock

* revert to ava 0.25.x

* deprecate `now ls help` since an app could be named `help`

* validate number of arguments

* Fixed integration tests to match downgraded AVA

* Trimmed newline

* WIP

* whitespace fix

* add source map support by @timneutkens

* fix source maps paths

* remove sort-deployments util. it only considers `package.json`

* created -> age for consistency

* remove sorting what wasn't working well

* multiple improvements and simplifications

* improve rendering of urls, fix filtering by app

* only attempt to fetch instances if we have a count > 0

* better check for no deployments

* add instance lists if --all is supplied

* prevent the `.map` file from being included by pkg

* Store artifacts in Circle CI

* adapt INITIALIZING display by suggestion of @tootallnate

* Nothing to return

* now scale: Args parsing and remove ls

* various code improvements, error link for deprecation of `now scale ls`

* improve help

* make error more specific to deployment

* use new error output utilities for `now deploy`

* make some requires conditional

* default command style fix

* add reusable dc validation and normalization utilities

* start doing dc / region validation in scale

* refactor deploy to use reusable dc / region utils

* add slug support for warn util

* add success helper

* improve `scale` command

* add `responseErrorMessage` helper

* add `now.fetch()` helper

* remove console.log

* tweak output

* draft of verification step

* better errors

* implement (customizable) verification timeout

* bump now-host api to v3

* finish verification

* improve verification and sanitization

* improve copy

* fix ctrl+c during scale

* fix max scale in the absense of max

* improved rules saving

* fix listing the context you're running `now list` under

* add context name to list commands from slots

* improve --no-verify

* add 'elapsed' utility to print out the elapsed time nicely

* add per-dc timers

* improve debug helper to save date, improve time helper to log eagerly

* log every request, automatically

* tweak

* general tweaks to `now deploy`

* pass additional now config fields

* refactor `now rm`

* begin `inspect` command

* bump fetch-h2

* nearly complete new inspect command

* add `(dev)` to --version while in development

* fix 404 error if app is not matched

* improve scaling

* pass event types to the events endpoint

* fix file uploads

* fix passing a deployment hostname with trailing `/`

* fetch events only for non-static

* include uid in inspect

* finish up events

* reduce one indent by recommendation of @leo

* fix debugging for `now ls`

* Always return and exit at top-level in now.js

* improved scale message

* more elegant way of exiting, allowing for resource cleanup & faster

* flowify

* fix strange error which happens when orderly cleanup is done

* flow

* flow fix

* invoke now.close()

* improve list indentation

* refactor alias

* exit clean

* improve fallthrough entry in path alias

* make scale exit properly

* fix closing agent for inspection

* add type of deployment to ls

* better error handling of 403

* improve list style

* various algorithmic improvements

* Certificates refactor to consume the new API (#1210)

* Adapt cert command to the new api

* Use the new certs api for cert command

* Console log certs table and point to the right endpoint

* Remove unused certs client file

* Refactor certs commands

* Fix access to args

* Always close client

* Refactor alias (#1216)

* remove unnecessary file

* reads events from /deployment/:id/events endpoint (#1219)

* add polling (#1220)

* add polling

* hack to prevent partial json to be unluckily parsed in _flush

* cleanupAndResolveCalled to prevent running twice

* call onOpen only of going to 'log'. also call from cleanup

* callOnOpenOnce, don't reject on stream error, polling to finish

* fix eraseLines, make cleanup routine reject

* remove build-logger.js

* restored printEvent from deleted build-logger.js

* print locations of instance events

* bump api versions

* Switch now logs to events endpoint (#1223)

* move eraseLines to onRetry. show error in onRetry

* move printEvents to 'sh/util/events.js'

* use printEvents in `now logs` command

* pass printEvent to events.js

* make both follow and non-follow modes work

* remove socket.io

* improve logs command

* clarify team context

* Refactor alias

* Use ellapsed util in stamp

* use v3

* Refactor alias (#1224)

* Refactor alias

* Use ellapsed util in stamp

* Improvements

* Fix unit tests

* Ensure body exists when copying error attrs

* Add hook to close socket and wait message on process exit

* More retries when verifying the DNS records in alias

* Remove nowExit event listener on close

* Add remaning DCs message right away on alias

* Consistent timestamp when creating a deployment + scale dcs

* Ignore flow error

* Remove not needed now.close from alias

* Remove not needed now.close from inspect

* Bugfix: bind context to close socket handler

* Better error handling for scale command

* Now logs limit (#1226)

* restored -n LIMIT cli arg

* show date in format usabe for since and until

* pass direction and limit to endpoint

* implement follow mode after backwards slice

* add query, fix linefeeds, strip term commands

* implement head argument

* better logs default

* logs: fix -o raw mode, fix all mode

* Add verification for deploy

* Run integration tests using random email address

* Fix flow errors

* Fix wrong scale check

* Finish deploy on state READY

* Correct URL parsing

* Bumped Node.js to the latest version

* Output node version

* fix url display

* Returned URLs

* Improve messages in scale

* Clear URLs

* Strip ANSI codes

* Better logging messages for deploy

* Print ls to console instead of stderr

* Add create certificate certificate and ensure verification is done for a domain

* Write success in alias to stdout

* clearURL in stdout for alias test

* Update scale integration test

* Use stdout for scale success message

* Write alias rm response to stdout

* Refactor alias rm to use fetch from now client

* Fix tests
2018-04-03 05:32:53 -07:00
Javi Velasco
c70d86c738 Add expectedPrice check (#1215)
* Add expectedPrice check

* Add expectedPrice to domain buy method
2018-03-29 10:58:57 -07:00
Leo Lamprecht
ab8f7e21a3 Run scheduled tests on Linux and unscheduled on macOS (#1213) 2018-03-27 18:18:36 -07:00
Leo Lamprecht
b7f56a6b9d Run scheduled tests on Linux and unscheduled on macOS (#1213) 2018-03-27 18:16:18 -07:00
Leo Lamprecht
2212130beb 10.2.2 2018-03-27 17:01:36 -07:00
Leo Lamprecht
294171ed37 Run integration tests on Linux (#1212) 2018-03-27 16:55:16 -07:00
Bart Deslagmulder
c025aa7596 Fix typos (#1208) 2018-03-27 16:55:10 -07:00
Guillermo Rauch
73035bd549 Explain how to run it locally 2018-03-27 16:55:04 -07:00
Leo Lamprecht
3a3fdef1a8 11.0.0-canary.33 2018-03-27 16:42:16 -07:00
Leo Lamprecht
7602daaaef Run integration tests on Linux (#1212) 2018-03-27 16:41:10 -07:00
Guillermo Rauch
6d5b6c6e73 Explain how to run it locally 2018-03-27 16:25:35 -07:00
Bart Deslagmulder
f44e177e43 Fix typos (#1208) 2018-03-22 14:03:08 -07:00
Leo Lamprecht
137552beed 10.2.1 2018-03-16 20:04:48 -07:00
Leo Lamprecht
8bca751e8e Added scheduled CI tests (#1199)
* Added scheduled CI tests

* Run every hour
2018-03-16 19:57:00 -07:00
Nathan Rajlich
b26228ebde Gracefully handle no scale object being returned (#1200)
* Gracefully handle no `scale` object being returned

* Fixed tests
2018-03-16 19:56:56 -07:00
Leo Lamprecht
0e43f85176 11.0.0-canary.32 2018-03-16 19:56:19 -07:00
Leo Lamprecht
11e645f334 Added scheduled CI tests (#1199)
* Added scheduled CI tests

* Run every hour
2018-03-16 19:49:49 -07:00
Nathan Rajlich
10eb83207b Gracefully handle no scale object being returned (#1200)
* Gracefully handle no `scale` object being returned

* Fixed tests
2018-03-16 19:42:26 -07:00
Leo Lamprecht
3a16b092f2 10.2.0 2018-03-16 18:44:45 -07:00
Nathan Rajlich
889d30322f Log the DC(s) that the deployment has been scaled to (#1197)
* Log the DC(s) that the deployment has been scaled to

* Fix Flow error
2018-03-16 18:37:37 -07:00
Leo Lamprecht
ed66a4b7f0 Pinned CI images (#1195)
* Pinned CI images

* Ignored error file

* Switched to different version
2018-03-16 18:37:29 -07:00
Guillermo Rauch
7b31ea29a1 Note about canary development 2018-03-16 18:37:12 -07:00
Guillermo Rauch
70ef3433a8 Update readme.md 2018-03-16 18:37:02 -07:00
Leo Lamprecht
efd3d97305 11.0.0-canary.31 2018-03-16 18:31:34 -07:00
Nathan Rajlich
05ba34f602 Log the DC(s) that the deployment has been scaled to (#1197)
* Log the DC(s) that the deployment has been scaled to

* Fix Flow error
2018-03-16 18:27:39 -07:00
Leo Lamprecht
cff85f78af Pinned CI images (#1195)
* Pinned CI images

* Ignored error file

* Switched to different version
2018-03-16 18:24:19 -07:00
Guillermo Rauch
cb015d8219 Note about canary development 2018-03-16 18:04:13 -07:00
Guillermo Rauch
50bd83abd8 Update readme.md 2018-03-16 18:01:18 -07:00
Volker Rose
ce7d482830 Fix waiting message appearance on now ls (#1192)
* Added debounced waiting message to `list` command

Refs #1167, #1166

* Integrated debouncing directly into wait function

Refs #1167, #1166

* Moved debouncing in `wait` module directly to `wait` function

Refs #1167, #1166

* Added test for `wait`function

Refs #1167, #1166

* Removes oboslete logging from `wait` utitlity

* Removed semis

* Removed semis

* Make sense of it

* Bumped lockfile

* Moved stopping of spinner right before first output within `now ls`
2018-03-16 14:06:27 -07:00
Naoyuki Kanezawa
6e48216234 Added support for multiple regions (#1191) 2018-03-16 14:06:21 -07:00
Volker Rose
05299eefb0 Added debounced waiting message to now ls (#1178)
* Added debounced waiting message to `list` command

Refs #1167, #1166

* Integrated debouncing directly into wait function

Refs #1167, #1166

* Moved debouncing in `wait` module directly to `wait` function

Refs #1167, #1166

* Added test for `wait`function

Refs #1167, #1166

* Removes oboslete logging from `wait` utitlity

* Removed semis

* Removed semis

* Make sense of it

* Bumped lockfile
2018-03-16 14:05:45 -07:00
Leo Lamprecht
a360a0b3f1 11.0.0-canary.30 2018-03-15 16:32:29 -07:00
Naoyuki Kanezawa
d819f5dc93 Added support for multiple regions (#1191) 2018-03-15 16:31:19 -07:00
Volker Rose
08508d1555 Fix waiting message appearance on now ls (#1192)
* Added debounced waiting message to `list` command

Refs #1167, #1166

* Integrated debouncing directly into wait function

Refs #1167, #1166

* Moved debouncing in `wait` module directly to `wait` function

Refs #1167, #1166

* Added test for `wait`function

Refs #1167, #1166

* Removes oboslete logging from `wait` utitlity

* Removed semis

* Removed semis

* Make sense of it

* Bumped lockfile

* Moved stopping of spinner right before first output within `now ls`
2018-03-15 11:02:15 -07:00
Leo Lamprecht
4a6290bd1a 11.0.0-canary.29 2018-03-14 13:53:08 -07:00
Volker Rose
a226f6bffa Added debounced waiting message to now ls (#1178)
* Added debounced waiting message to `list` command

Refs #1167, #1166

* Integrated debouncing directly into wait function

Refs #1167, #1166

* Moved debouncing in `wait` module directly to `wait` function

Refs #1167, #1166

* Added test for `wait`function

Refs #1167, #1166

* Removes oboslete logging from `wait` utitlity

* Removed semis

* Removed semis

* Make sense of it

* Bumped lockfile
2018-03-14 13:48:21 -07:00
Leo Lamprecht
059882fdb9 10.1.6 2018-03-13 20:47:35 -07:00
Leo Lamprecht
cf079e70d2 Added Spectrum badge (#1184) 2018-03-10 20:57:34 -08:00
Leo Lamprecht
49c470d131 Show better errors messages (#1182)
* Added support for fallback error

* Better errors for uploading files

* Ensure all errors are covered

* Formatted properly

* Added a few tests

* Wrapped up tests
2018-03-10 20:57:26 -08:00
Leo Lamprecht
3df6f62af8 11.0.0-canary.27 2018-03-10 20:51:50 -08:00
Leo Lamprecht
c9966aaf84 Added Spectrum badge (#1184) 2018-03-10 20:51:32 -08:00
Leo Lamprecht
d6c63921b8 11.0.0-canary.26 2018-03-10 19:19:52 -08:00
Leo Lamprecht
8a844f1880 Show better errors messages (#1182)
* Added support for fallback error

* Better errors for uploading files

* Ensure all errors are covered

* Formatted properly

* Added a few tests

* Wrapped up tests
2018-03-10 18:26:50 -08:00
Leo Lamprecht
650efbac89 10.1.5 2018-03-08 14:17:58 -08:00
Leo Lamprecht
7b149d0eb7 New integration test suite added (#1173)
* Proper unit tests

* Made integration tests run in CI

* Added packing to integration tests

* Don't lint test fixtures

* Added missing files

* Added command for local testing

* Correct command for local testing

* Compare client version

* Separate file for helper

* Added micro fixture

* Check OSS confirmation message

* Even better

* Deploy a microservice

* Made it run

* Remove deployment properly

* Clean up everything

* Fixed linting

* Added missing fixtures

* Added missing files

* Fixed linking

* Remove only deployments created in session

* Create alias for deployment

* Wrapped up 10 test

* Try scaling the deployment directly

* Wrapped up the 15 tests

* Ensure files are actually equal

* Test docker deployments

* Made sense of all

* Remove right after

* Set redirect URL properly

* Run integration tests on macOS

* Clean up in the end

* Use existing method to clean up

* Revoke the token properly

* Check for team error

* Wrapped up 18 tests

* Try deploying a static directory

* Try running it in user directory

* Auto-generate integration tests

* Removed Yarn lockfile

* Fixed linting

* Run test only if the one before was successful

* Bumped lockfile

* Removed catching

* Removed useless dependency

* Removed line

* Don't kill app and restore config

* Test properly locally

* Fixed linting

* Fixed properly

* Comment added

* Fixed arguments
2018-03-08 14:13:08 -08:00
Leo Lamprecht
627b570aa0 11.0.0-canary.25 2018-03-08 14:12:18 -08:00
Leo Lamprecht
17c5710b55 New integration test suite added (#1173)
* Proper unit tests

* Made integration tests run in CI

* Added packing to integration tests

* Don't lint test fixtures

* Added missing files

* Added command for local testing

* Correct command for local testing

* Compare client version

* Separate file for helper

* Added micro fixture

* Check OSS confirmation message

* Even better

* Deploy a microservice

* Made it run

* Remove deployment properly

* Clean up everything

* Fixed linting

* Added missing fixtures

* Added missing files

* Fixed linking

* Remove only deployments created in session

* Create alias for deployment

* Wrapped up 10 test

* Try scaling the deployment directly

* Wrapped up the 15 tests

* Ensure files are actually equal

* Test docker deployments

* Made sense of all

* Remove right after

* Set redirect URL properly

* Run integration tests on macOS

* Clean up in the end

* Use existing method to clean up

* Revoke the token properly

* Check for team error

* Wrapped up 18 tests

* Try deploying a static directory

* Try running it in user directory

* Auto-generate integration tests

* Removed Yarn lockfile

* Fixed linting

* Run test only if the one before was successful

* Bumped lockfile

* Removed catching

* Removed useless dependency

* Removed line

* Don't kill app and restore config

* Test properly locally

* Fixed linting

* Fixed properly

* Comment added

* Fixed arguments
2018-03-08 13:59:01 -08:00
Leo Lamprecht
86e19e46f5 10.1.4 2018-03-02 15:35:54 -08:00
Sreeram Jayan
d57d90381c Fixed duplicate deployment type prompt (#1168)
* 1163:Fix duplicate deployment type prompt

* Replace existing assets
2018-03-02 15:35:47 -08:00
Leo Lamprecht
3882c64a1d 11.0.0-canary.24 2018-03-02 15:28:08 -08:00
Sreeram Jayan
a5a18821cc Fixed duplicate deployment type prompt (#1168)
* 1163:Fix duplicate deployment type prompt

* Replace existing assets
2018-03-02 15:27:43 -08:00
Tim Neutkens
3fb89120f9 10.1.3 2018-03-02 16:44:22 +01:00
Tim Neutkens
93daac8be9 Remove .ws blocking (#1164)
Allow alias creation for `.ws` domains
2018-03-02 16:44:13 +01:00
Tim Neutkens
4dc9982f1d 11.0.0-canary.23 2018-03-02 16:42:22 +01:00
Tim Neutkens
781f79a87a Remove .ws blocking (#1164)
Allow alias creation for `.ws` domains
2018-03-02 12:40:22 -03:00
Leo Lamprecht
74b7bf6aeb 10.1.2 2018-03-01 21:45:15 -08:00
Sergio Xalambrí
003dac4d1e Allow aliasing .ws domains (#1161) 2018-03-01 21:44:57 -08:00
Leo Lamprecht
7e81abb2b6 11.0.0-canary.22 2018-03-01 21:39:52 -08:00
Sergio Xalambrí
2bcac63885 Allow aliasing .ws domains (#1161) 2018-03-02 02:31:52 -03:00
Leo Lamprecht
1f8343f350 10.1.1 2018-03-01 13:07:22 -08:00
Sreeram Jayan
f27f5180d6 Fixed synchronization timer when deploying (#1160) 2018-03-01 13:07:17 -08:00
Leo Lamprecht
baa5fa8019 11.0.0-canary.21 2018-03-01 13:00:33 -08:00
Sreeram Jayan
179e88b24f Fixed synchronization timer when deploying (#1160) 2018-03-01 12:31:02 -08:00
Leo Lamprecht
a9fd348ca2 10.1.0 2018-03-01 00:44:45 -08:00
Leo Lamprecht
b3ba4e232b Brought CI configuration in sync with canary 2018-03-01 00:43:03 -08:00
Leo Lamprecht
fee759f68d Removed configuration file for Travis CI 2018-03-01 00:42:15 -08:00
Leo Lamprecht
05a6db2956 11.0.0-canary.20 2018-03-01 00:40:57 -08:00
Leo Lamprecht
ae3a19c4e1 Removed configuration file for Travis CI 2018-03-01 00:40:53 -08:00
Leo Lamprecht
4e29f3fd5d Ensure the CI works as intended (#1155) 2018-03-01 00:39:25 -08:00
Leo Lamprecht
a7aa1bbff7 Fixed GitHub, Bitbucket and GitLab deployments (#1154) 2018-03-01 00:39:17 -08:00
Leo Lamprecht
d741019cb5 Switched from Travis CI to Circle CI (#1152)
* Added Circle CI config

* Test it

* Ensure machine property

* Another missing part

* Run one after another

* Use the same image in all jobs

* Made it shorter

* Sweeter syntax

* Split into separate jobs

* Pass on data

* Pass everything around

* Renamed workflow

* Fan-out/fan-in

* Added new build badge

* Better link for badge

* Named commands

* Show help

* Properly attach node modules for deployment

* Capitalized titles

* Install correct uploader

* Use correct image

* Try the uploading

* Try it like this

* Set user and repo

* Filter binaries properly

* Compress binaries only when deploying

* Switched image for deployment step

* Removed Cache

* Install Go properly

* Removed slash

* Set env var correctly for Go

* Use separate jobs

* Cache Go dependencies

* Only upload on tagged builds

* Separate jobs for channels

* Corrected description

* Optimized for maximum performance

* Removed dependency

* Use lockfile for checksum
2018-03-01 00:39:10 -08:00
Leo Lamprecht
48b6c7bab8 Added support multiple path arguments (#1148)
* Switched commands to Yarn

* Only use what's needed

* Use correct command to link

* Show proper deploying output

* Handle everything

* Log it when doing it

* Make all others work

* Fixed syntax

* Removed semis

* Fixed rest

* Make GitHub uploads work again

* Made it work properly

* Ensure paths are relative

* Made it work

* Bumped lockfile

* Fixed code

* Corrected code

* Properly debug

* Fixed linting

* Made it work correctly

* Fixed missing parenthesis
2018-03-01 00:39:03 -08:00
Leo Lamprecht
f536ac3f03 11.0.0-canary.19 2018-03-01 00:23:34 -08:00
Leo Lamprecht
87f289bef1 Only upload compressed binaries 2018-03-01 00:23:30 -08:00
Leo Lamprecht
82d8c26e1e 11.0.0-canary.18 2018-03-01 00:16:44 -08:00
Leo Lamprecht
ee2843bd3b Ensure commands are being run correctly 2018-03-01 00:16:40 -08:00
Leo Lamprecht
40ff0071d7 11.0.0-canary.17 2018-03-01 00:08:10 -08:00
Leo Lamprecht
b7e374cae5 Corrected input for CI 2018-03-01 00:08:08 -08:00
Leo Lamprecht
d42d695d85 11.0.0-canary.16 2018-03-01 00:04:13 -08:00
Leo Lamprecht
1d0943eaa4 Upload each binary separately 2018-03-01 00:04:08 -08:00
Leo Lamprecht
290e187925 11.0.0-canary.15 2018-02-28 23:47:48 -08:00
Leo Lamprecht
0031b273cb Ensure uploaded releases are compressed 2018-02-28 23:47:45 -08:00
Leo Lamprecht
92f5041105 11.0.0-canary.14 2018-02-28 23:40:39 -08:00
Leo Lamprecht
614e403b43 Resolve the full path of binaries 2018-02-28 23:40:30 -08:00
Leo Lamprecht
abbbee14fa 11.0.0-canary.13 2018-02-28 23:28:39 -08:00
Leo Lamprecht
34f52809e7 Corrected path for uploading release 2018-02-28 23:28:28 -08:00
Leo Lamprecht
20aad0e7e9 11.0.0-canary.12 2018-02-28 23:22:44 -08:00
Leo Lamprecht
51171cd9e7 Use different library for uploading releases 2018-02-28 23:22:39 -08:00
Leo Lamprecht
9fea77787b 11.0.0-canary.11 2018-02-28 22:57:32 -08:00
Leo Lamprecht
297f07e4e4 Use custom regular expressions for publishing 2018-02-28 22:57:20 -08:00
Leo Lamprecht
220cea23cd 11.0.0-canary.10 2018-02-28 22:31:31 -08:00
Leo Lamprecht
4594540c2e Properly handle branch detection 2018-02-28 22:31:24 -08:00
Leo Lamprecht
b61d05c8f8 11.0.0-canary.9 2018-02-28 22:27:39 -08:00
Leo Lamprecht
e7383d32de Detect tags and branches correctly 2018-02-28 22:27:28 -08:00
Leo Lamprecht
83e1f67052 11.0.0-canary.8 2018-02-28 22:11:20 -08:00
Leo Lamprecht
c6f12dcb35 Handle tag checkouts properly (#1157) 2018-02-28 22:11:00 -08:00
Leo Lamprecht
d1554d07d4 11.0.0-canary.7 2018-02-28 21:43:57 -08:00
Leo Lamprecht
c4793b9a88 Deploy and publish using Circle CI (#1156) 2018-02-28 21:42:10 -08:00
Leo Lamprecht
0a8f874096 11.0.0-canary.6 2018-02-28 21:28:56 -08:00
Leo Lamprecht
14e4cd7bfb Ensure the CI works as intended (#1155) 2018-02-28 21:25:32 -08:00
Leo Lamprecht
0c97fb327f 11.0.0-canary.5 2018-02-28 20:49:54 -08:00
Leo Lamprecht
4acb5c464b Fixed GitHub, Bitbucket and GitLab deployments (#1154) 2018-02-28 20:47:01 -08:00
Leo Lamprecht
80e66ad010 Switched from Travis CI to Circle CI (#1152)
* Added Circle CI config

* Test it

* Ensure machine property

* Another missing part

* Run one after another

* Use the same image in all jobs

* Made it shorter

* Sweeter syntax

* Split into separate jobs

* Pass on data

* Pass everything around

* Renamed workflow

* Fan-out/fan-in

* Added new build badge

* Better link for badge

* Named commands

* Show help

* Properly attach node modules for deployment

* Capitalized titles

* Install correct uploader

* Use correct image

* Try the uploading

* Try it like this

* Set user and repo

* Filter binaries properly

* Compress binaries only when deploying

* Switched image for deployment step

* Removed Cache

* Install Go properly

* Removed slash

* Set env var correctly for Go

* Use separate jobs

* Cache Go dependencies

* Only upload on tagged builds

* Separate jobs for channels

* Corrected description

* Optimized for maximum performance

* Removed dependency

* Use lockfile for checksum
2018-02-28 19:20:40 -08:00
Leo Lamprecht
21cb5f2ad3 11.0.0-canary.4 2018-02-28 14:13:05 -08:00
Leo Lamprecht
f4c47fd3f4 Added support multiple path arguments (#1148)
* Switched commands to Yarn

* Only use what's needed

* Use correct command to link

* Show proper deploying output

* Handle everything

* Log it when doing it

* Make all others work

* Fixed syntax

* Removed semis

* Fixed rest

* Make GitHub uploads work again

* Made it work properly

* Ensure paths are relative

* Made it work

* Bumped lockfile

* Fixed code

* Corrected code

* Properly debug

* Fixed linting

* Made it work correctly

* Fixed missing parenthesis
2018-02-28 14:11:52 -08:00
Leo Lamprecht
4978716725 10.0.3 2018-02-28 12:37:43 -08:00
Leo Lamprecht
c9358c4877 Ensure chalk is being used properly (#1151) 2018-02-28 12:30:46 -08:00
Leo Lamprecht
14d198cd30 11.0.0-canary.3 2018-02-28 12:30:19 -08:00
Leo Lamprecht
809c41d21a Ensure chalk is being used properly (#1151) 2018-02-28 12:28:48 -08:00
Leo Lamprecht
3469220226 10.0.2 2018-02-28 11:51:30 -08:00
Leo Lamprecht
f4715dfdec Added missing variable references (#1150) 2018-02-28 11:49:35 -08:00
Leo Lamprecht
8f8ee5fb73 11.0.0-canary.2 2018-02-28 11:49:09 -08:00
Leo Lamprecht
be754d8619 Added missing variable references (#1150) 2018-02-28 11:48:59 -08:00
Leo Lamprecht
2ff7f2c68c 10.0.1 2018-02-28 10:37:25 -08:00
Leo Lamprecht
2c95f2c9a9 Bumped lockfile 2018-02-28 10:37:04 -08:00
Matheus Fernandes
c8d2530620 Ensure new deployments are working correctly (#1149) 2018-02-28 10:36:56 -08:00
Nathan Rajlich
2eb736f97d Add new output helper functions (#1146)
* Add "output" helper

* Cleanup and use `output` helper in Now class

* Fixes

* Update `chalk` to v2.3.1

* More logging

* Finish `now deploy` using new output functions

* Remove `.only()`

* Tests are silent

* Prevent double `> >` at the beginning of the user log line
2018-02-28 10:36:50 -08:00
Leo Lamprecht
c73c0ba9f4 11.0.0-canary.1 2018-02-28 10:34:42 -08:00
Leo Lamprecht
04470a68c0 Bumped lockfile 2018-02-28 10:34:19 -08:00
Matheus Fernandes
f72dcefebd Ensure new deployments are working correctly (#1149) 2018-02-28 10:31:05 -08:00
Nathan Rajlich
030317ba67 Add new output helper functions (#1146)
* Add "output" helper

* Cleanup and use `output` helper in Now class

* Fixes

* Update `chalk` to v2.3.1

* More logging

* Finish `now deploy` using new output functions

* Remove `.only()`

* Tests are silent

* Prevent double `> >` at the beginning of the user log line
2018-02-27 16:59:25 -08:00
Leo Lamprecht
d36df53043 10.0.0 2018-02-27 10:23:30 -08:00
Leo Lamprecht
d8faea8332 Don't upload meta files for static deployments (#1144)
* Don't upload meta files for static deployments

* Updated lockfile

* Ignore dockerfile as well
2018-02-26 17:17:23 -08:00
Sam Pal
42f131086f Made now <file> work (#1139)
* Added functionality for single static file deployments.

* Added friendly error message to now alias command

* Deleted temp files

* Removed empty line

* Make it work

* Removed alias message

* Corrected intentation

* Brought variable back

* Removed it

* Set correct name

* Bumped lockfile
2018-02-26 17:17:17 -08:00
Conner Petzold
0450be2653 Add output mode option to logs command (#1131)
* Fix readme typo

* Add raw output mode
2018-02-26 17:17:12 -08:00
Leo Lamprecht
ccb1900af7 10.0.0-canary.30 2018-02-26 17:16:04 -08:00
Leo Lamprecht
dd9b75cbf1 Don't upload meta files for static deployments (#1144)
* Don't upload meta files for static deployments

* Updated lockfile

* Ignore dockerfile as well
2018-02-26 17:13:52 -08:00
Sam Pal
4401e4d3ee Made now <file> work (#1139)
* Added functionality for single static file deployments.

* Added friendly error message to now alias command

* Deleted temp files

* Removed empty line

* Make it work

* Removed alias message

* Corrected intentation

* Brought variable back

* Removed it

* Set correct name

* Bumped lockfile
2018-02-26 16:17:53 -08:00
Conner Petzold
a6fe7953e3 Add output mode option to logs command (#1131)
* Fix readme typo

* Add raw output mode
2018-02-26 15:41:59 -08:00
Ayushi Singh
d72ab61e6f Added friendly error message to now alias (#1140)
* Added friendly error message to now alias command

* Delete .login.js.swp

* Delete .domains.js.swp
2018-02-25 22:20:38 -08:00
Leo Lamprecht
d96473f5ed Removed undefined variable reference (#1143) 2018-02-25 22:20:33 -08:00
Leo Lamprecht
f5fefa88a4 10.0.0-canary.29 2018-02-25 22:19:31 -08:00
Ayushi Singh
b3234d2f5e Added friendly error message to now alias (#1140)
* Added friendly error message to now alias command

* Delete .login.js.swp

* Delete .domains.js.swp
2018-02-25 22:17:36 -08:00
Leo Lamprecht
dfe8163daf Removed undefined variable reference (#1143) 2018-02-25 22:11:20 -08:00
Leo Lamprecht
4391dae4b0 Bumped lockfile 2018-02-24 21:29:06 -08:00
Guillermo Rauch
e991904d02 bump email-prompt to fix #1104 2018-02-24 21:25:46 -08:00
Shaleen Jain
6d40ccb04a Add remaining missing 'console.log' (#1098) 2018-02-24 21:24:57 -08:00
Olli Vanhoja
e2518666ea Remove whois check when using domains add command
When a domain is added with `now domains add` command it's often
because the user needs a working Zone file before changing the NS
records at the registrar or due to issues with the whois service.
Therefore the command is almost always run with `-f` flag.

Remove the `--force` option and always add send the domain add
request without client side verification.
2018-02-24 21:22:15 -08:00
Nathan Rajlich
e83fb66513 Don't print the alias uid upon removal (#1109)
It's irrelevant information and now the uids are very long,
so let's not bother printing that information.
2018-02-24 21:20:47 -08:00
Robert Koch
3f5d3b3238 Corrected whitelisting mechanism for now.json (#1126)
* Updated how files are retrieved so whitelisted files specified in now.json or package.json are always added to the deployment, even if they are excluded in gitignore or npmignore.

* added new tests to check whitelisting of files in now.json and package.json and fixed/modified old tests to work with new behaviour.

* Ran linter, removed console statements.

* Wrote some documentation, fixed some typos, and removed some comments. Also ran prettier.

* Use spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Corrected indentation

* Corrected indentation

* Corrected indentation
2018-02-24 21:07:54 -08:00
Leo Lamprecht
db2c31d917 Pinned missing dependencies 2018-02-24 21:03:58 -08:00
Sam Pal
b8306ef3ba Added missing deps to package.json (#1137) 2018-02-24 21:03:53 -08:00
Leo Lamprecht
94ac6b9272 10.0.0-canary.28 2018-02-24 20:07:45 -08:00
Leo Lamprecht
86da780308 Pinned missing dependencies 2018-02-24 20:06:30 -08:00
Sam Pal
eab8692a58 Added missing deps to package.json (#1137) 2018-02-25 00:47:30 -03:00
Sreeram Jayan
c1d16f9965 Display confirmation message before adding a domain (#1130) 2018-02-24 19:34:35 -08:00
Guillermo Rauch
a63cb28723 Improved error for environment variable type (#1135) 2018-02-24 19:34:25 -08:00
Pranay Prakash
837dd124ea Circumvent attempt to connect logger if reusing an old deployment (#1132) 2018-02-24 19:33:06 -08:00
Leo Lamprecht
7177cad905 10.0.0-canary.27 2018-02-24 19:29:29 -08:00
Matt Mazzola
c2f7f118e9 Remove Microsoft Azure deployment section from README.md (#1138)
Apparently azure deployment was listed in the docs before it was actually supported by now-cli.

I just went through and become confused by the same error message and found the issue:
https://github.com/zeit/now-cli/issues/787

It seems it's easy to remove this section and add it back later when the feature is added
2018-02-24 19:29:23 -08:00
Matt Mazzola
3be1165552 Remove Microsoft Azure deployment section from README.md (#1138)
Apparently azure deployment was listed in the docs before it was actually supported by now-cli.

I just went through and become confused by the same error message and found the issue:
https://github.com/zeit/now-cli/issues/787

It seems it's easy to remove this section and add it back later when the feature is added
2018-02-24 19:23:47 -08:00
Leo Lamprecht
844f940123 10.0.0-canary.26 2018-02-24 11:32:24 -08:00
Robert Koch
cb7c81c66a Corrected whitelisting mechanism for now.json (#1126)
* Updated how files are retrieved so whitelisted files specified in now.json or package.json are always added to the deployment, even if they are excluded in gitignore or npmignore.

* added new tests to check whitelisting of files in now.json and package.json and fixed/modified old tests to work with new behaviour.

* Ran linter, removed console statements.

* Wrote some documentation, fixed some typos, and removed some comments. Also ran prettier.

* Use spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Use more spaces

* Corrected indentation

* Corrected indentation

* Corrected indentation
2018-02-24 11:30:02 -08:00
Sreeram Jayan
3a009fccf0 Display confirmation message before adding a domain (#1130) 2018-02-24 11:13:17 -08:00
Guillermo Rauch
e6f2364c71 Improved error for environment variable type (#1135) 2018-02-24 11:11:46 -08:00
Pranay Prakash
aed5cdb1a8 Circumvent attempt to connect logger if reusing an old deployment (#1132) 2018-02-22 21:33:48 +01:00
Leo Lamprecht
44fd600abb 9.3.3 2018-02-18 14:42:35 -08:00
Leo Lamprecht
17f593e004 Shortened message (#1125) 2018-02-16 18:25:18 -08:00
Leo Lamprecht
37636d84d9 10.0.0-canary.25 2018-02-16 18:21:55 -08:00
Leo Lamprecht
5a87eafb87 Shortened message (#1125) 2018-02-16 18:21:02 -08:00
Leo Lamprecht
8cf760d9d5 Perfected OSS confirmation prompt (#1124)
* Start using v3 endpoint

* Make it work

* Make it bullet proof

* Hide message the second time

* Make sense

* Show upgrade link in note

* Removed useless space

* Show upgrade notice in all cases
2018-02-16 17:53:26 -08:00
Leo Lamprecht
31c11dc06c 10.0.0-canary.24 2018-02-16 17:43:04 -08:00
Leo Lamprecht
ef66da7f3f Perfected OSS confirmation prompt (#1124)
* Start using v3 endpoint

* Make it work

* Make it bullet proof

* Hide message the second time

* Make sense

* Show upgrade link in note

* Removed useless space

* Show upgrade notice in all cases
2018-02-16 17:41:20 -08:00
Leo Lamprecht
8bc1b3f715 How to do a release 2018-02-13 11:44:44 -08:00
Leo Lamprecht
cceafabcd3 How to do a release 2018-02-13 11:38:04 -08:00
Leo Lamprecht
7c19bda30d 9.3.2 2018-02-13 11:31:01 -08:00
Olli Vanhoja
2588253b3d Removed WHOIS fallback (#1121)
The fallback is no longer needed.
2018-02-13 11:29:30 -08:00
Leo Lamprecht
5b56483a93 10.0.0-canary.23 2018-02-13 11:28:23 -08:00
Olli Vanhoja
3d52e8aeac Removed WHOIS fallback (#1121)
The fallback is no longer needed.
2018-02-13 11:28:09 -08:00
Matheus Fernandes
50d59902d6 10.0.0-canary.22 2018-02-13 10:47:57 -02:00
Matheus Fernandes
f4c14be2f2 Release 9.3.1 2018-02-13 10:46:03 -02:00
Matheus Fernandes
86bf608be3 Add more missing console.logs (#1116) 2018-02-13 10:45:30 -02:00
Olli Vanhoja
cf62cdd6f2 Fix creating a new default certificate
The commit 6e476ad454 broke
creating new certificates with `now certs create`.
2018-02-13 10:45:04 -02:00
Matheus Fernandes
5ccb953be1 Add more missing console.logs (#1116) 2018-02-12 11:57:14 -08:00
Leo Lamprecht
0d7b3a27e9 9.3.0 2018-02-09 21:59:42 -08:00
Nathan Rajlich
587201f723 Add now alias rm -y (#1114) 2018-02-09 21:59:31 -08:00
Leo Lamprecht
caeceb7edc 10.0.0-canary.21 2018-02-09 21:56:56 -08:00
Nathan Rajlich
6d9aa9134f Add now alias rm -y (#1114) 2018-02-09 21:50:03 -08:00
Leo Lamprecht
f392aa6d7a 10.0.0-canary.20 2018-02-09 21:05:14 -08:00
Matheus Fernandes
f92e592533 Fix many issues with now teams (#1113)
* Correctly extract the subcommand

* Check team name charset upon every keypress

* Add missing `console.log`s

* Add missing `process.stdout.write`

* Add more missing console.logs

* Add missing return

* Add more missing `process.stdout.write`

* We have to treat `switch` differently, unfortunately

* No need to print the team id

* Fix grammar
2018-02-09 21:04:14 -08:00
Leo Lamprecht
9b23518273 9.2.10 2018-02-09 21:02:04 -08:00
Matheus Fernandes
527650f210 Fix many issues with now teams (#1113)
* Correctly extract the subcommand

* Check team name charset upon every keypress

* Add missing `console.log`s

* Add missing `process.stdout.write`

* Add more missing console.logs

* Add missing return

* Add more missing `process.stdout.write`

* We have to treat `switch` differently, unfortunately

* No need to print the team id

* Fix grammar
2018-02-09 20:59:20 -08:00
Leo Lamprecht
cc9f9eb85d 10.0.0-canary.19 2018-02-09 15:20:23 -08:00
Naoyuki Kanezawa
8f4991ab70 fix help message for session-affinity (#1112) 2018-02-09 15:20:19 -08:00
Leo Lamprecht
7b98381471 9.2.9 2018-02-09 15:17:38 -08:00
Naoyuki Kanezawa
615756552d fix help message for session-affinity (#1112) 2018-02-09 15:14:46 -08:00
Leo Lamprecht
8c16f42826 10.0.0-canary.18 2018-02-06 17:05:37 -08:00
Matheus Fernandes
c4259323d3 Fixed now teams add and now cc add (#1110)
* Add missing `stdout.write`s

* Add missing console.log

* Add missing await
2018-02-06 17:03:00 -08:00
Leo Lamprecht
7b8c3934e2 9.2.8 2018-02-06 17:02:26 -08:00
Matheus Fernandes
930d085fe3 Fixed now teams add and now cc add (#1110)
* Add missing `stdout.write`s

* Add missing console.log

* Add missing await
2018-02-06 17:00:58 -08:00
Leo Lamprecht
d9469898f2 10.0.0-canary.17 2018-02-06 12:13:08 -08:00
Nathan Rajlich
e9c2d3790a Don't print the alias uid upon removal (#1109)
It's irrelevant information and now the uids are very long,
so let's not bother printing that information.
2018-02-06 12:12:21 -08:00
Guillermo Rauch
635a99cb31 bump email-prompt to fix #1104 2018-02-04 18:51:15 -08:00
Leo Lamprecht
aae2f5619f 10.0.0-canary.16 2018-01-31 23:17:16 +01:00
Olli Vanhoja
d0bc560625 Fix creating a new default certificate
The commit 6e476ad454 broke
creating new certificates with `now certs create`.
2018-01-30 16:23:19 +01:00
Shaleen Jain
1572fefe8c Add remaining missing 'console.log' (#1098) 2018-01-29 07:28:00 -08:00
Olli Vanhoja
1508486dc1 Remove whois check when using domains add command
When a domain is added with `now domains add` command it's often
because the user needs a working Zone file before changing the NS
records at the registrar or due to issues with the whois service.
Therefore the command is almost always run with `-f` flag.

Remove the `--force` option and always add send the domain add
request without client side verification.
2018-01-27 13:57:56 +01:00
Leo Lamprecht
c43c6c2c3c 9.2.7 2018-01-20 20:32:20 +01:00
Igor Klopov
5cb792bfbf Update pkg to the latest stable version (#1090)
* update pkg to 4.3.0 stable

* Bumped lockfile
2018-01-20 20:31:42 +01:00
Leo Lamprecht
56c0385d53 Show link for update message (#1091) 2018-01-20 20:31:37 +01:00
Leo Lamprecht
372b31461c 10.0.0-canary.15 2018-01-20 20:29:08 +01:00
Igor Klopov
aa63219743 Update pkg to the latest stable version (#1090)
* update pkg to 4.3.0 stable

* Bumped lockfile
2018-01-20 20:28:25 +01:00
Leo Lamprecht
0ffaf5afd7 Show link for update message (#1091) 2018-01-20 20:23:45 +01:00
Leo Lamprecht
00f8d88578 9.2.6 2018-01-20 11:32:13 +01:00
Leo Lamprecht
e4ffdc024e Pull releases directly from GitHub (#1089) 2018-01-20 11:30:59 +01:00
Leo Lamprecht
b166bc7903 10.0.0-canary.14 2018-01-20 11:28:42 +01:00
Leo Lamprecht
d5369224a4 Pull releases directly from GitHub (#1089) 2018-01-20 11:28:22 +01:00
Leo Lamprecht
a1ca1c047b 9.2.5 2018-01-19 18:31:14 +01:00
Leo Lamprecht
8cc806c4d7 Bring back progress bar (#1088)
* Bundle with compression

* Force gzip to overwrite existing compressions

* Clear directory

* Bring back progress bar

* Start using Cloudinary

* Always ungzip, since we're only shipping .gz

* Only upload .gz files

* Don't test after deployment

Exiting with 1 here doesn't crash test
2018-01-19 18:30:58 +01:00
Leo Lamprecht
a9bd2b8818 10.0.0-canary.13 2018-01-19 18:25:08 +01:00
Leo Lamprecht
ee3e7f0288 Bring back progress bar (#1088)
* Bundle with compression

* Force gzip to overwrite existing compressions

* Clear directory

* Bring back progress bar

* Start using Cloudinary

* Always ungzip, since we're only shipping .gz

* Only upload .gz files

* Don't test after deployment

Exiting with 1 here doesn't crash test
2018-01-19 18:18:46 +01:00
Sreeram Jayan
038c5c0e38 Allow --type to overwrite config (#1086)
* Fix DNS record typo (#929)

* 1064:Check if deployment type is specified/configured.
2018-01-19 13:00:54 +01:00
Sreeram Jayan
2525cd9efb Allow --type to overwrite config (#1086)
* Fix DNS record typo (#929)

* 1064:Check if deployment type is specified/configured.
2018-01-19 13:00:08 +01:00
Leo Lamprecht
cc1e2462f4 10.0.0-canary.12 2018-01-18 23:26:49 +01:00
Leo Lamprecht
d1071e1cd2 Ensure we're catching errors 2018-01-18 23:26:37 +01:00
Matheus Fernandes
c37f3602fb Remove broken function call 2018-01-18 23:26:31 +01:00
Leo Lamprecht
ca8e26f857 Revert "Revert "Show an even better message""
This reverts commit a12fd8cbe2.
2018-01-18 23:25:59 +01:00
Leo Lamprecht
af468f2c8e Revert "Revert "Temporarily disable progress bar""
This reverts commit 0c83b0fddf.
2018-01-18 23:25:46 +01:00
Leo Lamprecht
96084a09c0 9.2.4 2018-01-18 23:23:24 +01:00
Leo Lamprecht
a0a8ac46f5 Ensure we're catching errors 2018-01-18 23:23:12 +01:00
Leo Lamprecht
5f30faabde 10.0.0-canary.11 2018-01-18 22:57:38 +01:00
Leo Lamprecht
0c83b0fddf Revert "Temporarily disable progress bar"
This reverts commit 1edaa48351.
2018-01-18 22:57:20 +01:00
Leo Lamprecht
a12fd8cbe2 Revert "Show an even better message"
This reverts commit a5ddfa1ba0.
2018-01-18 22:57:12 +01:00
Matheus Fernandes
ee8084c98a 9.2.3 2018-01-18 19:38:43 -02:00
Matheus Fernandes
f00f874898 Remove broken function call 2018-01-18 19:38:32 -02:00
Leo Lamprecht
8d752a9bc7 9.2.2 2018-01-18 22:08:20 +01:00
Leo Lamprecht
7c891ac7d2 Show an even better message 2018-01-18 22:07:30 +01:00
Leo Lamprecht
f95cbe080f Temporarily disable progress bar 2018-01-18 22:07:25 +01:00
Leo Lamprecht
147580785f 10.0.0-canary.10 2018-01-18 22:06:06 +01:00
Leo Lamprecht
a5ddfa1ba0 Show an even better message 2018-01-18 22:03:51 +01:00
Leo Lamprecht
1edaa48351 Temporarily disable progress bar 2018-01-18 22:02:47 +01:00
Leo Lamprecht
b0238d827c 9.2.1 2018-01-18 21:28:21 +01:00
Leo Lamprecht
cde0620851 Check content encoding while installing (#1083) 2018-01-18 21:28:18 +01:00
Leo Lamprecht
e188d37348 10.0.0-canary.9 2018-01-18 21:24:12 +01:00
Leo Lamprecht
d08d9d91ae Check content encoding while installing (#1083) 2018-01-18 18:23:36 -02:00
Leo Lamprecht
e87a5b8644 9.2.0 2018-01-18 18:48:13 +01:00
Olli Vanhoja
76bf75d3bf Allow overwriting custom certs with auto-renewable ones (#1082)
Currently it's not possible to create a new auto-renewable
certificate if a custom certificate already exist for a domain,
as we only allow the other direction from the cli.

Add a command flag that allows overwriting a custom certificate
with an auto-renewable certificate.

`now cert create --overwrite zeit.rocks`
2018-01-18 18:48:07 +01:00
Leo Lamprecht
de12cba1df 10.0.0-canary.8 2018-01-18 18:44:26 +01:00
Olli Vanhoja
6e476ad454 Allow overwriting custom certs with auto-renewable ones (#1082)
Currently it's not possible to create a new auto-renewable
certificate if a custom certificate already exist for a domain,
as we only allow the other direction from the cli.

Add a command flag that allows overwriting a custom certificate
with an auto-renewable certificate.

`now cert create --overwrite zeit.rocks`
2018-01-18 18:42:39 +01:00
Leo Lamprecht
f8defc0499 9.1.0 2018-01-14 15:07:03 +01:00
Leo Lamprecht
7ad65696f6 Brought branch in sync with canary 2018-01-14 15:02:45 +01:00
Leo Lamprecht
df4e15ed56 10.0.0-canary.7 2018-01-14 14:47:32 +01:00
Leo Lamprecht
b6a4e3d2f4 Fixed package description 2018-01-14 14:47:17 +01:00
Leo Lamprecht
ac81d4657c Properly error on wrong token and handle team (#1073)
* Properly error on wrong token and handle team

* Better wording
2018-01-14 14:41:48 +01:00
Leo Lamprecht
b81488ac6b Ignore npm lockfile 2018-01-14 14:41:41 +01:00
Gillian
d1bbf85f37 Changed error message to match correct command (#1071) 2018-01-14 14:41:35 +01:00
Leo Lamprecht
7f71e693c5 Use package for checking for updates (#1070)
* Use package for checking for updates

* Set dep for dev
2018-01-14 14:41:26 +01:00
Leo Lamprecht
5d16bf5976 Removed triangle from company name 2018-01-14 14:40:24 +01:00
Leo Lamprecht
c7addf7c47 Properly detect API property
This is a hotfix!
2018-01-14 14:40:11 +01:00
Leo Lamprecht
68562d9f6f Added api option to local config (#1069)
* Always load local config

* Ensure local path can be specified by flag

* Respect path properly

* Catch more

* Stop catching

* Catch better
2018-01-14 14:40:04 +01:00
Igor Klopov
e2eb3180c1 Fix absent deployment for alias (#1063)
* fix absent deployment for alias

* deploymentDeletedStub and fix in row composition
2018-01-14 14:39:56 +01:00
Tim Neutkens
a6af5c8696 Error explanation for unauthorized domain access (#1059) 2018-01-14 14:39:51 +01:00
Olli Vanhoja
c4969b17dd Add an example of adding a CAA record (#1062) 2018-01-14 14:39:45 +01:00
Tim Neutkens
0d8b4a8386 Catch path alias scaling (#1057)
* Catch path alias scaling

* Better wording

* Fix grammar mistake
2018-01-14 14:39:39 +01:00
Leo Lamprecht
9bf7963f01 10.0.0-canary.6 2018-01-14 12:11:01 +01:00
Leo Lamprecht
28069beddc Properly error on wrong token and handle team (#1073)
* Properly error on wrong token and handle team

* Better wording
2018-01-14 12:08:26 +01:00
Leo Lamprecht
b25af90e99 Ignore npm lockfile 2018-01-13 20:19:39 +01:00
Leo Lamprecht
7258da68a8 10.0.0-canary.5 2018-01-12 20:29:48 +01:00
Gillian
17cb604161 Changed error message to match correct command (#1071) 2018-01-12 19:15:09 +01:00
Leo Lamprecht
4d31dd23fd 10.0.0-canary.4 2018-01-12 12:22:23 +01:00
Leo Lamprecht
1898fe813e Use package for checking for updates (#1070)
* Use package for checking for updates

* Set dep for dev
2018-01-12 12:21:34 +01:00
Leo Lamprecht
7d85470634 Removed triangle from company name 2018-01-12 10:27:11 +01:00
Leo Lamprecht
37d0584a30 10.0.0-canary.3 2018-01-11 23:46:46 +01:00
Leo Lamprecht
59598e529b Properly detect API property
This is a hotfix!
2018-01-11 23:46:28 +01:00
Leo Lamprecht
de9c1ca9a9 10.0.0-canary.2 2018-01-11 23:11:27 +01:00
Leo Lamprecht
1c131f2f25 Added api option to local config (#1069)
* Always load local config

* Ensure local path can be specified by flag

* Respect path properly

* Catch more

* Stop catching

* Catch better
2018-01-11 23:08:39 +01:00
Leo Lamprecht
c608435e32 10.0.0-canary.1 2018-01-10 12:04:28 +01:00
Igor Klopov
78d7c5cef5 Fix absent deployment for alias (#1063)
* fix absent deployment for alias

* deploymentDeletedStub and fix in row composition
2018-01-08 18:01:58 +01:00
Tim Neutkens
f2c5230424 Error explanation for unauthorized domain access (#1059) 2018-01-08 18:01:36 +01:00
Olli Vanhoja
b4636ca7ef Add an example of adding a CAA record (#1062) 2018-01-06 15:21:17 +01:00
Tim Neutkens
a357e21bb6 Catch path alias scaling (#1057)
* Catch path alias scaling

* Better wording

* Fix grammar mistake
2018-01-03 20:52:27 +01:00
Leo Lamprecht
c93eed08fc 9.0.1 2017-12-22 12:15:40 +01:00
Leo Lamprecht
33e7e410d2 Improved usage information 2017-12-22 12:15:34 +01:00
Leo Lamprecht
7811824a2c Corrected company name in license 2017-12-22 12:15:30 +01:00
Leo Lamprecht
d6bd77b903 9.0.0-canary.25 2017-12-22 12:12:41 +01:00
Leo Lamprecht
b36b970006 Improved usage information 2017-12-22 12:12:06 +01:00
Leo Lamprecht
f8969d2561 Corrected company name in license 2017-12-22 12:06:44 +01:00
Leo Lamprecht
132eabf450 9.0.0 2017-12-21 19:21:30 +01:00
Guillermo Rauch
ae1db0097e Overhauled deployment events and logs (#993)
* add jsonlines dep

* overhauled deployment events and logs output

* suppress http2 warnings

* make wait cancelation idempotent

* improve debugging and event fetching

* include node `--no-warnings` to avoid http2 warnings

* improve instrumentation

* log with info helper

* more consistent output
2017-12-21 17:07:36 +01:00
Leo Lamprecht
d0d8f11e15 Bumped lockfile 2017-12-21 16:43:06 +01:00
tripott
05ea32fea1 Fixed typo in project configuration docs (#1049) 2017-12-21 16:37:14 +01:00
Leo Lamprecht
8bb187f01e Improved error messages (#1048)
* Improved error messages

* Removed weird messages
2017-12-21 16:37:08 +01:00
Olli Vanhoja
9f18f60fc8 Optimized the deployment process (#1028)
The do..while loop causes event handlers to be registered
multiple times in case of an error occurs while creating a
deployment after uploading missing files. The loop doesn't
save nothing more than one call to `now.create()`.
2017-12-21 16:37:01 +01:00
Nathan Rajlich
c8e20a4038 Simplify the env parsing logic (#1046)
* Simplify the `env` parsing logic

This should be 100% backwards compatible with the previous
behavior, but with some new additions:

 * When using an Array in `package.json:now.env` or `now.json:env`, you
   may specify the value or secret name after an `=` sign (before, the
   entire string was attempted to be the env var key name, which was
   just wrong _(this is the main "fix")_.
 * Specifying `null` as the value of an env var in an Object forces the
   user prompt (before, this was only possibly by using an Array without
   an `=` sign).
 * You may specify an env var on the CLI without an `=` sign and it will
   show the user prompt (kind of silly since the user is invoking the
   command anyways, but this works due to the new normalization)
 * Less converting the env between Array and Object representations.

The code is also simpler to read now, and a few helpful comments added
as well.

* fix `now -e MY_SHELL_VAR` inheriting from user's env
2017-12-21 16:36:56 +01:00
Yuri Yakovlev
ef9c3c9c1f Exit with correct status code (#1045) 2017-12-21 16:36:40 +01:00
Nathan Rajlich
e60e8ddc6b Reject Errors properly in now logs -f (#1041) 2017-12-21 16:36:26 +01:00
Nathan Rajlich
fd4c1dea76 Remove --base64 argument from now secret add (#1033)
It's been broken on the server-side for quite a while now,
and on top of that it's never been clear as to *how* you
get the binary value back out from within the deployment.

For these reasons, let's get rid of the option altogether.

Users who need to encode binary data as the secret value
should encode to base64 manually. For example:

```
$ now secret add my-secret $(echo 'foo' | base64)
```
2017-12-21 16:36:01 +01:00
Nathan Rajlich
243ca1e06a Return an empty object early when nothing to prompt (#1032)
* Return an empty object early when nothing to prompt

So that the `console.log()` a few lines down does
not get invoked

* Use `Object.keys()` to iterate over the answers
2017-12-21 16:35:54 +01:00
Olli Vanhoja
6456b00441 Sort certs by root domain (#1030)
Instead of sorting cert CNs by the full domain we should sort them
by the root domain to group all likely related certs together.
2017-12-21 16:35:48 +01:00
Nathan Rajlich
5b17f5f08b Do not reference newTeam when switching to user scope (#1029)
Fixes error:

    $ now switch tootallnate
    > Error! An unexpected error occurred in switch: TypeError: Cannot read property 'slug' of undefined
        at module.exports (/snapshot/now-cli/dist/now.js:2995:81)
        at <anonymous>
        at process._tickCallback (internal/process/next_tick.js:188:7)
2017-12-21 16:35:42 +01:00
Leo Lamprecht
dd4df0ba4c Upgrade Node.js to the latest version (#1025) 2017-12-21 16:35:36 +01:00
Olli Vanhoja
699752f631 Improve domain removal UX (#1022)
- Don't prefix the domain with https as it may not be even using
  https nor have any records
- Don't show domain ID after the domain is removed as it has no
  meaning for cli users
2017-12-21 16:35:30 +01:00
Nathan Rajlich
a31f88848d Pluralize words automatically (#1024)
* use `pluralize` module

Instead of manually formatting these singular vs. plural cases.

Note that `util/alias.js` was previously incorrectly always printing as
plural, which is what let me down this rabbit hole in the first place.

* Bumped pkg version

* Downgrade node temporarily
2017-12-21 16:35:16 +01:00
Leo Lamprecht
065c9363f9 9.0.0-canary.24 2017-12-20 22:37:37 +01:00
tripott
c47302b2aa Fixed typo in project configuration docs (#1049) 2017-12-20 21:56:15 +01:00
Leo Lamprecht
7274d41b43 9.0.0-canary.23 2017-12-20 21:40:39 +01:00
Leo Lamprecht
3f306a1bfb Improved error messages (#1048)
* Improved error messages

* Removed weird messages
2017-12-20 21:36:37 +01:00
Leo Lamprecht
c9f5d4286b 9.0.0-canary.22 2017-12-20 19:15:13 +01:00
Olli Vanhoja
75be1ebc9c Optimized the deployment process (#1028)
The do..while loop causes event handlers to be registered
multiple times in case of an error occurs while creating a
deployment after uploading missing files. The loop doesn't
save nothing more than one call to `now.create()`.
2017-12-20 19:13:41 +01:00
Nathan Rajlich
7c3b2da48c Simplify the env parsing logic (#1046)
* Simplify the `env` parsing logic

This should be 100% backwards compatible with the previous
behavior, but with some new additions:

 * When using an Array in `package.json:now.env` or `now.json:env`, you
   may specify the value or secret name after an `=` sign (before, the
   entire string was attempted to be the env var key name, which was
   just wrong _(this is the main "fix")_.
 * Specifying `null` as the value of an env var in an Object forces the
   user prompt (before, this was only possibly by using an Array without
   an `=` sign).
 * You may specify an env var on the CLI without an `=` sign and it will
   show the user prompt (kind of silly since the user is invoking the
   command anyways, but this works due to the new normalization)
 * Less converting the env between Array and Object representations.

The code is also simpler to read now, and a few helpful comments added
as well.

* fix `now -e MY_SHELL_VAR` inheriting from user's env
2017-12-20 18:59:38 +01:00
Leo Lamprecht
c70a645516 9.0.0-canary.21 2017-12-19 13:24:52 +01:00
Yuri Yakovlev
c580d55be7 Exit with correct status code (#1045) 2017-12-19 13:23:47 +01:00
Nathan Rajlich
caa7ef61ec Reject Errors properly in now logs -f (#1041) 2017-12-15 09:11:52 +01:00
Leo Lamprecht
65dbb158ce 9.0.0-canary.20 2017-12-11 11:31:46 +01:00
Nathan Rajlich
5463e8b5d8 Remove --base64 argument from now secret add (#1033)
It's been broken on the server-side for quite a while now,
and on top of that it's never been clear as to *how* you
get the binary value back out from within the deployment.

For these reasons, let's get rid of the option altogether.

Users who need to encode binary data as the secret value
should encode to base64 manually. For example:

```
$ now secret add my-secret $(echo 'foo' | base64)
```
2017-12-11 11:29:59 +01:00
Nathan Rajlich
a63123e206 Return an empty object early when nothing to prompt (#1032)
* Return an empty object early when nothing to prompt

So that the `console.log()` a few lines down does
not get invoked

* Use `Object.keys()` to iterate over the answers
2017-12-08 21:31:53 +01:00
Olli Vanhoja
846c02c9e4 Sort certs by root domain (#1030)
Instead of sorting cert CNs by the full domain we should sort them
by the root domain to group all likely related certs together.
2017-12-08 18:32:50 +01:00
Nathan Rajlich
101b728d9b Do not reference newTeam when switching to user scope (#1029)
Fixes error:

    $ now switch tootallnate
    > Error! An unexpected error occurred in switch: TypeError: Cannot read property 'slug' of undefined
        at module.exports (/snapshot/now-cli/dist/now.js:2995:81)
        at <anonymous>
        at process._tickCallback (internal/process/next_tick.js:188:7)
2017-12-07 11:57:21 -08:00
Leo Lamprecht
63514669ea 9.0.0-canary.19 2017-12-06 23:33:22 +01:00
Leo Lamprecht
44397246bc Upgrade Node.js to the latest version (#1025) 2017-12-06 23:32:13 +01:00
Olli Vanhoja
d9a58fc8ce Improve domain removal UX (#1022)
- Don't prefix the domain with https as it may not be even using
  https nor have any records
- Don't show domain ID after the domain is removed as it has no
  meaning for cli users
2017-12-06 23:03:21 +01:00
Nathan Rajlich
57943d0f0a Pluralize words automatically (#1024)
* use `pluralize` module

Instead of manually formatting these singular vs. plural cases.

Note that `util/alias.js` was previously incorrectly always printing as
plural, which is what let me down this rabbit hole in the first place.

* Bumped pkg version

* Downgrade node temporarily
2017-12-06 23:02:41 +01:00
Leo Lamprecht
a6ceb44a5c 9.0.0-canary.18 2017-11-28 00:09:08 +01:00
Matheus Fernandes
bbc1b509f0 If quiet, be quiet 2017-11-22 17:58:12 -08:00
Matheus Fernandes
8936a1bf42 8.5.4 2017-11-22 17:28:24 -08:00
Matheus Fernandes
abc70e8558 If quiet, be quiet 2017-11-22 17:27:44 -08:00
Leo Lamprecht
c9c68b561c 8.5.3 2017-11-23 01:39:56 +01:00
Melvin
c6c64a1953 Only make global auth file readable/writable by owner (#1001) 2017-11-23 01:26:08 +01:00
Seth Holladay
bcce2c5ffc Overhaul JSON reading, parsing, and writing (#899)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Overhaul JSON loading and parsing

Reading JSON files from disk is now simpler, with clearer error messages.

Fixes #893

* More robust JSON writing

Make directories if needed and write to disk atomically.

* Remove unused import

* Escape @ in MX record example (#900)

* Pinned dependencies
2017-11-23 01:25:38 +01:00
Matheus Fernandes
058a30aec3 Made now switch and now logs -f work properly (#1003)
* Add missing `console.log`s

* Bubble the exit code correctly

* Clear the "final answer" output from inquirer on `now switch`

* Add more missing `console.log` :(

* Add the team slug to the success message

* Adjust `now log -f` to work with the new exit logic
2017-11-23 01:23:41 +01:00
Guillermo Rauch
7ba73f909c Fix deployments with no now.json file (#999) 2017-11-23 01:21:16 +01:00
Leo Lamprecht
90db214ac1 9.0.0-canary.17 2017-11-23 01:10:44 +01:00
Matheus Fernandes
887b625114 Made now switch and now logs -f work properly (#1003)
* Add missing `console.log`s

* Bubble the exit code correctly

* Clear the "final answer" output from inquirer on `now switch`

* Add more missing `console.log` :(

* Add the team slug to the success message

* Adjust `now log -f` to work with the new exit logic
2017-11-23 01:07:52 +01:00
Melvin
260aa944d5 Only make global auth file readable/writable by owner (#1001) 2017-11-22 11:27:08 +01:00
Guillermo Rauch
aa25de5cf8 Fix unexpected err message (#1000)
* fix deployments with no `now.json`

* improved global error handler
2017-11-21 16:56:19 -08:00
Guillermo Rauch
4ee4dd3645 Fix unexpected err message (#1000)
* fix deployments with no `now.json`

* improved global error handler
2017-11-21 16:52:22 -08:00
Leo Lamprecht
acf1ae9771 9.0.0-canary.16 2017-11-21 18:04:16 +01:00
Guillermo Rauch
42c6d6b52b Fix deployments with no now.json file (#999) 2017-11-21 18:03:54 +01:00
Leo Lamprecht
32384c847f 9.0.0-canary.15 2017-11-20 11:17:23 +01:00
Leo Lamprecht
15b8f857f0 8.5.2 2017-11-20 11:14:54 +01:00
Sebastian Richter
ef9862cbfb Better error message for missing gcp property (#997)
* Better error message

Better error message when "gcp" property is missing in now.json

* Make sure gcpConfig is defined

* Replaced destructor
2017-11-20 11:13:15 +01:00
George Tsiolis
21251548a7 Prevent trailing link character consumption by some terminals (#990)
* fix: broken link in missing `start` script error

* fix: removed trailing dot in error message
2017-11-20 11:13:02 +01:00
Nathan Rajlich
83fe413b96 Fix location of credentials files on error page (#995) 2017-11-20 11:11:23 +01:00
Nathan Rajlich
9a018b41cd Add "No Open Port Found" error page (#994) 2017-11-20 11:11:19 +01:00
Guillermo Rauch
2804bedab6 Overhauled deployment events and logs (#993)
* add jsonlines dep

* overhauled deployment events and logs output

* suppress http2 warnings

* make wait cancelation idempotent

* improve debugging and event fetching

* include node `--no-warnings` to avoid http2 warnings

* improve instrumentation

* log with info helper

* more consistent output
2017-11-20 11:06:02 +01:00
Sebastian Richter
934d159bc8 Better error message for missing gcp property (#997)
* Better error message

Better error message when "gcp" property is missing in now.json

* Make sure gcpConfig is defined

* Replaced destructor
2017-11-20 11:04:22 +01:00
Nathan Rajlich
dc4327e883 Fix location of credentials files on error page (#995) 2017-11-18 17:02:18 -08:00
Nathan Rajlich
0826958221 Add "No Open Port Found" error page (#994) 2017-11-18 16:54:17 -08:00
Graham Kaemmer
401f503d43 Add option to append 'https://' to deployment URL in now list (#991)
* Add option to append 'https://' to deployment URL in now list (#800)

* Rename includeProtocol -> includeScheme
2017-11-17 09:18:06 -08:00
George Tsiolis
75c6bcb291 Prevent trailing link character consumption by some terminals (#990)
* fix: broken link in missing `start` script error

* fix: removed trailing dot in error message
2017-11-17 02:37:18 -08:00
Leo Lamprecht
92c561af9b 9.0.0-canary.14 2017-11-13 22:34:05 +01:00
Leo Lamprecht
0a2f38b424 Hide debugging line in now deploy 2017-11-13 22:33:47 +01:00
Leo Lamprecht
77d2bcc119 8.5.1 2017-11-13 22:28:54 +01:00
Leo Lamprecht
555d0538e8 Hide debugging line in now deploy 2017-11-13 22:26:52 +01:00
Leo Lamprecht
4c619ecb6c 8.5.0 2017-11-13 21:41:38 +01:00
Leo Lamprecht
9c74c887c3 Bumped lockfile 2017-11-13 21:33:49 +01:00
Leo Lamprecht
33d7a02297 Fixed package description 2017-11-13 21:26:07 +01:00
Pranay Prakash
3dd2752b63 Only load the http2 module if HTTP/2 is enabled (#987)
* hide fetch-h2 import behind flag

* Removed semicolons
2017-11-13 21:20:29 +01:00
Leo Lamprecht
81b86c0798 9.0.0-canary.13 2017-11-13 21:18:48 +01:00
Pranay Prakash
d370205fda Only load the http2 module if HTTP/2 is enabled (#987)
* hide fetch-h2 import behind flag

* Removed semicolons
2017-11-13 21:18:03 +01:00
Igor Klopov
388e235d01 Made installation work on Git Bash (#986)
* look in APPDATA directory if not found in Program Files

* modifyGitBashFile to replace "now "with "now.exe"

* fix npm rm -g now

* fix fetch-h2 dep version
2017-11-13 20:12:07 +01:00
Josh Junon
529fb33f3b add explicit build script 2017-11-13 20:08:07 +01:00
Joe Lim
45874fe1ce Improve nameserver error message (#984) 2017-11-13 20:07:56 +01:00
Josh Junon
01334ea74e Improve wording of GCP login message 2017-11-13 20:06:36 +01:00
Naoyuki Kanezawa
7f86e54675 Add error handling to login command (#974)
* add error handling on login command

* fix error message
2017-11-13 20:06:30 +01:00
Leo Lamprecht
b86368a49f Removed useless keyword 2017-11-13 20:06:17 +01:00
Joe Lim
63f88b66eb Show login window message for GCP (#982) 2017-11-13 20:05:59 +01:00
Matheus Fernandes
148673057d Set the host header when using http2 2017-11-13 20:04:12 +01:00
Matheus Fernandes
2ce875df79 Bump fetch-h2 2017-11-13 20:03:58 +01:00
Josh Junon
9a705f6c85 improve api v2 support 2017-11-13 20:03:49 +01:00
Leo Lamprecht
8097f53aab Ensure that update message shows up (#971) 2017-11-13 20:03:34 +01:00
Leo Lamprecht
e04aa38dc2 Fixes inconsistency with flag for API URL (#968)
* Fixed inconsistency with API flag

* Accept config key

* Moved to earlier position
2017-11-13 20:02:25 +01:00
Olli Vanhoja
ba0e5bd131 Use the new deployment removal API (#966) 2017-11-13 20:02:12 +01:00
Olli Vanhoja
0afd40f47c Use v2 API to get a deployments list (#967) 2017-11-13 20:02:07 +01:00
Olli Vanhoja
5124f3d1bc Removed useless header from API requests (#964) 2017-11-13 20:02:00 +01:00
Leo Lamprecht
aa461b564d Start using Node.js 9.0.0 with PKG 2017-11-13 20:01:34 +01:00
Pranay Prakash
c68fed4fc5 Added support for HTTP/2 (#953)
* first working version

* implemented socket switching at socket request limit

* Use http2 only on canary

* fix typo
2017-11-13 19:59:55 +01:00
Leo Lamprecht
6f7ffafdc7 9.0.0-canary.12 2017-11-13 19:15:43 +01:00
Leo Lamprecht
2c3808ce77 Bumped lockfile 2017-11-13 19:13:37 +01:00
Igor Klopov
7774d7d72a Made installation work on Git Bash (#986)
* look in APPDATA directory if not found in Program Files

* modifyGitBashFile to replace "now "with "now.exe"

* fix npm rm -g now

* fix fetch-h2 dep version
2017-11-13 18:57:17 +01:00
Josh Junon
b3cd68bbb3 add explicit build script 2017-11-11 23:09:08 -08:00
Joe Lim
d69435c93f Improve nameserver error message (#984) 2017-11-10 23:09:03 -08:00
Josh Junon
b052388050 Improve wording of GCP login message 2017-11-10 11:56:37 -08:00
Leo Lamprecht
39566519e4 9.0.0-canary.11 2017-11-10 20:41:18 +01:00
Naoyuki Kanezawa
2d08379f87 Add error handling to login command (#974)
* add error handling on login command

* fix error message
2017-11-10 20:40:41 +01:00
Joe Lim
68a0332fce Show login window message for GCP (#982) 2017-11-10 20:39:47 +01:00
Matheus Fernandes
41f58d27db 9.0.0-canary.10 2017-11-09 12:27:46 +00:00
Matheus Fernandes
1047edd986 Set the host header when using http2 2017-11-09 12:27:11 +00:00
Matheus Fernandes
611401e2e1 Bump fetch-h2 2017-11-09 12:27:11 +00:00
Matheus Fernandes
853760b8c6 Revert "Temporarily disable HTTP2 when talking with now-bru's API (#973)"
This reverts commit cfcd6005ff.
2017-11-09 12:27:10 +00:00
Josh Junon
97d6604691 improve api v2 support 2017-11-08 19:33:40 -08:00
Matheus Fernandes
cfcd6005ff Temporarily disable HTTP2 when talking with now-bru's API (#973) 2017-11-09 00:51:53 +01:00
Leo Lamprecht
b06ef97ec8 9.0.0-canary.9 2017-11-07 22:05:10 +01:00
Leo Lamprecht
e6e92a27b4 Ensure that update message shows up (#971) 2017-11-07 12:57:04 -08:00
Leo Lamprecht
aeaf03a420 9.0.0-canary.8 2017-11-07 17:50:00 +01:00
Leo Lamprecht
826f983fb0 Removed useless keyword 2017-11-07 17:48:51 +01:00
Leo Lamprecht
12cbf0c0b8 Fixes inconsistency with flag for API URL (#968)
* Fixed inconsistency with API flag

* Accept config key

* Moved to earlier position
2017-11-07 17:34:12 +01:00
Olli Vanhoja
66e70c8074 Use the new deployment removal API (#966) 2017-11-06 22:56:43 +01:00
Olli Vanhoja
35eeeba9b4 Use v2 API to get a deployments list (#967) 2017-11-06 22:55:49 +01:00
Olli Vanhoja
eef37799b7 Removed useless header from API requests (#964) 2017-11-06 10:15:58 +01:00
Leo Lamprecht
0c4e00bb1b 8.4.0 2017-11-05 20:47:16 +01:00
Leo Lamprecht
45cb08e925 Bumped lockfile 2017-11-05 20:43:08 +01:00
Pranay Prakash
9a78e75466 Faster array-unique implementation (#933)
* faster unique implementation

* use my own arrayUnique implementation

* forgot to remove the extra array access
2017-11-05 20:41:17 +01:00
Leo Lamprecht
7b656d4ad4 Channel-specific Travis CI config 2017-11-05 20:34:17 +01:00
Leo Lamprecht
57ad585bed 9.0.0-canary.7 2017-11-05 19:39:51 +01:00
Leo Lamprecht
b5af6276e1 Start using Node.js 9.0.0 with PKG 2017-11-05 19:36:06 +01:00
Leo Lamprecht
fe5231a665 Canary-specific Travis CI config 2017-11-05 19:33:26 +01:00
Guillermo Rauch
450d2098e7 Fix zeit.world DNS examples list (#959)
* fix DNS examples list

* Update errors.js
2017-10-31 22:44:18 +01:00
Pranay Prakash
472d1ffab0 Added support for HTTP/2 (#953)
* first working version

* implemented socket switching at socket request limit

* Use http2 only on canary

* fix typo
2017-10-31 11:41:16 +01:00
Leo Lamprecht
861b2a5f3b 9.0.0-canary.6 2017-10-30 14:50:37 +01:00
Olli Vanhoja
bdb360704b Fixed zeit.world nameservers check (#954)
Instead of checking if the nameservers are from a known list we
can just check that every nameserver set for the domain ends with
.zeit.world.
2017-10-30 14:47:33 +01:00
Leo Lamprecht
3b9c861269 8.3.12 2017-10-30 14:46:09 +01:00
Vitor Capretz
90e2f4b6f5 Added validation for .ws domains (#935)
as in #365, ZEIT.world currently doesn't support .ws domains
and user should receive a notice when adding aliases or adding domains
2017-10-30 14:42:17 +01:00
Felix Yan
d7b0c3b303 Fixed a few comment typos (#947) 2017-10-30 14:41:35 +01:00
Matt Keas
1dbbbbb085 Fixes runtime issues with a type and some missing require statements (#946)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Ensure that `now logout` revokes the token (#920)

* 8.3.10

* instead of opening url with xdg-open (which is causing #911), print the URL for the user to open or click, as diff versions of xdg-open may be needed on various linux distros and opn has some issues within pkg.

* adds check for the platform, uses opn on windows/mac and just prints out URL for linux

* fixed runtime issues
2017-10-30 14:40:41 +01:00
Ryan Tsao
a6a7627c90 Wait until deployment is ready before exiting (#940) 2017-10-30 14:40:25 +01:00
Leo Lamprecht
20e9906d18 Corrected deployment to npm 2017-10-30 14:39:59 +01:00
Pranay Prakash
01dadf2d8d Exclude _fixtures from eslint (#928) 2017-10-30 14:38:43 +01:00
Olli Vanhoja
e524770fb7 Fixed zeit.world nameservers check (#954)
Instead of checking if the nameservers are from a known list we
can just check that every nameserver set for the domain ends with
.zeit.world.
2017-10-30 14:33:56 +01:00
Leo Lamprecht
8d7bae3792 8.3.11 2017-10-30 14:12:09 +01:00
Olli Vanhoja
5713718512 Use second generation of API for creating deployments (#906)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Escape @ in MX record example (#900)

* Remove duplication of deployment complete print out

* Use v2 now API

v2 API requires the client to upload files before creating a
deployment.
2017-10-30 14:10:48 +01:00
Olli Vanhoja
0a8f602644 Ignore DNS record conflict on aliasing (#924)
Conflicting record is just the right record in most of the cases
and in other cases altering the record would break something
explicitly setup by the user.
2017-10-30 14:10:18 +01:00
Matt Keas
128b2b7faa Get now gcp login working on various linux distros again (#944)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Ensure that `now logout` revokes the token (#920)

* 8.3.10

* instead of opening url with xdg-open (which is causing #911), print the URL for the user to open or click, as diff versions of xdg-open may be needed on various linux distros and opn has some issues within pkg.

* adds check for the platform, uses opn on windows/mac and just prints out URL for linux
2017-10-30 14:08:43 +01:00
Sergio Xalambrí
871b56ee42 Fix DNS record typo (#929) 2017-10-30 14:08:31 +01:00
Leo Lamprecht
6cd5308725 Only output error slug if it's available (#939) 2017-10-30 14:05:32 +01:00
Pranay Prakash
8cfe55b400 Add comments about new array-unique implementation (#948)
* Add comments about new array-unique implementation

* fix typo
2017-10-25 23:27:25 +02:00
Felix Yan
c49ba28bbf Fixed a few comment typos (#947) 2017-10-25 20:25:09 +02:00
Matt Keas
82112c79d6 Fixes runtime issues with a type and some missing require statements (#946)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Ensure that `now logout` revokes the token (#920)

* 8.3.10

* instead of opening url with xdg-open (which is causing #911), print the URL for the user to open or click, as diff versions of xdg-open may be needed on various linux distros and opn has some issues within pkg.

* adds check for the platform, uses opn on windows/mac and just prints out URL for linux

* fixed runtime issues
2017-10-21 00:45:09 +02:00
Matt Keas
d30dcf4db7 Get now gcp login working on various linux distros again (#944)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Ensure that `now logout` revokes the token (#920)

* 8.3.10

* instead of opening url with xdg-open (which is causing #911), print the URL for the user to open or click, as diff versions of xdg-open may be needed on various linux distros and opn has some issues within pkg.

* adds check for the platform, uses opn on windows/mac and just prints out URL for linux
2017-10-20 23:58:47 +02:00
Leo Lamprecht
9fc096d2d5 9.0.0-canary.5 2017-10-20 14:41:08 +02:00
Leo Lamprecht
8a6f967032 Bumped lockfile 2017-10-20 14:40:55 +02:00
Sergio Xalambrí
6a35a8b84a Fix DNS record typo (#929) 2017-10-20 14:39:11 +02:00
Ryan Tsao
336427afda Wait until deployment is ready before exiting (#940) 2017-10-20 14:34:59 +02:00
Leo Lamprecht
4444ca712a Fixed issues with code style 2017-10-20 01:03:36 +02:00
Pranay Prakash
ba1f96a1fd Faster array-unique implementation (#933)
* faster unique implementation

* use my own arrayUnique implementation

* forgot to remove the extra array access
2017-10-20 00:59:06 +02:00
Leo Lamprecht
697fd8b7c9 Only output error slug if it's available (#939) 2017-10-20 00:49:09 +02:00
Vitor Capretz
74951214e3 Added domain validation to the alias being set (#936)
Added domain validation to the alias being set
2017-10-16 18:07:01 +02:00
Vitor Capretz
35c6e89b4a Added validation for .ws domains (#935)
as in #365, ZEIT.world currently doesn't support .ws domains
and user should receive a notice when adding aliases or adding domains
2017-10-16 10:50:18 +02:00
Pranay Prakash
3aa19d366a Exclude _fixtures from eslint (#928) 2017-10-12 23:53:16 +02:00
Leo Lamprecht
b369779321 9.0.0-canary.4 2017-10-12 00:44:34 +02:00
Olli Vanhoja
da923fa879 Ignore DNS record conflict on aliasing (#924)
Conflicting record is just the right record in most of the cases
and in other cases altering the record would break something
explicitly setup by the user.
2017-10-12 00:41:09 +02:00
Leo Lamprecht
94952c0bd0 Even more bullet proof conditions 2017-10-11 22:48:20 +02:00
Leo Lamprecht
a4f012e5a6 Make sure to install dependencies on CI 2017-10-11 22:34:06 +02:00
Leo Lamprecht
5abf1dfb94 Use custom clone of repository on CI 2017-10-11 22:31:20 +02:00
Leo Lamprecht
0ca7d1fe44 9.0.0-canary.3 2017-10-09 18:21:18 +02:00
Leo Lamprecht
8083740804 Ensured correct arguments order
This closes #909
2017-10-09 18:20:04 +02:00
Leo Lamprecht
fd68ad8a79 Removed accidental echo output 2017-10-09 18:07:09 +02:00
Leo Lamprecht
d4714b05eb Check for tag correctly 2017-10-09 17:59:53 +02:00
Leo Lamprecht
48d76a734a Properly check for current branch on CI 2017-10-09 17:51:48 +02:00
Leo Lamprecht
9ce5ae8d95 9.0.0-canary.2 2017-10-09 17:35:26 +02:00
Leo Lamprecht
0b9bc73521 Ensure that now logout revokes the token (#920) 2017-10-09 17:34:18 +02:00
Leo Lamprecht
d8b559d952 8.3.10 2017-10-09 17:30:11 +02:00
Leo Lamprecht
ee4d441543 Ensure that now logout revokes the token (#920) 2017-10-09 17:29:45 +02:00
Leo Lamprecht
e91d767186 Removed deprecated Babel preset (#919)
* Removed deprecated Babel preset

* Fixed dependencies
2017-10-09 17:20:34 +02:00
Seth Holladay
3f0b06a642 Overhaul JSON reading, parsing, and writing (#899)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Overhaul JSON loading and parsing

Reading JSON files from disk is now simpler, with clearer error messages.

Fixes #893

* More robust JSON writing

Make directories if needed and write to disk atomically.

* Remove unused import

* Escape @ in MX record example (#900)

* Pinned dependencies
2017-10-09 16:48:13 +02:00
Olli Vanhoja
4338c6a205 Use second generation of API for creating deployments (#906)
* Fix `now alias` for domains without DNS records (#898)

* 8.3.9

* Escape @ in MX record example (#900)

* Remove duplication of deployment complete print out

* Use v2 now API

v2 API requires the client to upload files before creating a
deployment.
2017-10-09 16:15:37 +02:00
Matheus Fernandes
935fd58fd9 8.3.9 2017-09-29 00:31:33 +02:00
Matheus Fernandes
0d806f95ce Fix now alias for domains without DNS records (#898) 2017-09-29 00:31:08 +02:00
Leo Lamprecht
01b7f35845 Check for deployment conditions correctly (#897) 2017-09-28 12:06:47 +02:00
Leo Lamprecht
50194b30ae 9.0.0-canary.1 2017-09-28 11:37:55 +02:00
Leo Lamprecht
b0a3e92416 Tag canary releases properly on npm (#896) 2017-09-28 11:27:20 +02:00
Leo Lamprecht
03bb490673 Bumped dependencies to the latest version (#895) 2017-09-28 11:19:25 +02:00
Leo Lamprecht
7e02ca947e 8.3.8 2017-09-28 11:10:21 +02:00
Nathan Rajlich
592b4c71aa Do not consider deployment name in now scale (#874)
Consider a deployment with an app name that matches the
alias URL. Rather than matching what deployment the alias
points to, we would match the first deployment where that
name equals the alias doman name, which is not correct.
2017-09-28 11:05:12 +02:00
Nathan Rajlich
42b88df32f Do not print the fetch error when now alias validation fails (#894) 2017-09-28 11:01:52 +02:00
Nathan Rajlich
ab8bd45ca2 fix whitespace issue when deploying a remote repo 2017-09-27 23:56:54 +02:00
Leo Lamprecht
1a6a3f854c Removed slackup in favor of upcoming canary builds (#889) 2017-09-26 15:37:20 +02:00
Leo Lamprecht
923a6de903 8.3.7 2017-09-26 13:30:32 +02:00
Jon Babsvik
4861177900 Updated now ls -h to include the --all flag (#888) 2017-09-26 12:22:08 +02:00
Olli Vanhoja
ce36c4d507 Simplify domain DNS record validation (#885)
Instead of trying to figure out whether a custom domain resolves
to a certain IP address we could just try to make a `HEAD` request
and check the `Server` header in the response. This change will
make the cli ready for anycast DNS that may resolve to any
location.
2017-09-26 00:12:03 +02:00
Olli Vanhoja
f0655e785e Removed the -F flag (#886) 2017-09-26 00:05:13 +02:00
Leo Lamprecht
af697e5715 8.3.6 2017-09-22 23:41:38 +02:00
Igor Klopov
8b06b0b302 Let it show n/a instead of 17k days (#877) 2017-09-22 23:41:09 +02:00
Matheus Fernandes
72265c49c6 Add missing console.log 2017-09-22 23:35:34 +02:00
Leo Lamprecht
56a5adeb3a Renamed "now CLI" to "Now CLI" 2017-09-19 23:29:35 +02:00
Matheus Fernandes
b339fcb309 8.3.5 2017-09-19 04:34:31 +02:00
Matheus Fernandes
b033558aeb Add missing console.log 2017-09-19 01:55:28 +02:00
Matheus Fernandes
8c83b52b1a Fix method on log 2017-09-19 01:54:58 +02:00
Matheus Fernandes
cce5bfad82 Add missing console.log 2017-09-19 01:37:37 +02:00
Leo Lamprecht
0ae01581cc Fixed a typo in an error 2017-09-17 17:47:44 +02:00
Leo Lamprecht
a02d7012be 8.3.4 2017-09-17 17:26:21 +02:00
Leo Lamprecht
2a0d4555dc Added links to the errors (#869)
* Added two example error links

* More messages added

* Even more cool stuff

* Removed useless assignments

* Weird stuff removed

* Fixed exiting

* Added missing space

* Added another error message
2017-09-17 17:24:22 +02:00
Leo Lamprecht
0b1acc13a8 8.3.3 2017-09-17 00:52:31 +02:00
Joe Haddad
9e9f53fd64 Ensure retrying GCP deployments (#862) 2017-09-17 00:50:24 +02:00
Sergio Xalambrí
75c2b86e48 Brought Git deployments back to live (#867)
* Remove the hack

That hack removed the path user/repo from argv

* Use rawPath instead of path

With path it's going to always pass that try, we need to check the the rawPath is valid not the path

* Make GH, relative path and current path deployments work

* Remove semicolon
2017-09-17 00:01:54 +02:00
Leo Lamprecht
fad6109cf2 Corrected deployment type example (#864) 2017-09-16 15:59:26 +02:00
Leo Lamprecht
d888e59af2 8.3.2 2017-09-15 19:58:49 +02:00
Leo Lamprecht
8dd0cf7e58 Removed redundant check 2017-09-15 19:58:40 +02:00
Leo Lamprecht
cef988b078 Made --team accept the username (#860)
* Made `--team` accept the username

* Only handle value when credentials exist
2017-09-15 19:56:51 +02:00
Leo Lamprecht
0a327e3ae8 Only download team data if it's not cached (#859) 2017-09-15 19:15:13 +02:00
Luke Childs
ac7ae6629a Check if the files config property is an array (#858) 2017-09-15 16:02:19 +02:00
Leo Lamprecht
696f8a20be 8.3.1 2017-09-15 12:16:04 +02:00
Leo Lamprecht
6f56046c2a Allow --token to act without a config file (#855) 2017-09-15 12:12:06 +02:00
Leo Lamprecht
72e8c0be62 8.3.0 2017-09-15 00:18:35 +02:00
Leo Lamprecht
f8c0288bb3 Ability to set team scope using --team flag (#852)
* Fixed linting

* Use `mri` for setting the token

* Ability to set team scope using `--team` flag

* Added correct utils

* Handle 403 errors

* Better 403 error message

* Made it even more bullet proof

* Added to usage information
2017-09-14 23:58:53 +02:00
Leo Lamprecht
734c78f8fc Prevent --token from overwriting the user config (#851)
* Respect currently scoped team

* Allow `--token` to overwrite the config token

* Fixed syntax

* Print an error when switching team
2017-09-14 12:04:30 +02:00
Leo Lamprecht
7a916bd3da Made --local-config work properly (#850) 2017-09-13 22:49:30 +02:00
Matheus Fernandes
da5f1ac3ae Made sure to use the correct output utilities (#841) 2017-09-13 01:02:06 +02:00
Matheus Fernandes
80e1ee829f Fix edge case where --token was being ignored (#840)
* Fix edge case where `--token` was being ignored

* Fix logic
2017-09-12 23:31:42 +02:00
Josh Junon
3874ab76cb 8.2.5 2017-09-12 21:00:54 +02:00
Josh Junon
058fb5334d fix path detection when a path is specified (#839) 2017-09-12 20:53:00 +02:00
Leo Lamprecht
da15ce73f0 8.2.4 2017-09-12 12:36:04 +02:00
Leo Lamprecht
6332196b27 Introduced a much cleaner token name (#837) 2017-09-12 12:28:33 +02:00
Matheus Fernandes
7c5b04b39e 8.2.3 2017-09-11 11:31:57 +02:00
Matheus Fernandes
86deb0a1c6 Fix arguemnt types on now dns add 2017-09-11 11:30:40 +02:00
Leo Lamprecht
00f5d39114 8.2.2 2017-09-09 17:05:43 +02:00
Leo Lamprecht
1af69b9800 Argument parsing in now scale is now more efficient (#835)
* Support IDs on the `now scale` sub command

* Made it even shorter

* Correct usage info

* Fixed syntax
2017-09-09 17:05:21 +02:00
Leo Lamprecht
5670d93877 Made now scale work properly again (#834) 2017-09-09 11:47:26 -03:00
Leo Lamprecht
3bd40ae9c9 Fixed guide on how to install the package (#832) 2017-09-08 15:09:01 -07:00
Leo Lamprecht
c4d9383d86 8.2.1 2017-09-08 23:35:01 +02:00
Leo Lamprecht
17cc5d1630 Replaced minimist with mri (faster and lighter) (#831)
* Cleaned up help for `now scale`

* Made it even better

* Fixed dot notation

* Perfected secrets help

* Cleaned up teams help

* Help for upgrade cmd

* Fixed even more

* Help for login command

* Made output work for command

* Cleaned up domains help

* Cleaned up all remaining commands

* Fixed indentation for alias command

* Missing flag added

* Another missing flag added

* Replaced `minimist` with `mri` (faster and lighter)
2017-09-08 23:25:11 +02:00
Leo Lamprecht
aa4f7d1ccc Cleaned up the usage information (#830)
* Cleaned up help for `now scale`

* Made it even better

* Fixed dot notation

* Perfected secrets help

* Cleaned up teams help

* Help for upgrade cmd

* Fixed even more

* Help for login command

* Made output work for command

* Cleaned up domains help

* Cleaned up all remaining commands

* Fixed indentation for alias command

* Missing flag added

* Another missing flag added

* Fixed help
2017-09-08 23:14:11 +02:00
Leo Lamprecht
1ebb39ff67 Removed not working --login flag from usage information (#826) 2017-09-08 13:52:28 -03:00
Leo Lamprecht
1bfaaea8cb Test installation over npm after deployment (#828) 2017-09-08 13:52:00 -03:00
Leo Lamprecht
b5361468dd Added missing --token flag to now scale sub command (#829) 2017-09-08 13:51:15 -03:00
Leo Lamprecht
9a4cb75151 8.2.0 2017-09-08 13:33:27 +02:00
Leo Lamprecht
4d985b5521 Prevent doubled usage information output (#820)
* Prevent doubled usage information output

* Return instead of exiting without util

* Made it work
2017-09-08 13:26:37 +02:00
Leo Lamprecht
1134f65cda Added new flags for local and global config (#818)
* Added new config flag to usage info

* Different available short names for flags

* Made global config flag work

* Existance of global now dir is already handled

* Made it all work
2017-09-08 13:18:12 +02:00
Leo Lamprecht
daad07abbf Temporarily hide providers from usage information (#819) 2017-09-08 13:14:10 +02:00
Leo Lamprecht
f86f074a80 Corrected flags for now teams sub command (#822) 2017-09-08 13:07:34 +02:00
Leo Lamprecht
ebcc92c879 Revert "Made now whoami return the correct team context" (#824)
* Revert "Deploy on Now if no provider is specified (#821)"

This reverts commit bbb33417ee.

* Revert "Made `now whoami` return the correct team context (#823)"

This reverts commit a9e6e6c247.
2017-09-08 08:03:21 -03:00
Leo Lamprecht
bbb33417ee Deploy on Now if no provider is specified (#821) 2017-09-08 12:58:44 +02:00
Leo Lamprecht
a9e6e6c247 Made now whoami return the correct team context (#823) 2017-09-08 12:34:20 +02:00
Leo Lamprecht
929a14cc84 Don't delete dependencies before deploying 2017-09-06 18:42:54 +02:00
Leo Lamprecht
134056883c 8.1.0 2017-09-06 18:35:16 +02:00
Leo Lamprecht
f0bb4e3cdc Let the CI deploy releases to npm automatically (#816) 2017-09-06 18:34:53 +02:00
Roberto
8fafe75793 Use config for GCP settings, allow function update (#803)
* Use same function to verify the deployed function
* Use Google CloudFunction property names
* change gcpConfig.name to gcpConfig.functionName
* availableMemoryMb => memory
2017-09-06 10:47:13 +02:00
Benoit Averty
cc74eaf4c7 Only show account info caching message in TTY (#811)
* Only show account info caching message in TTY

* fix typo

* Fixed syntax
2017-09-06 10:38:35 +02:00
Nathan Rajlich
900f2bd306 Fixed typo in usage information 2017-09-06 10:27:03 +02:00
Leo Lamprecht
f4c536cc87 8.0.2 2017-09-05 12:16:33 +02:00
Leo Lamprecht
f67af44f21 Fixed the input and output utilities (#808)
* Fixed the input and output utilities

* Stop swallowing errors
2017-09-05 12:02:57 +02:00
Leo Lamprecht
9a9736bdd2 Made token-based authentication work (#805) 2017-09-05 09:57:57 +02:00
Leo Lamprecht
8d919874a5 8.0.1 2017-09-04 12:52:46 +02:00
Leo Lamprecht
5ef6f7be3d Only prompt for login in TTY, otherwise throw error (#798)
* Only prompt for login in terminal, otherwise throw error

* Removed colors for non-TTY
2017-09-04 12:51:50 +02:00
Michael Hsu
77e95e28b9 Don't prompt for login if token was defined (#797)
* fix(prompt): unexpected Prompt for login when given token [#795]

* update

* update
2017-09-04 12:26:56 +02:00
Leo Lamprecht
38f240bb64 Removed automatic tagging as beta 2017-09-04 02:55:15 +02:00
Leo Lamprecht
8bfcf68215 8.0.0 2017-09-04 02:42:50 +02:00
Leo Lamprecht
dd4db2427f Prompt for login if no credentials defined (#795)
* Prompt for login if no credentials defined

* Sub commands should lead to login as well

* Show a message

* Fixed syntax

* Even more syntax fixed
2017-09-04 02:38:29 +02:00
Leo Lamprecht
c1b6b819ae Automatically migrate the old configuration file (#794)
* Automatically migrate the old configuration file

* Fixed git.io links

* credentials.json => auth.json

* Let the user know

* Removed trailing dot
2017-09-04 01:51:34 +02:00
Leo Lamprecht
fdfdf8039b 8.0.0-beta.11 2017-09-03 19:34:50 +02:00
Leo Lamprecht
665e36eddf Google Cloud Platform support is working again 2017-09-03 18:11:42 +02:00
Leo Lamprecht
c156dd8698 Uploading testing builds should work now 2017-09-03 17:00:57 +02:00
Leo Lamprecht
a5cdaae401 Handle packing differently on CI 2017-09-03 16:56:14 +02:00
Leo Lamprecht
e5cd439383 Fixed tests for packed binary 2017-09-03 16:51:37 +02:00
Leo Lamprecht
4c7536ba51 Usage information is now consistent across commands 2017-09-03 16:38:31 +02:00
Leo Lamprecht
9b36c27598 Made usage information work for all commands 2017-09-03 16:29:43 +02:00
Leo Lamprecht
2fd34580f3 8.0.0-beta.10 2017-09-02 17:53:51 +02:00
Leo Lamprecht
cf97a06610 Use new config for everything 2017-09-02 17:44:33 +02:00
Leo Lamprecht
9492e395ca Fixed all remaining team features 2017-09-02 17:35:36 +02:00
Leo Lamprecht
c3f9a0ea75 Made team switching work again 2017-09-02 17:25:16 +02:00
Donnie West
0586987441 Prevent cross device linking error by copying instead of linking (#789) 2017-09-02 17:10:29 +02:00
Leo Lamprecht
aa38e055e7 Made tests for packed binary work 2017-09-02 17:09:39 +02:00
Leo Lamprecht
96bafc0e0d Temporarily use Yarn 2017-09-02 17:03:00 +02:00
Leo Lamprecht
bd35c4091f Fixed tests 2017-09-02 16:44:52 +02:00
Leo Lamprecht
7fee74a0c0 Bumped lockfile 2017-09-02 16:38:13 +02:00
Leo Lamprecht
d0562dd3bf Several tests added 2017-09-02 13:41:32 +02:00
Leo Lamprecht
25e59997f5 Corrected linting ignore configuration 2017-09-02 13:32:40 +02:00
Leo Lamprecht
b6a0e8730c No need to print when initializing config 2017-09-02 13:30:24 +02:00
Leo Lamprecht
20816b5a34 Smaller text for logo 2017-09-02 13:28:12 +02:00
Leo Lamprecht
62bece4a2f New repo banner added 2017-09-02 13:26:02 +02:00
Leo Lamprecht
9c5cb06bd0 8.0.0-beta.9 2017-09-02 01:07:10 +02:00
Leo Lamprecht
c32c36a98f New token for uploading releases 2017-09-02 01:05:47 +02:00
Leo Lamprecht
10a1d9125c Fixed command logo 2017-09-02 00:52:24 +02:00
Leo Lamprecht
1db1fbd9b4 Bumped dependencies to the latest version 2017-09-02 00:47:17 +02:00
Leo Lamprecht
8435180f13 Replaced all name occurences 2017-09-02 00:08:25 +02:00
Leo Lamprecht
3e677e3a34 Merged in the zeit/now repository 2017-09-01 23:36:24 +02:00
Leo Lamprecht
6f4f252875 Removed everything 2017-09-01 23:36:12 +02:00
Leo Lamprecht
2f723a3c1b Removed useless file 2017-09-01 21:43:03 +02:00
Leo Lamprecht
f6685729ae Perfected code structure for .sh 2017-09-01 21:40:40 +02:00
Leo Lamprecht
b9e7eb1d0b Even better structure for code 2017-09-01 21:12:55 +02:00
Leo Lamprecht
9b297cf76f Removed useless legacy files 2017-09-01 20:48:17 +02:00
Leo Lamprecht
ce2fe449cd Made loggin out from .sh work 2017-09-01 20:25:54 +02:00
Leo Lamprecht
fc082a8416 Corrected import comments 2017-09-01 20:07:13 +02:00
Leo Lamprecht
5b38f092d7 Made commands take advantage of new config 2017-09-01 19:56:48 +02:00
Leo Lamprecht
48a1ad5280 Better order for .sh commands 2017-09-01 19:15:06 +02:00
Leo Lamprecht
5e36b2f2e3 Support for special commands 2017-09-01 19:14:04 +02:00
Leo Lamprecht
ded122806f Implemented the last sub command 2017-09-01 13:35:49 +02:00
Leo Lamprecht
fbf58ef698 Made logs and logout work 2017-09-01 13:27:53 +02:00
Leo Lamprecht
f8339c53d8 Support for all aliases added 2017-09-01 13:12:46 +02:00
Leo Lamprecht
1b83978ac4 Added all team features and ability to upgrade 2017-09-01 12:49:50 +02:00
Leo Lamprecht
110abfce03 Fixed empty user-agent on logs 2017-09-01 12:25:55 +02:00
Leo Lamprecht
71a04d2811 Ability to load logs added 2017-09-01 12:19:15 +02:00
Leo Lamprecht
3bfd534700 Ability to get secrets and current team 2017-08-30 13:56:05 +02:00
Leo Lamprecht
110c959902 Ability to remove deployments brought back 2017-08-30 13:29:47 +02:00
Leo Lamprecht
c5d0f10455 Syntax improved 2017-08-30 13:24:53 +02:00
Leo Lamprecht
2a50c2bd7f Commands for getting DNS, domains and certs added 2017-08-30 13:24:25 +02:00
Leo Lamprecht
36a2fee6e6 Now able to debug and set a API URL 2017-08-30 13:07:43 +02:00
Leo Lamprecht
5a49cf0102 Added now scale and now alias sub commands 2017-08-30 13:03:38 +02:00
Leo Lamprecht
d383505b7c Brought back the now ls sub command 2017-08-30 12:46:08 +02:00
Leo Lamprecht
9ce4085a7b Always save dependencies as devDependencies 2017-08-30 11:57:30 +02:00
Igor Klopov
61631dc227 Made installation work on Windows (#56)
* use 'which' to detect the path of global cmd

* Take advantage of `which-promise`
2017-08-30 11:53:50 +02:00
Alexis Sgarbossa
575c0f46ee Fixed broken link for getting started (#750) 2017-08-29 16:27:15 +02:00
Matheus Fernandes
2f810ef60f 7.4.0 2017-08-25 06:23:43 -03:00
Matheus Fernandes
ca1be7b501 Add support for coupon codes (#747)
* [BREAKING] `now domains`: remove `--config` flag

Needed so we can introduce `--coupon`

* Remove test code

* Fix the amount of erased lines upon error

* Make it async

* Add option to clear the output after adding the card

* Tweak success message

* Add support for coupon codes
2017-08-25 06:16:30 -03:00
Igor Klopov
7336c8cb0e Fix for #729 (#745)
* use 'which' to detect the path of global cmd

* fix downloading apline binaries
2017-08-24 16:04:46 -03:00
Nathan Rajlich
d8de1bcd91 secrets: treat any 4xx error code as "user error" (#744)
The Secrets endpoints used to inappropriately return a 400
error code when a secret name collision occurred (i.e. when
creating a secret with a name that already exists, or when
trying to rename a secret to a name that is already in use).
Now they return 409 Conflict which is more correct for those
scenarios.

So while we're at it, just treat all 4xx error codes as user errors.
2017-08-24 15:58:51 -03:00
Matheus Fernandes
733a288677 7.3.1 2017-08-22 19:06:52 -03:00
Matheus Fernandes
372f2b4e4d When on non-TTY mode, wait for the deployment to complete before exiting (#743)
* When on non-tty mode, wait for the deployment to complete before exiting

* Fix typo
2017-08-23 00:05:44 +02:00
Jarmo Isotalo
55879b3e32 Atomically is the correct word (#741) 2017-08-21 11:21:37 +03:00
Leo Lamprecht
67801791c5 8.0.0-beta.8 2017-08-19 02:39:02 +02:00
Leo Lamprecht
ed90053a12 Automatically publish as a beta release 2017-08-19 02:38:43 +02:00
Leo Lamprecht
d75c3f9348 Set correct paths in bundle 2017-08-19 02:34:18 +02:00
Leo Lamprecht
cba609effd 8.0.0-beta.7 2017-08-19 01:23:27 +02:00
Leo Lamprecht
0b82f77def Bumped babel-loader to the latest version 2017-08-19 01:21:32 +02:00
Leo Lamprecht
ee6c78edd0 Made google cloud deployments work again 2017-08-19 01:19:57 +02:00
Leo Lamprecht
913e99364b 8.0.0-beta.6 2017-08-18 14:58:52 +02:00
Leo Lamprecht
e51e713564 Copy missing file into bundle 2017-08-18 14:58:33 +02:00
Leo Lamprecht
98ec36da64 8.0.0-beta.5 2017-08-18 14:15:43 +02:00
Leo Lamprecht
18cfb8ce75 Exit process when not logged into GCP and trying to deploy 2017-08-18 14:14:23 +02:00
Leo Lamprecht
e0fa631b99 Correctly inject directory names 2017-08-18 14:12:57 +02:00
Leo Lamprecht
f84e4e76a9 Removed unused dependency 2017-08-18 13:58:57 +02:00
Leo Lamprecht
a1f7dd1bea Use correct npm scripts 2017-08-18 13:54:23 +02:00
Leo Lamprecht
0ee23be289 8.0.0-beta.4 2017-08-18 13:43:32 +02:00
Leo Lamprecht
36d7cfd4eb Field for repository added to package info 2017-08-18 13:43:13 +02:00
Leo Lamprecht
b4db734ec6 Added missing arr-flatten dependency 2017-08-18 13:42:33 +02:00
Leo Lamprecht
a1a646e303 Bumped dependencies to the latest version 2017-08-18 13:40:18 +02:00
Leo Lamprecht
c508751bc3 Removed a directory description 2017-08-18 13:36:46 +02:00
Leo Lamprecht
98a654ab67 Remember the configuration again 2017-08-18 13:36:12 +02:00
Leo Lamprecht
0f4a493aa9 Sweetened message login messages 2017-08-18 13:24:10 +02:00
Leo Lamprecht
cbe4af8eaa Use mri instead of minimist 2017-08-18 13:16:01 +02:00
Leo Lamprecht
17796a682d 8.0.0-beta.3 2017-08-15 21:06:46 +02:00
Leo Lamprecht
ebf6c27aa3 Build before linking 2017-08-15 21:05:29 +02:00
Leo Lamprecht
7746efff3e Additional information added to readme 2017-08-15 20:55:39 +02:00
Leo Lamprecht
4f0651b26b Avoid useless bundle builds 2017-08-15 20:43:04 +02:00
Leo Lamprecht
870c95c870 Fixed deployments 2017-08-15 20:29:27 +02:00
Leo Lamprecht
f3b6f9edb0 Ignore pkg output in Git 2017-08-15 20:26:45 +02:00
Igor Klopov
ebd3db90b0 Yarn artifacts + fix alpine download (#51)
* backup of binary to be included into yarn artifacts

* fix downloading alpine binary
2017-08-15 20:25:47 +02:00
Leo Lamprecht
9d7cac8acb Build again before deploying 2017-08-15 20:18:34 +02:00
Leo Lamprecht
55dec6e419 Fixed ability to push releases to Slack 2017-08-15 20:13:07 +02:00
Leo Lamprecht
c847179be1 Missing pkg dependency added 2017-08-15 20:05:23 +02:00
Leo Lamprecht
ecbef2ac9d Ensure that package bundle doesn't get lost on CI 2017-08-15 19:59:43 +02:00
Leo Lamprecht
341c22ac31 Removed native module from dependency list 2017-08-15 19:56:27 +02:00
Leo Lamprecht
d2642f9601 Missing badges added 2017-08-15 19:51:42 +02:00
Leo Lamprecht
1f5a2dbd65 Use Travis CI instead of Circle CI 2017-08-15 19:47:11 +02:00
Leo Lamprecht
9d9fd7e097 Tell npm to publish as beta 2017-08-15 19:07:55 +02:00
Leo Lamprecht
6efdb0fb9d Test on Circle CI 2017-08-15 19:06:36 +02:00
Leo Lamprecht
30ed4bcc64 Added missing dependency 2017-08-15 19:03:54 +02:00
Leo Lamprecht
06f5ebf111 Added support for updates 2017-08-15 18:58:19 +02:00
Leo Lamprecht
fb67971bfd Package description added 2017-08-15 18:30:48 +02:00
Leo Lamprecht
c7535de719 Added ability to link in development 2017-08-15 18:30:13 +02:00
Leo Lamprecht
d2617270bb Fixed URL for pkg downloads 2017-08-15 18:26:49 +02:00
Leo Lamprecht
7e37d8825c Create a bundle using pkg on the fly 2017-08-15 18:25:31 +02:00
Leo Lamprecht
35e7b994ef Fixed Flow errors 2017-08-15 18:11:13 +02:00
Leo Lamprecht
3bb9011e2a Replaced fs.promised with fs-extra-promise 2017-08-15 17:50:07 +02:00
Leo Lamprecht
cfcfe4a729 Moved all dependencies into a single property 2017-08-15 17:46:25 +02:00
Leo Lamprecht
9be5808029 Made pre-commit hook only lint Flow code 2017-08-15 17:42:39 +02:00
Leo Lamprecht
b612fbc02b Removed examples, that's what the site is for 2017-08-15 17:37:20 +02:00
Leo Lamprecht
6ba6999bb9 Removed useless dependencies 2017-08-15 17:35:54 +02:00
Leo Lamprecht
e787d72a2f Tell Webpack to build into the correct directory 2017-08-15 17:26:28 +02:00
Leo Lamprecht
8f2f359462 Use Webpack for building Flow code 2017-08-15 17:21:12 +02:00
Leo Lamprecht
1ff8139f74 Automatically run flow when source changes 2017-08-15 16:56:39 +02:00
Leo Lamprecht
340b8721ac Made sure that shortlinks point to the right place 2017-08-15 16:37:09 +02:00
Leo Lamprecht
d8c8bb62bc Removed license note in readme.md 2017-08-15 16:30:12 +02:00
Leo Lamprecht
39bda5f6b6 Converted pre-commit hook to script 2017-08-15 16:27:20 +02:00
Leo Lamprecht
cf40198b22 Better directory name for build output 2017-08-15 16:26:18 +02:00
Leo Lamprecht
ac31ded446 Comments for ignored files 2017-08-15 16:24:52 +02:00
Leo Lamprecht
ba9567941d Made company name in license legally correct 2017-08-15 16:24:23 +02:00
Leo Lamprecht
100b37b475 Lowercased text files 2017-08-15 16:22:57 +02:00
Leo Lamprecht
2b908305d0 Bumped dependencies to the latest version 2017-08-15 16:22:42 +02:00
Leo Lamprecht
9d29e64038 Improved order of package fields 2017-08-15 16:20:50 +02:00
Leo Lamprecht
b5fcb44c64 Pinned dependencies 2017-08-15 16:20:13 +02:00
Logan McAnsh
602e121742 Fixed a typo in the now scale usage information (#734)
Fixed a typo in the `now scale` usage information
2017-08-15 15:33:50 +02:00
Leo Lamprecht
4bdaa3fa26 8.0.0-beta.2 2017-08-14 12:56:01 +02:00
Matheus Fernandes
8973f7c184 Move legacy code to where it belongs 2017-08-08 00:48:34 -03:00
Matheus Fernandes
21cbdc2059 7.3.0 2017-07-29 18:50:19 -03:00
Leo Lamprecht
43f7262bff Bumped dependencies to the latest version 2017-07-29 23:25:04 +02:00
Leo Lamprecht
4ae45b4e7e Invalided cache for slack badge 2017-07-29 23:20:19 +02:00
Igor Klopov
f4c6054acb Don't deploy again when name or public state changes (#706)
* no need in forceNew after https://github.com/zeit/now-create/pull/83

* fix lint
2017-07-29 23:15:14 +02:00
Matheus Fernandes
6169cc2f5b Fix the default config description (#38)
* There's no auth stuff in here

* `now` -> `Now`

* Add missing `'`

* Mention `now config help`
2017-07-28 14:44:09 +03:00
Naoyuki Kanezawa
817184951d Add basic config command (#33)
* add basic config command

* Add a success message

* Grammar

* Remove extra spaces
2017-07-21 00:31:28 -03:00
Naoyuki Kanezawa
cad1fbd31d Generate random bucket names and save to config (#32) 2017-07-21 00:31:17 -03:00
Naoyuki Kanezawa
648da4e85a Ignore out dir on lint (#35) 2017-07-21 00:00:38 -03:00
Naoyuki Kanezawa
71c586ec7b Fix flow annotations to suppress errors (#36) 2017-07-20 23:58:48 -03:00
Naoyuki Kanezawa
776c759de8 retry createFunction for the case role is not ready on aws deployment (#31) 2017-07-20 12:09:04 +08:00
Naoyuki Kanezawa
1ec72f0eef Add progress module to dependencies (#30) 2017-07-19 11:53:24 -03:00
Matheus Fernandes
e061c9bbc4 Tell ESLint to ignore legacy code 2017-07-19 09:47:39 -03:00
Matheus Fernandes
dc03fb4d4e Add the license 2017-07-19 09:47:23 -03:00
Elliott Beach
4db2c0619d Text.js: Remove bad restore call. (#26)
Fixes #25.
The `restore` call is not needed, since at this point no user input has been processed.
Even if you moved the definition up, it would still cause a ReferenceError due to setRawMode not existing, so it's best to just not do it.
2017-07-19 18:04:41 +09:00
Guillermo Rauch
9fe6e928f8 exit correctly from unhandled errors 2017-07-18 15:04:30 +08:00
Guillermo Rauch
2003bb67bf Merge branch 'master' of github.com:zeit/now 2017-07-18 15:04:09 +08:00
Guillermo Rauch
3e64c39390 handle unexpected rejections correctly 2017-07-18 15:00:42 +08:00
– Amio –
d0dae3b01a Fix typos in Readme.md (#20)
* Fix more typos in Readme.md

* `\` -> `|`
2017-07-16 14:13:47 -03:00
Mirza Brunjadze
2e548e5838 Fix typos in Readme.md (#19) 2017-07-14 18:42:14 +08:00
Guillermo Rauch
475e662992 preview tag -> beta 2017-07-13 22:26:45 +08:00
Guillermo Rauch
0b5998d4b2 Delete test.js 2017-07-13 21:51:30 +08:00
Guillermo Rauch
185c78a0fe Update Readme.md 2017-07-13 21:47:13 +08:00
Guillermo Rauch
4c5a0a0050 preview 2017-07-13 20:49:15 +08:00
Igor Klopov
316d711a9c Support for Node.js 0.10 and Git for Windows (#713)
* add support of nodejs 0.10

* handle 'incorrect header check' error from gunzip

* fix progress bar

* use async-retry restart after 'incorrect header check'

* fix for #613
2017-07-11 13:01:57 +02:00
nkzawa
dd43a3a57f Release 7.2.4 2017-07-09 11:32:15 +09:00
nkzawa
5be95dc6f8 use https for badge url 2017-07-09 11:26:37 +09:00
Naoyuki Kanezawa
2bc4a1e601 use https for downloading now binary (#712) 2017-07-08 19:20:46 -07:00
Leo Lamprecht
6bddeabdb3 Lockfile updated 2017-07-09 00:17:28 +02:00
Leo Lamprecht
2db1e514e2 7.2.3 2017-07-09 00:11:38 +02:00
Leo Lamprecht
4b163c4835 Now fetching CLI downloads from our CDN 2017-07-09 00:10:16 +02:00
Leo Lamprecht
f5c1261553 Only upload CI binaries to Slack for our branches 2017-07-08 11:26:46 +02:00
Leo Lamprecht
4a1e04fe46 Match all tags on Circle CI, we always use SemVer 2017-07-08 11:20:58 +02:00
Leo Lamprecht
a9c862a228 Allow GitHub Releases uploader to extend existing one 2017-07-08 00:18:40 +02:00
Leo Lamprecht
66a0641214 7.2.2 2017-07-07 23:52:00 +02:00
Leo Lamprecht
3647ce7bd9 Only allow releases inside the ZEIT org 2017-07-07 23:50:47 +02:00
Naoyuki Kanezawa
ed34ef6f74 Avoid retrieving the deployment list when aliasing (#708)
* 7.2.0

* alias: use deployment url which is included in alias data

* alias: remove remaining https prefix
2017-07-07 23:50:31 +02:00
Leo Lamprecht
153b20cee5 Automatically publish to npm 2017-07-07 23:41:05 +02:00
Leo Lamprecht
1cb7b3c8e4 Install custom dependencies after the normal ones 2017-07-07 23:34:42 +02:00
Leo Lamprecht
21b0c13b6b Let Circle CI determine the git tag 2017-07-07 23:34:31 +02:00
Leo Lamprecht
d4bcf75055 7.2.1 2017-07-07 23:28:52 +02:00
Leo Lamprecht
4a7cefa922 Perfected structure for testing config 2017-07-07 23:25:14 +02:00
Leo Lamprecht
9b138191d9 Better grouping for Circle CI commands 2017-07-07 23:20:07 +02:00
Leo Lamprecht
c74a88c2b6 Ensure that directory with packed binary exists 2017-07-07 23:05:00 +02:00
Leo Lamprecht
f035cd7415 Load binaries for release from ./packed 2017-07-07 22:57:18 +02:00
Leo Lamprecht
816b23177d Add binaries to the correct tag when releasing 2017-07-07 22:48:47 +02:00
Leo Lamprecht
1d2b6bc3e1 Don't check node version when uploading binary to Slack 2017-07-07 22:05:36 +02:00
Leo Lamprecht
8869a98597 Upload binaries to Slack for testing 2017-07-07 18:45:25 +02:00
Leo Lamprecht
4db07394a3 Adjusted uploading script for Slack 2017-07-07 18:44:18 +02:00
Leo Lamprecht
8f79c9d6f1 Make artifacts available on Circle CI 2017-07-07 18:29:21 +02:00
Leo Lamprecht
dd956e6cf7 Circle CI is using NVM to install Node.js 2017-07-07 18:24:21 +02:00
Leo Lamprecht
e11dde4c97 Use the latest Node.js version in Circle CI 2017-07-07 18:21:50 +02:00
Leo Lamprecht
517a811e08 Added ability to build on Circle CI 2017-07-07 18:18:39 +02:00
Naoyuki Kanezawa
84ecbcb772 Removed HTTPS prefix from alias list (#709)
* 7.2.0

* alias: remove https prefix
2017-07-07 17:49:52 +02:00
Leo Lamprecht
8dacdf8241 7.2.0 2017-07-07 13:18:52 +02:00
Olli Vanhoja
9fcf9c004e Remove associated aliases and certificates before removing a domain (#703)
* Remove associated aliases and certificates before removing a domain

Previously this has been partially done on the server side but
it's better to do it client side to avoid accidentally removing
something that shouldn't be removed in team environments.

* Don't print the domain id

* Grammar

* Remove indentation
2017-07-07 01:04:58 -03:00
Matheus Fernandes
4dcab272df Don't throw Domain not found when trying to now alias to a new domain (#702)
* Don't throw `Domain not found` when trying to alias to a new domain

* Remove `console.log`

* Prettier stuff
2017-07-07 01:02:34 -03:00
Leo Lamprecht
55d25a19d5 Avoid npm run link warnings 2017-07-04 12:20:48 +02:00
Leo Lamprecht
6eae5d1ab2 Lockfile added 2017-07-04 12:19:19 +02:00
Leo Lamprecht
7fcda07cc7 7.1.1 2017-06-28 20:19:13 +02:00
Leo Lamprecht
b2a4c7e7f5 Prettified everything 2017-06-28 20:17:19 +02:00
Leo Lamprecht
7e21d71a04 Bumped dependencies to the latest version 2017-06-28 20:13:46 +02:00
Jarmo Isotalo
1daaf3037b Keep trying to scale if deployment is not yet ready (#701)
* Keep on polling now-scale when deployment is not ready

* Use `ms`
2017-06-28 20:08:51 +02:00
Igor Klopov
50b7f87854 Fixed property username not being defined (#700)
https://github.com/zeit/now-cli/blob/7.1.0/bin/now-deploy.js#L298
fixes https://github.com/zeit/now-cli/issues/633
2017-06-28 19:44:18 +02:00
Leo Lamprecht
0392b5e318 7.1.0 2017-06-25 19:02:56 +02:00
Leo Lamprecht
d793695dcc Downgraded socket.io-client to avoid several problems 2017-06-25 18:35:49 +02:00
Leo Lamprecht
a604c1f558 Bumped dependencies to the latest version 2017-06-25 18:33:58 +02:00
Igor Klopov
ebcda315a5 Ensured correct output for error messages (#694)
* add await to responseError calls

* add await to login(apiUrl) calls
2017-06-25 18:32:56 +02:00
Josh Junon
17b7a5464d Now respecting the files property inside now.json (#692)
* whitelist now.json files over .gitignores (fixes #596)

* Prettified
2017-06-24 17:49:29 +02:00
Guillermo Rauch
301166831a Fixed missing token handling (#690)
* handle API errors when fetching user

* handle API errors in some of the core Now methods

* add ability for `handleError` to report full stack trace in debug mode

* make `responseError` utility reusable

* handle top-level promise errors in entry functions of all commands

* allow for logging in when user has a bad token

* fix CI

* Fix reference error

* Improve message

* Fix typo

* Prettify
2017-06-20 12:07:21 +02:00
Leo Lamprecht
89e08bc2e7 7.0.2 2017-06-17 14:47:54 +02:00
Igor Klopov
95042e1a77 Ask to re-install with --unsafe-perm on EACCES (#683)
* ask user to reinstall with --unsafe-perm on EACCES

* webpack overrides process.env totally. removed DefinePlugin

* Cleaned up the code a little

* Missing import comments added
2017-06-17 12:44:18 +02:00
Matheus Fernandes
d60251703c 7.0.1 2017-06-15 19:40:34 -07:00
Matheus Fernandes
8d971d7b2b Bump email-promptfixes #679 2017-06-15 19:39:40 -07:00
Matheus Fernandes
a88ecb9936 Revert ea9af7d and fix the existing message (#680) 2017-06-15 18:38:27 -07:00
Leo Lamprecht
b6a714f6c7 Be more definite about what is being installed 2017-06-15 16:19:27 +02:00
Leo Lamprecht
9d30b4fcd3 7.0.0 2017-06-15 16:05:07 +02:00
Leo Lamprecht
9fbeb61ff7 Prettified arrow function 2017-06-15 15:37:18 +02:00
Leo Lamprecht
ea9af7d746 Display proper error message if path doesn't exist
This closes #675
2017-06-15 15:35:45 +02:00
Leo Lamprecht
8a603c04d8 Made now cc add case-unsensitive
This closes #631
2017-06-15 15:29:36 +02:00
Leo Lamprecht
12edb30d20 Use arrow functions and import comments where possible 2017-06-15 14:28:24 +02:00
Mike Engel
9089fb8a41 Allow credit card numbers to be pasted with now cc add (#656)
This fixes a bug where, when pasting a credit card, it would print the
number correctly, but also append too much placeholder. When hitting
enter, backspace, or another number, it would begin printing (and
formatting) `undefined`. This adds a special case where the CC will be
formatted to account for spaces when comparing against the length of the
existing value or placeholder.
2017-06-15 14:26:05 +02:00
Leo Lamprecht
e2cc19e8d5 Added npm run prettify for running prettier manually 2017-06-15 14:16:00 +02:00
David Corwin
27319e34b4 Improved usage information for now switch (#668)
* updated help message for `now switch` to reference the argument for the team as the slug instead of the id

* Improved message

* Prettified
2017-06-15 14:06:25 +02:00
Naoyuki Kanezawa
1fc76f1b60 Removed IDs from secrets list (#665)
* remove secret ids

* prettier
2017-06-14 10:30:56 +02:00
Albert Martin
020365fd55 Fixed aliased results appearing in list with --safe flag (#672) 2017-06-14 09:28:39 +02:00
David Corwin
348b19e54d Try to clone git repositories over SSH on failure (#671)
* updated help message for `now switch` to reference the argument for the team as the slug instead of the id

* try ssh if https does not work

* add editor settings to .gitignore, update yarn.lock

* reverting change to teams in separate pr

* Removed unused ignored prop
2017-06-14 09:21:48 +02:00
Igor Klopov
588ba5acf1 Stop showing the full build path in stack traces (#669) 2017-06-13 11:59:41 +02:00
Leo Lamprecht
1fba7da419 6.4.1 2017-06-12 22:24:35 +02:00
Leo Lamprecht
3711d09352 Made using an array for the env variable list work 2017-06-12 22:23:45 +02:00
Leo Lamprecht
0fe740f847 6.4.0 2017-06-12 17:22:29 +02:00
Leo Lamprecht
925eb96882 Added npm run clean for cleaning up the development environment 2017-06-12 17:18:10 +02:00
Olli Vanhoja
5080520616 Reduce the number of retries on cert creation (#664)
Retrying multiple times on cert creation doesn't usually help but
makes the user wait for a longer time for nothing. Usually there
is either a configuration error that must be solved or the DNS
change hasn't propagated yet, which will usually take longer than
the retry window.
2017-06-12 17:14:46 +02:00
Leo Lamprecht
ac2a75fe41 Now asking for value of missing environment variables (#645)
* Ask for missing environment variables

* Prettified

* Use `info` helper

* Only apply fields if `now` is available

* Don't log

* Isolate our Inquirer patch

* Patch Inquirer before asking for the env fields

* Don't ask for env vars that are already defined
2017-06-12 16:24:49 +02:00
Igor Klopov
627ded2ee7 Removed useless code from installation mechanism (#663) 2017-06-12 16:10:09 +02:00
Leo Lamprecht
10862abef2 Linked to document about how to install the CLI 2017-06-12 10:15:44 +02:00
Olli Vanhoja
566f8bc17a Ask if the user really wants to add a subdomain as a domain (#662)
Closes #481
2017-06-12 09:54:52 +02:00
greenkeeper[bot]
d108fe9d67 chore(package): update psl to version 1.1.19 (#660) 2017-06-11 11:35:21 +02:00
greenkeeper[bot]
212e8a9d67 chore(package): update lint-staged to version 3.6.1 (#657) 2017-06-10 13:18:28 +02:00
2357 changed files with 307679 additions and 12093 deletions

490
.circleci/config.yml Normal file
View File

@@ -0,0 +1,490 @@
version: 2
jobs:
install:
docker:
- image: circleci/node:10
working_directory: ~/repo
environment:
GOPATH: $HOME/go
steps:
- checkout
- restore_cache:
keys:
- v1-dependencies-{{ checksum "yarn.lock" }}
# fallback to using the latest cache if no exact match is found
- v1-dependencies-
- run:
name: Updating apt packages
command: sudo apt-get update
- run:
name: Installing the latest version of Go
command: sudo apt-get install golang-go
- run:
name: Installing Dependencies
command: yarn install --check-files --frozen-lockfile
- save_cache:
paths:
- node_modules
- packages/gatsby-plugin-now/node_modules
- packages/now-build-utils/node_modules
- packages/now-cgi/node_modules
- packages/now-cli/node_modules
- packages/now-client/node_modules
- packages/now-go/node_modules
- packages/now-next/node_modules
- packages/now-node/node_modules
- packages/now-node-bridge/node_modules
- packages/now-python/node_modules
- packages/now-routing-utils/node_modules
- packages/now-ruby/node_modules
- packages/now-static-build/node_modules
key: v1-dependencies-{{ checksum "yarn.lock" }}
- persist_to_workspace:
root: .
paths:
- node_modules
- packages/gatsby-plugin-now/node_modules
- packages/now-build-utils/node_modules
- packages/now-cgi/node_modules
- packages/now-cli/node_modules
- packages/now-client/node_modules
- packages/now-go/node_modules
- packages/now-next/node_modules
- packages/now-node/node_modules
- packages/now-node-bridge/node_modules
- packages/now-python/node_modules
- packages/now-routing-utils/node_modules
- packages/now-ruby/node_modules
- packages/now-static-build/node_modules
build:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- run:
name: Installing apt dependencies
command: sudo apt install -y rsync
- attach_workspace:
at: .
- run:
name: Linking dependencies
command: yarn bootstrap
- run:
name: Building
command: yarn build
- store_artifacts:
path: packages/now-cli/dist
- persist_to_workspace:
root: .
paths:
- packages/gatsby-plugin-now/test/fixtures
- packages/now-build-utils/dist
- packages/now-cgi/dist
- packages/now-cli/dist
- packages/now-cli/assets
- packages/now-client/dist
- packages/now-go/dist
- packages/now-next/dist
- packages/now-node/dist
- packages/now-node/test/fixtures/15-helpers/ts/types.d.ts
- packages/now-node/test/fixtures/11-symlinks/symlink
- packages/now-node-bridge/index.js
- packages/now-node-bridge/bridge.js
- packages/now-python/dist
- packages/now-routing-utils/dist
- packages/now-ruby/dist
- packages/now-static-build/dist
- packages/now-static-build/test/fixtures/10a-gatsby-redirects/plugins
test-lint:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Compiling `now dev` HTML error templates
command: node packages/now-cli/scripts/compile-templates.js
- run:
name: Linting Code
command: yarn test-lint
test-integration-macos-node-8:
macos:
xcode: '9.2.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Update Node.js
command: curl -sfLS install-node.now.sh/8.11 | sh -s -- --yes
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-macos-node-10:
macos:
xcode: '10.0.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-macos-node-12:
macos:
xcode: '10.3.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-linux-node-8:
docker:
- image: circleci/node:8
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-linux-node-10:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-linux-node-12:
docker:
- image: circleci/node:12
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests
command: yarn test-integration --clean false
test-integration-macos-now-dev-node-8:
macos:
xcode: '9.2.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Update Node.js
command: curl -sfLS install-node.now.sh/8.11 | sh -s -- --yes
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.56.0/hugo_0.56.0_macOS-64bit.tar.gz && tar -xzf hugo_0.56.0_macOS-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-macos-now-dev-node-10:
macos:
xcode: '10.0.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.56.0/hugo_0.56.0_macOS-64bit.tar.gz && tar -xzf hugo_0.56.0_macOS-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-macos-now-dev-node-12:
macos:
xcode: '10.3.0'
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.56.0/hugo_0.56.0_macOS-64bit.tar.gz && tar -xzf hugo_0.56.0_macOS-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-linux-now-dev-node-8:
docker:
- image: circleci/node:8
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.55.6/hugo_0.55.6_Linux-64bit.tar.gz && tar -xzf hugo_0.55.6_Linux-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-linux-now-dev-node-10:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.55.6/hugo_0.55.6_Linux-64bit.tar.gz && tar -xzf hugo_0.55.6_Linux-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-linux-now-dev-node-12:
docker:
- image: circleci/node:12
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Downloading Hugo
command: curl -L -O https://github.com/gohugoio/hugo/releases/download/v0.55.6/hugo_0.55.6_Linux-64bit.tar.gz && tar -xzf hugo_0.55.6_Linux-64bit.tar.gz && mv ./hugo packages/now-cli/test/dev/fixtures/08-hugo/
- run:
name: Running Integration Tests for `now dev`
command: yarn test-integration-now-dev --clean false
test-integration-once:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Output version
command: node --version
- run:
name: Running Integration Tests Once
command: yarn test-integration-once --clean false
coverage:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Compiling `now dev` HTML error templates
command: node packages/now-cli/scripts/compile-templates.js
- run:
name: Run unit tests
command: yarn workspace now run test-unit
- run:
name: Run coverage report
command: yarn workspace now run coverage
source-maps:
docker:
- image: circleci/node:10
working_directory: ~/repo
steps:
- checkout
- attach_workspace:
at: .
- run:
name: Installing Sentry CLI
command: npm install -g @sentry/cli
- run:
name: Creating a New Sentry Release
command: sentry-cli releases new now-cli@`git describe --tags`
- run:
name: Upload Sourcemap Files
command: sentry-cli releases files now-cli@`git describe --tags` upload-sourcemaps ./dist
- run:
name: Finalize Sentry Release
command: sentry-cli releases finalize now-cli@`git describe --tags`
workflows:
version: 2
unscheduled:
jobs:
- install:
filters:
tags:
only: /.*/
- build:
requires:
- install
filters:
tags:
only: /.*/
- test-lint:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-node-8:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-node-10:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-node-12:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-node-8:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-node-10:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-node-12:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-now-dev-node-8:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-now-dev-node-10:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-macos-now-dev-node-12:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-now-dev-node-8:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-now-dev-node-10:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-linux-now-dev-node-12:
requires:
- build
filters:
tags:
only: /.*/
- test-integration-once:
requires:
- build
filters:
tags:
only: /.*/
- coverage:
requires:
- test-integration-macos-node-8
- test-integration-macos-node-10
- test-integration-macos-node-12
- test-integration-linux-node-8
- test-integration-linux-node-10
- test-integration-linux-node-12
- test-integration-macos-now-dev-node-8
- test-integration-macos-now-dev-node-10
- test-integration-macos-now-dev-node-12
- test-integration-linux-now-dev-node-8
- test-integration-linux-now-dev-node-10
- test-integration-linux-now-dev-node-12
- test-integration-once
- test-lint
filters:
tags:
only: /.*/

34
.circleci/publish.sh Executable file
View File

@@ -0,0 +1,34 @@
#!/bin/bash
set -euo pipefail
if [ -z "$NPM_TOKEN" ]; then
echo "NPM_TOKEN not found. Did you forget to assign the GitHub Action secret?"
exit 1
fi
echo "//registry.npmjs.org/:_authToken=$NPM_TOKEN" >> ~/.npmrc
if [ ! -e ~/.npmrc ]; then
echo "~/.npmrc file does not exist, skipping publish"
exit 0
fi
npm_tag=""
tag="$(git describe --tags --exact-match 2> /dev/null || :)"
if [ -z "$tag" ]; then
echo "Not a tagged commit, skipping publish"
exit 0
fi
if [[ "$tag" =~ -canary ]]; then
echo "Publishing canary release"
npm_tag="--npm-tag canary"
else
echo "Publishing stable release"
fi
# Sometimes this is a false alarm and blocks publish
git checkout yarn.lock
yarn run lerna publish from-git $npm_tag --yes

37
.editorconfig Normal file
View File

@@ -0,0 +1,37 @@
root = true
[*]
indent_style = space
indent_size = 2
tab_width = 2
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
[{*.json,*.json.example,*.gyp,*.yml,*.yaml}]
indent_style = space
indent_size = 2
[{*.py,*.asm}]
indent_style = space
[*.py]
indent_size = 4
[*.asm]
indent_size = 8
[*.md]
trim_trailing_whitespace = false
# Ideal settings - some plugins might support these.
[*.js]
quote_type = single
[{*.c,*.cc,*.h,*.hh,*.cpp,*.hpp,*.m,*.mm,*.mpp,*.js,*.java,*.go,*.rs,*.php,*.ng,*.jsx,*.ts,*.d,*.cs,*.swift}]
curly_bracket_next_line = false
spaces_around_operators = true
spaces_around_brackets = outside
# close enough to 1TB
indent_brace_style = K&R

32
.eslintignore Normal file
View File

@@ -0,0 +1,32 @@
node_modules
dist
# gatsby-plugin-now
packages/gatsby-plugin-now/test/fixtures
# now-cli
packages/now-cli/@types
packages/now-cli/download
packages/now-cli/dist
packages/now-cli/test/fixtures
packages/now-cli/test/dev/fixtures
packages/now-cli/bin
packages/now-cli/link
packages/now-cli/src/util/dev/templates/*.ts
# now-client
packages/now-client/tests/fixtures
packages/now-client/lib
# now-next
packages/now-next/test/fixtures
# now-node
packages/now-node/src/bridge.ts
packages/now-node/test/fixtures
# now-node-bridge
packages/now-node-bridge/bridge.*
# now-static-build
packages/now-static-build/test/fixtures

64
.eslintrc.json Normal file
View File

@@ -0,0 +1,64 @@
{
"root": true,
"parser": "@typescript-eslint/parser",
"parserOptions": {
"ecmaVersion": 2018,
"sourceType": "module",
"modules": true
},
"extends": [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"prettier",
"prettier/@typescript-eslint"
],
"env": {
"node": true,
"jest": true,
"es6": true
},
"rules": {
"require-atomic-updates": 0,
"@typescript-eslint/ban-ts-ignore": 0,
"@typescript-eslint/camelcase": 0,
"@typescript-eslint/explicit-function-return-type": 0,
"@typescript-eslint/no-empty-function": 0,
"@typescript-eslint/no-use-before-define": 0
},
"overrides": [
{
"files": ["**/*.js"],
"rules": {
"@typescript-eslint/no-var-requires": "off"
}
},
{
"files": ["packages/now-cli/**/*"],
"rules": {
"lines-between-class-members": 0,
"no-async-promise-executor": 0,
"no-control-regex": 0,
"no-empty": 0,
"prefer-const": 0,
"prefer-destructuring": 0,
"@typescript-eslint/ban-types": 0,
"@typescript-eslint/consistent-type-assertions": 0,
"@typescript-eslint/member-delimiter-style": 0,
"@typescript-eslint/no-empty-function": 0,
"@typescript-eslint/no-explicit-any": 0,
"@typescript-eslint/no-inferrable-types": 0,
"@typescript-eslint/no-var-requires": 0
}
},
{
"files": ["packages/now-client/**/*"],
"rules": {
"prefer-const": 0,
"require-atomic-updates": 0,
"@typescript-eslint/ban-ts-ignore": 0,
"@typescript-eslint/no-explicit-any": 0
}
}
]
}

3
.gitattributes vendored Normal file
View File

@@ -0,0 +1,3 @@
# Ignore test fixtures in GitHub Languages
# See https://github.com/github/linguist#vendored-code
packages/*/test/* linguist-vendored

18
.github/CODEOWNERS vendored Normal file
View File

@@ -0,0 +1,18 @@
# Documentation
# https://help.github.com/en/articles/about-code-owners
* @tootallnate @leo
/packages/now-cli/src/commands/dev/ @tootallnate @leo @styfle @AndyBitz
/packages/now-cli/src/util/dev/ @tootallnate @leo @styfle @AndyBitz
/packages/now-cli/src/commands/domains/ @javivelasco @mglagola @anatrajkovska
/packages/now-cli/src/commands/certs/ @javivelasco @mglagola @anatrajkovska
/packages/now-client @leo @rdev
/packages/now-build-utils @styfle @AndyBitz
/packages/now-node @styfle @tootallnate @lucleray
/packages/now-node-bridge @styfle @tootallnate @lucleray
/packages/now-next @Timer
/packages/now-go @styfle @sophearak
/packages/now-python @styfle @sophearak
/packages/now-ruby @styfle @coetry @nathancahill
/packages/now-static-build @styfle @AndyBitz
/packages/now-routing-utils @dav-is

33
.github/workflows/publish.yml vendored Normal file
View File

@@ -0,0 +1,33 @@
name: Publish
on:
push:
branches:
- master
- canary
tags:
- '!*'
jobs:
Publish:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [10.x]
steps:
- uses: actions/checkout@v1
- name: Checkout
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- name: Install
run: yarn install --check-files --frozen-lockfile
- name: Build
run: yarn build
- name: Publish
run: yarn publish-from-github
env:
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}

25
.gitignore vendored
View File

@@ -1,9 +1,20 @@
# build output
packed
download/dist
# dependencies
node_modules
# logs
package-lock.json
dist
npm-debug.log
yarn-error.log
.nyc_output
coverage
*.swp
*.bak
*.tgz
packages/now-cli/.builders
packages/now-cli/assets
packages/now-cli/src/util/dev/templates/*.ts
packages/now-cli/test/**/yarn.lock
!packages/now-cli/test/dev/**/yarn.lock
packages/now-cli/test/**/node_modules
packages/now-cli/test/dev/fixtures/08-hugo/hugo
packages/now-cli/test/dev/fixtures/**/dist
packages/now-cli/test/dev/fixtures/**/public
packages/now-cli/test/fixtures/integration

16
.kodiak.toml Normal file
View File

@@ -0,0 +1,16 @@
version = 1
[merge]
automerge_label = "automerge"
blacklist_title_regex = "^WIP.*"
blacklist_labels = ["work in progress"]
method = "squash"
delete_branch_on_merge = true
block_on_reviews_requested = false
notify_on_conflict = true
optimistic_updates = true
[merge.message]
title = "pull_request_title"
include_pr_number = true
body_type = "markdown"

1
.npmrc
View File

@@ -1 +0,0 @@
save-exact = true

4
.prettierrc Normal file
View File

@@ -0,0 +1,4 @@
{
"singleQuote": true,
"trailingComma": "es5"
}

View File

@@ -1,28 +0,0 @@
{
"language": "node_js",
"node_js": [
"node"
],
"script": [
"npm run test",
"./node_modules/.bin/prettier --single-quote --no-semi --write `find ./lib -name '*.js'` `find ./bin -name '*.js'` ; echo 'checking if prettier changed something' ; git diff-index --name-only HEAD ; git diff HEAD ; git diff-index --quiet HEAD && echo 'ok' || (echo 'pretier modified contents, please run prettier locally and add changes. exitting...' && exit 1)"
],
"before_deploy": "npm run pack",
"deploy": {
"provider": "releases",
"api_key": {
"secure": "RN06QEC2Vaigv2oX0rcBGCym1StJhQRoiRii6hq+AQJzdvuBJcWGDGz34CE0TPNeYbG56TyfnfryWxNtEmL+daQ9tjML3Wjk5cSt7bfo8uiB3qfuMSt2uUQvdwr7kOyzUDY6FNWB9ViTYxXzNZahZcOHdVxKdZ4RMDZfdvkun9baobhIF3OvPsFT+DiV0APVEcIg/e3PYNPLzyr59Z1yo2algvwn2c3TgHFiOBvTPLiNSO3eZQ33E8TuwSdl7D5Mnx5hUDc2Q9PDAH40aGM01Rq3aNvko4H2INfQJOlyu1JALEsnT3YGHkBOMkLoQGVGTNU7b7Ktxq+4FLDc5KiVTT49uvsPuNdMonEBRxahANqF6KJ9MqXeJZ59rBm7qa56hyffn2bXy2t2Wmn/8Wvn7gxj6eT4/1cVMNnUl/snLBvs5gHT4crPOkTT8vrdfpUWeacKIgfnvYYVcxJ8O5DCnFoIgd48+K5M6DG/g4N52lRFonHVj2VMpxSROEky/vlntalrKxqT7rJom0Ko5T3pYVMXoZGCuy2StBjXX6B4ofkj+9WkkHgzXxcpJDUb1ZPtUGul2sed2e8zPeG1sJVypLOnTXyJenm28w3oUckdH3Rd1Qv5BiFT6uiwIQExzyj9IGzaADAeoKctkGJlqbDW1PHyavFKePyLTpNh/bmXOuk="
},
"file_glob": true,
"file": "packed/*",
"skip_cleanup": true,
"on": {
"tags": true
}
},
"after_script": [
'npm install --global slackup',
'npm run pack',
'./scripts/slack.js'
]
}

1
.yarnrc Normal file
View File

@@ -0,0 +1 @@
save-prefix ""

74
CODE_OF_CONDUCT.md Normal file
View File

@@ -0,0 +1,74 @@
## Code of Conduct
### Our Pledge
In the interest of fostering an open and welcoming environment, we as
contributors and maintainers pledge to making participation in our project and
our community a harassment-free experience for everyone, regardless of age, body
size, disability, ethnicity, gender identity and expression, level of experience,
nationality, personal appearance, race, religion, or sexual identity and
orientation.
### Our Standards
Examples of behavior that contributes to creating a positive environment
include:
- Using welcoming and inclusive language
- Being respectful of differing viewpoints and experiences
- Gracefully accepting constructive criticism
- Focusing on what is best for the community
- Showing empathy towards other community members
Examples of unacceptable behavior by participants include:
- The use of sexualized language or imagery and unwelcome sexual attention or
advances
- Trolling, insulting/derogatory comments, and personal or political attacks
- Public or private harassment
- Publishing others' private information, such as a physical or electronic
address, without explicit permission
- Other conduct which could reasonably be considered inappropriate in a
professional setting
### Our Responsibilities
Project maintainers are responsible for clarifying the standards of acceptable
behavior and are expected to take appropriate and fair corrective action in
response to any instances of unacceptable behavior.
Project maintainers have the right and responsibility to remove, edit, or
reject comments, commits, code, wiki edits, issues, and other contributions
that are not aligned to this Code of Conduct, or to ban temporarily or
permanently any contributor for other behaviors that they deem inappropriate,
threatening, offensive, or harmful.
### Scope
This Code of Conduct applies both within project spaces and in public spaces
when an individual is representing the project or its community. Examples of
representing a project or community include using an official project e-mail
address, posting via an official social media account, or acting as an appointed
representative at an online or offline event. Representation of a project may be
further defined and clarified by project maintainers.
### Enforcement
Instances of abusive, harassing, or otherwise unacceptable behavior may be
reported by contacting the project team at [abuse@zeit.co](mailto:abuse@zeit.co). All
complaints will be reviewed and investigated and will result in a response that
is deemed necessary and appropriate to the circumstances. The project team is
obligated to maintain confidentiality with regard to the reporter of an incident.
Further details of specific enforcement policies may be posted separately.
Project maintainers who do not follow or enforce the Code of Conduct in good
faith may face temporary or permanent repercussions as determined by other
members of the project's leadership.
### Attribution
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
available at [http://contributor-covenant.org/version/1/4][version]
[homepage]: http://contributor-covenant.org
[version]: http://contributor-covenant.org/version/1/4/

96
CONTRIBUTING.md Normal file
View File

@@ -0,0 +1,96 @@
# Contributing
When contributing to this repository, please first discuss the change you wish to make via [GitHub Issue](https://github.com/zeit/now/issues/new) or [Spectrum](https://spectrum.chat/zeit) with the owners of this repository before submitting a Pull Request.
Please read our [code of conduct](CODE_OF_CONDUCT.md) and follow it in all your interactions with the project.
## Local development
This project is configured in a monorepo pattern where one repo contains multiple npm packages. Dependencies are installed and managed with `yarn`, not `npm` CLI.
To get started, execute the following:
```
git clone https://github.com/zeit/now
yarn install
yarn bootstrap
yarn build
yarn lint
yarn test
```
Make sure all the tests pass before making changes.
## Verifying your change
Once you are done with your changes (we even suggest doing it along the way ), make sure all the test still run by running
```
yarn build && yarn test
```
from the root of the project.
If any test fails, make sure to fix it along with your changes. See [Interpreting test errors](#Interpreting-test-errors) for more information about how the tests are executed, especially the integration tests.
## Pull Request Process
Once you are confident that your changes work properly, open a pull request on the main repository.
The pull request will be reviewed by the maintainers and the tests will be checked by our continuous integration platform.
## Interpreting test errors
There are 2 kinds of tests in this repository Unit tests and Integration tests.
Unit tests are run locally with `jest` and execute quickly because they are testing the smallest units of code.
### Integration tests
Integration tests create deployments to your ZEIT account using the `test` project name. After each test is deployed, the `probes` key is used to check if the response is the expected value. If the value doesn't match, you'll see a message explaining the difference. If the deployment failed to build, you'll see a more generic message like the following:
```
[Error: Fetched page https://test-8ashcdlew.now.sh/root.js does not contain hello Root!. Instead it contains An error occurred with this application.
NO_STATUS_CODE_FRO Response headers:
cache-control=s-maxage=0
connection=close
content-type=text/plain; charset=utf-8
date=Wed, 19 Jun 2019 18:01:37 GMT
server=now
strict-transport-security=max-age=63072000
transfer-encoding=chunked
x-now-id=iad1:hgtzj-1560967297876-44ae12559f95
x-now-trace=iad1]
```
In such cases you can visit the URL of the failed deployment and append `/_logs` so see the build error. In the case above, that would be https://test-8ashcdlew.now.sh/_logs
The logs of this deployment will contain the actual error which may help you to understand what went wrong.
### @zeit/node-file-trace
Some of the Builders use `@zeit/node-file-trace` to tree-shake files before deployment. If you suspect an error with this tree-shaking mechanism, you can create the following script in your project:
```js
const trace = require('@zeit/node-file-trace');
trace(['path/to/entrypoint.js'], {
ts: true,
mixedModules: true,
})
.then(o => console.log(o.fileList))
.then(e => console.error(e));
```
When you run this script, you'll see all imported files. If anything file is missing, the bug is in [@zeit/node-file-trace](https://github.com/zeit/node-file-trace) and not the Builder.
## Deploy a Builder with existing project
Sometimes you want to test changes to a Builder against an existing project, maybe with `now dev` or an actual deployment. You can avoid publishing every Builder change to npm by uploading the Builder as a tarball.
1. Change directory to the desired Builder `cd ./packages/now-node`
2. Run `yarn build` to compile typescript and other build steps
3. Run `npm pack` to create a tarball file
4. Run `now *.tgz` to upload the tarball file and get a URL
5. Edit any existing `now.json` project and replace `use` with the URL
6. Run `now` or `now dev` to deploy with the experimental Builder

447
DEVELOPING_A_BUILDER.md Normal file
View File

@@ -0,0 +1,447 @@
# Builders Developer Reference
The following page is a reference for how to create a Builder using the available Builder's API.
A Builder is an npm module that exposes a `build` function and optionally an `analyze` function and `prepareCache` function.
Official Builders are published to [npmjs.com](https://npmjs.com) as a package and referenced in the `use` property of the `now.json` configuration file.
However, the `use` property will work with any [npm install argument](https://docs.npmjs.com/cli/install) such as a git repo url which is useful for testing your Builder.
See the [Builders Documentation](https://zeit.co/docs/v2/advanced/builders) to view example usage.
## Builder Exports
### `version`
A **required** exported constant that decides which version of the Builder API to use.
The latest and suggested version is `2`.
### `analyze`
An **optional** exported function that returns a unique fingerprint used for the purpose of [build de-duplication](https://zeit.co/docs/v2/advanced/concepts/immutability#deduplication-algorithm). If the `analyze` function is not supplied, a random fingerprint is assigned to each build.
```js
export analyze({
files: Files,
entrypoint: String,
workPath: String,
config: Object
}) : String fingerprint
```
If you are using TypeScript, you should use the following types:
```ts
import { AnalyzeOptions } from '@now/build-utils'
export analyze(options: AnalyzeOptions) {
return 'fingerprint goes here'
}
```
### `build`
A **required** exported function that returns a [Files](#files) data structure that contains the Build outputs, which can be a [Static File](#file) or a [Serverless Function](#serverless-function).
What's a Serverless Function? Read about [Serverless Function concepts](https://zeit.co/docs/v2/deployments/concepts/lambdas) to learn more.
```js
build({
files: Files,
entrypoint: String,
workPath: String,
config: Object,
meta?: {
isDev?: Boolean,
requestPath?: String,
filesChanged?: Array<String>,
filesRemoved?: Array<String>
}
}) : {
watch: Array<String>,
output: Files output,
routes: Object
}
```
If you are using TypeScript, you should use the following types:
```ts
import { BuildOptions } from '@now/build-utils'
export build(options: BuildOptions) {
// Build the code here
return {
output: {
'path-to-file': File,
'path-to-lambda': Lambda
},
watch: [],
routes: {}
}
}
```
### `prepareCache`
An **optional** exported function that is equivalent to [`build`](#build), but it executes the instructions necessary to prepare a cache for the next run.
```js
prepareCache({
files: Files,
entrypoint: String,
workPath: String,
cachePath: String,
config: Object
}) : Files cacheOutput
```
If you are using TypeScript, you can import the types for each of these functions by using the following:
```ts
import { PrepareCacheOptions } from '@now/build-utils'
export prepareCache(options: PrepareCacheOptions) {
return { 'path-to-file': File }
}
```
### `shouldServe`
An **optional** exported function that is only used by `now dev` in [Now CLI](https:///download) and indicates whether a [Builder](https://zeit.co/docs/v2/advanced/builders) wants to be responsible for building a certain request path.
```js
shouldServe({
entrypoint: String,
files: Files,
config: Object,
requestPath: String,
workPath: String
}) : Boolean
```
If you are using TypeScript, you can import the types for each of these functions by using the following:
```ts
import { ShouldServeOptions } from '@now/build-utils'
export shouldServe(options: ShouldServeOptions) {
return Boolean
}
```
If this method is not defined, Now CLI will default to [this function](https://github.com/zeit/now/blob/52994bfe26c5f4f179bdb49783ee57ce19334631/packages/now-build-utils/src/should-serve.ts).
### Builder Options
The exported functions [`analyze`](#analyze), [`build`](#build), and [`prepareCache`](#preparecache) receive one argument with the following properties.
**Properties:**
- `files`: All source files of the project as a [Files](#files) data structure.
- `entrypoint`: Name of entrypoint file for this particular build job. Value `files[entrypoint]` is guaranteed to exist and be a valid [File](#files) reference. `entrypoint` is always a discrete file and never a glob, since globs are expanded into separate builds at deployment time.
- `workPath`: A writable temporary directory where you are encouraged to perform your build process. This directory will be populated with the restored cache from the previous run (if any) for [`analyze`](#analyze) and [`build`](#build).
- `cachePath`: A writable temporary directory where you can build a cache for the next run. This is only passed to `prepareCache`.
- `config`: An arbitrary object passed from by the user in the [Build definition](#defining-the-build-step) in `now.json`.
## Example: html-minifier
Let's walk through what it takes to create a simple builder that takes in a HTML source file and yields a minified HTML static file as its build output.
While this is a very simple builder, the approach demonstrated here can be used to return anything: one or more static files and/or one or more lambdas.
## Setting up the module
### Defining the analyze step
The `analyze` hook is optional. Its goal is to give the developer a tool to avoid wasting time _re-computing a build_ that has already occurred.
The return value of `analyze` is a _fingerprint_: a simple string that uniquely identifies the build process.
If `analyze` is not specified, its behavior is to use as the fingerprint the combined checksums of **all the files in the same directory level as the entrypoint**. This is a default that errs on making sure that we re-execute builds when files _other than the entrypoint_ (like dependencies, manifest files, etc) have changed.
For our `html-minify` example, we know that HTML files don't have dependencies. Therefore, our analyze step can just return the `digest` of the entrypoint.
Our `index.js` file looks as follows:
```js
exports.analyze = function({ files, entrypoint }) {
return files[entrypoint].digest
}
```
This means that we will only re-minify and re-create the build output _only if the file contents (and therefore its digest) change._
### Defining the build step
Your module will need some utilities to manipulate the data structures we pass you, create new ones and alter the filesystem.
To that end, we expose our API as part of a `@now/build-utils` package. This package is always loaded on your behalf, so make sure it's only included as `peerDependencies` in your `package.json`.
Builders can include dependencies of their liking:
```js
const htmlMinifier = require('html-minifier')
exports.version = 2
exports.analyze = ({ files, entrypoint }) => files[entrypoint].digest
exports.build = async ({ files, entrypoint, config }) => {
const stream = files[entrypoint].toStream()
const options = Object.assign({}, config || {})
const { data } = await FileBlob.fromStream({ stream })
const content = data.toString()
const minified = htmlMinifier(content, options)
const result = new FileBlob({ data: minified })
return {
output: {
[entrypoint]: result
},
watch: [],
routes: {}
}
}
```
### Defining a `prepareCache` step
If our builder had performed work that could be re-used in the next build invocation, we could define a `prepareCache` step.
In this case, there are not intermediate artifacts that we can cache, and our `analyze` step already takes care of caching the full output based on the fingerprint of the input.
## Technical Details
### Execution Context
A [Serverless Function](https://zeit.co/docs/v2/advanced/concepts/lambdas) is created where the builder logic is executed. The lambda is run using the Node.js 8 runtime. A brand new sandbox is created for each deployment, for security reasons. The sandbox is cleaned up between executions to ensure no lingering temporary files are shared from build to build.
All the APIs you export ([`analyze`](#analyze), [`build`](#build) and [`prepareCache`](#preparecache)) are not guaranteed to be run in the same process, but the filesystem we expose (e.g.: `workPath` and the results of calling [`getWriteableDirectory`](#getWriteableDirectory) ) is retained.
If you need to share state between those steps, use the filesystem.
### Directory and Cache Lifecycle
When a new build is created, we pre-populate the `workPath` supplied to `analyze` with the results of the `prepareCache` step of the previous build.
The `analyze` step can modify that directory, and it will not be re-created when it's supplied to `build` and `prepareCache`.
To learn how the cache key is computed and invalidated, refer to the [overview](https://zeit.co/docs/v2/advanced/builders#technical-details).
### Accessing Environment and Secrets
The env and secrets specified by the user as `build.env` are passed to the builder process. This means you can access user env via `process.env` in Node.js.
### Utilities as peerDependencies
When you publish your builder to npm, make sure to not specify `@now/build-utils` (as seen below in the API definitions) as a dependency, but rather as part of `peerDependencies`.
## Types
### `Files`
```ts
import { File } from '@now/build-utils'
type Files = { [filePath: string]: File }
```
This is an abstract type that is implemented as a plain [JavaScript Object](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object). It's helpful to think of it as a virtual filesystem representation.
When used as an input, the `Files` object will only contain `FileRefs`. When `Files` is an output, it may consist of `Lambda` (Serverless Functions) types as well as `FileRefs`.
An example of a valid output `Files` object is:
```json
{
"index.html": FileRef,
"api/index.js": Lambda
}
```
### `File`
This is an abstract type that can be imported if you are using TypeScript.
```ts
import { File } from '@now/build-utils'
```
Valid `File` types include:
- [`FileRef`](#fileref)
- [`FileFsRef`](#filefsref)
- [`FileBlob`](#fileblob)
### `FileRef`
```ts
import { FileRef } from '@now/build-utils'
```
This is a [JavaScript class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes) that represents an abstract file instance stored in our platform, based on the file identifier string (its checksum). When a `Files` object is passed as an input to `analyze` or `build`, all its values will be instances of `FileRef`.
**Properties:**
- `mode : Number` file mode
- `digest : String` a checksum that represents the file
**Methods:**
- `toStream() : Stream` creates a [Stream](https://nodejs.org/api/stream.html) of the file body
### `FileFsRef`
```ts
import { FileFsRef } from '@now/build-utils'
```
This is a [JavaScript class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes) that represents an abstract instance of a file present in the filesystem that the build process is executing in.
**Properties:**
- `mode : Number` file mode
- `fsPath : String` the absolute path of the file in file system
**Methods:**
- `static async fromStream({ mode : Number, stream : Stream, fsPath : String }) : FileFsRef` creates an instance of a [FileFsRef](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object) from `Stream`, placing file at `fsPath` with `mode`
- `toStream() : Stream` creates a [Stream](https://nodejs.org/api/stream.html) of the file body
### `FileBlob`
```ts
import { FileBlob } from '@now/build-utils'
```
This is a [JavaScript class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes) that represents an abstract instance of a file present in memory.
**Properties:**
- `mode : Number` file mode
- `data : String | Buffer` the body of the file
**Methods:**
- `static async fromStream({ mode : Number, stream : Stream }) :FileBlob` creates an instance of a [FileBlob](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object) from [`Stream`](https://nodejs.org/api/stream.html) with `mode`
- `toStream() : Stream` creates a [Stream](https://nodejs.org/api/stream.html) of the file body
### `Lambda`
```ts
import { Lambda } from '@now/build-utils'
```
This is a [JavaScript class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes), called a Serverless Function, that can be created by supplying `files`, `handler`, `runtime`, and `environment` as an object to the [`createLambda`](#createlambda) helper. The instances of this class should not be created directly. Instead use a call to [`createLambda`](#createlambda).
**Properties:**
- `files : Files` the internal filesystem of the lambda
- `handler : String` path to handler file and (optionally) a function name it exports
- `runtime : LambdaRuntime` the name of the lambda runtime
- `environment : Object` key-value map of handler-related (aside of those passed by user) environment variables
### `LambdaRuntime`
This is an abstract enumeration type that is implemented by one of the following possible `String` values:
- `nodejs10.x`
- `nodejs8.10`
- `go1.x`
- `java-1.8.0-openjdk`
- `python3.6`
- `python2.7`
- `dotnetcore2.1`
- `dotnetcore2.0`
- `dotnetcore1.0`
## JavaScript API
The following is exposed by `@now/build-utils` to simplify the process of writing Builders, manipulating the file system, using the above types, etc.
### `createLambda`
Signature: `createLambda(Object spec) : Lambda`
```ts
import { createLambda } from '@now/build-utils'
```
Constructor for the [`Lambda`](#lambda) type.
```js
const { createLambda, FileBlob } = require('@now/build-utils')
await createLambda({
runtime: 'nodejs8.10',
handler: 'index.main',
files: {
'index.js': new FileBlob({ data: 'exports.main = () => {}' })
}
})
```
### `download`
Signature: `download() : Files`
```ts
import { download } from '@now/build-utils'
```
This utility allows you to download the contents of a [`Files`](#files) data structure, therefore creating the filesystem represented in it.
Since `Files` is an abstract way of representing files, you can think of `download` as a way of making that virtual filesystem _real_.
If the **optional** `meta` property is passed (the argument for [build](#build)), only the files that have changed are downloaded. This is decided using `filesRemoved` and `filesChanged` inside that object.
```js
await download(files, workPath, meta)
```
### `glob`
Signature: `glob() : Files`
```ts
import { glob } from '@now/build-utils'
```
This utility allows you to _scan_ the filesystem and return a [`Files`](#files) representation of the matched glob search string. It can be thought of as the reverse of [`download`](#download).
The following trivial example downloads everything to the filesystem, only to return it back (therefore just re-creating the passed-in [`Files`](#files)):
```js
const { glob, download } = require('@now/build-utils')
exports.build = ({ files, workPath }) => {
await download(files, workPath)
return glob('**', workPath)
}
```
### `getWriteableDirectory`
Signature: `getWriteableDirectory() : String`
```ts
import { getWriteableDirectory } from '@now/build-utils'
```
In some occasions, you might want to write to a temporary directory.
### `rename`
Signature: `rename(Files) : Files`
```ts
import { rename } from '@now/build-utils'
```
Renames the keys of the [`Files`](#files) object, which represent the paths. For example, to remove the `*.go` suffix you can use:
```js
const rename = require('@now/build-utils')
const originalFiles = { 'one.go': fileFsRef1, 'two.go': fileFsRef2 }
const renamedFiles = rename(originalFiles, path => path.replace(/\.go$/, '')
```

190
LICENSE Normal file
View File

@@ -0,0 +1,190 @@
Apache License
Version 2.0, January 2004
https://www.apache.org/licenses/
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
1. Definitions.
"License" shall mean the terms and conditions for use, reproduction,
and distribution as defined by Sections 1 through 9 of this document.
"Licensor" shall mean the copyright owner or entity authorized by
the copyright owner that is granting the License.
"Legal Entity" shall mean the union of the acting entity and all
other entities that control, are controlled by, or are under common
control with that entity. For the purposes of this definition,
"control" means (i) the power, direct or indirect, to cause the
direction or management of such entity, whether by contract or
otherwise, or (ii) ownership of fifty percent (50%) or more of the
outstanding shares, or (iii) beneficial ownership of such entity.
"You" (or "Your") shall mean an individual or Legal Entity
exercising permissions granted by this License.
"Source" form shall mean the preferred form for making modifications,
including but not limited to software source code, documentation
source, and configuration files.
"Object" form shall mean any form resulting from mechanical
transformation or translation of a Source form, including but
not limited to compiled object code, generated documentation,
and conversions to other media types.
"Work" shall mean the work of authorship, whether in Source or
Object form, made available under the License, as indicated by a
copyright notice that is included in or attached to the work
(an example is provided in the Appendix below).
"Derivative Works" shall mean any work, whether in Source or Object
form, that is based on (or derived from) the Work and for which the
editorial revisions, annotations, elaborations, or other modifications
represent, as a whole, an original work of authorship. For the purposes
of this License, Derivative Works shall not include works that remain
separable from, or merely link (or bind by name) to the interfaces of,
the Work and Derivative Works thereof.
"Contribution" shall mean any work of authorship, including
the original version of the Work and any modifications or additions
to that Work or Derivative Works thereof, that is intentionally
submitted to Licensor for inclusion in the Work by the copyright owner
or by an individual or Legal Entity authorized to submit on behalf of
the copyright owner. For the purposes of this definition, "submitted"
means any form of electronic, verbal, or written communication sent
to the Licensor or its representatives, including but not limited to
communication on electronic mailing lists, source code control systems,
and issue tracking systems that are managed by, or on behalf of, the
Licensor for the purpose of discussing and improving the Work, but
excluding communication that is conspicuously marked or otherwise
designated in writing by the copyright owner as "Not a Contribution."
"Contributor" shall mean Licensor and any individual or Legal Entity
on behalf of whom a Contribution has been received by Licensor and
subsequently incorporated within the Work.
2. Grant of Copyright License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
copyright license to reproduce, prepare Derivative Works of,
publicly display, publicly perform, sublicense, and distribute the
Work and such Derivative Works in Source or Object form.
3. Grant of Patent License. Subject to the terms and conditions of
this License, each Contributor hereby grants to You a perpetual,
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
(except as stated in this section) patent license to make, have made,
use, offer to sell, sell, import, and otherwise transfer the Work,
where such license applies only to those patent claims licensable
by such Contributor that are necessarily infringed by their
Contribution(s) alone or by combination of their Contribution(s)
with the Work to which such Contribution(s) was submitted. If You
institute patent litigation against any entity (including a
cross-claim or counterclaim in a lawsuit) alleging that the Work
or a Contribution incorporated within the Work constitutes direct
or contributory patent infringement, then any patent licenses
granted to You under this License for that Work shall terminate
as of the date such litigation is filed.
4. Redistribution. You may reproduce and distribute copies of the
Work or Derivative Works thereof in any medium, with or without
modifications, and in Source or Object form, provided that You
meet the following conditions:
(a) You must give any other recipients of the Work or
Derivative Works a copy of this License; and
(b) You must cause any modified files to carry prominent notices
stating that You changed the files; and
(c) You must retain, in the Source form of any Derivative Works
that You distribute, all copyright, patent, trademark, and
attribution notices from the Source form of the Work,
excluding those notices that do not pertain to any part of
the Derivative Works; and
(d) If the Work includes a "NOTICE" text file as part of its
distribution, then any Derivative Works that You distribute must
include a readable copy of the attribution notices contained
within such NOTICE file, excluding those notices that do not
pertain to any part of the Derivative Works, in at least one
of the following places: within a NOTICE text file distributed
as part of the Derivative Works; within the Source form or
documentation, if provided along with the Derivative Works; or,
within a display generated by the Derivative Works, if and
wherever such third-party notices normally appear. The contents
of the NOTICE file are for informational purposes only and
do not modify the License. You may add Your own attribution
notices within Derivative Works that You distribute, alongside
or as an addendum to the NOTICE text from the Work, provided
that such additional attribution notices cannot be construed
as modifying the License.
You may add Your own copyright statement to Your modifications and
may provide additional or different license terms and conditions
for use, reproduction, or distribution of Your modifications, or
for any such Derivative Works as a whole, provided Your use,
reproduction, and distribution of the Work otherwise complies with
the conditions stated in this License.
5. Submission of Contributions. Unless You explicitly state otherwise,
any Contribution intentionally submitted for inclusion in the Work
by You to the Licensor shall be under the terms and conditions of
this License, without any additional terms or conditions.
Notwithstanding the above, nothing herein shall supersede or modify
the terms of any separate license agreement you may have executed
with Licensor regarding such Contributions.
6. Trademarks. This License does not grant permission to use the trade
names, trademarks, service marks, or product names of the Licensor,
except as required for reasonable and customary use in describing the
origin of the Work and reproducing the content of the NOTICE file.
7. Disclaimer of Warranty. Unless required by applicable law or
agreed to in writing, Licensor provides the Work (and each
Contributor provides its Contributions) on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied, including, without limitation, any warranties or conditions
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
PARTICULAR PURPOSE. You are solely responsible for determining the
appropriateness of using or redistributing the Work and assume any
risks associated with Your exercise of permissions under this License.
8. Limitation of Liability. In no event and under no legal theory,
whether in tort (including negligence), contract, or otherwise,
unless required by applicable law (such as deliberate and grossly
negligent acts) or agreed to in writing, shall any Contributor be
liable to You for damages, including any direct, indirect, special,
incidental, or consequential damages of any character arising as a
result of this License or out of the use or inability to use the
Work (including but not limited to damages for loss of goodwill,
work stoppage, computer failure or malfunction, or any and all
other commercial damages or losses), even if such Contributor
has been advised of the possibility of such damages.
9. Accepting Warranty or Additional Liability. While redistributing
the Work or Derivative Works thereof, You may choose to offer,
and charge a fee for, acceptance of support, warranty, indemnity,
or other liability obligations and/or rights consistent with this
License. However, in accepting such obligations, You may act only
on Your own behalf and on Your sole responsibility, not on behalf
of any other Contributor, and only if You agree to indemnify,
defend, and hold each Contributor harmless for any liability
incurred by, or claims asserted against, such Contributor by reason
of your accepting any such warranty or additional liability.
END OF TERMS AND CONDITIONS
Copyright 2017 ZEIT, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

43
PUBLISHING.md Normal file
View File

@@ -0,0 +1,43 @@
# Publishing to npm
Always publish to the Canary Channel as soon as a PR is merged into the `canary` branch.
```
yarn publish-canary
```
Publish the Stable Channel weekly.
- Cherry pick each commit from `canary` to `master` branch
- Verify that you are _in-sync_ with canary (with the exception of the `version` line in `package.json`)
- Deploy the modified Builders
```
# View differences excluding "Publish" commits
git checkout canary && git pull
git log --pretty=format:"$ad- %s [%an]" | grep -v Publish > ~/Desktop/canary.txt
git checkout master && git pull
git log --pretty=format:"$ad- %s [%an]" | grep -v Publish > ~/Desktop/master.txt
diff ~/Desktop/canary.txt ~/Desktop/master.txt
# Cherry pick all PRs from canary into master ...
git cherry-pick <PR501_COMMIT_SHA>
git cherry-pick <PR502_COMMIT_SHA>
git cherry-pick <PR503_COMMIT_SHA>
git cherry-pick <PR504_COMMIT_SHA>
# Verify the only difference is "version" in package.json
git diff origin/canary
# Generate release notes since previous publish
git log --pretty=format:"- %s [%an] %H" `git log --pretty=format:"%s %H" | grep "^Publish" | head -n 1 | awk '{ print $NF }'`...HEAD
# Ship it
yarn publish-stable
```
After running this publish step, GitHub Actions will take care of publishing the modified Builder packages to npm.
If for some reason GitHub Actions fails to publish the npm package, you may do so
manually by running `npm publish` from the package directory. Make sure to
use `npm publish --tag canary` if you are publishing a canary release!

41
README.md Normal file
View File

@@ -0,0 +1,41 @@
![now](https://assets.zeit.co/image/upload/v1542240976/repositories/now-cli/now-cli-repo-banner-v3.png)
[![Build Status](https://circleci.com/gh/zeit/now.svg?&style=shield)](https://circleci.com/gh/zeit/workflows/now)
[![Join the community on Spectrum](https://withspectrum.github.io/badge/badge.svg)](https://spectrum.chat/zeit)
**Note**: The [canary](https://github.com/zeit/now/tree/canary) branch is under heavy development the stable release branch is [master](https://github.com/zeit/now/tree/master).
## Usage
To install the latest version of Now CLI, visit [zeit.co/download](https://zeit.co/download) or run this command:
```
npm i -g now
```
To quickly start a new project, run the following commands:
```
now init # Pick an example project to clone
cd <PROJECT> # Change directory to the newly created project
now dev # Run locally during development
now # Deploy to the cloud
```
## Documentation
For details on how to use Now CLI, check out our [documentation](https://zeit.co/docs).
## Caught a Bug?
1. [Fork](https://help.github.com/articles/fork-a-repo/) this repository to your own GitHub account and then [clone](https://help.github.com/articles/cloning-a-repository/) it to your local device
2. Install dependencies with `yarn install`
3. Compile the code: `yarn build`
4. Link the package to the global module directory: `yarn link`
5. You can now start using `now` anywhere inside the command line
As always, you should use `yarn test-unit` to run the tests and see if your changes have broken anything.
## How to Create a Release
If you have write access to this repository, you can read more about how to publish a release [here](https://github.com/zeit/now/wiki/Creating-a-Release).

25
VERSIONING.md Normal file
View File

@@ -0,0 +1,25 @@
# Versioning
Builders are released to two different channels.
## Channels
| Channel | Git Branch | npm dist-tag | use example |
| ------- | ------------------------------------------------------------- | ------------ | ------------------ |
| Canary | [canary](https://github.com/zeit/now/commits/canary) | `@canary` | `@now/node@canary` |
| Stable | [master](https://github.com/zeit/now/commits/master) | `@latest` | `@now/node@latest` |
All PRs are submitted to the `canary` branch. Once a PR is merged into the `canary` branch, it should be published to npm immediately using the Canary Channel.
## Version Selection
Since Builders are published to [npmjs.com](https://npmjs.com), this makes versioning works the same for Builders as it does for any npm package. The `use` statement in [now.json](https://zeit.co/docs/v2/advanced/configuration#builds) has a similar syntax to `npm install`.
The following are valid examples [@now/node](https://www.npmjs.com/package/@now/node?activeTab=versions):
- `@now/node`
- `@now/node@0.7.3`
- `@now/node@canary`
- `@now/node@0.7.2-canary.2`
We always recommend using the latest version by leaving off the dist-tag suffix, `@now/node` for example.

View File

@@ -1,80 +0,0 @@
const { italic, bold } = require('chalk')
const error = require('../../lib/utils/output/error')
const wait = require('../../lib/utils/output/wait')
const cmd = require('../../lib/utils/output/cmd')
const param = require('../../lib/utils/output/param')
const info = require('../../lib/utils/output/info')
const uid = require('../../lib/utils/output/uid')
const success = require('../../lib/utils/output/success')
const stamp = require('../../lib/utils/output/stamp')
const promptBool = require('../../lib/utils/input/prompt-bool')
const eraseLines = require('../../lib/utils/output/erase-lines')
const treatBuyError = require('../../lib/utils/domains/treat-buy-error')
module.exports = async function({ domains, args, currentTeam, user }) {
const name = args[0]
let elapsed
if (!name) {
return error(`Missing domain name. Run ${cmd('now domains help')}`)
}
const nameParam = param(name)
elapsed = stamp()
let stopSpinner = wait(`Checking availability for ${nameParam}`)
let price
let period
try {
const json = await domains.price(name)
price = json.price
period = json.period
} catch (err) {
stopSpinner()
return error(err.message)
}
const available = await domains.status(name)
stopSpinner()
if (!available) {
return error(
`The domain ${nameParam} is ${italic('unavailable')}! ${elapsed()}`
)
}
const periodMsg = `${period}yr${period > 1 ? 's' : ''}`
info(
`The domain ${nameParam} is ${italic('available')} to buy under ${bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}! ${elapsed()}`
)
const confirmation = await promptBool(
`Buy now for ${bold(`$${price}`)} (${periodMsg})?`
)
eraseLines(1)
if (!confirmation) {
return info('Aborted')
}
stopSpinner = wait('Purchasing')
elapsed = stamp()
let domain
try {
domain = await domains.buy(name)
} catch (err) {
stopSpinner()
return treatBuyError(err)
}
stopSpinner()
success(`Domain purchased and created ${uid(domain.uid)} ${elapsed()}`)
info(
`You may now use your domain as an alias to your deployments. Run ${cmd(
'now alias --help'
)}`
)
}

View File

@@ -1,525 +0,0 @@
#!/usr/bin/env node
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
const table = require('text-table')
const ms = require('ms')
const printf = require('printf')
require('epipebomb')()
const supportsColor = require('supports-color')
// Ours
const strlen = require('../lib/strlen')
const NowAlias = require('../lib/alias')
const NowDomains = require('../lib/domains')
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { error } = require('../lib/error')
const toHost = require('../lib/to-host')
const { reAlias } = require('../lib/re-alias')
const exit = require('../lib/utils/exit')
const info = require('../lib/utils/output/info')
const logo = require('../lib/utils/output/logo')
const promptBool = require('../lib/utils/input/prompt-bool')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token', 'rules'],
boolean: ['help', 'debug'],
alias: {
help: 'h',
config: 'c',
rules: 'r',
debug: 'd',
token: 't'
}
})
const subcommand = argv._[0]
const grayWidth = 10
const underlineWidth = 11
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now alias`)} <ls | set | rm> <deployment> <alias>
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-r ${chalk.bold.underline('RULES_FILE')}, --rules=${chalk.bold.underline(
'RULES_FILE'
)} Rules file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Lists all your aliases:
${chalk.cyan('$ now alias ls')}
${chalk.gray('')} Adds a new alias to ${chalk.underline('my-api.now.sh')}:
${chalk.cyan(
`$ now alias set ${chalk.underline(
'api-ownv3nc9f8.now.sh'
)} ${chalk.underline('my-api.now.sh')}`
)}
The ${chalk.dim('`.now.sh`')} suffix can be ommited:
${chalk.cyan('$ now alias set api-ownv3nc9f8 my-api')}
The deployment id can be used as the source:
${chalk.cyan('$ now alias set deploymentId my-alias')}
Custom domains work as alias targets:
${chalk.cyan(
`$ now alias set ${chalk.underline(
'api-ownv3nc9f8.now.sh'
)} ${chalk.underline('my-api.com')}`
)}
${chalk.dim('')} The subcommand ${chalk.dim(
'`set`'
)} is the default and can be skipped.
${chalk.dim('')} ${chalk.dim(
'`http(s)://`'
)} in the URLs is unneeded / ignored.
${chalk.gray('')} Add and modify path based aliases for ${chalk.underline(
'zeit.ninja'
)}:
${chalk.cyan(
`$ now alias ${chalk.underline('zeit.ninja')} -r ${chalk.underline(
'rules.json'
)}`
)}
Export effective routing rules:
${chalk.cyan(
`$ now alias ls aliasId --json > ${chalk.underline('rules.json')}`
)}
${chalk.cyan(`$ now alias ls zeit.ninja`)}
${chalk.gray('')} Removing an alias:
${chalk.cyan('$ now alias rm aliasId')}
To get the list of alias ids, use ${chalk.dim('`now alias ls`')}.
${chalk.dim('Alias:')} ln
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err}\n${err.stack}`)
}
exit(1)
}
})
}
async function run({ token, config: { currentTeam, user } }) {
const alias = new NowAlias({ apiUrl, token, debug, currentTeam })
const domains = new NowDomains({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
switch (subcommand) {
case 'ls':
case 'list': {
if (args.length === 1) {
const list = await alias.listAliases()
const item = list.find(
e => e.uid === argv._[1] || e.alias === argv._[1]
)
if (!item || !item.rules) {
error(`Could not match path alias for: ${argv._[1]}`)
return exit(1)
}
if (argv.json) {
console.log(JSON.stringify({ rules: item.rules }, null, 2))
} else {
const header = [
['', 'pathname', 'method', 'dest'].map(s => chalk.dim(s))
]
const text = list.length === 0
? null
: table(
header.concat(
item.rules.map(rule => {
return [
'',
rule.pathname ? rule.pathname : '',
rule.method ? rule.method : '*',
rule.dest
]
})
),
{
align: ['l', 'l', 'l', 'l'],
hsep: ' '.repeat(2),
stringLength: strlen
}
)
console.log(text)
}
break
} else if (args.length !== 0) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan('`now alias ls`')}`
)
return exit(1)
}
const start_ = new Date()
const list = await alias.list()
const urls = new Map(list.map(l => [l.uid, l.url]))
const aliases = await alias.ls()
aliases.sort((a, b) => new Date(b.created) - new Date(a.created))
const current = new Date()
const sourceUrlLength =
aliases.reduce((acc, i) => {
return Math.max(
acc,
(i.deploymentId && urls.get(i.deploymentId).length) || 0
)
}, 0) + 9
const aliasLength =
aliases.reduce((acc, i) => {
return Math.max(acc, (i.alias && i.alias.length) || 0)
}, 0) + 8
const elapsed_ = ms(new Date() - start_)
console.log(
`> ${aliases.length} alias${aliases.length === 1
? ''
: 'es'} found ${chalk.gray(`[${elapsed_}]`)} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
console.log()
if (supportsColor) {
const urlSpecHeader = `%-${sourceUrlLength + 1}s`
const aliasSpecHeader = `%-${aliasLength + 1}s`
console.log(
printf(
` ${chalk.gray(urlSpecHeader + ' ' + aliasSpecHeader + ' %5s')}`,
'source',
'url',
'age'
)
)
} else {
const urlSpecHeader = `%-${sourceUrlLength}s`
const aliasSpecHeader = `%-${aliasLength}s`
console.log(
printf(
` ${urlSpecHeader} ${aliasSpecHeader} %5s`,
'source',
'url',
'age'
)
)
}
let text = ''
aliases.forEach(_alias => {
let urlSpec = sourceUrlLength
let aliasSpec = aliasLength
let ageSpec = 5
const _url = chalk.underline(`https://${_alias.alias}`)
const target = _alias.deploymentId
let _sourceUrl
if (supportsColor) {
aliasSpec += underlineWidth
ageSpec += grayWidth
}
if (urls.get(target)) {
_sourceUrl = chalk.underline(`https://${urls.get(target)}`)
if (supportsColor) {
urlSpec += grayWidth
}
} else if (_alias.rules) {
_sourceUrl = chalk.gray(
`[${_alias.rules.length} custom rule${_alias.rules.length > 1
? 's'
: ''}]`
)
if (supportsColor) {
urlSpec += underlineWidth
}
} else {
_sourceUrl = chalk.gray('<null>')
}
const time = chalk.gray(ms(current - new Date(_alias.created)))
text += printf(
` %-${urlSpec}s %-${aliasSpec}s %${ageSpec}s\n`,
_sourceUrl,
_url,
time
)
})
console.log(text)
break
}
case 'rm':
case 'remove': {
const _target = String(args[0])
if (!_target) {
const err = new Error('No alias id specified')
err.userError = true
throw err
}
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now alias rm <id>`'
)}`
)
return exit(1)
}
const _aliases = await alias.ls()
const _alias = findAlias(_target, _aliases)
if (!_alias) {
const err = new Error(
`Alias not found by "${_target}" under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}. Run ${chalk.dim('`now alias ls`')} to see your aliases.`
)
err.userError = true
throw err
}
try {
const confirmation = await confirmDeploymentRemoval(alias, _alias)
if (!confirmation) {
info('Aborted')
return process.exit(0)
}
const start = new Date()
await alias.rm(_alias)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Alias ${chalk.bold(
_alias.uid
)} removed [${elapsed}]`
)
} catch (err) {
error(err)
exit(1)
}
break
}
case 'add':
case 'set': {
if (argv.rules) {
await updatePathAlias(alias, argv._[0], argv.rules, domains)
break
}
if (args.length !== 2) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now alias set <id> <domain>`'
)}`
)
return exit(1)
}
await alias.set(
String(args[0]),
String(args[1]),
domains,
currentTeam,
user
)
break
}
default: {
if (argv._.length === 0) {
await reAlias(
token,
null,
null,
help,
exit,
apiUrl,
debug,
alias,
currentTeam,
user
)
break
}
if (argv.rules) {
await updatePathAlias(alias, argv._[0], argv.rules, domains)
break
}
if (argv._.length === 1) {
await reAlias(
token,
null,
String(argv._[0]),
help,
exit,
apiUrl,
debug,
alias,
currentTeam,
user
)
break
} else if (argv._.length === 2) {
await alias.set(
String(argv._[0]),
String(argv._[1]),
domains,
currentTeam,
user
)
} else if (argv._.length >= 3) {
error('Invalid number of arguments')
help()
exit(1)
} else {
error('Please specify a valid subcommand: ls | set | rm')
help()
exit(1)
}
}
}
domains.close()
alias.close()
}
async function confirmDeploymentRemoval(alias, _alias) {
const deploymentsList = await alias.list()
const urls = new Map(deploymentsList.map(l => [l.uid, l.url]))
const time = chalk.gray(ms(new Date() - new Date(_alias.created)) + ' ago')
const _sourceUrl = chalk.underline(`https://${urls.get(_alias.deploymentId)}`)
const tbl = table(
[
[_alias.uid, _sourceUrl, chalk.underline(`https://${_alias.alias}`), time]
],
{ align: ['l', 'r', 'l'], hsep: ' '.repeat(6) }
)
const msg =
'> The following alias will be removed permanently\n' +
` ${tbl} \nAre you sure?`
return promptBool(msg, {
trailing: '\n'
})
}
function findAlias(alias, list) {
let key
let val
if (/\./.test(alias)) {
val = toHost(alias)
key = 'alias'
} else {
val = alias
key = 'uid'
}
const _alias = list.find(d => {
if (d[key] === val) {
if (debug) {
console.log(`> [debug] matched alias ${d.uid} by ${key} ${val}`)
}
return true
}
// Match prefix
if (`${val}.now.sh` === d.alias) {
if (debug) {
console.log(`> [debug] matched alias ${d.uid} by url ${d.host}`)
}
return true
}
return false
})
return _alias
}
async function updatePathAlias(alias, aliasName, rules, domains) {
const start = new Date()
const res = await alias.updatePathBasedroutes(
String(aliasName),
rules,
domains
)
const elapsed = ms(new Date() - start)
if (res.error) {
const err = new Error(res.error.message)
err.userError = true
throw err
} else {
console.log(
`${chalk.cyan(
'> Success!'
)} ${res.ruleCount} rules configured for ${chalk.underline(
res.alias
)} [${elapsed}]`
)
}
}

View File

@@ -1,219 +0,0 @@
#!/usr/bin/env node
// Packages
const ansiEscapes = require('ansi-escapes')
const chalk = require('chalk')
const ccValidator = require('credit-card')
// Ours
const textInput = require('../lib/utils/input/text')
const countries = require('../lib/utils/billing/country-list')
const cardBrands = require('../lib/utils/billing/card-brands')
const geocode = require('../lib/utils/billing/geocode')
const success = require('../lib/utils/output/success')
const wait = require('../lib/utils/output/wait')
const { tick } = require('../lib/utils/output/chars')
const rightPad = require('../lib/utils/output/right-pad')
function expDateMiddleware(data) {
return data
}
module.exports = function({ creditCards, currentTeam, user }) {
const state = {
error: undefined,
cardGroupLabel: `> ${chalk.bold(
`Enter your card details for ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)}`,
name: {
label: rightPad('Full Name', 12),
placeholder: 'John Appleseed',
validateValue: data => data.trim().length > 0
},
cardNumber: {
label: rightPad('Number', 12),
mask: 'cc',
placeholder: '#### #### #### ####',
validateKeypress: (data, value) => /\d/.test(data) && value.length < 19,
validateValue: data => {
data = data.replace(/ /g, '')
const type = ccValidator.determineCardType(data)
if (!type) {
return false
}
return ccValidator.isValidCardNumber(data, type)
}
},
ccv: {
label: rightPad('CCV', 12),
mask: 'ccv',
placeholder: '###',
validateValue: data => {
const brand = state.cardNumber.brand.toLowerCase()
return ccValidator.doesCvvMatchType(data, brand)
}
},
expDate: {
label: rightPad('Exp. Date', 12),
mask: 'expDate',
placeholder: 'mm / yyyy',
middleware: expDateMiddleware,
validateValue: data => !ccValidator.isExpired(...data.split(' / '))
},
addressGroupLabel: `\n> ${chalk.bold('Enter your billing address')}`,
country: {
label: rightPad('Country', 12),
async autoComplete(value) {
for (const country in countries) {
if (!Object.hasOwnProperty.call(countries, country)) {
continue
}
if (country.startsWith(value)) {
return country.substr(value.length)
}
}
return false
},
validateValue: value => countries[value] !== undefined
},
zipCode: {
label: rightPad('ZIP', 12),
validadeKeypress: data => data.trim().length > 0,
validateValue: data => data.trim().length > 0
},
state: {
label: rightPad('State', 12),
validateValue: data => data.trim().length > 0
},
city: {
label: rightPad('City', 12),
validateValue: data => data.trim().length > 0
},
address1: {
label: rightPad('Address', 12),
validateValue: data => data.trim().length > 0
}
}
async function render() {
for (const key in state) {
if (!Object.hasOwnProperty.call(state, key)) {
continue
}
const piece = state[key]
if (typeof piece === 'string') {
console.log(piece)
} else if (typeof piece === 'object') {
let result
try {
/* eslint-disable no-await-in-loop */
result = await textInput({
label: '- ' + piece.label,
initialValue: piece.initialValue || piece.value,
placeholder: piece.placeholder,
mask: piece.mask,
validateKeypress: piece.validateKeypress,
validateValue: piece.validateValue,
autoComplete: piece.autoComplete
})
piece.value = result
if (key === 'cardNumber') {
let brand = cardBrands[ccValidator.determineCardType(result)]
piece.brand = brand
if (brand === 'American Express') {
state.ccv.placeholder = '#'.repeat(4)
} else {
state.ccv.placeholder = '#'.repeat(3)
}
brand = chalk.cyan(`[${brand}]`)
const masked = chalk.gray('#### '.repeat(3)) + result.split(' ')[3]
process.stdout.write(
`${chalk.cyan(tick)} ${piece.label}${masked} ${brand}\n`
)
} else if (key === 'ccv') {
process.stdout.write(
`${chalk.cyan(tick)} ${piece.label}${'*'.repeat(result.length)}\n`
)
} else if (key === 'expDate') {
let text = result.split(' / ')
text = text[0] + chalk.gray(' / ') + text[1]
process.stdout.write(`${chalk.cyan(tick)} ${piece.label}${text}\n`)
} else if (key === 'zipCode') {
const stopSpinner = wait(piece.label + result)
const addressInfo = await geocode({
country: state.country.value,
zipCode: result
})
if (addressInfo.state) {
state.state.initialValue = addressInfo.state
}
if (addressInfo.city) {
state.city.initialValue = addressInfo.city
}
stopSpinner()
process.stdout.write(
`${chalk.cyan(tick)} ${piece.label}${result}\n`
)
} else {
process.stdout.write(
`${chalk.cyan(tick)} ${piece.label}${result}\n`
)
}
} catch (err) {
if (err.message === 'USER_ABORT') {
process.exit(1)
} else {
console.error(err)
}
}
}
}
console.log('') // New line
const stopSpinner = wait('Saving card')
try {
const res = await creditCards.add({
name: state.name.value,
cardNumber: state.cardNumber.value,
ccv: state.ccv.value,
expDate: state.expDate.value,
country: state.country.value,
zipCode: state.zipCode.value,
state: state.state.value,
city: state.city.value,
address1: state.address1.value
})
stopSpinner()
success(
`${state.cardNumber
.brand} ending in ${res.last4} was added to ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
} catch (err) {
stopSpinner()
const linesToClear = state.error ? 13 : 12
process.stdout.write(ansiEscapes.eraseLines(linesToClear))
state.error = `${chalk.red(
'> Error!'
)} ${err.message} Please make sure the info is correct`
await render()
}
}
render().catch(console.error)
}

View File

@@ -1,378 +0,0 @@
#!/usr/bin/env node
// Native
const { resolve } = require('path')
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
const ms = require('ms')
// Ours
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { error } = require('../lib/error')
const NowCreditCards = require('../lib/credit-cards')
const indent = require('../lib/indent')
const listInput = require('../lib/utils/input/list')
const success = require('../lib/utils/output/success')
const promptBool = require('../lib/utils/input/prompt-bool')
const info = require('../lib/utils/output/info')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't'
}
})
const subcommand = argv._[0]
const help = () => {
console.log(`
${chalk.bold(`${logo} now billing`)} <ls | add | rm | set-default>
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Lists all your credit cards:
${chalk.cyan('$ now billing ls')}
${chalk.gray('')} Adds a credit card (interactively):
${chalk.cyan(`$ now billing add`)}
${chalk.gray('')} Removes a credit card:
${chalk.cyan(`$ now billing rm <id>`)}
${chalk.gray('')} If the id is omitted, you can choose interactively
${chalk.gray('')} Selects your default credit card:
${chalk.cyan(`$ now billing set-default <id>`)}
${chalk.gray('')} If the id is omitted, you can choose interactively
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
const exit = code => {
// We give stdout some time to flush out
// because there's a node bug where
// stdout writes are asynchronous
// https://github.com/nodejs/node/issues/6456
setTimeout(() => process.exit(code || 0), 100)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err.stack}`)
}
exit(1)
}
})
}
// Builds a `choices` object that can be passesd to inquirer.prompt()
function buildInquirerChoices(cards) {
return cards.cards.map(card => {
const _default = card.id === cards.defaultCardId
? ' ' + chalk.bold('(default)')
: ''
const id = `${chalk.cyan(`ID: ${card.id}`)}${_default}`
const number = `${chalk.gray('#### ').repeat(3)}${card.last4}`
const str = [
id,
indent(card.name, 2),
indent(`${card.brand} ${number}`, 2)
].join('\n')
return {
name: str, // Will be displayed by Inquirer
value: card.id, // Will be used to identify the answer
short: card.id // Will be displayed after the users answers
}
})
}
async function run({ token, config: { currentTeam, user } }) {
const start = new Date()
const creditCards = new NowCreditCards({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
switch (subcommand) {
case 'ls':
case 'list': {
let cards
try {
cards = await creditCards.ls()
} catch (err) {
error(err.message)
return
}
const text = cards.cards
.map(card => {
const _default = card.id === cards.defaultCardId
? ' ' + chalk.bold('(default)')
: ''
const id = `${chalk.gray('-')} ${chalk.cyan(
`ID: ${card.id}`
)}${_default}`
const number = `${chalk.gray('#### ').repeat(3)}${card.last4}`
let address = card.address_line1
if (card.address_line2) {
address += `, ${card.address_line2}.`
} else {
address += '.'
}
address += `\n${card.address_city}, `
if (card.address_state) {
address += `${card.address_state}, `
}
// Stripe is returning a two digit code for the country,
// but we want the full country name
address += `${card.address_zip}. ${card.address_country}`
return [
id,
indent(card.name, 2),
indent(`${card.brand} ${number}`, 2),
indent(address, 2)
].join('\n')
})
.join('\n\n')
const elapsed = ms(new Date() - start)
console.log(
`> ${cards.cards.length} card${cards.cards.length === 1
? ''
: 's'} found under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed}]`)}`
)
if (text) {
console.log(`\n${text}\n`)
}
break
}
case 'set-default': {
if (args.length > 1) {
error('Invalid number of arguments')
return exit(1)
}
const start = new Date()
let cards
try {
cards = await creditCards.ls()
} catch (err) {
error(err.message)
return
}
if (cards.cards.length === 0) {
error('You have no credit cards to choose from')
return exit(0)
}
let cardId = args[0]
if (cardId === undefined) {
const elapsed = ms(new Date() - start)
const message = `Selecting a new default payment card for ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed}]`)}`
const choices = buildInquirerChoices(cards)
cardId = await listInput({
message,
choices,
separator: true,
abort: 'end'
})
}
// Check if the provided cardId (in case the user
// typed `now billing set-default <some-id>`) is valid
if (cardId) {
const label = `Are you sure that you to set this card as the default?`
const confirmation = await promptBool(label, {
trailing: '\n'
})
if (!confirmation) {
info('Aborted')
break
}
const start = new Date()
await creditCards.setDefault(cardId)
const card = cards.cards.find(card => card.id === cardId)
const elapsed = ms(new Date() - start)
success(
`${card.brand} ending in ${card.last4} is now the default ${chalk.gray(
`[${elapsed}]`
)}`
)
} else {
console.log('No changes made')
}
break
}
case 'rm':
case 'remove': {
if (args.length > 1) {
error('Invalid number of arguments')
return exit(1)
}
const start = new Date()
let cards
try {
cards = await creditCards.ls()
} catch (err) {
error(err.message)
return
}
if (cards.cards.length === 0) {
error(
`You have no credit cards to choose from to delete under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
return exit(0)
}
let cardId = args[0]
if (cardId === undefined) {
const elapsed = ms(new Date() - start)
const message = `Selecting a card to ${chalk.underline(
'remove'
)} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed}]`)}`
const choices = buildInquirerChoices(cards)
cardId = await listInput({
message,
choices,
separator: true,
abort: 'start'
})
}
// Shoud check if the provided cardId (in case the user
// typed `now billing rm <some-id>`) is valid
if (cardId) {
const label = `Are you sure that you want to remove this card?`
const confirmation = await promptBool(label)
if (!confirmation) {
console.log('Aborted')
break
}
const start = new Date()
await creditCards.rm(cardId)
const deletedCard = cards.cards.find(card => card.id === cardId)
const remainingCards = cards.cards.filter(card => card.id !== cardId)
let text = `${deletedCard.brand} ending in ${deletedCard.last4} was deleted`
// ${chalk.gray(`[${elapsed}]`)}
if (cardId === cards.defaultCardId) {
if (remainingCards.length === 0) {
// The user deleted the last card in their account
text += `\n${chalk.yellow('Warning!')} You have no default card`
} else {
// We can't guess the current default card let's ask the API
const cards = await creditCards.ls()
const newDefaultCard = cards.cards.find(
card => card.id === cards.defaultCardId
)
text += `\n${newDefaultCard.brand} ending in ${newDefaultCard.last4} in now default for ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
}
}
const elapsed = ms(new Date() - start)
text += ` ${chalk.gray(`[${elapsed}]`)}`
success(text)
} else {
console.log('No changes made')
}
break
}
case 'add': {
require(resolve(__dirname, 'now-billing-add.js'))({
creditCards,
currentTeam,
user
})
break
}
default:
error('Please specify a valid subcommand: ls | add | rm | set-default')
help()
exit(1)
}
creditCards.close()
}

View File

@@ -1,379 +0,0 @@
#!/usr/bin/env node
// Native
const path = require('path')
// Packages
const chalk = require('chalk')
const table = require('text-table')
const minimist = require('minimist')
const fs = require('fs-extra')
const ms = require('ms')
const printf = require('printf')
require('epipebomb')()
const supportsColor = require('supports-color')
// Ours
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const NowCerts = require('../lib/certs')
const login = require('../lib/login')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token', 'crt', 'key', 'ca'],
boolean: ['help', 'debug'],
alias: { help: 'h', config: 'c', debug: 'd', token: 't' }
})
const subcommand = argv._[0]
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now certs`)} <ls | create | renew | replace | rm> <cn>
${chalk.dim('Note:')}
This command is intended for advanced use only, normally ${chalk.bold(
'now'
)} manages your certificates automatically.
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
--crt ${chalk.bold.underline('FILE')} Certificate file
--key ${chalk.bold.underline('FILE')} Certificate key file
--ca ${chalk.bold.underline('FILE')} CA certificate chain file
${chalk.dim('Examples:')}
${chalk.gray('')} Listing all your certificates:
${chalk.cyan('$ now certs ls')}
${chalk.gray('')} Creating a new certificate:
${chalk.cyan('$ now certs create domain.com')}
${chalk.gray('')} Renewing an existing certificate issued with ${chalk.bold(
'now'
)}:
${chalk.cyan('$ now certs renew domain.com')}
${chalk.gray(
''
)} Replacing an existing certificate with a user-supplied certificate:
${chalk.cyan(
'$ now certs replace --crt domain.crt --key domain.key --ca ca_chain.crt domain.com'
)}
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
handleError(err)
exit(1)
}
})
}
function formatExpirationDate(date) {
const diff = date - Date.now()
return diff < 0
? chalk.gray(ms(-diff) + ' ago')
: chalk.gray('in ' + ms(diff))
}
async function run({ token, config: { currentTeam, user } }) {
const certs = new NowCerts({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
const start = Date.now()
if (subcommand === 'ls' || subcommand === 'list') {
if (args.length !== 0) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan('`now certs ls`')}`
)
return exit(1)
}
const list = await certs.ls()
const elapsed = ms(new Date() - start)
console.log(
`> ${list.length} certificate${list.length === 1
? ''
: 's'} found ${chalk.gray(`[${elapsed}]`)} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
if (list.length > 0) {
const cur = Date.now()
list.sort((a, b) => {
return a.cn.localeCompare(b.cn)
})
const maxCnLength =
list.reduce((acc, i) => {
return Math.max(acc, (i.cn && i.cn.length) || 0)
}, 0) + 1
console.log(
chalk.dim(
printf(
` %-${maxCnLength}s %-8s %-10s %-10s`,
'cn',
'created',
'expiration',
'auto-renew'
)
)
)
list.forEach(cert => {
const cn = chalk.bold(cert.cn)
const time = chalk.gray(ms(cur - new Date(cert.created)) + ' ago')
const expiration = formatExpirationDate(new Date(cert.expiration))
const autoRenew = cert.autoRenew ? 'yes' : 'no'
let spec
if (supportsColor) {
spec = ` %-${maxCnLength + 9}s %-18s %-20s %-20s\n`
} else {
spec = ` %-${maxCnLength}s %-8s %-10s %-10s\n`
}
process.stdout.write(printf(spec, cn, time, expiration, autoRenew))
})
}
} else if (subcommand === 'create') {
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now certs create <cn>`'
)}`
)
return exit(1)
}
const cn = args[0]
let cert
if (argv.crt || argv.key || argv.ca) {
// Issue a custom certificate
if (!argv.crt || !argv.key) {
error(
`Missing required arguments for a custom certificate entry. Usage: ${chalk.cyan(
'`now certs create --crt DOMAIN.CRT --key DOMAIN.KEY [--ca CA.CRT] <id | cn>`'
)}`
)
return exit(1)
}
const crt = readX509File(argv.crt)
const key = readX509File(argv.key)
const ca = argv.ca ? readX509File(argv.ca) : ''
cert = await certs.put(cn, crt, key, ca)
} else {
// Issue a standard certificate
cert = await certs.create(cn)
}
if (!cert) {
// Cert is undefined and "Cert is already issued" has been printed to stdout
return exit(1)
}
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Certificate entry ${chalk.bold(
cn
)} ${chalk.gray(`(${cert.uid})`)} created ${chalk.gray(`[${elapsed}]`)}`
)
} else if (subcommand === 'renew') {
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now certs renew <id | cn>`'
)}`
)
return exit(1)
}
const cert = await getCertIdCn(certs, args[0], currentTeam, user)
if (!cert) {
return exit(1)
}
const yes = await readConfirmation(
cert,
'The following certificate will be renewed\n'
)
if (!yes) {
error('User abort')
return exit(0)
}
await certs.renew(cert.cn)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Certificate ${chalk.bold(
cert.cn
)} ${chalk.gray(`(${cert.uid})`)} renewed ${chalk.gray(`[${elapsed}]`)}`
)
} else if (subcommand === 'replace') {
if (!argv.crt || !argv.key) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now certs replace --crt DOMAIN.CRT --key DOMAIN.KEY [--ca CA.CRT] <id | cn>`'
)}`
)
return exit(1)
}
const crt = readX509File(argv.crt)
const key = readX509File(argv.key)
const ca = argv.ca ? readX509File(argv.ca) : ''
const cert = await getCertIdCn(certs, args[0], currentTeam, user)
if (!cert) {
return exit(1)
}
const yes = await readConfirmation(
cert,
'The following certificate will be replaced permanently\n'
)
if (!yes) {
error('User abort')
return exit(0)
}
await certs.put(cert.cn, crt, key, ca)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Certificate ${chalk.bold(
cert.cn
)} ${chalk.gray(`(${cert.uid})`)} replaced ${chalk.gray(`[${elapsed}]`)}`
)
} else if (subcommand === 'rm' || subcommand === 'remove') {
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now certs rm <id | cn>`'
)}`
)
return exit(1)
}
const cert = await getCertIdCn(certs, args[0], currentTeam, user)
if (!cert) {
return exit(1)
}
const yes = await readConfirmation(
cert,
'The following certificate will be removed permanently\n'
)
if (!yes) {
error('User abort')
return exit(0)
}
await certs.delete(cert.cn)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Certificate ${chalk.bold(
cert.cn
)} ${chalk.gray(`(${cert.uid})`)} removed ${chalk.gray(`[${elapsed}]`)}`
)
} else {
error(
'Please specify a valid subcommand: ls | create | renew | replace | rm'
)
help()
exit(1)
}
return certs.close()
}
process.on('uncaughtException', err => {
handleError(err)
exit(1)
})
function readConfirmation(cert, msg) {
return new Promise(resolve => {
const time = chalk.gray(ms(new Date() - new Date(cert.created)) + ' ago')
const tbl = table([[cert.uid, chalk.bold(cert.cn), time]], {
align: ['l', 'r', 'l'],
hsep: ' '.repeat(6)
})
process.stdout.write(`> ${msg}`)
process.stdout.write(' ' + tbl + '\n')
process.stdout.write(
`${chalk.bold.red('> Are you sure?')} ${chalk.gray('[y/N] ')}`
)
process.stdin
.on('data', d => {
process.stdin.pause()
resolve(d.toString().trim().toLowerCase() === 'y')
})
.resume()
})
}
function readX509File(file) {
return fs.readFileSync(path.resolve(file), 'utf8')
}
async function getCertIdCn(certs, idOrCn, currentTeam, user) {
const list = await certs.ls()
const thecert = list.filter(cert => {
return cert.uid === idOrCn || cert.cn === idOrCn
})[0]
if (!thecert) {
error(
`No certificate found by id or cn "${idOrCn}" under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
return null
}
return thecert
}

View File

@@ -1,829 +0,0 @@
#!/usr/bin/env node
// Native
const { resolve } = require('path')
// Packages
const Progress = require('progress')
const fs = require('fs-extra')
const bytes = require('bytes')
const chalk = require('chalk')
const minimist = require('minimist')
const ms = require('ms')
const flatten = require('arr-flatten')
const dotenv = require('dotenv')
const { eraseLines } = require('ansi-escapes')
const { write: copy } = require('clipboardy')
// Ours
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { version } = require('../lib/pkg')
const Logger = require('../lib/build-logger')
const Now = require('../lib')
const toHumanPath = require('../lib/utils/to-human-path')
const { handleError, error } = require('../lib/error')
const { fromGit, isRepoPath, gitPathParts } = require('../lib/git')
const readMetaData = require('../lib/read-metadata')
const checkPath = require('../lib/utils/check-path')
const { reAlias, assignAlias } = require('../lib/re-alias')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const cmd = require('../lib/utils/output/cmd')
const info = require('../lib/utils/output/info')
const wait = require('../lib/utils/output/wait')
const NowPlans = require('../lib/plans')
const promptBool = require('../lib/utils/input/prompt-bool')
const promptOptions = require('../lib/utils/input/prompt-options')
const note = require('../lib/utils/output/note')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token', 'name', 'alias', 'session-affinity'],
boolean: [
'help',
'version',
'debug',
'force',
'links',
'login',
'no-clipboard',
'forward-npm',
'docker',
'npm',
'static'
],
alias: {
env: 'e',
dotenv: 'E',
help: 'h',
config: 'c',
debug: 'd',
version: 'v',
force: 'f',
token: 't',
forceSync: 'F',
links: 'l',
login: 'L',
public: 'p',
'no-clipboard': 'C',
'forward-npm': 'N',
'session-affinity': 'S',
name: 'n',
alias: 'a'
}
})
const help = () => {
console.log(`
${chalk.bold(`${logo} now`)} [options] <command | path>
${chalk.dim('Commands:')}
${chalk.dim('Cloud')}
deploy [path] Performs a deployment ${chalk.bold(
'(default)'
)}
ls | list [app] List deployments
rm | remove [id] Remove a deployment
ln | alias [id] [url] Configures aliases for deployments
domains [name] Manages your domain names
certs [cmd] Manages your SSL certificates
secrets [name] Manages your secret environment variables
dns [name] Manages your DNS records
logs [url] Displays the logs for a deployment
scale [args] Scales the instance count of a deployment
help [cmd] Displays complete help for [cmd]
${chalk.dim('Administrative')}
billing | cc [cmd] Manages your credit cards and billing methods
upgrade | downgrade [plan] Upgrades or downgrades your plan
teams [team] Manages your teams
switch Switches between teams and your account
login Login into your account or creates a new one
logout Logout from your account
${chalk.dim('Options:')}
-h, --help Output usage information
-v, --version Output the version number
-n, --name Set the name of the deployment
-c ${chalk.underline('FILE')}, --config=${chalk.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-f, --force Force a new deployment even if nothing has changed
-t ${chalk.underline('TOKEN')}, --token=${chalk.underline(
'TOKEN'
)} Login token
-L, --login Configure login
-l, --links Copy symlinks without resolving their target
-p, --public Deployment is public (${chalk.dim(
'`/_src`'
)} is exposed) [on for oss, off for premium]
-e, --env Include an env var (e.g.: ${chalk.dim(
'`-e KEY=value`'
)}). Can appear many times.
-E ${chalk.underline('FILE')}, --dotenv=${chalk.underline(
'FILE'
)} Include env vars from .env file. Defaults to '.env'
-C, --no-clipboard Do not attempt to copy URL to clipboard
-N, --forward-npm Forward login information to install private npm modules
--session-affinity Session affinity, \`ip\` (default) or \`random\` to control session affinity.
${chalk.dim(
'Enforcable Types (when both package.json and Dockerfile exist):'
)}
--npm Node.js application
--docker Docker container
--static Static file hosting
${chalk.dim('Examples:')}
${chalk.gray('')} Deploys the current directory
${chalk.cyan('$ now')}
${chalk.gray('')} Deploys a custom path ${chalk.dim('`/usr/src/project`')}
${chalk.cyan('$ now /usr/src/project')}
${chalk.gray('')} Deploys a GitHub repository
${chalk.cyan('$ now user/repo#ref')}
${chalk.gray('')} Deploys a GitHub, GitLab or Bitbucket repo using its URL
${chalk.cyan('$ now https://gitlab.com/user/repo')}
${chalk.gray('')} Deploys with ENV vars
${chalk.cyan(
'$ now -e NODE_ENV=production -e MYSQL_PASSWORD=@mysql-password'
)}
${chalk.gray('')} Displays comprehensive help for the subcommand ${chalk.dim(
'`list`'
)}
${chalk.cyan('$ now help list')}
`)
}
let path = argv._[0]
if (path) {
// If path is relative: resolve
// if path is absolute: clear up strange `/` etc
path = resolve(process.cwd(), path)
} else {
path = process.cwd()
}
// If the current deployment is a repo
const gitRepo = {}
// Options
let forceNew = argv.force
let deploymentName = argv.name
let sessionAffinity = argv['session-affinity']
const debug = argv.debug
const clipboard = !argv['no-clipboard']
const forwardNpm = argv['forward-npm']
const forceSync = argv.forceSync
const shouldLogin = argv.login
const followSymlinks = !argv.links
const wantsPublic = argv.public
const apiUrl = argv.url || 'https://api.zeit.co'
const isTTY = process.stdout.isTTY
const quiet = !isTTY
const autoAliases = typeof argv.alias === 'undefined'
? false
: flatten([argv.alias])
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (Array.isArray(autoAliases)) {
console.log(
`${chalk.red('Deprecated!')} The option ${chalk.grey(
'--alias'
)} will be removed soon.`
)
console.log('Read more about the new way here: http://bit.ly/2l2v5Fg\n')
}
const stopDeployment = msg => {
handleError(msg)
process.exit(1)
}
// Create a new deployment if user changed the name or made `_src` public.
// This works fine because it doesn't force a new sync,
// it just forces a new deployment.
if (deploymentName || wantsPublic) {
forceNew = true
}
let alwaysForwardNpm
async function main() {
let config = await cfg.read({ token: argv.token })
alwaysForwardNpm = config.forwardNpm
if (argv.h || argv.help) {
help()
return exit(0)
} else if (argv.v || argv.version) {
console.log(version)
return exit(0)
}
let token = argv.token || config.token
if (!token || shouldLogin) {
try {
token = await login(apiUrl)
config = await cfg.read()
} catch (err) {
return stopDeployment(`Authentication error ${err.message}`)
}
console.log(
`> Logged in successfully. Token saved to ${chalk.bold('~/.now.json')}.`
)
console.log(
`> Run ${cmd('now')} to deploy the current directory, or ${cmd(
'now --help'
)} for usage info.\n`
)
return exit(0)
}
// If we got to here then `token` should be set
try {
await sync({ token, config })
} catch (err) {
return stopDeployment(err)
}
}
async function sync({ token, config: { currentTeam, user } }) {
const start = Date.now()
const rawPath = argv._[0]
const planPromise = new NowPlans({
apiUrl,
token,
debug,
currentTeam
}).getCurrent()
try {
await fs.stat(path)
} catch (err) {
let repo
let isValidRepo = false
try {
isValidRepo = isRepoPath(rawPath)
} catch (err) {
if (err.code === 'INVALID_URL') {
stopDeployment(err)
} else {
throw err
}
}
if (isValidRepo) {
const gitParts = gitPathParts(rawPath)
Object.assign(gitRepo, gitParts)
const searchMessage = setTimeout(() => {
console.log(`> Didn't find directory. Searching on ${gitRepo.type}...`)
}, 500)
try {
repo = await fromGit(rawPath, debug)
} catch (err) {}
clearTimeout(searchMessage)
}
if (repo) {
// Tell now which directory to deploy
path = repo.path
// Set global variable for deleting tmp dir later
// once the deployment has finished
Object.assign(gitRepo, repo)
} else if (isValidRepo) {
const gitRef = gitRepo.ref ? `with "${chalk.bold(gitRepo.ref)}" ` : ''
stopDeployment(
`There's no repository named "${chalk.bold(
gitRepo.main
)}" ${gitRef}on ${gitRepo.type}`
)
} else {
stopDeployment(`Could not read directory ${chalk.bold(path)}`)
}
}
// Make sure that directory is deployable
try {
await checkPath(path)
} catch (err) {
error(err)
return
}
if (!quiet) {
if (gitRepo.main) {
const gitRef = gitRepo.ref ? ` at "${chalk.bold(gitRepo.ref)}" ` : ''
console.log(
`> Deploying ${gitRepo.type} repository "${chalk.bold(
gitRepo.main
)}" ${gitRef} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
} else {
console.log(
`> Deploying ${chalk.bold(toHumanPath(path))} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
}
}
let deploymentType
// CLI deployment type explicit overrides
if (argv.docker) {
if (debug) {
console.log(`> [debug] Forcing \`deploymentType\` = \`docker\``)
}
deploymentType = 'docker'
} else if (argv.npm) {
if (debug) {
console.log(`> [debug] Forcing \`deploymentType\` = \`npm\``)
}
deploymentType = 'npm'
} else if (argv.static) {
if (debug) {
console.log(`> [debug] Forcing \`deploymentType\` = \`static\``)
}
deploymentType = 'static'
}
let meta
;({ meta, deploymentName, deploymentType, sessionAffinity } = await readMeta(
path,
deploymentName,
deploymentType,
sessionAffinity
))
const nowConfig = meta.nowConfig
const now = new Now({ apiUrl, token, debug, currentTeam })
let dotenvConfig
let dotenvOption
if (argv.dotenv) {
dotenvOption = argv.dotenv
} else if (nowConfig && nowConfig.dotenv) {
dotenvOption = nowConfig.dotenv
}
if (dotenvOption) {
const dotenvFileName = typeof dotenvOption === 'string'
? dotenvOption
: '.env'
if (!fs.existsSync(dotenvFileName)) {
error(`--dotenv flag is set but ${dotenvFileName} file is missing`)
return process.exit(1)
}
const dotenvFile = await fs.readFile(dotenvFileName)
dotenvConfig = dotenv.parse(dotenvFile)
}
// Merge `now.env` from package.json with `-e` arguments.
const pkgEnv = nowConfig && nowConfig.env
const envs = [
...Object.keys(dotenvConfig || {}).map(k => `${k}=${dotenvConfig[k]}`),
...Object.keys(pkgEnv || {}).map(k => `${k}=${pkgEnv[k]}`),
...[].concat(argv.env || [])
]
let secrets
const findSecret = async uidOrName => {
if (!secrets) {
secrets = await now.listSecrets()
}
return secrets.filter(secret => {
return secret.name === uidOrName || secret.uid === uidOrName
})
}
const env_ = await Promise.all(
envs.map(async kv => {
if (typeof kv !== 'string') {
error('Env key and value missing')
return process.exit(1)
}
const [key, ...rest] = kv.split('=')
let val
if (rest.length > 0) {
val = rest.join('=')
}
if (/[^A-z0-9_]/i.test(key)) {
error(
`Invalid ${chalk.dim('-e')} key ${chalk.bold(
`"${chalk.bold(key)}"`
)}. Only letters, digits and underscores are allowed.`
)
return process.exit(1)
}
if (!key) {
error(`Invalid env option ${chalk.bold(`"${kv}"`)}`)
return process.exit(1)
}
if (val === undefined) {
if (key in process.env) {
console.log(
`> Reading ${chalk.bold(
`"${chalk.bold(key)}"`
)} from your env (as no value was specified)`
)
// Escape value if it begins with @
val = process.env[key].replace(/^@/, '\\@')
} else {
error(
`No value specified for env ${chalk.bold(
`"${chalk.bold(key)}"`
)} and it was not found in your env.`
)
return process.exit(1)
}
}
if (val[0] === '@') {
const uidOrName = val.substr(1)
const secrets = await findSecret(uidOrName)
if (secrets.length === 0) {
if (uidOrName === '') {
error(
`Empty reference provided for env key ${chalk.bold(
`"${chalk.bold(key)}"`
)}`
)
} else {
error(
`No secret found by uid or name ${chalk.bold(`"${uidOrName}"`)}`
)
}
return process.exit(1)
} else if (secrets.length > 1) {
error(
`Ambiguous secret ${chalk.bold(
`"${uidOrName}"`
)} (matches ${chalk.bold(secrets.length)} secrets)`
)
return process.exit(1)
}
val = { uid: secrets[0].uid }
}
return [key, typeof val === 'string' ? val.replace(/^\\@/, '@') : val]
})
)
const env = {}
env_.filter(v => Boolean(v)).forEach(([key, val]) => {
if (key in env) {
note(`Overriding duplicate env key ${chalk.bold(`"${key}"`)}`)
}
env[key] = val
})
try {
await now.create(
path,
Object.assign(
{
env,
followSymlinks,
forceNew,
forceSync,
forwardNpm: alwaysForwardNpm || forwardNpm,
quiet,
wantsPublic,
sessionAffinity
},
meta
)
)
} catch (err) {
if (debug) {
console.log(`> [debug] error: ${err}\n${err.stack}`)
}
return stopDeployment(err)
}
const { url } = now
const elapsed = ms(new Date() - start)
if (isTTY) {
if (clipboard) {
try {
await copy(url)
console.log(
`${chalk.cyan('> Ready!')} ${chalk.bold(
url
)} (copied to clipboard) [${elapsed}]`
)
} catch (err) {
console.log(`${chalk.cyan('> Ready!')} ${chalk.bold(url)} [${elapsed}]`)
}
} else {
console.log(`> ${url} [${elapsed}]`)
}
} else {
process.stdout.write(url)
}
const startU = new Date()
const complete = ({ syncCount }) => {
if (!quiet) {
const elapsedU = ms(new Date() - startU)
console.log(
`> Synced ${syncCount} (${bytes(now.syncAmount)}) [${elapsedU}] `
)
console.log('> Initializing…')
}
// Close http2 agent
now.close()
// Show build logs
if (!quiet) {
if (deploymentType === 'static') {
console.log(`${chalk.cyan('> Deployment complete!')}`)
} else {
printLogs(now.host, token, currentTeam, user)
}
}
}
const plan = await planPromise
if (plan.id === 'oss' && !wantsPublic) {
if (isTTY) {
info(
`${chalk.bold(
(currentTeam && `${currentTeam.slug} is`) ||
`You (${user.username || user.email}) are`
)} on the OSS plan. Your code and logs will be made ${chalk.bold(
'public'
)}.`
)
const proceed = await promptBool(
'Are you sure you want to proceed with the deployment?',
{ trailing: eraseLines(1) }
)
if (proceed) {
note(`You can use ${cmd('now --public')} to skip this prompt`)
} else {
const stopSpinner = wait('Canceling deployment')
await now.remove(now.id, { hard: true })
stopSpinner()
info('Deployment aborted. No files were synced.')
info(`You can upgrade by running ${cmd('now upgrade')}.`)
return exit()
}
} else if (!wantsPublic) {
const msg =
'\nYou are on the OSS plan. Your code and logs will be made public.' +
' If you agree with that, please run again with --public.'
return stopDeployment(msg)
}
}
if (now.syncAmount) {
if (debug && now.syncFileCount !== now.fileCount) {
console.log(
`> [debug] total files ${now.fileCount}, ${now.syncFileCount} changed. `
)
}
const size = bytes(now.syncAmount)
const syncCount = `${now.syncFileCount} file${now.syncFileCount > 1
? 's'
: ''}`
const bar = new Progress(
`> Upload [:bar] :percent :etas (${size}) [${syncCount}]`,
{
width: 20,
complete: '=',
incomplete: '',
total: now.syncAmount,
clear: true
}
)
now.upload()
now.on('upload', ({ names, data }) => {
const amount = data.length
if (debug) {
console.log(
`> [debug] Uploaded: ${names.join(' ')} (${bytes(data.length)})`
)
}
bar.tick(amount)
})
now.on('complete', () => complete({ syncCount }))
now.on('error', err => {
error('Upload failed')
return stopDeployment(err)
})
} else {
if (!quiet) {
console.log(`> Initializing…`)
}
// Close http2 agent
now.close()
// Show build logs
if (!quiet) {
if (deploymentType === 'static') {
console.log(`${chalk.cyan('> Deployment complete!')}`)
} else {
printLogs(now.host, token, currentTeam, user)
}
}
}
}
async function readMeta(path, deploymentName, deploymentType, sessionAffinity) {
try {
const meta = await readMetaData(path, {
deploymentType,
deploymentName,
quiet: true,
sessionAffinity
})
if (!deploymentType) {
deploymentType = meta.type
if (debug) {
console.log(
`> [debug] Detected \`deploymentType\` = \`${deploymentType}\``
)
}
}
if (!deploymentName) {
deploymentName = meta.name
if (debug) {
console.log(
`> [debug] Detected \`deploymentName\` = "${deploymentName}"`
)
}
}
return {
meta,
deploymentName,
deploymentType,
sessionAffinity
}
} catch (err) {
if (isTTY && err.code === 'MULTIPLE_MANIFESTS') {
if (debug) {
console.log('> [debug] Multiple manifests found, disambiguating')
}
console.log(
`> Two manifests found. Press [${chalk.bold(
'n'
)}] to deploy or re-run with --flag`
)
deploymentType = await promptOptions([
['npm', `${chalk.bold('package.json')}\t${chalk.gray(' --npm')} `],
['docker', `${chalk.bold('Dockerfile')}\t${chalk.gray('--docker')} `]
])
if (debug) {
console.log(
`> [debug] Selected \`deploymentType\` = "${deploymentType}"`
)
}
return readMeta(path, deploymentName, deploymentType)
}
throw err
}
}
function printLogs(host, token, currentTeam, user) {
// Log build
const logger = new Logger(host, token, { debug, quiet })
logger.on('error', async err => {
if (!quiet) {
if (err && err.type === 'BUILD_ERROR') {
error(
`The build step of your project failed. To retry, run ${cmd(
'now --force'
)}.`
)
} else {
error('Deployment failed')
}
}
if (gitRepo && gitRepo.cleanup) {
// Delete temporary directory that contains repository
gitRepo.cleanup()
if (debug) {
console.log(`> [debug] Removed temporary repo directory`)
}
}
process.exit(1)
})
logger.on('close', async () => {
if (Array.isArray(autoAliases)) {
const aliasList = autoAliases.filter(item => item !== '')
if (aliasList.length > 0) {
const assignments = []
for (const alias of aliasList) {
assignments.push(
assignAlias(alias, token, host, apiUrl, debug, currentTeam, user)
)
}
await Promise.all(assignments)
} else {
await reAlias(
token,
host,
null,
help,
exit,
apiUrl,
debug,
currentTeam,
user
)
}
}
if (!quiet) {
console.log(`${chalk.cyan('> Deployment complete!')}`)
}
if (gitRepo && gitRepo.cleanup) {
// Delete temporary directory that contains repository
gitRepo.cleanup()
if (debug) {
console.log(`> [debug] Removed temporary repo directory`)
}
}
process.exit(0)
})
}
main()

View File

@@ -1,338 +0,0 @@
#!/usr/bin/env node
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
const ms = require('ms')
const table = require('text-table')
// Ours
const cfg = require('../lib/cfg')
const DomainRecords = require('../lib/domain-records')
const indent = require('../lib/indent')
const login = require('../lib/login')
const strlen = require('../lib/strlen')
const { handleError, error } = require('../lib/error')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config'],
boolean: ['help', 'debug'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't'
}
})
const subcommand = argv._[0]
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now dns ls`)} [domain]
${chalk.bold(
`${logo} now dns add`
)} <domain> <name> <A | AAAA | ALIAS | CNAME | TXT> <value>
${chalk.bold(`${logo} now dns add`)} <domain> <name> MX <value> <mx_priority>
${chalk.bold(
`${logo} now dns add`
)} <domain> <name> SRV <priority> <weight> <port> <target>
${chalk.bold(`${logo} now dns rm`)} <id>
${chalk.dim('Options:')}
-h, --help output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} config file
-d, --debug debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} login token
${chalk.dim('Examples:')}
${chalk.gray('')} List all your DNS records
${chalk.cyan('$ now dns ls')}
${chalk.gray('')} Add an A record for a subdomain
${chalk.cyan(
'$ now dns add <YOUR DOMAIN> <SUBDOMAIN NAME> A <RECORD VALUE>'
)}
${chalk.cyan('$ now dns add zeit.rocks api A 198.51.100.100')}
${chalk.gray('')} Add an MX record (@ as a name refers to the domain)
${chalk.cyan(
'$ now dns add <YOUR DOMAIN> @ MX <RECORD VALUE> <PRIORITY>'
)}
${chalk.cyan('$ now dns add zeit.rocks @ MX mail.zeit.rocks 10')}
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
handleError(err)
exit(1)
}
})
}
async function run({ token, config: { currentTeam, user } }) {
const domainRecords = new DomainRecords({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
const start = Date.now()
if (subcommand === 'ls' || subcommand === 'list') {
if (args.length > 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now dns ls [domain]`'
)}`
)
return exit(1)
}
const elapsed = ms(new Date() - start)
const res = await domainRecords.ls(args[0])
const text = []
let count = 0
res.forEach((records, domain) => {
count += records.length
if (records.length > 0) {
const cur = Date.now()
const header = [
['', 'id', 'name', 'type', 'value', 'aux', 'created'].map(s =>
chalk.dim(s)
)
]
const out = table(
header.concat(
records.map(record => {
const time = chalk.gray(
ms(cur - new Date(Number(record.created))) + ' ago'
)
const aux = (() => {
if (record.mxPriority !== undefined) return record.mxPriority
if (record.priority !== undefined) return record.priority
return ''
})()
return [
'',
record.id,
record.name,
record.type,
record.value,
aux,
time
]
})
),
{
align: ['l', 'r', 'l', 'l', 'l', 'l'],
hsep: ' '.repeat(2),
stringLength: strlen
}
)
text.push(`\n\n${chalk.bold(domain)}\n${indent(out, 2)}`)
}
})
console.log(
`> ${count} record${count === 1 ? '' : 's'} found ${chalk.gray(
`[${elapsed}]`
)} under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}`
)
console.log(text.join(''))
} else if (subcommand === 'add') {
const param = parseAddArgs(args)
if (!param) {
error(
`Invalid number of arguments. See: ${chalk.cyan(
'`now dns --help`'
)} for usage.`
)
return exit(1)
}
const record = await domainRecords.create(param.domain, param.data)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} A new DNS record for domain ${chalk.bold(
param.domain
)} ${chalk.gray(`(${record.uid})`)} created ${chalk.gray(
`[${elapsed}]`
)} (${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)})`
)
} else if (subcommand === 'rm' || subcommand === 'remove') {
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan('`now dns rm <id>`')}`
)
return exit(1)
}
const record = await domainRecords.getRecord(args[0])
if (!record) {
error('DNS record not found')
return exit(1)
}
const yes = await readConfirmation(
record,
'The following record will be removed permanently \n'
)
if (!yes) {
error('User abort')
return exit(0)
}
await domainRecords.delete(record.domain, record.id)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Record ${chalk.gray(
`${record.id}`
)} removed ${chalk.gray(`[${elapsed}]`)}`
)
} else {
error('Please specify a valid subcommand: ls | add | rm')
help()
exit(1)
}
return domainRecords.close()
}
process.on('uncaughtException', err => {
handleError(err)
exit(1)
})
function parseAddArgs(args) {
if (!args || args.length < 4) {
return null
}
const domain = args[0]
const name = args[1] === '@' ? '' : args[1].toString()
const type = args[2]
const value = args[3]
if (!(domain && typeof name === 'string' && type)) {
return null
}
if (type === 'MX') {
if (args.length !== 5) {
return null
}
return {
domain,
data: {
name,
type,
value,
mxPriority: args[4]
}
}
} else if (type === 'SRV') {
if (args.length !== 7) {
return null
}
return {
domain,
data: {
name,
type,
srv: {
priority: value,
weight: args[4],
port: args[5],
target: args[6]
}
}
}
}
if (args.length !== 4) {
return null
}
return {
domain,
data: {
name,
type,
value
}
}
}
function readConfirmation(record, msg) {
return new Promise(resolve => {
const time = chalk.gray(
ms(new Date() - new Date(Number(record.created))) + ' ago'
)
const tbl = table(
[
[
record.id,
chalk.bold(
`${record.name.length > 0
? record.name + '.'
: ''}${record.domain} ${record.type} ${record.value} ${record.mxPriority
? record.mxPriority
: ''}`
),
time
]
],
{ align: ['l', 'r', 'l'], hsep: ' '.repeat(6) }
)
process.stdout.write(`> ${msg}`)
process.stdout.write(' ' + tbl + '\n')
process.stdout.write(
`${chalk.bold.red('> Are you sure?')} ${chalk.gray('[y/N] ')}`
)
process.stdin
.on('data', d => {
process.stdin.pause()
resolve(d.toString().trim().toLowerCase() === 'y')
})
.resume()
})
}

View File

@@ -1,395 +0,0 @@
#!/usr/bin/env node
// Native
const { resolve } = require('path')
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
const table = require('text-table')
const ms = require('ms')
// Ours
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { error } = require('../lib/error')
const toHost = require('../lib/to-host')
const strlen = require('../lib/strlen')
const NowDomains = require('../lib/domains')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug', 'external', 'force'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
external: 'e',
force: 'f',
token: 't'
}
})
const subcommand = argv._[0]
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now domains`)} <ls | add | rm | buy> <domain>
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-e, --external Use external DNS server
-f, --force Skip DNS verification
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Lists all your domains:
${chalk.cyan('$ now domains ls')}
${chalk.gray('')} Buy a new domain:
${chalk.cyan(`$ now domains buy ${chalk.underline('domain-name.com')}`)}
${chalk.gray('')} Adds a domain name:
${chalk.cyan(`$ now domains add ${chalk.underline('domain-name.com')}`)}
Make sure the domain's DNS nameservers are at least 2 of these:
${chalk.gray('')} ${chalk.underline(
'california.zeit.world'
)} ${chalk.dim('173.255.215.107')}
${chalk.gray('')} ${chalk.underline(
'london.zeit.world'
)} ${chalk.dim('178.62.47.76')}
${chalk.gray('')} ${chalk.underline(
'newark.zeit.world'
)} ${chalk.dim('173.255.231.87')}
${chalk.gray('')} ${chalk.underline(
'amsterdam.zeit.world'
)} ${chalk.dim('188.226.197.55')}
${chalk.gray('')} ${chalk.underline(
'dallas.zeit.world'
)} ${chalk.dim('173.192.101.194')}
${chalk.gray('')} ${chalk.underline(
'paris.zeit.world'
)} ${chalk.dim('37.123.115.172')}
${chalk.gray('')} ${chalk.underline(
'singapore.zeit.world'
)} ${chalk.dim('119.81.97.170')}
${chalk.gray('')} ${chalk.underline(
'sydney.zeit.world'
)} ${chalk.dim('52.64.171.200')}
${chalk.gray('')} ${chalk.underline(
'frankfurt.zeit.world'
)} ${chalk.dim('91.109.245.139')}
${chalk.gray('')} ${chalk.underline(
'iowa.zeit.world'
)} ${chalk.dim('23.236.59.22')}
${chalk.yellow('NOTE:')} running ${chalk.dim(
'`now alias`'
)} will automatically register your domain
if it's configured with these nameservers (no need to ${chalk.dim(
'`domain add`'
)}).
For more details head to ${chalk.underline('https://zeit.world')}.
${chalk.gray('')} Removing a domain:
${chalk.cyan('$ now domain rm my-app.com')}
or
${chalk.cyan('$ now domain rm domainId')}
To get the list of domain ids, use ${chalk.dim('`now domains ls`')}.
${chalk.gray(
''
)} Adding and verifying a domain name using zeit.world nameservers:
${chalk.cyan('$ now domain add my-app.com')}
The command will tell you if the domain was verified succesfully. In case the domain was not verified succesfully you should retry adding the domain after some time.
${chalk.gray(
''
)} Adding and verifying a domain name using an external nameserver:
${chalk.cyan('$ now domain add -e my-app.com')}
and follow the verification instructions if requested. Finally, rerun the same command after completing the verification step.
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err}\n${err.stack}`)
}
exit(1)
}
})
}
async function run({ token, config: { currentTeam, user } }) {
const domain = new NowDomains({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
switch (subcommand) {
case 'ls':
case 'list': {
if (args.length !== 0) {
error('Invalid number of arguments')
return exit(1)
}
const start_ = new Date()
const domains = await domain.ls()
domains.sort((a, b) => new Date(b.created) - new Date(a.created))
const current = new Date()
const header = [
['', 'domain', 'dns', 'verified', 'created'].map(s => chalk.dim(s))
]
const out = domains.length === 0
? null
: table(
header.concat(
domains.map(domain => {
const ns = domain.isExternal ? 'external' : 'zeit.world'
const url = chalk.bold(domain.name)
const time = chalk.gray(
ms(current - new Date(domain.created)) + ' ago'
)
return ['', url, ns, domain.verified, time]
})
),
{
align: ['l', 'l', 'l', 'l', 'l'],
hsep: ' '.repeat(2),
stringLength: strlen
}
)
const elapsed_ = ms(new Date() - start_)
console.log(
`> ${domains.length} domain${domains.length === 1
? ''
: 's'} found under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed_}]`)}`
)
if (out) {
console.log('\n' + out + '\n')
}
break
}
case 'rm':
case 'remove': {
if (args.length !== 1) {
error('Invalid number of arguments')
return exit(1)
}
const _target = String(args[0])
if (!_target) {
const err = new Error('No domain specified')
err.userError = true
throw err
}
const _domains = await domain.ls()
const _domain = findDomain(_target, _domains)
if (!_domain) {
const err = new Error(
`Domain not found by "${_target}". Run ${chalk.dim(
'`now domains ls`'
)} to see your domains.`
)
err.userError = true
throw err
}
try {
const confirmation = (await readConfirmation(
domain,
_domain,
_domains
)).toLowerCase()
if (confirmation !== 'y' && confirmation !== 'yes') {
console.log('\n> Aborted')
process.exit(0)
}
const start = new Date()
await domain.rm(_domain.name)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
_domain.uid
)} removed [${elapsed}]`
)
} catch (err) {
error(err)
exit(1)
}
break
}
case 'add':
case 'set': {
if (args.length !== 1) {
error('Invalid number of arguments')
return exit(1)
}
const start = new Date()
const name = String(args[0])
const { uid, code, created, verified } = await domain.add(
name,
argv.force,
argv.external
)
const elapsed = ms(new Date() - start)
if (created) {
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
chalk.underline(name)
)} ${chalk.dim(`(${uid})`)} added [${elapsed}]`
)
} else if (verified) {
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
chalk.underline(name)
)} ${chalk.dim(`(${uid})`)} verified [${elapsed}]`
)
} else if (code === 'not_modified') {
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
chalk.underline(name)
)} ${chalk.dim(`(${uid})`)} already exists [${elapsed}]`
)
} else {
console.log(
'> Verification required: Please rerun this command after some time'
)
}
break
}
case 'buy': {
await require(resolve(__dirname, 'domains', 'buy.js'))({
domains: domain,
args,
currentTeam,
user
})
break
}
default:
error('Please specify a valid subcommand: ls | add | rm')
help()
exit(1)
}
domain.close()
}
async function readConfirmation(domain, _domain) {
return new Promise(resolve => {
const time = chalk.gray(ms(new Date() - new Date(_domain.created)) + ' ago')
const tbl = table(
[[_domain.uid, chalk.underline(`https://${_domain.name}`), time]],
{ align: ['l', 'r', 'l'], hsep: ' '.repeat(6) }
)
process.stdout.write('> The following domain will be removed permanently\n')
process.stdout.write(' ' + tbl + '\n')
if (_domain.aliases.length > 0) {
process.stdout.write(
`> ${chalk.yellow('Warning!')} This domain's ` +
`${chalk.bold(
_domain.aliases.length +
' alias' +
(_domain.aliases.length === 1 ? '' : 'es')
)} ` +
`will be removed. Run ${chalk.dim('`now alias ls`')} to list.\n`
)
}
process.stdout.write(
` ${chalk.bold.red('> Are you sure?')} ${chalk.gray('[y/N] ')}`
)
process.stdin
.on('data', d => {
process.stdin.pause()
resolve(d.toString().trim())
})
.resume()
})
}
function findDomain(val, list) {
return list.find(d => {
if (d.uid === val) {
if (debug) {
console.log(`> [debug] matched domain ${d.uid} by uid`)
}
return true
}
// Match prefix
if (d.name === toHost(val)) {
if (debug) {
console.log(`> [debug] matched domain ${d.uid} by name ${d.name}`)
}
return true
}
return false
})
}

View File

@@ -1,235 +0,0 @@
#!/usr/bin/env node
// Packages
const minimist = require('minimist')
const chalk = require('chalk')
const ms = require('ms')
const printf = require('printf')
require('epipebomb')()
const supportsColor = require('supports-color')
// Ours
const Now = require('../lib')
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const logo = require('../lib/utils/output/logo')
const sort = require('../lib/sort-deployments')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug', 'all'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't'
}
})
const help = () => {
console.log(`
${chalk.bold(`${logo} now list`)} [app]
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} List all deployments
${chalk.cyan('$ now ls')}
${chalk.gray('')} List all deployments for the app ${chalk.dim('`my-app`')}
${chalk.cyan('$ now ls my-app')}
${chalk.dim('Alias:')} ls
`)
}
if (argv.help) {
help()
process.exit(0)
}
const app = argv._[0]
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
process.exit(1)
}
try {
await list({ token, config })
} catch (err) {
error(`Unknown error: ${err}\n${err.stack}`)
process.exit(1)
}
})
async function list({ token, config: { currentTeam, user } }) {
const now = new Now({ apiUrl, token, debug, currentTeam })
const start = new Date()
if (argv.all && !app) {
console.log('> You must define an app when using `--all`')
process.exit(1)
}
let deployments
try {
deployments = await now.list(app)
} catch (err) {
handleError(err)
process.exit(1)
}
if (!deployments || (Array.isArray(deployments) && deployments.length <= 0)) {
const match = await now.findDeployment(app)
if (match !== null && typeof match !== 'undefined') {
deployments = Array.of(match)
}
}
if (!deployments || (Array.isArray(deployments) && deployments.length <= 0)) {
const aliases = await now.listAliases()
const item = aliases.find(e => e.uid === app || e.alias === app)
if (item) {
const match = await now.findDeployment(item.deploymentId)
if (match !== null && typeof match !== 'undefined') {
deployments = Array.of(match)
}
}
}
now.close()
const apps = new Map()
if (argv.all) {
await Promise.all(
deployments.map(async ({ uid }, i) => {
deployments[i].instances = await now.listInstances(uid)
})
)
}
for (const dep of deployments) {
const deps = apps.get(dep.name) || []
apps.set(dep.name, deps.concat(dep))
}
const sorted = await sort([...apps])
const urlLength =
deployments.reduce((acc, i) => {
return Math.max(acc, (i.url && i.url.length) || 0)
}, 0) + 5
const timeNow = new Date()
console.log(
`> ${deployments.length} deployment${deployments.length === 1
? ''
: 's'} found under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.grey('[' + ms(timeNow - start) + ']')}`
)
let shouldShowAllInfo = false
for (const app of apps) {
shouldShowAllInfo =
app[1].length > 5 ||
app.find(depl => {
return depl.scale && depl.scale.current > 1
})
if (shouldShowAllInfo) {
break
}
}
if (!argv.all && shouldShowAllInfo) {
console.log(
`> To expand the list and see instances run ${chalk.cyan(
'`now ls --all [app]`'
)}`
)
}
console.log()
sorted.forEach(([name, deps]) => {
const listedDeployments = argv.all ? deps : deps.slice(0, 5)
console.log(
`${chalk.bold(name)} ${chalk.gray(
'(' + listedDeployments.length + ' of ' + deps.length + ' total)'
)}`
)
const urlSpec = `%-${urlLength}s`
console.log(
printf(
` ${chalk.grey(urlSpec + ' %8s %-16s %8s')}`,
'url',
'inst #',
'state',
'age'
)
)
listedDeployments.forEach(dep => {
let state = dep.state
let extraSpaceForState = 0
if (state === null || typeof state === 'undefined') {
state = 'DEPLOYMENT_ERROR'
}
if (/ERROR/.test(state)) {
state = chalk.red(state)
extraSpaceForState = 10
} else if (state === 'FROZEN') {
state = chalk.grey(state)
extraSpaceForState = 10
}
let spec
if (supportsColor) {
spec = ` %-${urlLength + 10}s %8s %-${extraSpaceForState + 16}s %8s`
} else {
spec = ` %-${urlLength + 1}s %8s %-${16}s %8s`
}
console.log(
printf(
spec,
chalk.underline(dep.url),
dep.scale ? dep.scale.current : '✖',
state,
ms(timeNow - dep.created)
)
)
if (Array.isArray(dep.instances) && dep.instances.length > 0) {
dep.instances.forEach(i => {
console.log(
printf(` %-${urlLength + 10}s`, ` - ${chalk.underline(i.url)}`)
)
})
console.log()
}
})
console.log()
})
}

View File

@@ -1,126 +0,0 @@
#!/usr/bin/env node
// Packages
const minimist = require('minimist')
const chalk = require('chalk')
const fetch = require('node-fetch')
const ora = require('ora')
// Utilities
const cfg = require('../lib/cfg')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config'],
boolean: ['help'],
alias: {
help: 'h',
config: 'c'
}
})
const help = () => {
console.log(`
${chalk.bold(`${logo} now logout`)}
${chalk.dim('Options:')}
-h, --help output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} config file
${chalk.dim('Examples:')}
${chalk.gray('')} Logout from the CLI:
${chalk.cyan('$ now logout')}
`)
}
if (argv.help) {
help()
process.exit(0)
}
const apiUrl = argv.url || 'https://api.zeit.co'
const endpoint = apiUrl + '/www/user/tokens/'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
const requestHeaders = token => ({
headers: {
Authorization: `bearer ${token}`
}
})
const getTokenId = async token => {
const result = await fetch(endpoint, requestHeaders(token))
const tokenList = await result.json()
if (!tokenList.tokens) {
return
}
const tokenInfo = tokenList.tokens.find(t => token === t.token)
if (!tokenInfo) {
return
}
return tokenInfo.id
}
const revokeToken = async (token, tokenId) => {
const details = {
method: 'DELETE'
}
Object.assign(details, requestHeaders(token))
const result = await fetch(endpoint + encodeURIComponent(tokenId), details)
if (!result.ok) {
console.error('Not able to log out')
}
}
const logout = async () => {
const spinner = ora({
text: 'Logging out...'
}).start()
const config = await cfg.read()
try {
await cfg.removeFile()
} catch (err) {
spinner.fail(`Couldn't remove config while logging out`)
process.exit(1)
}
let tokenId
try {
tokenId = await getTokenId(argv.token || config.token)
} catch (err) {
spinner.fail('Not able to get token id on logout')
process.exit(1)
}
if (!tokenId) {
return
}
try {
await revokeToken(argv.token || config.token, tokenId)
} catch (err) {
spinner.fail('Could not revoke token on logout')
process.exit(1)
}
spinner.succeed('Logged out!')
}
logout()

View File

@@ -1,290 +0,0 @@
#!/usr/bin/env node
const qs = require('querystring')
const minimist = require('minimist')
const chalk = require('chalk')
const dateformat = require('dateformat')
const io = require('socket.io-client')
const Now = require('../lib')
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const logo = require('../lib/utils/output/logo')
const { compare, deserialize } = require('../lib/logs')
const { maybeURL, normalizeURL, parseInstanceURL } = require('../lib/utils/url')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'query', 'since', 'token', 'until'],
boolean: ['help', 'all', 'debug', 'f'],
alias: {
help: 'h',
all: 'a',
config: 'c',
debug: 'd',
token: 't',
query: 'q'
}
})
let deploymentIdOrURL = argv._[0]
const help = () => {
console.log(`
${chalk.bold(`${logo} now logs`)} <deploymentId|url>
${chalk.dim('Options:')}
-h, --help output usage information
-a, --all include access logs
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} config file
-d, --debug debug mode [off]
-f wait for additional data [off]
-n ${chalk.bold.underline('NUMBER')} number of logs [1000]
-q ${chalk.bold.underline('QUERY')}, --query=${chalk.bold.underline(
'QUERY'
)} search query
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} login token
--since=${chalk.bold.underline(
'SINCE'
)} only return logs after date (ISO 8601)
--until=${chalk.bold.underline(
'UNTIL'
)} only return logs before date (ISO 8601), ignored if the f option is enbled.
${chalk.dim('Examples:')}
${chalk.gray('')} Print logs for the deployment ${chalk.dim(
'`deploymentId`'
)}
${chalk.cyan('$ now logs deploymentId')}
`)
}
if (argv.help || !deploymentIdOrURL) {
help()
process.exit(0)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
const limit = typeof argv.n === 'number' ? argv.n : 1000
const query = argv.query || ''
const follow = argv.f
const types = argv.all ? [] : ['command', 'stdout', 'stderr', 'exit']
let since
try {
since = argv.since ? toSerial(argv.since) : null
} catch (err) {
error(`Invalid date string: ${argv.since}`)
process.exit(1)
}
let until
try {
until = argv.until ? toSerial(argv.until) : null
} catch (err) {
error(`Invalid date string: ${argv.until}`)
process.exit(1)
}
let instanceId
if (maybeURL(deploymentIdOrURL)) {
const normalizedURL = normalizeURL(deploymentIdOrURL)
if (normalizedURL.includes('/')) {
error(`Invalid deployment url: can't include path (${deploymentIdOrURL})`)
process.exit(1)
}
;[deploymentIdOrURL, instanceId] = parseInstanceURL(normalizedURL)
}
Promise.resolve()
.then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || login(apiUrl)
} catch (err) {
error(`Authentication error ${err.message}`)
process.exit(1)
}
await printLogs({ token, config })
})
.catch(err => {
error(`Unknown error: ${err.stack}`)
process.exit(1)
})
async function printLogs({ token, config: { currentTeam } }) {
let buf = []
let init = false
let lastLog
if (!follow) {
onLogs(await fetchLogs({ token, currentTeam, since, until }))
return
}
const isURL = deploymentIdOrURL.includes('.')
const q = qs.stringify({
deploymentId: isURL ? '' : deploymentIdOrURL,
host: isURL ? deploymentIdOrURL : '',
instanceId,
types: types.join(','),
query
})
const socket = io(`https://log-io.zeit.co?${q}`)
socket.on('connect', () => {
if (debug) {
console.log('> [debug] Socket connected')
}
})
socket.on('auth', callback => {
if (debug) {
console.log('> [debug] Socket authenticate')
}
callback(token)
})
socket.on('ready', () => {
if (debug) {
console.log('> [debug] Socket ready')
}
// For the case socket reconnected
const _since = lastLog ? lastLog.serial : since
fetchLogs({ token, currentTeam, since: _since }).then(logs => {
init = true
const m = {}
logs.concat(buf.map(b => b.log)).forEach(l => {
m[l.id] = l
})
buf = []
onLogs(Object.values(m))
})
})
socket.on('logs', l => {
const log = deserialize(l)
let timer
if (init) {
// Wait for other logs for a while
// and sort them in the correct order
timer = setTimeout(() => {
buf.sort((a, b) => compare(a.log, b.log))
const idx = buf.findIndex(b => b.log.id === log.id)
buf.slice(0, idx + 1).forEach(b => {
clearTimeout(b.timer)
onLog(b.log)
})
buf = buf.slice(idx + 1)
}, 300)
}
buf.push({ log, timer })
})
socket.on('disconnect', () => {
if (debug) {
console.log('> [debug] Socket disconnect')
}
init = false
})
socket.on('error', err => {
if (debug) {
console.log('> [debug] Socket error', err.stack)
}
})
function onLogs(logs) {
logs.sort(compare).forEach(onLog)
}
function onLog(log) {
lastLog = log
printLog(log)
}
}
function printLog(log) {
let data
const obj = log.object
if (log.type === 'request') {
data =
`REQ "${obj.method} ${obj.uri} ${obj.protocol}"` +
` ${obj.remoteAddr} - ${obj.remoteUser || ''}` +
` "${obj.referer || ''}" "${obj.userAgent}"`
} else if (log.type === 'response') {
data =
`RES "${obj.method} ${obj.uri} ${obj.protocol}"` +
` ${obj.status} ${obj.bodyBytesSent}`
} else {
data = obj
? JSON.stringify(obj, null, 2)
: (log.text || '').replace(/\n$/, '')
}
const date = dateformat(log.date, 'mm/dd hh:MM TT')
data.split('\n').forEach((line, i) => {
if (i === 0) {
console.log(`${chalk.dim(date)} ${line}`)
} else {
console.log(`${repeat(' ', date.length)} ${line}`)
}
})
}
async function fetchLogs({ token, currentTeam, since, until } = {}) {
const now = new Now({ apiUrl, token, debug, currentTeam })
let logs
try {
logs = await now.logs(deploymentIdOrURL, {
instanceId,
types,
limit,
query,
since,
until
})
} catch (err) {
handleError(err)
process.exit(1)
} finally {
now.close()
}
return logs.map(deserialize)
}
function repeat(s, n) {
return new Array(n + 1).join(s)
}
function toSerial(datestr) {
const t = Date.parse(datestr)
if (isNaN(t)) {
throw new TypeError('Invalid date string')
}
const pidLen = 19
const seqLen = 19
return t + repeat('0', pidLen + seqLen)
}

View File

@@ -1,209 +0,0 @@
#!/usr/bin/env node
// Packages
const minimist = require('minimist')
const chalk = require('chalk')
const ms = require('ms')
const table = require('text-table')
// Ours
const Now = require('../lib')
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const logo = require('../lib/utils/output/logo')
const { normalizeURL } = require('../lib/utils/url')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug', 'hard', 'yes', 'safe'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't',
yes: 'y'
}
})
const ids = argv._
// Options
const help = () => {
console.log(`
${chalk.bold(
`${logo} now remove`
)} deploymentId|deploymentName [...deploymentId|deploymentName]
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
-y, --yes Skip confirmation
--safe Skip deployments with an active alias
${chalk.dim('Examples:')}
${chalk.gray('')} Remove a deployment identified by ${chalk.dim(
'`deploymentId`'
)}:
${chalk.cyan('$ now rm deploymentId')}
${chalk.gray('')} Remove all deployments with name ${chalk.dim('`my-app`')}:
${chalk.cyan('$ now rm my-app')}
${chalk.gray('')} Remove two deployments with IDs ${chalk.dim(
'`eyWt6zuSdeus`'
)} and ${chalk.dim('`uWHoA9RQ1d1o`')}:
${chalk.cyan('$ now rm eyWt6zuSdeus uWHoA9RQ1d1o')}
${chalk.dim('Alias:')} rm
`)
}
if (argv.help || ids.length === 0) {
help()
process.exit(0)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
const hard = argv.hard || false
const skipConfirmation = argv.yes || false
if (argv.config) {
cfg.setConfigFile(argv.config)
}
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || login(apiUrl)
} catch (err) {
error(`Authentication error ${err.message}`)
process.exit(1)
}
try {
await remove({ token, config })
} catch (err) {
error(`Unknown error: ${err}\n${err.stack}`)
process.exit(1)
}
})
function readConfirmation(matches) {
return new Promise(resolve => {
process.stdout.write(
`> The following deployment${matches.length === 1
? ''
: 's'} will be removed permanently:\n`
)
const tbl = table(
matches.map(depl => {
const time = chalk.gray(ms(new Date() - depl.created) + ' ago')
const url = depl.url ? chalk.underline(`https://${depl.url}`) : ''
return [depl.uid, url, time]
}),
{ align: ['l', 'r', 'l'], hsep: ' '.repeat(6) }
)
process.stdout.write(tbl + '\n')
for (const [index, depl] of matches.entries()) {
for (const alias of depl.aliases) {
if (argv.safe) {
delete matches[index]
continue
}
process.stdout.write(
`> ${chalk.yellow('Warning!')} Deployment ${chalk.bold(depl.uid)} ` +
`is an alias for ${chalk.underline(
`https://${alias.alias}`
)} and will be removed.\n`
)
}
}
process.stdout.write(
`${chalk.bold.red('> Are you sure?')} ${chalk.gray('[y/N] ')}`
)
process.stdin
.on('data', d => {
process.stdin.pause()
resolve(d.toString().trim())
})
.resume()
})
}
async function remove({ token, config: { currentTeam } }) {
const now = new Now({ apiUrl, token, debug, currentTeam })
const deployments = await now.list()
const matches = deployments.filter(d => {
return ids.some(id => {
return d.uid === id || d.name === id || d.url === normalizeURL(id)
})
})
if (matches.length === 0) {
error(
`Could not find any deployments matching ${ids
.map(id => chalk.bold(`"${id}"`))
.join(', ')}. Run ${chalk.dim(`\`now ls\``)} to list.`
)
return process.exit(1)
}
const aliases = await Promise.all(
matches.map(depl => now.listAliases(depl.uid))
)
for (let i = 0; i < matches.length; i++) {
matches[i].aliases = aliases[i]
}
try {
if (!skipConfirmation) {
const confirmation = (await readConfirmation(matches)).toLowerCase()
if (confirmation !== 'y' && confirmation !== 'yes') {
console.log('\n> Aborted')
process.exit(0)
}
}
const start = new Date()
await Promise.all(matches.map(depl => now.remove(depl.uid, { hard })))
const elapsed = ms(new Date() - start)
console.log(`${chalk.cyan('> Success!')} [${elapsed}]`)
console.log(
table(
matches.map(depl => {
return [`Deployment ${chalk.bold(depl.uid)} removed`]
})
)
)
} catch (err) {
handleError(err)
process.exit(1)
}
now.close()
}

View File

@@ -1,379 +0,0 @@
#!/usr/bin/env node
// Packages
const chalk = require('chalk')
const isURL = require('is-url')
const minimist = require('minimist')
const ms = require('ms')
const printf = require('printf')
require('epipebomb')()
const supportsColor = require('supports-color')
// Ours
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const NowScale = require('../lib/scale')
const login = require('../lib/login')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const info = require('../lib/scale-info')
const sort = require('../lib/sort-deployments')
const success = require('../lib/utils/output/success')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug'],
alias: { help: 'h', config: 'c', debug: 'd', token: 't' }
})
let id = argv._[0]
const scaleArg = argv._[1]
const optionalScaleArg = argv._[2]
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now scale`)} ls
${chalk.bold(`${logo} now scale`)} <url>
${chalk.bold(`${logo} now scale`)} <url> <min> [max]
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
${chalk.dim('Examples:')}
${chalk.gray('')} Create an deployment with 3 instances, never sleeps:
${chalk.cyan('$ now scale my-deployment-ntahoeato.now.sh 3')}
${chalk.gray('')} Create an automatically scaling deployment:
${chalk.cyan('$ now scale my-deployment-ntahoeato.now.sh 1 5')}
${chalk.gray(
''
)} Create an automatically scaling deployment without specifying max:
${chalk.cyan('$ now scale my-deployment-ntahoeato.now.sh 1 auto')}
${chalk.gray(
''
)} Create an automatically scaling deployment without specifying min or max:
${chalk.cyan('$ now scale my-deployment-ntahoeato.now.sh auto')}
${chalk.gray(
''
)} Create an deployment that is always active and never "sleeps":
${chalk.cyan('$ now scale my-deployment-ntahoeato.now.sh 1')}
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err}\n${err.stack}`)
}
exit(1)
}
})
}
function guessParams() {
if (Number.isInteger(scaleArg) && !optionalScaleArg) {
return { min: scaleArg, max: scaleArg }
} else if (Number.isInteger(scaleArg) && Number.isInteger(optionalScaleArg)) {
return { min: scaleArg, max: optionalScaleArg }
} else if (Number.isInteger(scaleArg) && optionalScaleArg === 'auto') {
return { min: scaleArg, max: 'auto' }
} else if (
(!scaleArg && !optionalScaleArg) ||
(scaleArg === 'auto' && !optionalScaleArg)
) {
return { min: 1, max: 'auto' }
}
help()
process.exit(1)
}
function isHostNameOrId(str) {
return (
/(https?:\/\/)?((?:(?=[a-z0-9-]{1,63}\.)(?:xn--)?[a-z0-9]+(?:-[a-z0-9]+)*\.)+[a-z]{2,63})/.test(
str
) || str.length === 28
)
}
async function run({ token, config: { currentTeam } }) {
const scale = new NowScale({ apiUrl, token, debug, currentTeam })
const start = Date.now()
if (id === 'ls') {
await list(scale)
process.exit(0)
} else if (id === 'info') {
await info(scale)
process.exit(0)
} else if (id && isHostNameOrId(id)) {
// Normalize URL by removing slash from the end
if (isURL(id)) {
id = id.replace(/^https:\/\//i, '')
if (id.slice(-1) === '/') {
id = id.slice(0, -1)
}
}
} else {
error('Please specify a deployment: now scale <id|url>')
help()
exit(1)
}
const deployments = await scale.list()
let match = deployments.find(d => {
// `url` should match the hostname of the deployment
let u = id.replace(/^https:\/\//i, '')
if (u.indexOf('.') === -1) {
// `.now.sh` domain is implied if just the subdomain is given
u += '.now.sh'
}
return d.uid === id || d.name === id || d.url === u
})
if (!match) {
// Maybe it's an alias
const aliasDeployment = (await scale.listAliases()).find(
e => e.alias === id
)
if (!aliasDeployment) {
error(`Could not find any deployments matching ${id}`)
return process.exit(1)
}
match = deployments.find(d => {
return d.uid === aliasDeployment.deploymentId
})
}
const { min, max } = guessParams()
if (
!(Number.isInteger(min) || min === 'auto') &&
!(Number.isInteger(max) || max === 'auto')
) {
help()
return exit(1)
}
if (match.type === 'STATIC') {
if (min === 0 && max === 0) {
error("Static deployments can't be FROZEN. Use `now rm` to remove")
return process.exit(1)
}
console.log('> Static deployments are automatically scaled!')
return process.exit(0)
}
const {
max: currentMax,
min: currentMin,
current: currentCurrent
} = match.scale
if (
max === currentMax &&
min === currentMin &&
Number.isInteger(min) &&
currentCurrent >= min &&
Number.isInteger(max) &&
currentCurrent <= max
) {
// Nothing to do, let's print the rules
printScaleingRules(match.url, currentCurrent, min, max)
return
}
if ((match.state === 'FROZEN' || match.scale.current === 0) && min > 0) {
console.log(
`> Deployment is currently in 0 replicas, preparing deployment for scaling...`
)
if (match.scale.max < 1) {
await scale.setScale(match.uid, { min: 0, max: 1 })
}
await scale.unfreeze(match)
}
const { min: newMin, max: newMax } = await scale.setScale(match.uid, {
min,
max
})
const elapsed = ms(new Date() - start)
const currentReplicas = match.scale.current
printScaleingRules(match.url, currentReplicas, newMin, newMax, elapsed)
await info(scale, match.url)
scale.close()
}
function printScaleingRules(url, currentReplicas, min, max, elapsed) {
const log = console.log
success(
`Configured scaling rules ${chalk.gray(elapsed ? '[' + elapsed + ']' : '')}`
)
log()
log(
`${chalk.bold(url)} (${chalk.gray(currentReplicas)} ${chalk.gray(
'current'
)})`
)
log(printf('%6s %s', 'min', chalk.bold(min)))
log(printf('%6s %s', 'max', chalk.bold(max)))
log(printf('%6s %s', 'auto', chalk.bold(min === max ? '✖' : '✔')))
log()
}
async function list(scale) {
let deployments
try {
const app = argv._[1]
deployments = await scale.list(app)
} catch (err) {
handleError(err)
process.exit(1)
}
scale.close()
const apps = new Map()
for (const dep of deployments) {
const deps = apps.get(dep.name) || []
apps.set(dep.name, deps.concat(dep))
}
const sorted = await sort([...apps])
const timeNow = new Date()
const urlLength =
deployments.reduce((acc, i) => {
return Math.max(acc, (i.url && i.url.length) || 0)
}, 0) + 5
for (const app of sorted) {
const depls = argv.all ? app[1] : app[1].slice(0, 5)
console.log(
`${chalk.bold(app[0])} ${chalk.gray(
'(' + depls.length + ' of ' + app[1].length + ' total)'
)}`
)
console.log()
const urlSpec = `%-${urlLength}s`
console.log(
printf(
` ${chalk.grey(urlSpec + ' %8s %8s %8s %8s %8s')}`,
'url',
'cur',
'min',
'max',
'auto',
'age'
)
)
for (const instance of depls) {
if (!instance.scale) {
let spec
if (supportsColor) {
spec = ` %-${urlLength + 10}s %8s %8s %8s %8s %8s`
} else {
spec = ` %-${urlLength + 1}s %8s %8s %8s %8s %8s`
}
const infinite = '∞'
console.log(
printf(
spec,
chalk.underline(instance.url),
infinite,
1,
infinite,
'✔',
ms(timeNow - instance.created)
)
)
} else if (instance.scale.current > 0) {
let spec
if (supportsColor) {
spec = ` %-${urlLength + 10}s %8s %8s %8s %8s %8s`
} else {
spec = ` %-${urlLength + 1}s %8s %8s %8s %8s %8s`
}
console.log(
printf(
spec,
chalk.underline(instance.url),
instance.scale.current,
instance.scale.min,
instance.scale.max,
instance.scale.max === instance.scale.min ? '✖' : '✔',
ms(timeNow - instance.created)
)
)
} else {
let spec
if (supportsColor) {
spec = ` %-${urlLength + 10}s ${chalk.gray('%8s %8s %8s %8s %8s')}`
} else {
spec = ` %-${urlLength + 1}s ${chalk.gray('%8s %8s %8s %8s %8s')}`
}
console.log(
printf(
spec,
chalk.underline(instance.url),
instance.scale.current,
instance.scale.min,
instance.scale.max,
instance.scale.max === instance.scale.min ? '✖' : '✔',
ms(timeNow - instance.created)
)
)
}
}
console.log()
}
}
process.on('uncaughtException', err => {
handleError(err)
exit(1)
})

View File

@@ -1,297 +0,0 @@
#!/usr/bin/env node
// Packages
const chalk = require('chalk')
const table = require('text-table')
const minimist = require('minimist')
const ms = require('ms')
// Ours
const strlen = require('../lib/strlen')
const cfg = require('../lib/cfg')
const { handleError, error } = require('../lib/error')
const NowSecrets = require('../lib/secrets')
const login = require('../lib/login')
const exit = require('../lib/utils/exit')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug', 'base64'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
base64: 'b',
token: 't'
}
})
const subcommand = argv._[0]
// Options
const help = () => {
console.log(`
${chalk.bold(`${logo} now secrets`)} <ls | add | rename | rm> <secret>
${chalk.dim('Options:')}
-h, --help Output usage information
-b, --base64 Treat value as base64-encoded
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Lists all your secrets:
${chalk.cyan('$ now secrets ls')}
${chalk.gray('')} Adds a new secret:
${chalk.cyan('$ now secrets add my-secret "my value"')}
${chalk.gray(
''
)} Once added, a secret's value can't be retrieved in plaintext anymore
${chalk.gray(
''
)} If the secret's value is more than one word, wrap it in quotes
${chalk.gray('')} Actually, when in doubt, wrap your value in quotes
${chalk.gray('')} Exposes a secret as an env variable:
${chalk.cyan(`$ now -e MY_SECRET=${chalk.bold('@my-secret')}`)}
Notice the ${chalk.cyan.bold(
'`@`'
)} symbol which makes the value a secret reference.
${chalk.gray('')} Renames a secret:
${chalk.cyan(`$ now secrets rename my-secret my-renamed-secret`)}
${chalk.gray('')} Removes a secret:
${chalk.cyan(`$ now secrets rm my-secret`)}
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
handleError(err)
exit(1)
}
})
}
async function run({ token, config: { currentTeam, user } }) {
const secrets = new NowSecrets({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
const start = Date.now()
if (subcommand === 'ls' || subcommand === 'list') {
if (args.length !== 0) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan('`now secret ls`')}`
)
return exit(1)
}
const list = await secrets.ls()
const elapsed = ms(new Date() - start)
console.log(
`> ${list.length} secret${list.length === 1
? ''
: 's'} found under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed}]`)}`
)
if (list.length > 0) {
const cur = Date.now()
const header = [['', 'id', 'name', 'created'].map(s => chalk.dim(s))]
const out = table(
header.concat(
list.map(secret => {
return [
'',
secret.uid,
chalk.bold(secret.name),
chalk.gray(ms(cur - new Date(secret.created)) + ' ago')
]
})
),
{
align: ['l', 'r', 'l', 'l'],
hsep: ' '.repeat(2),
stringLength: strlen
}
)
if (out) {
console.log('\n' + out + '\n')
}
}
return secrets.close()
}
if (subcommand === 'rm' || subcommand === 'remove') {
if (args.length !== 1) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now secret rm <id | name>`'
)}`
)
return exit(1)
}
const list = await secrets.ls()
const theSecret = list.filter(secret => {
return secret.uid === args[0] || secret.name === args[0]
})[0]
if (theSecret) {
const yes = await readConfirmation(theSecret)
if (!yes) {
error('User abort')
return exit(0)
}
} else {
error(`No secret found by id or name "${args[0]}"`)
return exit(1)
}
const secret = await secrets.rm(args[0])
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Secret ${chalk.bold(
secret.name
)} ${chalk.gray(`(${secret.uid})`)} removed ${chalk.gray(`[${elapsed}]`)}`
)
return secrets.close()
}
if (subcommand === 'rename') {
if (args.length !== 2) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now secret rename <old-name> <new-name>`'
)}`
)
return exit(1)
}
const secret = await secrets.rename(args[0], args[1])
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Secret ${chalk.bold(
secret.oldName
)} ${chalk.gray(`(${secret.uid})`)} renamed to ${chalk.bold(
args[1]
)} ${chalk.gray(`[${elapsed}]`)}`
)
return secrets.close()
}
if (subcommand === 'add' || subcommand === 'set') {
if (args.length !== 2) {
error(
`Invalid number of arguments. Usage: ${chalk.cyan(
'`now secret add <name> <value>`'
)}`
)
if (args.length > 2) {
const example = chalk.cyan(`$ now secret add ${args[0]}`)
console.log(
`> If your secret has spaces, make sure to wrap it in quotes. Example: \n ${example} `
)
}
return exit(1)
}
const [name, value_] = args
let value
if (argv.base64) {
value = { base64: value_ }
} else {
value = value_
}
const secret = await secrets.add(name, value)
const elapsed = ms(new Date() - start)
console.log(
`${chalk.cyan('> Success!')} Secret ${chalk.bold(
name.toLowerCase()
)} ${chalk.gray(`(${secret.uid})`)} added (${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}) ${chalk.gray(`[${elapsed}]`)}`
)
return secrets.close()
}
error('Please specify a valid subcommand: ls | add | rename | rm')
help()
exit(1)
}
process.on('uncaughtException', err => {
handleError(err)
exit(1)
})
function readConfirmation(secret) {
return new Promise(resolve => {
const time = chalk.gray(ms(new Date() - new Date(secret.created)) + ' ago')
const tbl = table([[secret.uid, chalk.bold(secret.name), time]], {
align: ['l', 'r', 'l'],
hsep: ' '.repeat(6)
})
process.stdout.write('> The following secret will be removed permanently\n')
process.stdout.write(' ' + tbl + '\n')
process.stdout.write(
`${chalk.bold.red('> Are you sure?')} ${chalk.gray('[y/N] ')}`
)
process.stdin
.on('data', d => {
process.stdin.pause()
resolve(d.toString().trim().toLowerCase() === 'y')
})
.resume()
})
}

View File

@@ -1,162 +0,0 @@
#!/usr/bin/env node
// Native
const { resolve } = require('path')
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
// Ours
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const error = require('../lib/utils/output/error')
const NowTeams = require('../lib/teams')
const logo = require('../lib/utils/output/logo')
const exit = require('../lib/utils/exit')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't',
switch: 'change'
}
})
const subcommand = argv._[0]
const help = () => {
console.log(`
${chalk.bold(`${logo} now teams`)} <add | ls | rm | invite>
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Add a new team:
${chalk.cyan('$ now teams add')}
${chalk.gray('')} Switch to a team:
${chalk.cyan(`$ now switch <id>`)}
${chalk.gray('')} If the id is omitted, you can choose interactively
${chalk.yellow(
'NOTE:'
)} When you switch, everything you add, list or remove will be scoped that team!
${chalk.gray('')} Invite new members (interactively):
${chalk.cyan(`$ now teams invite`)}
${chalk.gray('')} Invite a specific email:
${chalk.cyan(`$ now teams invite geist@zeit.co`)}
${chalk.gray('')} Remove a team:
${chalk.cyan(`$ now teams rm <id>`)}
${chalk.gray('')} If the id is omitted, you can choose interactively
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
if (argv.help || !subcommand) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err.stack}`)
}
exit(1)
}
})
}
async function run({ token, config: { currentTeam } }) {
const teams = new NowTeams({ apiUrl, token, debug, currentTeam })
const args = argv._.slice(1)
switch (subcommand) {
case 'list':
case 'ls': {
await require(resolve(__dirname, 'teams', 'list.js'))({
teams,
token
})
break
}
case 'switch':
case 'change': {
await require(resolve(__dirname, 'teams', 'switch.js'))({
teams,
args,
token
})
break
}
case 'add':
case 'create': {
await require(resolve(__dirname, 'teams', 'add.js'))({ teams, token })
break
}
case 'invite': {
await require(resolve(__dirname, 'teams', 'invite.js'))({
teams,
args,
token
})
break
}
default: {
let code = 0
if (subcommand !== 'help') {
error('Please specify a valid subcommand: ls | add | rm | set-default')
code = 1
}
help()
exit(code)
}
}
}

View File

@@ -1,251 +0,0 @@
#!/usr/bin/env node
// Packages
const chalk = require('chalk')
const minimist = require('minimist')
const ms = require('ms')
// Ours
const login = require('../lib/login')
const cfg = require('../lib/cfg')
const NowPlans = require('../lib/plans')
const indent = require('../lib/indent')
const listInput = require('../lib/utils/input/list')
const code = require('../lib/utils/output/code')
const error = require('../lib/utils/output/error')
const success = require('../lib/utils/output/success')
const cmd = require('../lib/utils/output/cmd')
const logo = require('../lib/utils/output/logo')
const { bold } = chalk
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't'
}
})
const help = () => {
console.log(`
${chalk.bold(`${logo} now upgrade`)} [plan]
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} List available plans and pick one interactively
${chalk.cyan('$ now upgrade')}
${chalk.yellow('NOTE:')} ${chalk.gray(
'Make sure you have a payment method, or add one:'
)}
${chalk.cyan(`$ now billing add`)}
${chalk.gray('')} Pick a specific plan (premium):
${chalk.cyan(`$ now upgrade premium`)}
`)
}
// Options
const debug = argv.debug
const apiUrl = argv.url || 'https://api.zeit.co'
if (argv.config) {
cfg.setConfigFile(argv.config)
}
const exit = code => {
// We give stdout some time to flush out
// because there's a node bug where
// stdout writes are asynchronous
// https://github.com/nodejs/node/issues/6456
setTimeout(() => process.exit(code || 0), 100)
}
if (argv.help) {
help()
exit(0)
} else {
Promise.resolve().then(async () => {
const config = await cfg.read({ token: argv.token })
let token
try {
token = config.token || (await login(apiUrl))
} catch (err) {
error(`Authentication error ${err.message}`)
exit(1)
}
try {
await run({ token, config })
} catch (err) {
if (err.userError) {
error(err.message)
} else {
error(`Unknown error: ${err.stack}`)
}
exit(1)
}
})
}
function buildInquirerChoices(current, until) {
if (until) {
until = until.split(' ')
until = ' for ' + chalk.bold(until[0]) + ' more ' + until[1]
} else {
until = ''
}
const currentText = bold('(current)')
let ossName = `OSS ${bold('FREE')}`
let premiumName = `Premium ${bold('$15')}`
let proName = `Pro ${bold('$50')}`
let advancedName = `Advanced ${bold('$200')}`
switch (current) {
case 'oss': {
ossName += indent(currentText, 6)
break
}
case 'premium': {
premiumName += indent(currentText, 3)
break
}
case 'pro': {
proName += indent(currentText, 7)
break
}
case 'advanced': {
advancedName += indent(currentText, 1)
break
}
default: {
ossName += indent(currentText, 6)
}
}
return [
{
name: ossName,
value: 'oss',
short: `OSS ${bold('FREE')}`
},
{
name: premiumName,
value: 'premium',
short: `Premium ${bold('$15')}`
},
{
name: proName,
value: 'pro',
short: `Pro ${bold('$50')}`
},
{
name: advancedName,
value: 'advanced',
short: `Advanced ${bold('$200')}`
}
]
}
async function run({ token, config: { currentTeam, user } }) {
const args = argv._
if (args.length > 1) {
error('Invalid number of arguments')
return exit(1)
}
const start = new Date()
const plans = new NowPlans({ apiUrl, token, debug, currentTeam })
let planId = args[0]
if (![undefined, 'oss', 'premium', 'pro', 'advanced'].includes(planId)) {
error(`Invalid plan name should be ${code('oss')} or ${code('premium')}`)
return exit(1)
}
const currentPlan = await plans.getCurrent()
if (planId === undefined) {
const elapsed = ms(new Date() - start)
let message = `For more info, please head to https://zeit.co`
message = currentTeam
? `${message}/${currentTeam.slug}/settings/plan`
: `${message}/account/plan`
message += `\n> Select a plan for ${bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)} ${chalk.gray(`[${elapsed}]`)}`
const choices = buildInquirerChoices(currentPlan.id, currentPlan.until)
planId = await listInput({
message,
choices,
separator: false,
abort: 'end'
})
}
if (
planId === undefined ||
(planId === currentPlan.id && currentPlan.until === undefined)
) {
return console.log('No changes made')
}
let newPlan
try {
newPlan = await plans.set(planId)
} catch (err) {
if (err.code === 'customer_not_found' || err.code === 'source_not_found') {
error(
`You have no payment methods available. Run ${cmd(
'now billing add'
)} to add one`
)
} else {
error(`An unknow error occured. Please try again later ${err.message}`)
}
plans.close()
return
}
if (currentPlan.until && newPlan.id !== 'oss') {
success(
`The cancelation has been undone. You're back on the ${chalk.bold(
`${newPlan.name} plan`
)}`
)
} else if (newPlan.until) {
success(
`Your plan will be switched to ${chalk.bold(
newPlan.name
)} in ${chalk.bold(newPlan.until)}. Your card will not be charged again`
)
} else {
success(`You're now on the ${chalk.bold(`${newPlan.name} plan`)}`)
}
plans.close()
}

View File

@@ -1,74 +0,0 @@
#!/usr/bin/env node
// Packages
const minimist = require('minimist')
const chalk = require('chalk')
// Ours
const cfg = require('../lib/cfg')
const exit = require('../lib/utils/exit')
const cmd = require('../lib/utils/output/cmd')
const logo = require('../lib/utils/output/logo')
const argv = minimist(process.argv.slice(2), {
string: ['config', 'token'],
boolean: ['help', 'debug', 'all'],
alias: {
help: 'h',
config: 'c',
debug: 'd',
token: 't'
}
})
const help = () => {
console.log(`
${chalk.bold(`${logo} now whoami`)}
${chalk.dim('Options:')}
-h, --help Output usage information
-c ${chalk.bold.underline('FILE')}, --config=${chalk.bold.underline(
'FILE'
)} Config file
-d, --debug Debug mode [off]
-t ${chalk.bold.underline('TOKEN')}, --token=${chalk.bold.underline(
'TOKEN'
)} Login token
${chalk.dim('Examples:')}
${chalk.gray('')} Show the current team context
${chalk.cyan('$ now whoami')}
`)
}
if (argv.help) {
help()
process.exit(0)
}
if (argv.config) {
cfg.setConfigFile(argv.config)
}
async function whoami() {
const config = await cfg.read({ token: argv.token })
if (!config || !config.token) {
console.log(
`> Not currently logged in! Please run ${cmd('now --login')}.\n`
)
return exit(1)
}
if (process.stdout.isTTY) {
process.stdout.write('> ')
}
const { user } = config
const name = user.username || user.email
console.log(name)
}
whoami()

View File

@@ -1,142 +0,0 @@
#!/usr/bin/env node
// Native
const { resolve } = require('path')
// Packages
const updateNotifier = require('update-notifier')
const chalk = require('chalk')
// Check if the current path exists and throw and error
// if the user is trying to deploy a non-existing path!
// This needs to be done exactly in this place, because
// the utility imports are taking advantage of it
try {
process.cwd()
} catch (err) {
if (err.code === 'ENOENT' && err.syscall === 'uv_cwd') {
console.log(`Current path doesn't exist!`)
} else {
console.log(err)
}
process.exit(1)
}
// Utilities
const pkg = require('../lib/pkg')
if (process.pkg) {
const notifier = updateNotifier({ pkg })
const update = notifier.update
if (update) {
let message = `Update available! ${chalk.red(
update.current
)}${chalk.green(update.latest)} \n`
message += `${chalk.magenta(
'Changelog:'
)} https://github.com/zeit/now-cli/releases/tag/${update.latest}\n`
if (pkg._npmPkg) {
message += `Run ${chalk.magenta('npm i -g now')} to update!`
} else {
message += `Please download binaries from https://zeit.co/download`
}
notifier.notify({ message })
}
}
// This command will be run if no other sub command is specified
const defaultCommand = 'deploy'
const commands = new Set([
defaultCommand,
'help',
'list',
'ls',
'rm',
'remove',
'alias',
'aliases',
'ln',
'domain',
'domains',
'dns',
'cert',
'certs',
'secret',
'secrets',
'cc',
'billing',
'upgrade',
'downgrade',
'team',
'teams',
'switch',
'log',
'logs',
'scale',
'logout',
'whoami'
])
const aliases = new Map([
['ls', 'list'],
['rm', 'remove'],
['ln', 'alias'],
['aliases', 'alias'],
['domain', 'domains'],
['cert', 'certs'],
['secret', 'secrets'],
['cc', 'billing'],
['downgrade', 'upgrade'],
['team', 'teams'],
['switch', 'teams switch'],
['log', 'logs']
])
let cmd = defaultCommand
let args = process.argv.slice(2)
const index = args.findIndex(a => commands.has(a))
if (index > -1) {
cmd = args[index]
args.splice(index, 1)
if (cmd === 'help') {
if (index < args.length && commands.has(args[index])) {
cmd = args[index]
args.splice(index, 1)
} else {
cmd = defaultCommand
}
args.unshift('--help')
}
cmd = aliases.get(cmd) || cmd
if (cmd.includes(' ')) {
const parts = cmd.split(' ')
cmd = parts.shift()
args = [].concat(parts, args)
}
}
// Don't throw a useless error message when running `now help help`
// rather show the general help and be useful
if (cmd === 'help') {
cmd = 'deploy'
} else if (cmd === defaultCommand && args[0] === 'login') {
args[0] = '--login'
}
const bin = resolve(__dirname, 'now-' + cmd + '.js')
// Prepare process.argv for subcommand
process.argv = process.argv.slice(0, 2).concat(args)
// Load sub command
// With custom parameter to make "pkg" happy
require(bin, 'may-exclude')

View File

@@ -1,135 +0,0 @@
// Packages
const chalk = require('chalk')
// Ours
const stamp = require('../../lib/utils/output/stamp')
const info = require('../../lib/utils/output/info')
const error = require('../../lib/utils/output/error')
const wait = require('../../lib/utils/output/wait')
const rightPad = require('../../lib/utils/output/right-pad')
const eraseLines = require('../../lib/utils/output/erase-lines')
const { tick } = require('../../lib/utils/output/chars')
const success = require('../../lib/utils/output/success')
const cmd = require('../../lib/utils/output/cmd')
const note = require('../../lib/utils/output/note')
const uid = require('../../lib/utils/output/uid')
const textInput = require('../../lib/utils/input/text')
const exit = require('../../lib/utils/exit')
const cfg = require('../../lib/cfg')
function validateSlugKeypress(data, value) {
// TODO: the `value` here should contain the current value + the keypress
// should be fixed on utils/input/text.js
return /^[a-zA-Z]+[a-zA-Z0-9_-]*$/.test(value + data)
}
function gracefulExit() {
console.log() // Blank line
note(
`Your team is now active for all ${cmd('now')} commands!\n Run ${cmd(
'now switch'
)} to change it in the future.`
)
return exit()
}
const teamUrlPrefix = rightPad('Team URL', 14) + chalk.gray('zeit.co/')
const teamNamePrefix = rightPad('Team Name', 14)
module.exports = async function({ teams, token }) {
let slug
let team
let elapsed
let stopSpinner
info(
`Pick a team identifier for its url (e.g.: ${chalk.cyan('`zeit.co/acme`')})`
)
do {
try {
// eslint-disable-next-line no-await-in-loop
slug = await textInput({
label: `- ${teamUrlPrefix}`,
validateKeypress: validateSlugKeypress,
initialValue: slug,
valid: team,
forceLowerCase: true
})
} catch (err) {
if (err.message === 'USER_ABORT') {
info('Aborted')
return exit()
}
throw err
}
elapsed = stamp()
stopSpinner = wait(teamUrlPrefix + slug)
let res
try {
// eslint-disable-next-line no-await-in-loop
res = await teams.create({ slug })
stopSpinner()
team = res
} catch (err) {
stopSpinner()
eraseLines(2)
error(err.message)
}
} while (!team)
eraseLines(2)
success(`Team created ${uid(team.id)} ${elapsed()}`)
console.log(chalk.cyan(`${tick} `) + teamUrlPrefix + slug + '\n')
info('Pick a display name for your team')
let name
try {
name = await textInput({
label: `- ${teamNamePrefix}`,
validateValue: value => value.trim().length > 0
})
} catch (err) {
if (err.message === 'USER_ABORT') {
info('No name specified')
gracefulExit()
} else {
throw err
}
}
elapsed = stamp()
stopSpinner = wait(teamNamePrefix + name)
const res = await teams.edit({ id: team.id, name })
stopSpinner()
eraseLines(2)
if (res.error) {
error(res.error.message)
console.log(`${chalk.red(`${teamNamePrefix}`)}${name}`)
exit(1)
// TODO: maybe we want to ask the user to retry? not sure if
// there's a scenario where that would be wanted
}
team = Object.assign(team, res)
success(`Team name saved ${elapsed()}`)
console.log(chalk.cyan(`${tick} `) + teamNamePrefix + team.name + '\n')
stopSpinner = wait('Saving')
await cfg.merge({ currentTeam: team })
stopSpinner()
await require('./invite')({
teams,
args: [],
token,
introMsg:
'Invite your team mates! When done, press enter on an empty field',
noopMsg: `You can invite team mates later by running ${cmd(
'now teams invite'
)}`
})
gracefulExit()
}

View File

@@ -1,160 +0,0 @@
// Packages
const chalk = require('chalk')
// Ours
const regexes = require('../../lib/utils/input/regexes')
const wait = require('../../lib/utils/output/wait')
const cfg = require('../../lib/cfg')
const fatalError = require('../../lib/utils/fatal-error')
const cmd = require('../../lib/utils/output/cmd')
const info = require('../../lib/utils/output/info')
const stamp = require('../../lib/utils/output/stamp')
const param = require('../../lib/utils/output/param')
const { tick } = require('../../lib/utils/output/chars')
const rightPad = require('../../lib/utils/output/right-pad')
const textInput = require('../../lib/utils/input/text')
const eraseLines = require('../../lib/utils/output/erase-lines')
const success = require('../../lib/utils/output/success')
const error = require('../../lib/utils/output/error')
function validateEmail(data) {
return regexes.email.test(data.trim()) || data.length === 0
}
const domains = Array.from(
new Set([
'aol.com',
'gmail.com',
'google.com',
'yahoo.com',
'ymail.com',
'hotmail.com',
'live.com',
'outlook.com',
'inbox.com',
'mail.com',
'gmx.com',
'icloud.com'
])
)
function emailAutoComplete(value, teamSlug) {
const parts = value.split('@')
if (parts.length === 2 && parts[1].length > 0) {
const [, host] = parts
let suggestion = false
domains.unshift(teamSlug)
for (const domain of domains) {
if (domain.startsWith(host)) {
suggestion = domain.substr(host.length)
break
}
}
domains.shift()
return suggestion
}
return false
}
module.exports = async function(
{ teams, args, token, introMsg, noopMsg = 'No changes made' } = {}
) {
const { user, currentTeam } = await cfg.read({ token })
domains.push(user.email.split('@')[1])
if (!currentTeam) {
let err = `You can't run this command under ${param(
user.username || user.email
)}.\n`
err += `${chalk.gray('>')} Run ${cmd('now switch')} to choose to a team.`
return fatalError(err)
}
info(introMsg || `Inviting team members to ${chalk.bold(currentTeam.name)}`)
if (args.length > 0) {
for (const email of args) {
if (regexes.email.test(email)) {
const stopSpinner = wait(email)
const elapsed = stamp()
// eslint-disable-next-line no-await-in-loop
await teams.inviteUser({ teamId: currentTeam.id, email })
stopSpinner()
console.log(`${chalk.cyan(tick)} ${email} ${elapsed()}`)
} else {
console.log(`${chalk.red(`${email}`)} ${chalk.gray('[invalid]')}`)
}
}
return
}
const inviteUserPrefix = rightPad('Invite User', 14)
const emails = []
let hasError = false
let email
do {
email = ''
try {
// eslint-disable-next-line no-await-in-loop
email = await textInput({
label: `- ${inviteUserPrefix}`,
validateValue: validateEmail,
autoComplete: value => emailAutoComplete(value, currentTeam.slug)
})
} catch (err) {
if (err.message !== 'USER_ABORT') {
throw err
}
}
let elapsed
let stopSpinner
if (email) {
elapsed = stamp()
stopSpinner = wait(inviteUserPrefix + email)
try {
// eslint-disable-next-line no-await-in-loop
await teams.inviteUser({ teamId: currentTeam.id, email })
stopSpinner()
email = `${email} ${elapsed()}`
emails.push(email)
console.log(`${chalk.cyan(tick)} ${inviteUserPrefix}${email}`)
if (hasError) {
hasError = false
eraseLines(emails.length + 2)
info(
introMsg ||
`Inviting team members to ${chalk.bold(currentTeam.name)}`
)
for (const email of emails) {
console.log(`${chalk.cyan(tick)} ${inviteUserPrefix}${email}`)
}
}
} catch (err) {
stopSpinner()
eraseLines(emails.length + 2)
error(err.message)
hasError = true
for (const email of emails) {
console.log(`${chalk.cyan(tick)} ${inviteUserPrefix}${email}`)
}
}
}
} while (email !== '')
eraseLines(emails.length + 2)
const n = emails.length
if (emails.length === 0) {
info(noopMsg)
} else {
success(`Invited ${n} team mate${n > 1 ? 's' : ''}`)
for (const email of emails) {
console.log(`${chalk.cyan(tick)} ${inviteUserPrefix}${email}`)
}
}
}

View File

@@ -1,62 +0,0 @@
const chalk = require('chalk')
const wait = require('../../lib/utils/output/wait')
const cfg = require('../../lib/cfg')
const info = require('../../lib/utils/output/info')
const error = require('../../lib/utils/output/error')
const { tick: tickChar } = require('../../lib/utils/output/chars')
const table = require('../../lib/utils/output/table')
module.exports = async function({ teams, token }) {
const stopSpinner = wait('Fetching teams')
const list = (await teams.ls()).teams
let { user, currentTeam } = await cfg.read({ token })
const accountIsCurrent = !currentTeam
stopSpinner()
if (accountIsCurrent) {
currentTeam = {
slug: user.username || user.email
}
}
const teamList = list.map(({ slug, name }) => {
return {
name,
value: slug,
current: slug === currentTeam.slug ? tickChar : ''
}
})
teamList.unshift({
name: user.email,
value: user.username || user.email,
current: (accountIsCurrent && tickChar) || ''
})
// Let's bring the current team to the beginning of the list
if (!accountIsCurrent) {
const index = teamList.findIndex(
choice => choice.value === currentTeam.slug
)
const choice = teamList.splice(index, 1)[0]
teamList.unshift(choice)
}
// Printing
const count = teamList.length
if (!count) {
// Maybe should not happen
error(`No team found`)
return
}
info(`${chalk.bold(count)} team${count > 1 ? 's' : ''} found`)
console.log()
table(
['', 'id', 'email / name'],
teamList.map(team => [team.current, team.value, team.name]),
[1, 5]
)
}

View File

@@ -1,124 +0,0 @@
const chalk = require('chalk')
const wait = require('../../lib/utils/output/wait')
const listInput = require('../../lib/utils/input/list')
const cfg = require('../../lib/cfg')
const exit = require('../../lib/utils/exit')
const success = require('../../lib/utils/output/success')
const info = require('../../lib/utils/output/info')
const error = require('../../lib/utils/output/error')
const param = require('../../lib/utils/output/param')
async function updateCurrentTeam({ cfg, newTeam } = {}) {
delete newTeam.created
delete newTeam.creator_id
await cfg.merge({ currentTeam: newTeam })
}
module.exports = async function({ teams, args, token }) {
let stopSpinner = wait('Fetching teams')
const list = (await teams.ls()).teams
let { user, currentTeam } = await cfg.read({ token })
const accountIsCurrent = !currentTeam
stopSpinner()
if (accountIsCurrent) {
currentTeam = {
slug: user.username || user.email
}
}
if (args.length !== 0) {
const desiredSlug = args[0]
const newTeam = list.find(team => team.slug === desiredSlug)
if (newTeam) {
await updateCurrentTeam({ cfg, newTeam })
success(`The team ${chalk.bold(newTeam.name)} is now active!`)
return exit()
}
if (desiredSlug === user.username) {
stopSpinner = wait('Saving')
await cfg.remove('currentTeam')
stopSpinner()
return success(`Your account (${chalk.bold(desiredSlug)}) is now active!`)
}
error(`Could not find membership for team ${param(desiredSlug)}`)
return exit(1)
}
const choices = list.map(({ slug, name }) => {
name = `${slug} (${name})`
if (slug === currentTeam.slug) {
name += ` ${chalk.bold('(current)')}`
}
return {
name,
value: slug,
short: slug
}
})
const suffix = accountIsCurrent ? ` ${chalk.bold('(current)')}` : ''
const userEntryName = user.username
? `${user.username} (${user.email})${suffix}`
: user.email
choices.unshift({
name: userEntryName,
value: user.email,
short: user.username
})
// Let's bring the current team to the beginning of the list
if (!accountIsCurrent) {
const index = choices.findIndex(choice => choice.value === currentTeam.slug)
const choice = choices.splice(index, 1)[0]
choices.unshift(choice)
}
let message
if (currentTeam) {
message = `Switch to:`
}
const choice = await listInput({
message,
choices,
separator: false
})
// Abort
if (!choice) {
info('No changes made')
return exit()
}
const newTeam = list.find(item => item.slug === choice)
// Switch to account
if (!newTeam) {
if (currentTeam.slug === user.username || currentTeam.slug === user.email) {
info('No changes made')
return exit()
}
stopSpinner = wait('Saving')
await cfg.remove('currentTeam')
stopSpinner()
return success(`Your account (${chalk.bold(choice)}) is now active!`)
}
if (newTeam.slug === currentTeam.slug) {
info('No changes made')
return exit()
}
stopSpinner = wait('Saving')
await updateCurrentTeam({ cfg, newTeam })
stopSpinner()
success(`The team ${chalk.bold(newTeam.name)} is now active!`)
}

View File

@@ -1,30 +0,0 @@
/* eslint-disable no-var */
// Native
var path = require('path')
var fs = require('fs')
var dist = path.join(__dirname, 'dist')
var src = path.join(__dirname, 'src')
// Don't install when developing locally
if (fs.existsSync(src)) {
// eslint-disable-next-line unicorn/no-process-exit
process.exit(0)
}
var download = path.join(dist, 'download.js')
try {
fs.mkdirSync(dist)
} catch (err) {
if (err.code !== 'EEXIST') {
throw err
}
}
fs.closeSync(
fs.openSync(download, 'a')
)
require(download)

View File

@@ -1,9 +0,0 @@
import fs from 'fs'
export default function (file) {
const s = fs.statSync(file)
const newMode = s.mode | 64 | 8 | 1
if (s.mode === newMode) return
const base8 = newMode.toString(8).slice(-3)
fs.chmodSync(file, base8)
}

View File

@@ -1,110 +0,0 @@
/* eslint-disable unicorn/no-process-exit */
// Native
import fs from 'fs'
import path from 'path'
// Packages
import onDeath from 'death'
import fetch from 'node-fetch'
// Utilities
import plusxSync from './chmod'
import { disableProgress, enableProgress, info, showProgress } from './log'
const now = path.join(__dirname, 'now')
const targetWin32 = path.join(__dirname, 'now.exe')
const target = process.platform === 'win32' ? targetWin32 : now
const partial = target + '.partial'
const packagePath = path.join(__dirname, '../../package.json')
const packageJSON = JSON.parse(fs.readFileSync(packagePath, 'utf8'))
const platformToName = {
darwin: 'now-macos',
linux: 'now-linux',
win32: 'now-win.exe'
}
async function main() {
fs.writeFileSync(
now,
'#!/usr/bin/env node\n' +
'console.log("Please wait until the \'now\' installation completes!")\n'
)
onDeath(() => {
fs.writeFileSync(
now,
'#!/usr/bin/env node\n' +
'console.log("The \'now\' installation did not complete successfully.")\n' +
'console.log("Please run \'npm i -g now\' to reinstall!")\n'
)
process.exit();
})
info('For the sources, check out: https://github.com/zeit/now-cli')
// Print an empty line
console.log('')
enableProgress('Downloading now CLI ' + packageJSON.version)
showProgress(0)
const name = platformToName[process.platform]
const url = `https://github.com/zeit/now-cli/releases/download/${packageJSON.version}/${name}`
const resp = await fetch(url)
if (resp.status !== 200) {
disableProgress()
throw new Error(resp.statusText + ' ' + url)
}
const size = resp.headers.get('content-length')
const ws = fs.createWriteStream(partial)
await new Promise((resolve, reject) => {
let bytesRead = 0
resp.body.on('data', chunk => {
bytesRead += chunk.length
showProgress(100 * bytesRead / size)
}).on('error', error => {
disableProgress()
reject(error)
})
resp.body.pipe(ws)
ws.on('close', () => {
showProgress(100)
disableProgress()
resolve()
}).on('error', error => {
disableProgress()
reject(error)
})
})
fs.renameSync(partial, target)
if (process.platform === 'win32') {
fs.writeFileSync(
now,
'#!/usr/bin/env node\n' +
'var chip = require("child_process")\n' +
'var args = process.argv.slice(2)\n' +
'var opts = { stdio: "inherit" }\n' +
'var r = chip.spawnSync(__dirname + "/now.exe", args, opts)\n' +
'if (r.error) throw r.error\n' +
'process.exit(r.status)\n'
)
} else {
plusxSync(now)
}
}
main().catch(err => {
console.error(err)
process.exit(2)
})

View File

@@ -1,38 +0,0 @@
// Packages
import assert from 'assert'
import Progress from 'progress'
let bar
export function enableProgress(text) {
assert(!bar)
// OLD: text += ' '.repeat(28 - text.length);
bar = new Progress(`> ${text} [:bar] :percent`, {
stream: process.stdout,
width: 20,
complete: '=',
incomplete: ' ',
total: 100
})
}
export function info(text) {
console.log(`> ${text}`)
}
export function showProgress(percentage) {
assert(bar)
bar.update(percentage / 100)
}
export function disableProgress() {
assert(bar)
// It is auto-completed once it updates to 100
// otherwise it outputs a blank line
if (!bar.complete) {
bar.update(1)
}
bar = undefined
}

View File

@@ -1,40 +0,0 @@
const path = require('path')
const webpack = require('webpack')
module.exports = {
target: 'node',
node: {
__dirname: false,
__filename: false
},
entry: [
'./src/index.js'
],
output: {
path: path.join(__dirname, 'dist'),
filename: 'download.js'
},
module: {
loaders: [ {
test: /.js$/,
loader: 'babel-loader',
exclude: /node_modules/,
query: {
plugins: [
'transform-async-to-generator',
'transform-runtime'
],
presets: [
'es2015'
]
}
} ]
},
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify('production')
}
})
]
}

View File

@@ -0,0 +1,27 @@
# The DNS Challenge Could Not Be Solved
## Why This Error Occurred
When generating a certificate, we have to prove ownership over the domain
for the Certificate Authority (CA) that issues it. This error means that
the provider couldnt solve the requested challenges.
## How to Fix It
If your domain is pointing to ZEIT World DNS and youre getting this error,
it could be that:
- The domain was acquired recently, and it might not be ready for use yet.
- Required DNS records have not propagated yet.
When running into this, ensure that your nameservers are configured correctly. Also, if you bought the domain recently or have made changes, please be patient,
it might take a while for these to be ready.
If your domain is _not_ pointing to ZEIT World DNS and youre getting this
error, the following methods could help:
- When solving challenges *manually*, ensure that the TXT
records required to solve the challenges exist and are propagated. You can do so by querying the nameservers with `nslookup -q=TXT _acme-challenge.domain.com` depending on the Common Names you want for your certificate.
- If you are not solving the challenges manually you must ensure that you have an
`ALIAS` and `CNAME` records in place. Ensure also that you have disabled automatic redirects to `https` and ensure all changes were propagated.

View File

@@ -0,0 +1,37 @@
# Invalid Region or DC Identifier
#### Why This Error Occurred
When supplying `regions` or `scale` settings, you
used an unknown or invalid dc identifier.
#### Possible Ways to Fix It
Check your `now.json` or `--regions` flag and
make sure you are using a valid string. Regions
and DCs have to be in *lowercase*.
**Valid region identifiers**:
- `all` (special, used to scale to all DCs, can only appear once)
- `sfo`
- `bru`
- `gru`
- `iad`
In `now-cli`, they currently are transformed to
DC identifiers before being sent to our APIs.
**Valid DC identifiers**:
- `sfo1`
- `bru1`
- `gru1`
- `iad1`
When passing multiple `--regions` as a CLI parameter,
make sure they're separated by a comma (`,`). For example:
```console
now --regions sfo,bru,gru
```

View File

@@ -0,0 +1,23 @@
# The DNS Configuration can't be verified
## Why This Error Occurred
When generating a certificate, we have to prove ownership over the domain
for the Certificate Authority (CA) that issues it. We also run some pretests
to make sure the DNS is properly configured before submitting the request to
the CA. This error means that these pretests did not succeed.
## How to Fix It
If your domain is pointing to ZEIT World DNS and youre getting this error,
it could be that:
- The domain was acquired recently, and it might not be ready for use yet.
- Required DNS records have not propagated yet.
When running into this, ensure that your nameservers have configuration is correct. Also, if you bought the domain recently or have made changes, please be patient,
it might take a while for these to be ready.
If your domain is _not_ pointing to ZEIT World DNS and youre getting this
error, you must ensure that you have an `ALIAS` and `CNAME` records in place.
Ensure also that you have disabled automatic redirects to `https` and ensure all changes were propagated.

View File

@@ -0,0 +1,21 @@
# Domain Verification
#### Why This Error Occurred
The domain you supplied cannot be verified using either the intended set of nameservers of the given verification TXT record.
#### Possible Ways to Fix It
Apply the intended set of nameservers to your domain or add the given TXT verification record through your domain provider.
You can retrieve both the intended nameservers and TXT verification record for the domain you wish to verify by running `now domains inspect <domain>`.
When you have added either verification method to your domain, you can run `now domains verify <domain>` again to complete verification for your domain.
ZEIT will also automatically check periodically that your domain has been verified and automatically mark it as such if we detect either verification method on the domain.
If you would not like to verify your domain, you can remove it from your account using `now domains rm <domain>`.
#### Resources
- [ZEIT Domains Documentation](https://zeit.co/docs/v2/domains-and-aliases/adding-a-domain/)
- [Zero-Downtime Domain Migration Guide](https://zeit.co/docs/v2/domains-and-aliases/zero-downtime-domain-migration/)

17
errors/env-no-secret.md Normal file
View File

@@ -0,0 +1,17 @@
# Secret Not Found
#### Why This Error Occurred
You specified the `--env` or `-e` flag with the value of a secret. However, the secret doesn't exist in the current scope you're in.
#### Possible Ways to Fix It
Make sure to specify the environment variable and secret like that:
```bash
now -e VARIABLE_NAME=@secret-name
```
In addition, ensure that the secret (`@secret-name` in the example above) exists in the current scope (the team or user account that you're using).
You can run `now switch` or `--scope` to switch to a different team or user.

View File

@@ -0,0 +1,21 @@
# Bad Type in Env Value
#### Why This Error Occurred
You supplied a value in the `env` of your deployment whose type is not allowed.
This occurs for example if you use a `Boolean` as a type:
```json
{
"env": {
"VALID": 1,
"INVALID": true
}
}
```
#### Possible Ways to Fix It
The only accepted types are `String` or `Number`. If you're using a
`Boolean`, consider using `1` (`Number`) or `"true"` (`String`).

View File

@@ -0,0 +1,9 @@
# Missing `--dotenv` Target
#### Why This Error Occurred
You specified a path as the value for the `--dotenv` flag, but the target of the path doesn't exist.
#### Possible Ways to Fix It
Make sure the target file you've specified exists and is readable by Now CLI. In addition, please ensure that the filename starts with a dot (example: `.env`) - then it should work.

View File

@@ -0,0 +1,26 @@
# Missing Environment Variables While Developing
#### Why This Error Occurred
You ran `now dev` inside a project that contains a `now.json` file with `env` or `build.env` properties that use [Now Secrets](https://zeit.co/docs/v2/deployments/environment-variables-and-secrets).
In order to use environment variables in your project locally that have values defined using the Now Secrets format (e.g. `@my-secret-value`), you will need to provide the value as an environment variable using a `.env` or `.env.build` file.
We require this to ensure your app works as you intend it to, in the Now Dev environment, and to provide you with a way to mirror or separate private environment variables within your applications, for example when connecting to a database.
Read below for how to address this error.
#### Possible Ways to Fix It
The error message will list environment variables that are required and which file they are required to be included in (either `.env` or `.env.build`).
If the file does not exist yet, please create the file that the error message mentions and insert the missing environment variable into it.
For example, if the error message shows that the environment variable `TEST` is missing from `.env`, then the `.env` file should look like this:
```
TEST=value
```
In the above example, `TEST` represents the name of the environment variable and `value` its value.
For more information on Environment Variables in development, [see the documentation](https://zeit.co/docs/v2/development/environment-variables/).

View File

@@ -0,0 +1,19 @@
# Missing Env Key and Value
#### Why This Error Occurred
You specified the `--env` or `-e` flag and didn't add a name and value for the environment variable.
#### Possible Ways to Fix It
Make sure to set the name and value of the variable like this:
```bash
now -e VARIABLE_NAME="VALUE"
```
You can also specify a environment variable that contains a secret:
```bash
now -e VARIABLE_NAME=@secret-name
```

View File

@@ -0,0 +1,11 @@
# Missing Scope Value
#### Why This Error Occurred
The `--scope` flag was specified, but there's no value for it available.
#### Possible Ways to Fix It
In order to make it work, you need to specify a value for the `--scope` flag. This needs to be the slug or ID of the team as which you'd like to act or the username or ID of a user you'd like to act as.
As an example, if your team URL is `https://zeit.co/teams/zeit`, you would set `--scope` to `zeit`.

View File

@@ -0,0 +1,11 @@
# Missing Token Value
#### Why This Error Occurred
The `--token` flag was specified, but there's no value for it available.
#### Possible Ways to Fix It
In order to make it work, you need to specify a value for the `--token` flag. This needs to be the token of the user account as which you'd like to act.
You can either get the token from the `./now/auth.json` file located in your user directory or [from the dashboard](https://zeit.co/account/tokens).

View File

@@ -0,0 +1,10 @@
# No Credentials Found
#### Why This Error Occurred
You're running Now CLI in a non-terminal context and there are no credentials available. This means that Now CLI is not able to authenticate against our service.
#### Possible Ways to Fix It
- Specify a value for the `--token` flag (this needs to be the token of the user account as which you'd like to act). You can either get the token from the `./now/auth.json` file located in your user directory or [from the dashboard](https://zeit.co/account/tokens).
- Ensure that both `~/now/auth.json` and `~/now/config.json` exist

View File

@@ -0,0 +1,10 @@
# No Open Port Found
#### Why This Error Occurred
Your application code exited or timed out before binding to a port number.
#### Possible Ways to Fix It
- For Node.js deployments, a call to [`Server#listen()`](https://nodejs.org/dist/latest/docs/api/http.html#http_server_listen) might be missing.
- For Docker deployments, there might be a mismatch from what the `EXPOSE` directive specifies compared to what your application binds to.

View File

@@ -0,0 +1,11 @@
# No Token Allowed
#### Why This Error Occurred
You tried to run a command that doesn't allow the `--token` flag (like `now switch`). This is not allowed because commands like these are influencing the configuration files.
In turn, they would have to take the value of the `--token` flag into consideration (which is not a good idea, because flags in Now CLI should never change the configuration).
#### Possible Ways to Fix It
Specify a value for the `--scope` flag. This needs to be the slug or ID of the team as which you'd like to act (as an example, if your team URL is `https://zeit.co/teams/zeit`, the value can be `zeit`) or the username or ID of a user you'd like to act as.

View File

@@ -0,0 +1,9 @@
# `now dev` as `dev` script
#### Why This Error Occurred
The `package.json` file of the used project invokes `now dev` as `dev` script. This would cause `now dev` to recursively invoke itself.
#### Possible Ways to Fix It
Adjust the `dev` script inside the `package.json` file to match what your framework uses to begin development mode, e.g. `next` for Next.js or `gatsby develop` for Gatsby.

View File

@@ -0,0 +1,72 @@
# `@now/next` Legacy Mode
#### Why This Warning Occurred
`@now/next` has two modes: `legacy` and `serverless`. You will always want to use the `serverless` mode. `legacy` is to provide backwards compatibility with previous `@now/next` versions.
The differences:
Legacy:
- Minimal lambda size of `2.2Mb` (approximately)
- Forces `next@v7.0.2-canary.49` and `next-server@v7.0.2-canary.49`
- Forces all `dependencies` to be `devDependencies`
- Loads `next.config.js` on bootup, breaking sometimes when users didn't use `phases` to load files
- Used `next-server` which is the full Next.js server with routing etc.
- Runs `npm install`
- Runs `npm run now-build`
- Runs `npm install --production` after build
Serverless:
- Minimal lambda size of `49Kb` (approximately)
- Uses Next.js build targets (`target: 'serverless'`) in `next.config.js`. [documentation](https://github.com/zeit/next.js#summary)
- Does not make changes to your application dependencies
- Does not load `next.config.js` ([as per the serverless target documentation](https://github.com/zeit/next.js#summary))
- Runs `npm install`
- Runs `npm run now-build`
- Does not run `npm install --production` as the output from the build is all that's needed to bundle lambdas.
- No runtime dependencies, meaning smaller lambda functions
- Optimized for fast [cold start](https://zeit.co/blog/serverless-ssr#cold-start)
#### Possible Ways to Fix It
In order to create the smallest possible lambdas Next.js has to be configured to build for the `serverless` target.
1. Serverless Next.js requires Next.js 8 or later, to upgrade you can install the `latest` version:
```
npm install next --save
```
2. Add the `now-build` script to your `package.json`
```json
{
"scripts": {
"now-build": "next build"
}
}
```
3. Add `target: 'serverless'` to `next.config.js`
```js
module.exports = {
target: 'serverless',
// Other options are still valid
};
```
4. Optionally make sure the `"src"` in `"builds"` points to your application `package.json`
```js
{
"version": 2,
"builds": [{ "src": "package.json", "use": "@now/next" }]
}
```
### Useful Links
- [Serverless target implementation](https://github.com/zeit/now-builders/pull/150)

View File

@@ -0,0 +1,45 @@
# `@now/next` No Serverless Pages Built
#### Why This Error Occurred
This error occurs when you have your application is not configured for Serverless Next.js build output.
#### Possible Ways to Fix It
In order to create the smallest possible lambdas Next.js has to be configured to build for the `serverless` target.
1. Serverless Next.js requires Next.js 8 or later, to upgrade you can install the `latest` version:
```
npm install next --save
```
2. Add the `now-build` script to your `package.json`
```json
{
"scripts": {
"now-build": "next build"
}
}
```
3. Add `target: 'serverless'` to `next.config.js`
```js
module.exports = {
target: 'serverless',
// Other options
};
```
4. Remove `distDir` from `next.config.js` as `@now/next` can't parse this file and expects your build output at `/.next`
5. Optionally make sure the `"src"` in `"builds"` points to your application `package.json`
```js
{
"version": 2,
"builds": [{ "src": "package.json", "use": "@now/next" }]
}
```

View File

@@ -0,0 +1,38 @@
# `@now/static-build` Failed to detect a server running
#### Why This Warning Occurred
When running `now dev`, the `@now/static-build` builder proxies relevant HTTP
requests to the server that is created by the `now-dev` script in the
`package.json` file.
In order for `now dev` to know which port the server is running on, the builder
is provided a `$PORT` environment variable that the server _must_ bind to. The
error "Failed to detect a server running on port" is printed if the builder fails
to detect a server listening on that specific port within five minutes.
#### Possible Ways to Fix It
Please ensure that your `now-dev` script binds the spawned development server on
the provided `$PORT` that the builder expects the server to bind to.
For example, if you are using Gatsby, your `now-dev` script must use the `-p`
(port) option to bind to the `$PORT` specified from the builder:
```
{
...
"scripts": {
...
"now-dev": "gatsby develop -p $PORT"
}
}
```
Consult your static builder program's `--help` or documentation to figure out what
the command line flag to bind to a specific port is (in many cases, it is one of:
`-p` / `-P` / `--port`).
### Useful Links
- [`@now/static-build` Local Development Documentation](https://zeit.co/docs/v2/deployments/official-builders/static-build-now-static-build#local-development)

View File

@@ -0,0 +1,15 @@
# Path Not Deployable
#### Why This Error Occurred
You either tried to run Now CLI inside a directory that should never be deployed, or you specified a directory that should never be deployed like this: `now <directory>`.
#### Possible Ways to Fix It
Make sure that you're not trying to deploy one of these directories:
- User
- Downloads
- Desktop
These directories are not supported for security reasons.

View File

@@ -0,0 +1,32 @@
# Can't Set `regions` and `scale` Options Simultaneously
#### Why This Error Occurred
Your deployment's configuration contains a `regions` and `scale`
configuration simultaneously.
#### Possible Ways to Fix It
The `regions` setting is intended to be used to scale the
deployment to the supplied regions or datacenters identifiers
with default scale settings.
```json
{
"regions": ["sfo", "bru", "gru", "iad"]
}
```
The `scale` object allows you to be more granular: you can decide a
`min` and `max` number of instances per region:
```json
{
"scale": {
"sfo": { "min": 0, "max": 10 }
}
}
```
To solve this problem, use only one of the two ways of deciding
where to scale your deployment to.

View File

@@ -0,0 +1,36 @@
# Invalid Region or DC Identifier
#### Why This Error Occurred
When supplying a region or DC identifier in `now scale`,
we weren't able to recognize the value as valid.
#### Possible Ways to Fix It
Check your `now scale` command make sure you are using a
valid string after the URL. Regions
and DCs have to be in *lowercase*.
**Valid region identifiers**:
- `all` (special, used to scale to all DCs, can only appear once)
- `sfo`
- `bru`
- `gru`
- `iad`
In `now-cli`, they currently are transformed to
DC identifiers before being sent to our APIs.
**Valid DC identifiers**:
- `sfo1`
- `bru1`
- `gru1`
- `iad1`
To pass multiple ones, use a comma:
```
now scale my-url-123.now.sh sfo,bru,gru 1 5
```

31
errors/scale-ls.md Normal file
View File

@@ -0,0 +1,31 @@
# `now scale ls` is deprecated
#### Why This Error Occurred
We have stopped supporting this command, in favor of
better alternatives.
`now scale ls` used to list all the scaling rules
for all your deployments. The output would be too long,
and it would often be hard to find the information
you needed in a long list of items.
#### Possible Ways to Fix It
Instead of using `now scale ls` to list all your deployments
and their scaling rules, first use `now ls` to find
your deployment:
```console
now ls
```
Then, select the URL of your deployment, which uniquely identifies it, and run:
```console
now inspect my-deployment-12345.now.sh
```
The `inspect` subcommand will give you your deployment's scale information, including what datacenters it's enabled on, the
current number of instances and minimums/maximums.

View File

@@ -0,0 +1,12 @@
# Scaling path alias
#### Why This Error Occurred
You tried to use `now scale` on a path alias (`now alias -r rules.json`).
#### Possible Ways to Fix It
Path aliases are routes to instances. Instances can be scaled independent from each other.
You can view path aliases by running `now alias ls <id>`.
Documentation for Path Aliases can be found [here](https://zeit.co/docs/features/path-aliases).

View File

@@ -0,0 +1,10 @@
# Scope Not Accessible
#### Why This Error Occurred
You specified the `--scope` flag and specified the ID or slug of a team that you're not a part of or a user whose account you don't own. This problem could also occur if your user credentials aren't valid anymore.
#### Possible Ways to Fix It
- Make sure commands like `now ls` work just fine. This will ensure that your user credentials are valid. If it's not working correctly, please log in again using `now login`.
- Ensure that the scope you specified using `--scope` shows up in the output of `now switch`. If it doesn't, you're either not part of the team (if you specified a team) or you logged into the wrong user account.

View File

@@ -0,0 +1,11 @@
# Scope Not Existent
#### Why This Error Occurred
You specified the `--scope` flag and specified the ID or slug of a team that does not exist or that you're not a part of. Similarly you might have specified the ID or username of user whose account you don't own.
#### Possible Ways to Fix It
If you're sure the specified team exists, please make sure that you're a part of it (ask an owner of the team to invite you). If you specified the identifier of a user, make sure you are actually the owner of this account.
Otherwise, either create a team with the specified slug or ensure that the identifier is correct if you're sure that the scope exists.

View File

@@ -0,0 +1,20 @@
# DNS Challenges must be solved manually
## Why This Error Occurred
When generating a certificate, we have to prove ownership over the domain
for the Certificate Authority (CA) that issues it. In the case of Wildcard Certificates,
the requested challenge consists of adding TXT DNS records so, when the domain does not
point to ZEIT World DNS, we cannot create the records to solve the challenge.
## How to Fix It
To generate a certificate solving challenges manually, you must add the given `TXT` records with
the appropriate name to your DNS. Then, after verifying that the CA can read the records,
you can rerun the issuance command.
In case you want to start issuing a certificate to get the records you have to add or to
get those records again in the console, You can run the issuance command including the
`--challenge-only` option. This way the CLI will output the challenges information and,
after adding those records, you can rerun the command without `--challenge-only` to finish
issuance.

View File

@@ -0,0 +1,9 @@
# Not authorized to access domain
#### Why This Error Occurred
You tried to add or update a domain's configuration, but you don't have permission to modify the domain.
#### Possible Ways to Fix It
If you or your team owns the domain, then you are most likely in the wrong context. Use `now switch` to select the team or user that owns the domain.

17
errors/v2-no-min.md Normal file
View File

@@ -0,0 +1,17 @@
# No minimum scale settings on Cloud v2 deployments
#### Why This Error Occurred
An attempt was made at scaling a Cloud v2 deployment with a `min` scale
setting. This isn't supported yet.
#### Possible Ways to Fix It
Ensure your scale settings (in `now.json`, the command you're running
or from a previous deployment who's alias you're trying to overwrite) has
the `min` scale setting set to `0`. You can do this by running
```
now scale <deployment> 0 10
```

View File

@@ -0,0 +1,29 @@
# Verification Timeout
#### Why This Error Occurred
After the deployment build completed and the deployment state was set to `READY`,
instances failed to initialize properly.
The CLI attempted to verify that the scale settings of your instances matched,
but it couldn't do so within the allotted time (defaults to 2 minutes).
#### Possible Ways to Fix It
Instance verification is the process of ensuring that after
your deployment is ready, we can actually run (instantiate) your code.
If you configured [regions or scale](https://zeit.co/docs/features/scaling),
we ensure the minimums and maximums are met for the regions you enabled.
If you think your code is taking too long to instantiate, this can be due
to slow boot up times. You can supply `--no-verify` to skip verification
if you are confident your code runs properly.
If your application is not listening on a HTTP port, we might be failing to
instantiate your deployment as well. It might not be showing any errors,
but the deployment instance is effectively not routable and cannot be
verified.
If your instances are crashing before an HTTP port is exposed, verification
will fail as well. Double check your logs (e.g.: by running `now logs <url>`)

14
lerna.json Normal file
View File

@@ -0,0 +1,14 @@
{
"npmClient": "yarn",
"useWorkspaces": true,
"packages": ["packages/*"],
"command": {
"publish": {
"npmClient": "npm",
"allowBranch": ["master", "canary"],
"registry": "https://registry.npmjs.org/"
}
},
"version": "independent"
}

View File

@@ -1,83 +0,0 @@
// Native
const { parse } = require('url')
const http = require('http')
const https = require('https')
// Packages
const fetch = require('node-fetch')
/**
* Returns a `fetch` version with a similar
* API to the browser's configured with a
* HTTP2 agent.
*
* It encodes `body` automatically as JSON.
*
* @param {String} host
* @return {Function} fetch
*/
module.exports = class Agent {
constructor(url, { tls = true, debug } = {}) {
this._url = url
const parsed = parse(url)
this._protocol = parsed.protocol
this._debug = debug
if (tls) {
this._initAgent()
}
}
_initAgent() {
const module = this._protocol === 'https:' ? https : http
this._agent = new module.Agent({
keepAlive: true,
keepAliveMsecs: 10000,
maxSockets: 8
}).on('error', err => this._onError(err, this._agent))
}
_onError(err, agent) {
if (this._debug) {
console.log(`> [debug] agent connection error ${err}\n${err.stack}`)
}
if (this._agent === agent) {
this._agent = null
}
}
fetch(path, opts = {}) {
if (!this._agent) {
if (this._debug) {
console.log('> [debug] re-initializing agent')
}
this._initAgent()
}
const { body } = opts
if (this._agent) {
opts.agent = this._agent
}
if (body && typeof body === 'object' && typeof body.pipe !== 'function') {
opts.headers['Content-Type'] = 'application/json'
opts.body = JSON.stringify(body)
}
if (opts.body && typeof body.pipe !== 'function') {
opts.headers['Content-Length'] = Buffer.byteLength(opts.body)
}
return fetch(this._url + path, opts)
}
close() {
if (this._debug) {
console.log('> [debug] closing agent')
}
if (this._agent) {
this._agent.destroy()
}
}
}

View File

@@ -1,872 +0,0 @@
// Packages
const { readFileSync } = require('fs')
const publicSuffixList = require('psl')
const minimist = require('minimist')
const ms = require('ms')
const chalk = require('chalk')
const { write: copy } = require('clipboardy')
// Ours
const promptBool = require('../lib/utils/input/prompt-bool')
const info = require('../lib/utils/output/info')
const param = require('../lib/utils/output/param')
const wait = require('../lib/utils/output/wait')
const success = require('../lib/utils/output/success')
const uid = require('../lib/utils/output/uid')
const eraseLines = require('../lib/utils/output/erase-lines')
const stamp = require('../lib/utils/output/stamp')
const error = require('../lib/utils/output/error')
const treatBuyError = require('../lib/utils/domains/treat-buy-error')
const scaleInfo = require('./scale-info')
const { DOMAIN_VERIFICATION_ERROR } = require('./errors')
const isZeitWorld = require('./is-zeit-world')
const resolve4 = require('./dns')
const toHost = require('./to-host')
const exit = require('./utils/exit')
const Now = require('./')
const argv = minimist(process.argv.slice(2), {
boolean: ['no-clipboard'],
alias: { 'no-clipboard': 'C' }
})
const isTTY = process.stdout.isTTY
const clipboard = !argv['no-clipboard']
const domainRegex = /^((?=[a-z0-9-]{1,63}\.)(xn--)?[a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,63}$/
module.exports = class Alias extends Now {
async ls(deployment) {
if (deployment) {
const target = await this.findDeployment(deployment)
if (!target) {
const err = new Error(
`Aliases not found by "${deployment}". Run ${chalk.dim(
'`now alias ls`'
)} to see your aliases.`
)
err.userError = true
throw err
}
return this.listAliases(target.uid)
}
return this.listAliases()
}
async rm(_alias) {
return this.retry(async bail => {
const res = await this._fetch(`/now/aliases/${_alias.uid}`, {
method: 'DELETE'
})
if (res.status === 403) {
return bail(new Error('Unauthorized'))
}
if (res.status !== 200) {
const err = new Error('Deletion failed. Try again later.')
throw err
}
})
}
async findDeployment(deployment) {
const list = await this.list()
let key
let val
if (/\./.test(deployment)) {
val = toHost(deployment)
key = 'url'
} else {
val = deployment
key = 'uid'
}
const depl = list.find(d => {
if (d[key] === val) {
if (this._debug) {
console.log(`> [debug] matched deployment ${d.uid} by ${key} ${val}`)
}
return true
}
// Match prefix
if (`${val}.now.sh` === d.url) {
if (this._debug) {
console.log(`> [debug] matched deployment ${d.uid} by url ${d.url}`)
}
return true
}
return false
})
return depl
}
async updatePathBasedroutes(alias, rules, domains) {
alias = await this.maybeSetUpDomain(alias, domains)
return this.upsertPathAlias(alias, rules)
}
async upsertPathAlias(alias, rules) {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] /now/aliases #${attempt}`)
}
const rulesData = this.readRulesFile(rules)
const ruleCount = rulesData.rules.length
const res = await this._fetch(`/now/aliases`, {
method: 'POST',
body: { alias, rules: rulesData.rules }
})
const body = await res.json()
body.ruleCount = ruleCount
if (this._debug) {
console.timeEnd(`> [debug] /now/aliases #${attempt}`)
}
// 409 conflict is returned if it already exists
if (res.status === 409) {
return { uid: body.error.uid }
}
if (res.status === 422) {
return body
}
// No retry on authorization problems
if (res.status === 403) {
const code = body.error.code
if (code === 'custom_domain_needs_upgrade') {
const err = new Error(
`Custom domains are only enabled for premium accounts. Please upgrade by running ${chalk.gray(
'`'
)}${chalk.cyan('now upgrade')}${chalk.gray('`')}.`
)
err.userError = true
return bail(err)
}
if (code === 'alias_in_use') {
const err = new Error(
`The alias you are trying to configure (${chalk.underline(
chalk.bold(alias)
)}) is already in use by a different account.`
)
err.userError = true
return bail(err)
}
if (code === 'forbidden') {
const err = new Error(
'The domain you are trying to use as an alias is already in use by a different account.'
)
err.userError = true
return bail(err)
}
return bail(new Error('Authorization error'))
}
// All other errors
if (body.error) {
const code = body.error.code
if (code === 'cert_missing') {
console.log(
`> Provisioning certificate for ${chalk.underline(
chalk.bold(alias)
)}`
)
try {
await this.createCert(alias)
} catch (err) {
// We bail to avoid retrying the whole process
// of aliasing which would involve too many
// retries on certificate provisioning
return bail(err)
}
// Try again, but now having provisioned the certificate
return this.upsertPathAlias(alias, rules)
}
if (code === 'cert_expired') {
console.log(
`> Renewing certificate for ${chalk.underline(chalk.bold(alias))}`
)
try {
await this.createCert(alias, { renew: true })
} catch (err) {
return bail(err)
}
}
return bail(new Error(body.error.message))
}
// The two expected succesful cods are 200 and 304
if (res.status !== 200 && res.status !== 304) {
throw new Error('Unhandled error')
}
return body
})
}
readRulesFile(rules) {
try {
const rulesJson = readFileSync(rules, 'utf8')
return JSON.parse(rulesJson)
} catch (err) {
console.error(`Reading rules file ${rules} failed: ${err}`)
}
}
async set(deployment, alias, domains, currentTeam, user) {
alias = alias.replace(/^https:\/\//i, '')
if (alias.indexOf('.') === -1) {
// `.now.sh` domain is implied if just the subdomain is given
alias += '.now.sh'
}
const depl = await this.findDeployment(deployment)
if (!depl) {
const err = new Error(
`Deployment not found by "${deployment}". Run ${chalk.dim(
'`now ls`'
)} to see your deployments.`
)
err.userError = true
throw err
}
const aliasDepl = (await this.listAliases()).find(e => e.alias === alias)
if (aliasDepl && aliasDepl.rules) {
if (isTTY) {
try {
const msg =
`> Path alias exists with ${aliasDepl.rules.length} rule${aliasDepl
.rules.length > 1
? 's'
: ''}.\n` +
`> Are you sure you want to update ${alias} to be a normal alias?\n`
const confirmation = await promptBool(msg, {
trailing: '\n'
})
if (!confirmation) {
info('Aborted')
return exit(1)
}
} catch (err) {
console.log(err)
}
} else {
console.log(
`Overwriting path alias with ${aliasDepl.rules.length} rule${aliasDepl
.rules.length > 1
? 's'
: ''} to be a normal alias.`
)
}
}
let aliasedDeployment = null
let shouldScaleDown = false
if (aliasDepl && depl.scale) {
aliasedDeployment = await this.findDeployment(aliasDepl.deploymentId)
if (
aliasedDeployment &&
aliasedDeployment.scale &&
aliasedDeployment.scale.current >= depl.scale.current &&
(aliasedDeployment.scale.min > depl.scale.min ||
aliasedDeployment.scale.max > depl.scale.max)
) {
shouldScaleDown = true
console.log(
`> Alias ${alias} points to ${chalk.bold(
aliasedDeployment.url
)} (${chalk.bold(aliasedDeployment.scale.current + ' instances')})`
)
// Test if we need to change the scale or just update the rules
console.log(
`> Scaling ${depl.url} to ${chalk.bold(
aliasedDeployment.scale.current + ' instances'
)} atomically`
)
if (depl.scale.current !== aliasedDeployment.scale.current) {
if (depl.scale.max < 1) {
if (this._debug) {
console.log(
'Updating max scale to 1 so that deployment may be unfrozen.'
)
}
await this.setScale(depl.uid, {
min: depl.scale.min,
max: Math.max(aliasedDeployment.scale.max, 1)
})
}
if (depl.scale.current < 1) {
if (this._debug) {
console.log(`> Deployment ${depl.url} is frozen, unfreezing...`)
}
await this.unfreeze(depl)
if (this._debug) {
console.log(
`> Deployment is now unfrozen, scaling it to match current instance count`
)
}
}
// Scale it to current limit
if (depl.scale.current !== aliasedDeployment.scale.current) {
if (this._debug) {
console.log(`> Scaling deployment to match current scale.`)
}
await this.setScale(depl.uid, {
min: aliasedDeployment.scale.current,
max: aliasedDeployment.scale.current
})
}
await scaleInfo(this, depl.url)
if (this._debug) {
console.log(`> Updating scaling rules for deployment.`)
}
}
await this.setScale(depl.uid, {
min: Math.max(aliasedDeployment.scale.min, depl.scale.min),
max: Math.max(aliasedDeployment.scale.max, depl.scale.max)
})
}
}
alias = await this.maybeSetUpDomain(alias, domains, currentTeam, user)
const aliasTime = Date.now()
const newAlias = await this.createAlias(depl, alias)
if (!newAlias) {
throw new Error(
`Unexpected error occurred while setting up alias: ${JSON.stringify(
newAlias
)}`
)
}
const { created, uid } = newAlias
if (created) {
const output = `${chalk.cyan(
'> Success!'
)} ${alias} now points to ${chalk.bold(depl.url)}! ${chalk.grey(
'[' + ms(Date.now() - aliasTime) + ']'
)}`
if (isTTY && clipboard) {
try {
await copy(depl.url)
} catch (err) {
} finally {
console.log(output)
}
} else {
console.log(output)
}
} else {
console.log(
`${chalk.cyan('> Success!')} Alias already exists ${chalk.dim(
`(${uid})`
)}.`
)
}
if (aliasedDeployment && shouldScaleDown) {
const scaleDown = Date.now()
await this.setScale(aliasedDeployment.uid, { min: 0, max: 1 })
console.log(
`> Scaled ${chalk.gray(
aliasedDeployment.url
)} down to 1 instance ${chalk.gray(
'[' + ms(Date.now() - scaleDown) + ']'
)}`
)
}
}
createAlias(depl, alias) {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(
`> [debug] /now/deployments/${depl.uid}/aliases #${attempt}`
)
}
const res = await this._fetch(`/now/deployments/${depl.uid}/aliases`, {
method: 'POST',
body: { alias }
})
const body = await res.json()
if (this._debug) {
console.timeEnd(
`> [debug] /now/deployments/${depl.uid}/aliases #${attempt}`
)
}
// 409 conflict is returned if it already exists
if (res.status === 409) {
return { uid: body.error.uid }
}
// No retry on authorization problems
if (res.status === 403) {
const code = body.error.code
if (code === 'custom_domain_needs_upgrade') {
const err = new Error(
`Custom domains are only enabled for premium accounts. Please upgrade by running ${chalk.gray(
'`'
)}${chalk.cyan('now upgrade')}${chalk.gray('`')}.`
)
err.userError = true
return bail(err)
}
if (code === 'alias_in_use') {
const err = new Error(
`The alias you are trying to configure (${chalk.underline(
chalk.bold(alias)
)}) is already in use by a different account.`
)
err.userError = true
return bail(err)
}
if (code === 'forbidden') {
const err = new Error(
'The domain you are trying to use as an alias is already in use by a different account.'
)
err.userError = true
return bail(err)
}
return bail(new Error('Authorization error'))
}
// All other errors
if (body.error) {
const code = body.error.code
if (code === 'deployment_not_found') {
return bail(new Error('Deployment not found'))
}
if (code === 'cert_missing') {
console.log(
`> Provisioning certificate for ${chalk.underline(
chalk.bold(alias)
)}`
)
try {
await this.createCert(alias)
} catch (err) {
// We bail to avoid retrying the whole process
// of aliasing which would involve too many
// retries on certificate provisioning
return bail(err)
}
// Try again, but now having provisioned the certificate
return this.createAlias(depl, alias)
}
if (code === 'cert_expired') {
console.log(
`> Renewing certificate for ${chalk.underline(chalk.bold(alias))}`
)
try {
await this.createCert(alias, { renew: true })
} catch (err) {
return bail(err)
}
}
return bail(new Error(body.error.message))
}
// The two expected succesful cods are 200 and 304
if (res.status !== 200 && res.status !== 304) {
throw new Error('Unhandled error')
}
return body
})
}
async setupRecord(domain, name) {
await this.setupDomain(domain)
if (this._debug) {
console.log(`> [debug] Setting up record "${name}" for "${domain}"`)
}
const type = name === '' ? 'ALIAS' : 'CNAME'
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] /domains/${domain}/records #${attempt}`)
}
const res = await this._fetch(`/domains/${domain}/records`, {
method: 'POST',
body: { type, name: name === '' ? name : '*', value: 'alias.zeit.co' }
})
if (this._debug) {
console.timeEnd(`> [debug] /domains/${domain}/records #${attempt}`)
}
if (res.status === 403) {
return bail(new Error('Unauthorized'))
}
const body = await res.json()
if (res.status !== 200) {
throw new Error(body.error.message)
}
return body
})
}
async maybeSetUpDomain(alias, domains, currentTeam, user) {
const gracefulExit = () => {
this.close()
domains.close()
// eslint-disable-next-line unicorn/no-process-exit
process.exit()
}
// Make alias lowercase
alias = alias.toLowerCase()
// Trim leading and trailing dots
// for example: `google.com.` => `google.com`
alias = alias.replace(/^\.+/, '').replace(/\.+$/, '')
// Evaluate the alias
if (/\./.test(alias)) {
alias = toHost(alias)
} else {
if (this._debug) {
console.log(`> [debug] suffixing \`.now.sh\` to alias ${alias}`)
}
alias = `${alias}.now.sh`
}
if (!domainRegex.test(alias)) {
const err = new Error(`Invalid alias "${alias}"`)
err.userError = true
throw err
}
if (!/\.now\.sh$/.test(alias)) {
console.log(`> ${chalk.bold(chalk.underline(alias))} is a custom domain.`)
let stopSpinner = wait('Fetching domain info')
let elapsed = stamp()
const parsed = publicSuffixList.parse(alias)
const pricePromise = domains.price(parsed.domain).catch(() => {
// Can be safely ignored
})
const canBePurchased = await domains.status(parsed.domain)
const aliasParam = param(parsed.domain)
let price
let period
stopSpinner()
if (canBePurchased) {
try {
const json = await pricePromise
price = json.price
period = json.period
} catch (err) {
// Can be safely ignored
}
}
if (canBePurchased && price && period) {
const periodMsg = `${period}yr${period > 1 ? 's' : ''}`
info(
`The domain ${aliasParam} is ${chalk.italic(
'available'
)} to buy under ${chalk.bold(
(currentTeam && currentTeam.slug) || user.username || user.email
)}! ${elapsed()}`
)
const confirmation = await promptBool(
`Buy now for ${chalk.bold(`$${price}`)} (${periodMsg})?`
)
eraseLines(1)
if (!confirmation) {
info('Aborted')
gracefulExit()
}
elapsed = stamp()
stopSpinner = wait('Purchasing')
let domain
try {
domain = await domains.buy(parsed.domain)
} catch (err) {
stopSpinner()
treatBuyError(err)
gracefulExit()
}
stopSpinner()
success(`Domain purchased and created ${uid(domain.uid)} ${elapsed()}`)
stopSpinner = wait('Verifying nameservers')
let domainInfo
try {
domainInfo = await this.setupDomain(parsed.domain)
} catch (err) {
if (this._debug) {
console.log('> [debug] Error while trying to setup the domain', err)
}
}
stopSpinner()
if (!domainInfo.verified) {
const tld = param(`.${parsed.tld}`)
error(
'The nameservers are pending propagation. Please try again shortly'
)
info(
`The ${tld} servers might take some extra time to reflect changes`
)
gracefulExit()
}
}
console.log(
`> Verifying the DNS settings for ${chalk.bold(
chalk.underline(alias)
)} (see ${chalk.underline('https://zeit.world')} for help)`
)
const _domain = publicSuffixList.parse(alias).domain
const _domainInfo = await this.getDomain(_domain)
const domainInfo = _domainInfo && !_domainInfo.error
? _domainInfo
: undefined
const { domain, nameservers } = domainInfo
? { domain: _domain }
: await this.getNameservers(alias)
const usingZeitWorld = domainInfo
? !domainInfo.isExternal
: isZeitWorld(nameservers)
let skipDNSVerification = false
if (this._debug) {
if (domainInfo) {
console.log(
`> [debug] Found domain ${domain} with verified:${domainInfo.verified}`
)
} else {
console.log(
`> [debug] Found domain ${domain} and nameservers ${nameservers}`
)
}
}
if (!usingZeitWorld && domainInfo) {
if (domainInfo.verified) {
skipDNSVerification = true
} else if (domainInfo.uid) {
const { verified, created } = await this.setupDomain(domain, {
isExternal: true
})
if (!(created && verified)) {
const e = new Error(
`> Failed to verify the ownership of ${domain}, please refer to 'now domain --help'.`
)
e.userError = true
throw e
}
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
chalk.underline(domain)
)} verified`
)
}
}
try {
if (!skipDNSVerification) {
await this.verifyOwnership(alias)
}
} catch (err) {
if (err.userError) {
// A user error would imply that verification failed
// in which case we attempt to correct the dns
// configuration (if we can!)
try {
if (usingZeitWorld) {
console.log(
`> Detected ${chalk.bold(
chalk.underline('zeit.world')
)} nameservers! Configuring records.`
)
const record = alias.substr(0, alias.length - domain.length)
// Lean up trailing and leading dots
const _record = record.replace(/^\./, '').replace(/\.$/, '')
const _domain = domain.replace(/^\./, '').replace(/\.$/, '')
if (_record === '') {
await this.setupRecord(_domain, '*')
}
await this.setupRecord(_domain, _record)
this.recordSetup = true
console.log('> DNS Configured! Verifying propagation…')
try {
await this.retry(() => this.verifyOwnership(alias), {
retries: 10,
maxTimeout: 8000
})
} catch (err2) {
const e = new Error(
'> We configured the DNS settings for your alias, but we were unable to ' +
"verify that they've propagated. Please try the alias again later."
)
e.userError = true
throw e
}
} else {
console.log(
`> Resolved IP: ${err.ip
? `${chalk.underline(err.ip)} (unknown)`
: chalk.dim('none')}`
)
console.log(
`> Nameservers: ${nameservers && nameservers.length
? nameservers.map(ns => chalk.underline(ns)).join(', ')
: chalk.dim('none')}`
)
throw err
}
} catch (e) {
if (e.userError) {
throw e
}
throw err
}
} else {
throw err
}
}
if (!usingZeitWorld && !skipDNSVerification) {
if (this._debug) {
console.log(
`> [debug] Trying to register a non-ZeitWorld domain ${domain} for the current user`
)
}
const { uid, verified, created } = await this.setupDomain(domain, {
isExternal: true
})
if (!(created && verified)) {
const e = new Error(
`> Failed to verify the ownership of ${domain}, please refer to 'now domain --help'.`
)
e.userError = true
throw e
}
console.log(
`${chalk.cyan('> Success!')} Domain ${chalk.bold(
chalk.underline(domain)
)} ${chalk.dim(`(${uid})`)} added`
)
}
console.log(`> Verification ${chalk.bold('OK')}!`)
}
return alias
}
verifyOwnership(domain) {
return this.retry(
async bail => {
const targets = await resolve4('alias.zeit.co')
if (targets.length <= 0) {
return bail(new Error('Unable to resolve alias.zeit.co'))
}
let ips = []
try {
ips = await resolve4(domain)
} catch (err) {
if (
err.code === 'ENODATA' ||
err.code === 'ESERVFAIL' ||
err.code === 'ENOTFOUND'
) {
// Not errors per se, just absence of records
if (this._debug) {
console.log(`> [debug] No records found for "${domain}"`)
}
const err = new Error(DOMAIN_VERIFICATION_ERROR)
err.userError = true
return bail(err)
}
throw err
}
if (ips.length <= 0) {
const err = new Error(DOMAIN_VERIFICATION_ERROR)
err.userError = true
return bail(err)
}
for (const ip of ips) {
if (targets.indexOf(ip) === -1) {
const err = new Error(
`The domain ${domain} has an A record ${chalk.bold(
ip
)} that doesn't resolve to ${chalk.bold(
chalk.underline('alias.zeit.co')
)}.\n> ` + DOMAIN_VERIFICATION_ERROR
)
err.ip = ip
err.userError = true
return bail(err)
}
}
},
{ retries: 5 }
)
}
}

View File

@@ -1,138 +0,0 @@
// Native
const EventEmitter = require('events')
// Packages
const io = require('socket.io-client')
const chalk = require('chalk')
const { compare, deserialize } = require('./logs')
module.exports = class Logger extends EventEmitter {
constructor(host, token, { debug = false, quiet = false } = {}) {
super()
this.host = host
this.token = token
this.debug = debug
this.quiet = quiet
// ReadyState
this.building = false
this.socket = io(`https://io.now.sh/states?host=${host}&v=2`)
this.socket.once('error', this.onSocketError.bind(this))
this.socket.on('auth', this.onAuth.bind(this))
this.socket.on('state', this.onState.bind(this))
this.socket.on('logs', this.onLog.bind(this))
this.socket.on('backend', this.onComplete.bind(this))
// Log buffer
this.buf = []
this.printed = new Set()
}
onAuth(callback) {
if (this.debug) {
console.log('> [debug] authenticate')
}
callback(this.token)
}
onState(state) {
// Console.log(state)
if (!state.id) {
console.error('> Deployment not found')
this.emit('error')
return
}
if (state.error) {
this.emit('error', state)
return
}
if (state.backend) {
this.onComplete()
return
}
if (state.logs) {
state.logs.forEach(this.onLog, this)
}
}
onLog(log) {
if (!this.building) {
if (!this.quiet) {
console.log('> Building')
}
this.building = true
}
if (this.quiet) {
return
}
log = deserialize(log)
const timer = setTimeout(() => {
this.buf.sort((a, b) => compare(a.log, b.log))
const idx = this.buf.findIndex(b => b.log.id === log.id) + 1
for (const b of this.buf.slice(0, idx)) {
clearTimeout(b.timer)
this.printLog(b.log)
}
this.buf = this.buf.slice(idx)
}, 500)
this.buf.push({ log, timer })
}
onComplete() {
this.socket.disconnect()
if (this.building) {
this.building = false
}
this.buf.sort((a, b) => compare(a.log, b.log))
// Flush all buffer
for (const b of this.buf) {
clearTimeout(b.timer)
this.printLog(b.log)
}
this.buf = []
this.emit('close')
}
onSocketError(err) {
if (this.debug) {
console.log(`> [debug] Socket error ${err}\n${err.stack}`)
}
}
printLog(log) {
if (this.printed.has(log.id)) return
this.printed.add(log.id)
const data = log.object ? JSON.stringify(log.object) : log.text
if (log.type === 'command') {
console.log(`${chalk.gray('>')}${data}`)
} else if (log.type === 'stderr') {
data.split('\n').forEach(v => {
if (v.length > 0) {
console.error(chalk.gray(`> ${v}`))
}
})
} else if (log.type === 'stdout') {
data.split('\n').forEach(v => {
if (v.length > 0) {
console.log(`${chalk.gray('>')} ${v}`)
}
})
}
}
}

View File

@@ -1,101 +0,0 @@
// Ours
const Now = require('../lib')
module.exports = class Certs extends Now {
ls() {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} GET now/certs`)
}
const res = await this._fetch('/now/certs')
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} GET now/certs`)
}
const body = await res.json()
return body.certs
})
}
create(cn) {
return this.createCert(cn)
}
renew(cn) {
return this.createCert(cn, { renew: true })
}
put(cn, crt, key, ca) {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} PUT now/certs`)
}
const res = await this._fetch('/now/certs', {
method: 'PUT',
body: {
domains: [cn],
ca,
cert: crt,
key
}
})
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} PUT now/certs`)
}
if (res.status === 403) {
return bail(new Error('Unauthorized'))
}
const body = await res.json()
if (res.status !== 200) {
if (res.status === 404 || res.status === 400) {
const err = new Error(body.error.message)
err.userError = true
return bail(err)
}
throw new Error(body.error.message)
}
return body
})
}
delete(cn) {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} DELETE now/certs/${cn}`)
}
const res = await this._fetch(`/now/certs/${cn}`, { method: 'DELETE' })
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} DELETE now/certs/${cn}`)
}
if (res.status === 403) {
return bail(new Error('Unauthorized'))
}
const body = await res.json()
if (res.status !== 200) {
if (res.status === 404 || res.status === 400) {
const err = new Error(body.error.message)
err.userError = true
return bail(err)
}
throw new Error(body.error.message)
}
return body
})
}
}

View File

@@ -1,112 +0,0 @@
// Native
const { homedir } = require('os')
const path = require('path')
// Packages
const fs = require('fs-extra')
const ms = require('ms')
// Ours
const { get: getUser } = require('./user')
// `8h` is arbitrarily used based on the average sleep time
const TTL = ms('8h')
let file = process.env.NOW_JSON
? path.resolve(process.env.NOW_JSON)
: path.resolve(homedir(), '.now.json')
function setConfigFile(nowjson) {
file = path.resolve(nowjson)
}
function save(data) {
fs.writeFileSync(file, JSON.stringify(data, null, 2))
}
/**
* Reads the config file
*
* Optionally, always queries the API to get the user info even if the
* config file is not present
*
* @param {Boolean} force [false] Queries the API even if the config
* file is not present. If `true`, `token`
* *must* be specified
* @param {String} token Will be used to autenticate in the API
if needed
* @param {String} apiUrl URL of the API to be used
* @return {Object}
*/
async function read({ force = false, token, apiUrl } = {}) {
let existing = {}
try {
existing = fs.readFileSync(file, 'utf8')
existing = JSON.parse(existing)
} catch (err) {}
// Will happen if `force`d or if `--token` is used and it's different from
// The one that's stored (which can be `undefined`)
if ((force && token) || (token && token !== existing.token)) {
const user = await getUser({ token, apiUrl })
if (user) {
return {
token,
user: {
uid: user.uid,
username: user.username,
email: user.email
},
currentTeam: existing.currentTeam
}
}
return {}
}
if (!existing.token) {
return {}
}
if (!existing.lastUpdate || Date.now() - existing.lastUpdate > TTL) {
// TODO: update `teams` info
const token = existing.token
const user = await getUser({ token })
if (user) {
existing.user = user
existing.lastUpdate = Date.now()
save(existing)
}
}
return existing
}
/**
* Merges the `data` object onto the
* JSON config stored in `.now.json`.
*
* (atomic)
* @param {Object} data
*/
async function merge(data) {
const cfg = Object.assign({}, await read(), data)
save(cfg)
}
// Removes a key from the config and store the result
async function remove(key) {
const cfg = await read()
delete cfg[key]
fs.writeFileSync(file, JSON.stringify(cfg, null, 2))
}
// We need to remove the config file when running `now logout`
const removeFile = async () => fs.remove(file)
module.exports = {
setConfigFile,
read,
merge,
remove,
removeFile
}

View File

@@ -1,73 +0,0 @@
const stripe = require('stripe')('pk_live_alyEi3lN0kSwbdevK0nrGwTw')
const Now = require('../lib')
module.exports = class CreditCards extends Now {
async ls() {
const res = await this._fetch('/cards')
const body = await res.json()
if (res.status !== 200) {
const e = new Error(body.error.message)
e.code = body.error.code
throw e
}
return body
}
async setDefault(cardId) {
await this._fetch('/cards/default', {
method: 'PUT',
body: { cardId }
})
return true
}
async rm(cardId) {
await this._fetch(`/cards/${encodeURIComponent(cardId)}`, {
method: 'DELETE'
})
return true
}
/* eslint-disable camelcase */
add(card) {
return new Promise(async (resolve, reject) => {
const expDateParts = card.expDate.split(' / ')
card = {
name: card.name,
number: card.cardNumber,
cvc: card.ccv,
address_country: card.country,
address_zip: card.zipCode,
address_state: card.state,
address_city: card.city,
address_line1: card.address1
}
card.exp_month = expDateParts[0]
card.exp_year = expDateParts[1]
try {
const stripeToken = (await stripe.tokens.create({ card })).id
const res = await this._fetch('/cards', {
method: 'POST',
body: { stripeToken }
})
const body = await res.json()
if (body && body.id) {
resolve({
last4: body.last4
})
} else if (body.error && body.error.message) {
reject(new Error(body.error.message))
} else {
reject(new Error('Unknown error'))
}
} catch (err) {
reject(new Error(err.message || 'Unknown error'))
}
})
}
}

View File

@@ -1,15 +0,0 @@
// Packages
const dns = require('dns')
function resolve4(host) {
return new Promise((resolve, reject) => {
return dns.resolve4(host, (err, answer) => {
if (err) {
return reject(err)
}
resolve(answer)
})
})
}
module.exports = resolve4

View File

@@ -1,148 +0,0 @@
// Ours
const Now = require('../lib')
module.exports = class DomainRecords extends Now {
async getRecord(id) {
const all = (await this.ls()).entries()
for (const [domain, records] of all) {
for (const record of records) {
if (record.id === id) {
record.domain = domain
return record
}
}
}
return null
}
async ls(dom) {
let domains
if (dom) {
domains = [dom]
} else {
const ret = await this.listDomains()
domains = ret
.filter(x => !x.isExternal)
.map(x => x.name)
.sort((a, b) => a.localeCompare(b))
}
const records = new Map()
const bodies = []
for (const domain of domains) {
bodies.push(
this.retry(async (bail, attempt) => {
const url = `/domains/${domain}/records`
if (this._debug) {
console.time(`> [debug] #${attempt} GET ${url}`)
}
const res = await this._fetch(url)
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} GET ${url}`)
}
const body = await res.json()
if (res.status === 404 && body.code === 'not_found') {
return bail(new Error(body.message))
} else if (res.status !== 200) {
throw new Error(`Failed to get DNS records for domain "${domain}"`)
}
return body
})
)
}
const domainList = await Promise.all(bodies)
for (const body of domainList) {
const index = domainList.indexOf(body)
records.set(
domains[index],
body.records.sort((a, b) => a.slug.localeCompare(b.slug))
)
}
return records
}
create(domain, data) {
const url = `/domains/${domain}/records`
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} POST ${url}`)
}
const res = await this._fetch(url, {
method: 'POST',
body: data
})
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} POST ${url}`)
}
const body = await res.json()
if (res.status === 400) {
return bail(
new Error(body.error ? body.error.message : 'Unknown error')
)
} else if (res.status === 403) {
const err = new Error(`Not authorized to access the domain "${domain}"`)
err.userError = true
return bail(err)
} else if (res.status === 404) {
let err
if (body.error.code === 'not_found') {
err = new Error(`The domain "${domain}" was not found`)
err.userError = true
return bail(err)
}
}
if (res.status !== 200) {
throw new Error(body.error ? body.error.message : 'Unknown error')
}
return body
})
}
delete(domain, recordId) {
const url = `/domains/${domain}/records/${recordId}`
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} DELETE ${url}`)
}
const res = await this._fetch(url, { method: 'DELETE' })
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} DELETE ${url}`)
}
const body = await res.json()
if (res.status === 403) {
const err = new Error(`Not authorized to access domain ${domain}`)
err.userError = true
return bail(err)
} else if (res.status === 404) {
let err
if (body.error.code === 'not_found') {
err = new Error(body.error.message)
err.userError = true
return bail(err)
}
}
if (res.status !== 200) {
throw new Error(body.error ? body.error.message : 'Unkown error')
}
return body
})
}
}

View File

@@ -1,181 +0,0 @@
// Native
const { encode: encodeQuery } = require('querystring')
// Packages
const chalk = require('chalk')
// Ours
const Now = require('../lib')
const isZeitWorld = require('./is-zeit-world')
const { DNS_VERIFICATION_ERROR } = require('./errors')
const cmd = require('./utils/output/param')
const domainRegex = /^((?=[a-z0-9-]{1,63}\.)(xn--)?[a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,63}$/
module.exports = class Domains extends Now {
async ls() {
return this.listDomains()
}
async rm(name) {
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} DELETE /domains/${name}`)
}
const res = await this._fetch(`/domains/${name}`, { method: 'DELETE' })
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} DELETE /domains/${name}`)
}
if (res.status === 403) {
return bail(new Error('Unauthorized'))
}
if (res.status !== 200) {
const body = await res.json()
throw new Error(body.error.message)
}
})
}
async add(domain, skipVerification, isExternal) {
if (!domainRegex.test(domain)) {
const err = new Error(
`The supplied value ${chalk.bold(`"${domain}"`)} is not a valid domain.`
)
err.userError = true
throw err
}
if (skipVerification || isExternal) {
return this.setupDomain(domain, { isExternal })
}
let ns
try {
console.log('> Verifying nameservers…')
const res = await this.getNameservers(domain)
ns = res.nameservers
} catch (err) {
const err2 = new Error(
`Unable to fetch nameservers for ${chalk.underline(
chalk.bold(domain)
)}.`
)
err2.userError = true
throw err2
}
if (isZeitWorld(ns)) {
console.log(`> Verification ${chalk.bold('OK')}!`)
return this.setupDomain(domain)
}
if (this._debug) {
console.log(
`> [debug] Supplied domain "${domain}" has non-zeit nameservers`
)
}
const err3 = new Error(DNS_VERIFICATION_ERROR)
err3.userError = true
throw err3
}
async status(name) {
if (!name) {
throw new Error('`domain` is not defined')
}
const query = encodeQuery({ name })
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} GET /domains/status?${query}`)
}
const res = await this._fetch(`/domains/status?${query}`)
const json = await res.json()
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} GET /domains/status?${query}`)
}
return json.available
})
}
async price(name) {
if (!name) {
throw new Error('`domain` is not defined')
}
const query = encodeQuery({ name })
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} GET /domains/price?${query}`)
}
const res = await this._fetch(`/domains/price?${query}`)
const json = await res.json()
if (res.status === 400) {
const e = new Error(json.error.message)
e.code = json.error.code
return bail(e)
}
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} GET /domains/price?${query}`)
}
return json
})
}
async buy(name) {
if (!name) {
throw new Error('`name` is not defined')
}
const rawBody = { name }
if (name.startsWith('test')) {
rawBody.dev = true
}
const body = JSON.stringify(rawBody)
return this.retry(async (bail, attempt) => {
if (this._debug) {
console.time(`> [debug] #${attempt} GET /domains/buy`)
}
const res = await this._fetch(`/domains/buy`, {
method: 'POST',
body
})
const json = await res.json()
if (this._debug) {
console.timeEnd(`> [debug] #${attempt} GET /domains/buy`)
}
if ([400, 403, 500, 503].includes(res.status)) {
const e = new Error()
e.code = json.error.code
if (json.error.code === 'source_not_found') {
e.message = `No credit cards found please run ${cmd('now cc add')}`
} else {
e.message = json.error.message
}
return bail(e)
}
return json
})
}
}

View File

@@ -1,45 +0,0 @@
// Packages
const ms = require('ms')
const chalk = require('chalk')
const error = require('./utils/output/error')
const info = require('./utils/output/info')
function handleError(err) {
// Coerce Strings to Error instances
if (typeof err === 'string') {
err = new Error(err)
}
if (err.status === 403) {
error(
'Authentication error. Run `now -L` or `now --login` to log-in again.'
)
} else if (err.status === 429) {
if (err.retryAfter === 'never') {
error(err.message)
} else if (err.retryAfter === null) {
error('Rate limit exceeded error. Please try later.')
} else {
error(
'Rate limit exceeded error. Try again in ' +
ms(err.retryAfter * 1000, { long: true }) +
', or upgrade your account by runnung ' +
`${chalk.gray('`')}${chalk.cyan('now upgrade')}${chalk.gray('`')}`
)
}
} else if (err.userError) {
error(err.message)
} else if (err.status === 500) {
error('Unexpected server error. Please retry.')
} else if (err.code === 'USER_ABORT') {
info('Aborted')
} else {
error(`Unexpected error. Please try later. (${err.message})`)
}
}
module.exports = {
handleError,
error
}

View File

@@ -1,30 +0,0 @@
// Packages
const chalk = require('chalk')
const DNS_VERIFICATION_ERROR = `Please make sure that your nameservers point to ${chalk.underline(
'zeit.world'
)}.
> Examples: (full list at ${chalk.underline('https://zeit.world')})
> ${chalk.gray('-')} ${chalk.underline('california.zeit.world')} ${chalk.dim(
'173.255.215.107'
)}
> ${chalk.gray('-')} ${chalk.underline('newark.zeit.world')} ${chalk.dim(
'173.255.231.87'
)}
> ${chalk.gray('-')} ${chalk.underline('london.zeit.world')} ${chalk.dim(
'178.62.47.76'
)}
> ${chalk.gray('-')} ${chalk.underline('singapore.zeit.world')} ${chalk.dim(
'119.81.97.170'
)}`
const DOMAIN_VERIFICATION_ERROR =
DNS_VERIFICATION_ERROR +
`\n> Alternatively, ensure it resolves to ${chalk.underline(
'alias.zeit.co'
)} via ${chalk.dim('CNAME')} / ${chalk.dim('ALIAS')}.`
module.exports = {
DNS_VERIFICATION_ERROR,
DOMAIN_VERIFICATION_ERROR
}

View File

@@ -1,384 +0,0 @@
// Native
const { resolve } = require('path')
// Packages
const flatten = require('arr-flatten')
const unique = require('array-unique')
const ignore = require('ignore')
const _glob = require('glob')
const { stat, readdir, readFile } = require('fs-extra')
// Ours
const IGNORED = require('./ignored')
const glob = async function(pattern, options) {
return new Promise((resolve, reject) => {
_glob(pattern, options, (error, files) => {
if (error) {
reject(error)
} else {
resolve(files)
}
})
})
}
/**
* Remove leading `./` from the beginning of ignores
* because our parser doesn't like them :|
*/
const clearRelative = function(str) {
return str.replace(/(\n|^)\.\//g, '$1')
}
/**
* Returns the contents of a file if it exists.
*
* @return {String} results or `''`
*/
const maybeRead = async function(path, default_ = '') {
try {
return await readFile(path, 'utf8')
} catch (err) {
return default_
}
}
/**
* Transform relative paths into absolutes,
* and maintains absolutes as such.
*
* @param {String} maybe relative path
* @param {String} parent full path
*/
const asAbsolute = function(path, parent) {
if (path[0] === '/') {
return path
}
return resolve(parent, path)
}
/**
* Returns a list of files in the given
* directory that are subject to be
* synchronized for static deployments.
*
* @param {String} full path to directory
* @param {Object} options:
* - `limit` {Number|null} byte limit
* - `debug` {Boolean} warn upon ignore
* @return {Array} comprehensive list of paths to sync
*/
async function staticFiles(
path,
nowConfig = {},
{ limit = null, hasNowJson = false, debug = false } = {}
) {
const whitelist = nowConfig.files
// The package.json `files` whitelist still
// honors ignores: https://docs.npmjs.com/files/package.json#files
const search_ = whitelist || ['.']
// Convert all filenames into absolute paths
const search = Array.prototype.concat.apply(
[],
await Promise.all(
search_.map(file => glob(file, { cwd: path, absolute: true, dot: true }))
)
)
// Compile list of ignored patterns and files
const gitIgnore = await maybeRead(resolve(path, '.gitignore'))
const filter = ignore()
.add(IGNORED + '\n' + clearRelative(gitIgnore))
.createFilter()
const prefixLength = path.length + 1
// The package.json `files` whitelist still
// honors npmignores: https://docs.npmjs.com/files/package.json#files
// but we don't ignore if the user is explicitly listing files
// under the now namespace, or using files in combination with gitignore
const accepts = file => {
const relativePath = file.substr(prefixLength)
if (relativePath === '') {
return true
}
const accepted = filter(relativePath)
if (!accepted && debug) {
console.log('> [debug] ignoring "%s"', file)
}
return accepted
}
// Locate files
if (debug) {
console.time(`> [debug] locating files ${path}`)
}
const files = await explode(search, {
accepts,
limit,
debug
})
if (debug) {
console.timeEnd(`> [debug] locating files ${path}`)
}
if (hasNowJson) {
files.push(asAbsolute('now.json', path))
}
// Get files
return unique(files)
}
/**
* Returns a list of files in the given
* directory that are subject to be
* synchronized for npm.
*
* @param {String} full path to directory
* @param {String} contents of `package.json` to avoid lookup
* @param {Object} options:
* - `limit` {Number|null} byte limit
* - `debug` {Boolean} warn upon ignore
* @return {Array} comprehensive list of paths to sync
*/
async function npm(
path,
pkg = {},
nowConfig = {},
{ limit = null, hasNowJson = false, debug = false } = {}
) {
const whitelist = nowConfig.files || pkg.files
// The package.json `files` whitelist still
// honors ignores: https://docs.npmjs.com/files/package.json#files
const search_ = whitelist || ['.']
// Convert all filenames into absolute paths
const search = Array.prototype.concat.apply(
[],
await Promise.all(
search_.map(file => glob(file, { cwd: path, absolute: true, dot: true }))
)
)
// Compile list of ignored patterns and files
const npmIgnore = await maybeRead(resolve(path, '.npmignore'), null)
const gitIgnore = npmIgnore === null
? await maybeRead(resolve(path, '.gitignore'))
: null
const filter = ignore()
.add(
IGNORED + '\n' + clearRelative(npmIgnore === null ? gitIgnore : npmIgnore)
)
.createFilter()
const prefixLength = path.length + 1
// The package.json `files` whitelist still
// honors npmignores: https://docs.npmjs.com/files/package.json#files
// but we don't ignore if the user is explicitly listing files
// under the now namespace, or using files in combination with gitignore
const overrideIgnores =
(pkg.now && pkg.now.files) || (gitIgnore !== null && pkg.files)
const accepts = overrideIgnores
? () => true
: file => {
const relativePath = file.substr(prefixLength)
if (relativePath === '') {
return true
}
const accepted = filter(relativePath)
if (!accepted && debug) {
console.log('> [debug] ignoring "%s"', file)
}
return accepted
}
// Locate files
if (debug) {
console.time(`> [debug] locating files ${path}`)
}
const files = await explode(search, {
accepts,
limit,
debug
})
if (debug) {
console.timeEnd(`> [debug] locating files ${path}`)
}
// Always include manifest as npm does not allow ignoring it
// source: https://docs.npmjs.com/files/package.json#files
files.push(asAbsolute('package.json', path))
if (hasNowJson) {
files.push(asAbsolute('now.json', path))
}
// Get files
return unique(files)
}
/**
* Returns a list of files in the given
* directory that are subject to be
* sent to docker as build context.
*
* @param {String} full path to directory
* @param {String} contents of `Dockerfile`
* @param {Object} options:
* - `limit` {Number|null} byte limit
* - `debug` {Boolean} warn upon ignore
* @return {Array} comprehensive list of paths to sync
*/
async function docker(
path,
nowConfig = {},
{ limit = null, hasNowJson = false, debug = false } = {}
) {
const whitelist = nowConfig.files
// Base search path
// the now.json `files` whitelist still
// honors ignores: https://docs.npmjs.com/files/package.json#files
const search_ = whitelist || ['.']
// Convert all filenames into absolute paths
const search = search_.map(file => asAbsolute(file, path))
// Compile list of ignored patterns and files
const dockerIgnore = await maybeRead(resolve(path, '.dockerignore'), null)
const filter = ignore()
.add(
IGNORED +
'\n' +
clearRelative(
dockerIgnore === null
? await maybeRead(resolve(path, '.gitignore'))
: dockerIgnore
)
)
.createFilter()
const prefixLength = path.length + 1
const accepts = function(file) {
const relativePath = file.substr(prefixLength)
if (relativePath === '') {
return true
}
const accepted = filter(relativePath)
if (!accepted && debug) {
console.log('> [debug] ignoring "%s"', file)
}
return accepted
}
// Locate files
if (debug) {
console.time(`> [debug] locating files ${path}`)
}
const files = await explode(search, { accepts, limit, debug })
if (debug) {
console.timeEnd(`> [debug] locating files ${path}`)
}
// Always include manifest as npm does not allow ignoring it
// source: https://docs.npmjs.com/files/package.json#files
files.push(asAbsolute('Dockerfile', path))
if (hasNowJson) {
files.push(asAbsolute('now.json', path))
}
// Get files
return unique(files)
}
/**
* Explodes directories into a full list of files.
* Eg:
* in: ['/a.js', '/b']
* out: ['/a.js', '/b/c.js', '/b/d.js']
*
* @param {Array} of {String}s representing paths
* @param {Array} of ignored {String}s.
* @param {Object} options:
* - `limit` {Number|null} byte limit
* - `debug` {Boolean} warn upon ignore
* @return {Array} of {String}s of full paths
*/
async function explode(paths, { accepts, debug }) {
const list = async file => {
let path = file
let s
if (!accepts(file)) {
return null
}
try {
s = await stat(path)
} catch (e) {
// In case the file comes from `files`
// and it wasn't specified with `.js` by the user
path = file + '.js'
try {
s = await stat(path)
} catch (e2) {
if (debug) {
console.log('> [debug] ignoring invalid file "%s"', file)
}
return null
}
}
if (s.isDirectory()) {
const all = await readdir(file)
/* eslint-disable no-use-before-define */
return many(all.map(subdir => asAbsolute(subdir, file)))
/* eslint-enable no-use-before-define */
} else if (!s.isFile()) {
if (debug) {
console.log('> [debug] ignoring special file "%s"', file)
}
return null
}
return path
}
const many = all => Promise.all(all.map(file => list(file)))
return flatten(await many(paths)).filter(v => v !== null)
}
module.exports = {
npm,
docker,
staticFiles
}

View File

@@ -1,214 +0,0 @@
// Native
const path = require('path')
const url = require('url')
const childProcess = require('child_process')
// Packages
const fs = require('fs-extra')
const download = require('download')
const tmp = require('tmp-promise')
const isURL = require('is-url')
const cloneRepo = (parts, tmpDir) =>
new Promise((resolve, reject) => {
let host
switch (parts.type) {
case 'GitLab':
host = `gitlab.com`
break
case 'Bitbucket':
host = `bitbucket.org`
break
default:
host = `github.com`
}
const url = `https://${host}/${parts.main}`
const ref = parts.ref || (parts.type === 'Bitbucket' ? 'default' : 'master')
const cmd = `git clone ${url} --single-branch ${ref}`
childProcess.exec(cmd, { cwd: tmpDir.path }, (err, stdout) => {
if (err) {
reject(err)
}
resolve(stdout)
})
})
const renameRepoDir = async (pathParts, tmpDir) => {
const tmpContents = await fs.readdir(tmpDir.path)
const oldTemp = path.join(tmpDir.path, tmpContents[0])
const newTemp = path.join(tmpDir.path, pathParts.main.replace('/', '-'))
await fs.rename(oldTemp, newTemp)
tmpDir.path = newTemp
return tmpDir
}
const capitalizePlatform = name => {
const names = {
github: 'GitHub',
gitlab: 'GitLab',
bitbucket: 'Bitbucket'
}
return names[name]
}
const splittedURL = fullURL => {
const parsedURL = url.parse(fullURL)
const pathParts = parsedURL.path.split('/')
pathParts.shift()
// Set path to repo...
const main = pathParts[0] + '/' + pathParts[1]
// ...and then remove it from the parts
pathParts.splice(0, 2)
// Assign Git reference
let ref = pathParts.length >= 2 ? pathParts[1] : ''
// Firstly be sure that we haven know the ref type
if (pathParts[0]) {
// Then shorten the SHA of the commit
if (pathParts[0] === 'commit' || pathParts[0] === 'commits') {
ref = ref.substring(0, 7)
}
}
// We're deploying master by default,
// so there's no need to indicate it explicitly
if (ref === 'master') {
ref = ''
}
return {
main,
ref,
type: capitalizePlatform(parsedURL.host.split('.')[0])
}
}
const gitPathParts = main => {
let ref = ''
if (isURL(main)) {
return splittedURL(main)
}
if (main.split('/')[1].includes('#')) {
const parts = main.split('#')
ref = parts[1]
main = parts[0]
}
return {
main,
ref,
type: capitalizePlatform('github')
}
}
const downloadRepo = async repoPath => {
const pathParts = gitPathParts(repoPath)
const tmpDir = await tmp.dir({
// We'll remove it manually once deployment is done
keep: true,
// Recursively remove directory when calling respective method
unsafeCleanup: true
})
let gitInstalled = true
try {
await cloneRepo(pathParts, tmpDir)
} catch (err) {
gitInstalled = false
}
if (gitInstalled) {
const renaming = await renameRepoDir(pathParts, tmpDir)
return renaming
}
let url
switch (pathParts.type) {
case 'GitLab': {
const ref = pathParts.ref ? `?ref=${pathParts.ref}` : ''
url = `https://gitlab.com/${pathParts.main}/repository/archive.tar` + ref
break
}
case 'Bitbucket':
url = `https://bitbucket.org/${pathParts.main}/get/${pathParts.ref ||
'default'}.zip`
break
default:
url = `https://api.github.com/repos/${pathParts.main}/tarball/${pathParts.ref}`
}
try {
await download(url, tmpDir.path, {
extract: true
})
} catch (err) {
tmpDir.cleanup()
return false
}
const renaming = await renameRepoDir(pathParts, tmpDir)
return renaming
}
const isRepoPath = path => {
if (!path) {
return false
}
const allowedHosts = ['github.com', 'gitlab.com', 'bitbucket.org']
if (isURL(path)) {
const urlParts = url.parse(path)
const slashSplitted = urlParts.path.split('/').filter(n => n)
const notBare = slashSplitted.length >= 2
if (allowedHosts.includes(urlParts.host) && notBare) {
return true
}
const err = new Error(`Host "${urlParts.host}" is unsupported.`)
err.code = 'INVALID_URL'
err.userError = true
throw err
}
return /[^\s\\]\/[^\s\\]/g.test(path)
}
const fromGit = async (path, debug) => {
let tmpDir = false
try {
tmpDir = await downloadRepo(path)
} catch (err) {
if (debug) {
console.log(`Could not download "${path}" repo from GitHub`)
}
}
return tmpDir
}
module.exports = {
gitPathParts,
isRepoPath,
fromGit
}

View File

@@ -1,5 +0,0 @@
function indent(text, n) {
return text.split('\n').map(l => ' '.repeat(n) + l).join('\n')
}
module.exports = indent

File diff suppressed because it is too large Load Diff

View File

@@ -1,32 +0,0 @@
/**
* List of `zeit.world` nameservers
*/
const nameservers = new Set([
'california.zeit.world',
'london.zeit.world',
'newark.zeit.world',
'sydney.zeit.world',
'iowa.zeit.world',
'dallas.zeit.world',
'amsterdam.zeit.world',
'paris.zeit.world',
'frankfurt.zeit.world',
'singapore.zeit.world'
])
/**
* Given an array of nameservers (ie: as returned
* by `resolveNs` from Node, assert that they're
* zeit.world's.
*/
function isZeitWorld(ns) {
return (
ns.length > 1 &&
ns.every(host => {
return nameservers.has(host)
})
)
}
module.exports = isZeitWorld

View File

@@ -1,141 +0,0 @@
// Native
const os = require('os')
// Packages
const { stringify: stringifyQuery } = require('querystring')
const chalk = require('chalk')
const fetch = require('node-fetch')
const { validate } = require('email-validator')
const readEmail = require('email-prompt')
const ora = require('ora')
// Ours
const pkg = require('./pkg')
const ua = require('./ua')
const cfg = require('./cfg')
async function getVerificationData(url, email) {
const tokenName = `Now CLI ${os.platform()}-${os.arch()} ${pkg.version} (${os.hostname()})`
const data = JSON.stringify({ email, tokenName })
const res = await fetch(`${url}/now/registration`, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(data),
'User-Agent': ua
},
body: data
})
const body = await res.json()
if (res.status !== 200) {
throw new Error(
`Verification error: ${res.status} ${JSON.stringify(body)}`
)
}
return body
}
async function verify(url, email, verificationToken) {
const query = {
email,
token: verificationToken
}
const res = await fetch(
`${url}/now/registration/verify?${stringifyQuery(query)}`,
{
headers: { 'User-Agent': ua }
}
)
const body = await res.json()
return body.token
}
function sleep(ms) {
return new Promise(resolve => {
setTimeout(resolve, ms)
})
}
async function register(url, { retryEmail = false } = {}) {
let email
try {
email = await readEmail({ invalid: retryEmail })
} catch (err) {
process.stdout.write('\n')
throw err
}
process.stdout.write('\n')
if (!validate(email)) {
return register(url, { retryEmail: true })
}
const { token, securityCode } = await getVerificationData(url, email)
console.log(
`> Please follow the link sent to ${chalk.bold(email)} to log in.`
)
if (securityCode) {
console.log(
`> Verify that the provided security code in the email matches ${chalk.cyan(
chalk.bold(securityCode)
)}.`
)
}
process.stdout.write('\n')
const spinner = ora({
text: 'Waiting for confirmation...'
}).start()
let final
/* eslint-disable no-await-in-loop */
do {
await sleep(2500)
try {
final = await verify(url, email, token)
} catch (err) {}
} while (!final)
/* eslint-enable no-await-in-loop */
let user
try {
user = (await (await fetch(`${url}/www/user`, {
headers: {
Authorization: `Bearer ${final}`
}
})).json()).user
} catch (err) {
spinner.stop()
throw new Error(`Couldn't retrieve user details ${err.message}`)
}
spinner.text = 'Confirmed email address!'
spinner.stopAndPersist('✔')
process.stdout.write('\n')
return {
token: final,
user: {
uid: user.uid,
username: user.username,
email: user.email
},
lastUpdate: Date.now()
}
}
module.exports = async function(url) {
const loginData = await register(url)
await cfg.merge(loginData)
await cfg.remove('currentTeam') // Make sure to logout the team too
await cfg.remove('email') // Remove old schema from previus versions
return loginData.token
}

View File

@@ -1,14 +0,0 @@
exports.compare = function(a, b) {
return (
a.serial.localeCompare(b.serial) ||
// For the case serials are a same value on old logs
a.created.getTime() - b.created.getTime()
)
}
exports.deserialize = function(log) {
return Object.assign({}, log, {
date: new Date(log.date),
created: new Date(log.created)
})
}

View File

@@ -1,13 +0,0 @@
/* eslint-disable import/no-unresolved */
const path = require('path')
const pkg = require('../package.json')
try {
const distDir = path.dirname(process.execPath)
pkg._npmPkg = require(path.join(distDir, '../../package.json'))
} catch (err) {
pkg._npmPkg = null
}
module.exports = pkg

View File

@@ -1,57 +0,0 @@
const ms = require('ms')
const Now = require('../lib')
async function parsePlan(json) {
const { subscription } = json
let id
let until
let name
if (subscription) {
const planItems = subscription.items.data
const mainPlan = planItems.find(d => d.plan.metadata.is_main_plan === '1')
if (mainPlan) {
id = mainPlan.plan.id
name = mainPlan.plan.name
if (subscription.cancel_at_period_end) {
until = ms(
new Date(subscription.current_period_end * 1000) - new Date(),
{ long: true }
)
}
} else {
id = 'oss'
}
} else {
id = 'oss'
}
return { id, name, until }
}
module.exports = class Plans extends Now {
async getCurrent() {
const res = await this._fetch('/plan')
const json = await res.json()
return parsePlan(json)
}
async set(plan) {
const res = await this._fetch('/plan', {
method: 'PUT',
body: { plan }
})
const json = await res.json()
if (res.ok) {
return parsePlan(json)
}
const err = new Error(json.error.message)
err.code = json.error.code
throw err
}
}

View File

@@ -1,134 +0,0 @@
// Native
const { join } = require('path')
// Packages
const fs = require('fs-extra')
const chalk = require('chalk')
// Ours
const { error } = require('./error')
const readMetaData = require('./read-metadata')
const NowAlias = require('./alias')
const NowDomains = require('./domains')
exports.assignAlias = async (
autoAlias,
token,
deployment,
apiUrl,
debug,
currentTeam,
user
) => {
const aliases = new NowAlias({ apiUrl, token, debug, currentTeam })
const domains = new NowDomains({ apiUrl, token, debug, currentTeam })
console.log(
`> Assigning alias ${chalk.bold.underline(autoAlias)} to deployment...`
)
// Assign alias
await aliases.set(
String(deployment),
String(autoAlias),
domains,
currentTeam,
user
)
}
exports.reAlias = async (
token,
host,
pointer,
help,
exit,
apiUrl,
debug,
alias,
currentTeam,
user
) => {
const path = process.cwd()
const configFiles = {
pkg: join(path, 'package.json'),
nowJSON: join(path, 'now.json')
}
if (!fs.existsSync(configFiles.pkg) && !fs.existsSync(configFiles.nowJSON)) {
error(
`Couldn't find a now.json or package.json file with an alias list in it`
)
return
}
const { nowConfig, name } = await readMetaData(path, {
deploymentType: 'npm', // Hard coding settings…
quiet: true // `quiet`
})
if (!host) {
const lastAlias = await alias.last(name)
host = lastAlias.url
}
if (!nowConfig) {
help()
return exit(0)
}
let pointers = []
if (pointer) {
pointers.push(pointer)
} else {
if (nowConfig.alias) {
const value = nowConfig.alias
if (typeof value === 'string') {
pointers.push(value)
} else if (Array.isArray(value)) {
pointers = pointers.concat(nowConfig.alias)
} else {
error(
`Property ${chalk.grey('aliases')} is not a valid array or string`
)
return exit(1)
}
}
if (nowConfig.aliases && Array.isArray(nowConfig.aliases)) {
console.log(
`${chalk.red('Deprecated!')} The property ${chalk.grey(
'aliases'
)} will be removed from the config file soon.`
)
console.log('Read more about the new way here: http://bit.ly/2l2v5Fg\n')
pointers = pointers.concat(nowConfig.aliases)
}
}
if (pointers.length === 0) {
help()
return exit(0)
}
const assignments = []
for (const pointer of pointers) {
assignments.push(
exports.assignAlias(
pointer,
token,
host,
apiUrl,
debug,
currentTeam,
user
)
)
}
await Promise.all(assignments)
}

View File

@@ -1,195 +0,0 @@
// Native
const { basename, resolve: resolvePath } = require('path')
// Packages
const chalk = require('chalk')
const { readFile } = require('fs-extra')
const { parse: parseDockerfile } = require('docker-file-parser')
const determineType = require('deployment-type')
module.exports = readMetaData
async function readMetaData(
path,
{
deploymentType,
deploymentName,
sessionAffinity,
quiet = false,
strict = true
}
) {
let description
let type = deploymentType
let name = deploymentName
let affinity = sessionAffinity
const pkg = await readJSON(path, 'package.json')
let nowConfig = await readJSON(path, 'now.json')
const dockerfile = await readDockerfile(path)
const hasNowJson = Boolean(nowConfig)
if (pkg && pkg.now) {
// If the project has both a `now.json` and `now` Object in the `package.json`
// file, then fail hard and let the user know that they need to pick one or the
// other
if (nowConfig) {
const err = new Error(
'You have a `now` configuration field inside `package.json` ' +
'but configuration is also present in `now.json`! ' +
"Please ensure there's a single source of configuration by removing one."
)
err.userError = true
throw err
} else {
nowConfig = pkg.now
}
}
// We can remove this once the prompt for choosing `--npm` or `--docker` is gone
if (pkg && pkg.now && pkg.now.type) {
type = nowConfig.type
}
// The same goes for this
if (nowConfig && nowConfig.type) {
type = nowConfig.type
}
if (!type) {
type = await determineType(path)
// Both `package.json` and `Dockerfile` exist! Prompt the user to pick one.
// We can remove this soon (details are internal) - also read the comment paragraph above
if (type === 'docker' && (pkg && dockerfile)) {
const err = new Error(
'Ambiguous deployment (`package.json` and `Dockerfile` found). ' +
'Please supply `--npm` or `--docker` to disambiguate.'
)
err.userError = true
err.code = 'MULTIPLE_MANIFESTS'
throw err
}
}
if (!name && nowConfig) {
name = nowConfig.name
}
if (!affinity && nowConfig) {
affinity = nowConfig.sessionAffinity
}
if (type === 'npm') {
if (pkg) {
if (!name && pkg.now && pkg.now.name) {
name = String(pkg.now.name)
}
if (!name && pkg.name) {
name = String(pkg.name)
}
description = pkg.description
}
} else if (type === 'docker') {
if (strict && dockerfile.length <= 0) {
const err = new Error('No commands found in `Dockerfile`')
err.userError = true
throw err
}
const labels = {}
dockerfile.filter(cmd => cmd.name === 'LABEL').forEach(({ args }) => {
for (const key in args) {
if (!{}.hasOwnProperty.call(args, key)) {
continue
}
// Unescape and convert into string
try {
labels[key] = args[key]
} catch (err) {
const e = new Error(
`Error parsing value for LABEL ${key} in \`Dockerfile\``
)
e.userError = true
throw e
}
}
})
if (!name) {
name = labels.name
}
description = labels.description
} else if (type === 'static') {
// Do nothing
} else {
throw new TypeError(`Unsupported "deploymentType": ${type}`)
}
// No name in `package.json` / `now.json`, or "name" label in Dockerfile.
// Default to the basename of the root dir
if (!name) {
name = basename(path)
if (!quiet && type !== 'static') {
if (type === 'docker') {
console.log(
`> No \`name\` LABEL in \`Dockerfile\`, using ${chalk.bold(name)}`
)
} else {
console.log(
`> No \`name\` in \`package.json\`, using ${chalk.bold(name)}`
)
}
}
}
return {
name,
description,
type,
pkg,
nowConfig,
hasNowJson,
// XXX: legacy
deploymentType: type,
sessionAffinity: affinity
}
}
async function readJSON(path, name) {
try {
const contents = await readFile(resolvePath(path, name), 'utf8')
return JSON.parse(contents)
} catch (err) {
// If the file doesn't exist then that's fine; any other error bubbles up
if (err.code !== 'ENOENT') {
err.userError = true
throw err
}
}
}
async function readDockerfile(path, name = 'Dockerfile') {
try {
const contents = await readFile(resolvePath(path, name), 'utf8')
return parseDockerfile(contents, { includeComments: true })
} catch (err) {
// If the file doesn't exist then that's fine; any other error bubbles up
if (err.code !== 'ENOENT') {
err.userError = true
throw err
}
}
}

Some files were not shown because too many files have changed in this diff Show More