forked from extern/bruno
Merge pull request #754 from survivant/feature/add-yaml-support-insomnia
[feature] Can import Insomnia Yaml file
This commit is contained in:
commit
d90cb91a19
@ -1,3 +1,4 @@
|
|||||||
|
import jsyaml from 'js-yaml';
|
||||||
import each from 'lodash/each';
|
import each from 'lodash/each';
|
||||||
import get from 'lodash/get';
|
import get from 'lodash/get';
|
||||||
import fileDialog from 'file-dialog';
|
import fileDialog from 'file-dialog';
|
||||||
@ -8,7 +9,22 @@ import { validateSchema, transformItemsInCollection, hydrateSeqInCollection } fr
|
|||||||
const readFile = (files) => {
|
const readFile = (files) => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
const fileReader = new FileReader();
|
const fileReader = new FileReader();
|
||||||
fileReader.onload = (e) => resolve(e.target.result);
|
fileReader.onload = (e) => {
|
||||||
|
try {
|
||||||
|
// try to load JSON
|
||||||
|
const parsedData = JSON.parse(e.target.result);
|
||||||
|
resolve(parsedData);
|
||||||
|
} catch (jsonError) {
|
||||||
|
// not a valid JSOn, try yaml
|
||||||
|
try {
|
||||||
|
const parsedData = jsyaml.load(e.target.result);
|
||||||
|
resolve(parsedData);
|
||||||
|
} catch (yamlError) {
|
||||||
|
console.error('Error parsing the file :', jsonError, yamlError);
|
||||||
|
reject(new BrunoError('Import collection failed'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
fileReader.onerror = (err) => reject(err);
|
fileReader.onerror = (err) => reject(err);
|
||||||
fileReader.readAsText(files[0]);
|
fileReader.readAsText(files[0]);
|
||||||
});
|
});
|
||||||
@ -167,7 +183,7 @@ const parseInsomniaCollection = (data) => {
|
|||||||
|
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
try {
|
try {
|
||||||
const insomniaExport = JSON.parse(data);
|
const insomniaExport = data;
|
||||||
const insomniaResources = get(insomniaExport, 'resources', []);
|
const insomniaResources = get(insomniaExport, 'resources', []);
|
||||||
const insomniaCollection = insomniaResources.find((resource) => resource._type === 'workspace');
|
const insomniaCollection = insomniaResources.find((resource) => resource._type === 'workspace');
|
||||||
|
|
||||||
@ -213,7 +229,7 @@ const parseInsomniaCollection = (data) => {
|
|||||||
|
|
||||||
const importCollection = () => {
|
const importCollection = () => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
fileDialog({ accept: 'application/json' })
|
fileDialog({ accept: '.json, .yaml, .yml, application/json, application/yaml, application/x-yaml' })
|
||||||
.then(readFile)
|
.then(readFile)
|
||||||
.then(parseInsomniaCollection)
|
.then(parseInsomniaCollection)
|
||||||
.then(transformItemsInCollection)
|
.then(transformItemsInCollection)
|
||||||
@ -221,8 +237,8 @@ const importCollection = () => {
|
|||||||
.then(validateSchema)
|
.then(validateSchema)
|
||||||
.then((collection) => resolve(collection))
|
.then((collection) => resolve(collection))
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
console.log(err);
|
console.error(err);
|
||||||
reject(new BrunoError('Import collection failed'));
|
reject(new BrunoError('Import collection failed: ' + err.message));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user