fix: unzip override existed file in uploadonly mode
This commit is contained in:
parent
412d42e338
commit
6a097e0496
3 changed files with 9 additions and 6 deletions
|
@ -15,7 +15,7 @@
|
||||||
<svg width="16" height="16" viewBox="0 0 16 16"><path d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"/><path d="M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z"/></svg>
|
<svg width="16" height="16" viewBox="0 0 16 16"><path d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"/><path d="M7.646 11.854a.5.5 0 0 0 .708 0l3-3a.5.5 0 0 0-.708-.708L8.5 10.293V1.5a.5.5 0 0 0-1 0v8.793L5.354 8.146a.5.5 0 1 0-.708.708l3 3z"/></svg>
|
||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
<div class="upload-control hidden" title="Upload file">
|
<div class="upload-control hidden" title="Upload files">
|
||||||
<label for="file">
|
<label for="file">
|
||||||
<svg width="16" height="16" viewBox="0 0 16 16"><path d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"/><path d="M7.646 1.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 2.707V11.5a.5.5 0 0 1-1 0V2.707L5.354 4.854a.5.5 0 1 1-.708-.708l3-3z"/></svg>
|
<svg width="16" height="16" viewBox="0 0 16 16"><path d="M.5 9.9a.5.5 0 0 1 .5.5v2.5a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-2.5a.5.5 0 0 1 1 0v2.5a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2v-2.5a.5.5 0 0 1 .5-.5z"/><path d="M7.646 1.146a.5.5 0 0 1 .708 0l3 3a.5.5 0 0 1-.708.708L8.5 2.707V11.5a.5.5 0 0 1-1 0V2.707L5.354 4.854a.5.5 0 1 1-.708-.708l3-3z"/></svg>
|
||||||
</label>
|
</label>
|
||||||
|
|
|
@ -27,7 +27,6 @@ class Uploader {
|
||||||
const ajax = new XMLHttpRequest();
|
const ajax = new XMLHttpRequest();
|
||||||
ajax.upload.addEventListener("progress", e => this.progress(e), false);
|
ajax.upload.addEventListener("progress", e => this.progress(e), false);
|
||||||
ajax.addEventListener("readystatechange", () => {
|
ajax.addEventListener("readystatechange", () => {
|
||||||
console.log(ajax.readyState, ajax.status)
|
|
||||||
if(ajax.readyState === 4) {
|
if(ajax.readyState === 4) {
|
||||||
if (ajax.status == 200) {
|
if (ajax.status == 200) {
|
||||||
this.complete();
|
this.complete();
|
||||||
|
|
|
@ -11,7 +11,8 @@ use headers::{
|
||||||
HeaderMap, HeaderMapExt, IfModifiedSince, IfNoneMatch, IfRange, LastModified, Range,
|
HeaderMap, HeaderMapExt, IfModifiedSince, IfNoneMatch, IfRange, LastModified, Range,
|
||||||
};
|
};
|
||||||
use hyper::header::{
|
use hyper::header::{
|
||||||
HeaderValue, ACCEPT, CONTENT_DISPOSITION, CONTENT_TYPE, ORIGIN, RANGE, WWW_AUTHENTICATE,
|
HeaderValue, ACCEPT, AUTHORIZATION, CONTENT_DISPOSITION, CONTENT_TYPE, ORIGIN, RANGE,
|
||||||
|
WWW_AUTHENTICATE,
|
||||||
};
|
};
|
||||||
use hyper::service::{make_service_fn, service_fn};
|
use hyper::service::{make_service_fn, service_fn};
|
||||||
use hyper::{Body, Method, StatusCode};
|
use hyper::{Body, Method, StatusCode};
|
||||||
|
@ -193,8 +194,8 @@ impl InnerService {
|
||||||
|
|
||||||
io::copy(&mut body_reader, &mut file).await?;
|
io::copy(&mut body_reader, &mut file).await?;
|
||||||
|
|
||||||
let req_query = req.uri().query().unwrap_or_default();
|
let query = req.uri().query().unwrap_or_default();
|
||||||
if req_query == "unzip" {
|
if query == "unzip" {
|
||||||
let root = path.parent().unwrap();
|
let root = path.parent().unwrap();
|
||||||
let mut zip = ZipFileReader::new(File::open(&path).await?).await?;
|
let mut zip = ZipFileReader::new(File::open(&path).await?).await?;
|
||||||
for i in 0..zip.entries().len() {
|
for i in 0..zip.entries().len() {
|
||||||
|
@ -204,6 +205,9 @@ impl InnerService {
|
||||||
if entry_name.ends_with('/') {
|
if entry_name.ends_with('/') {
|
||||||
fs::create_dir_all(entry_path).await?;
|
fs::create_dir_all(entry_path).await?;
|
||||||
} else {
|
} else {
|
||||||
|
if !self.args.allow_delete && fs::metadata(&entry_path).await.is_ok() {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if let Some(parent) = entry_path.parent() {
|
if let Some(parent) = entry_path.parent() {
|
||||||
if fs::symlink_metadata(parent).await.is_err() {
|
if fs::symlink_metadata(parent).await.is_err() {
|
||||||
fs::create_dir_all(&parent).await?;
|
fs::create_dir_all(&parent).await?;
|
||||||
|
@ -395,7 +399,7 @@ impl InnerService {
|
||||||
let pass = {
|
let pass = {
|
||||||
match &self.args.auth {
|
match &self.args.auth {
|
||||||
None => true,
|
None => true,
|
||||||
Some(auth) => match req.headers().get("Authorization") {
|
Some(auth) => match req.headers().get(AUTHORIZATION) {
|
||||||
Some(value) => match value.to_str().ok().map(|v| {
|
Some(value) => match value.to_str().ok().map(|v| {
|
||||||
let mut it = v.split(' ');
|
let mut it = v.split(' ');
|
||||||
(it.next(), it.next())
|
(it.next(), it.next())
|
||||||
|
|
Loading…
Reference in a new issue