commit
5022276863
|
@ -2,7 +2,6 @@ from realms.modules.wiki.models import Wiki
|
|||
from realms import search
|
||||
|
||||
|
||||
|
||||
@Wiki.after('write_page')
|
||||
def wiki_write_page(name, content, message=None, username=None, email=None, **kwargs):
|
||||
|
||||
|
@ -19,5 +18,18 @@ def wiki_write_page(name, content, message=None, username=None, email=None, **kw
|
|||
|
||||
|
||||
@Wiki.after('rename_page')
|
||||
def wiki_rename_page(*args, **kwargs):
|
||||
pass
|
||||
def wiki_rename_page(old_name, *args, **kwargs):
|
||||
|
||||
if not hasattr(search, 'index_wiki'):
|
||||
return
|
||||
|
||||
return search.delete_wiki(old_name)
|
||||
|
||||
|
||||
@Wiki.after('delete_page')
|
||||
def wiki_delete_page(name, *args, **kwargs):
|
||||
|
||||
if not hasattr(search, 'index_wiki'):
|
||||
return
|
||||
|
||||
return search.delete_wiki(name)
|
||||
|
|
|
@ -92,9 +92,19 @@ class WhooshSearch(BaseSearch):
|
|||
writer.update_document(path=id_.decode("utf-8"), body=body["content"].decode("utf-8"))
|
||||
writer.commit()
|
||||
|
||||
def delete(self, id_):
|
||||
with self.search_index.searcher() as s:
|
||||
doc_num = s.document_number(path=id_.decode("utf-8"))
|
||||
writer = self.search_index.writer()
|
||||
writer.delete_document(doc_num)
|
||||
writer.commit()
|
||||
|
||||
def index_wiki(self, name, body):
|
||||
self.index('wiki', 'page', id_=name, body=body)
|
||||
|
||||
def delete_wiki(self, name):
|
||||
self.delete(id_=name)
|
||||
|
||||
def delete_index(self, index):
|
||||
from whoosh import index as whoosh_index
|
||||
self.search_index.close()
|
||||
|
@ -133,9 +143,15 @@ class ElasticSearch(BaseSearch):
|
|||
def index(self, index, doc_type, id_=None, body=None):
|
||||
return self.elastic.index(index=index, doc_type=doc_type, id=id_, body=body)
|
||||
|
||||
def delete(self, index, doc_type, id_):
|
||||
return self.elastic.delete(index=index, doc_type=doc_type, id=id_)
|
||||
|
||||
def index_wiki(self, name, body):
|
||||
self.index('wiki', 'page', id_=name, body=body)
|
||||
|
||||
def delete_wiki(self, name):
|
||||
self.delete('wiki', 'page', id_=name)
|
||||
|
||||
def delete_index(self, index):
|
||||
return self.elastic.indices.delete(index=index, ignore=[400, 404])
|
||||
|
||||
|
|
|
@ -156,11 +156,14 @@ class Wiki(HookMixin):
|
|||
message = "Deleted %s" % name
|
||||
|
||||
filename = cname_to_filename(name)
|
||||
|
||||
# gittle.rm won't actually remove the file, have to do it ourselves
|
||||
os.remove(os.path.join(self.path, filename))
|
||||
self.gittle.rm(filename)
|
||||
commit = self.gittle.commit(name=username,
|
||||
email=email,
|
||||
message=message,
|
||||
files=[str(filename)])
|
||||
files=[filename])
|
||||
cache.delete_many(name)
|
||||
return commit
|
||||
|
||||
|
|
|
@ -52,6 +52,11 @@ class WikiTest(WikiBaseTest):
|
|||
self.assert_403(self.client.delete(url_for('wiki.page_write', name='test')))
|
||||
self.app.config['WIKI_LOCKED_PAGES'] = []
|
||||
|
||||
# Create page, check it exists
|
||||
self.create_page('test', message='test message', content='testing')
|
||||
self.assert_200(self.client.get(url_for('wiki.page', name='test')))
|
||||
|
||||
# Delete page
|
||||
self.assert_200(self.client.delete(url_for('wiki.page_write', name='test')))
|
||||
|
||||
rv = self.client.get(url_for('wiki.page', name='test'))
|
||||
|
|
|
@ -151,12 +151,12 @@ def page_write(name):
|
|||
|
||||
return dict(sha=sha)
|
||||
|
||||
else:
|
||||
elif request.method == 'DELETE':
|
||||
# DELETE
|
||||
if cname in current_app.config.get('WIKI_LOCKED_PAGES'):
|
||||
return dict(error=True, message="Page is locked"), 403
|
||||
|
||||
sha = g.current_wiki.delete_page(name,
|
||||
sha = g.current_wiki.delete_page(cname,
|
||||
username=current_user.username,
|
||||
email=current_user.email)
|
||||
|
||||
|
|
|
@ -58,10 +58,31 @@ $(function(){
|
|||
});
|
||||
|
||||
$("#delete-page-btn").click(function() {
|
||||
bootbox.alert("Not Done Yet! Sorry");
|
||||
bootbox.confirm('Are you sure you want to delete this page?', function(result) {
|
||||
if (result) {
|
||||
deletePage();
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
var deletePage = function() {
|
||||
var pageName = $page_name.val();
|
||||
var path = Config['RELATIVE_PATH'] + '/' + pageName;
|
||||
|
||||
$.ajax({
|
||||
type: 'DELETE',
|
||||
url: path,
|
||||
}).done(function(data) {
|
||||
var msg = 'Deleted page: ' + pageName;
|
||||
bootbox.alert(msg, function() {
|
||||
location.href = '/';
|
||||
});
|
||||
}).fail(function(data, status, error) {
|
||||
bootbox.alert('Error deleting page!');
|
||||
});
|
||||
};
|
||||
|
||||
var aced = new Aced({
|
||||
editor: $('#entry-markdown-content').find('.editor').attr('id'),
|
||||
renderer: function(md) { return MDR.convert(md) },
|
||||
|
@ -73,7 +94,11 @@ var aced = new Aced({
|
|||
content: content
|
||||
};
|
||||
|
||||
var path = Config['RELATIVE_PATH'] + '/' + data['name'];
|
||||
// If renaming an existing page, use the old page name for the URL to PUT to
|
||||
var subPath = (PAGE_NAME) ? PAGE_NAME : data['name']
|
||||
var path = Config['RELATIVE_PATH'] + '/' + subPath;
|
||||
var newPath = Config['RELATIVE_PATH'] + '/' + data['name'];
|
||||
|
||||
var type = (Commit.info['sha']) ? "PUT" : "POST";
|
||||
|
||||
$.ajax({
|
||||
|
@ -87,7 +112,7 @@ var aced = new Aced({
|
|||
$page_name.addClass('parsley-error');
|
||||
bootbox.alert("<h3>" + res['message'] + "</h3>");
|
||||
} else {
|
||||
location.href = path;
|
||||
location.href = newPath;
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -3,6 +3,8 @@
|
|||
<script>
|
||||
var Commit = {};
|
||||
Commit.info = {{ info|tojson }};
|
||||
|
||||
var PAGE_NAME = '{{ name }}';
|
||||
</script>
|
||||
<script src="{{ url_for('static', filename='js/editor.js') }}"></script>
|
||||
|
||||
|
@ -169,4 +171,4 @@
|
|||
|
||||
</div>
|
||||
|
||||
{% endblock %}
|
||||
{% endblock %}
|
||||
|
|
Loading…
Reference in a new issue