| import logging |
| import re |
| |
| from pylons import c |
| |
| from ming.orm import ThreadLocalORMSession |
| |
| from allura import model as M |
| from allura.lib import utils |
| from forgewiki import model as WM |
| from forgewiki.wiki_main import ForgeWikiApp |
| |
| log = logging.getLogger(__name__) |
| |
| default_description = r'^\s*(?:You can edit this description in the admin page)?\s*$' |
| |
| default_personal_project_tmpl = ("This is the personal project of %s." |
| " This project is created automatically during user registration" |
| " as an easy place to store personal data that doesn't need its own" |
| " project such as cloned repositories.\n\n%s") |
| |
| def main(): |
| users = M.Neighborhood.query.get(name='Users') |
| for chunk in utils.chunked_find(M.Project, {'neighborhood_id': users._id}): |
| for p in chunk: |
| user = p.user_project_of |
| if not user: |
| continue |
| |
| description = p.description |
| if description is None or re.match(default_description, description): |
| continue |
| |
| app = p.app_instance('wiki') |
| if app is None: |
| try: |
| app = p.install_app('wiki') |
| except Exception as e: |
| log.error("Unable to install wiki for user %s: %s" % (user.username, str(e))) |
| continue |
| |
| page = WM.Page.query.get(app_config_id=app.config._id, title='Home') |
| if page is None: |
| continue |
| |
| c.app = app |
| c.project = p |
| c.user = user |
| |
| if "This is the personal project of" in page.text: |
| if description not in page.text: |
| page.text = "%s\n\n%s" % (page.text, description) |
| log.info("Update wiki home page text for %s" % user.username) |
| elif "This is the default page" in page.text: |
| page.text = default_personal_project_tmpl % (user.display_name, description) |
| log.info("Update wiki home page text for %s" % user.username) |
| else: |
| pass |
| |
| ThreadLocalORMSession.flush_all() |
| |
| if __name__ == '__main__': |
| main() |