copyparty 1.18.4__py3-none-any.whl → 1.18.5__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
copyparty/__main__.py CHANGED
@@ -1280,6 +1280,7 @@ def add_stats(ap):
1280
1280
  def add_yolo(ap):
1281
1281
  ap2 = ap.add_argument_group('yolo options')
1282
1282
  ap2.add_argument("--allow-csrf", action="store_true", help="disable csrf protections; let other domains/sites impersonate you through cross-site requests")
1283
+ ap2.add_argument("--cookie-lax", action="store_true", help="allow cookies from other domains (if you follow a link from another website into your server, you will arrive logged-in); this reduces protection against CSRF")
1283
1284
  ap2.add_argument("--getmod", action="store_true", help="permit ?move=[...] and ?delete as GET")
1284
1285
  ap2.add_argument("--wo-up-readme", action="store_true", help="allow users with write-only access to upload logues and readmes without adding the _wo_ filename prefix (volflag=wo_up_readme)")
1285
1286
 
copyparty/__version__.py CHANGED
@@ -1,8 +1,8 @@
1
1
  # coding: utf-8
2
2
 
3
- VERSION = (1, 18, 4)
3
+ VERSION = (1, 18, 5)
4
4
  CODENAME = "logtail"
5
- BUILD_DT = (2025, 7, 25)
5
+ BUILD_DT = (2025, 7, 28)
6
6
 
7
7
  S_VERSION = ".".join(map(str, VERSION))
8
8
  S_BUILD_DT = "{0:04d}-{1:02d}-{2:02d}".format(*BUILD_DT)
copyparty/httpcli.py CHANGED
@@ -2981,12 +2981,20 @@ class HttpCli(object):
2981
2981
  # reset both plaintext and tls
2982
2982
  # (only affects active tls cookies when tls)
2983
2983
  for k in ("cppwd", "cppws") if self.is_https else ("cppwd",):
2984
- ck = gencookie(k, pwd, self.args.R, False)
2984
+ ck = gencookie(k, pwd, self.args.R, self.args.cookie_lax, False)
2985
2985
  self.out_headerlist.append(("Set-Cookie", ck))
2986
2986
  self.out_headers.pop("Set-Cookie", None) # drop keepalive
2987
2987
  else:
2988
2988
  k = "cppws" if self.is_https else "cppwd"
2989
- ck = gencookie(k, pwd, self.args.R, self.is_https, dur, "; HttpOnly")
2989
+ ck = gencookie(
2990
+ k,
2991
+ pwd,
2992
+ self.args.R,
2993
+ self.args.cookie_lax,
2994
+ self.is_https,
2995
+ dur,
2996
+ "; HttpOnly",
2997
+ )
2990
2998
  self.out_headers["Set-Cookie"] = ck
2991
2999
 
2992
3000
  return dur > 0, msg
@@ -4843,13 +4851,21 @@ class HttpCli(object):
4843
4851
  def tx_svcs(self) :
4844
4852
  aname = re.sub("[^0-9a-zA-Z]+", "", self.args.vname) or "a"
4845
4853
  ep = self.host
4846
- host = ep.split(":")[0]
4847
- hport = ep[ep.find(":") :] if ":" in ep else ""
4848
- rip = (
4849
- host
4850
- if self.args.rclone_mdns or not self.args.zm
4851
- else self.conn.hsrv.nm.map(self.ip) or host
4852
- )
4854
+ sep = "]:" if "]" in ep else ":"
4855
+ if sep in ep:
4856
+ host, hport = ep.rsplit(":", 1)
4857
+ hport = ":" + hport
4858
+ else:
4859
+ host = ep
4860
+ hport = ""
4861
+
4862
+ if host.endswith(".local") and self.args.zm and not self.args.rclone_mdns:
4863
+ rip = self.conn.hsrv.nm.map(self.ip) or host
4864
+ if ":" in rip and "[" not in rip:
4865
+ rip = "[%s]" % (rip,)
4866
+ else:
4867
+ rip = host
4868
+
4853
4869
  # safer than html_escape/quotep since this avoids both XSS and shell-stuff
4854
4870
  pw = re.sub(r"[<>&$?`\"']", "_", self.pw or "hunter2")
4855
4871
  vp = re.sub(r"[<>&$?`\"']", "_", self.uparam["hc"] or "").lstrip("/")
@@ -5018,7 +5034,7 @@ class HttpCli(object):
5018
5034
  def setck(self) :
5019
5035
  k, v = self.uparam["setck"].split("=", 1)
5020
5036
  t = 0 if v in ("", "x") else 86400 * 299
5021
- ck = gencookie(k, v, self.args.R, False, t)
5037
+ ck = gencookie(k, v, self.args.R, self.args.cookie_lax, False, t)
5022
5038
  self.out_headerlist.append(("Set-Cookie", ck))
5023
5039
  if "cc" in self.ouparam:
5024
5040
  self.redirect("", "?h#cc")
@@ -5030,7 +5046,7 @@ class HttpCli(object):
5030
5046
  for k in ALL_COOKIES:
5031
5047
  if k not in self.cookies:
5032
5048
  continue
5033
- cookie = gencookie(k, "x", self.args.R, False)
5049
+ cookie = gencookie(k, "x", self.args.R, self.args.cookie_lax, False)
5034
5050
  self.out_headerlist.append(("Set-Cookie", cookie))
5035
5051
 
5036
5052
  self.redirect("", "?h#cc")
copyparty/util.py CHANGED
@@ -1951,15 +1951,25 @@ def formatdate(ts = None) :
1951
1951
  return RFC2822 % (WKDAYS[wd], d, MONTHS[mo - 1], y, h, mi, s)
1952
1952
 
1953
1953
 
1954
- def gencookie(k , v , r , tls , dur = 0, txt = "") :
1954
+ def gencookie(
1955
+ k , v , r , lax , tls , dur = 0, txt = ""
1956
+ ) :
1955
1957
  v = v.replace("%", "%25").replace(";", "%3B")
1956
1958
  if dur:
1957
1959
  exp = formatdate(time.time() + dur)
1958
1960
  else:
1959
1961
  exp = "Fri, 15 Aug 1997 01:00:00 GMT"
1960
1962
 
1961
- t = "%s=%s; Path=/%s; Expires=%s%s%s; SameSite=Lax"
1962
- return t % (k, v, r, exp, "; Secure" if tls else "", txt)
1963
+ t = "%s=%s; Path=/%s; Expires=%s%s%s; SameSite=%s"
1964
+ return t % (
1965
+ k,
1966
+ v,
1967
+ r,
1968
+ exp,
1969
+ "; Secure" if tls else "",
1970
+ txt,
1971
+ "Lax" if lax else "Strict",
1972
+ )
1963
1973
 
1964
1974
 
1965
1975
  def humansize(sz , terse = False) :
Binary file
copyparty/web/util.js.gz CHANGED
Binary file
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: copyparty
3
- Version: 1.18.4
3
+ Version: 1.18.5
4
4
  Summary: Portable file server with accelerated resumable uploads, deduplication, WebDAV, FTP, zeroconf, media indexer, video thumbnails, audio transcoding, and write-only folders
5
5
  Author-email: ed <copyparty@ocv.me>
6
6
  License: MIT
@@ -1,6 +1,6 @@
1
1
  copyparty/__init__.py,sha256=4aJw_Mt3eSNMV8sJ95Nh4ris-tBUYhCOV094Rnxa5Xo,2651
2
- copyparty/__main__.py,sha256=rfSaVAHy9NpF6U-dWu4NS6zab96v7DLnG95M7WRXyxo,126024
3
- copyparty/__version__.py,sha256=VYBE-faUq6KuT0awfdhYnaqRvlnX2Tni0a63zOMGx_A,249
2
+ copyparty/__main__.py,sha256=Y2bTkxG_bmf_IAnt6brZtxWRh7FixaflrFwXU2igNDU,126249
3
+ copyparty/__version__.py,sha256=uhS3dAMtTM8r9haiBv5Lrq_rDPstnacAWWZt4fw8yVg,249
4
4
  copyparty/authsrv.py,sha256=PDX6-ob-vqpKE8XkMCEph662EE4Mp8IKbtIEZUKk5IM,120514
5
5
  copyparty/broker_mp.py,sha256=QdOXXvV2Xn6J0CysEqyY3GZbqxQMyWnTpnba-a5lMc0,4987
6
6
  copyparty/broker_mpw.py,sha256=PpSS4SK3pItlpfD8OwVr3QmJEPKlUgaf2nuMOozixgU,3347
@@ -11,7 +11,7 @@ copyparty/cfg.py,sha256=O2jhYbt7WV9X80_Av1f7r4u1JVi7U5Z_cLgSGhpipLg,15423
11
11
  copyparty/dxml.py,sha256=vu5uZQtwvwoqnFHbULs2Zh_y2DETu0T-ENpMZ1i2CV4,2505
12
12
  copyparty/fsutil.py,sha256=NC_CJC4TDag399vVDH9_uQfdfpTMwRFLNxERSWhlVvs,4594
13
13
  copyparty/ftpd.py,sha256=xDDWixo5O2HT8wlexXQ0QRazU_fYERIJ4yF0mtu9wD0,18141
14
- copyparty/httpcli.py,sha256=ZNwaI4DVM6ljDz5ALRVuk07qG19i66_CLm9h6eARTSA,230544
14
+ copyparty/httpcli.py,sha256=u61-6XvcIzmOUXA9J2MTNz3VraKKRy9SLRNOTZZ5uAY,230976
15
15
  copyparty/httpconn.py,sha256=IA9fdCjigawZ4kWhgvVN3nSiy5pb3W2qaE6rFqUYdq0,6943
16
16
  copyparty/httpsrv.py,sha256=x6dl6ZjpwYREbm-eJZYnwdkhDeCA58hw_iwUMCD1Wz8,18819
17
17
  copyparty/ico.py,sha256=-7QjF_jIxnPo4Vr0oUPksQ_U_Ef0HRsSPm3s71idOz8,3879
@@ -32,7 +32,7 @@ copyparty/th_cli.py,sha256=IEX5tCb0gw9Z2aRIDL9bwdvJ6g5jhWZ8OEAAz16_xN4,5426
32
32
  copyparty/th_srv.py,sha256=INLaV1_NH1VKtBx9XaqyJbZNAj2ZhfcQwz0_5Y5fyiY,32744
33
33
  copyparty/u2idx.py,sha256=4Y5OOPyVkc-pS0z6e3p4StXAMnjHobSOMmMsvNUTD34,13674
34
34
  copyparty/up2k.py,sha256=S-SPTzLqxFvgSkFsWHqJwgUeT7QguLZgdZMQIh5eWiU,178957
35
- copyparty/util.py,sha256=p4Z2JHjIKWo-x5RS1kQl5qBG5T_E1FUV2pRfukAdyzA,104391
35
+ copyparty/util.py,sha256=AtY7rVW64F6xJ00FbM7f43YBiVI6ctjtjUeb6zahAeY,104493
36
36
  copyparty/bos/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
37
37
  copyparty/bos/bos.py,sha256=ZwpTla_mFpoN_BbGn9h0dEn7wpZ607QJ7uYyxWJMcmw,1953
38
38
  copyparty/bos/path.py,sha256=yEjCq2ki9CvxA5sCT8pS0keEXwugs0ZeUyUhdBziOCI,777
@@ -57,7 +57,7 @@ copyparty/stolen/ifaddr/_win32.py,sha256=EE-QyoBgeB7lYQ6z62VjXNaRozaYfCkaJBHGNA8
57
57
  copyparty/web/baguettebox.js.gz,sha256=MxRofvhXjmUN7RtXtC17_9AlROVNUT-66WwJ_pHLY9c,8258
58
58
  copyparty/web/browser.css.gz,sha256=29D3F4uB-VMd6uJo-SxWAwLfn08jcETYZm0SOJFJLAE,11847
59
59
  copyparty/web/browser.html,sha256=auvhLVE_t0aIN0q-nk0zOWFqITgDhroMAAviBNLoFfc,4788
60
- copyparty/web/browser.js.gz,sha256=EZ58H7mtO6VEjeNxU5ZOlbelSRTuc_-JAmAGd3S11aY,96694
60
+ copyparty/web/browser.js.gz,sha256=CUpLvqCMFQXpRFf_T15Ie0tJsCqmdJzJK-HYdD6Ea_o,96908
61
61
  copyparty/web/browser2.html,sha256=NRUZ08GH-e2YcGXcoz0UjYg6JIVF42u4IMX4HHwWTmg,1587
62
62
  copyparty/web/cf.html,sha256=lJThtNFNAQT1ClCHHlivAkDGE0LutedwopXD62Z8Nys,589
63
63
  copyparty/web/dbg-audio.js.gz,sha256=Ma-KZtK8LnmiwNvNKFKXMPYl_Nn_3U7GsJ6-DRWC2HE,688
@@ -85,7 +85,7 @@ copyparty/web/svcs.html,sha256=cxgrhX9wD0Z_kvidry3aS9ubuGXYDj2f4ehq1X8T1EA,14227
85
85
  copyparty/web/svcs.js.gz,sha256=lMXEP9W-VlXyANlva4q0ASSxvvHYlE2CrmxGgZXZop0,713
86
86
  copyparty/web/ui.css.gz,sha256=e3iIflzddmjoyPrun_1jsu9j7fbdonNQLyhEE2oKKOQ,2819
87
87
  copyparty/web/up2k.js.gz,sha256=_uOZzORAFO91SG3TUHd9xhKhAIXwL3fUFBNEUKnEVHY,24812
88
- copyparty/web/util.js.gz,sha256=qa1B5w3bW7NNOTtuiiiL1ZWboqD9YVNZMKn3y1mf-oU,15247
88
+ copyparty/web/util.js.gz,sha256=zC_5OONJOR2g33uVlyn4GufUWIOvVZCleUY-VW3lnTc,15327
89
89
  copyparty/web/w.hash.js.gz,sha256=cFH6Xo4YRgH9Wr7RmHMSEfpuTmmIvEmzmSvv4RLmyPU,1193
90
90
  copyparty/web/a/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
91
91
  copyparty/web/a/partyfuse.py,sha256=9p5Hpg_IBiSimv7j9kmPhCGpy-FLXSRUOYnLjJ5JifU,28049
@@ -110,9 +110,9 @@ copyparty/web/deps/prismd.css.gz,sha256=ObUlksQVr-OuYlTz-I4B23TeBg2QDVVGRnWBz8cV
110
110
  copyparty/web/deps/scp.woff2,sha256=w99BDU5i8MukkMEL-iW0YO9H4vFFZSPWxbkH70ytaAg,8612
111
111
  copyparty/web/deps/sha512.ac.js.gz,sha256=lFZaCLumgWxrvEuDr4bqdKHsqjX82AbVAb7_F45Yk88,7033
112
112
  copyparty/web/deps/sha512.hw.js.gz,sha256=UAed2_ocklZCnIzcSYz2h4P1ycztlCLj-ewsRTud2lU,7939
113
- copyparty-1.18.4.dist-info/licenses/LICENSE,sha256=gOr4h33pCsBEg9uIy9AYmb7qlocL4V9t2uPJS5wllr0,1072
114
- copyparty-1.18.4.dist-info/METADATA,sha256=4D8UUVWS75gzR3fW8ngJNPa_TNcGz8Dmci1CF_OHzq8,166420
115
- copyparty-1.18.4.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
116
- copyparty-1.18.4.dist-info/entry_points.txt,sha256=4zw6a3rqASywQomiYLObjjlxybaI65LYYOTJwgKz7b0,128
117
- copyparty-1.18.4.dist-info/top_level.txt,sha256=LnYUPsDyk-8kFgM6YJLG4h820DQekn81cObKSu9g-sI,10
118
- copyparty-1.18.4.dist-info/RECORD,,
113
+ copyparty-1.18.5.dist-info/licenses/LICENSE,sha256=gOr4h33pCsBEg9uIy9AYmb7qlocL4V9t2uPJS5wllr0,1072
114
+ copyparty-1.18.5.dist-info/METADATA,sha256=WETwkcbYrz8FBFDRd3SgMaHco780aGTuV_924AK0I5o,166420
115
+ copyparty-1.18.5.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
116
+ copyparty-1.18.5.dist-info/entry_points.txt,sha256=4zw6a3rqASywQomiYLObjjlxybaI65LYYOTJwgKz7b0,128
117
+ copyparty-1.18.5.dist-info/top_level.txt,sha256=LnYUPsDyk-8kFgM6YJLG4h820DQekn81cObKSu9g-sI,10
118
+ copyparty-1.18.5.dist-info/RECORD,,