2019-03-11 01:42:53 +00:00
|
|
|
import {withCredentials} from "@/api/http";
|
|
|
|
import {ServerApplicationCredentials} from "@/store/types";
|
|
|
|
|
2019-03-16 23:36:08 +00:00
|
|
|
type PathChangeObject = {
|
|
|
|
currentPath: string,
|
|
|
|
newPath: string,
|
|
|
|
}
|
2019-03-11 01:42:53 +00:00
|
|
|
/**
|
|
|
|
* Creates a copy of the given file or directory on the Daemon. Expects a fully resolved path
|
|
|
|
* to be passed through for both data arguments.
|
|
|
|
*/
|
2019-03-16 23:36:08 +00:00
|
|
|
export function copyElement(server: string, credentials: ServerApplicationCredentials, data: PathChangeObject, isMove = false): Promise<void> {
|
2019-03-11 01:42:53 +00:00
|
|
|
return new Promise((resolve, reject) => {
|
2019-03-16 23:36:08 +00:00
|
|
|
withCredentials(server, credentials).post(`/v1/server/file/${isMove ? 'move' : 'copy'}`, {
|
2019-03-11 01:42:53 +00:00
|
|
|
from: data.currentPath,
|
|
|
|
to: data.newPath,
|
|
|
|
})
|
|
|
|
.then(() => resolve())
|
|
|
|
.catch(reject);
|
|
|
|
});
|
|
|
|
}
|
2019-03-16 23:36:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Moves a file or folder to a new location on the server. Works almost exactly the same as the copy
|
|
|
|
* file logic, so it really just passes an extra argument to copy to indicate that it is a move.
|
|
|
|
*/
|
|
|
|
export function moveElement(server: string, credentials: ServerApplicationCredentials, data: PathChangeObject): Promise<void> {
|
|
|
|
return copyElement(server, credentials, data, true);
|
|
|
|
}
|