GitHub publishing enhancements
This commit is contained in:
parent
7283ff7229
commit
0c1c8b274f
@ -12,12 +12,14 @@
|
|||||||
}
|
}
|
||||||
var client_id = getParameter("client_id");
|
var client_id = getParameter("client_id");
|
||||||
var code = getParameter("code");
|
var code = getParameter("code");
|
||||||
if (code) {
|
if (client_id) {
|
||||||
localStorage["githubCode"] = code;
|
|
||||||
window.close();
|
|
||||||
} else if (client_id) {
|
|
||||||
window.location.href = "https://github.com/login/oauth/authorize?client_id="
|
window.location.href = "https://github.com/login/oauth/authorize?client_id="
|
||||||
+ client_id + "&scope=repo";
|
+ client_id + "&scope=repo";
|
||||||
|
} else {
|
||||||
|
if (code) {
|
||||||
|
localStorage["githubCode"] = code;
|
||||||
|
}
|
||||||
|
window.close();
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
|
25
index.html
25
index.html
@ -258,33 +258,25 @@
|
|||||||
<div class="modal-header">
|
<div class="modal-header">
|
||||||
<button type="button" class="close" data-dismiss="modal"
|
<button type="button" class="close" data-dismiss="modal"
|
||||||
aria-hidden="true">×</button>
|
aria-hidden="true">×</button>
|
||||||
<h3>Publish</h3>
|
<h3 class="modal-publish-github">Publish on GitHub</h3>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
<div class="form-horizontal">
|
<div class="form-horizontal">
|
||||||
<div class="control-group control-publish-github">
|
<div class="control-group modal-publish-github">
|
||||||
<label class="control-label" for="input-publish-github-username">GitHub
|
|
||||||
user</label>
|
|
||||||
<div class="controls">
|
|
||||||
<input type="text" id="input-publish-github-username"
|
|
||||||
placeholder="User name">
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="control-group control-publish-github">
|
|
||||||
<label class="control-label" for="input-publish-github-reponame">Repository</label>
|
<label class="control-label" for="input-publish-github-reponame">Repository</label>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<input type="text" id="input-publish-github-reponame"
|
<input type="text" id="input-publish-github-reponame"
|
||||||
placeholder="Repository name">
|
placeholder="Repository name">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="control-group control-publish-github">
|
<div class="control-group modal-publish-github">
|
||||||
<label class="control-label" for="input-publish-github-branch">Branch</label>
|
<label class="control-label" for="input-publish-github-branch">Branch</label>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<input type="text" id="input-publish-github-branch"
|
<input type="text" id="input-publish-github-branch"
|
||||||
placeholder="Branch name">
|
placeholder="Branch name">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="control-group control-publish-github">
|
<div class="control-group modal-publish-github">
|
||||||
<label class="control-label" for="input-publish-github-path">File
|
<label class="control-label" for="input-publish-github-path">File
|
||||||
path</label>
|
path</label>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
@ -292,7 +284,7 @@
|
|||||||
placeholder="path/to/file.md">
|
placeholder="path/to/file.md">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="control-group control-publish-blogger">
|
<div class="control-group modal-publish-blogger">
|
||||||
<label class="control-label" for="input-publish-blogger-url">Blog
|
<label class="control-label" for="input-publish-blogger-url">Blog
|
||||||
URL</label>
|
URL</label>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
@ -300,7 +292,7 @@
|
|||||||
placeholder="http://exemple.blogger.com/">
|
placeholder="http://exemple.blogger.com/">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="control-group control-publish-blogger">
|
<div class="control-group modal-publish-blogger">
|
||||||
<label class="control-label" for="input-publish-blogger-postid">Update
|
<label class="control-label" for="input-publish-blogger-postid">Update
|
||||||
existing post ID (optional)</label>
|
existing post ID (optional)</label>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
@ -309,13 +301,12 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="control-group">
|
<div class="control-group">
|
||||||
<div class="control-label">Publish as</div>
|
<div class="control-label">Format</div>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<label class="radio"> <input type="radio"
|
<label class="radio"> <input type="radio"
|
||||||
name="radio-publish-format" value="markdown"> Markdown
|
name="radio-publish-format" value="markdown"> Markdown
|
||||||
format
|
|
||||||
</label> <label class="radio"> <input type="radio"
|
</label> <label class="radio"> <input type="radio"
|
||||||
name="radio-publish-format" value="html"> HTML format
|
name="radio-publish-format" value="html"> HTML
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -434,7 +434,7 @@ define(["jquery", "google-helper", "dropbox-helper", "github-helper", "synchroni
|
|||||||
newPublishProvider = provider;
|
newPublishProvider = provider;
|
||||||
|
|
||||||
// Show/hide controls depending on provider
|
// Show/hide controls depending on provider
|
||||||
$('div[class*=" control-publish-"]').hide().filter(".control-publish-" + provider).show();
|
$('div[class*=" modal-publish-"]').hide().filter(".modal-publish-" + provider).show();
|
||||||
|
|
||||||
// Reset fields
|
// Reset fields
|
||||||
core.resetModalInputs();
|
core.resetModalInputs();
|
||||||
@ -457,7 +457,6 @@ define(["jquery", "google-helper", "dropbox-helper", "github-helper", "synchroni
|
|||||||
// Create a new publication on GitHub
|
// Create a new publication on GitHub
|
||||||
function newPublishGithub(event) {
|
function newPublishGithub(event) {
|
||||||
var publishObject = {};
|
var publishObject = {};
|
||||||
publishObject.username = core.getInputValue($("#input-publish-github-username"), event);
|
|
||||||
publishObject.repository = core.getInputValue($("#input-publish-github-reponame"), event);
|
publishObject.repository = core.getInputValue($("#input-publish-github-reponame"), event);
|
||||||
publishObject.branch = core.getInputValue($("#input-publish-github-branch"), event);
|
publishObject.branch = core.getInputValue($("#input-publish-github-branch"), event);
|
||||||
publishObject.path = core.getInputValue($("#input-publish-github-path"), event);
|
publishObject.path = core.getInputValue($("#input-publish-github-path"), event);
|
||||||
@ -470,7 +469,7 @@ define(["jquery", "google-helper", "dropbox-helper", "github-helper", "synchroni
|
|||||||
var title = localStorage[fileIndex + ".title"];
|
var title = localStorage[fileIndex + ".title"];
|
||||||
var content = publisher.getPublishContent(publishObject);
|
var content = publisher.getPublishContent(publishObject);
|
||||||
var commitMsg = core.settings.commitMsg;
|
var commitMsg = core.settings.commitMsg;
|
||||||
githubHelper.upload(publishObject.username, publishObject.repository,
|
githubHelper.upload(publishObject.repository,
|
||||||
publishObject.branch, publishObject.path, content, commitMsg,
|
publishObject.branch, publishObject.path, content, commitMsg,
|
||||||
function(error) {
|
function(error) {
|
||||||
if(error === undefined) {
|
if(error === undefined) {
|
||||||
|
@ -55,6 +55,7 @@ define(["jquery", "async-runner"], function($, asyncTaskRunner) {
|
|||||||
var intervalId = undefined;
|
var intervalId = undefined;
|
||||||
var authWindow = undefined;
|
var authWindow = undefined;
|
||||||
var token = localStorage["githubToken"];
|
var token = localStorage["githubToken"];
|
||||||
|
var errorMsg = "Access to GitHub is not authorized.";
|
||||||
var asyncTask = {};
|
var asyncTask = {};
|
||||||
asyncTask.run = function() {
|
asyncTask.run = function() {
|
||||||
if (github !== undefined) {
|
if (github !== undefined) {
|
||||||
@ -71,7 +72,7 @@ define(["jquery", "async-runner"], function($, asyncTaskRunner) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(immediate === true) {
|
if(immediate === true) {
|
||||||
core.showError("Unable to perform GitHub authenticate.");
|
core.showError();
|
||||||
asyncTask.error();
|
asyncTask.error();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -85,15 +86,18 @@ define(["jquery", "async-runner"], function($, asyncTaskRunner) {
|
|||||||
authWindow.focus();
|
authWindow.focus();
|
||||||
intervalId = setInterval(function() {
|
intervalId = setInterval(function() {
|
||||||
var code = localStorage["githubCode"];
|
var code = localStorage["githubCode"];
|
||||||
if(code !== undefined) {
|
if(authWindow.closed === true || code !== undefined) {
|
||||||
localStorage.removeItem("githubCode");
|
localStorage.removeItem("githubCode");
|
||||||
|
if(code === undefined) {
|
||||||
|
asyncTask.error();
|
||||||
|
return;
|
||||||
|
}
|
||||||
$.getJSON(GATEKEEPER_URL + "authenticate/" + code, function(data) {
|
$.getJSON(GATEKEEPER_URL + "authenticate/" + code, function(data) {
|
||||||
if(data.token !== undefined) {
|
if(data.token !== undefined) {
|
||||||
localStorage["githubToken"] = data.token;
|
localStorage["githubToken"] = data.token;
|
||||||
asyncTask.success();
|
asyncTask.success();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
core.showError("Error retrieving GitHub Oauth token.");
|
|
||||||
asyncTask.error();
|
asyncTask.error();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -117,50 +121,59 @@ define(["jquery", "async-runner"], function($, asyncTaskRunner) {
|
|||||||
if(authWindow !== undefined) {
|
if(authWindow !== undefined) {
|
||||||
authWindow.close();
|
authWindow.close();
|
||||||
}
|
}
|
||||||
|
core.showError(errorMsg);
|
||||||
callback();
|
callback();
|
||||||
};
|
};
|
||||||
asyncTaskRunner.addTask(asyncTask);
|
asyncTaskRunner.addTask(asyncTask);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
githubHelper.upload = function(username, reponame, branch, path, content, commitMsg, callback) {
|
githubHelper.upload = function(reponame, branch, path, content, commitMsg, callback) {
|
||||||
callback = callback || core.doNothing;
|
callback = callback || core.doNothing;
|
||||||
authenticate(function() {
|
authenticate(function() {
|
||||||
if (github === undefined) {
|
if (github === undefined) {
|
||||||
callback();
|
callback("error");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var error = undefined;
|
var error = undefined;
|
||||||
var asyncTask = {};
|
var asyncTask = {};
|
||||||
asyncTask.run = function() {
|
asyncTask.run = function() {
|
||||||
var repo = github.getRepo(username, reponame);
|
var user = github.getUser();
|
||||||
repo.write(branch, path, content, commitMsg, function(err) {
|
user.show(undefined, function(err, result) {
|
||||||
if(!err) {
|
if(err) {
|
||||||
asyncTask.success();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
error = err.error;
|
error = err.error;
|
||||||
asyncTask.error();
|
asyncTask.error();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var repo = github.getRepo(result.login, reponame);
|
||||||
|
repo.write(branch, path, content, commitMsg, function(err) {
|
||||||
|
if(err) {
|
||||||
|
error = err.error;
|
||||||
|
asyncTask.error();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
asyncTask.success();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
asyncTask.onSuccess = function() {
|
asyncTask.onSuccess = function() {
|
||||||
callback(error);
|
callback(error);
|
||||||
};
|
};
|
||||||
asyncTask.onError = function() {
|
asyncTask.onError = function() {
|
||||||
if(error === 401) {
|
var errorMsg = "Could not publish on GitHub";
|
||||||
|
if(error === 401 || error === 403) {
|
||||||
github = undefined;
|
github = undefined;
|
||||||
// Token must be renewed
|
// Token must be renewed
|
||||||
localStorage.removeItem("githubToken");
|
localStorage.removeItem("githubToken");
|
||||||
githubHelper.upload(username, reponame, branch, path, content, commitMsg, callback);
|
errorMsg = "Access to GitHub is not authorized.";
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
if(error === 0) {
|
else if(error === 0) {
|
||||||
connected = false;
|
connected = false;
|
||||||
github = undefined;
|
github = undefined;
|
||||||
core.setOffline();
|
core.setOffline();
|
||||||
}
|
}
|
||||||
core.showError("Could not publish on GitHub");
|
core.showError(errorMsg);
|
||||||
callback(error);
|
callback(error);
|
||||||
};
|
};
|
||||||
asyncTaskRunner.addTask(asyncTask);
|
asyncTaskRunner.addTask(asyncTask);
|
||||||
|
@ -66,8 +66,7 @@ define(["jquery", "google-helper", "github-helper"], function($, googleHelper, g
|
|||||||
|
|
||||||
// Try to find the provider
|
// Try to find the provider
|
||||||
if(publishObject.provider == PUBLISH_PROVIDER_GITHUB) {
|
if(publishObject.provider == PUBLISH_PROVIDER_GITHUB) {
|
||||||
githubHelper.upload(publishObject.username, publishObject.repository,
|
githubHelper.upload(publishObject.repository, publishObject.branch, publishObject.path, content, commitMsg,
|
||||||
publishObject.branch, publishObject.path, content, commitMsg,
|
|
||||||
function(error) {
|
function(error) {
|
||||||
publishLocation(callback, error);
|
publishLocation(callback, error);
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user