mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
231 lines
5.8 KiB
231 lines
5.8 KiB
4 years ago
|
import axios from 'axios';
|
||
|
import SqlQueryParser from '../helpers/SqlQueryParser'
|
||
|
|
||
|
export const state = () => ({
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
* type : SELECT, INSERT, UPDATE, CREATE, DELETE, DROP
|
||
|
*
|
||
|
* query :
|
||
|
*
|
||
|
*
|
||
|
* response :
|
||
|
* status : 0 / -1
|
||
|
*
|
||
|
*/
|
||
|
list: [{
|
||
|
type: 'SELECT',
|
||
|
query: 'SELECT 1',
|
||
|
response: {status: 0}
|
||
|
}],
|
||
|
clipboardQuery: null,
|
||
|
// editors: ['', '', '']
|
||
|
editors: [
|
||
|
{
|
||
|
type: 'temp',
|
||
|
code: '',
|
||
|
fileName: null,
|
||
|
filePath: null,
|
||
|
edited: false
|
||
|
}, {
|
||
|
type: 'temp',
|
||
|
code: '',
|
||
|
fileName: null,
|
||
|
filePath: null,
|
||
|
edited: false
|
||
|
}, {
|
||
|
type: 'temp',
|
||
|
code: '',
|
||
|
fileName: null,
|
||
|
filePath: null,
|
||
|
edited: false
|
||
|
},
|
||
|
],
|
||
|
|
||
|
sqlFilePaths: [],
|
||
|
|
||
|
projectSqlFilePaths: {},
|
||
|
currentProjectKey: ''
|
||
|
|
||
|
});
|
||
|
|
||
|
export const mutations = {
|
||
|
|
||
|
MutSqlFilePathsAdd(state, args) {
|
||
|
state.projectSqlFilePaths = {
|
||
|
...state.projectSqlFilePaths,
|
||
|
[state.currentProjectKey]: [...state.projectSqlFilePaths[state.currentProjectKey], args]
|
||
|
}
|
||
|
},
|
||
|
|
||
|
MutSqlFilePathsRemove(state, index) {
|
||
|
state.projectSqlFilePaths[state.currentProjectKey].splice(index, 1);
|
||
|
state.projectSqlFilePaths[state.currentProjectKey] = [...state.projectSqlFilePaths[state.currentProjectKey]];
|
||
|
},
|
||
|
|
||
|
MutList(state, list) {
|
||
|
state.projectSqlFilePaths[state.currentProjectKey] = list;
|
||
|
},
|
||
|
MutCurrentProjectKey(state, currentProjectKey) {
|
||
|
state.currentProjectKey = currentProjectKey;
|
||
|
},
|
||
|
MutListAdd(state, args) {
|
||
|
state.list.unshift(args);
|
||
|
if (state.list.length > 500) state.list.pop();
|
||
|
},
|
||
|
|
||
|
MutListRemove(state, index) {
|
||
|
// find index and set status
|
||
|
state.list.splice(index, 1);
|
||
|
state.list = [...state.list]
|
||
|
},
|
||
|
MutListRemoveItem(state, item) {
|
||
|
state.list = state.list.filter(query => item.query !== query.query)
|
||
|
},
|
||
|
MutSetClipboardQuery(state, clipboardQuery) {
|
||
|
state.clipboardQuery = clipboardQuery;
|
||
|
},
|
||
|
MutSetEditorByIndex(state, {editor, index}) {
|
||
|
state.editors[index] = editor;
|
||
|
state.editors = [...state.editors];
|
||
|
},
|
||
|
MutSetEditors(state, editors) {
|
||
|
state.editors = editors.map(editor => ({...editor}));
|
||
|
}
|
||
|
|
||
|
};
|
||
|
|
||
|
export const getters = {
|
||
|
GtrCurrentSqlFilePaths(state) {
|
||
|
return state.projectSqlFilePaths[state.currentProjectKey];
|
||
|
}
|
||
|
};
|
||
|
|
||
|
export const actions = {
|
||
|
|
||
|
async executeQuery({commit, state, rootState}, {envs, query}) {
|
||
|
|
||
|
|
||
|
const sqlMgr = rootState.sqlMgr.sqlMgr;
|
||
|
let result;
|
||
|
// const type = SqlQueryParser.getType(query);
|
||
|
// const typeColor = SqlQueryParser.getColorForQueryType(type)
|
||
|
|
||
|
|
||
|
// let t = process.hrtime();
|
||
|
try {
|
||
|
// const client = await sqlMgr.projectGetSqlClient(envs);
|
||
|
|
||
|
|
||
|
// result = await sqlMgr.sqlOp(envs, 'executeRawQuery', query);
|
||
|
result = await this.dispatch('sqlMgr/ActSqlOp', [envs, 'executeRawQuery', query]);
|
||
|
|
||
|
// var t1 = process.hrtime(t);
|
||
|
// var t2 = (t1[0] + t1[1] / 1000000000).toFixed(2);
|
||
|
|
||
|
// commit('MutListAdd', {
|
||
|
// id: Date.now(),
|
||
|
// name: '',
|
||
|
// query: query,
|
||
|
// type,
|
||
|
// typeColor,
|
||
|
// response: {status: 0},
|
||
|
// createdAt: Date.now(),
|
||
|
// timeTaken: t2,
|
||
|
// })
|
||
|
|
||
|
} catch (e) {
|
||
|
// var t1 = process.hrtime(t);
|
||
|
// var t2 = (t1[0] + t1[1] / 1000000000).toFixed(2);
|
||
|
//
|
||
|
// commit('MutListAdd', {
|
||
|
// id: Date.now(),
|
||
|
// name: '',
|
||
|
// query: query,
|
||
|
// type,
|
||
|
// typeColor,
|
||
|
// response: {status: -1},
|
||
|
// createdAt: Date.now(),
|
||
|
// timeTaken: t2,
|
||
|
//
|
||
|
// });
|
||
|
throw e;
|
||
|
}
|
||
|
return result;
|
||
|
|
||
|
//
|
||
|
//
|
||
|
// let a = {...action};
|
||
|
// try {
|
||
|
// commit('notification/MutToggleProgressBar', true, {root: true});
|
||
|
//
|
||
|
// if(action.body) {
|
||
|
// try {
|
||
|
// a.body = JSON.parse(a.body);
|
||
|
// } catch (e) {
|
||
|
// console.log(e);
|
||
|
// }
|
||
|
// }
|
||
|
// if(action.headers) {
|
||
|
// try {
|
||
|
// a.headers = JSON.parse(a.headers);
|
||
|
// } catch (e) {
|
||
|
// console.log(e);
|
||
|
// }
|
||
|
// }
|
||
|
//
|
||
|
// a.response = {};
|
||
|
// let data = await axios({
|
||
|
// url: a.url,
|
||
|
// method: a.type,
|
||
|
// data: a.body,
|
||
|
// headers: a.headers
|
||
|
// });
|
||
|
//
|
||
|
// a.response.status = data.status;
|
||
|
// a.response.data = data.data;
|
||
|
// console.log(data);
|
||
|
// } catch (e) {
|
||
|
// console.log(Object.keys(e), Object.entries(e));
|
||
|
// a.response = e.response;
|
||
|
// //throw e;
|
||
|
// } finally {
|
||
|
// commit('notification/MutToggleProgressBar', false, {root: true});
|
||
|
// commit('MutListAdd', {...a,body:JSON.stringify(a.body),headers:JSON.stringify(a.headers)});
|
||
|
// return a.response;
|
||
|
// }
|
||
|
|
||
|
|
||
|
},
|
||
|
async loadSqlCollectionForProject({commit, state}, {projectName, projectId}) {
|
||
|
const key = projectName + "__" + projectId;
|
||
|
commit('MutCurrentProjectKey', key)
|
||
|
if (!(key in state.projectSqlFilePaths)) {
|
||
|
commit('MutList', []);
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
/**
|
||
|
* @copyright Copyright (c) 2021, Xgene Cloud Ltd
|
||
|
*
|
||
|
* @author Naveen MR <oof1lab@gmail.com>
|
||
|
* @author Pranav C Balan <pranavxc@gmail.com>
|
||
|
*
|
||
|
* @license GNU AGPL version 3 or any later version
|
||
|
*
|
||
|
* This program is free software: you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU Affero General Public License as
|
||
|
* published by the Free Software Foundation, either version 3 of the
|
||
|
* License, or (at your option) any later version.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU Affero General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Affero General Public License
|
||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*
|
||
|
*/
|