-
Notifications
You must be signed in to change notification settings - Fork 296
refactor: convert config API to async await #1155
Changes from 7 commits
1d9d263
359f13f
113ffec
56a7b2d
ea74f9d
cdc97ad
67994bd
f4d5128
d4377c6
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,39 +1,27 @@ | ||
'use strict' | ||
|
||
const promisify = require('promisify-es6') | ||
const configure = require('../lib/configure') | ||
|
||
const toObject = function (res, callback) { | ||
if (Buffer.isBuffer(res)) { | ||
callback(null, JSON.parse(res.toString())) | ||
} else { | ||
callback(null, res) | ||
} | ||
} | ||
|
||
module.exports = (send) => { | ||
return promisify((key, callback) => { | ||
if (typeof key === 'function') { | ||
callback = key | ||
key = undefined | ||
module.exports = configure(({ ky }) => { | ||
return async (key, options) => { | ||
if (key && typeof key === 'object') { | ||
options = key | ||
key = null | ||
} | ||
|
||
if (!key) { | ||
send.andTransform({ | ||
path: 'config/show', | ||
buffer: true | ||
}, toObject, callback) | ||
return | ||
} | ||
options = options || {} | ||
|
||
send.andTransform({ | ||
path: 'config', | ||
args: key, | ||
buffer: true | ||
}, toObject, (err, response) => { | ||
if (err) { | ||
return callback(err) | ||
} | ||
callback(null, response.Value) | ||
}) | ||
}) | ||
} | ||
const searchParams = new URLSearchParams(options.searchParams) | ||
if (key) searchParams.set('arg', key) | ||
|
||
const url = key ? 'config' : 'config/show' | ||
const data = await ky.get(url, { | ||
timeout: options.timeout, | ||
signal: options.signal, | ||
headers: options.headers, | ||
searchParams | ||
}).json() | ||
|
||
return key ? data.Value : data | ||
} | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,10 @@ | ||
'use strict' | ||
|
||
module.exports = (send, config) => { | ||
return { | ||
get: require('./get')(send), | ||
set: require('./set')(send), | ||
replace: require('./replace')(send), | ||
profiles: { | ||
apply: require('./profiles/apply')(config), | ||
list: require('./profiles/list')(config) | ||
} | ||
} | ||
} | ||
const callbackify = require('callbackify') | ||
|
||
module.exports = config => ({ | ||
get: callbackify.variadic(require('./get')(config)), | ||
set: callbackify.variadic(require('./set')(config)), | ||
replace: callbackify.variadic(require('./replace')(config)), | ||
profiles: require('./profiles')(config) | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,27 +1,24 @@ | ||
'use strict' | ||
|
||
const callbackify = require('callbackify') | ||
const configure = require('../../lib/configure') | ||
|
||
module.exports = configure(({ ky }) => { | ||
return callbackify.variadic(async (profile, options) => { | ||
return async (profile, options) => { | ||
options = options || {} | ||
|
||
const searchParams = new URLSearchParams(options.searchParams) | ||
searchParams.set('arg', profile) | ||
if (options.dryRun != null) searchParams.set('dry-run', options.dryRun) | ||
|
||
const res = await ky.post('config/profile/apply', { | ||
timeout: options.timeout, | ||
signal: options.signal, | ||
headers: options.headers, | ||
searchParams: { | ||
arg: profile, | ||
// can only pass strings or numbers as values https://github.com/sindresorhus/ky/issues/182 | ||
'dry-run': options.dryRun ? 'true' : 'false' | ||
} | ||
}) | ||
|
||
const parsed = await res.json() | ||
searchParams | ||
}).json() | ||
|
||
return { | ||
original: parsed.OldCfg, updated: parsed.NewCfg | ||
original: res.OldCfg, updated: res.NewCfg | ||
} | ||
}) | ||
} | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
'use strict' | ||
|
||
const callbackify = require('callbackify') | ||
|
||
module.exports = config => ({ | ||
apply: callbackify.variadic(require('./apply')(config)), | ||
list: callbackify.variadic(require('./list')(config)) | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,22 +1,19 @@ | ||
'use strict' | ||
|
||
const callbackify = require('callbackify') | ||
const configure = require('../../lib/configure') | ||
const toCamel = require('../../lib/object-to-camel') | ||
|
||
module.exports = configure(({ ky }) => { | ||
return callbackify.variadic(async (options) => { | ||
return async (options) => { | ||
options = options || {} | ||
|
||
const res = await ky.get('config/profile/list', { | ||
timeout: options.timeout, | ||
signal: options.signal, | ||
headers: options.headers | ||
}) | ||
headers: options.headers, | ||
searchParams: options.searchParams | ||
}).json() | ||
|
||
const parsed = await res.json() | ||
|
||
return parsed | ||
.map(profile => toCamel(profile)) | ||
}) | ||
return res.map(profile => toCamel(profile)) | ||
} | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,25 +1,21 @@ | ||
'use strict' | ||
|
||
const { Readable } = require('readable-stream') | ||
const promisify = require('promisify-es6') | ||
const SendOneFile = require('../utils/send-one-file') | ||
const { Buffer } = require('buffer') | ||
const configure = require('../lib/configure') | ||
const toFormData = require('../lib/buffer-to-form-data') | ||
|
||
function toStream (input) { | ||
return new Readable({ | ||
read () { | ||
this.push(input) | ||
this.push(null) | ||
} | ||
}) | ||
} | ||
module.exports = configure(({ ky }) => { | ||
return async (config, options) => { | ||
options = options || {} | ||
|
||
module.exports = (send) => { | ||
const sendOneFile = SendOneFile(send, 'config/replace') | ||
return promisify((config, callback) => { | ||
if (typeof config === 'object') { | ||
config = toStream(Buffer.from(JSON.stringify(config))) | ||
} | ||
const res = await ky.post('config/replace', { | ||
timeout: options.timeout, | ||
signal: options.signal, | ||
headers: options.headers, | ||
searchParams: options.searchParams, | ||
body: toFormData(Buffer.from(JSON.stringify(config))) | ||
}).text() | ||
|
||
sendOneFile(config, {}, callback) | ||
}) | ||
} | ||
return res | ||
} | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,35 +1,36 @@ | ||
'use strict' | ||
|
||
const promisify = require('promisify-es6') | ||
const configure = require('../lib/configure') | ||
const toCamel = require('../lib/object-to-camel') | ||
|
||
module.exports = configure(({ ky }) => { | ||
return async (key, value, options) => { | ||
options = options || {} | ||
|
||
module.exports = (send) => { | ||
return promisify((key, value, opts, callback) => { | ||
if (typeof opts === 'function') { | ||
callback = opts | ||
opts = {} | ||
} | ||
if (typeof key !== 'string') { | ||
return callback(new Error('Invalid key type')) | ||
throw new Error('invalid key') | ||
} | ||
|
||
if (value === undefined || Buffer.isBuffer(value)) { | ||
return callback(new Error('Invalid value type')) | ||
} | ||
const searchParams = new URLSearchParams(options.searchParams) | ||
|
||
if (typeof value === 'boolean') { | ||
searchParams.set('bool', true) | ||
value = value.toString() | ||
opts = { bool: true } | ||
} else if (typeof value !== 'string') { | ||
searchParams.set('json', true) | ||
value = JSON.stringify(value) | ||
opts = { json: true } | ||
} | ||
|
||
send({ | ||
path: 'config', | ||
args: [key, value], | ||
qs: opts, | ||
files: undefined, | ||
buffer: true | ||
}, callback) | ||
}) | ||
} | ||
searchParams.set('arg', key) | ||
searchParams.append('arg', value) | ||
|
||
const res = await ky.post('config', { | ||
timeout: options.timeout, | ||
signal: options.signal, | ||
headers: options.headers, | ||
searchParams | ||
}).json() | ||
|
||
return toCamel(res) | ||
} | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -21,8 +21,9 @@ describe('lib/error-handler', () => { | |
|
||
const err = await throwsAsync(errorHandler(null, null, res)) | ||
|
||
expect(err instanceof HTTPError).to.be.true() | ||
expect(err.message).to.eql('boom') | ||
expect(err.status).to.eql(500) | ||
expect(err.response.status).to.eql(500) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Breaking change? I guess errors aren't really part of the spec other than 'you will get an error'. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes, it is breaking. I've updated the PR description with the info and will include it when merging. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Great. One small thing - the description says There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Well this test was looking for |
||
}) | ||
|
||
it('should gracefully fail on parse json', async () => { | ||
|
Uh oh!
There was an error while loading. Please reload this page.