From 9cb978a2c6a2f2273706e1ffa934c1b17acf53b6 Mon Sep 17 00:00:00 2001 From: Nicolas Bonnel Date: Fri, 10 Mar 2017 18:36:09 +0100 Subject: [PATCH] feat: can now specify request body --- OpenApi.vue | 60 +++++++++++++++++++++++++++++++++++++---------------- 1 file changed, 42 insertions(+), 18 deletions(-) diff --git a/OpenApi.vue b/OpenApi.vue index 39cc36e..6676a4e 100644 --- a/OpenApi.vue +++ b/OpenApi.vue @@ -59,7 +59,7 @@ - open_in_new + open_in_new body @@ -111,7 +111,7 @@ - open_in_new + open_in_new @@ -140,32 +140,36 @@

Request

+ + + + +
- + - + {{val}} - + {{val}} - - + + - {{parameter.name}}{{parameter.description}} + {{parameter.name}}{{parameter.description}}
@@ -210,6 +214,9 @@ function processContent(contentType, api) { contentType.examples.push(contentType.example) } if (contentType.examples) { + if(!contentType.example && contentType.examples.length){ + contentType.example = contentType.examples[0] + } contentType.examples = contentType.examples.map(e => '
' + JSON.stringify(e, null, 2) + '
') } if (contentType.schema) { @@ -219,7 +226,7 @@ function processContent(contentType, api) { contentType.schema.items = get(api, contentType.schema.items.$ref.split('#/').pop().replace(/\//g, '.')) } if (typeof contentType.schema !== 'string') { - contentType.schema = '
' + JSON.stringify(contentType.schema, null, 2) + '
' + contentType.schemaHTML = '
' + JSON.stringify(contentType.schema, null, 2) + '
' } } } @@ -304,10 +311,15 @@ export default { }, methods: { resetRequest(entry) { - for (var p in this.currentRequest) delete this.currentRequest[p] - this.currentRequest = Object.assign({}, this.currentRequest, ...(entry.parameters || []).map(p => ({ + // for (var p in this.currentRequest) delete this.currentRequest[p] + + this.currentRequest.params = Object.assign({}, ...(entry.parameters || []).map(p => ({ [p.name]: p.schema.enum ? p.schema.enum[0] : (p.schema.type === 'array' ? [] : null) }))) + if(entry.requestBody){ + this.currentRequest.contentType = Object.keys(entry.requestBody.content)[0] + this.currentRequest.requestBody = entry.requestBody.content[this.currentRequest.contentType].example || '' + } }, select(entry) { this.resetRequest(entry) @@ -331,19 +343,31 @@ export default { }, request() { this.currentResponse = '' - let params = Object.assign({}, ...(this.selectedEntry.parameters || []).filter(p => p.in === 'query' && (p.schema.type === 'array' ? this.currentRequest[p.name].length : this.currentRequest[p.name])) + let params = Object.assign({}, ...(this.selectedEntry.parameters || []).filter(p => p.in === 'query' && (p.schema.type === 'array' ? this.currentRequest.params[p.name].length : this.currentRequest.params[p.name])) .map(p => ({ // TODO : join character for array should depend of p.style - [p.name]: p.schema.type === 'array' ? this.currentRequest[p.name].join(',') : this.currentRequest[p.name] + [p.name]: p.schema.type === 'array' ? this.currentRequest.params[p.name].join(',') : this.currentRequest.params[p.name] })) ) - this.$http({ + let headers = Object.assign({}, ...(this.selectedEntry.parameters || []).filter(p => p.in === 'header' && (p.schema.type === 'array' ? this.currentRequest.params[p.name].length : this.currentRequest.params[p.name])) + .map(p => ({ + // TODO : join character for array should depend of p.style + [p.name]: p.schema.type === 'array' ? this.currentRequest.params[p.name].join(',') : this.currentRequest.params[p.name] + })) + ) + let request = { method: this.selectedEntry.method, url: this.api.servers[0].url + this.selectedEntry.path.replace(/{(\w*)}/g, (m, key) => { - return this.currentRequest[key] + return this.currentRequest.params[key] }), - params - }).then(response => { + params, + headers + } + if(this.selectedEntry.requestBody){ + request.headers['Content-type'] = this.currentRequest.contentType + request.body = this.currentRequest.requestBody + } + this.$http(request).then(response => { this.currentResponse = JSON.stringify(response.body, null, 2) }, response => { this.currentResponse = JSON.stringify(response.body, null, 2)