/* SPDX-License-Identifier: GPL-3.0-only
 *
 * Copyright (C) 2024 asvow
 */
'use strict';
'require form';
'require fs';
'require poll';
'require rpc';
'require uci';
'require view';
var callServiceList = rpc.declare({
	object: 'service',
	method: 'list',
	params: ['name'],
	expect: { '': {} }
});
function getServiceStatus() {
	return L.resolveDefault(callServiceList('tailscale'), {}).then(function (res) {
		var isRunning = false;
		try {
			isRunning = res['tailscale']['instances']['instance1']['running'];
		} catch (e) { }
		return isRunning;
	});
}
function getLoginStatus() {
	return fs.exec("/usr/sbin/tailscale", ["status"]).then(function(res) {
		if (res.stdout.includes("Logged out"))
			return false;
		else
			return true;
	});
}
function renderStatus(isRunning) {
	var spanTemp = '%s %s';
	var renderHTML;
	if (isRunning) {
		renderHTML = String.format(spanTemp, 'green', _('Tailscale'), _('RUNNING'));
	} else {
		renderHTML = String.format(spanTemp, 'red', _('Tailscale'), _('NOT RUNNING'));
	}
	return renderHTML;
}
function renderLogin(isLoggedIn) {
	var spanTemp = '%s %s';
	var renderHTML;
	if (isLoggedIn) {
		renderHTML = String.format(spanTemp, 'green', _('Logged'), _('IN'));
	} else {
		renderHTML = String.format(spanTemp, 'red', _('Logged'), _('OUT'));
	}
	return renderHTML;
}
return view.extend({
	load: function() {
		return Promise.all([
			uci.load('tailscale')
		]);
	},
	render: function(data) {
		var m, s, o;
		m = new form.Map('tailscale', _('Tailscale'),
			_('Tailscale is a cross-platform and easy to use virtual LAN.'));
		s = m.section(form.TypedSection);
		s.anonymous = true;
		s.render = function () {
			poll.add(function () {
				return L.resolveDefault(getServiceStatus()).then(function (res) {
					var view = document.getElementById("service_status");
					view.innerHTML = renderStatus(res);
				});
			});
			return E('div', { class: 'cbi-section', id: 'status_bar' }, [
					E('p', { id: 'service_status' }, _('Collecting data ...'))
			]);
		}
		s = m.section(form.NamedSection, 'settings', 'config');
		o = s.option(form.Flag, 'enabled', _('Enable'));
		o.default = o.disabled;
		o.rmempty = false;
		
		o = s.option(form.DummyValue, 'login_status', _('Login Status'));
		o.depends('enabled', '1');
		o.renderWidget = function(section_id, option_id) {
			poll.add(function() {
				return L.resolveDefault(getLoginStatus()).then(function(res) {
					document.getElementById('login_status_div').innerHTML = renderLogin(res);
				});
			});
	
			return E('div', { 'id': 'login_status_div' }, _('Collecting data ...'));
		};
		return m.render();
	}
});