1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00

Handle cloning a project without package.json

This commit is contained in:
Nick O'Leary 2018-05-02 16:24:58 +01:00
parent c4d1ccb6f5
commit 53e3e08d70
No known key found for this signature in database
GPG Key ID: 4F2157149161A6C9
5 changed files with 78 additions and 15 deletions

View File

@ -214,6 +214,18 @@
} }
] ]
} }
} else if (msg.error === "missing_package_file") {
if (RED.user.hasPermission("projects.write")) {
options.buttons = [
{
text: "Create default package file",
click: function() {
persistentNotifications[notificationId].hideNotification();
RED.projects.createDefaultPackageFile();
}
}
]
}
} else if (msg.error === "project_empty") { } else if (msg.error === "project_empty") {
if (RED.user.hasPermission("projects.write")) { if (RED.user.hasPermission("projects.write")) {
options.buttons = [ options.buttons = [

View File

@ -2251,6 +2251,43 @@ RED.projects = (function() {
createProjectOptions = {}; createProjectOptions = {};
show('default-files',{existingProject: true}); show('default-files',{existingProject: true});
} }
function createDefaultPackageFile() {
RED.deploy.setDeployInflight(true);
RED.projects.settings.switchProject(activeProject.name);
var method = "PUT";
var url = "projects/"+activeProject.name;
var createProjectOptions = {
initialise: true
};
sendRequest({
url: url,
type: method,
requireCleanWorkspace: true,
handleAuthFail: false,
responses: {
200: function(data) { },
400: {
'git_error': function(error) {
console.log("git error",error);
},
'missing_flow_file': function(error) {
// This is a natural next error - but let the runtime event
// trigger the dialog rather than double-report it.
$( dialog ).dialog( "close" );
},
'*': function(error) {
reportUnexpectedError(error);
$( dialog ).dialog( "close" );
}
}
}
},createProjectOptions).always(function() {
setTimeout(function() {
RED.deploy.setDeployInflight(false);
},500);
})
}
function refresh(done) { function refresh(done) {
$.getJSON("projects",function(data) { $.getJSON("projects",function(data) {
@ -2330,6 +2367,7 @@ RED.projects = (function() {
RED.projects.settings.show('deps'); RED.projects.settings.show('deps');
}, },
createDefaultFileSet: createDefaultFileSet, createDefaultFileSet: createDefaultFileSet,
createDefaultPackageFile: createDefaultPackageFile,
// showSidebar: showSidebar, // showSidebar: showSidebar,
refresh: refresh, refresh: refresh,
editProject: function() { editProject: function() {

View File

@ -93,6 +93,7 @@
"credentials_load_failed": "<p>Flows stopped as the credentials could not be decrypted.</p><p>The flow credential file is encrypted, but the project's encryption key is missing or invalid.</p>", "credentials_load_failed": "<p>Flows stopped as the credentials could not be decrypted.</p><p>The flow credential file is encrypted, but the project's encryption key is missing or invalid.</p>",
"credentials_load_failed_reset":"<p>Credentials could not be decrypted</p><p>The flow credential file is encrypted, but the project's encryption key is missing or invalid.</p><p>The flow credential file will be reset on the next deployment. Any existing flow credentials will be cleared.</p>", "credentials_load_failed_reset":"<p>Credentials could not be decrypted</p><p>The flow credential file is encrypted, but the project's encryption key is missing or invalid.</p><p>The flow credential file will be reset on the next deployment. Any existing flow credentials will be cleared.</p>",
"missing_flow_file": "<p>Project flow file not found.</p><p>The project is not configured with a flow file.</p>", "missing_flow_file": "<p>Project flow file not found.</p><p>The project is not configured with a flow file.</p>",
"missing_package_file": "<p>Project package file not found.</p><p>The project is missing a package.json file.</p>",
"project_empty": "<p>The project is empty.</p><p>Do you want to create a default set of project files?<br/>Otherwise, you will have to manually add files to the project outside of the editor.</p>", "project_empty": "<p>The project is empty.</p><p>Do you want to create a default set of project files?<br/>Otherwise, you will have to manually add files to the project outside of the editor.</p>",
"project_not_found": "<p>Project '__project__' not found.</p>", "project_not_found": "<p>Project '__project__' not found.</p>",
"git_merge_conflict": "<p>Automatic merging of changes failed.</p><p>Fix the unmerged conflicts then commit the results.</p>" "git_merge_conflict": "<p>Automatic merging of changes failed.</p><p>Fix the unmerged conflicts then commit the results.</p>"

View File

@ -81,9 +81,7 @@ Project.prototype.load = function () {
var promises = []; var promises = [];
return checkProjectFiles(project).then(function(missingFiles) { return checkProjectFiles(project).then(function(missingFiles) {
if (missingFiles.length > 0) {
project.missingFiles = missingFiles; project.missingFiles = missingFiles;
}
if (missingFiles.indexOf('package.json') === -1) { if (missingFiles.indexOf('package.json') === -1) {
project.paths['package.json'] = fspath.join(project.path,"package.json"); project.paths['package.json'] = fspath.join(project.path,"package.json");
promises.push(fs.readFile(project.paths['package.json'],"utf8").then(function(content) { promises.push(fs.readFile(project.paths['package.json'],"utf8").then(function(content) {
@ -135,9 +133,9 @@ Project.prototype.load = function () {
Project.prototype.initialise = function(user,data) { Project.prototype.initialise = function(user,data) {
var project = this; var project = this;
if (!this.empty) { // if (!this.empty) {
throw new Error("Cannot initialise non-empty project"); // throw new Error("Cannot initialise non-empty project");
} // }
var files = Object.keys(defaultFileSet); var files = Object.keys(defaultFileSet);
var promises = []; var promises = [];
@ -148,6 +146,8 @@ Project.prototype.initialise = function(user,data) {
promises.push(settings.set('projects',projects)); promises.push(settings.set('projects',projects));
} }
if (data.hasOwnProperty('files')) {
if (data.files.hasOwnProperty('flow') && data.files.hasOwnProperty('credentials')) {
project.files.flow = data.files.flow; project.files.flow = data.files.flow;
project.files.credentials = data.files.credentials; project.files.credentials = data.files.credentials;
var flowFilePath = fspath.join(project.path,project.files.flow); var flowFilePath = fspath.join(project.path,project.files.flow);
@ -156,9 +156,15 @@ Project.prototype.initialise = function(user,data) {
promises.push(util.writeFile(credsFilePath,"{}")); promises.push(util.writeFile(credsFilePath,"{}"));
files.push(project.files.flow); files.push(project.files.flow);
files.push(project.files.credentials); files.push(project.files.credentials);
}
}
for (var file in defaultFileSet) { for (var file in defaultFileSet) {
if (defaultFileSet.hasOwnProperty(file)) { if (defaultFileSet.hasOwnProperty(file)) {
promises.push(util.writeFile(fspath.join(project.path,file),defaultFileSet[file](project))); var path = fspath.join(project.path,file);
if (!fs.existsSync(path)) {
promises.push(util.writeFile(path,defaultFileSet[file](project)));
}
} }
} }

View File

@ -479,6 +479,12 @@ function getFlows() {
error.code = "project_empty"; error.code = "project_empty";
return when.reject(error); return when.reject(error);
} }
if (activeProject.missingFiles && activeProject.missingFiles.indexOf('package.json') !== -1) {
log.warn("Project missing package.json");
error = new Error("Project missing package.json");
error.code = "missing_package_file";
return when.reject(error);
}
if (!activeProject.getFlowFile()) { if (!activeProject.getFlowFile()) {
log.warn("Project has no flow file"); log.warn("Project has no flow file");
error = new Error("Project has no flow file"); error = new Error("Project has no flow file");