Compare commits
No commits in common. "master" and "v1.0.3" have entirely different histories.
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@push.rocks/smartwebdav",
|
||||
"version": "1.1.2",
|
||||
"version": "1.0.3",
|
||||
"private": false,
|
||||
"description": "A TypeScript library for easy interaction with WebDAV servers, including file and directory management.",
|
||||
"main": "dist_ts/index.js",
|
||||
@ -29,12 +29,12 @@
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://code.foss.global/push.rocks/smartwebdav.git"
|
||||
"url": "git+https://code.foss.global/push.rocks/smartwebdav.git"
|
||||
},
|
||||
"bugs": {
|
||||
"url": "https://code.foss.global/push.rocks/smartwebdav/issues"
|
||||
},
|
||||
"homepage": "https://code.foss.global/push.rocks/smartwebdav",
|
||||
"homepage": "https://code.foss.global/push.rocks/smartwebdav#readme",
|
||||
"browserslist": [
|
||||
"last 1 chrome versions"
|
||||
],
|
||||
|
@ -3,6 +3,6 @@
|
||||
*/
|
||||
export const commitinfo = {
|
||||
name: '@push.rocks/smartwebdav',
|
||||
version: '1.1.2',
|
||||
version: '1.0.3',
|
||||
description: 'A TypeScript library for easy interaction with WebDAV servers, including file and directory management.'
|
||||
}
|
||||
|
@ -1,9 +1,8 @@
|
||||
import type { isFile } from '@push.rocks/smartpath/dist_ts/smartpath.check.js';
|
||||
import * as plugins from './plugins.js';
|
||||
|
||||
export interface IWebdavClientOptions {
|
||||
serverUrl: string;
|
||||
authType?: plugins.webdav.AuthType;
|
||||
authType: plugins.webdav.AuthType;
|
||||
username?: string;
|
||||
password?: string;
|
||||
}
|
||||
@ -12,11 +11,7 @@ export class WebdavClient {
|
||||
wdClient: plugins.webdav.WebDAVClient;
|
||||
constructor(optionsArg: IWebdavClientOptions) {
|
||||
this.wdClient = plugins.webdav.createClient(optionsArg.serverUrl, {
|
||||
...optionsArg.authType ? {
|
||||
authType: optionsArg.authType,
|
||||
} : {
|
||||
authType: plugins.webdav.AuthType.Password,
|
||||
},
|
||||
...(optionsArg.username
|
||||
? {
|
||||
username: optionsArg.username,
|
||||
@ -35,18 +30,6 @@ export class WebdavClient {
|
||||
return result as plugins.webdav.FileStat[];
|
||||
}
|
||||
|
||||
public async getDirectoryAsSmartfileArray(pathArg: string): Promise<plugins.smartfile.SmartFile[]> {
|
||||
const directoryListing = await this.listDirectory(pathArg);
|
||||
const smartfileArray: plugins.smartfile.SmartFile[] = [];
|
||||
for (const file of directoryListing) {
|
||||
const fileContents = (await this.wdClient.getFileContents(file.filename, {
|
||||
format: 'binary',
|
||||
})) as Buffer;
|
||||
smartfileArray.push(await plugins.smartfile.SmartFile.fromBuffer(file.filename, fileContents));
|
||||
}
|
||||
return smartfileArray;
|
||||
}
|
||||
|
||||
public async ensureDirectory(path: string): Promise<void> {
|
||||
console.log(`Ensuring directory at ${path}`);
|
||||
const pathLevels = plugins.smartpath.get.pathLevels(path);
|
||||
@ -113,27 +96,7 @@ export class WebdavClient {
|
||||
await this.wdClient.moveFile(sourcePathArg, targetPathArg);
|
||||
}
|
||||
|
||||
public async deleteFile(pathArg: string, checkNotDirectory = true) {
|
||||
if (!(await this.wdClient.exists(pathArg))) {
|
||||
throw new Error(`Path does not exist`);
|
||||
}
|
||||
if (checkNotDirectory && (await this.isDirecory(pathArg))) {
|
||||
throw new Error(`Path is a directory, not a file`);
|
||||
}
|
||||
public async deleteDirectory(pathArg: string) {
|
||||
await this.wdClient.deleteFile(pathArg);
|
||||
}
|
||||
|
||||
public async deleteDirectory(pathArg: string) {
|
||||
await this.deleteFile(pathArg, false);
|
||||
}
|
||||
|
||||
public async isFile(pathArg: string) {
|
||||
const stat = (await this.wdClient.stat(pathArg)) as plugins.webdav.FileStat;
|
||||
return stat.type === 'file';
|
||||
}
|
||||
|
||||
public async isDirecory(pathArg: string) {
|
||||
const stat = (await this.wdClient.stat(pathArg)) as plugins.webdav.FileStat;
|
||||
return stat.type === 'directory';
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user