Browse Source

Option `--session-affinity` was added for setting session affinity (#600)

master
Jarmo Isotalo 8 years ago
committed by Leo Lamprecht
parent
commit
493d9123fd
  1. 21
      bin/now-deploy.js
  2. 6
      lib/index.js
  3. 16
      lib/read-metadata.js

21
bin/now-deploy.js

@ -38,7 +38,7 @@ const promptOptions = require('../lib/utils/input/prompt-options')
const note = require('../lib/utils/output/note') const note = require('../lib/utils/output/note')
const argv = minimist(process.argv.slice(2), { const argv = minimist(process.argv.slice(2), {
string: ['config', 'token', 'name', 'alias'], string: ['config', 'token', 'name', 'alias', 'session-affinity'],
boolean: [ boolean: [
'help', 'help',
'version', 'version',
@ -67,6 +67,7 @@ const argv = minimist(process.argv.slice(2), {
public: 'p', public: 'p',
'no-clipboard': 'C', 'no-clipboard': 'C',
'forward-npm': 'N', 'forward-npm': 'N',
'session-affinity': 'S',
name: 'n', name: 'n',
alias: 'a' alias: 'a'
} }
@ -117,6 +118,7 @@ const help = () => {
-E ${chalk.underline('FILE')}, --dotenv=${chalk.underline('FILE')} Include env vars from .env file. Defaults to '.env' -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 -C, --no-clipboard Do not attempt to copy URL to clipboard
-N, --forward-npm Forward login information to install private npm modules -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):')} ${chalk.dim('Enforcable Types (when both package.json and Dockerfile exist):')}
@ -168,6 +170,7 @@ const gitRepo = {}
// Options // Options
let forceNew = argv.force let forceNew = argv.force
let deploymentName = argv.name let deploymentName = argv.name
let sessionAffinity = argv['session-affinity']
const debug = argv.debug const debug = argv.debug
const clipboard = !argv['no-clipboard'] const clipboard = !argv['no-clipboard']
const forwardNpm = argv['forward-npm'] const forwardNpm = argv['forward-npm']
@ -349,10 +352,11 @@ async function sync({ token, config: { currentTeam, user } }) {
} }
let meta let meta
;({ meta, deploymentName, deploymentType } = await readMeta( ;({ meta, deploymentName, deploymentType, sessionAffinity } = await readMeta(
path, path,
deploymentName, deploymentName,
deploymentType deploymentType,
sessionAffinity
)) ))
const nowConfig = meta.nowConfig const nowConfig = meta.nowConfig
@ -489,7 +493,8 @@ async function sync({ token, config: { currentTeam, user } }) {
forceSync, forceSync,
forwardNpm: alwaysForwardNpm || forwardNpm, forwardNpm: alwaysForwardNpm || forwardNpm,
quiet, quiet,
wantsPublic wantsPublic,
sessionAffinity
}, },
meta meta
) )
@ -633,12 +638,13 @@ async function sync({ token, config: { currentTeam, user } }) {
} }
} }
async function readMeta(path, deploymentName, deploymentType) { async function readMeta(path, deploymentName, deploymentType, sessionAffinity) {
try { try {
const meta = await readMetaData(path, { const meta = await readMetaData(path, {
deploymentType, deploymentType,
deploymentName, deploymentName,
quiet: true quiet: true,
sessionAffinity
}) })
if (!deploymentType) { if (!deploymentType) {
@ -664,7 +670,8 @@ async function readMeta(path, deploymentName, deploymentType) {
return { return {
meta, meta,
deploymentName, deploymentName,
deploymentType deploymentType,
sessionAffinity
} }
} catch (err) { } catch (err) {
if (isTTY && err.code === 'MULTIPLE_MANIFESTS') { if (isTTY && err.code === 'MULTIPLE_MANIFESTS') {

6
lib/index.js

@ -61,7 +61,8 @@ module.exports = class Now extends EventEmitter {
type = 'npm', type = 'npm',
pkg = {}, pkg = {},
nowConfig = {}, nowConfig = {},
hasNowJson = false hasNowJson = false,
sessionAffinity = 'ip'
} }
) { ) {
this._path = path this._path = path
@ -166,7 +167,8 @@ module.exports = class Now extends EventEmitter {
deploymentType: type, deploymentType: type,
registryAuthToken: authToken, registryAuthToken: authToken,
files, files,
engines engines,
sessionAffinity
} }
}) })

16
lib/read-metadata.js

@ -11,11 +11,18 @@ module.exports = readMetaData
async function readMetaData( async function readMetaData(
path, path,
{ deploymentType, deploymentName, quiet = false, strict = true } {
deploymentType,
deploymentName,
sessionAffinity,
quiet = false,
strict = true
}
) { ) {
let description let description
let type = deploymentType let type = deploymentType
let name = deploymentName let name = deploymentName
let affinity = sessionAffinity
const pkg = await readJSON(path, 'package.json') const pkg = await readJSON(path, 'package.json')
let nowConfig = await readJSON(path, 'now.json') let nowConfig = await readJSON(path, 'now.json')
@ -72,6 +79,10 @@ async function readMetaData(
name = nowConfig.name name = nowConfig.name
} }
if (!affinity && nowConfig) {
affinity = nowConfig.sessionAffinity
}
if (type === 'npm') { if (type === 'npm') {
if (pkg) { if (pkg) {
if (!name && pkg.now && pkg.now.name) { if (!name && pkg.now && pkg.now.name) {
@ -152,7 +163,8 @@ async function readMetaData(
hasNowJson, hasNowJson,
// XXX: legacy // XXX: legacy
deploymentType: type deploymentType: type,
sessionAffinity: affinity
} }
} }

Loading…
Cancel
Save