123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- from django.utils.translation import gettext as _
- import mycreole
- import pages
- from themes import color_icon_url
-
-
- HELP_UID = 'help'
-
- MAIN = mycreole.render_simple(_(
- """
- = Piki
-
- **piki** is a minimal wiki implemented with python and django.
-
- == Get it
- For download and installation instructions, visit [[https://git.mount-mockery.de/application/piki]].
-
- == Help
- * [[creole|Creole Markup Language]]
- * [[access|Access Control for the site content]]
- * [[search|Help on Search]]
- """))
-
- CREOLE = mycreole.mycreole_help_pagecontent()
- CREOLE += mycreole.render_simple("""
- = Piki Markup
- | {{{[[rel_path_to_page|Name]]}}} | will result in a Link to the given wiki page. |
- | {{{<<subpages>>}}} | will result in a list of all subpages below the current page. |
- | {{{<<subpages=N,startswith>>}}} | will result in a list of subpages below the current page.\
- N will reduce the depth of the subpages to N. \
- startswith will reduce the hits to all pages starting with the given string. \
- You can give one or both Parameters. |
- | {{{<<allpages>>}}} | will result in a last of all pages. You can use [N,startswith] as with subpages. |
- """)
-
- ACCESS = mycreole.render_simple(_("""
- = Access
- == Administrator
- If the user has //Superuser status//, the user is able to create, read and write all pages.
- == Create new pages
- Only users with //Superuser status// or //Staff status// are able to create new pages.
- == Page rigths
- All following subsections are able to grant read or write access to the user
- === Owner permissions
- Every page has an owner, if the user is the owner, the defined read or write permissions will be granted.
- === Group permissions
- Every page has a group, if the user is in that group, the defined read or write permissions will be granted.
- === Other permissions
- If no other mechanism granted the permissions, the defined read or write permissions for all other users will be granted.
-
- = Default permissions
- | =Mechanism | =Read | Write |
- | Owner | X | X |
- | Group | X | X |
- | Other | X | - |
- """))
-
- SEARCH = mycreole.render_simple(_(
- """
- = Search
- The search looks up full words in //title (page basename)//, //page_src (the creole source)// and //tag (page tags)// \
- without giving special search commands in the search string.
-
- === Search fields
- * title (TEXT)
- * page_src (TEXT)
- * tag (TEXT)
- * creation_time (DATETIME)
- * modified_time (DATETIME)
- * modified_user (TEXT)
-
- == Search syntax (Whoosh)
- === Logic operators
- * AND
- ** **Example:** "foo AND bar" - Search will find all items with foo and bar.
- * OR
- ** **Example:** "foo OR bar" - Search will find all items with foo, bar or with foo and bar.
- * NOT
- ** **Example:** "foo NOT bar" - Search will find all items with foo and no bar.
- === Search in specific fields
- A search pattern like //foo:bar// does look for //bar// in the field named //foo//.
-
- This search pattern can also be combined with other search text via logical operators.
- === Search for specific content
- * **Wildcards:**
- * **Range:**
- ** From To:
- ** Above:
- ** Below:
- * **Named constants:**
- ** //now//: Current date
- ** //-[num]y//: Current date minus [num] years
- ** //+[num]mo//: Current date plus [num] months
- ** //-[num]d//: Current date minus [num] days
- ** ...
-
- == Examples
- * [[/search/?q=modified_user:system-page|modified_user:system-page]] results in a list of all system pages.
- * [[/search/?q=modified_time%3A%5B-5d+to+now%5D| modified_time:[-5d to now] ]] results in a list of all pages which have been modified within the last 5 days.
- * [[/search/?q=tag%3Afoo| tag:foo ]] results in a list of all pages which are tagged with //foo//.
- """))
-
- BACKUP = mycreole.render_simple(_(
- """
- = Backup
- With the following command, you create a backup of your piki. It contains out of two files. {{{pages.json}}} \
- includes userdata, bottombar configurations and so on. The pages are included in {{{pages.tgz}}}.
- {{{
- $ cd <PROJECT_DIRECTORY>
- $ source venv/bin/activate
- $ python manage.py dumpdata --natural-foreign --natural-primary -e contenttypes -e sessions -e auth.Permission -e sessions -e pages --indent 2 > pages.json
- $ tar -czf pages.tgz data/pages data/media
- }}}
-
- = Recovery
- Be carefull with these commands. They delete all the data, before recovering from the backup files!
- {{{
- $ cd <PROJECT_DIRECTORY>
- $ source venv/bin/activate
- $ rm db.sqlite3
- $ rm -rf data/pages data/media
- $ python manage.py migrate
- $ python manage.py loaddata pages.json
- $ tar -xvzf pages.tgz
- }}}
- """))
-
- help_pages = {
- 'main': MAIN,
- 'creole': CREOLE,
- 'access': ACCESS,
- 'search': SEARCH,
- 'backup': BACKUP
- }
-
-
- def actionbar(context, request, current_help_page=None, **kwargs):
- actionbar_entries = (
- ('1', 'Main'),
- ('2', 'Creole'),
- ('3', 'Access'),
- ('4', 'Search'),
- ('5', 'Backup'),
- )
- for num, name in actionbar_entries:
- context[context.ACTIONBAR].append_entry(
- HELP_UID + '-%s' % name.lower(), # uid
- _(name), # name
- color_icon_url(request, num + '.png'), # icon
- pages.url_helpview(name.lower()), # url
- True, # left
- name.lower() == current_help_page, # active
- )
|