diff --git a/.gitignore b/.gitignore index d5d8772b0..46617a455 100644 --- a/.gitignore +++ b/.gitignore @@ -177,7 +177,6 @@ plugins/l2tp plugins/openlitespeed plugins/tamper_proof plugins/cryptocurrency_trade -plugins/mtproxy plugins/zimg plugins/bk_demo plugins/mail diff --git a/plugins/mtproxy/LICENSE b/plugins/mtproxy/LICENSE new file mode 100644 index 000000000..261eeb9e9 --- /dev/null +++ b/plugins/mtproxy/LICENSE @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/plugins/mtproxy/README.md b/plugins/mtproxy/README.md new file mode 100644 index 000000000..beec8bff2 --- /dev/null +++ b/plugins/mtproxy/README.md @@ -0,0 +1,13 @@ +# mtproxy +MTProxy代理 + + +## 基本安装 +``` +cd /www/server/mdserver-web/plugins && rm -rf mtproxy && git clone https://github.com/mw-plugin/mtproxy && cd mtproxy && rm -rf .git && cd /www/server/mdserver-web/plugins/mtproxy && bash install.sh install 1.0 +``` + +## DEBUG +``` +cd /www/server/mdserver-web && python3 /www/server/mdserver-web/plugins/mtproxy/index.py start +``` \ No newline at end of file diff --git a/plugins/mtproxy/conf/mt.toml b/plugins/mtproxy/conf/mt.toml new file mode 100644 index 000000000..2a1f76c65 --- /dev/null +++ b/plugins/mtproxy/conf/mt.toml @@ -0,0 +1,26 @@ +#secret = "7t9xA1qO1IpiPY6D5mrsTQViaW5nLmNvbQ" + + +debug = false + +secret = "{$SECRET}" +bind-to = "0.0.0.0:{$PORT}" + +concurrency = 256 +prefer-ip = "prefer-ipv4" +domain-fronting-port = 443 +tolerate-time-skewness = "10s" + +[network] +doh-ip = "9.9.9.9" + +[network.timeout] +tcp = "5s" +http = "10s" +idle = "1m" + +[defense.anti-replay] +enabled = true +max-size = "1mib" +error-rate = 0.001 + diff --git a/plugins/mtproxy/ico.png b/plugins/mtproxy/ico.png new file mode 100644 index 000000000..efaab9dfb Binary files /dev/null and b/plugins/mtproxy/ico.png differ diff --git a/plugins/mtproxy/index.html b/plugins/mtproxy/index.html new file mode 100755 index 000000000..030b3f3c1 --- /dev/null +++ b/plugins/mtproxy/index.html @@ -0,0 +1,22 @@ +
+
+
+

服务

+

自启动

+

配置修改

+

配置文件

+
+
+
+
+
+
+ \ No newline at end of file diff --git a/plugins/mtproxy/index.py b/plugins/mtproxy/index.py new file mode 100755 index 000000000..df7aef97c --- /dev/null +++ b/plugins/mtproxy/index.py @@ -0,0 +1,182 @@ +# coding:utf-8 + +import sys +import io +import os +import time + +web_dir = os.getcwd() + "/web" +if os.path.exists(web_dir): + sys.path.append(web_dir) + os.chdir(web_dir) + +import core.mw as mw + +app_debug = False +if mw.isAppleSystem(): + app_debug = True + + +def getPluginName(): + return 'mtproxy' + + +def getPluginDir(): + return mw.getPluginDir() + '/' + getPluginName() + + +def getServerDir(): + return mw.getServerDir() + '/' + getPluginName() + + +def getServiceTpl(): + path = getPluginDir() + "/init.d/" + getPluginName() + ".service.tpl" + return path + + +def getConfEnvTpl(): + path = getPluginDir() + "/conf/mt.toml" + return path + + +def getConfEnv(): + path = getServerDir() + "/mt.toml" + return path + + +def getArgs(): + args = sys.argv[2:] + tmp = {} + args_len = len(args) + + if args_len == 1: + t = args[0].strip('{').strip('}') + t = t.split(':') + tmp[t[0]] = t[1] + elif args_len > 1: + for i in range(len(args)): + t = args[i].split(':') + tmp[t[0]] = t[1] + + return tmp + + +def status(): + data = mw.execShell( + "ps -ef|grep mtproxy| grep mtg |grep -v grep | grep -v python | awk '{print $2}'") + + if data[0] == '': + return 'stop' + return 'start' + + +def getServiceFile(): + return '/usr/lib/systemd/system/mtproxy.service' + + +def initDreplace(): + + envTpl = getConfEnvTpl() + dstEnv = getConfEnv() + cmd = getServerDir() + '/mtg/mtg generate-secret `head -c 16 /dev/urandom | xxd -ps`' + secret = mw.execShell(cmd) + if not os.path.exists(dstEnv): + env_content = mw.readFile(envTpl) + env_content = env_content.replace('{$PORT}', '8349') + env_content = env_content.replace('{$SECRET}', secret[0].strip()) + mw.writeFile(dstEnv, env_content) + + # systemd + systemDir = mw.systemdCfgDir() + systemService = systemDir + '/mtproxy.service' + systemServiceTpl = getServiceTpl() + if os.path.exists(systemDir) and not os.path.exists(systemService): + service_path = mw.getServerDir() + se_content = mw.readFile(systemServiceTpl) + se_content = se_content.replace('{$SERVER_PATH}', service_path) + mw.writeFile(systemService, se_content) + mw.execShell('systemctl daemon-reload') + + return 'ok' + + +def mtOp(method): + file = initDreplace() + + if not mw.isAppleSystem(): + mw.execShell('systemctl daemon-reload') + data = mw.execShell('systemctl ' + method + ' mtproxy') + if data[1] == '': + return 'ok' + return data[1] + + return 'fail' + + +def start(): + return mtOp('start') + + +def stop(): + return mtOp('stop') + + +def restart(): + return mtOp('restart') + + +def reload(): + return redisOp('reload') + + +def initdStatus(): + if mw.isAppleSystem(): + return "Apple Computer does not support" + + shell_cmd = 'systemctl status mtproxy | grep loaded | grep "enabled;"' + data = mw.execShell(shell_cmd) + if data[0] == '': + return 'fail' + return 'ok' + + +def initdInstall(): + if mw.isAppleSystem(): + return "Apple Computer does not support" + + mw.execShell('systemctl enable mtproxy') + return 'ok' + + +def initdUinstall(): + + if mw.isAppleSystem(): + return "Apple Computer does not support" + + mw.execShell('systemctl disable mtproxy') + return 'ok' + +if __name__ == "__main__": + func = sys.argv[1] + if func == 'status': + print(status()) + elif func == 'start': + print(start()) + elif func == 'stop': + print(stop()) + elif func == 'restart': + print(restart()) + elif func == 'reload': + print(reload()) + elif func == 'initd_status': + print(initdStatus()) + elif func == 'initd_install': + print(initdInstall()) + elif func == 'initd_uninstall': + print(initdUinstall()) + elif func == 'conf': + print(getServiceFile()) + elif func == 'conf_env': + print(getConfEnv()) + else: + print('error') diff --git a/plugins/mtproxy/info.json b/plugins/mtproxy/info.json new file mode 100755 index 000000000..6cb413722 --- /dev/null +++ b/plugins/mtproxy/info.json @@ -0,0 +1,18 @@ +{ + "sort": 7, + "ps": "你的纸飞机", + "name": "mtproxy", + "title": "mtproxy", + "shell": "install.sh", + "versions":["1.0"], + "updates":["1.0"], + "tip": "soft", + "checks": "server/mtproxy", + "path": "server/mtproxy", + "display": 1, + "author": "TelegramMessenger", + "date": "2022-07-09", + "home": "https://github.com/9seconds/mtg", + "type": 0, + "pid": "5" +} \ No newline at end of file diff --git a/plugins/mtproxy/init.d/mtproxy.service.tpl b/plugins/mtproxy/init.d/mtproxy.service.tpl new file mode 100644 index 000000000..03ad10760 --- /dev/null +++ b/plugins/mtproxy/init.d/mtproxy.service.tpl @@ -0,0 +1,14 @@ +[Unit] +Description=MTProxy +After=network.target + +[Service] +Type=simple +WorkingDirectory={$SERVER_PATH}/mtproxy +ExecStart={$SERVER_PATH}/mtproxy/mtg/mtg run {$SERVER_PATH}/mtproxy/mt.toml +RestartSec=3 +Restart=on-failure +AmbientCapabilities=CAP_NET_BIND_SERVICE + +[Install] +WantedBy=multi-user.target \ No newline at end of file diff --git a/plugins/mtproxy/install.sh b/plugins/mtproxy/install.sh new file mode 100755 index 000000000..acc157fc0 --- /dev/null +++ b/plugins/mtproxy/install.sh @@ -0,0 +1,129 @@ +#!/bin/bash +PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin +export PATH + +curPath=`pwd` +rootPath=$(dirname "$curPath") +rootPath=$(dirname "$rootPath") +serverPath=$(dirname "$rootPath") + +install_tmp=${rootPath}/tmp/mw_install.pl + + + +bash ${rootPath}/scripts/getos.sh +OSNAME=`cat ${rootPath}/data/osname.pl` +OSNAME_ID=`cat /etc/*-release | grep VERSION_ID | awk -F = '{print $2}' | awk -F "\"" '{print $2}'` + + + +VERSION=v2.1.7 +VERSION_MIN=2.1.7 +OS=$(uname | tr '[:upper:]' '[:lower:]') + +ARCH=amd64 +get_arch() { + echo "package main +import ( + \"fmt\" + \"runtime\" +) +func main() { fmt.Println(runtime.GOARCH) }" > /tmp/go_arch.go + + ARCH=$(go run /tmp/go_arch.go) +} + +TARGET_DIR="${serverPath}/mtproxy" + + + +get_download_url() { + DOWNLOAD_URL="https://github.com/9seconds/mtg/releases/download/$VERSION/mtg-${VERSION_MIN}-${OS}-${ARCH}.tar.gz" +} + +# download file +download_file() { + url="${1}" + destination="${2}" + + printf "Fetching ${url} \n\n" + + if test -x "$(command -v curl)"; then + code=$(curl --connect-timeout 15 -w '%{http_code}' -L "${url}" -o "${destination}") + elif test -x "$(command -v wget)"; then + code=$(wget -t2 -T15 -O "${destination}" --server-response "${url}" 2>&1 | awk '/^ HTTP/{print $2}' | tail -1) + else + printf "\e[1;31mNeither curl nor wget was available to perform http requests.\e[0m\n" + exit 1 + fi + + if [ "${code}" != 200 ]; then + printf "\e[1;31mRequest failed with code %s\e[0m\n" $code + exit 1 + else + printf "\n\e[1;33mDownload succeeded\e[0m\n" + fi +} + +# /www/server/mtproxy/mtg/mtg run /www/server/mtproxy/mt.toml + +Install_app() +{ + + if [[ $OSNAME = "centos" ]]; then + yum install -y golang golang-src + elif [[ $OSNAME = "amazon" ]]; then + yum install -y golang golang-src + else + apt install -y golang golang-src + fi + + mkdir -p ${serverPath}/mtproxy + mkdir -p ${serverPath}/source/mtproxy + + get_arch + get_download_url + + DOWNLOAD_FILE="$(mktemp).tar.gz" + download_file $DOWNLOAD_URL $DOWNLOAD_FILE + + tar -C "$TARGET_DIR" -zxf $DOWNLOAD_FILE + rm -rf $DOWNLOAD_FILE + + if [ -d ${serverPath}/mtproxy/mtg ];then + rm -rf ${serverPath}/mtproxy/mtg + fi + + # cd ${serverPath}/mtproxy + # curl -s https://core.telegram.org/getProxySecret -o proxy-secret + # curl -s https://core.telegram.org/getProxyConfig -o proxy-multi.conf + + + mv ${serverPath}/mtproxy/mtg-${VERSION_MIN}-${OS}-${ARCH} ${serverPath}/mtproxy/mtg + + + echo "${1}" > ${serverPath}/mtproxy/version.pl + echo '安装完成' > $install_tmp + + #初始化 + cd ${rootPath} && python3 ${rootPath}/plugins/mtproxy/index.py start + cd ${rootPath} && python3 ${rootPath}/plugins/mtproxy/index.py initd_install +} + +Uninstall_app() +{ + if [ -f /usr/lib/systemd/system/mtproxy.service ];then + systemctl stop mtproxy + rm -rf /usr/lib/systemd/system/mtproxy.service + systemctl daemon-reload + fi + rm -rf ${serverPath}/mtproxy + echo '卸载完成' > $install_tmp +} + +action=$1 +if [ "${1}" == 'install' ];then + Install_app $2 +else + Uninstall_app $2 +fi diff --git a/plugins/mtproxy/js/mtproxy.js b/plugins/mtproxy/js/mtproxy.js new file mode 100644 index 000000000..e69de29bb