2021-11-30 15:39:08 +00:00
|
|
|
//
|
|
|
|
// Copyright © 2020, 2021 Anticrm Platform Contributors.
|
|
|
|
// Copyright © 2021 Hardcore Engineering Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Eclipse Public License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License. You may
|
|
|
|
// obtain a copy of the License at https://www.eclipse.org/legal/epl-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
//
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
//
|
|
|
|
|
2022-09-21 08:08:25 +00:00
|
|
|
import type { Class, Doc, Ref, Space, TxOperations as Client } from '@hcengineering/core'
|
|
|
|
import login from '@hcengineering/login'
|
|
|
|
import { getMetadata, setPlatformStatus, unknownError } from '@hcengineering/platform'
|
2022-04-12 17:28:46 +00:00
|
|
|
|
|
|
|
import attachment from './plugin'
|
2021-11-30 15:39:08 +00:00
|
|
|
|
2022-04-23 02:40:38 +00:00
|
|
|
export async function uploadFile (file: File, opts?: { space: Ref<Space>, attachedTo: Ref<Doc> }): Promise<string> {
|
2021-11-30 15:39:08 +00:00
|
|
|
const uploadUrl = getMetadata(login.metadata.UploadUrl)
|
|
|
|
|
2022-01-20 09:27:41 +00:00
|
|
|
if (uploadUrl === undefined) {
|
|
|
|
throw Error('UploadURL is not defined')
|
|
|
|
}
|
|
|
|
|
2021-11-30 15:39:08 +00:00
|
|
|
const data = new FormData()
|
|
|
|
data.append('file', file)
|
|
|
|
|
2022-04-13 10:46:19 +00:00
|
|
|
const params =
|
|
|
|
opts !== undefined
|
|
|
|
? [
|
|
|
|
['space', opts.space],
|
|
|
|
['attachedTo', opts.attachedTo]
|
|
|
|
]
|
|
|
|
.filter((x): x is [string, Ref<any>] => x[1] !== undefined)
|
|
|
|
.map(([name, value]) => `${name}=${value}`)
|
|
|
|
.join('&')
|
|
|
|
: ''
|
2022-01-20 09:27:41 +00:00
|
|
|
const suffix = params === '' ? params : `?${params}`
|
2022-01-12 09:52:22 +00:00
|
|
|
|
2022-01-20 09:27:41 +00:00
|
|
|
const url = `${uploadUrl}${suffix}`
|
2021-11-30 15:39:08 +00:00
|
|
|
const resp = await fetch(url, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
Authorization: 'Bearer ' + (getMetadata(login.metadata.LoginToken) as string)
|
|
|
|
},
|
|
|
|
body: data
|
|
|
|
})
|
2022-01-20 09:27:41 +00:00
|
|
|
|
2021-11-30 15:39:08 +00:00
|
|
|
if (resp.status !== 200) {
|
2022-01-20 09:27:41 +00:00
|
|
|
throw Error(`Failed to upload file: ${resp.statusText}`)
|
2021-11-30 15:39:08 +00:00
|
|
|
}
|
2022-01-20 09:27:41 +00:00
|
|
|
|
|
|
|
return await resp.text()
|
2021-11-30 15:39:08 +00:00
|
|
|
}
|
2022-01-14 09:09:01 +00:00
|
|
|
|
2022-04-23 02:40:38 +00:00
|
|
|
export async function deleteFile (id: string): Promise<void> {
|
2022-01-14 09:09:01 +00:00
|
|
|
const uploadUrl = getMetadata(login.metadata.UploadUrl)
|
|
|
|
|
|
|
|
const url = `${uploadUrl as string}?file=${id}`
|
|
|
|
const resp = await fetch(url, {
|
|
|
|
method: 'DELETE',
|
|
|
|
headers: {
|
|
|
|
Authorization: 'Bearer ' + (getMetadata(login.metadata.LoginToken) as string)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (resp.status !== 200) {
|
|
|
|
throw new Error('Failed to delete file')
|
|
|
|
}
|
|
|
|
}
|
2022-03-12 12:24:30 +00:00
|
|
|
|
2022-04-23 02:40:38 +00:00
|
|
|
export async function createAttachments (
|
2022-04-13 10:46:19 +00:00
|
|
|
client: Client,
|
|
|
|
list: FileList,
|
2022-04-23 02:40:38 +00:00
|
|
|
attachTo: { objectClass: Ref<Class<Doc>>, space: Ref<Space>, objectId: Ref<Doc> }
|
2022-04-29 05:27:17 +00:00
|
|
|
): Promise<void> {
|
2022-04-13 10:46:19 +00:00
|
|
|
const { objectClass, objectId, space } = attachTo
|
2022-04-12 17:28:46 +00:00
|
|
|
try {
|
2022-04-13 10:46:19 +00:00
|
|
|
for (let index = 0; index < list.length; index++) {
|
|
|
|
const file = list.item(index)
|
|
|
|
if (file !== null) {
|
|
|
|
const uuid = await uploadFile(file, { space, attachedTo: objectId })
|
2022-04-29 05:27:17 +00:00
|
|
|
await client.addCollection(attachment.class.Attachment, space, objectId, objectClass, 'attachments', {
|
2022-04-13 10:46:19 +00:00
|
|
|
name: file.name,
|
|
|
|
file: uuid,
|
|
|
|
type: file.type,
|
|
|
|
size: file.size,
|
|
|
|
lastModified: file.lastModified
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2022-04-12 17:28:46 +00:00
|
|
|
} catch (err: any) {
|
2022-04-29 05:27:17 +00:00
|
|
|
await setPlatformStatus(unknownError(err))
|
2022-04-12 17:28:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-23 02:40:38 +00:00
|
|
|
export function getType (type: string): 'image' | 'video' | 'audio' | 'pdf' | 'other' {
|
2022-03-12 12:24:30 +00:00
|
|
|
if (type.startsWith('image/')) {
|
|
|
|
return 'image'
|
|
|
|
}
|
|
|
|
if (type.startsWith('audio/')) {
|
|
|
|
return 'audio'
|
|
|
|
}
|
|
|
|
if (type.startsWith('video/')) {
|
|
|
|
return 'video'
|
|
|
|
}
|
|
|
|
if (type.includes('application/pdf')) {
|
|
|
|
return 'pdf'
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'other'
|
|
|
|
}
|