From 28e560ae34a366285f09247804d0656154fa571b Mon Sep 17 00:00:00 2001 From: okxlin <61420215+okxlin@users.noreply.github.com> Date: Tue, 4 Jul 2023 10:01:00 +0800 Subject: [PATCH] =?UTF-8?q?feat:=E6=B7=BB=E5=8A=A0adguardhome=E3=80=81memc?= =?UTF-8?q?ached=E3=80=81qiandao=E3=80=81lsky-pro=E3=80=81bitwarden?= =?UTF-8?q?=E3=80=81rustdesk=E3=80=81synapse=20(#187)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/adguardhome/0.107.32/data.yml | 96 ++++ apps/adguardhome/0.107.32/docker-compose.yml | 32 ++ apps/adguardhome/README.md | 529 +++++++++++++++++++ apps/adguardhome/data.yml | 20 + apps/adguardhome/logo.png | Bin 0 -> 6363 bytes apps/bitwarden/1.28.1/data.yml | 17 + apps/bitwarden/1.28.1/docker-compose.yml | 18 + apps/bitwarden/README.md | 95 ++++ apps/bitwarden/data.yml | 20 + apps/bitwarden/logo.png | Bin 0 -> 16591 bytes apps/lsky-pro/README.md | 98 ++++ apps/lsky-pro/data.yml | 20 + apps/lsky-pro/latest/data.yml | 17 + apps/lsky-pro/latest/docker-compose.yml | 20 + apps/lsky-pro/logo.png | Bin 0 -> 18655 bytes apps/memcached/1.6.19/data.yml | 17 + apps/memcached/1.6.19/docker-compose.yml | 16 + apps/memcached/README.md | 54 ++ apps/memcached/data.yml | 20 + apps/memcached/logo.png | Bin 0 -> 24668 bytes apps/qiandao/20230618/data.yml | 35 ++ apps/qiandao/20230618/docker-compose.yml | 153 ++++++ apps/qiandao/README.md | 134 +++++ apps/qiandao/data.yml | 20 + apps/qiandao/logo.png | Bin 0 -> 15887 bytes apps/rustdesk/README.md | 241 +++++++++ apps/rustdesk/data.yml | 20 + apps/rustdesk/latest/data.yml | 50 ++ apps/rustdesk/latest/docker-compose.yml | 50 ++ apps/rustdesk/logo.png | Bin 0 -> 11655 bytes apps/synapse/1.86.0/data.yml | 11 + apps/synapse/1.86.0/docker-compose.yml | 30 ++ apps/synapse/README.md | 244 +++++++++ apps/synapse/data.yml | 20 + apps/synapse/logo.png | Bin 0 -> 2949 bytes 35 files changed, 2097 insertions(+) create mode 100644 apps/adguardhome/0.107.32/data.yml create mode 100644 apps/adguardhome/0.107.32/docker-compose.yml create mode 100644 apps/adguardhome/README.md create mode 100644 apps/adguardhome/data.yml create mode 100644 apps/adguardhome/logo.png create mode 100644 apps/bitwarden/1.28.1/data.yml create mode 100644 apps/bitwarden/1.28.1/docker-compose.yml create mode 100644 apps/bitwarden/README.md create mode 100644 apps/bitwarden/data.yml create mode 100644 apps/bitwarden/logo.png create mode 100644 apps/lsky-pro/README.md create mode 100644 apps/lsky-pro/data.yml create mode 100644 apps/lsky-pro/latest/data.yml create mode 100644 apps/lsky-pro/latest/docker-compose.yml create mode 100644 apps/lsky-pro/logo.png create mode 100644 apps/memcached/1.6.19/data.yml create mode 100644 apps/memcached/1.6.19/docker-compose.yml create mode 100644 apps/memcached/README.md create mode 100644 apps/memcached/data.yml create mode 100644 apps/memcached/logo.png create mode 100644 apps/qiandao/20230618/data.yml create mode 100644 apps/qiandao/20230618/docker-compose.yml create mode 100644 apps/qiandao/README.md create mode 100644 apps/qiandao/data.yml create mode 100644 apps/qiandao/logo.png create mode 100644 apps/rustdesk/README.md create mode 100644 apps/rustdesk/data.yml create mode 100644 apps/rustdesk/latest/data.yml create mode 100644 apps/rustdesk/latest/docker-compose.yml create mode 100644 apps/rustdesk/logo.png create mode 100644 apps/synapse/1.86.0/data.yml create mode 100644 apps/synapse/1.86.0/docker-compose.yml create mode 100644 apps/synapse/README.md create mode 100644 apps/synapse/data.yml create mode 100644 apps/synapse/logo.png diff --git a/apps/adguardhome/0.107.32/data.yml b/apps/adguardhome/0.107.32/data.yml new file mode 100644 index 000000000..742b03ac4 --- /dev/null +++ b/apps/adguardhome/0.107.32/data.yml @@ -0,0 +1,96 @@ +additionalProperties: + formFields: + - default: 20053 + edit: true + envKey: PLAIN_DNS_PORT + labelEn: Plain DNS port + labelZh: 普通DNS端口 + required: true + rule: paramPort + type: number + - default: 20067 + edit: true + envKey: DHCP_PORT1 + labelEn: DHCP service port 1 + labelZh: DHCP服务端口1 + required: true + rule: paramPort + type: number + - default: 20068 + edit: true + envKey: DHCP_PORT2 + labelEn: DHCP service port 2 + labelZh: DHCP服务端口2 + required: true + rule: paramPort + type: number + - default: 23000 + edit: true + envKey: HTTP_PORT + labelEn: HTTP web port + labelZh: HTTP网页端口 + required: true + rule: paramPort + type: number + - default: 23001 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Initial setup web page port + labelZh: 初始设置网页端口 + required: true + rule: paramPort + type: number + - default: 20443 + edit: true + envKey: DOH_PORT + labelEn: DOH service port + labelZh: DOH服务端口 + required: true + rule: paramPort + type: number + - default: 853 + edit: true + envKey: DOT_PORT + labelEn: DOT service port + labelZh: DOT服务端口 + required: true + rule: paramPort + type: number + - default: 20784 + edit: true + envKey: QUIC_PORT1 + labelEn: QUIC service port 1 + labelZh: QUIC服务端口1 + required: true + rule: paramPort + type: number + - default: 8853 + edit: true + envKey: QUIC_PORT2 + labelEn: QUIC service port 2 + labelZh: QUIC服务端口2 + required: true + rule: paramPort + type: number + - default: 5443 + edit: true + envKey: DNS_CRYPT_PORT + labelEn: DNS Crypt service port + labelZh: DNS Crypt服务端口 + required: true + rule: paramPort + type: number + - default: ./data/work + edit: true + envKey: WORK_PATH + labelEn: Work data folder path + labelZh: 工作数据文件夹路径 + required: true + type: text + - default: ./data/conf + edit: true + envKey: CONFIG_PATH + labelEn: Configuration folder path + labelZh: 配置文件夹路径 + required: true + type: text diff --git a/apps/adguardhome/0.107.32/docker-compose.yml b/apps/adguardhome/0.107.32/docker-compose.yml new file mode 100644 index 000000000..a87a5edad --- /dev/null +++ b/apps/adguardhome/0.107.32/docker-compose.yml @@ -0,0 +1,32 @@ +version: '3' +services: + adguardhome: + container_name: ${CONTAINER_NAME} + restart: always + networks: + - 1panel-network + ports: + - ${PLAIN_DNS_PORT}:53/tcp + - ${PLAIN_DNS_PORT}:53/udp + - ${DHCP_PORT1}:67/udp + - ${DHCP_PORT2}:68/udp + - ${HTTP_PORT}:80/tcp + - ${DOH_PORT}:443/tcp + - ${DOH_PORT}:443/udp + - ${PANEL_APP_PORT_HTTP}:3000/tcp + - ${DOT_PORT}:853/tcp + - ${QUIC_PORT1}:784/udp + - ${DOT_PORT}:853/udp + - ${QUIC_PORT2}:8853/udp + - ${DNS_CRYPT_PORT}:5443/tcp + - ${DNS_CRYPT_PORT}:5443/udp + volumes: + - ${WORK_PATH}:/opt/adguardhome/work + - ${CONFIG_PATH}:/opt/adguardhome/conf + image: adguard/adguardhome:v0.107.32 + labels: + createdBy: "Apps" + +networks: + 1panel-network: + external: true diff --git a/apps/adguardhome/README.md b/apps/adguardhome/README.md new file mode 100644 index 000000000..6aa82defc --- /dev/null +++ b/apps/adguardhome/README.md @@ -0,0 +1,529 @@ +  +

+ + + AdGuard Home + +

+

Privacy protection center for you and your devices

+

+ Free and open source, powerful network-wide ads & trackers blocking DNS + server. +

+

+ AdGuard.com | + Wiki | + Reddit | + Twitter | + Telegram +

+ + Code Coverage + + + Go Report Card + + + Docker Pulls + +
+ + Latest release + + + adguard-home + +

+
+

+ +

+
+ +AdGuard Home is a network-wide software for blocking ads and tracking. After you +set it up, it'll cover ALL your home devices, and you don't need any client-side +software for that. + +It operates as a DNS server that re-routes tracking domains to a “black hole”, +thus preventing your devices from connecting to those servers. It's based on +software we use for our public [AdGuard DNS] servers, and both share a lot of +code. + +[AdGuard DNS]: https://adguard-dns.io/ + + + + * [Getting Started](#getting-started) + * [Automated install (Unix)](#automated-install-linux-and-mac) + * [Alternative methods](#alternative-methods) + * [Guides](#guides) + * [API](#api) + * [Comparing AdGuard Home to other solutions](#comparison) + * [How is this different from public AdGuard DNS servers?](#comparison-adguard-dns) + * [How does AdGuard Home compare to Pi-Hole](#comparison-pi-hole) + * [How does AdGuard Home compare to traditional ad blockers](#comparison-adblock) + * [Known limitations](#comparison-limitations) + * [How to build from source](#how-to-build) + * [Prerequisites](#prerequisites) + * [Building](#building) + * [Contributing](#contributing) + * [Test unstable versions](#test-unstable-versions) + * [Reporting issues](#reporting-issues) + * [Help with translations](#translate) + * [Other](#help-other) + * [Projects that use AdGuard Home](#uses) + * [Acknowledgments](#acknowledgments) + * [Privacy](#privacy) + + + +## Getting Started + + ### Automated install (Unix) + +To install with `curl` run the following command: + +```sh +curl -s -S -L https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s -- -v +``` + +To install with `wget` run the following command: + +```sh +wget --no-verbose -O - https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s -- -v +``` + +To install with `fetch` run the following command: + +```sh +fetch -o - https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s -- -v +``` + +The script also accepts some options: + + * `-c ` to use specified channel; + * `-r` to reinstall AdGuard Home; + * `-u` to uninstall AdGuard Home; + * `-v` for verbose output. + +Note that options `-r` and `-u` are mutually exclusive. + + + + ### Alternative methods + + #### Manual installation + +Please read the **[Getting Started][wiki-start]** article on our Wiki to learn +how to install AdGuard Home manually, and how to configure your devices to use +it. + + #### Docker + +You can use our official Docker image on [Docker Hub]. + + #### Snap Store + +If you're running **Linux,** there's a secure and easy way to install AdGuard +Home: get it from the [Snap Store]. + +[Docker Hub]: https://hub.docker.com/r/adguard/adguardhome +[Snap Store]: https://snapcraft.io/adguard-home +[wiki-start]: https://github.com/AdguardTeam/AdGuardHome/wiki/Getting-Started + + + + ### Guides + +See our [Wiki][wiki]. + +[wiki]: https://github.com/AdguardTeam/AdGuardHome/wiki + + + + ### API + +If you want to integrate with AdGuard Home, you can use our [REST API][openapi]. +Alternatively, you can use this [python client][pyclient], which is used to +build the [AdGuard Home Hass.io Add-on][hassio]. + +[hassio]: https://www.home-assistant.io/integrations/adguard/ +[openapi]: https://github.com/AdguardTeam/AdGuardHome/tree/master/openapi +[pyclient]: https://pypi.org/project/adguardhome/ + + + +## Comparing AdGuard Home to other solutions + + ### How is this different from public AdGuard DNS servers? + +Running your own AdGuard Home server allows you to do much more than using a +public DNS server. It's a completely different level. See for yourself: + + * Choose what exactly the server blocks and permits. + + * Monitor your network activity. + + * Add your own custom filtering rules. + + * **Most importantly, it's your own server, and you are the only one who's in + control.** + + + + ### How does AdGuard Home compare to Pi-Hole + +At this point, AdGuard Home has a lot in common with Pi-Hole. Both block ads +and trackers using the so-called “DNS sinkholing” method and both allow +customizing what's blocked. + + + +AdGuard Home provides a lot of features out-of-the-box with no need to install +and configure additional software. We want it to be simple to the point when +even casual users can set it up with minimal effort. + +**Disclaimer:** some of the listed features can be added to Pi-Hole by +installing additional software or by manually using SSH terminal and +reconfiguring one of the utilities Pi-Hole consists of. However, in our +opinion, this cannot be legitimately counted as a Pi-Hole's feature. + +| Feature | AdGuard Home | Pi-Hole | +|-------------------------------------------------------------------------|-------------------|-----------------------------------------------------------| +| Blocking ads and trackers | ✅ | ✅ | +| Customizing blocklists | ✅ | ✅ | +| Built-in DHCP server | ✅ | ✅ | +| HTTPS for the Admin interface | ✅ | Kind of, but you'll need to manually configure lighttpd | +| Encrypted DNS upstream servers (DNS-over-HTTPS, DNS-over-TLS, DNSCrypt) | ✅ | ❌ (requires additional software) | +| Cross-platform | ✅ | ❌ (not natively, only via Docker) | +| Running as a DNS-over-HTTPS or DNS-over-TLS server | ✅ | ❌ (requires additional software) | +| Blocking phishing and malware domains | ✅ | ❌ (requires non-default blocklists) | +| Parental control (blocking adult domains) | ✅ | ❌ | +| Force Safe search on search engines | ✅ | ❌ | +| Per-client (device) configuration | ✅ | ✅ | +| Access settings (choose who can use AGH DNS) | ✅ | ❌ | +| Running [without root privileges][wiki-noroot] | ✅ | ❌ | + +[wiki-noroot]: https://github.com/AdguardTeam/AdGuardHome/wiki/Getting-Started#running-without-superuser + + + + ### How does AdGuard Home compare to traditional ad blockers + +It depends. + +DNS sinkholing is capable of blocking a big percentage of ads, but it lacks +the flexibility and the power of traditional ad blockers. You can get a good +impression about the difference between these methods by reading [this +article][blog-adaway], which compares AdGuard for Android (a traditional ad +blocker) to hosts-level ad blockers (which are almost identical to DNS-based +blockers in their capabilities). This level of protection is enough for some +users. + +Additionally, using a DNS-based blocker can help to block ads, tracking and +analytics requests on other types of devices, such as SmartTVs, smart speakers +or other kinds of IoT devices (on which you can't install traditional ad +blockers). + + + + ### Known limitations + +Here are some examples of what cannot be blocked by a DNS-level blocker: + + * YouTube, Twitch ads; + + * Facebook, Twitter, Instagram sponsored posts. + +Essentially, any advertising that shares a domain with content cannot be blocked +by a DNS-level blocker. + +Is there a chance to handle this in the future? DNS will never be enough to do +this. Our only option is to use a content blocking proxy like what we do in the +standalone AdGuard applications. We're [going to bring][issue-1228] this +feature support to AdGuard Home in the future. Unfortunately, even in this +case, there still will be cases when this won't be enough or would require quite +a complicated configuration. + +[blog-adaway]: https://adguard.com/blog/adguard-vs-adaway-dns66.html +[issue-1228]: https://github.com/AdguardTeam/AdGuardHome/issues/1228 + + + +## How to build from source + + ### Prerequisites + +Run `make init` to prepare the development environment. + +You will need this to build AdGuard Home: + + * [Go](https://golang.org/dl/) v1.19 or later; + * [Node.js](https://nodejs.org/en/download/) v10.16.2 or later; + * [npm](https://www.npmjs.com/) v6.14 or later; + * [yarn](https://yarnpkg.com/) v1.22.5 or later. + + + + ### Building + +Open your terminal and execute these commands: + +```sh +git clone https://github.com/AdguardTeam/AdGuardHome +cd AdGuardHome +make +``` + +**NOTE:** The non-standard `-j` flag is currently not supported, so building +with `make -j 4` or setting your `MAKEFLAGS` to include, for example, `-j 4` is +likely to break the build. If you do have your `MAKEFLAGS` set to that, and you +don't want to change it, you can override it by running `make -j 1`. + +Check the [`Makefile`][src-makefile] to learn about other commands. + + #### Building for a different platform + +You can build AdGuard Home for any OS/ARCH that Go supports. In order to do +this, specify `GOOS` and `GOARCH` environment variables as macros when running +`make`. + +For example: + +```sh +env GOOS='linux' GOARCH='arm64' make +``` + +or: + +```sh +make GOOS='linux' GOARCH='arm64' +``` + + #### Preparing releases + +You'll need [`snapcraft`] to prepare a release build. Once installed, run the +following command: + +```sh +make build-release CHANNEL='...' VERSION='...' +``` + +See the [`build-release` target documentation][targ-release]. + + #### Docker image + +Run `make build-docker` to build the Docker image locally (the one that we +publish to DockerHub). Please note, that we're using [Docker Buildx][buildx] to +build our official image. + +You may need to prepare before using these builds: + + * (Linux-only) Install Qemu: + + ```sh + docker run --rm --privileged multiarch/qemu-user-static --reset -p yes --credential yes + ``` + + * Prepare the builder: + + ```sh + docker buildx create --name buildx-builder --driver docker-container --use + ``` + +See the [`build-docker` target documentation][targ-docker]. + + #### Debugging the frontend + +When you need to debug the frontend without recompiling the production version +every time, for example to check how your labels would look on a form, you can +run the frontend build a development environment. + +1. In a separate terminal, run: + + ```sh + ( cd ./client/ && env NODE_ENV='development' npm run watch ) + ``` + +2. Run your `AdGuardHome` binary with the `--local-frontend` flag, which + instructs AdGuard Home to ignore the built-in frontend files and use those + from the `./build/` directory. + +3. Now any changes you make in the `./client/` directory should be recompiled + and become available on the web UI. Make sure that you disable the browser + cache to make sure that you actually get the recompiled version. + +[`snapcraft`]: https://snapcraft.io/ +[buildx]: https://docs.docker.com/buildx/working-with-buildx/ +[src-makefile]: https://github.com/AdguardTeam/AdGuardHome/blob/master/Makefile +[targ-docker]: https://github.com/AdguardTeam/AdGuardHome/tree/master/scripts#build-dockersh-build-a-multi-architecture-docker-image +[targ-release]: https://github.com/AdguardTeam/AdGuardHome/tree/master/scripts#build-releasesh-build-a-release-for-all-platforms + + + +## Contributing + +You are welcome to fork this repository, make your changes and [submit a pull +request][pr]. Please make sure you follow our [code guidelines][guide] though. + +Please note that we don't expect people to contribute to both UI and backend +parts of the program simultaneously. Ideally, the backend part is implemented +first, i.e. configuration, API, and the functionality itself. The UI part can +be implemented later in a different pull request by a different person. + +[guide]: https://github.com/AdguardTeam/CodeGuidelines/ +[pr]: https://github.com/AdguardTeam/AdGuardHome/pulls + + + + ### Test unstable versions + +There are two update channels that you can use: + + * `beta`: beta versions of AdGuard Home. More or less stable versions, + usually released every two weeks or more often. + + * `edge`: the newest version of AdGuard Home from the development branch. New + updates are pushed to this channel daily. + +There are three options how you can install an unstable version: + +1. [Snap Store]: look for the `beta` and `edge` channels. + +2. [Docker Hub]: look for the `beta` and `edge` tags. + +3. Standalone builds. Use the automated installation script or look for the + available builds [on the Wiki][wiki-platf]. + + Script to install a beta version: + + ```sh + curl -s -S -L https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s -- -c beta + ``` + + Script to install an edge version: + + ```sh + curl -s -S -L https://raw.githubusercontent.com/AdguardTeam/AdGuardHome/master/scripts/install.sh | sh -s -- -c edge + ``` +[wiki-platf]: https://github.com/AdguardTeam/AdGuardHome/wiki/Platforms + + + + ### Report issues + +If you run into any problem or have a suggestion, head to [this page][iss] and +click on the “New issue” button. + +[iss]: https://github.com/AdguardTeam/AdGuardHome/issues + + + + ### Help with translations + +If you want to help with AdGuard Home translations, please learn more about +translating AdGuard products [in our Knowledge Base][kb-trans]. You can +contribute to the [AdGuardHome project on CrowdIn][crowdin]. + +[crowdin]: https://crowdin.com/project/adguard-applications/en#/adguard-home +[kb-trans]: https://kb.adguard.com/en/general/adguard-translations + + + + ### Other + +Another way you can contribute is by [looking for issues][iss-help] marked as +`help wanted`, asking if the issue is up for grabs, and sending a PR fixing the +bug or implementing the feature. + +[iss-help]: https://github.com/AdguardTeam/AdGuardHome/issues?q=is%3Aissue+is%3Aopen+label%3A%22help+wanted%22 + + + +## Projects that use AdGuard Home + + + + * [AdGuard Home Remote](https://apps.apple.com/app/apple-store/id1543143740): + iOS app by [Joost](https://rocketscience-it.nl/). + + * [Python library](https://github.com/frenck/python-adguardhome) by + [@frenck](https://github.com/frenck). + + * [Home Assistant add-on](https://github.com/hassio-addons/addon-adguard-home) + by [@frenck](https://github.com/frenck). + + * [OpenWrt LUCI app](https://github.com/kongfl888/luci-app-adguardhome) by + [@kongfl888](https://github.com/kongfl888) (originally by + [@rufengsuixing](https://github.com/rufengsuixing)). + + * [Prometheus exporter for AdGuard + Home](https://github.com/ebrianne/adguard-exporter) by + [@ebrianne](https://github.com/ebrianne). + + * [Terminal-based, real-time traffic monitoring and statistics for your AdGuard Home + instance](https://github.com/Lissy93/AdGuardian-Term) by + [@Lissy93](https://github.com/Lissy93) + + * [AdGuard Home on GLInet + routers](https://forum.gl-inet.com/t/adguardhome-on-gl-routers/10664) by + [Gl-Inet](https://gl-inet.com/). + + * [Cloudron app](https://git.cloudron.io/cloudron/adguard-home-app) by + [@gramakri](https://github.com/gramakri). + + * [Asuswrt-Merlin-AdGuardHome-Installer](https://github.com/jumpsmm7/Asuswrt-Merlin-AdGuardHome-Installer) + by [@jumpsmm7](https://github.com/jumpsmm7) aka + [@SomeWhereOverTheRainBow](https://www.snbforums.com/members/somewhereovertherainbow.64179/). + + * [Node.js library](https://github.com/Andrea055/AdguardHomeAPI) by + [@Andrea055](https://github.com/Andrea055/). + + + +## Acknowledgments + + + +This software wouldn't have been possible without: + + * [Go](https://golang.org/dl/) and its libraries: + * [gcache](https://github.com/bluele/gcache) + * [miekg's dns](https://github.com/miekg/dns) + * [go-yaml](https://github.com/go-yaml/yaml) + * [service](https://godoc.org/github.com/kardianos/service) + * [dnsproxy](https://github.com/AdguardTeam/dnsproxy) + * [urlfilter](https://github.com/AdguardTeam/urlfilter) + * [Node.js](https://nodejs.org/) and its libraries: + * And many more Node.js packages. + * [React.js](https://reactjs.org) + * [Tabler](https://github.com/tabler/tabler) + * [whotracks.me data](https://github.com/cliqz-oss/whotracks.me) + +You might have seen that [CoreDNS] was mentioned here before, but we've stopped +using it in AdGuard Home. + +For the full list of all Node.js packages in use, please take a look at +[`client/package.json`][src-packagejson] file. + +[CoreDNS]: https://coredns.io +[src-packagejson]: https://github.com/AdguardTeam/AdGuardHome/blob/master/client/package.json + + + +## Privacy + +Our main idea is that you are the one, who should be in control of your data. +So it is only natural, that AdGuard Home does not collect any usage statistics, +and does not use any web services unless you configure it to do so. See also +the [full privacy policy][privacy] with every bit that *could in theory be sent* +by AdGuard Home is available. + +[privacy]: https://adguard.com/en/privacy/home.html diff --git a/apps/adguardhome/data.yml b/apps/adguardhome/data.yml new file mode 100644 index 000000000..203301c32 --- /dev/null +++ b/apps/adguardhome/data.yml @@ -0,0 +1,20 @@ +name: AdGuardHome +tags: + - 工具 +title: 自由且开源的,功能强大的网络广告和跟踪器屏蔽DNS服务器 +type: 工具 +description: 自由且开源的,功能强大的网络广告和跟踪器屏蔽DNS服务器 +additionalProperties: + key: adguardhome + name: AdGuardHome + tags: + - Tool + shortDescZh: 自由且开源的,功能强大的网络广告和跟踪器屏蔽DNS服务器 + shortDescEn: Free and open source, powerful network-wide ads & trackers blocking DNS server + type: tool + crossVersionUpdate: true + limit: 0 + recommend: 0 + website: https://hub.docker.com/r/adguard/adguardhome + github: https://github.com/AdguardTeam/AdGuardHome + document: https://github.com/AdguardTeam/AdGuardHome/wiki diff --git a/apps/adguardhome/logo.png b/apps/adguardhome/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..87ad08af453528cff500e66df77f2706f022a0d4 GIT binary patch literal 6363 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 literal 0 HcmV?d00001 diff --git a/apps/bitwarden/1.28.1/data.yml b/apps/bitwarden/1.28.1/data.yml new file mode 100644 index 000000000..4812fc505 --- /dev/null +++ b/apps/bitwarden/1.28.1/data.yml @@ -0,0 +1,17 @@ +additionalProperties: + formFields: + - default: 40031 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Port + labelZh: 端口 + required: true + rule: paramPort + type: number + - default: ./data + edit: true + envKey: DATA_PATH + labelEn: Data folder path + labelZh: 数据文件夹路径 + required: true + type: text diff --git a/apps/bitwarden/1.28.1/docker-compose.yml b/apps/bitwarden/1.28.1/docker-compose.yml new file mode 100644 index 000000000..731000596 --- /dev/null +++ b/apps/bitwarden/1.28.1/docker-compose.yml @@ -0,0 +1,18 @@ +version: '3' +services: + bitwarden: + container_name: ${CONTAINER_NAME} + restart: always + networks: + - 1panel-network + ports: + - "${PANEL_APP_PORT_HTTP}:80" + volumes: + - "${DATA_PATH}:/data" + image: vaultwarden/server:1.28.1-alpine + labels: + createdBy: "Apps" + +networks: + 1panel-network: + external: true diff --git a/apps/bitwarden/README.md b/apps/bitwarden/README.md new file mode 100644 index 000000000..dc98d41db --- /dev/null +++ b/apps/bitwarden/README.md @@ -0,0 +1,95 @@ +### Alternative implementation of the Bitwarden server API written in Rust and compatible with [upstream Bitwarden clients](https://bitwarden.com/download/)*, perfect for self-hosted deployment where running the official resource-heavy service might not be ideal. + +📢 Note: This project was known as Bitwarden_RS and has been renamed to separate itself from the official Bitwarden server in the hopes of avoiding confusion and trademark/branding issues. Please see [#1642](https://github.com/dani-garcia/vaultwarden/discussions/1642) for more explanation. + +--- +[![Build](https://github.com/dani-garcia/vaultwarden/actions/workflows/build.yml/badge.svg)](https://github.com/dani-garcia/vaultwarden/actions/workflows/build.yml) +[![ghcr.io](https://img.shields.io/badge/ghcr.io-download-blue)](https://github.com/dani-garcia/vaultwarden/pkgs/container/vaultwarden) +[![Docker Pulls](https://img.shields.io/docker/pulls/vaultwarden/server.svg)](https://hub.docker.com/r/vaultwarden/server) +[![Quay.io](https://img.shields.io/badge/Quay.io-download-blue)](https://quay.io/repository/vaultwarden/server) +[![Dependency Status](https://deps.rs/repo/github/dani-garcia/vaultwarden/status.svg)](https://deps.rs/repo/github/dani-garcia/vaultwarden) +[![GitHub Release](https://img.shields.io/github/release/dani-garcia/vaultwarden.svg)](https://github.com/dani-garcia/vaultwarden/releases/latest) +[![AGPL-3.0 Licensed](https://img.shields.io/github/license/dani-garcia/vaultwarden.svg)](https://github.com/dani-garcia/vaultwarden/blob/main/LICENSE.txt) +[![Matrix Chat](https://img.shields.io/matrix/vaultwarden:matrix.org.svg?logo=matrix)](https://matrix.to/#/#vaultwarden:matrix.org) + +Image is based on [Rust implementation of Bitwarden API](https://github.com/dani-garcia/vaultwarden). + +**This project is not associated with the [Bitwarden](https://bitwarden.com/) project nor Bitwarden, Inc.** + +#### ⚠️**IMPORTANT**⚠️: When using this server, please report any bugs or suggestions to us directly (look at the bottom of this page for ways to get in touch), regardless of whatever clients you are using (mobile, desktop, browser...). DO NOT use the official support channels. + +--- + +## Features + +Basically full implementation of Bitwarden API is provided including: + + * Organizations support + * Attachments and Send + * Vault API support + * Serving the static files for Vault interface + * Website icons API + * Authenticator and U2F support + * YubiKey and Duo support + * Emergency Access + +## Installation +Pull the docker image and mount a volume from the host for persistent storage: + +```sh +docker pull vaultwarden/server:latest +docker run -d --name vaultwarden -v /vw-data/:/data/ -p 80:80 vaultwarden/server:latest +``` +This will preserve any persistent data under /vw-data/, you can adapt the path to whatever suits you. + +**IMPORTANT**: Most modern web browsers, disallow the use of Web Crypto APIs in insecure contexts. In this case, you might get an error like `Cannot read property 'importKey'`. To solve this problem, you need to access the web vault via HTTPS or localhost. + +This can be configured in [vaultwarden directly](https://github.com/dani-garcia/vaultwarden/wiki/Enabling-HTTPS) or using a third-party reverse proxy ([some examples](https://github.com/dani-garcia/vaultwarden/wiki/Proxy-examples)). + +If you have an available domain name, you can get HTTPS certificates with [Let's Encrypt](https://letsencrypt.org/), or you can generate self-signed certificates with utilities like [mkcert](https://github.com/FiloSottile/mkcert). Some proxies automatically do this step, like Caddy (see examples linked above). + +## Usage +See the [vaultwarden wiki](https://github.com/dani-garcia/vaultwarden/wiki) for more information on how to configure and run the vaultwarden server. + +## Get in touch +To ask a question, offer suggestions or new features or to get help configuring or installing the software, please use [GitHub Discussions](https://github.com/dani-garcia/vaultwarden/discussions) or [the forum](https://vaultwarden.discourse.group/). + +If you spot any bugs or crashes with vaultwarden itself, please [create an issue](https://github.com/dani-garcia/vaultwarden/issues/). Make sure you are on the latest version and there aren't any similar issues open, though! + +If you prefer to chat, we're usually hanging around at [#vaultwarden:matrix.org](https://matrix.to/#/#vaultwarden:matrix.org) room on Matrix. Feel free to join us! + +### Sponsors +Thanks for your contribution to the project! + + + + + + + + + + +
+ + Chris Alfano + +
+ + Numberly + +
diff --git a/apps/bitwarden/data.yml b/apps/bitwarden/data.yml new file mode 100644 index 000000000..58192b246 --- /dev/null +++ b/apps/bitwarden/data.yml @@ -0,0 +1,20 @@ +name: Bitwarden +tags: + - 工具 +title: 一个开源的密码管理服务 +type: 工具 +description: 一个开源的密码管理服务 +additionalProperties: + key: bitwarden + name: Bitwarden + tags: + - Tool + shortDescZh: 一个开源的密码管理服务 + shortDescEn: An open source password management service + type: tool + crossVersionUpdate: true + limit: 0 + recommend: 0 + website: https://bitwarden.com/ + github: https://github.com/dani-garcia/vaultwarden + document: https://github.com/dani-garcia/vaultwarden/wiki \ No newline at end of file diff --git a/apps/bitwarden/logo.png b/apps/bitwarden/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..e7c6fac3dd3b12905c9972dd9089bafb00c003ab GIT binary patch literal 16591 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 `pfW1n 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 + +

Lsky Pro

+ +☁ Your photo album on the cloud. + +[![PHP](https://img.shields.io/badge/PHP->=8.0-orange.svg)](http://php.net) +[![Release](https://img.shields.io/github/v/release/lsky-org/lsky-pro)](https://github.com/lsky-org/lsky-pro/releases) +[![Issues](https://img.shields.io/github/issues/lsky-org/lsky-pro)](https://github.com/lsky-org/lsky-pro/issues) +[![Code size](https://img.shields.io/github/languages/code-size/lsky-org/lsky-pro?color=blueviolet)](https://github.com/lsky-org/lsky-pro) +[![Repo size](https://img.shields.io/github/repo-size/lsky-org/lsky-pro?color=eb56fd)](https://github.com/lsky-org/lsky-pro) +[![Last commit](https://img.shields.io/github/last-commit/lsky-org/lsky-pro/dev)](https://github.com/lsky-org/lsky-pro/commits/dev) +[![License](https://img.shields.io/badge/license-GPL_V3.0-yellowgreen.svg)](https://github.com/lsky-org/lsky-pro/blob/master/LICENSE) + +[官网](https://www.lsky.pro) · +[文档](https://docs.lsky.pro) · +[社区](https://github.com/lsky-org/lsky-pro/discussions) · +[演示](https://pic.vv1234.cn) · +[Telegram 群组](https://t.me/lsky_pro) + +> master 分支为未安装三方拓展的版本,通常包含了最新未发布版本的一些实验性新特性和修复补丁,正式版本请点击 [这里](https://github.com/lsky-org/lsky-pro/releases) 下载。 +> 发现 bug 请提交 [issues](https://github.com/lsky-org/lsky-pro/issues) (提问前建议阅读[提问的智慧](https://github.com/ryanhanwu/How-To-Ask-Questions-The-Smart-Way/blob/main/README-zh_CN.md)) +> 有任何想法、建议、或分享,请移步 [社区](https://github.com/lsky-org/lsky-pro/discussions) + +![看不见图片请使用科学上网](https://user-images.githubusercontent.com/22728201/157242302-bfbd04a0-fb30-4241-800e-cc2b1dad9b19.png) +![看不见图片请使用科学上网](https://user-images.githubusercontent.com/22728201/157242314-5716d578-fee5-4083-8d91-0d98cb2545d9.png) + +### 📌 TODO +* [x] 支持`本地`等多种第三方云储存 `AWS S3`、`阿里云 OSS`、`腾讯云 COS`、`七牛云`、`又拍云`、`SFTP`、`FTP`、`WebDav`、`Minio` +* [x] 多种数据库驱动支持,`MySQL 5.7+`、`PostgreSQL 9.6+`、`SQLite 3.8.8+`、`SQL Server 2017+` +* [x] 支持配置使用多种缓存驱动,`Memcached`、`Redis`、`DynamoDB`、等其他关系型数据库,默认以文件的方式缓存 +* [x] 多图上传、拖拽上传、粘贴上传、动态设置策略上传、复制、一键复制链接 +* [x] 强大的图片管理功能,瀑布流展示,支持鼠标右键、单选多选、重命名等操作 +* [x] 自由度极高的角色组配置,可以为每个组配置多个储存策略,同时储存策略可以配置多个角色组 +* [x] 可针对角色组设置上传文件、文件夹路径命名规则、上传频率限制、图片审核等功能 +* [x] 支持图片水印、文字水印、水印平铺、设置水印位置、X/y 轴偏移量设置、旋转角度等 +* [x] 支持通过接口上传、管理图片、管理相册 +* [x] 支持在线增量更新、跨版本更新 +* [x] 图片广场 + +### 🛠 安装要求 +- PHP >= 8.0.2 +- BCMath PHP 扩展 +- Ctype PHP 扩展 +- DOM PHP 拓展 +- Fileinfo PHP 扩展 +- JSON PHP 扩展 +- Mbstring PHP 扩展 +- OpenSSL PHP 扩展 +- PDO PHP 扩展 +- Tokenizer PHP 扩展 +- XML PHP 扩展 +- Imagick 拓展 +- exec、shell_exec 函数 +- readlink、symlink 函数 +- putenv、getenv 函数 +- chmod、chown、fileperms 函数 + +### 😋 鸣谢 +- [Laravel](https://laravel.com) +- [Tailwindcss](https://tailwindcss.com) +- [Fontawesome](https://fontawesome.com) +- [Echarts](https://echarts.apache.org) +- [Intervention/image](https://github.com/Intervention/image) +- [league/flysystem](https://flysystem.thephpleague.com) +- [overtrue](https://github.com/overtrue) +- [Jquery](https://jquery.com) +- [jQuery-File-Upload](https://github.com/blueimp/jQuery-File-Upload) +- [Alpinejs](https://alpinejs.dev/) +- [Viewer.js](https://github.com/fengyuanchen/viewerjs) +- [DragSelect](https://github.com/ThibaultJanBeyer/DragSelect) +- [Justified-Gallery](https://github.com/miromannino/Justified-Gallery) +- [Clipboard.js](https://github.com/zenorocha/clipboard.js) + +### 💰 捐赠 +Lsky Pro 的开发和更新等,都是作者在业余时间独立开发,并免费开源使用,如果您认可我的作品,并且觉得对你有所帮助我愿意接受来自各方面的捐赠😃。 + + + + + + + + + +
支付宝微信
看不见图片请使用科学上网看不见图片请使用科学上网
+ +### 🤩 Stargazers over time +[![Stargazers over time](https://starchart.cc/lsky-org/lsky-pro.svg)](https://starchart.cc/lsky-org/lsky-pro) + +### 📧 联系我 +- Email: i@wispx.cn + +### 📃 开源许可 +[GPL 3.0](https://opensource.org/licenses/GPL-3.0) + +Copyright (c) 2018-present Lsky Pro. + diff --git a/apps/lsky-pro/data.yml b/apps/lsky-pro/data.yml new file mode 100644 index 000000000..65a8dde7b --- /dev/null +++ b/apps/lsky-pro/data.yml @@ -0,0 +1,20 @@ +name: Lsky-pro +tags: + - 工具 +title: Lsky Pro 是一个用于在线上传、管理图片的图床程序 +type: 工具 +description: Lsky Pro 是一个用于在线上传、管理图片的图床程序 +additionalProperties: + key: lsky-pro + name: Lsky-pro + tags: + - Tool + shortDescZh: Lsky Pro 是一个用于在线上传、管理图片的图床程序 + shortDescEn: Lsky Pro is an image bed program for uploading and managing images online + type: tool + crossVersionUpdate: true + limit: 0 + recommend: 0 + website: https://hub.docker.com/r/halcyonazure/lsky-pro-docker + github: https://github.com/lsky-org/lsky-pro + document: https://docs.lsky.pro/ diff --git a/apps/lsky-pro/latest/data.yml b/apps/lsky-pro/latest/data.yml new file mode 100644 index 000000000..bbc3f4e1e --- /dev/null +++ b/apps/lsky-pro/latest/data.yml @@ -0,0 +1,17 @@ +additionalProperties: + formFields: + - default: 40027 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Port + labelZh: 端口 + required: true + rule: paramPort + type: number + - default: ./data + edit: true + envKey: DATA_PATH + labelEn: Data folder path + labelZh: 数据文件夹路径 + required: true + type: text diff --git a/apps/lsky-pro/latest/docker-compose.yml b/apps/lsky-pro/latest/docker-compose.yml new file mode 100644 index 000000000..d916808a2 --- /dev/null +++ b/apps/lsky-pro/latest/docker-compose.yml @@ -0,0 +1,20 @@ +version: "3" +services: + lskypro: + container_name: ${CONTAINER_NAME} + restart: always + networks: + - 1panel-network + volumes: + - "${DATA_PATH}:/var/www/html/" + ports: + - "${PANEL_APP_PORT_HTTP}:8089" + environment: + - "WEB_PORT=8089" + image: halcyonazure/lsky-pro-docker:latest + labels: + createdBy: "Apps" + +networks: + 1panel-network: + external: true diff --git a/apps/lsky-pro/logo.png b/apps/lsky-pro/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..91b87330ec6d2989e1a3c88d23fe2dcb0390b07d GIT binary patch literal 18655 zcmb?iV|N`)*FH&3*v2-R#}MHgYvMZ^4nAV+}%iahaWeli??fHOknlQPL!L;rZ)M;Eob zTxA}(O!FOcPm6FJuOyUALFBbrI4aD$&jghhLlo@e##uR~ zgh3Jjc1ZvLNXWpD5SOoQHAJqNKQwg#yFKqE0lbDdaZJ0*r!CAqxTlL{EoKi_b5=i!O7;?mdDv4`*{0YteiOq6`zC zz1i!vtC)HeC4`p;2S$oN@7o0aL9E@!y?_|G|BSMn+&d%qVRw$^SmZ$Ht-QMV} zvvL|5wKK90_tMxvtsK3wAr*@`i57Z|O*1xbV&6%}0VJUP@H`J_)?GODjoNMGFv8|X ze6ThkcJG|X*P-#R&r(@r%9X-XB>VDQcUCi<)e;*Tb^l;U z8YppO;%K|&0;ETnI47mNe4ZYSh_H;I4n=NZ7~o>6^DWxurJ6Gxj6@qZh)Ko4s4Y;* zyehQ%3@$S)ci1s#y0u+>&7ZdL5_K)z<*bSoG9%>@HYUPC!(LzoGa^;y-RIk~MHr7J z4n$%+xG^(-tBsHHB9l*J6^8pBDg-G62LV;U0)u?)$Xc4>!c4FG@pJZ%7sks|L!uk?um_mI3{(r}4?5CcuMICR%Xd>p za-CFU!77oVLa+r+NWcQ<91`W=CLB`Jdm{K)oYqZXv9f__tDsZJroUto-8Y2e8SmGJ+1=;QV3*O*9lb{G z^uHs$DwfR#jf&QXPz69H*&(bv-tUSMLkPL{YzTsJ zG4K0`%*-CpX!m1OIZ&ZS;fqep^I&0d%STJ5Bqoif*MSrs z6cyRmyH*iPDxMaGi;DV*_3%M=?x#8r%?lBsD6XYxfgrRm)EKgORiPc}kLV0Z*l8672$SDtEsM@l1n<83+vt z)RsbDH3s8;(Vv)VgQC*OJ6A3ZiRiuuf^g8tsqGrZ)Cexl{{gC(!<`q59vHS-Q^!g& zAmjL-wu5ft=DnxqHOB|eQZR@K@7@f6U_x52$^B6jhXst~#JLOhn)+#V^g-+Vdx9@o z5XhEuLJ-M<-sHwo{WbhK_cYiOezWED!fXqjYsZ!~EUS_S0A3b-gF)&Oq23c`rq4L1 zj7N{TcNXj4|633o7o3$YXOuz>er>kc7wowc!0YKmGz_mPDE>*!t(rOT{-YX7h2cUrP0IMOpu0h@Q+z9%+P)$$FAKX> zYziSJJ;hq_(7_8AHT@jTkn-*dR88gN{Grj*6ur(PSY~<&nWM=Le(_Uu>OV}^KO{qc zrIWUac~>$f?Y&j<^*Z7-%KP_}>0P zY!}2G9Z$wlkIQjl{h`2j-rp~2GUR9CU}g~+Wy=O;$N@EC0L6*HNhU5cZb;(XRHVCM0LABw=?3iD~NT2A$sMtH@|)p|0* za0%Yto-ui3k)WpXa_2p6rl4mPB{wzz4wgJhC{0{UE2!yqAuHd4n$M@Q# zms9ZNHC-Q*)cZWdd<7v3_-h}@NDc*%8(XNMKJnhcF;9j)gcGV(+fZDkO|?V76ba<` z)}NfMUWuaJ4p^#&lr=8%C`!!+shhb8R69E#M>t0rUkt^luza^sg zuN8rvAw&qlE2x?MSz+q_3?RH-8NX%t+WA*8LOLx1)3E;qa@Lg9p0!jpqDv(2e z+im6eoK?WvJDe*(4kKteBEgr>@nxSimIY$JZ_67|(SPTq|2)4_fo3$;%NP<-VZZra*zo20@SED!#>kz3p^7>MSUh3IUg~{e2KPbAf;ByoRgM}P# z!&)x#>7;$3`xXm(RRxdOQaFj}3O@*y0VF_$;hE}6zf!i6j01uwRVKTeD<04%EJZF+ z+@fK-=I2M<xhe*h7+srDIK73XIZG_` z0Vs45cr&|d#yc)s#}`Z28kA{T6?-Lb^+(y=0EIL)J_Rzzv&T#0UF(0#Q{q1#o5iFHl1f`#A5tk8f zQGVX_PuZHD-FX`NbxYjHV~M}wIrw59aZ^%If55YlQXo9=4%AWtn+6B#jbq+Hbx3c) zEUdNNeAeJ;|FnnkHab>4dziWi#5HvsB(CS|UmXIjnI{%I@jpG0UVY7CU8GXNhr$m4 z7@+s9jMoXTA;bfJ^US`}{TIhpkEwqaCXC6DuaCoge>{=2Et8D_p}uRxBlttpTn0kl z!qQH8*ZEY`y^W16RXoDiO z*!1tnKprZq5)M?X1Vk)qN(xU4Q8j|Tr%eFvQt;KxV>pa@7#^hZv!@KkaIjPEW7RS| zX`nROihA)`UBFStdp6$Ba!lJX`6xyM4o;5sb2FndsyKg&UmVJ9`aA+}9wV|oPwf$O z=zdz?I@ISYpS`=QHe-d6{vIfsCZ>Qo(=_DJM%x56%>_}t$IJK z?o?flhe1I?JGY?}Tf790NEvb%0%5x`cKV$%E!^R3|J(B|aJlOG#*@SKl;=C?_yX!lIf< ze%M!6n#+Hg*44go6OadJ3_iTNdWYs_c{VU)M6Xc@?v!+ovy)Z^2n%0BV2 zx*j%bP!%mm=g;}~N)|3=V#c++xlVAw&j45kNP^$LuU;{3Jht{E4PDtJa?q6a;;Yfk zAP0idG%(+hJ$VcRichZuduMSL2EBRUIuSnuZ>uSZSQNaO6(hqlBT*N9xmhM_ugZxqfe7FL;W%+ zBxX6{bLq_S(j;RZoKP?K!vzxT%#a55$pPgsY&}<)PX9{&PIe)>^LOzn@bOz&eN{=D z)yg1~4zBA|2?#I(Q3{_pKa0yXEk5sVsPy@>Fsp{s&d+cvuCP{k#V=}(I zs4~9K(f?%Bm4OQ)d4alu_`;vXEwCXV0ZWL-F(BFz;%yj&#~~p`5A@?iC>|i|6Gh+SK-%aT&&Lg^wwqj7DAB z#=j?$Dx&aggCq*gh%cjz>WT3|k*3$O9@TPgbrM-*-TL&yqWoxUygxiOzwd&F5iMGY zhwI84FUAn6Cdd3MtAZCOpt;x`(M+$3R9A|gDgcT`ozzl+d`6CDL(|}!Tm)v&zMUkJ&5!Y9igJUQRVESGBw*>aPKo*}y zi{PW$Fr92HP_ldOT;e}oZdjNfVXJbxPG{xZJHv%|CDt|-HjinHJeqcIO~rJht-Qwn zv{we#qHR)M(YbZE6KCrNAoyOf5KG4F&Kwx=-T`J!w^_8!zh2Tyrk)j|_7z_GZN3>D zg(@DK_~$}snb>k(wv+FB68YZCerjI$Jz@=kPZgBr^4C?@$~%R5_8gB-l--q6GVX6k zAcUin%@o6NE%KI~|88l+ZRmCPHqRXhLrk2z}0Vbn>Kcmi1 z;)#h~K?W{u^6Mo&AG9a8`*0ZLR`U~r)hHswLvv3_k3z(4+tqI9%fwd83*`Fr zvacXGC=w1eE_o7B1fX52w810b-P?STNQq?lx%0KS)$;3pMw5bP9=;usJ`fHdlBFsE zc;SMA5a(##br#)V0r*MO_+2_Lf})~3))}N7evp!OMT z>zCMV=oWM8@oC7p`gEQfxlXSXJ`)}YbTSzqojV)}u_#g1?gQlkjp9P8HOTk^*80zP z=kl#7X`O>>9rWz;bTJavm(+!_aKPaL8-XJ}ykw;v^fo(fL8m^zo*X-0$?%7^5ndMZ)%r{umYGM}o)I(;vk z@qjQ|x>eGz0t%n%6g+gs67jz>6~j`b_HW30m!(p_GO64I<1l8}`_5+!d(O7%5e>?= zj!qZwvaA=QpRk&<+8;qjA$hEG?#S&0?2cg&3VvGSV&9nUYItUlM&`7tG z;wtK|*Fn9_r2(P`t6Nj-9cHRsA@T2Y`GCMPx`!vC@Q#p?1hV1)jjs|ZEcmvFprscM zgZG)Xh9{_=B+*0A)O#!P=r$pi2*XKt^+fxs&YyXcpW&i$AU8cZbd><|xB#R+WJvul zbJ>aYR!Va6FFMlQOe*2PUV{Gxs|8%fP0t>3}v`-6Z;xbHMvhC1>)B)7V=+* zE56i8STZcoiSQ(-LJ#@FEbe-fFxS+XK6Fy>H+2gIfR3sLG}M9yxD2a$E|3<1;V9~1 zbGqSYXY5_emut=1L+cSK;uY+`L4>=I&Cw1-@e)k*HyW~E0|ZW!d+nt!nAcuekmf-j zwe`2Fo#^QDoFjkvu_&WYOskhud|-N46U~`S12}oSp9I&}m!CQ8)k6$4yoIQ9ISt0I zUs0Z{2n5{EOxGXCwO>}{qhv{6e^W`5GvQEi_^)WZ4yj7k5|n3rI~vBwrp$~f+saPC z#$=pM+#`340sMyO81G}hx?VcHG)q1G3ybt3=oSYSgcKqtp+LZsHcFFQ=mvh@788WQ_p;&`eDN(VQ_|1OGm5kr7H5*MeRX2RnnxbarBV)ftLtLT0X zE_eI(lY9I8zSA9JxZtD=>p@%lC{uGX&fw(Yf!IZt4pQJ<(c<2PaY6rUk;p^I4ADD- zYu1!qt_7n^jsrXYF{F)*do!gh6AptjWPLEu9r56WQ);HSuT1rC1po{ydT2z{Hv*9l zfHV2iG~_C(vqwJRyH4&hn?n4vwvN%M+G^{Pr)B^thWL%J`RSIWrZ_rS1WxoB6%vw@ z4G!g&@Xvwak1{@t3!D7^iItj`=3|2iEfLUKr5cM|zIlj>@PjP+Tg{Sy?$2xcCp%l4 z+n7ux$S5=^jJt~3sVqyH$t*mG(s!Hw)N9AR*RQG`@P19MaOc6WLh~>tU1Vl@fXRl- zyuG3?=TT?9M|nj!pJY0WVlKi`MF`c0<)lk*7{T{V6SOl2-TpNY4 z-~bUq9M2}xqxKP5NndH>S~x3Src@V~Yc@A9)z0QtY?Dv#!s_oCdt4@U(Xa8}85rXX z_RKM?s}QbCNxIgr5F-MiX6fx;xVolj)Hp@Qp;2QHh^1aF*QSTNGC62Fc3kCt*g}A> zE8P?W3OH?#fC&Sx_%OWzJXjJNR-?YRJgO=)C3=Q-_WqC9?CkR`T)FsuIfG)4SH+=2~MloM)yUU2w`!UcP^ z?jI^2FCAdBY`oLPns%OsI?ee~TQ>b|=6H3oDzsdf9kF@S<~>XQ5D{s%iaD{A6NSIH zRDUbo&c3^9pHL-=1~G+oae{6`fu*aRp*5wJ$-zO6`pO12oD1xJOBg0LYiUMNdGQud$G4Q{MInm`R2$U zQi?Y87fnoZS2qeWxl}9KrBtUTP60C&vo?Ihz`l)hhQQ*J#NG+~CHonFI=*6Y;K`jm z3d{lMA@3^NX6(ei^HYCk5}O%{r7a?+Zliq7ZPHf$rCT$Y72GUQq5svP^XN*6bMT+m zyuTW#z-b3E$*5ahA>ik_5&YYqyMpDaua4TQ-EB_xP5+hSkl!kifKYqQR1mjsj!6#P z#CBAy-qJc3td6?hXZpD8r9D#PZ;}DAOG-mlf%z2dh#58|9F#~IB@7>JO(sO}}Ga4rr7XzBKqtUi#IBv@_FZ>%@@|3UEXOfRhP*kT=+O(@$(4$%W*lk%YDE<>6cL}8uPOK9Y}s>rz> z3F}%5Sb_Fa@;IILc{c2ocko~dEk)X_AOR3486CoWD2?U>l;wbzFhbaC1x>20t-Rhf z-Q3bYYHBW5FYP^2daZBO9O$2G+*={`i-tDf_v$zO zZq;P{RdQ1NJk!6~EVl^wRW2)LTjaBUmcDEsg6U4_e|ZlPq>uOWu%l!Kj$^2mqIka+ zp+RH9M@oIJwp$p(lOiys4z3rHl1YO=?E+U(IpR)!-U)Btxb+`>>ylNmH%u~ap2yhc zh=CXsPzgb#XfTeD)#mDEU&mElS1yK!tvagd!+$@WvR3)l8QwM@X^xptAffvj z5fMGWJ@vP*$%dS)V@dZ9MWdIAFl1kQjB&DHx1oAefc>k%WX(iC;@e)hV&~G9_jFK| zg8!zOAfe01%K3i&jnoj37*-i~$IOTbN#1ORy+_?bZyDzyIlv4UNRFzF5-B9ELL!5) zAOwJd2)+95FdPrWH;UN>dbl7 zqi7Bc6#XW8%YcA@ttORYOoW@w2{PUCtMQs-4{%w2KG$;3p4Ud);g#LnPv02TMQcYe=h zRc-UgJNCCy-MQh-j2pR)-|+W-M1+n|vBg1)uQUsrps6eVyeWM*88_W34PB?vWs8G# zZB=@wG)wB$Jmb;&IMxG%({Nur#u9jnENN;8R0xI9S&q@N8uzsdBLX=nId^8CjlV7U z=y%m-zs*A8;koT-U6CgcSCKzA5?)7fti#jKXHc?+Q%Cj{pGcU3gVE!1q3$%!W{x>%s-nE?{rJ+BW)5RH68|0z8L__XM_7~F_J2i*}{-lJ_ z>`;-y(%U>iXx()daePmRt z4NZ{5zXkckY9rI9&Jm6M(V+UJQ{l6f3W0%E$OXx{wP>SJH&=DNeRc(>WpbsaXWfV? z*Q#|i)ue+h&z?PREQY!$Knz~p0-tU3@(_KF_f|py^14{wQfW&w()8|aJGEP#KMw`X z7P=l4?gts`Y`v{~!Mvc@4DHb?;D+t=Z76J7Oe$2Eql{>bLUJ600eAj$c?9(D} z0%vD5er1jKx2?K5OMt#ttD}p2OtB04y5;)A|APOv4)5j0>oBgb{Ye9T2yd{?a^SU^ zM0kXFWSdM~*@683I)(;Iv)ZoCavv3i`koW0ra2LDDl?_-x^gCy01L>%s-*vJ^)~Bu zA77RVi(epS7C`J6m^}U99NQCEf97q1`&?tp46^zY%9+D8b#;mT%9<~4W%4!Kd3b}jRc!n54Xq<_6leZaSrS>a zaT*6#?2OtVdR)EmIEt4zCiC)>vA3+Wkn^nb&1aBf4w4hB3+2H`d5Gid@0aUrgB`~l ztceI0JViH~Pe#I4RfS^K;yE}&3cUt?sAHnGVGCD4#~LRyn65<#$PKDepZeL z@TtF z$iPBZOgb$Fq}pIScLYrux=#`(E+IkVD|Oxyc0b)d=gL<#`rIG)%WQeIj+w0QI6W>tDg`M5xx zUsx;YgA@$28|{3&?ybfUa08TGw?bc^-uFtgu+f47ZMH#D$lL@>E8+_QyISwNHL2Uq zR!9|{wbp5XOso=;=7ZDP-?Z4)nl;87RJV|fxB*P?WJm$TGw7XK0l|X-&yR|mrvJ? znre?R#~9zkZW8y2WKx|l<_ivv-+dGRmz*~iTkzY}dfru}sUw)wvWPA4X`4(k;95^; zxbTV8P5A@0!=ok=SG&BMK@SlGfk6gjDk?-JS{RIxII6OrO+CXqIaF6;tits2qHS8^ z*wpQ;s~S(n$|VH^4w35O)~^Fi^g`p>n0clqja3Teld!Itp*n#OGIYX?8_<%jXh2mA z9`{}g%Q{zTfKgtKJ>_gvRQSOVfy+{c2s1rxd|bB5BqEm3ZIB}jB+}S%@P%7oCr|$d zQaQsh&EHeIdp9aX@4}K~P~CgE5!+)DE&6yAa^A zR_C%#zE7F{q#PYbr?5EJtF=6oiUdfeWP2clfo+5?cS0tFuPlqH7;#)s*L=|kH&NMj z860tL+n>+ZX@7OU7r6b#yRXFw@$b|0Avu<2w7-HuVSD?Wnt>;&J6!}`cR{J&57?@^3!Gsz|m}YW3O?z z)bB3w*d%fZ&a*1J*!@~?h5HdC_#yjzwXW0Y_4)16XIzoG<0Oiss^o=NHdOi;Q=0kd zbp!1%A7#GxQ!Ivs1WzcI0*(yUffv%C-YsnZoc~NvzBqAnaD0w6>4)M2}Lmz;Rq?wW0~R@%=!4ZiwSNl$y_ZMC7AZngK@DJK{W9tMCm zG8dUf#bIl5A~cM78-5mFzOTw|@vn;8l-G_)``~h!joJP> z+VX6z(auP8_p-U~U-~BSeiTA)g1|DD#Nc=JqgE|VE#PBqlirNiXY)Z^J~HXY@pOPt zh89<{#9xe%C)7Q+rmb2yILPv!kVCUth1V->{jaB`slV~ZVfFl|P2#$#j>Fr^$W*^W z>m6@q?uCRXLDHbIUAxw7-j)roSy-E(0O7LU-`sjtU+_#!eVBMUvgTB$V6@|D?G+Uriyx+@y~BT^ z%45mzNjzUzjae0Kulk#VuUMY1J#%rm?THTK_4&%ir{a%u@SfS^?Aq|eQk{ct>*;Il z_>;ebXY#intoP|ZKY!8;YL$B{+)B?XM(%KOKJ~6Youn%go;IqeEA1mn3KLJSs>m64 zk@DD8Q*(Iapk(qQ4R4rIV3eEz$9Te4OkiEyMV7u_uWq^q)WukqCsJ8cOF}){Sq5vU ze{&GeT{D~GHPWN_&ZHq3jR?``$e<*j3E=PWI~FUU*4wCk`Rhq?+s zE0x@4@H#tTWUx4O0HbBPgN;2tOVhJkdcdB8E!_}`h{*vRFGv&B?XqqrYDgH0J6hi% z10zX_;Dn%ZE@#$xm#o$~YX$Ej*gxYOq%%=7{hk{BEMI7siY%58@^V}w6QFztFSh$< zyG+HU<2zWbof0&S95p>te`jA`T!H~00$L#Z#AF-TqvwaHB+yN8lH^G^0)H-Q64<0eVoHY+q2eQ4u)FERxZ`6$rmx7@hUjdkwa`yhZ!wdifW8 zx6~6^=G|RD&-+9%`PO-gW(ZRwAC$4eecU8?aAL`UPoH^7;~wkz-@`J3P)SabSI;Zm zAj|)ifNM5V+y;|6DZwwPPHCoHO0UDRv`;m9v-kYTw#@Lsz*&+Ul9O=8ahmyFpHJBa zJH13^a8c*5o)k(l@9FK5e&;)e+kUpqc3kgSa7(1D1--cS79<>5K^0tOS=bqb>P8?p zvt}MMhbAabEyH^{{x0WdiOrh8W;<=hvrc14BcH&ux9(brvKhQrnl|cwEGsk=glc;) zqZcC<5hlD?rpPikUXOG2`j^3bqdNYYh=#hGlzg16Zg`X?D^yNZ0@Ko-rf;JO*i_X@K*Dly=G(ZGXLJoS6HQ~ z_T;HL{+E-_7?0I~dwJ6+uTF#L_2suuc56B`AE8`EW|m2h_ZXDx$ALJ?VUOmS!|Z2g z`VJ z#pUws>^TJdf^U6PIz$qPdShiAP#Er2Twq7u2 zIX#J-ob~DcMMLPfw$qRi(3=M@jl=SKEIdwp#|f}o&4=Ymt&t=%n@eis@ zWgmoQvCd-GM04ShU~bh}uXE_nft#jGg2oYysV>sXGfJ@DO?IYvKTw7mNKjRqZ%mZT zx|){SXmsI`cJTu8PH9T3F;s4T15Ic3o_V}2obCnO6Tj`VCi~YfP>tW5Ah-_Po+Wx* z3u;dSP^6O^&5WT)hs{``y1x#tJJ+qp{q%X4rJaumYJEs04j7w`FSikPQX&{f=G&Tk z=D^+8wN0x@Xknp4WVKXKR~r?)1Wv}_64}d^m!XVI^lOLBhE~3nbmF(RZeXACeZN3I z9XbSy#mxFsZXVBk+0WFw-3{LS*Zi>wFgvUL+N78X0h!o0xdlKXLP9xQRCEF~6kQT- zViKl_+-)0GkK zyGG%{HI6xHn3g`K!N(Z1v%JoQxlL14{(534G7V>iylBQs~A-VP`33%UM@Df)l<`nwD?#!*NI+8JT(B$y%Tv+;BCr*ab2bL zP?vUXg}MFd`gr^CSm(X`hX-f^lD zXBW8GYPWPYIDp?hR2lN22X>cWo)T10MuWd6TLMi87Hjb?TnIMQcPqDaPI=T+_N}Sv z9ywC4?KcVMXwofKryEMM&|H$~rMYoiCO;~aEvCjB%}s};G+Zm}spKF?foO^Ut$Y3V z%K84~JM|tRz*Ta>FsjXTT@RxD*1Z%tUAes7b$BlrKx;Cblw>yEwYzK>wU9F3 zIDi0yzCpOC8|Qm>XP3(>fH)47=s3-ftQ`}L6>={Zkg);SArMOvij^pTeAFc%_J2`1 z$9MRCruF8E!XYf^17h6P7Z?`-^=F zoe5)EnH-fwe*Hm<^US`D2np!EJnW`5IJ3L>i~Vs|5fwF`hX3i9@cCj?|)B8shE;{Q-|`_KB=nDuGVs@T^(h~E=a{jO?cwPi$dh8DL9E4 z<_e(qkx9XW;ZbG42O*^Q)#}wb-`g`093TpArY)`+5kLQ0b`p?)m#c4?FgcTnq!f6+ zwZBLZ(PMzkZ~n%Il7)D(qX+v7ax#rs9R6=i9>CGZp^iVVR#Cu<-T6u{8wHcyrLPng z;D~hO9->9JirQ$gZQc8{25RZ`Ti4@Jg^MY$7*;e)vB$Mp%nT6!20Jn$iC*eqQGi0F z7nV4hVJkn8XDKta)bCWCPk#+kDcr2b2SQQ-Xl*Gi8_%ShlM5d(HnA zdR%>C`fr}|O-px@2Y{Q_FA2Jq;~+-npYoqM6}v5dD~vKDCm4PKpXyn$hxMC`MDI%% zAvUw@0^ZlN7Pi6ei714Z4tBgs^H2ad2#-$EpX3-?(a~7CclWY-B_*PH$X+x9dxw#% zE2@aW7;%M)@UR_&(w_kUpFvP5K#yqvYp!0IOpVydscGkt8U$)7LR1EdD<@ol+Rpwq$*% z{{B9$kYQZ5TH;TYcK3mR^R8o6@*CT!U{oG1jfJk(qgEfo&)KV^Tt6bdgA#)bUQ$vA zEV$cjeBr&T%9Ct58!Y8`>-X4h=u7fKr#F?xTp1M}&wmLpUZ6AT&Q>>&_stA zmUN2C)2D4jPB3&X>S$$fw?T+1jzVvCBl({17`2h1AfTrfFd^nQ*{^?G^k~-du57ht zLI7AB>atRK?T^UBAM;KuceFcJ<5PpVhu*{CP z1$?!m+j?nzwmu06B=-qtBHg{?Fmg z>_jhZi+#PF#{w?Wjp=G@7kRh^J-fmZeh&?_!OJM^=P?-$E`PnZK(_CjL30+?U(f(?~V2x{Tf|?L~P`cMl zNz1cUEz{=lt%Y3P8|7#Qf^-83i`$Q?TwP+7|Kub!)$`R>=Cz8%W z*J4u3Qs6iz(1lAs)J%1hYhIkpy-WyEQa5XmLT5KTSds?p_@!?Mo_>T~3+A2S;{5lm zs-gm$0Sy|SM^*8Kh!m)>7^R`;vS?&6>I&^_Dl(g4^^N$OYmLP;QJKSZ-W1BGS2$?} z!60|rH0=ID1*eY1B$o+C^XSIIeny^$+D4qI#t|66>_B4teajR!=BG} z2Lo@G73Mi~=gWCk#$I*~vXapMS)oFv?J9eY7xNUoWuc1L$d@tk#P(yDjYcY1 zq?EIo8eJ5GcuC|ABx{!bgj99QJib?5ezWl4|H?1BvlR0LPO590;V6`3KriZ9A)@4v zMSrCNm3+5)iqB5F>-3%@_yevqdp0MltB9qd^8QP3A?(8D%q^uRviMsuf%V|Cl@kPK ztYfOMgE^HvK~?8(>YjLkSM&Fv5*Wkyw|lM4?~ zh>^t@xyT)eeX!!jBgAF956X3r&qw<&Ki1)Ti(XG%)I^e)Z~=DAK7yIo$NU6_kn2|? z?9xJYz{mdZG$$*FG>MhfZPt)wIR7l5Pxsu*_{&C6tKl$if@9I1=6sr~v6Rlh_4Lnq zJ_$)h<(265`Y*_-V+1mn9E4C<1E6=@TutKsw@H)6Z&3Qz42;{~)#>3^5fB45I81Tp zR_eLaKKk$%9ML(19UR_EcYhClb@g_g3uOx@2n$cc&4+}9IKiM|Fsonyg@+B#1q~kO z=OX3|x8L8!!Eqk9f1vLf1kSS}ggh%jO#*xDAKg=I@tiwHD$$YBKa0K-O*(PIwpI3V z)Eo8u{4uh$T#}c|o4wf50#kcl*jNk?aqlf$Tx5=We;2+HhP_0%F6oxt0(Rf7TGr&L zeDE}(D=LvvLOJ<(Ac}pC!~tBWkPl}k@BZkEetWcWVDx#Y%y;O%e!G-kf7h>l+LK-e z^)kJ$MVR*I5T00OqXZ*ug)ub$*zqf$wWj>MkvPeMRW_OKoK5o7=!^F|oGE0vx_!Ak zQHsn$aje5OHYJ}_EuCaBH-p}MU?T|K#L{v(7<_b5HP?4HQ@PcjFQS|tizsulXo&tgwNbB2$U`B_huy(iliby~+wveSWUu z_64q?ql7K`3n`ER*R?1LMw?q2(wqP1`Hh07c1N*X zkpuWYuB-u7)4%^cC+9yZGQ%Fiq?2JA{yDA|EX>qLHOhqg1AvrUU)=M{UC$wu=yZ;# zKH1)o69Ncl6xv_>K2za3Q0(J4qpk~fI{){_h2z8GFfYwvEjT*vI;?R%`o50K=M>#3 z(Zm9tM9CGI>o|y*cP}2^%4I>*ov<1%BgQ;dZX81lDg)2AG`_auS4$bTHhO~v@s>3r8JYN875w1qox-vWbd>i6ZusHqwaVmU;}aIiZ+RXVLS$u znQM~GbYC4=ooO=ZL_$JYyU_Jc%pW%WdfRiE_XT4*K2y=Iyr!;vXLY_zE2}%cl)m6l zlM|l}!+-pbt@Ldy4ySi;$=!iYgb4SoTnJaJL)X$yt(?$&q-*?RL70WD+0B?uZrOZ;xJJKIX$u!+juCP2dfhy9OrX zy8Khk|AOM`PyfiH^i)p;=U+=3oeVtZS=umTNmZKk-H^;I>3zy_+?gmX@qHFJYK*It+1wo3ofvgaa*GMVYeSA6i0_NwFVp zQ#`J&fiv&{`W@_m1e1v-T<8$Yf`SwT$Z`OvQ0V!kzz3t0I`#5h1bmy8$MlndmpK4r z)-ITnYdWn*6~lrtwS4U)<)K<&U1RRoxrXN`YAMfefm9;m$k2)I0Ia1&nN0llJ*uJ| zFz(%{W@BG#ZqF%J%v|2|U%@Ux0{M)x@Uw!Kg<1Tl;y2Y1%tH!s3oJbzE9GAe{5DbA z(SQ&nb$qQO9#XLFV+aW9r)1p43G2f`5}zR&(IEU53eM|nENzItJ5%@wR*G9O^ z@(~6~)b4Z3Ar+PvS5!nMuAd;gnDz=HGB)s>Mog4^QhERWtwY7ex^mC{83D!FWE4pY z@Rb7(!Hy#V&95dWmzBpu?KM0AeGK;PnIh1Y66*8v7^k0ybpwbA_4Uo3*==s<7}m4T zJRUXWkk#5i`McvRlSFf5&_(&#f8XTw;GpDxD@RWWX2RlekVI~(%fsD0>{Xeua%z9t zs6S?uiJ7K1&}!pbB+0lln}tIXGC^38UIfD;kOB=hV>WAeIXT!K`~pof|KW4UD@c75 zv?lieeN3VTNJNBCJkOY44OcS#k3jKROHVm`$PD%a8=i+>U|E2Hqs-EG<6y6R-Q@{@q^M}riiAjST`tZSYRE*SEyX`pg+(jBQr-b$%2?{EW zYQZTUPD(K(l3NDt@pmFc3zx&5EyXKurucj=RSY>LW-eiuVIerwNvl-~5B2K^d}}|y zlBG2SW(Edw{K32r$*V^Z53b-dadae!>H-V%>3qM}1>z~iW(#_DTwDLnjMJG+7{ZaF zy#drJc{rg8U~65YtD%WiAC2VfF~%{aq4T`2{v*=e@J%*hD3(gd7)*ht@H-7n3zcMC z7YPLg!;hShsK9A9DOhxjz#HkN%56f9~^C-dpjpbJDb~ zbwag~9F$2%F9jNME&1|J0ZMr!hlS{(kKtGSbcY83g`2~ng`3BO0>8lK#+0j&sQ2<IIL@(rkos0Cl&AmwHPe0q&yrREiBS+o+OJ|3T3{#bfzYom)bU z$$L}W(<9uXfBMP2&W4bzvx?$DMqE2;Iq%ckbWFFmMkc_}QrXF)+{tzZh*?C#a)uP=KHK? zWXAVoUYy~`XxoKdZ%0-G3Kg9~RC^b#BRw@888XN-)OQn?4oKmK9-VS`2YN|@_Owyf zq_4DggGf~=NDUvm-W&?^&m~fE35r**vO6crUD4xIJ^7#@w-+D0Qg=D^DVUI(EOT~- zkUG&B=LzkOl>D7Mlwq_bQdMkl=c#uQ{>8c_p5PTar@~2rSUh@_>PyQlvtk_G97H`B zR;TOTs7j)wHfULwF@fkSnLy{5Avz@5s;#@-O`r`l_*=NObtM*$ca{01f#gA)||ZVDgCF;FwT6;tz9#7RK+>ESYr?hBe0Ntv}Xy?EKJ{X~Rnqv$7taLwM{&LnYf+z`J03;(@M z1AMk=t|~n7kcqb;7!{T%KJ)vz+KX0~`0xw|>nZyQ-wB@6g_lelV?Aw2O6DJpj1% z2wF2qQzY|6G~>)0mTb}e+|HU7Umc4p^)23^K65gzP^g;r5V&HQ(^bZX98kptz#|bH{;oyLkeyV z!wDc@Z5U=YO3#clB&ihN>L+rny>6&F_C=mj95d>-lWo$Z41kJ3yqHA2PfQCpWp@`& z@%uLaT7jD87`lBKDXu_QVc5u0MGh+g1~-LUwLKUil0R-6vJpp_}5*OkxwSxwpMG;*Bo`CMN}?vCPCC!h{uUWj`(v+x2B0aF{6p zAcSsZ}&}i$#5;eT=2Arc3wL<(LV1?7##dg z11ilDTKR9k{4EUn+ z@^WEXz}i6k$d^r9T+6v{6S<8_*JMg*9c+Cq5|?1)_v5=Uvef&nbH?o=LCKsNaRFcs z5vsjFoNi0BpVb>cZv6KO3pJdC;t|b~m`lv$dGsv0F`1+MQv^m>oz1CKvOES^6b|wFDy_@Nn6mfhc4J<2{XO?x;g+r z!*74Cz%U8P)UJpUFV{M^PqUf_SZ~OXM9~B z7na}G71XlADcY+uiTlJSsF4E4Z){aG9CTQG0F|zP(v7W>Rb8Lx@<~`3`uB(PW{G^z u`aUmchGNKr+tx literal 0 HcmV?d00001 diff --git a/apps/memcached/1.6.19/data.yml b/apps/memcached/1.6.19/data.yml new file mode 100644 index 000000000..fa42cd8ba --- /dev/null +++ b/apps/memcached/1.6.19/data.yml @@ -0,0 +1,17 @@ +additionalProperties: + formFields: + - default: 11211 + edit: true + envKey: PANEL_APP_PORT_HTTP + labelEn: Port + labelZh: 端口 + required: true + rule: paramPort + type: number + - default: '64' + edit: true + envKey: MEM_CACHED + labelEn: Maximum memory usage(MB) + labelZh: 内存最大占用量(MB) + required: true + type: number diff --git a/apps/memcached/1.6.19/docker-compose.yml b/apps/memcached/1.6.19/docker-compose.yml new file mode 100644 index 000000000..8ee3af6f4 --- /dev/null +++ b/apps/memcached/1.6.19/docker-compose.yml @@ -0,0 +1,16 @@ +version: '3' +services: + memcached: + container_name: ${CONTAINER_NAME} + restart: always + networks: + - 1panel-network + ports: + - "${PANEL_APP_PORT_HTTP}:11211" + command: memcached -m ${MEM_CACHED} + image: "memcached:1.6.19-alpine3.17" + labels: + createdBy: "Apps" +networks: + 1panel-network: + external: true diff --git a/apps/memcached/README.md b/apps/memcached/README.md new file mode 100644 index 000000000..d674c6975 --- /dev/null +++ b/apps/memcached/README.md @@ -0,0 +1,54 @@ +# Memcached + +Memcached is a high performance multithreaded event-based key/value cache +store intended to be used in a distributed system. + +See: https://memcached.org/about + +A fun story explaining usage: https://memcached.org/tutorial + +If you're having trouble, try the wiki: https://memcached.org/wiki + +If you're trying to troubleshoot odd behavior or timeouts, see: +https://memcached.org/timeouts + +https://memcached.org/ is a good resource in general. Please use the mailing +list to ask questions, github issues aren't seen by everyone! + +## Dependencies + +* libevent - https://www.monkey.org/~provos/libevent/ (libevent-dev) +* libseccomp (optional, experimental, linux) - enables process restrictions for + better security. Tested only on x86-64 architectures. +* openssl (optional) - enables TLS support. need relatively up to date + version. pkg-config is needed to find openssl dependencies (such as -lz). + +## Environment + +Be warned that the -k (mlockall) option to memcached might be +dangerous when using a large cache. Just make sure the memcached machines +don't swap. memcached does non-blocking network I/O, but not disk. (it +should never go to disk, or you've lost the whole point of it) + +## Build status + +See https://build.memcached.org/ for multi-platform regression testing status. + +## Bug reports + +Feel free to use the issue tracker on github. + +**If you are reporting a security bug** please contact a maintainer privately. +We follow responsible disclosure: we handle reports privately, prepare a +patch, allow notifications to vendor lists. Then we push a fix release and your +bug can be posted publicly with credit in our release notes and commit +history. + +## Website + +* https://www.memcached.org + +## Contributing + +See https://github.com/memcached/memcached/wiki/DevelopmentRepos + diff --git a/apps/memcached/data.yml b/apps/memcached/data.yml new file mode 100644 index 000000000..7f63170de --- /dev/null +++ b/apps/memcached/data.yml @@ -0,0 +1,20 @@ +name: Memcached +tags: + - 工具 +title: Memcached是一套分布式的高速缓存系统 +type: 工具 +description: Memcached是一套分布式的高速缓存系统 +additionalProperties: + key: memcached + name: Memcached + tags: + - Tool + shortDescZh: Memcached是一套分布式的高速缓存系统 + shortDescEn: Memcached is a distributed caching system + type: tool + crossVersionUpdate: true + limit: 0 + recommend: 0 + website: https://memcached.org/ + github: https://github.com/memcached/memcached + document: https://github.com/memcached/memcached/wiki diff --git a/apps/memcached/logo.png b/apps/memcached/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..1edabde4b29367e622198f16f0fae466ee753dc8 GIT binary patch literal 24668 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 + + + +

+ +

QD for Python3

+ +
+QD —— 一个HTTP请求定时任务自动执行框架 base on HAR Editor and Tornado Server + +[![HomePage][HomePage-image]][HomePage-url] +[![Github][Github-image]][Github-url] +[![Gitee][Gitee-image]][Gitee-url] +[![license][github-license-image]][github-license-url] +[![Build Image][workflow-image]][workflow-url] +[![last commit][last-commit-image]][last-commit-url] +[![commit activity][commit-activity-image]][commit-activity-url] +[![docker version][docker-version-image]][docker-version-url] +[![docker pulls][docker-pulls-image]][docker-pulls-url] +[![docker stars][docker-stars-image]][docker-stars-url] +[![docker image size][docker-image-size-image]][docker-image-size-url] +![repo size][repo-size-image] +![python version][python-version-image] + +[![All Contributors](https://img.shields.io/badge/all_contributors-15-orange.svg?style=flat-square)](#contributors-) + + +[HomePage-image]: https://img.shields.io/badge/HomePage-qd--today-brightgreen +[HomePage-url]: https://qiandao.a76yyyy.cn +[Github-image]: https://img.shields.io/static/v1?label=Github&message=qd-today&color=brightgreen +[Github-url]: https://github.com/qd-today/qd/ +[Gitee-image]: https://img.shields.io/static/v1?label=Gitee&message=a76yyyy&color=brightgreen +[Gitee-url]: https://gitee.com/qd-today/qd/ +[github-license-image]: https://img.shields.io/github/license/qd-today/qd +[github-license-url]: https://github.com/qd-today/qd/blob/master/LICENSE +[last-commit-image]: https://img.shields.io/github/last-commit/qd-today/qd +[last-commit-url]: https://github.com/qd-today/qd/ +[commit-activity-image]: https://img.shields.io/github/commit-activity/m/qd-today/qd +[commit-activity-url]: https://github.com/qd-today/qd/ +[docker-version-image]: https://img.shields.io/docker/v/qdtoday/qd?style=flat +[docker-version-url]: https://hub.docker.com/r/qdtoday/qd/tags?page=1&ordering=last_updated +[docker-pulls-image]: https://img.shields.io/docker/pulls/qdtoday/qd?style=flat +[docker-pulls-url]: https://hub.docker.com/r/qdtoday/qd +[docker-stars-image]: https://img.shields.io/docker/stars/qdtoday/qd?style=flat +[docker-stars-url]: https://hub.docker.com/r/qdtoday/qd +[docker-image-size-image]: https://img.shields.io/docker/image-size/qdtoday/qd?style=flat +[docker-image-size-url]: https://hub.docker.com/r/qdtoday/qd +[repo-size-image]: https://img.shields.io/github/repo-size/qd-today/qd +[python-version-image]: https://img.shields.io/github/pipenv/locked/python-version/qd-today/qd +[workflow-image]: https://github.com/qd-today/qd/actions/workflows/Publish%20Package.yml/badge.svg +[workflow-url]: https://github.com/qd-today/qd/actions/workflows/Publish%20Package.yml + +
+ +

+ + +

+ +操作说明 +========== + +请参阅 **[使用指南](https://qd-today.github.io/qd/zh_CN/)** + +更新日志 +=========== + +详见 **[CHANGELOG.md](./CHANGELOG.md)** + +维护项目精力有限, 仅保证对 Chrome 浏览器的支持。如果测试了其他浏览器可以 Pull Request。 + +许可 +=========== + +[MIT](https://fastly.jsdelivr.net/gh/qd-today/qd@master/LICENSE) 许可协议 + +致谢 +=========== + +## Contributors ✨ + +Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)): + + + + + + + + + + + + + + + + + + + + + + + + + + +

a76yyyy

🎨 💻 🚧

Roy Binux

🎨 💻 🚧

AragonSnow

💻 🎨 🚧

Mark

🎨 📝 💡 📖

pidan

🎨

buzhibujue

💻

billypon

💻

acooler15

💻 🚧

shxyke

💻

xiaoxiao

💻

hiCasper

💻

旋子

💻

chen8945

💻

seiuneko

💻

powersee

💻
+ + + + + + +This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome! + +Stargazers over time +=========== + +[![Stargazers over time](https://starchart.cc/qd-today/qd.svg)](https://starchart.cc/qd-today/qd) diff --git a/apps/qiandao/data.yml b/apps/qiandao/data.yml new file mode 100644 index 000000000..eb64d5c9c --- /dev/null +++ b/apps/qiandao/data.yml @@ -0,0 +1,20 @@ +name: QianDao +tags: + - 工具 +title: 一个HTTP请求定时任务自动执行框架 +type: 工具 +description: 一个HTTP请求定时任务自动执行框架 +additionalProperties: + key: qiandao + name: QianDao + tags: + - Tool + shortDescZh: 一个HTTP请求定时任务自动执行框架 + shortDescEn: An HTTP request timed task automation framework + type: tool + crossVersionUpdate: true + limit: 0 + recommend: 0 + website: https://hub.docker.com/r/a76yyyy/qiandao + github: https://github.com/qiandao-today/qiandao + document: https://qiandao-today.github.io/qiandao/zh_CN/ diff --git a/apps/qiandao/logo.png b/apps/qiandao/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..33dd37aee369118a829be6e658bdd9aa5e7fd6ee GIT binary patch literal 15887 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%0DLyU`T~4o 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 literal 0 HcmV?d00001 diff --git a/apps/rustdesk/README.md b/apps/rustdesk/README.md new file mode 100644 index 000000000..3d55ea793 --- /dev/null +++ b/apps/rustdesk/README.md @@ -0,0 +1,241 @@ +# 本应用相关 + +# **注意事项** + - 运行完容器后需要获取当前数据目录"./data/hbbs"下的key,方便客户端使用。 + +``` +# 面板的话在文件管理里查看即可 +# 终端的话输入以下获得 +cat ./data/hbbs/id_ed25519.pub +``` + + - 如果要更改key,请删除"./data/hbbs"和"./data/hbbr"文件夹下的"id_ed25519"和"id_ed25519.pub"文件并重新启动 hbbs/hbbr,hbbs将会产生新的密钥对。 + +# 原项目说明 + +

+ RustDesk - Your remote desktop
+ 服务器 • + 编译 • + Docker • + 结构 • + 截图
+ [English] | [Українська] | [česky] | [Magyar] | [Español] | [فارسی] | [Français] | [Deutsch] | [Polski] | [Indonesian] | [Suomi] | [മലയാളം] | [日本語] | [Nederlands] | [Italiano] | [Русский] | [Português (Brasil)] | [Esperanto] | [한국어] | [العربي] | [Tiếng Việt] | [Ελληνικά]
+

+ +Chat with us: [知乎](https://www.zhihu.com/people/rustdesk) | [Discord](https://discord.gg/nDceKgxnkV) | [Reddit](https://www.reddit.com/r/rustdesk) + +[![ko-fi](https://ko-fi.com/img/githubbutton_sm.svg)](https://ko-fi.com/I2I04VU09) + +远程桌面软件,开箱即用,无需任何配置。您完全掌控数据,不用担心安全问题。您可以使用我们的注册/中继服务器, +或者[自己设置](https://rustdesk.com/server), +亦或者[开发您的版本](https://github.com/rustdesk/rustdesk-server-demo)。 + +欢迎大家贡献代码, 请看 [`docs/CONTRIBUTING.md`](CONTRIBUTING.md). + +[**可执行程序下载**](https://github.com/rustdesk/rustdesk/releases) + +## 免费的公共服务器 + +以下是您可以使用的、免费的、会随时更新的公共服务器列表,在国内也许网速会很慢或者无法访问。 + +| Location | Vendor | Specification | +| --------- | ------------- | ------------------ | +| Seoul | AWS lightsail | 1 vCPU / 0.5GB RAM | +| Germany | Hetzner | 2 vCPU / 4GB RAM | +| Germany | Codext | 4 vCPU / 8GB RAM | +| Finland (Helsinki) | 0x101 Cyber Security | 4 vCPU / 8GB RAM | +| USA (Ashburn) | 0x101 Cyber Security | 4 vCPU / 8GB RAM | + +## 依赖 + +桌面版本界面使用[sciter](https://sciter.com/), 请自行下载。 + +[Windows](https://raw.githubusercontent.com/c-smile/sciter-sdk/master/bin.win/x64/sciter.dll) | +[Linux](https://raw.githubusercontent.com/c-smile/sciter-sdk/master/bin.lnx/x64/libsciter-gtk.so) | +[macOS](https://raw.githubusercontent.com/c-smile/sciter-sdk/master/bin.osx/libsciter.dylib) + +移动版本使用Flutter,未来会将桌面版本从Sciter迁移到Flutter。 + +## 基本构建步骤 + +- 请准备好 Rust 开发环境和 C++编译环境 + +- 安装[vcpkg](https://github.com/microsoft/vcpkg), 正确设置`VCPKG_ROOT`环境变量 + + - Windows: vcpkg install libvpx:x64-windows-static libyuv:x64-windows-static opus:x64-windows-static + - Linux/Osx: vcpkg install libvpx libyuv opus + +- 运行 `cargo run` + +## [构建](https://rustdesk.com/docs/en/dev/build/) + +## 在 Linux 上编译 + +### Ubuntu 18 (Debian 10) + +```sh +sudo apt install -y g++ gcc git curl wget nasm yasm libgtk-3-dev clang libxcb-randr0-dev libxdo-dev libxfixes-dev libxcb-shape0-dev libxcb-xfixes0-dev libasound2-dev libpulse-dev cmake +``` + +### Fedora 28 (CentOS 8) + +```sh +sudo yum -y install gcc-c++ git curl wget nasm yasm gcc gtk3-devel clang libxcb-devel libxdo-devel libXfixes-devel pulseaudio-libs-devel cmake alsa-lib-devel +``` + +### Arch (Manjaro) + +```sh +sudo pacman -Syu --needed unzip git cmake gcc curl wget yasm nasm zip make pkg-config clang gtk3 xdotool libxcb libxfixes alsa-lib pipewire +``` + +### 安装 vcpkg + +```sh +git clone https://github.com/microsoft/vcpkg +cd vcpkg +git checkout 2021.12.01 +cd .. +vcpkg/bootstrap-vcpkg.sh +export VCPKG_ROOT=$HOME/vcpkg +vcpkg/vcpkg install libvpx libyuv opus +``` + +### 修复 libvpx (仅仅针对 Fedora) + +```sh +cd vcpkg/buildtrees/libvpx/src +cd * +./configure +sed -i 's/CFLAGS+=-I/CFLAGS+=-fPIC -I/g' Makefile +sed -i 's/CXXFLAGS+=-I/CXXFLAGS+=-fPIC -I/g' Makefile +make +cp libvpx.a $HOME/vcpkg/installed/x64-linux/lib/ +cd +``` + +### 构建 + +```sh +curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh +source $HOME/.cargo/env +git clone https://github.com/rustdesk/rustdesk +cd rustdesk +mkdir -p target/debug +wget https://raw.githubusercontent.com/c-smile/sciter-sdk/master/bin.lnx/x64/libsciter-gtk.so +mv libsciter-gtk.so target/debug +cargo run +``` + +### 把 Wayland 修改成 X11 (Xorg) + +RustDesk 暂时不支持 Wayland,不过正在积极开发中。 +> [点我](https://docs.fedoraproject.org/en-US/quick-docs/configuring-xorg-as-default-gnome-session/) +查看 如何将Xorg设置成默认的GNOME session + +## 使用 Docker 编译 + +### 构建Docker容器 + +```sh +git clone https://github.com/rustdesk/rustdesk # 克隆Github存储库 +cd rustdesk # 进入文件夹 +docker build -t "rustdesk-builder" . # 构建容器 +``` +请注意: +* 针对国内网络访问问题,可以做以下几点优化: + 1. Dockerfile 中修改系统的源到国内镜像 + ``` + 在Dockerfile的RUN apt update之前插入两行: + + RUN sed -i "s/deb.debian.org/mirrors.163.com/g" /etc/apt/sources.list + RUN sed -i "s/security.debian.org/mirrors.163.com/g" /etc/apt/sources.list + ``` + + 2. 修改容器系统中的 cargo 源,在`RUN ./rustup.sh -y`后插入下面代码: + + ``` + RUN echo '[source.crates-io]' > ~/.cargo/config \ + && echo 'registry = "https://github.com/rust-lang/crates.io-index"' >> ~/.cargo/config \ + && echo '# 替换成你偏好的镜像源' >> ~/.cargo/config \ + && echo "replace-with = 'sjtu'" >> ~/.cargo/config \ + && echo '# 上海交通大学' >> ~/.cargo/config \ + && echo '[source.sjtu]' >> ~/.cargo/config \ + && echo 'registry = "https://mirrors.sjtug.sjtu.edu.cn/git/crates.io-index"' >> ~/.cargo/config \ + && echo '' >> ~/.cargo/config + ``` + + 3. Dockerfile 中加入代理的 env + + ``` + 在User root后插入两行 + + ENV http_proxy=http://host:port + ENV https_proxy=http://host:port + ``` + + 4. docker build 命令后面加上 proxy 参数 + + ``` + docker build -t "rustdesk-builder" . --build-arg http_proxy=http://host:port --build-arg https_proxy=http://host:port + ``` + +### 构建RustDesk程序 +容器构建完成后,运行下列指令以完成对RustDesk应用程序的构建: + +```sh +docker run --rm -it -v $PWD:/home/user/rustdesk -v rustdesk-git-cache:/home/user/.cargo/git -v rustdesk-registry-cache:/home/user/.cargo/registry -e PUID="$(id -u)" -e PGID="$(id -g)" rustdesk-builder +``` + +请注意: +* 因为需要缓存依赖项,首次构建一般很慢(国内网络会经常出现拉取失败,可以多试几次)。 +* 如果您需要添加不同的构建参数,可以在指令末尾的`` 位置进行修改。例如构建一个"Release"版本,在指令后面加上` --release`即可。 +* 如果出现以下的提示,则是无权限问题,可以尝试把`-e PUID="$(id -u)" -e PGID="$(id -g)"`参数去掉。 + ``` + usermod: user user is currently used by process 1 + groupmod: Permission denied. + groupmod: cannot lock /etc/group; try again later. + ``` + > **原因:** 容器的entrypoint脚本会检测UID和GID,在度判和给定的环境变量的不一致时,会强行修改user的UID和GID并重新运行。但在重启后读不到环境中的UID和GID,然后再次进入判错重启环节 + + +### 运行RustDesk程序 + +生成的可执行程序在target目录下,可直接通过指令运行调试(Debug)版本的RustDesk: +```sh +target/debug/rustdesk +``` + +或者您想运行发行(Release)版本: + +```sh +target/release/rustdesk +``` + +请注意: +* 请保证您运行的目录是在RustDesk库的根目录内,否则软件会读不到文件。 +* `install`、`run`等Cargo的子指令在容器内不可用,宿主机才行。 + +## 文件结构 + +- **[libs/hbb_common](https://github.com/rustdesk/rustdesk/tree/master/libs/hbb_common)**: 视频编解码, 配置, tcp/udp 封装, protobuf, 文件传输相关文件系统操作函数, 以及一些其他实用函数 +- **[libs/scrap](https://github.com/rustdesk/rustdesk/tree/master/libs/scrap)**: 屏幕截取 +- **[libs/enigo](https://github.com/rustdesk/rustdesk/tree/master/libs/enigo)**: 平台相关的鼠标键盘输入 +- **[src/ui](https://github.com/rustdesk/rustdesk/tree/master/src/ui)**: GUI +- **[src/server](https://github.com/rustdesk/rustdesk/tree/master/src/server)**: 被控端服务音频、剪切板、输入、视频服务、网络连接的实现 +- **[src/client.rs](https://github.com/rustdesk/rustdesk/tree/master/src/client.rs)**: 控制端 +- **[src/rendezvous_mediator.rs](https://github.com/rustdesk/rustdesk/tree/master/src/rendezvous_mediator.rs)**: 与[rustdesk-server](https://github.com/rustdesk/rustdesk-server)保持UDP通讯, 等待远程连接(通过打洞直连或者中继) +- **[src/platform](https://github.com/rustdesk/rustdesk/tree/master/src/platform)**: 平台服务相关代码 +- **[flutter](https://github.com/rustdesk/rustdesk/tree/master/flutter)**: 移动版本的Flutter代码 +- **[flutter/web/js](https://github.com/rustdesk/rustdesk/tree/master/flutter/web/js)**: Flutter Web版本中的Javascript代码 + +## 截图 + +![image](https://user-images.githubusercontent.com/71636191/113112362-ae4deb80-923b-11eb-957d-ff88daad4f06.png) + +![image](https://user-images.githubusercontent.com/71636191/113112619-f705a480-923b-11eb-911d-97e984ef52b6.png) + +![image](https://user-images.githubusercontent.com/71636191/113112857-3fbd5d80-923c-11eb-9836-768325faf906.png) + +![image](https://user-images.githubusercontent.com/71636191/135385039-38fdbd72-379a-422d-b97f-33df71fb1cec.png) diff --git a/apps/rustdesk/data.yml b/apps/rustdesk/data.yml new file mode 100644 index 000000000..0a4702f26 --- /dev/null +++ b/apps/rustdesk/data.yml @@ -0,0 +1,20 @@ +name: RustDesk +tags: + - 工具 +title: RustDesk是一款开源的远程桌面软件 +type: 工具 +description: RustDesk是一款开源的远程桌面软件 +additionalProperties: + key: rustdesk + name: RustDesk + tags: + - Tool + shortDescZh: RustDesk是一款开源的远程桌面软件 + shortDescEn: RustDesk is an open source remote desktop software + type: tool + crossVersionUpdate: false + limit: 0 + recommend: 0 + website: https://rustdesk.com/zh/ + github: https://github.com/rustdesk/rustdesk + document: https://rustdesk.com/docs/zh-cn/ diff --git a/apps/rustdesk/latest/data.yml b/apps/rustdesk/latest/data.yml new file mode 100644 index 000000000..92fbd1aa4 --- /dev/null +++ b/apps/rustdesk/latest/data.yml @@ -0,0 +1,50 @@ +additionalProperties: + formFields: + - default: 21115 + edit: true + envKey: NAT_TEST_PORT + labelEn: NAT type test port + labelZh: NAT类型测试端口 + required: true + rule: paramPort + type: number + - default: 21116 + edit: true + envKey: HBBS_PORT + labelEn: hbbs port (used with IP/domain) + labelZh: hbbs端口(配合IP/域名使用) + required: true + rule: paramPort + type: number + - default: 21117 + edit: true + envKey: HBBR_PORT + labelEn: hbbr port (client relay server port) + labelZh: hbbr端口(客户端中继服务器端口) + required: true + rule: paramPort + type: number + - default: 21118 + edit: true + envKey: WEB_CLIENT_PORT1 + labelEn: Web Client Support Port 1 + labelZh: 网页客户端支持端口1 + required: true + rule: paramPort + type: number + - default: 21119 + edit: true + envKey: WEB_CLIENT_PORT2 + labelEn: Web Client Support Port 2 + labelZh: 网页客户端支持端口2 + required: true + rule: paramPort + type: number + - default: 172.17.0.1 + edit: true + envKey: HOST_ADDRESS + labelEn: IP address or domain name (must change item) + labelZh: IP地址或域名(必改项) + required: true + rule: paramCommon + type: text diff --git a/apps/rustdesk/latest/docker-compose.yml b/apps/rustdesk/latest/docker-compose.yml new file mode 100644 index 000000000..0d912f329 --- /dev/null +++ b/apps/rustdesk/latest/docker-compose.yml @@ -0,0 +1,50 @@ +version: '3' +services: + hbbs: + container_name: ${CONTAINER_NAME}_hbbs + restart: always + ports: + - "${NAT_TEST_PORT}:21115" #NAT类型测试 + - "${HBBS_PORT}:21116" # 自定义 hbbs 映射端口 + - "${HBBS_PORT}:21116/udp" #自定义 hbbs 映射端口 + - "${WEB_CLIENT_PORT1}:21118" #网页客户端支持端口 + command: hbbs -r ${HOST_ADDRESS}:${HBBS_PORT} -k _ # 填入个人域名或 IP + 暴露端口 + volumes: + - "./data/hbbs:/root" # 自定义挂载目录 + networks: + - 1panel-network + depends_on: + - hbbr +# deploy: +# resources: +# limits: +# memory: 64M + image: rustdesk/rustdesk-server:latest +# image: rustdesk/rustdesk-server:latest-arm64v8 # 镜像选用 arm64 版 + labels: + createdBy: "Apps" + + hbbr: + container_name: ${CONTAINER_NAME}_hbbr + restart: always + ports: + - "${HBBR_PORT}:21117" # 自定义 hbbr 映射端口 + - "${WEB_CLIENT_PORT2}:21119" #网页客户端支持端口 + command: hbbr -k _ + volumes: + - "./data/hbbr:/root" # 自定义挂载目录 + networks: + - 1panel-network +# deploy: +# resources: +# limits: +# memory: 64M + image: rustdesk/rustdesk-server:latest +# image: rustdesk/rustdesk-server:latest-arm64v8 # 镜像选用 arm64 版 + labels: + createdBy: "Apps" + +networks: + 1panel-network: + external: true + diff --git a/apps/rustdesk/logo.png b/apps/rustdesk/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..6a425f7e08d7b981ecb348bf8dafd45c59e7e048 GIT binary patch literal 11655 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[Installing and configuration](#installing-and-configuration) + - [Using a reverse proxy with Synapse](#using-a-reverse-proxy-with-synapse) + - [Upgrading an existing Synapse](#upgrading-an-existing-synapse) + - [Platform dependencies](#platform-dependencies) + - [Security note](#security-note) +- [Testing a new installation](#testing-a-new-installation) + - [Registering a new user from a client](#registering-a-new-user-from-a-client) +- [Troubleshooting and support](#troubleshooting-and-support) +- [Identity Servers](#identity-servers) +- [Development](#development) + + + +## [Installing and configuration](#id1) + +The Synapse documentation describes [how to install Synapse](https://matrix-org.github.io/synapse/latest/setup/installation.html). We recommend using [Docker images](https://matrix-org.github.io/synapse/latest/setup/installation.html#docker-images-and-ansible-playbooks) or [Debian packages from Matrix.org](https://matrix-org.github.io/synapse/latest/setup/installation.html#matrixorg-packages). + +Synapse has a variety of [config options](https://matrix-org.github.io/synapse/latest/usage/configuration/config_documentation.html) which can be used to customise its behaviour after installation. There are additional details on how to [configure Synapse for federation here](https://matrix-org.github.io/synapse/latest/federate.html). + + + +### [Using a reverse proxy with Synapse](#id2) + +It is recommended to put a reverse proxy such as [nginx](https://nginx.org/en/docs/http/ngx_http_proxy_module.html), [Apache](https://httpd.apache.org/docs/current/mod/mod_proxy_http.html), [Caddy](https://caddyserver.com/docs/quick-starts/reverse-proxy), [HAProxy](https://www.haproxy.org/) or [relayd](https://man.openbsd.org/relayd.8) in front of Synapse. One advantage of doing so is that it means that you can expose the default https port (443) to Matrix clients without needing to run Synapse with root privileges. For information on configuring one, see [the reverse proxy docs](https://matrix-org.github.io/synapse/latest/reverse_proxy.html). + + + +### [Upgrading an existing Synapse](#id3) + +The instructions for upgrading Synapse are in [the upgrade notes](https://matrix-org.github.io/synapse/develop/upgrade.html). Please check these instructions as upgrading may require extra steps for some versions of Synapse. + + + +### [Platform dependencies](#id4) + +Synapse uses a number of platform dependencies such as Python and PostgreSQL, and aims to follow supported upstream versions. See the [deprecation policy](https://matrix-org.github.io/synapse/latest/deprecation_policy.html) for more details. + + + +### [Security note](#id5) + +Matrix serves raw, user-supplied data in some APIs -- specifically the [content repository endpoints](https://matrix.org/docs/spec/client_server/latest.html#get-matrix-media-r0-download-servername-mediaid). + +Whilst we make a reasonable effort to mitigate against XSS attacks (for instance, by using [CSP](https://github.com/matrix-org/synapse/pull/1021)), a Matrix homeserver should not be hosted on a domain hosting other web applications. This especially applies to sharing the domain with Matrix web clients and other sensitive applications like webmail. See https://developer.github.com/changes/2014-04-25-user-content-security for more information. + +Ideally, the homeserver should not simply be on a different subdomain, but on a completely different [registered domain](https://tools.ietf.org/html/draft-ietf-httpbis-rfc6265bis-03#section-2.3) (also known as top-level site or eTLD+1). This is because [some attacks](https://en.wikipedia.org/wiki/Session_fixation#Attacks_using_cross-subdomain_cookie) are still possible as long as the two applications share the same registered domain. + +To illustrate this with an example, if your Element Web or other sensitive web application is hosted on `A.example1.com`, you should ideally host Synapse on `example2.com`. Some amount of protection is offered by hosting on `B.example1.com` instead, so this is also acceptable in some scenarios. However, you should *not* host your Synapse on `A.example1.com`. + +Note that all of the above refers exclusively to the domain used in Synapse's `public_baseurl` setting. In particular, it has no bearing on the domain mentioned in MXIDs hosted on that server. + +Following this advice ensures that even if an XSS is found in Synapse, the impact to other applications will be minimal. + + + +## [Testing a new installation](#id6) + +The easiest way to try out your new Synapse installation is by connecting to it from a web client. + +Unless you are running a test instance of Synapse on your local machine, in general, you will need to enable TLS support before you can successfully connect from a client: see [TLS certificates](https://matrix-org.github.io/synapse/latest/setup/installation.html#tls-certificates). + +An easy way to get started is to login or register via Element at https://app.element.io/#/login or https://app.element.io/#/register respectively. You will need to change the server you are logging into from `matrix.org` and instead specify a Homeserver URL of `https://:8448` (or just `https://` if you are using a reverse proxy). If you prefer to use another client, refer to our [client breakdown](https://matrix.org/docs/projects/clients-matrix). + +If all goes well you should at least be able to log in, create a room, and start sending messages. + + + +### [Registering a new user from a client](#id7) + +By default, registration of new users via Matrix clients is disabled. To enable it: + +1. In the [registration config section](https://matrix-org.github.io/synapse/latest/usage/configuration/config_documentation.html#registration) set `enable_registration: true` in `homeserver.yaml`. +2. Then **either**: + 1. set up a [CAPTCHA](https://matrix-org.github.io/synapse/latest/CAPTCHA_SETUP.html), or + 2. set `enable_registration_without_verification: true` in `homeserver.yaml`. + +We **strongly** recommend using a CAPTCHA, particularly if your homeserver is exposed to the public internet. Without it, anyone can freely register accounts on your homeserver. This can be exploited by attackers to create spambots targetting the rest of the Matrix federation. + +Your new user name will be formed partly from the `server_name`, and partly from a localpart you specify when you create the account. Your name will take the form of: + +@localpart:my.domain.name + +(pronounced "at localpart on my dot domain dot name"). + +As when logging in, you will need to specify a "Custom server". Specify your desired `localpart` in the 'User name' box. + + + +## [Troubleshooting and support](#id8) + +The [Admin FAQ](https://matrix-org.github.io/synapse/latest/usage/administration/admin_faq.html) includes tips on dealing with some common problems. For more details, see [Synapse's wider documentation](https://matrix-org.github.io/synapse/latest/). + +For additional support installing or managing Synapse, please ask in the community support room [`#synapse:matrix.org`](https://matrix.to/#/#synapse:matrix.org) (from a [matrix.org](https://github.com/matrix-org/matrix.org) account if necessary). We do not use GitHub issues for support requests, only for bug reports and feature requests. + + + +## [Identity Servers](#id9) + +Identity servers have the job of mapping email addresses and other 3rd Party IDs (3PIDs) to Matrix user IDs, as well as verifying the ownership of 3PIDs before creating that mapping. + +**They are not where accounts or credentials are stored - these live on home servers. Identity Servers are just for mapping 3rd party IDs to matrix IDs.** + +This process is very security-sensitive, as there is obvious risk of spam if it is too easy to sign up for Matrix accounts or harvest 3PID data. In the longer term, we hope to create a decentralised system to manage it ([matrix-doc #712](https://github.com/matrix-org/matrix-doc/issues/712)), but in the meantime, the role of managing trusted identity in the Matrix ecosystem is farmed out to a cluster of known trusted ecosystem partners, who run 'Matrix Identity Servers' such as [Sydent](https://github.com/matrix-org/sydent), whose role is purely to authenticate and track 3PID logins and publish end-user public keys. + +You can host your own copy of Sydent, but this will prevent you reaching other users in the Matrix ecosystem via their email address, and prevent them finding you. We therefore recommend that you use one of the centralised identity servers at `https://matrix.org` or `https://vector.im` for now. + +To reiterate: the Identity server will only be used if you choose to associate an email address with your account, or send an invite to another user via their email address. + + + +## [Development](#id10) + +We welcome contributions to Synapse from the community! The best place to get started is our [guide for contributors](https://matrix-org.github.io/synapse/latest/development/contributing_guide.html). This is part of our larger [documentation](https://matrix-org.github.io/synapse/latest), which includes + +information for Synapse developers as well as Synapse administrators. Developers might be particularly interested in: + +- [Synapse's database schema](https://matrix-org.github.io/synapse/latest/development/database_schema.html), +- [notes on Synapse's implementation details](https://matrix-org.github.io/synapse/latest/development/internal_documentation/index.html), and +- [how we use git](https://matrix-org.github.io/synapse/latest/development/git.html). + +Alongside all that, join our developer community on Matrix: [#synapse-dev:matrix.org](https://matrix.to/#/#synapse-dev:matrix.org), featuring real humans! diff --git a/apps/synapse/data.yml b/apps/synapse/data.yml new file mode 100644 index 000000000..8474d18da --- /dev/null +++ b/apps/synapse/data.yml @@ -0,0 +1,20 @@ +name: Synapse +tags: + - 工具 +title: Synapse是一个开源的Matrix家庭服务器,自建聊天服务端 +type: 工具 +description: Synapse是一个开源的Matrix家庭服务器,自建聊天服务端 +additionalProperties: + key: synapse + name: Synapse + tags: + - Tool + shortDescZh: Synapse是一个开源的Matrix家庭服务器,自建聊天服务端 + shortDescEn: Synapse is an open-source Matrix homeserver,build your own chat server + type: tool + crossVersionUpdate: true + limit: 1 + recommend: 0 + website: https://matrix.org/docs/projects/server/synapse + github: https://github.com/matrix-org/synapse + document: https://matrix-org.github.io/synapse/latest/ diff --git a/apps/synapse/logo.png b/apps/synapse/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..b4b6d4fc11a9605535b012d5a76fcf65211dcfdc GIT binary patch literal 2949 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 nD7`bhGV|i!hW-A-s51xjmcp!)y#wzKxf