location-based rproxy fixes
This commit is contained in:
		
							parent
							
								
									85321a6f31
								
							
						
					
					
						commit
						18942ed066
					
				| @ -697,7 +697,7 @@ def add_zeroconf(ap): | ||||
| 
 | ||||
| 
 | ||||
| def add_zc_mdns(ap): | ||||
|     ap2 = ap.add_argument_group("Zeroconf-mDNS options:") | ||||
|     ap2 = ap.add_argument_group("Zeroconf-mDNS options") | ||||
|     ap2.add_argument("--zm", action="store_true", help="announce the enabled protocols over mDNS (multicast DNS-SD) -- compatible with KDE, gnome, macOS, ...") | ||||
|     ap2.add_argument("--zm-on", metavar="NETS", type=u, default="", help="enable zeroconf ONLY on the comma-separated list of subnets and/or interface names/indexes") | ||||
|     ap2.add_argument("--zm-off", metavar="NETS", type=u, default="", help="disable zeroconf on the comma-separated list of subnets and/or interface names/indexes") | ||||
| @ -716,7 +716,7 @@ def add_zc_mdns(ap): | ||||
| 
 | ||||
| 
 | ||||
| def add_zc_ssdp(ap): | ||||
|     ap2 = ap.add_argument_group("Zeroconf-SSDP options:") | ||||
|     ap2 = ap.add_argument_group("Zeroconf-SSDP options") | ||||
|     ap2.add_argument("--zs", action="store_true", help="announce the enabled protocols over SSDP -- compatible with Windows") | ||||
|     ap2.add_argument("--zs-on", metavar="NETS", type=u, default="", help="enable zeroconf ONLY on the comma-separated list of subnets and/or interface names/indexes") | ||||
|     ap2.add_argument("--zs-off", metavar="NETS", type=u, default="", help="disable zeroconf on the comma-separated list of subnets and/or interface names/indexes") | ||||
|  | ||||
| @ -1789,7 +1789,7 @@ class HttpCli(object): | ||||
|             if x[0] != "Set-Cookie" or "cppwd=" not in x[1] | ||||
|         ] | ||||
| 
 | ||||
|         dst = "/" | ||||
|         dst = self.args.SRS | ||||
|         if self.vpath: | ||||
|             dst += quotep(self.vpath) | ||||
| 
 | ||||
| @ -2614,6 +2614,7 @@ class HttpCli(object): | ||||
|             if self.args.rclone_mdns or not self.args.zm | ||||
|             else self.conn.hsrv.nm.map(self.ip) or host | ||||
|         ) | ||||
|         vp = (self.uparam["hc"] or "").lstrip("/") | ||||
|         html = self.j2s( | ||||
|             "svcs", | ||||
|             args=self.args, | ||||
| @ -2621,7 +2622,8 @@ class HttpCli(object): | ||||
|             s="s" if self.is_https else "", | ||||
|             rip=rip, | ||||
|             ep=ep, | ||||
|             vp=(self.uparam["hc"] or "").lstrip("/"), | ||||
|             vp=vp, | ||||
|             rvp=vjoin(self.args.R, vp), | ||||
|             host=host, | ||||
|             hport=hport, | ||||
|             aname=aname, | ||||
|  | ||||
| @ -310,6 +310,7 @@ class SvcHub(object): | ||||
|         al.R = R = R.strip("/") | ||||
|         al.SR = "/" + R if R else "" | ||||
|         al.RS = R + "/" if R else "" | ||||
|         al.SRS = "/" + R + "/" if R else "/" | ||||
| 
 | ||||
|         return True | ||||
| 
 | ||||
|  | ||||
| @ -46,7 +46,7 @@ | ||||
| 				<tbody> | ||||
| 					{% for mp in avol %} | ||||
| 					{%- if mp in vstate and vstate[mp] %} | ||||
| 					<tr><td><a href="{{ mp }}{{ url_suf }}">{{ mp }}</a></td><td><a class="s" href="{{ mp }}?scan">rescan</a></td><td>{{ vstate[mp] }}</td></tr> | ||||
| 					<tr><td><a href="{{ r }}{{ mp }}{{ url_suf }}">{{ mp }}</a></td><td><a class="s" href="{{ r }}{{ mp }}?scan">rescan</a></td><td>{{ vstate[mp] }}</td></tr> | ||||
| 					{%- endif %} | ||||
| 					{% endfor %} | ||||
| 				</tbody> | ||||
| @ -62,7 +62,7 @@ | ||||
| 		<h1 id="f">you can browse:</h1> | ||||
| 		<ul> | ||||
| 			{% for mp in rvol %} | ||||
| 			<li><a href="{{ mp }}{{ url_suf }}">{{ mp }}</a></li> | ||||
| 			<li><a href="{{ r }}{{ mp }}{{ url_suf }}">{{ mp }}</a></li> | ||||
| 			{% endfor %} | ||||
| 		</ul> | ||||
| 		{%- endif %} | ||||
| @ -71,7 +71,7 @@ | ||||
| 		<h1 id="g">you can upload to:</h1> | ||||
| 		<ul> | ||||
| 			{% for mp in wvol %} | ||||
| 			<li><a href="{{ mp }}{{ url_suf }}">{{ mp }}</a></li> | ||||
| 			<li><a href="{{ r }}{{ mp }}{{ url_suf }}">{{ mp }}</a></li> | ||||
| 			{% endfor %} | ||||
| 		</ul> | ||||
| 		{%- endif %} | ||||
|  | ||||
| @ -15,7 +15,7 @@ | ||||
| <body> | ||||
| 	<div id="wrap" class="w"> | ||||
|         <div class="cn"> | ||||
|             <p class="btns"><a href="{{ r }}/{{ vp }}">browse files</a> // <a href="{{ r }}/?h">control panel</a></p> | ||||
|             <p class="btns"><a href="{{ rvp }}">browse files</a> // <a href="{{ r }}/?h">control panel</a></p> | ||||
|             <p>or choose your OS for cooler alternatives:</p> | ||||
|             <div class="ossel"> | ||||
|                 <a id="swin" href="#">Windows</a> | ||||
| @ -47,7 +47,7 @@ | ||||
|             <p>if you can, install <a href="https://winfsp.dev/rel/">winfsp</a>+<a href="https://downloads.rclone.org/rclone-current-windows-amd64.zip">rclone</a> and then paste this in cmd:</p> | ||||
|             <pre> | ||||
|                 rclone config create {{ aname }}-dav webdav url=http{{ s }}://{{ rip }}{{ hport }} vendor=other{% if accs %} user=k pass=<b>{{ pw }}</b>{% endif %} | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-dav:{{ vp }} <b>W:</b> | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-dav:{{ rvp }} <b>W:</b> | ||||
|             </pre> | ||||
|             {% if s %} | ||||
|             <p><em>note: if you are on LAN (or just dont have valid certificates), add <code>--no-check-certificate</code> to the mount command</em><br />---</p> | ||||
| @ -55,19 +55,19 @@ | ||||
|              | ||||
|             <p>if you want to use the native WebDAV client in windows instead (slow and buggy), first run <a href="{{ r }}/.cpr/a/webdav-cfg.bat">webdav-cfg.bat</a> to remove the 47 MiB filesize limit (also fixes latency and password login), then connect:</p> | ||||
|             <pre> | ||||
|                 net use <b>w:</b> http{{ s }}://{{ ep }}/{{ vp }}{% if accs %} k /user:<b>{{ pw }}</b>{% endif %} | ||||
|                 net use <b>w:</b> http{{ s }}://{{ ep }}/{{ rvp }}{% if accs %} k /user:<b>{{ pw }}</b>{% endif %} | ||||
|             </pre> | ||||
|         </div> | ||||
| 
 | ||||
|         <div class="os lin"> | ||||
|             <pre> | ||||
|                 yum install davfs2 | ||||
|                 {% if accs %}printf '%s\n' <b>{{ pw }}</b> k | {% endif %}mount -t davfs -ouid=1000 http{{ s }}://{{ ep }}/{{ vp }} <b>mp</b> | ||||
|                 {% if accs %}printf '%s\n' <b>{{ pw }}</b> k | {% endif %}mount -t davfs -ouid=1000 http{{ s }}://{{ ep }}/{{ rvp }} <b>mp</b> | ||||
|             </pre> | ||||
|             <p>or you can use rclone instead, which is much slower but doesn't require root:</p> | ||||
|             <pre> | ||||
|                 rclone config create {{ aname }}-dav webdav url=http{{ s }}://{{ rip }}{{ hport }} vendor=other{% if accs %} user=k pass=<b>{{ pw }}</b>{% endif %} | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-dav:{{ vp }} <b>mp</b> | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-dav:{{ rvp }} <b>mp</b> | ||||
|             </pre> | ||||
|             {% if s %} | ||||
|             <p><em>note: if you are on LAN (or just dont have valid certificates), add <code>--no-check-certificate</code> to the mount command</em><br />---</p> | ||||
| @ -77,20 +77,20 @@ | ||||
|             <!-- gnome-bug: ignores vp --> | ||||
|             <pre> | ||||
|                 {%- if accs %} | ||||
|                 echo <b>{{ pw }}</b> | gio mount dav{{ s }}://k@{{ ep }}/{{ vp }} | ||||
|                 echo <b>{{ pw }}</b> | gio mount dav{{ s }}://k@{{ ep }}/{{ rvp }} | ||||
|                 {%- else %} | ||||
|                 gio mount -a dav{{ s }}://{{ ep }}/{{ vp }} | ||||
|                 gio mount -a dav{{ s }}://{{ ep }}/{{ rvp }} | ||||
|                 {%- endif %} | ||||
|             </pre> | ||||
|         </div> | ||||
| 
 | ||||
|         <div class="os mac"> | ||||
|             <pre> | ||||
|                 osascript -e ' mount volume "http{{ s }}://k:<b>{{ pw }}</b>@{{ ep }}/{{ vp }}" ' | ||||
|                 osascript -e ' mount volume "http{{ s }}://k:<b>{{ pw }}</b>@{{ ep }}/{{ rvp }}" ' | ||||
|             </pre> | ||||
|             <p>or you can open up a Finder, press command-K and paste this instead:</p> | ||||
|             <pre> | ||||
|                 http{{ s }}://k:<b>{{ pw }}</b>@{{ ep }}/{{ vp }} | ||||
|                 http{{ s }}://k:<b>{{ pw }}</b>@{{ ep }}/{{ rvp }} | ||||
|             </pre> | ||||
|              | ||||
|             {% if s %} | ||||
| @ -108,26 +108,26 @@ | ||||
|             <p>if you can, install <a href="https://winfsp.dev/rel/">winfsp</a>+<a href="https://downloads.rclone.org/rclone-current-windows-amd64.zip">rclone</a> and then paste this in cmd:</p> | ||||
|             <pre> | ||||
|                 rclone config create {{ aname }}-ftp ftp host={{ rip }} port={{ args.ftp or args.ftps }} pass=k user={% if accs %}<b>{{ pw }}</b>{% else %}anonymous{% endif %} tls={{ "false" if args.ftp else "true" }} | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-ftp:{{ vp }} <b>W:</b> | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-ftp:{{ rvp }} <b>W:</b> | ||||
|             </pre> | ||||
|             <p>if you want to use the native FTP client in windows instead (please dont), press <code>win+R</code> and run this command:</p> | ||||
|             <pre> | ||||
|                 explorer {{ "ftp" if args.ftp else "ftps" }}://{% if accs %}<b>{{ pw }}</b>:k@{% endif %}{{ host }}:{{ args.ftp or args.ftps }}/{{ vp }} | ||||
|                 explorer {{ "ftp" if args.ftp else "ftps" }}://{% if accs %}<b>{{ pw }}</b>:k@{% endif %}{{ host }}:{{ args.ftp or args.ftps }}/{{ rvp }} | ||||
|             </pre> | ||||
|         </div> | ||||
| 
 | ||||
|         <div class="os lin"> | ||||
|             <pre> | ||||
|                 rclone config create {{ aname }}-ftp ftp host={{ rip }} port={{ args.ftp or args.ftps }} pass=k user={% if accs %}<b>{{ pw }}</b>{% else %}anonymous{% endif %} tls={{ "false" if args.ftp else "true" }} | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-ftp:{{ vp }} <b>mp</b> | ||||
|                 rclone mount --vfs-cache-mode writes --dir-cache-time 5s {{ aname }}-ftp:{{ rvp }} <b>mp</b> | ||||
|             </pre> | ||||
|             <p>emergency alternative (gnome/gui-only):</p> | ||||
|             <!-- gnome-bug: ignores vp --> | ||||
|             <pre> | ||||
|                 {%- if accs %} | ||||
|                 echo <b>{{ pw }}</b> | gio mount ftp{{ "" if args.ftp else "s" }}://k@{{ host }}:{{ args.ftp or args.ftps }}/{{ vp }} | ||||
|                 echo <b>{{ pw }}</b> | gio mount ftp{{ "" if args.ftp else "s" }}://k@{{ host }}:{{ args.ftp or args.ftps }}/{{ rvp }} | ||||
|                 {%- else %} | ||||
|                 gio mount -a ftp{{ "" if args.ftp else "s" }}://{{ host }}:{{ args.ftp or args.ftps }}/{{ vp }} | ||||
|                 gio mount -a ftp{{ "" if args.ftp else "s" }}://{{ host }}:{{ args.ftp or args.ftps }}/{{ rvp }} | ||||
|                 {%- endif %} | ||||
|             </pre> | ||||
|         </div> | ||||
| @ -135,7 +135,7 @@ | ||||
|         <div class="os mac"> | ||||
|             <p>note: FTP is read-only on macos; please use WebDAV instead</p> | ||||
|             <pre> | ||||
|                 open {{ "ftp" if args.ftp else "ftps" }}://{% if accs %}k:<b>{{ pw }}</b>@{% else %}anonymous:@{% endif %}{{ host }}:{{ args.ftp or args.ftps }}/{{ vp }} | ||||
|                 open {{ "ftp" if args.ftp else "ftps" }}://{% if accs %}k:<b>{{ pw }}</b>@{% else %}anonymous:@{% endif %}{{ host }}:{{ args.ftp or args.ftps }}/{{ rvp }} | ||||
|             </pre> | ||||
|         </div> | ||||
|         {% endif %} | ||||
| @ -149,7 +149,7 @@ | ||||
|             <span class="os lin">doesn't need root</span> | ||||
|         </p> | ||||
|         <pre> | ||||
|             partyfuse.py{% if accs %} -a <b>{{ pw }}</b>{% endif %} http{{ s }}://{{ ep }}/{{ vp }} <b><span class="os win">W:</span><span class="os lin mac">mp</span></b> | ||||
|             partyfuse.py{% if accs %} -a <b>{{ pw }}</b>{% endif %} http{{ s }}://{{ ep }}/{{ rvp }} <b><span class="os win">W:</span><span class="os lin mac">mp</span></b> | ||||
|         </pre> | ||||
|         {% if s %} | ||||
|         <p><em>note: if you are on LAN (or just dont have valid certificates), add <code>-td</code></em></p> | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed