fix: ui readonly if no write perm (#258)
This commit is contained in:
parent
0fd0f11298
commit
9545fb6e37
3 changed files with 47 additions and 6 deletions
|
@ -460,7 +460,7 @@ impl Server {
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
let mut paths = vec![];
|
let mut paths = vec![];
|
||||||
if exist {
|
if exist {
|
||||||
paths = match self.list_dir(path, path, access_paths).await {
|
paths = match self.list_dir(path, path, access_paths.clone()).await {
|
||||||
Ok(paths) => paths,
|
Ok(paths) => paths,
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
status_forbid(res);
|
status_forbid(res);
|
||||||
|
@ -468,7 +468,16 @@ impl Server {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
self.send_index(path, paths, exist, query_params, head_only, user, res)
|
self.send_index(
|
||||||
|
path,
|
||||||
|
paths,
|
||||||
|
exist,
|
||||||
|
query_params,
|
||||||
|
head_only,
|
||||||
|
user,
|
||||||
|
access_paths,
|
||||||
|
res,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn handle_search_dir(
|
async fn handle_search_dir(
|
||||||
|
@ -490,6 +499,7 @@ impl Server {
|
||||||
let hidden = Arc::new(self.args.hidden.to_vec());
|
let hidden = Arc::new(self.args.hidden.to_vec());
|
||||||
let hidden = hidden.clone();
|
let hidden = hidden.clone();
|
||||||
let running = self.running.clone();
|
let running = self.running.clone();
|
||||||
|
let access_paths = access_paths.clone();
|
||||||
let search_paths = tokio::task::spawn_blocking(move || {
|
let search_paths = tokio::task::spawn_blocking(move || {
|
||||||
let mut paths: Vec<PathBuf> = vec![];
|
let mut paths: Vec<PathBuf> = vec![];
|
||||||
for dir in access_paths.leaf_paths(&path_buf) {
|
for dir in access_paths.leaf_paths(&path_buf) {
|
||||||
|
@ -534,7 +544,16 @@ impl Server {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
self.send_index(path, paths, true, query_params, head_only, user, res)
|
self.send_index(
|
||||||
|
path,
|
||||||
|
paths,
|
||||||
|
true,
|
||||||
|
query_params,
|
||||||
|
head_only,
|
||||||
|
user,
|
||||||
|
access_paths,
|
||||||
|
res,
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn handle_zip_dir(
|
async fn handle_zip_dir(
|
||||||
|
@ -928,6 +947,7 @@ impl Server {
|
||||||
query_params: &HashMap<String, String>,
|
query_params: &HashMap<String, String>,
|
||||||
head_only: bool,
|
head_only: bool,
|
||||||
user: Option<String>,
|
user: Option<String>,
|
||||||
|
access_paths: AccessPaths,
|
||||||
res: &mut Response,
|
res: &mut Response,
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
if let Some(sort) = query_params.get("sort") {
|
if let Some(sort) = query_params.get("sort") {
|
||||||
|
@ -988,12 +1008,13 @@ impl Server {
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
let href = format!("/{}", normalize_path(path.strip_prefix(&self.args.path)?));
|
let href = format!("/{}", normalize_path(path.strip_prefix(&self.args.path)?));
|
||||||
|
let readwrite = access_paths.perm().readwrite();
|
||||||
let data = IndexData {
|
let data = IndexData {
|
||||||
kind: DataKind::Index,
|
kind: DataKind::Index,
|
||||||
href,
|
href,
|
||||||
uri_prefix: self.args.uri_prefix.clone(),
|
uri_prefix: self.args.uri_prefix.clone(),
|
||||||
allow_upload: self.args.allow_upload,
|
allow_upload: self.args.allow_upload && readwrite,
|
||||||
allow_delete: self.args.allow_delete,
|
allow_delete: self.args.allow_delete && readwrite,
|
||||||
allow_search: self.args.allow_search,
|
allow_search: self.args.allow_search,
|
||||||
allow_archive: self.args.allow_archive,
|
allow_archive: self.args.allow_archive,
|
||||||
dir_exists: exist,
|
dir_exists: exist,
|
||||||
|
|
|
@ -213,3 +213,22 @@ fn no_auth_propfind_dir(
|
||||||
assert!(body.contains("<D:href>/dir1/</D:href>"));
|
assert!(body.contains("<D:href>/dir1/</D:href>"));
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[rstest]
|
||||||
|
fn auth_data(
|
||||||
|
#[with(&["--auth", "user:pass@/:rw|@/", "-A", "--auth-method", "basic"])] server: TestServer,
|
||||||
|
) -> Result<(), Error> {
|
||||||
|
let resp = reqwest::blocking::get(server.url())?;
|
||||||
|
let content = resp.text()?;
|
||||||
|
let json = utils::retrive_json(&content).unwrap();
|
||||||
|
assert_eq!(json["allow_delete"], serde_json::Value::Bool(false));
|
||||||
|
assert_eq!(json["allow_upload"], serde_json::Value::Bool(false));
|
||||||
|
let resp = fetch!(b"GET", server.url())
|
||||||
|
.basic_auth("user", Some("pass"))
|
||||||
|
.send()?;
|
||||||
|
let content = resp.text()?;
|
||||||
|
let json = utils::retrive_json(&content).unwrap();
|
||||||
|
assert_eq!(json["allow_delete"], serde_json::Value::Bool(true));
|
||||||
|
assert_eq!(json["allow_upload"], serde_json::Value::Bool(true));
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
|
@ -59,7 +59,8 @@ pub fn encode_uri(v: &str) -> String {
|
||||||
parts.join("/")
|
parts.join("/")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn retrive_json(content: &str) -> Option<Value> {
|
#[allow(dead_code)]
|
||||||
|
pub fn retrive_json(content: &str) -> Option<Value> {
|
||||||
let lines: Vec<&str> = content.lines().collect();
|
let lines: Vec<&str> = content.lines().collect();
|
||||||
let line = lines.iter().find(|v| v.contains("DATA ="))?;
|
let line = lines.iter().find(|v| v.contains("DATA ="))?;
|
||||||
let line_col = line.find("DATA =").unwrap() + 6;
|
let line_col = line.find("DATA =").unwrap() + 6;
|
||||||
|
|
Loading…
Reference in a new issue