Remove gittle dependency and use dulwich directly
This commit is contained in:
		
							parent
							
								
									0b931d1a05
								
							
						
					
					
						commit
						1c097a146a
					
				
					 3 changed files with 24 additions and 41 deletions
				
			
		|  | @ -2,11 +2,9 @@ import os | ||||||
| import posixpath | import posixpath | ||||||
| import re | import re | ||||||
| import ghdiff | import ghdiff | ||||||
| import gittle.utils |  | ||||||
| import yaml | import yaml | ||||||
| from gittle import Gittle |  | ||||||
| from dulwich.object_store import tree_lookup_path | from dulwich.object_store import tree_lookup_path | ||||||
| from dulwich.repo import NotGitRepository | from dulwich.repo import Repo, NotGitRepository | ||||||
| from realms.lib.util import cname_to_filename, filename_to_cname | from realms.lib.util import cname_to_filename, filename_to_cname | ||||||
| from realms import cache | from realms import cache | ||||||
| from realms.lib.hook import HookMixin | from realms.lib.hook import HookMixin | ||||||
|  | @ -23,17 +21,13 @@ class Wiki(HookMixin): | ||||||
|     default_committer_name = 'Anon' |     default_committer_name = 'Anon' | ||||||
|     default_committer_email = 'anon@anon.anon' |     default_committer_email = 'anon@anon.anon' | ||||||
|     index_page = 'home' |     index_page = 'home' | ||||||
|     gittle = None |  | ||||||
|     repo = None |     repo = None | ||||||
| 
 | 
 | ||||||
|     def __init__(self, path): |     def __init__(self, path): | ||||||
|         try: |         try: | ||||||
|             self.gittle = Gittle(path) |             self.repo = Repo(path) | ||||||
|         except NotGitRepository: |         except NotGitRepository: | ||||||
|             self.gittle = Gittle.init(path) |             self.repo = Repo.init(path, mkdir=True) | ||||||
| 
 |  | ||||||
|         # Dulwich repo |  | ||||||
|         self.repo = self.gittle.repo |  | ||||||
| 
 | 
 | ||||||
|         self.path = path |         self.path = path | ||||||
| 
 | 
 | ||||||
|  | @ -46,20 +40,20 @@ class Wiki(HookMixin): | ||||||
|         :param name: Committer name |         :param name: Committer name | ||||||
|         :param email: Committer email |         :param email: Committer email | ||||||
|         :param message: Commit message |         :param message: Commit message | ||||||
|         :param files: list of file names that should be committed |         :param files: list of file names that will be staged for commit | ||||||
|         :return: |         :return: | ||||||
|         """ |         """ | ||||||
|         # Dulwich and gittle seem to want us to encode ourselves at the moment. see #152 |  | ||||||
|         if isinstance(name, unicode): |         if isinstance(name, unicode): | ||||||
|             name = name.encode('utf-8') |             name = name.encode('utf-8') | ||||||
|         if isinstance(email, unicode): |         if isinstance(email, unicode): | ||||||
|             email = email.encode('utf-8') |             email = email.encode('utf-8') | ||||||
|         if isinstance(message, unicode): |         if isinstance(message, unicode): | ||||||
|             message = message.encode('utf-8') |             message = message.encode('utf-8') | ||||||
|         return self.gittle.commit(name=name, |         author = committer = "%s <%s>" % (name, email) | ||||||
|                                   email=email, |         self.repo.stage(files) | ||||||
|                                   message=message, |         return self.repo.do_commit(message=message, | ||||||
|                                   files=files) |                                    committer=committer, | ||||||
|  |                                    author=author) | ||||||
| 
 | 
 | ||||||
|     def get_page(self, name, sha='HEAD'): |     def get_page(self, name, sha='HEAD'): | ||||||
|         """Get page data, partials, commit info. |         """Get page data, partials, commit info. | ||||||
|  | @ -104,7 +98,8 @@ class WikiPage(HookMixin): | ||||||
|         if cached: |         if cached: | ||||||
|             return cached |             return cached | ||||||
| 
 | 
 | ||||||
|         data = self.wiki.gittle.get_commit_files(self.sha, paths=[self.filename]).get(self.filename).get('data') |         mode, sha = tree_lookup_path(self.wiki.repo.get_object, self.wiki.repo[self.sha].tree, self.filename) | ||||||
|  |         data = self.wiki.repo[sha].data | ||||||
|         cache.set(cache_key, data) |         cache.set(cache_key, data) | ||||||
|         return data |         return data | ||||||
| 
 | 
 | ||||||
|  | @ -126,20 +121,20 @@ class WikiPage(HookMixin): | ||||||
|         :return: list -- List of dicts |         :return: list -- List of dicts | ||||||
| 
 | 
 | ||||||
|         """ |         """ | ||||||
|         if not len(self.wiki.repo.open_index()): |  | ||||||
|             # Index is empty, no commits |  | ||||||
|             return [] |  | ||||||
| 
 |  | ||||||
|         versions = [] |         versions = [] | ||||||
| 
 | 
 | ||||||
|         walker = self.wiki.repo.get_walker(paths=[self.filename], max_entries=limit) |         try: | ||||||
|  |             walker = self.wiki.repo.get_walker(paths=[self.filename], max_entries=limit, follow=True) | ||||||
|  |         except KeyError: | ||||||
|  |             # We don't have a head, no commits | ||||||
|  |             return [] | ||||||
|  | 
 | ||||||
|         for entry in walker: |         for entry in walker: | ||||||
|             change_type = None |             change_type = None | ||||||
|             for change in entry.changes(): |             for change in entry.changes(): | ||||||
|                 if change.old.path == self.filename: |                 # Changes should already be filtered to only the one affecting our file | ||||||
|                     change_type = change.type |  | ||||||
|                 elif change.new.path == self.filename: |  | ||||||
|                 change_type = change.type |                 change_type = change.type | ||||||
|  |                 break | ||||||
|             author_name, author_email = entry.commit.author.rstrip('>').split('<') |             author_name, author_email = entry.commit.author.rstrip('>').split('<') | ||||||
|             versions.append(dict( |             versions.append(dict( | ||||||
|                 author=author_name.strip(), |                 author=author_name.strip(), | ||||||
|  | @ -211,9 +206,7 @@ class WikiPage(HookMixin): | ||||||
|         if not message: |         if not message: | ||||||
|             message = "Deleted %s" % self.name |             message = "Deleted %s" % self.name | ||||||
| 
 | 
 | ||||||
|         # gittle.rm won't actually remove the file, have to do it ourselves |  | ||||||
|         os.remove(os.path.join(self.wiki.path, self.filename)) |         os.remove(os.path.join(self.wiki.path, self.filename)) | ||||||
|         self.wiki.gittle.rm(self.filename) |  | ||||||
|         commit = self.wiki.commit(name=username, |         commit = self.wiki.commit(name=username, | ||||||
|                                   email=email, |                                   email=email, | ||||||
|                                   message=message, |                                   message=message, | ||||||
|  | @ -232,7 +225,7 @@ class WikiPage(HookMixin): | ||||||
|         """ |         """ | ||||||
|         assert self.sha == 'HEAD' |         assert self.sha == 'HEAD' | ||||||
|         old_filename, new_filename = self.filename, cname_to_filename(new_name) |         old_filename, new_filename = self.filename, cname_to_filename(new_name) | ||||||
|         if old_filename not in self.wiki.gittle.index: |         if old_filename not in self.wiki.repo.open_index(): | ||||||
|             # old doesn't exist |             # old doesn't exist | ||||||
|             return None |             return None | ||||||
|         elif old_filename == new_filename: |         elif old_filename == new_filename: | ||||||
|  | @ -247,10 +240,6 @@ class WikiPage(HookMixin): | ||||||
|             message = "Moved %s to %s" % (self.name, new_name) |             message = "Moved %s to %s" % (self.name, new_name) | ||||||
| 
 | 
 | ||||||
|         os.rename(os.path.join(self.wiki.path, old_filename), os.path.join(self.wiki.path, new_filename)) |         os.rename(os.path.join(self.wiki.path, old_filename), os.path.join(self.wiki.path, new_filename)) | ||||||
| 
 |  | ||||||
|         self.wiki.gittle.add(new_filename) |  | ||||||
|         self.wiki.gittle.rm(old_filename) |  | ||||||
| 
 |  | ||||||
|         commit = self.wiki.commit(name=username, |         commit = self.wiki.commit(name=username, | ||||||
|                                   email=email, |                                   email=email, | ||||||
|                                   message=message, |                                   message=message, | ||||||
|  | @ -264,12 +253,11 @@ class WikiPage(HookMixin): | ||||||
| 
 | 
 | ||||||
|         return commit |         return commit | ||||||
| 
 | 
 | ||||||
|     def write(self, content, message=None, create=False, username=None, email=None): |     def write(self, content, message=None, username=None, email=None): | ||||||
|         """Write page to git repo |         """Write page to git repo | ||||||
| 
 | 
 | ||||||
|         :param content: Content of page. |         :param content: Content of page. | ||||||
|         :param message: Commit message. |         :param message: Commit message. | ||||||
|         :param create: Perform git add operation? |  | ||||||
|         :param username: Commit Name. |         :param username: Commit Name. | ||||||
|         :param email: Commit Email. |         :param email: Commit Email. | ||||||
|         :return: Git commit sha1. |         :return: Git commit sha1. | ||||||
|  | @ -283,9 +271,6 @@ class WikiPage(HookMixin): | ||||||
|         with open(self.wiki.path + "/" + self.filename, 'w') as f: |         with open(self.wiki.path + "/" + self.filename, 'w') as f: | ||||||
|             f.write(content) |             f.write(content) | ||||||
| 
 | 
 | ||||||
|         if create: |  | ||||||
|             self.wiki.gittle.add(self.filename) |  | ||||||
| 
 |  | ||||||
|         if not message: |         if not message: | ||||||
|             message = "Updated %s" % self.name |             message = "Updated %s" % self.name | ||||||
| 
 | 
 | ||||||
|  | @ -315,8 +300,7 @@ class WikiPage(HookMixin): | ||||||
|             raise PageNotFound('Commit not found') |             raise PageNotFound('Commit not found') | ||||||
| 
 | 
 | ||||||
|         if not message: |         if not message: | ||||||
|             commit_info = gittle.utils.git.commit_info(self.wiki.gittle[commit_sha.encode('latin-1')]) |             message = "Revert '%s' to %s" % (self.name, commit_sha[:7]) | ||||||
|             message = commit_info['message'] |  | ||||||
| 
 | 
 | ||||||
|         return self.write(new_page.data, message=message, username=username, email=email) |         return self.write(new_page.data, message=message, username=username, email=email) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -168,7 +168,6 @@ def page_write(name): | ||||||
| 
 | 
 | ||||||
|         sha = g.current_wiki.get_page(cname).write(request.form['content'], |         sha = g.current_wiki.get_page(cname).write(request.form['content'], | ||||||
|                                                    message=request.form['message'], |                                                    message=request.form['message'], | ||||||
|                                                    create=True, |  | ||||||
|                                                    username=current_user.username, |                                                    username=current_user.username, | ||||||
|                                                    email=current_user.email) |                                                    email=current_user.email) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								setup.py
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								setup.py
									
										
									
									
									
								
							|  | @ -35,10 +35,10 @@ setup(name='realms-wiki', | ||||||
|           'bcrypt==1.0.2', |           'bcrypt==1.0.2', | ||||||
|           'beautifulsoup4==4.3.2', |           'beautifulsoup4==4.3.2', | ||||||
|           'click==3.3', |           'click==3.3', | ||||||
|  |           'dulwich==0.14.1', | ||||||
|           'flask-ldap-login==0.3.0', |           'flask-ldap-login==0.3.0', | ||||||
|           'gevent==1.0.2', |           'gevent==1.0.2', | ||||||
|           'ghdiff==0.4', |           'ghdiff==0.4', | ||||||
|           'gittle==0.5.0', |  | ||||||
|           'gunicorn==19.3', |           'gunicorn==19.3', | ||||||
|           'itsdangerous==0.24', |           'itsdangerous==0.24', | ||||||
|           'markdown2==2.3.1', |           'markdown2==2.3.1', | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue