mirror of
https://github.com/jrnl-org/jrnl.git
synced 2025-05-10 16:48:31 +02:00
* update copyright symbols to unicode * clean up version screen/copyright notice * small change to make commands more similar * update imports to appease isort * fix test * update one more file merged since PR was open
158 lines
4.8 KiB
Python
158 lines
4.8 KiB
Python
# Copyright © 2012-2022 jrnl contributors
|
|
# License: https://www.gnu.org/licenses/gpl-3.0.html
|
|
|
|
import glob
|
|
import logging
|
|
import os
|
|
import sys
|
|
|
|
from jrnl.config import DEFAULT_JOURNAL_KEY
|
|
from jrnl.config import get_config_path
|
|
from jrnl.config import get_default_config
|
|
from jrnl.config import get_default_journal_path
|
|
from jrnl.config import load_config
|
|
from jrnl.config import save_config
|
|
from jrnl.config import verify_config_colors
|
|
from jrnl.exception import JrnlException
|
|
from jrnl.messages import Message
|
|
from jrnl.messages import MsgStyle
|
|
from jrnl.messages import MsgText
|
|
from jrnl.output import print_msg
|
|
from jrnl.path import absolute_path
|
|
from jrnl.path import expand_path
|
|
from jrnl.path import home_dir
|
|
from jrnl.prompt import yesno
|
|
from jrnl.upgrade import is_old_version
|
|
|
|
|
|
def upgrade_config(config_data, alt_config_path=None):
|
|
"""Checks if there are keys missing in a given config dict, and if so, updates the config file accordingly.
|
|
This essentially automatically ports jrnl installations if new config parameters are introduced in later
|
|
versions.
|
|
Supply alt_config_path if using an alternate config through --config-file."""
|
|
default_config = get_default_config()
|
|
missing_keys = set(default_config).difference(config_data)
|
|
if missing_keys:
|
|
for key in missing_keys:
|
|
config_data[key] = default_config[key]
|
|
save_config(config_data, alt_config_path)
|
|
config_path = alt_config_path if alt_config_path else get_config_path()
|
|
print_msg(
|
|
Message(
|
|
MsgText.ConfigUpdated, MsgStyle.NORMAL, {"config_path": config_path}
|
|
)
|
|
)
|
|
|
|
|
|
def find_default_config():
|
|
config_path = (
|
|
get_config_path()
|
|
if os.path.exists(get_config_path())
|
|
else os.path.join(home_dir(), ".jrnl_config")
|
|
)
|
|
return config_path
|
|
|
|
|
|
def find_alt_config(alt_config):
|
|
if not os.path.exists(alt_config):
|
|
raise JrnlException(
|
|
Message(
|
|
MsgText.AltConfigNotFound, MsgStyle.ERROR, {"config_file": alt_config}
|
|
)
|
|
)
|
|
|
|
return alt_config
|
|
|
|
|
|
def load_or_install_jrnl(alt_config_path):
|
|
"""
|
|
If jrnl is already installed, loads and returns a default config object.
|
|
If alternate config is specified via --config-file flag, it will be used.
|
|
Else, perform various prompts to install jrnl.
|
|
"""
|
|
config_path = (
|
|
find_alt_config(alt_config_path) if alt_config_path else find_default_config()
|
|
)
|
|
|
|
if os.path.exists(config_path):
|
|
logging.debug("Reading configuration from file %s", config_path)
|
|
config = load_config(config_path)
|
|
|
|
if config is None:
|
|
raise JrnlException(
|
|
Message(
|
|
MsgText.CantParseConfigFile,
|
|
MsgStyle.ERROR,
|
|
{
|
|
"config_path": config_path,
|
|
},
|
|
)
|
|
)
|
|
|
|
if is_old_version(config_path):
|
|
from jrnl import upgrade
|
|
|
|
upgrade.upgrade_jrnl(config_path)
|
|
|
|
upgrade_config(config, alt_config_path)
|
|
verify_config_colors(config)
|
|
|
|
else:
|
|
logging.debug("Configuration file not found, installing jrnl...")
|
|
config = install()
|
|
|
|
logging.debug('Using configuration "%s"', config)
|
|
return config
|
|
|
|
|
|
def install():
|
|
_initialize_autocomplete()
|
|
|
|
# Where to create the journal?
|
|
default_journal_path = get_default_journal_path()
|
|
user_given_path = print_msg(
|
|
Message(
|
|
MsgText.InstallJournalPathQuestion,
|
|
MsgStyle.PROMPT,
|
|
params={
|
|
"default_journal_path": default_journal_path,
|
|
},
|
|
),
|
|
get_input=True,
|
|
)
|
|
journal_path = absolute_path(user_given_path or default_journal_path)
|
|
default_config = get_default_config()
|
|
default_config["journals"][DEFAULT_JOURNAL_KEY] = journal_path
|
|
|
|
# If the folder doesn't exist, create it
|
|
path = os.path.split(default_config["journals"][DEFAULT_JOURNAL_KEY])[0]
|
|
try:
|
|
os.makedirs(path)
|
|
except OSError:
|
|
pass
|
|
|
|
# Encrypt it?
|
|
encrypt = yesno(Message(MsgText.EncryptJournalQuestion), default=False)
|
|
if encrypt:
|
|
default_config["encrypt"] = True
|
|
print_msg(Message(MsgText.JournalEncrypted, MsgStyle.NORMAL))
|
|
|
|
save_config(default_config)
|
|
return default_config
|
|
|
|
|
|
def _initialize_autocomplete():
|
|
# readline is not included in Windows Active Python and perhaps some other distributions
|
|
if sys.modules.get("readline"):
|
|
import readline
|
|
|
|
readline.set_completer_delims(" \t\n;")
|
|
readline.parse_and_bind("tab: complete")
|
|
readline.set_completer(_autocomplete_path)
|
|
|
|
|
|
def _autocomplete_path(text, state):
|
|
expansions = glob.glob(expand_path(text) + "*")
|
|
expansions = [e + "/" if os.path.isdir(e) else e for e in expansions]
|
|
expansions.append(None)
|
|
return expansions[state]
|