Current File : //usr/bin/systemd-sysv-convert
#!/usr/bin/python
# -*- Mode: Python; python-indent: 8; indent-tabs-mode: t -*-

import sys, os, argparse, errno

def find_service(service, runlevel):
	priority = -1

	for l in os.listdir("/etc/rc%i.d" % runlevel):
		if len(l) < 4:
			continue

		if l[0] != 'S' or l[3:] != service:
			continue

		p = int(l[1:3])

		if p >= 0 and p <= 99 and p >= priority:
			priority = p;

	return priority

def lookup_database(services):
	try:
		database = open("/var/lib/systemd/sysv-convert/database", "r")
	except IOError, e:
		if e.errno != errno.ENOENT:
			raise e

		return {}

	found = {}
	k = 0

	for line in database:
		service, r, p = line.strip().split("\t", 3)
		k += 1

		try:
			runlevel = int(r)
			priority = int(p)
		except ValueError, e:
			sys.stderr.write("Failed to parse database line %i. Ignoring." % k)
			continue

		if runlevel not in (2, 3, 4, 5):
			sys.stderr.write("Runlevel out of bounds in database line %i. Ignoring." % k)
			continue

		if priority < 0 or priority > 99:
			sys.stderr.write("Priority out of bounds in database line %i. Ignoring." % k)
			continue

		if service not in services:
			continue

		if service not in found:
			found[service] = {}

		if runlevel not in found[service] or found[service][runlevel] < priority:
			found[service][runlevel] = priority

	return found

def mkdir_p(path):
	try:
		os.makedirs(path, 0755)
	except OSError, e:
		if e.errno != errno.EEXIST:
			raise e

if os.geteuid() != 0:
	sys.stderr.write("Need to be root.\n")
	sys.exit(1)

parser = argparse.ArgumentParser(description='Save and Restore SysV Service Runlevel Information')

parser.add_argument('services', metavar='SERVICE', type=str, nargs='+',
		    help='Service names')

parser.add_argument('--save', dest='save', action='store_const',
		    const=True, default=False,
		    help='Save SysV runlevel information for one or more services')

parser.add_argument('--show', dest='show', action='store_const',
		    const=True, default=False,
		    help='Show saved SysV runlevel information for one or more services')

parser.add_argument('--apply', dest='apply', action='store_const',
		    const=True, default=False,
		    help='Apply saved SysV runlevel information for one or more services to systemd counterparts')

a = parser.parse_args()

if a.save:
	for service in a.services:
		if not os.access("/etc/rc.d/init.d/%s" % service, os.F_OK):
			sys.stderr.write("SysV service %s does not exist.\n" % service)
			sys.exit(1)

	mkdir_p("/var/lib/systemd/sysv-convert")
	database = open("/var/lib/systemd/sysv-convert/database", "a")

	for runlevel in (2, 3, 4, 5):
		priority = find_service(service, runlevel)

		if priority >= 0:
			database.write("%s\t%s\t%s\n" % (service, runlevel, priority))

elif a.show:
	found = lookup_database(a.services)

	if len(found) <= 0:
		sys.stderr.write("No information about passed services found.\n")
		sys.exit(1)

	for service, data in found.iteritems():
		for runlevel, priority in data.iteritems():
			sys.stdout.write("SysV service %s enabled in runlevel %s at priority %s\n" % (service, runlevel, priority))

elif a.apply:
	for service in a.services:
		if not os.access("/lib/systemd/system/%s.service" % service, os.F_OK):
			sys.stderr.write("systemd service %s.service does not exist.\n" % service)
			sys.exit(1)

	found = lookup_database(a.services)

	if len(found) <= 0:
		sys.stderr.write("No information about passed services found.\n")
		sys.exit(1)

	for service, data in found.iteritems():
		for runlevel in data.iterkeys():

			sys.stderr.write("ln -sf /lib/systemd/system/%s.service /etc/systemd/system/runlevel%i.target.wants/%s.service\n" % (service, runlevel, service))

			mkdir_p("/etc/systemd/system/runlevel%i.target.wants" % runlevel)

			try:
				os.symlink("/lib/systemd/system/%s.service" % service,
					   "/etc/systemd/system/runlevel%i.target.wants/%s.service" % (runlevel, service))
			except OSError, e:
				if e.errno != errno.EEXIST:
					raise e

else:
	parser.print_help()
blog

blog

1win официальный сайт букмекера — Обзор и зеркало для входа.793

1win официальный сайт букмекера — Обзор и зеркало для входа ▶️ ИГРАТЬ Содержимое 1вин: Официальный сайт букмекера – Обзор и зеркало для входа Официальный сайт 1вин Преимущества официального сайта 1вин Зеркало для входа 1win Официальный Сайт Букмекера Обзор и Зеркало для Входа Преимущества 1вин Зеркало для входа Преимущества и Недостатки …

Read More »

1Win официальный сайт букмекера — 1Вин ставки на спорт.5124

1Win официальный сайт букмекера — 1Вин ставки на спорт ▶️ ИГРАТЬ Содержимое 1Win – Официальный Сайт Букмекера Преимущества и Функции 1Win Как сделать Ставку на Спорт Шаг 2: Выберите Матч Бонусы и Акции 1Вин Отзывы и Рейтинг Преимущества 1вин В мире ставок на спорт есть много букмекеров, но не все …

Read More »

1win — букмекерская контора 1вин.4455

1win — букмекерская контора 1вин ▶️ ИГРАТЬ Содержимое 1win – Букмекерская контора 1вин Преимущества 1win О компании 1win Преимущества для игроков Удобство и доступность Большой выбор ставок на спорт Выгодные условия для игроков Виды ставок и коэффициенты Основные виды ставок Коэффициенты в 1win Бонусы и акции 1win Отзывы и оценки …

Read More »

1win официальный сайт букмекера — Обзор и зеркало для входа.946

1win официальный сайт букмекера — Обзор и зеркало для входа ▶️ ИГРАТЬ Содержимое 1win Официальный Сайт Букмекера Обзор и Зеркало для Входа Преимущества и Функции 1win Функции 1win: Как Зарегистрироваться и Начать Играть на 1win Безопасность и Надежность В мире ставок и азарта 1win является одним из самых популярных букмекеров, …

Read More »

1win — скачать приложение букмекерской конторы.1701

1win — скачать приложение букмекерской конторы ▶️ ИГРАТЬ Содержимое Установка и регистрация 1win apk Регистрация на 1win Основные функции и преимущества 1win В мире ставок и азарта 1win является одним из самых популярных букмекеров. Компания была основана в 2018 году и с тех пор стала одним из лидеров на рынке. …

Read More »

1win — официальный сайт букмекерской конторы 1вин.4184 (2)

1win — официальный сайт букмекерской конторы 1вин ▶️ ИГРАТЬ Содержимое 1win – Официальный Сайт Букмекерской Конторы 1вин Оформление и Дизайн 1win Функциональность и Инструменты 1win Анализ игроков и команд Бонусы и Промокоды 1вин Промокоды для постоянных клиентов Безопасность и Надежность Отзывы и Рейтинг В мире ставок и азарта 1win – …

Read More »

1win официальный сайт букмекера — Обзор и зеркало для входа.450

1win официальный сайт букмекера — Обзор и зеркало для входа ▶️ ИГРАТЬ Содержимое 1win Официальный Сайт Букмекера Преимущества Официального Сайта 1вин Зеркало для входа Обзор и Зеркало для Входа Преимущества 1win Зеркало для Входа Преимущества и Функции 1win Удобство и доступность В мире ставок и азарта 1win является одним из …

Read More »

1win официальный сайт букмекера — Обзор и зеркало для входа.477

1win официальный сайт букмекера — Обзор и зеркало для входа ▶️ ИГРАТЬ Содержимое 1win Официальный Сайт Букмекера Преимущества 1win Обзор и Зеркало для Входа Преимущества 1вин Зеркало для Входа В мире ставок и азарта 1вин является одним из самых популярных букмекеров, предлагающих широкий спектр услуг для игроков. В этой статье …

Read More »

1win — официальный сайт букмекерской конторы 1вин.3301

1win — официальный сайт букмекерской конторы 1вин ▶️ ИГРАТЬ Содержимое Официальный сайт букмекерской конторы 1вин Быстрый доступ к ставкам и линиям Преимущества быстрого доступа Преимущества и функции официального сайта 1вин Функции официального сайта 1вин: В мире ставок и азарта 1вин – это имя, которое ассоциируется с надежностью, быстротой и комфортом. …

Read More »

1win — скачать приложение букмекерской конторы.534

1win — скачать приложение букмекерской конторы ▶️ ИГРАТЬ Содержимое Установка приложения 1win Функциональность приложения 1win Главные функции Преимущества использования приложения 1win Как скачать приложение 1win Шаг 1: Установка 1win apk Шаг 2: Установка 1win на ваше устройство Шаг 3: Регистрация и вход в приложение 1win В мире ставок и азарта …

Read More »