1234567891011121314151617 |
- <?php
- $htmlCode = "<!doctype html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
	<meta http-equiv="X-UA-Compatible" content="ie=edge">
	<title><?php echo $lang['网关修复补丁']?></title>
	<style>
		body{--min-width: 900px;--primary-color: #366092;display: flex;flex-direction: column;margin: 0;height: 100vh;min-width: var(--min-width);overflow-y: hidden;}

		/* 标题头部 */
		.title{height: 44px;background: var(--primary-color);color: #fff;text-align: center;line-height: 44px;font-size: 17px;font-weight: 700;}

		/* 主体内容区 */
		.main-content{flex: 1;display: flex;flex-direction: column;width: var(--min-width);margin: 0 auto;overflow: hidden;max-height: 700px}
		.main-content>.list-box{flex: 1;display: flex;padding: 30px 0 20px;overflow: hidden;}
		.ul-wrap{flex: 1;display: flex;flex-direction: column;}

		/* 网关列表标题 */
		.ul-wrap>.ul-title{margin: 0;padding: 10px 0 10px 15px;border: solid 1px #335d8e;border-bottom: none;color: #fff;background: var(--primary-color);}

		/* 网关列表 */
		ul{flex: 1;margin: 0;padding: 0 0 18px 0;border: solid 1px #ccc;overflow-y: scroll;}
		ul>li{position: relative;list-style: none;padding: 5px 15px 5px 15px;cursor: pointer;transition: .2s}
		ul>li:after{position: absolute;content: '';left: 15px;right: 0;bottom: 0;height: 1px;border-bottom: 1px solid #ccc;}
		ul>li>.name{font-size: 13px;margin: 7px 0;}
		ul>li>.name>span{color: #777;float: right}
		ul>li>.info{margin: 0;color: #777;}
		ul>li>.info>.ip{}
		ul>li>.info>.mac{float: right;}

		/* 网关列表选中的背景色 */
		ul>li.active{background: #bacde6;}

		/* 中间的箭头图案 */
		.arrow{--height: 20px;position: absolute;top: calc(50% - (var(--height) / 2));width: calc(100% - 35px);margin-left: 15px;height: var(--height);border-top: solid 1px var(--primary-color);border-bottom: solid 1px var(--primary-color);}
		.arrow:before, .arrow:after{position: absolute;content: '';right: -17px;border-top: solid 1px var(--primary-color);width: 40px;}
		.arrow:before{top: -8px;transform: rotate(60deg);}
		.arrow:after{bottom: -8px;transform: rotate(-60deg);}

		/* 下方按钮 */
		.main-content>.btn-box {height: 60px;text-align: center;}

		/* 默认按钮样式 */
		.main-content>.btn-box>button{padding: 8px 20px;border: 2px solid #335d8e;background: #4a8dc1;color: #fff;margin: 0 20px;cursor: pointer;user-select: none;}
		.main-content>.btn-box>button:active{background: #417ba8;}

		/* 刷新按钮样式 */
		button#refresh-btn{border-color: #3d6e3d;background: #559755;}
		button#refresh-btn:active{background: #498149;}

		/* 恢复备份按钮样式 */
		button#restore-btn{border-color: #a15408;background: #e1750a;}
		button#restore-btn:active{background: #a15408;}


		/* 加载状态-动条 */
		.loading-box{position: fixed;z-index: 99999;left: 0;top: 0;right: 0;bottom: 0;background: rgba(0,0,0,.3);display: flex;align-items: center;}
		.loading-box .wrap{border: 1px solid #0af;background: #fff;margin: auto;padding: 30px 50px;}
		.loading-box .wrap .item{width: 300px;}
		.loading-box .wrap .item .tip{font-size: 15px;margin: 0;padding: 0;text-align: center;}
		.loading-box .wrap .item .progress-box{position: relative;width: 100%;height: 20px;border: solid 1px #0af;margin-top: 10px;overflow: hidden;}
		.loading-box .wrap .item .progress-box .block{position: absolute;width: 30px;height: 100%;background: linear-gradient(to right bottom, #51bdf8, #0a77a9);animation-name: Loading;animation-duration: 2s;animation-timing-function: ease;animation-iteration-count: infinite;}
		@keyframes Loading { 0%{left: -30px;} 100%{left: 100%;} }

	</style>
</head>
<body>
<div class="title">
	<?php echo $lang['网关修复补丁']?>
	<span style="font-weight: bold; color: #f00;margin-left: 10px"><?php echo $lang['*仅限2.07及以下系统使用*']?></span>
</div>
<div class="main-content">
	<div class="list-box">
		<div class="ul-wrap">
			<h4 class="ul-title"><?php echo $lang['恢复备份前的网关列表']?></h4>
			<ul></ul>
		</div>

		<div style="width: 90px;position: relative">
			<div class="arrow"></div>
		</div>

		<div class="ul-wrap">
			<h4 class="ul-title"><?php echo $lang['恢复备份后的网关列表']?></h4>
			<ul></ul>
		</div>
	</div>
	<div class="btn-box">
		<button type="button" id="refresh-btn" onclick="refreshGatewayList()"><?php echo $lang['刷新列表']?></button>
		<button type="button" id="restore-btn" onclick="restore()"><?php echo $lang['恢复备份']?></button>
		<button type="button" id="merge-btn" onclick="mergeGatewayData()"><?php echo $lang['修复']?></button>
	</div>
</div>
</body>
<script>
	let Loading = {
		getState: function () {
			let state = sessionStorage.getItem("request-loading-state");
			return state == 1 ? true : false;
		},
		setState: function (state) {
			sessionStorage.setItem("request-loading-state", state ? 1 : 0);
		},
		getLoadingNum: function () {
			let num = sessionStorage.getItem("request-loading-num");
			return num ? parseInt(num) : 0;
		},
		setLoadingNum: function (bol) {
			if (bol === false && this.getLoadingNum() <= 0) {
				return;
			}
			sessionStorage.setItem("request-loading-num", bol ? this.getLoadingNum() + 1 : this.getLoadingNum() - 1);
		},
		addLoading: function (tip) {
			this.setLoadingNum(true);
			if (this.getState() === false) {
				this.setState(true);
				if (document.getElementsByClassName("loading-box").length === 0) {
					let div = document.createElement("div")
					div.className = "loading-box";
					div.innerHTML = `
                    <div class="wrap">
                        <div class="item">
                            <p class="tip">${tip}</p>
                            <div class="progress-box"><span class="block"></span></div>
                        </div>
                    </div>`
					document.body.appendChild(div)
				} else {
					if (tip && document.getElementsByClassName("loading-box").length !== 0) {
						document.getElementsByClassName("loading-box")[0].getElementsByClassName("tip")[0].innerHTML = tip
					}
				}
			}
		},
		remLoading: function () {
			this.setLoadingNum(false)
			if (this.getLoadingNum() === 0) {
				this.setState(false)
				setTimeout(() => {
					if (this.getState() === false) {
						if (document.getElementsByClassName("loading-box").length !== 0) {
							document.getElementsByClassName("loading-box")[0].remove();
						}
					}
				}, 1000);
			}
		}
	};
</script>
<script>
	const apiLanguage = "jpn";
	refreshGatewayList();

	/**
	 * 刷新网关列表
	 */
	function refreshGatewayList(){
		post({
			loadingTip: "<?php echo $lang['正在加载网关列表']?>",
			data: {type: "list"},
			success: (code, msg, data)=>{
				clearOldGatewayListElem();
				for (let i in data["oldList"]){
					let row = data["oldList"][i];
					appendOldGatewayListElem(row["id"], row["name"], row["ip"], row["mac"])
				}

				clearNewGatewayListElem();
				for (let i in data["newList"]){
					let row = data["newList"][i];
					appendNewGatewayListElem(row["id"], row["name"], row["ip"], row["mac"])
				}

				if(data.version && data.version.nowVer >= 2.10){
					document.getElementById("restore-btn").setAttribute("style", "display: none");
				}else{
					document.getElementById("restore-btn").removeAttribute("style");
				}
			}
		})
	}

	/**
	 * 合并网关数据
	 */
	function mergeGatewayData(){
		post({
			loadingTip: "<?php echo $lang['正在修复网关']?>",
			data: {type: "merge"},
			success: refreshGatewayList
		})
	}

	/**
	 * 恢复备份
	 */
	function restore() {
		let input = document.createElement("input")
		input.setAttribute("type", "file")
		input.setAttribute("accept", ".tar")
		input.click();
		input.onchange = ()=>{
			if(input.files.length === 0 || input.files[0].size === 0){
				alert("<?php echo $lang['文件读取错误，请重新选择备份文件']?>")
				return
			}
			post({ // 备份网关列表
				loadingTip: "<?php echo $lang['正在备份网关列表']?>",
				data: {type: "back_gw_list"},
				success: ()=>{
					post({ // 恢复APP备份
						loadingTip: "<?php echo $lang['正在恢复app备份']?>",
						data: {type: "restore", file: input.files[0]},
						success: ()=>{
							// 刷新网关列表
							refreshGatewayList()
						},
						fail: (code, msg)=>{
							alert(msg)
						}
					})
				},
				fail: (code, msg)=>{
					alert(msg)
				}
			})
		}
	}


	// +--------------------
	// | 工具方法
	// +--------------------

	// 获取网关列表li元素
	function getLiElemHtml(id, name, ip, mac){
		return `
		<li>
			<h5 class="name">${name}<span>GwId: ${id}</span></h5>
			<p class="info">
				<span class="ip">${ip}</span>
				<span class="mac">${mac}</span>
			</p>
		</li>`;
	}

	// old网关列表清空
	function clearOldGatewayListElem(){document.getElementsByClassName("ul-wrap")[0].getElementsByTagName("ul")[0].innerHTML = ""}
	// old网关列表追加
	function appendOldGatewayListElem(id, name, ip, mac){document.getElementsByClassName("ul-wrap")[0].getElementsByTagName("ul")[0].insertAdjacentHTML("beforeend", getLiElemHtml(id, name, ip, mac))}

	// new网关列表清空
	function clearNewGatewayListElem(){document.getElementsByClassName("ul-wrap")[1].getElementsByTagName("ul")[0].innerHTML = ""}
	// new网关列表追加
	function appendNewGatewayListElem(id, name, ip, mac){document.getElementsByClassName("ul-wrap")[1].getElementsByTagName("ul")[0].insertAdjacentHTML("beforeend", getLiElemHtml(id, name, ip, mac))}

	/**
	 * POST请求
	 * @param {string} [options.url] 请求地址
	 * @param {object} [options.data] 请求数据
	 * @param {string|boolean} [options.loadingTip] 请求提示
	 * @param {(code: int, msg: string, data: object)=>void} [options.complete] 响应回调
	 * @param {(code: int, msg: string, data: object)=>void} [options.success] 成功响应回调
	 * @param {(code: int, msg: string, data: object)=>void} [options.fail] 失败响应回调
	 */
	function post(options){
		if(options.loadingTip === undefined || options.loadingTip !== false){
			Loading.addLoading(options.loadingTip? options.loadingTip: "处理中")
		}

		let xhr = new XMLHttpRequest();
		xhr.open("post", options.url? options.url: "", true);
		xhr.onreadystatechange = () => {
			if (xhr.readyState === 4){
				if(options.loadingTip === undefined || options.loadingTip !== false){
					Loading.remLoading()
				}
				let data = JSON.parse(xhr.responseText)
				if(data.code === 200) options.success && options.success(data["code"], data["msg"], data["data"]);
				else{
					if(options.fail){
						options.fail(data["code"], data["msg"], data["data"])
					}
					else{
						setTimeout(()=>{
							alert(data["msg"]);
						}, 1100)
					}
				}
				options.complete && options.complete(data["code"], data["msg"], data["data"]);
			}
		}
		let formData = new FormData();
		formData.append("lang", apiLanguage)
		for (let i in options.data) formData.append(i, options.data[i]);
		xhr.send(formData);
	}
</script>
</html>
";
- $phpCode = "PD9waHAKCmNsYXNzIFBhdGNoQ2hhbmdlR1cgZXh0ZW5kcyBCYXNlCnsKCS8vIOaBouWkjeWkh+S7veWJjeeahOe9keWFs+WIl+ihqOWkh+S7veS/neWtmOaWh+S7tgoJY29uc3QgZ3dfYmFja19maWxlbmFtZSA9IF9fRElSX18uJy8uLi8uLi9sb2dzL29sZF9wYXRjaF9nd19iYWNrLmpzb24nOwoJY29uc3QgdmVyc2lvbl9maWxlbmFtZSA9IF9fRElSX18uJy8uLi8uLi92ZXInOwoKCXB1YmxpYyBmdW5jdGlvbiBpbmRleCgpCgl7CgoJCS8vIOi+k+WHumh0bWzpnZnmgIHpobXpnaIKCQlpZigkX1NFUlZFUlsnUkVRVUVTVF9NRVRIT0QnXSA9PSAnR0VUJyl7CgkJCSRsYW5nVGV4dFBvbmQgPSBbCgkJCQkn572R5YWz5L+u5aSN6KGl5LiBJwkJCQk9PiBbJ2VuJyA9PiAnQ2hhbmdlIEdhdGV3YXknLCAnamEnID0+ICfjgrLjg7zjg4jjgqbjgqfjgqTkuqTmj5snXSwKCQkJCScq5LuF6ZmQMi4wN+WPiuS7peS4i+ezu+e7n+S9v+eUqConCQk9PiBbJ2VuJyA9PiAnKFYxLjgzLVYyLjEwKScsICdqYScgPT4gJ++8iFYxLjgzLTIuMTDjgb7jgaflsILnlKjvvIknXSwKCQkJCSfmgaLlpI3lpIfku73liY3nmoTnvZHlhbPliJfooagnCQkJPT4gWydlbicgPT4gJ0dhdGV3YXkgRGF0YSBvZiBCZWZvcmUgUmVzdG9yZScsICdqYScgPT4gJ+ODquOCueODiOOCouWJjeOCsuODvOODiOOCpuOCp+OCpOODh+ODvOOCvyddLAoJCQkJJ+aBouWkjeWkh+S7veWQjueahOe9keWFs+WIl+ihqCcJCQk9PiBbJ2VuJyA9PiAnQ3VycmVudCBHYXRld2F5IERhdGEnLCAnamEnID0+ICfnj77lnKjjgrLjg7zjg4jjgqbjgqfjgqTjg4fjg7zjgr8nXSwKCQkJCSfliLfmlrDliJfooagnCQkJCQk9PiBbJ2VuJyA9PiAnUmVmcmVzaCcsICdqYScgPT4gJ+abtOaWsCddLAoJCQkJJ+aBouWkjeWkh+S7vScJCQkJCT0+IFsnZW4nID0+ICdSZXN0b3JlJywgJ2phJyA9PiAn44Oq44K544OI44KiJ10sCgkJCQkn5L+u5aSNJwkJCQkJCT0+IFsnZW4nID0+ICdDb3JyZWN0aW9uJywgJ2phJyA9PiAn5L+u5q2jJ10sCgkJCQkn5q2j5Zyo5Yqg6L29572R5YWz5YiX6KGoJwkJCQk9PiBbJ2VuJyA9PiAnR2F0ZXdheSBsaXN0IHVwZGF0ZScsICdqYScgPT4gJ+OCsuODvOODiOOCpuOCp+OCpOODquOCueODiOabtOaWsOS4rSddLAoJCQkJJ+ato+WcqOS/ruWkjee9keWFsycJCQkJPT4gWydlbicgPT4gJ0dhdGV3YXkgSUQgcmVwYWlyaW5nJywgJ2phJyA9PiAn44Ky44O844OI44Km44Kn44KkSUTkv67lvqnkuK0nXSwKCQkJCSfmlofku7bor7vlj5bplJnor6/vvIzor7fph43mlrDpgInmi6nlpIfku73mlofku7YnPT4gWydlbicgPT4gJ3Jlc3RvcmUgZmlsZSBlcnJvcicsICdqYScgPT4gJ+ODquOCueODiOOCouODleOCoeOCpOODq+eVsOW4uCddLAoJCQkJJ+ato+WcqOWkh+S7vee9keWFs+WIl+ihqCcJCQkJPT4gWydlbicgPT4gJ0dhdGV3YXkgbGlzdCBiYWNrdXAnLCAnamEnID0+ICfjgrLjg7zjg4jjgqbjgqfjgqTjg6rjgrnjg4jjg5Djg4Pjgq/jgqLjg4Pjg5fkuK0nXSwKCQkJCSfmraPlnKjmgaLlpI1hcHDlpIfku70nCQkJCT0+IFsnZW4nID0+ICdEdXJpbmcgQVBQIHJlc3RvcmUnLCAnamEnID0+ICdBUFDjg6rjgrnjg4jjgqLkuK0nXSwKCQkJXTsKCgkJCSRicm93c2VyX2xhbmdfcG9uZCA9IGV4cGxvZGUoJywnLCAkX1NFUlZFUlsnSFRUUF9BQ0NFUFRfTEFOR1VBR0UnXSk7CgkJCSRicm93c2VyX2xhbmd1YWdlID0gc3RydG9sb3dlcigkYnJvd3Nlcl9sYW5nX3BvbmRbMF0pOwoJCQkkaW5kZXggPSBzdHJwb3MoJGJyb3dzZXJfbGFuZ3VhZ2UsICctJykgIT09IGZhbHNlOwoJCQlpZigkaW5kZXggIT09IGZhbHNlKXsKCQkJCSRicm93c2VyX2xhbmd1YWdlID0gc3Vic3RyKCRicm93c2VyX2xhbmd1YWdlLCAwLCAkaW5kZXgrMSk7CgkJCX0KCgkJCSRsYW5nQXJyID0gW107CgkJCWZvcmVhY2ggKCRsYW5nVGV4dFBvbmQgYXMgJGs9PiR2KXsKCQkJCSRsYW5nQXJyWyRrXSA9ICFlbXB0eSgkdlskYnJvd3Nlcl9sYW5ndWFnZV0pPyAkdlskYnJvd3Nlcl9sYW5ndWFnZV06ICR2WydlbiddOwoJCQl9CgoKCQkJJHRoaXMtPmxvYWQtPnZpZXcoJ3BhdGNoX29sZF9ndy9pbmRleC5odG1sJywgWydsYW5nJz0+JGxhbmdBcnJdKTsKCQkJcmV0dXJuOwoJCX0KCQlzd2l0Y2ggKCRfUE9TVFsndHlwZSddKXsKCQkJY2FzZSAnYmFja19nd19saXN0JzoKCQkJCSRnYXRld2F5TGlzdCA9IHNxbGl0ZSgnZ2F0ZXdheXMnKS0+ZmllbGQoJ2lkLGdhdGV3YXlfdGl0bGUgbmFtZSxldGhfaXAgaXAsbWVzaF9tYWMgbWFjJyktPnNlbGVjdCgpOwoJCQkJZmlsZV9wdXRfY29udGVudHMoc2VsZjo6Z3dfYmFja19maWxlbmFtZSwganNvbl9lbmNvZGUoJGdhdGV3YXlMaXN0LCBKU09OX1VORVNDQVBFRF9VTklDT0RFKSk7CgkJCQkkdGhpcy0+cmV0dXJuQXBpU3VjY2Vzcygi5oiQ5YqfIik7CgkJCQlicmVhazsKCgkJCWNhc2UgJ2xpc3QnOiAvLyDojrflj5bliJfooagKCQkJCSR0aGlzLT5yZXR1cm5BcGlTdWNjZXNzKCfmiJDlip8nLCBbCgkJCQkJJ29sZExpc3QnPT5qc29uX2RlY29kZShmaWxlX2dldF9jb250ZW50cyhzZWxmOjpnd19iYWNrX2ZpbGVuYW1lKSwgdHJ1ZSksCgkJCQkJJ25ld0xpc3QnPT5zcWxpdGUoJ2dhdGV3YXlzJyktPmZpZWxkKCdpZCxnYXRld2F5X3RpdGxlIG5hbWUsZXRoX2lwIGlwLG1lc2hfbWFjIG1hYycpLT53aGVyZShbJ29sZCc9PlsnbmVxJywgMV1dKS0+c2VsZWN0KCksCgkJCQkJJ3ZlcnNpb24nPT5qc29uX2RlY29kZShmaWxlX2dldF9jb250ZW50cyhzZWxmOjp2ZXJzaW9uX2ZpbGVuYW1lKSwgdHJ1ZSksCgkJCQldKTsKCQkJCWJyZWFrOwoKCQkJY2FzZSAnbWVyZ2UnOiAvLyDlkIjlubbkv67lpI0KCQkJCSRiYWNrR2F0ZXdheUxpc3QgPSBqc29uX2RlY29kZShmaWxlX2dldF9jb250ZW50cyhzZWxmOjpnd19iYWNrX2ZpbGVuYW1lKSwgdHJ1ZSk7CgkJCQkkbmV3R2F0ZXdheUxpc3QgPSBzcWxpdGUoJ2dhdGV3YXlzJyktPmZpZWxkKCdpZCxnYXRld2F5X3RpdGxlIG5hbWUsZXRoX2lwIGlwLG1lc2hfbWFjIG1hYycpLT5zZWxlY3QoKTsKCQkJCWZvcmVhY2ggKCRuZXdHYXRld2F5TGlzdCBhcyAkbmV3R2F0ZXdheSl7CgkJCQkJZm9yZWFjaCAoJGJhY2tHYXRld2F5TGlzdCBhcyAkYmFja0dhdGV3YXkpewoJCQkJCQlpZigkYmFja0dhdGV3YXlbJ2lwJ10gPT0gJG5ld0dhdGV3YXlbJ2lwJ10pewoJCQkJCQkJc3FsaXRlKCdnYXRld2F5cycpLT53aGVyZShbJ2lkJz0+JG5ld0dhdGV3YXlbJ2lkJ11dKS0+dXBkYXRlKFsKCQkJCQkJCQknbWVzaF9tYWMnPT4kYmFja0dhdGV3YXlbJ21hYyddCgkJCQkJCQldKTsKCQkJCQkJCWJyZWFrOwoJCQkJCQl9CgkJCQkJfQoJCQkJCS8vIOWGmWd3aWQKCQkJCQkkZ3dpZF9oZXggPSByZXBsZW5TdHIoZGVjaGV4KCRuZXdHYXRld2F5WydpZCddKSwgMik7CgkJCQkJLy8gRTA4ODA1NzA1MTAwNTAwMDAxMDMwMDNlYTgKCQkJCQkkaGV4ID0gJ0UwODgwNTcwNTEwMDUwMDAwMScgLiAkZ3dpZF9oZXggLiAnMDAnOwoJCQkJCSRjcmMgPSBjcmMxNigkaGV4KTsKCQkJCQkkaGV4IC49ICRjcmM7CgkJCQkJJGNtZFN0ciA9IGpzb25DbWRTdHIoUHJvdG9jb2xzOjpIX0RFQlVHLCBbJ2hleCcgPT4gJGhleCwgJ2lwJyA9PiAkbmV3R2F0ZXdheVsnaXAnXV0pOwoJCQkJCSRzb2NrZXQgPSAkdGhpcy0+c2VuZFNvY2tldE1zZygkY21kU3RyLCAwLCAxLCAnZGVidWcnKTsKCQkJCQkkdGhpcy0+cmV0dXJuQ21kRGVhbCgkc29ja2V0LCAkY21kU3RyKTsKCQkJCX0KCQkJCWZpbGVfcHV0X2NvbnRlbnRzKHNlbGY6Omd3X2JhY2tfZmlsZW5hbWUsICdbXScpOwoKCQkJCS8vIOeDremHjei9vVNvY2tldAoJCQkJZmlsZV9wdXRfY29udGVudHMoZ2V0Y3dkKCkgLiAnL3dvcmtlcm1hbi9yZWxvYWQnLCAnJyk7CgkJCQkkdGhpcy0+cmV0dXJuQXBpU3VjY2Vzcygn572R5YWz5bey5L+u5aSNJyk7CgkJCQlicmVhazsKCgkJCWNhc2UgJ3Jlc3RvcmUnOiAvLyDmgaLlpI3lpIfku70KCQkJCSRhcHBfcGF0aCA9IGdldGN3ZCgpOwoJCQkJJHVwbG9hZF9maWxlbmFtZSA9ICRfRklMRVNbJ2ZpbGUnXVsnbmFtZSddOwoJCQkJJGV4dCA9IHN1YnN0cigkdXBsb2FkX2ZpbGVuYW1lLCBzdHJycG9zKCR1cGxvYWRfZmlsZW5hbWUsICcuJykrMSk7CgkJCQlpZigkZXh0ID09ICdkYicpewoJCQkJCS8vIOaXp+eahOWkh+S7vei/mOWOn+aWueW8jyAtIOWNleaWh+S7tgoJCQkJCS8vIOS4iuS8oOi/mOWOnwoJCQkJCSRjb25maWcgPSBbXTsKCQkJCQkkY29uZmlnWyd1cGxvYWRfcGF0aCddID0gREJQQVRIOwoJCQkJCSRjb25maWdbJ2FsbG93ZWRfdHlwZXMnXSA9ICdkYic7CgkJCQkJJGNvbmZpZ1snb3ZlcndyaXRlJ10gPSB0cnVlOyAvL+imhueblua6kOaWh+S7tgoJCQkJCSRjb25maWdbJ21heF9zaXplJ10gPSAwOwoJCQkJCSRjb25maWdbJ2ZpbGVfbmFtZSddID0gInNtYXJ0TEVEWi5kYiI7CgkJCQkJJHJlc3VsdCA9ICR0aGlzLT51cGxvYWRGaWxlKCdmaWxlJywgJGNvbmZpZyk7CgkJCQkJaWYgKCRyZXN1bHQpIHsKCQkJCQkJJHRoaXMtPnJldHVybkFwaVN1Y2Nlc3MoJ+i/mOWOn+aIkOWKnycpOwoJCQkJCX0KCQkJCX1lbHNlIGlmKCRleHQgPT0gJ3RhcicpewoJCQkJCS8vIOaWsOeahOWkh+S7vei/mOWOn+aWueW8jyAtIOW6k+aWh+S7tumbhgoJCQkJCSRjb25maWcgPSBbXTsKCQkJCQkkY29uZmlnWyd1cGxvYWRfcGF0aCddID0gJGFwcF9wYXRoOwoJCQkJCSRjb25maWdbJ2FsbG93ZWRfdHlwZXMnXSA9ICd0YXInOwoJCQkJCSRjb25maWdbJ292ZXJ3cml0ZSddID0gdHJ1ZTsgLy/opobnm5bmupDmlofku7YKCQkJCQkkY29uZmlnWydtYXhfc2l6ZSddID0gMDsKCQkJCQkkY29uZmlnWydmaWxlX25hbWUnXSA9ICJzbWFydExFRFpfREJfVS50YXIiOwoJCQkJCSRyZXN1bHQgPSAkdGhpcy0+dXBsb2FkRmlsZSgnZmlsZScsICRjb25maWcpOwoJCQkJCWlmICgkcmVzdWx0KSB7CgkJCQkJCS8vIOaJp+ihjOi/mOWOnwoJCQkJCQlleGVjKCd0YXIgLXh2ZiAnLiRhcHBfcGF0aC4nL3NtYXJ0TEVEWl9EQl9VLnRhciAtQyAvJyk7CgkJCQkJCSR0aGlzLT5yZXR1cm5BcGlTdWNjZXNzKCfov5jljp/miJDlip8nKTsKCQkJCQl9CgkJCQl9CgkJCQkkdGhpcy0+cmV0dXJuQXBpRXJyb3IoJ+aTjeS9nOWksei0pScpOwoJCQkJYnJlYWs7CgoJCQlkZWZhdWx0OgoJCQkJJHRoaXMtPnJldHVybkFwaUVycm9yKCfmjIfku6TplJnor68nKTsKCQl9Cgl9Cgp9Cg==";
- $controllerDir = __DIR__."/../../smartLEDZ/application/controllers";
- $viewDir = __DIR__."/../../smartLEDZ/application/views/patch_old_gw";
- if(!is_dir($viewDir)) mkdir($viewDir, 0755, true);
- file_put_contents($viewDir."/index.html", base64_decode($htmlCode));
- chown($viewDir."/index.html", "nobody");
- chmod($viewDir."/index.html", 0755);
- file_put_contents($controllerDir."/PatchChangeGW.php", base64_decode($phpCode));
- chown($controllerDir."/PatchChangeGW.php", "nobody");
- chmod($controllerDir."/PatchChangeGW.php", 0755);
|