summaryrefslogtreecommitdiff
path: root/km-package-install
blob: ea43a71fee92c6013dfa535ac83836cd06221674 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#!/usr/bin/python3

import argparse
import logging
import sys
import os
from keyman_config import __version__

import datetime
import time

def get_languages():
	import json
	import requests
	import requests_cache
	from keyman_config.get_kmp import keyman_cache_dir

	logging.info("Getting language list from search")
	api_url = "https://api.keyman.com/search?q=l:*&platform=linux"
	logging.debug("At URL %s", api_url)
	cache_dir = keyman_cache_dir()
	current_dir = os.getcwd()
	expire_after = datetime.timedelta(days=7)
	if not os.path.isdir(cache_dir):
		os.makedirs(cache_dir)
	os.chdir(cache_dir)
	requests_cache.install_cache(cache_name='keyman_cache', backend='sqlite', expire_after=expire_after)
	now = time.ctime(int(time.time()))
	try:
		response = requests.get(api_url)
		logging.debug("Time: {0} / Used Cache: {1}".format(now, response.from_cache))
		os.chdir(current_dir)
		requests_cache.core.uninstall_cache()
		if response.status_code == 200:
			return response.json()
		else:
			return None
	except:
		return None

def get_keyboard_list():
	languages = get_languages()
	keyboards = []
	if "languages" in languages:
		for lang in languages["languages"]:
			if "keyboards" in lang:
				for kb in lang["keyboards"]:
					kbnospace = kb.replace(" ", "%20")
					if kbnospace not in keyboards:
						keyboards.append(kbnospace)
	if keyboards:
		keyboards.sort()
	return keyboards

def write_kmpdirlist(kmpdirfile):
	with open(kmpdirfile, 'wt') as kmpdirlist:
		keyboards = get_keyboard_list()
		if keyboards:
			for kb in get_keyboard_list():
				print(kb, file=kmpdirlist)

def list_keyboards():
	from keyman_config.get_kmp import keyman_cache_dir
	kmpdirfile = os.path.join(keyman_cache_dir(), 'kmpdirlist')
	if not os.path.exists(kmpdirfile):
		write_kmpdirlist(kmpdirfile)
	else:
		logging.debug("kmpdirlist already exists")
		# file empty
		if os.path.getsize(kmpdirfile) == 0:
			write_kmpdirlist(kmpdirfile)

def main():
	parser = argparse.ArgumentParser(description='Install a Keyman keyboard package, either a local .kmp file or specify a keyboard id to download and install')
	parser.add_argument('-s', '--shared', action='store_true', help='Install to shared area /usr/local')
	parser.add_argument('-f', '--file', metavar='<kmpfile>', help='Keyman kmp file')
	parser.add_argument('-p', '--package', metavar='<packageID>', help='Keyman package id')
	parser.add_argument('--version', action='version', version='%(prog)s version '+__version__)
	parser.add_argument('-v', '--verbose', action='store_true', help='verbose logging')
	parser.add_argument('-vv', '--veryverbose', action='store_true', help='very verbose logging')

	args = parser.parse_args()
	if args.verbose:
		logging.basicConfig(level=logging.INFO, format='%(levelname)s:%(message)s')
	elif args.veryverbose:
		logging.basicConfig(level=logging.DEBUG, format='%(levelname)s:%(message)s')
	else:
		logging.basicConfig(format='%(levelname)s:%(message)s')

	if args.package and args.file:
		logging.error("km-package-install: error: too many arguments: either install a local kmp file or specify a keyboard id to download and install.")
		sys.exit(2)

	from keyman_config.install_kmp import install_kmp, InstallError, InstallStatus
	from keyman_config.list_installed_kmp import get_kmp_version
	from keyman_config.get_kmp import get_keyboard_data, get_kmp, keyman_cache_dir

	if os.path.exists(os.path.join(keyman_cache_dir(), 'kmpdirlist')):
		os.remove(os.path.join(keyman_cache_dir(), 'kmpdirlist'))


	def try_install_kmp(inputfile, arg, online=False, sharedarea=False):
		try:
			install_kmp(inputfile, online, sharedarea)
		except InstallError as e:
			if e.status == InstallStatus.Abort:
				logging.error("km-package-install: error: Failed to install %s", arg)
				logging.error(e.message)
				sys.exit(3)
			else:
				logging.warning(e.message)

	if args.file:
		name, ext = os.path.splitext(args.file)
		if ext != ".kmp":
			logging.error("km-package-install: Input file %s is not a kmp file.", args.file)
			logging.error("km-package-install -f <kmpfile>")
			sys.exit(2)

		if not os.path.isfile(args.file):
			logging.error("km-package-install: Keyman kmp file %s not found.", args.file)
			logging.error("km-package-install -f <kmpfile>")
			sys.exit(2)
		try_install_kmp(args.file, "file " + args.file, False, args.shared)
	elif args.package:
		installed_kmp_ver = get_kmp_version(args.package)
		kbdata = get_keyboard_data(args.package)
		if not kbdata:
			logging.error("km-package-install: error: Could not download keyboard data for %s", args.package)
			sys.exit(3)
		if installed_kmp_ver:
			if kbdata['version'] == installed_kmp_ver:
				logging.error("km-package-install: The %s version of the %s keyboard package is already installed.", installed_kmp_ver, args.package)
				sys.exit(1)
			elif float(kbdata['version']) > float(installed_kmp_ver):
				logging.error("km-package-install: A newer version of %s keyboard package is available. Uninstalling old version %s then downloading and installing new version %s.", args.package, installed_kmp_ver, kbdata['version'])
				uninstall_kmp(args.package, args.shared)

		kmpfile = get_kmp(args.package)
		if kmpfile:
			try_install_kmp(kmpfile, "keyboard package " + args.package, True, args.shared)
		else:
			logging.error("km-package-install: error: Could not download keyboard package %s", args.package)
			sys.exit(2)
	else:
		logging.error("km-package-install: error: no arguments: either install a local kmp file or specify a keyboard package id to download and install.")
		sys.exit(2)



if __name__ == "__main__":
	main()