2017-08-30 05:52:24 +00:00
|
|
|
"""TODO"""
|
2017-08-30 06:27:09 +00:00
|
|
|
import os
|
2017-08-29 07:33:03 +00:00
|
|
|
import sys
|
2017-08-30 05:52:24 +00:00
|
|
|
from os.path import expanduser
|
2017-08-30 06:27:09 +00:00
|
|
|
from os.path import exists as path_exists
|
|
|
|
from os.path import join as path_join
|
2017-08-29 07:33:03 +00:00
|
|
|
|
|
|
|
import click
|
2017-08-30 05:52:24 +00:00
|
|
|
import pygit2
|
|
|
|
from click.types import Path
|
|
|
|
|
|
|
|
# TODO support reading from env
|
|
|
|
SITE_NAME = 'tilde.town'
|
|
|
|
PUBLISH_PATH = '/var/www/{site_name}/wiki'.format(site_name=SITE_NAME)
|
|
|
|
PREVIEW_PATH = expanduser('~/public_html/wiki')
|
|
|
|
LOCAL_REPOSITORY_PATH = expanduser('~/wiki')
|
|
|
|
REPOSITORY_PATH = '/wiki'
|
|
|
|
|
|
|
|
PATH_TYPE_KWARGS = dict(
|
|
|
|
exists=True,
|
|
|
|
writable=True,
|
|
|
|
readable=True,
|
|
|
|
file_okay=False,
|
2017-08-30 06:27:09 +00:00
|
|
|
dir_okay=True)
|
|
|
|
|
|
|
|
class GitRepo(Path):
|
|
|
|
name = 'git repository'
|
|
|
|
|
|
|
|
def convert(self, value, param, ctx):
|
|
|
|
path = super().convert(value, param, ctx)
|
|
|
|
if not path_exists(path_join(path, '.git')):
|
|
|
|
self.fail('No .git directory found in {}'.format(path))
|
|
|
|
|
|
|
|
return path
|
|
|
|
|
|
|
|
|
|
|
|
class WikiRepo(GitRepo):
|
|
|
|
name = 'wiki repository'
|
|
|
|
|
|
|
|
def convert(self, value, param, ctx):
|
|
|
|
path = super().convert(value, param, ctx)
|
|
|
|
|
|
|
|
if not path_exists(path_join(path, 'src/articles')):
|
|
|
|
self.fail(
|
|
|
|
'{} does not appear to be a wiki repository; missing src/articles.'.format(
|
|
|
|
path))
|
|
|
|
|
|
|
|
return path
|
|
|
|
|
2017-08-30 05:52:24 +00:00
|
|
|
|
|
|
|
class Config:
|
|
|
|
def __init__(self):
|
|
|
|
self.site_name = SITE_NAME
|
|
|
|
self.publish_path = PUBLISH_PATH
|
|
|
|
self.preview_path = PREVIEW_PATH
|
|
|
|
self.local_repo_path = LOCAL_REPOSITORY_PATH
|
|
|
|
self.repo_path = REPOSITORY_PATH
|
|
|
|
|
|
|
|
pass_config = click.make_pass_decorator(Config, ensure=True)
|
|
|
|
|
|
|
|
@click.group()
|
|
|
|
@click.option('--site-name', default=SITE_NAME, help='The root domain of the wiki.')
|
|
|
|
@click.option('--publish-path',
|
|
|
|
default=PUBLISH_PATH,
|
|
|
|
help='System level path to wiki for publishing.',
|
|
|
|
type=Path(**PATH_TYPE_KWARGS))
|
|
|
|
@click.option('--preview-path',
|
|
|
|
default=PREVIEW_PATH,
|
|
|
|
help='Local path to wiki for previewing.',
|
|
|
|
type=Path(**PATH_TYPE_KWARGS))
|
|
|
|
@click.option('--local-repo-path',
|
|
|
|
default=LOCAL_REPOSITORY_PATH,
|
|
|
|
help='Path to shared wiki git repository.',
|
2017-08-30 06:27:09 +00:00
|
|
|
type=WikiRepo(**PATH_TYPE_KWARGS))
|
2017-08-30 05:52:24 +00:00
|
|
|
@click.option('--repo-path',
|
|
|
|
default=REPOSITORY_PATH,
|
|
|
|
help='Path to your clone of the shared git repository.',
|
2017-08-30 06:27:09 +00:00
|
|
|
type=WikiRepo(**PATH_TYPE_KWARGS))
|
2017-08-30 05:52:24 +00:00
|
|
|
@pass_config
|
|
|
|
def main(config, site_name, publish_path, preview_path,
|
|
|
|
local_repo_path, repo_path):
|
2017-08-30 06:27:09 +00:00
|
|
|
# TODO click does not appear to call expanduser on things. it'd be nice to
|
|
|
|
# opt into that with the Path type. Should click be patched? Or should we
|
|
|
|
# use a custom Path type?
|
2017-08-30 05:52:24 +00:00
|
|
|
config.site_name = site_name
|
|
|
|
config.publish_path = publish_path
|
|
|
|
config.preview_path = preview_path
|
|
|
|
config.local_repo_path = local_repo_path
|
|
|
|
config.repo_path = repo_path
|
2017-08-29 07:33:03 +00:00
|
|
|
|
2017-08-30 05:52:24 +00:00
|
|
|
@main.command()
|
|
|
|
@pass_config
|
|
|
|
def init(config):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@main.command()
|
|
|
|
@pass_config
|
|
|
|
def preview(config):
|
2017-08-30 06:27:09 +00:00
|
|
|
click.echo('SUP')
|
2017-08-30 05:52:24 +00:00
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@main.command()
|
|
|
|
@pass_config
|
|
|
|
def publish(config):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@main.command()
|
|
|
|
@pass_config
|
|
|
|
def get(config):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@main.command()
|
|
|
|
@pass_config
|
|
|
|
def reset(config):
|
|
|
|
raise NotImplementedError()
|