/** * @copyright Copyright (c) 2020 John Molakvoæ * * @author John Molakvoæ * * @license AGPL-3.0-or-later * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * */ import { parseXML, type DAVResult, type FileStat, type ResponseDataDetailed } from 'webdav' // https://github.com/perry-mitchell/webdav-client/issues/339 import { processResponsePayload } from 'webdav/dist/node/response.js' import { prepareFileFromProps } from 'webdav/dist/node/tools/dav.js' import client from './DavClient.js' export const DEFAULT_LIMIT = 20 /** * Retrieve the comments list * * @param {object} data destructuring object * @param {string} data.resourceType the resource type * @param {number} data.resourceId the resource ID * @param {object} [options] optional options for axios * @param {number} [options.offset] the pagination offset * @param {number} [options.limit] the pagination limit, defaults to 20 * @param {Date} [options.datetime] optional date to query * @return {{data: object[]}} the comments list */ export const getComments = async function({ resourceType, resourceId }, options: { offset: number, limit?: number, datetime?: Date }) { const resourcePath = ['', resourceType, resourceId].join('/') const datetime = options.datetime ? `${options.datetime.toISOString()}` : '' const response = await client.customRequest(resourcePath, Object.assign({ method: 'REPORT', data: ` ${options.limit ?? DEFAULT_LIMIT} ${options.offset || 0} ${datetime} `, }, options)) const responseData = await response.text() const result = await parseXML(responseData) const stat = getDirectoryFiles(result, true) return processResponsePayload(response, stat, true) as ResponseDataDetailed } // https://github.com/perry-mitchell/webdav-client/blob/8d9694613c978ce7404e26a401c39a41f125f87f/source/operations/directoryContents.ts const getDirectoryFiles = function( result: DAVResult, isDetailed = false, ): Array { // Extract the response items (directory contents) const { multistatus: { response: responseItems }, } = result // Map all items to a consistent output structure (results) return responseItems.map(item => { // Each item should contain a stat object const props = item.propstat!.prop!; return prepareFileFromProps(props, props.id!.toString(), isDetailed) }) }