@payloadcms/plugin-cloud-storage 1.0.17 → 1.0.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -3
- package/dist/adapters/azure/handleUpload.js +3 -2
- package/dist/adapters/azure/handleUpload.js.map +1 -1
- package/dist/adapters/gcs/handleUpload.js +3 -2
- package/dist/adapters/gcs/handleUpload.js.map +1 -1
- package/dist/adapters/s3/handleUpload.js +1 -1
- package/dist/adapters/s3/handleUpload.js.map +1 -1
- package/dist/adapters/s3/index.d.ts +10 -0
- package/dist/adapters/s3/index.js +1 -1
- package/dist/adapters/s3/index.js.map +1 -1
- package/dist/fields/getFields.js +1 -1
- package/dist/fields/getFields.js.map +1 -1
- package/package.json +1 -1
- package/.editorconfig +0 -10
- package/.gitignore +0 -248
- package/.prettierignore +0 -1
- package/.prettierrc.js +0 -8
- package/.vscode/launch.json +0 -40
- package/.vscode/settings.json +0 -9
- package/dev/.env +0 -21
- package/dev/.env.example +0 -21
- package/dev/dist/dev/src/collections/Media.js +0 -56
- package/dev/dist/dev/src/collections/Media.js.map +0 -1
- package/dev/dist/dev/src/collections/Users.js +0 -23
- package/dev/dist/dev/src/collections/Users.js.map +0 -1
- package/dev/dist/dev/src/payload.config.js +0 -153
- package/dev/dist/dev/src/payload.config.js.map +0 -1
- package/dev/dist/dev/src/server.js +0 -26
- package/dev/dist/dev/src/server.js.map +0 -1
- package/dev/dist/src/adapters/azure/generateURL.js +0 -16
- package/dev/dist/src/adapters/azure/generateURL.js.map +0 -1
- package/dev/dist/src/adapters/azure/handleDelete.js +0 -64
- package/dev/dist/src/adapters/azure/handleDelete.js.map +0 -1
- package/dev/dist/src/adapters/azure/handleUpload.js +0 -81
- package/dev/dist/src/adapters/azure/handleUpload.js.map +0 -1
- package/dev/dist/src/adapters/azure/index.js +0 -43
- package/dev/dist/src/adapters/azure/index.js.map +0 -1
- package/dev/dist/src/adapters/azure/staticHandler.js +0 -82
- package/dev/dist/src/adapters/azure/staticHandler.js.map +0 -1
- package/dev/dist/src/adapters/azure/webpack.js +0 -25
- package/dev/dist/src/adapters/azure/webpack.js.map +0 -1
- package/dev/dist/src/adapters/gcs/generateURL.js +0 -16
- package/dev/dist/src/adapters/gcs/generateURL.js.map +0 -1
- package/dev/dist/src/adapters/gcs/handleDelete.js +0 -63
- package/dev/dist/src/adapters/gcs/handleDelete.js.map +0 -1
- package/dev/dist/src/adapters/gcs/handleUpload.js +0 -73
- package/dev/dist/src/adapters/gcs/handleUpload.js.map +0 -1
- package/dev/dist/src/adapters/gcs/index.js +0 -36
- package/dev/dist/src/adapters/gcs/index.js.map +0 -1
- package/dev/dist/src/adapters/gcs/staticHandler.js +0 -77
- package/dev/dist/src/adapters/gcs/staticHandler.js.map +0 -1
- package/dev/dist/src/adapters/gcs/webpack.js +0 -25
- package/dev/dist/src/adapters/gcs/webpack.js.map +0 -1
- package/dev/dist/src/adapters/s3/generateURL.js +0 -16
- package/dev/dist/src/adapters/s3/generateURL.js.map +0 -1
- package/dev/dist/src/adapters/s3/handleDelete.js +0 -64
- package/dev/dist/src/adapters/s3/handleDelete.js.map +0 -1
- package/dev/dist/src/adapters/s3/handleUpload.js +0 -94
- package/dev/dist/src/adapters/s3/handleUpload.js.map +0 -1
- package/dev/dist/src/adapters/s3/index.js +0 -60
- package/dev/dist/src/adapters/s3/index.js.map +0 -1
- package/dev/dist/src/adapters/s3/staticHandler.js +0 -82
- package/dev/dist/src/adapters/s3/staticHandler.js.map +0 -1
- package/dev/dist/src/adapters/s3/webpack.js +0 -25
- package/dev/dist/src/adapters/s3/webpack.js.map +0 -1
- package/dev/dist/src/fields/getFields.js +0 -119
- package/dev/dist/src/fields/getFields.js.map +0 -1
- package/dev/dist/src/hooks/afterDelete.js +0 -92
- package/dev/dist/src/hooks/afterDelete.js.map +0 -1
- package/dev/dist/src/hooks/afterRead.js +0 -80
- package/dev/dist/src/hooks/afterRead.js.map +0 -1
- package/dev/dist/src/hooks/beforeChange.js +0 -106
- package/dev/dist/src/hooks/beforeChange.js.map +0 -1
- package/dev/dist/src/index.js +0 -6
- package/dev/dist/src/index.js.map +0 -1
- package/dev/dist/src/plugin.js +0 -131
- package/dev/dist/src/plugin.js.map +0 -1
- package/dev/dist/src/types.js +0 -3
- package/dev/dist/src/types.js.map +0 -1
- package/dev/dist/src/utilities/getFilePrefix.js +0 -81
- package/dev/dist/src/utilities/getFilePrefix.js.map +0 -1
- package/dev/dist/src/utilities/getIncomingFiles.js +0 -38
- package/dev/dist/src/utilities/getIncomingFiles.js.map +0 -1
- package/dev/dist/src/utilities/getRangeFromHeader.js +0 -67
- package/dev/dist/src/utilities/getRangeFromHeader.js.map +0 -1
- package/dev/dist/src/webpack.js +0 -40
- package/dev/dist/src/webpack.js.map +0 -1
- package/dev/nodemon.json +0 -8
- package/dev/package.json +0 -34
- package/dev/src/collections/Media.ts +0 -56
- package/dev/src/collections/Users.ts +0 -23
- package/dev/src/mocks/fsMock.js +0 -1
- package/dev/src/mocks/promisifyMock.js +0 -1
- package/dev/src/payload.config.ts +0 -111
- package/dev/src/server.ts +0 -26
- package/dev/tsconfig.json +0 -20
- package/docs/local-dev.md +0 -47
- package/eslint-config/index.js +0 -15
- package/eslint-config/rules/import.js +0 -38
- package/eslint-config/rules/prettier.js +0 -7
- package/eslint-config/rules/style.js +0 -21
- package/eslint-config/rules/typescript.js +0 -628
- package/src/adapters/azure/emulator/docker-compose.yml +0 -16
- package/src/adapters/azure/fileStub.js +0 -1
- package/src/adapters/azure/generateURL.ts +0 -13
- package/src/adapters/azure/handleDelete.ts +0 -16
- package/src/adapters/azure/handleUpload.ts +0 -41
- package/src/adapters/azure/index.ts +0 -48
- package/src/adapters/azure/mock.js +0 -13
- package/src/adapters/azure/staticHandler.ts +0 -38
- package/src/adapters/azure/webpack.ts +0 -24
- package/src/adapters/gcs/emulator/docker-compose.yml +0 -15
- package/src/adapters/gcs/generateURL.ts +0 -16
- package/src/adapters/gcs/handleDelete.ts +0 -16
- package/src/adapters/gcs/handleUpload.ts +0 -34
- package/src/adapters/gcs/index.ts +0 -37
- package/src/adapters/gcs/mock.js +0 -3
- package/src/adapters/gcs/staticHandler.ts +0 -34
- package/src/adapters/gcs/webpack.ts +0 -21
- package/src/adapters/s3/emulator/.localstack/cache/machine.json +0 -1
- package/src/adapters/s3/emulator/.localstack/cache/server.test.pem +0 -127
- package/src/adapters/s3/emulator/.localstack/cache/server.test.pem.crt +0 -99
- package/src/adapters/s3/emulator/.localstack/cache/server.test.pem.key +0 -28
- package/src/adapters/s3/emulator/.localstack/cache/service-catalog-2_1_1_dev-1_29_149.pickle +0 -0
- package/src/adapters/s3/emulator/docker-compose.yml +0 -15
- package/src/adapters/s3/fileStub.js +0 -1
- package/src/adapters/s3/fsMock.js +0 -1
- package/src/adapters/s3/generateURL.ts +0 -14
- package/src/adapters/s3/handleDelete.ts +0 -17
- package/src/adapters/s3/handleUpload.ts +0 -62
- package/src/adapters/s3/index.ts +0 -38
- package/src/adapters/s3/mock.js +0 -9
- package/src/adapters/s3/staticHandler.ts +0 -41
- package/src/adapters/s3/webpack.ts +0 -23
- package/src/fields/getFields.ts +0 -155
- package/src/hooks/afterDelete.ts +0 -35
- package/src/hooks/afterRead.ts +0 -38
- package/src/hooks/beforeChange.ts +0 -59
- package/src/index.ts +0 -1
- package/src/plugin.ts +0 -101
- package/src/types.ts +0 -79
- package/src/utilities/getFilePrefix.ts +0 -26
- package/src/utilities/getIncomingFiles.ts +0 -44
- package/src/utilities/getRangeFromHeader.ts +0 -27
- package/src/webpack.ts +0 -46
- package/tsconfig.json +0 -23
- package/yarn-error.log +0 -8163
- package/yarn.lock +0 -8062
package/src/types.ts
DELETED
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import type { NextFunction, Response } from 'express'
|
|
2
|
-
import type { TypeWithID } from 'payload/dist/collections/config/types'
|
|
3
|
-
import type { FileData, ImageSize } from 'payload/dist/uploads/types'
|
|
4
|
-
import type { CollectionConfig, PayloadRequest } from 'payload/types'
|
|
5
|
-
import type { Configuration as WebpackConfig } from 'webpack'
|
|
6
|
-
|
|
7
|
-
export interface File {
|
|
8
|
-
buffer: Buffer
|
|
9
|
-
filename: string
|
|
10
|
-
filesize: number
|
|
11
|
-
mimeType: string
|
|
12
|
-
tempFilePath?: string
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export type HandleUpload = (args: {
|
|
16
|
-
collection: CollectionConfig
|
|
17
|
-
req: PayloadRequest
|
|
18
|
-
data: any
|
|
19
|
-
file: File
|
|
20
|
-
}) => Promise<void> | void
|
|
21
|
-
|
|
22
|
-
export interface TypeWithPrefix {
|
|
23
|
-
prefix?: string
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export type HandleDelete = (args: {
|
|
27
|
-
collection: CollectionConfig
|
|
28
|
-
req: PayloadRequest
|
|
29
|
-
doc: TypeWithID & FileData & TypeWithPrefix
|
|
30
|
-
filename: string
|
|
31
|
-
}) => Promise<void> | void
|
|
32
|
-
|
|
33
|
-
export type GenerateURL = (args: {
|
|
34
|
-
filename: string
|
|
35
|
-
collection: CollectionConfig
|
|
36
|
-
prefix?: string
|
|
37
|
-
}) => string | Promise<string>
|
|
38
|
-
|
|
39
|
-
export type StaticHandler = (
|
|
40
|
-
req: PayloadRequest,
|
|
41
|
-
res: Response,
|
|
42
|
-
next: NextFunction,
|
|
43
|
-
) => Promise<unknown> | unknown
|
|
44
|
-
|
|
45
|
-
export interface GeneratedAdapter {
|
|
46
|
-
handleUpload: HandleUpload
|
|
47
|
-
handleDelete: HandleDelete
|
|
48
|
-
generateURL: GenerateURL
|
|
49
|
-
staticHandler: StaticHandler
|
|
50
|
-
webpack?: (config: WebpackConfig) => WebpackConfig
|
|
51
|
-
onInit?: () => void
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
export type Adapter = (args: { collection: CollectionConfig; prefix?: string }) => GeneratedAdapter
|
|
55
|
-
|
|
56
|
-
export type GenerateFileURL = (args: {
|
|
57
|
-
collection: CollectionConfig
|
|
58
|
-
filename: string
|
|
59
|
-
prefix?: string
|
|
60
|
-
size?: ImageSize
|
|
61
|
-
}) => Promise<string> | string
|
|
62
|
-
|
|
63
|
-
export interface CollectionOptions {
|
|
64
|
-
disableLocalStorage?: boolean
|
|
65
|
-
disablePayloadAccessControl?: true
|
|
66
|
-
generateFileURL?: GenerateFileURL
|
|
67
|
-
prefix?: string
|
|
68
|
-
adapter: Adapter | null
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export interface PluginOptions {
|
|
72
|
-
/**
|
|
73
|
-
* Whether or not to enable the plugin
|
|
74
|
-
*
|
|
75
|
-
* Default: true
|
|
76
|
-
*/
|
|
77
|
-
enabled?: boolean
|
|
78
|
-
collections: Record<string, CollectionOptions>
|
|
79
|
-
}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import type { CollectionConfig, PayloadRequest } from 'payload/types'
|
|
2
|
-
import { IncomingUploadType } from 'payload/dist/uploads/types'
|
|
3
|
-
|
|
4
|
-
export async function getFilePrefix({
|
|
5
|
-
req,
|
|
6
|
-
collection,
|
|
7
|
-
}: {
|
|
8
|
-
req: PayloadRequest
|
|
9
|
-
collection: CollectionConfig
|
|
10
|
-
}): Promise<string> {
|
|
11
|
-
const imageSizes = (collection?.upload as IncomingUploadType)?.imageSizes || []
|
|
12
|
-
const files = await req.payload.find({
|
|
13
|
-
collection: collection.slug,
|
|
14
|
-
where: {
|
|
15
|
-
or: [
|
|
16
|
-
{
|
|
17
|
-
filename: { equals: req.params.filename },
|
|
18
|
-
},
|
|
19
|
-
...imageSizes.map(imageSize => ({
|
|
20
|
-
[`sizes.${imageSize.name}.filename`]: { equals: req.params.filename },
|
|
21
|
-
})),
|
|
22
|
-
],
|
|
23
|
-
},
|
|
24
|
-
})
|
|
25
|
-
return files?.docs?.[0]?.prefix || ''
|
|
26
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import type { FileData } from 'payload/dist/uploads/types'
|
|
2
|
-
import type { PayloadRequest } from 'payload/types'
|
|
3
|
-
import type { File } from '../types'
|
|
4
|
-
|
|
5
|
-
export function getIncomingFiles({
|
|
6
|
-
req,
|
|
7
|
-
data,
|
|
8
|
-
}: {
|
|
9
|
-
data: Partial<FileData>
|
|
10
|
-
req: PayloadRequest
|
|
11
|
-
}): File[] {
|
|
12
|
-
const file = req.files?.file
|
|
13
|
-
|
|
14
|
-
let files: File[] = []
|
|
15
|
-
|
|
16
|
-
if (file && data.filename && data.mimeType) {
|
|
17
|
-
const mainFile: File = {
|
|
18
|
-
filename: data.filename,
|
|
19
|
-
mimeType: data.mimeType,
|
|
20
|
-
buffer: file.data,
|
|
21
|
-
tempFilePath: file.tempFilePath,
|
|
22
|
-
filesize: file.size,
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
files = [mainFile]
|
|
26
|
-
|
|
27
|
-
if (data?.sizes) {
|
|
28
|
-
Object.entries(data.sizes).forEach(([key, resizedFileData]) => {
|
|
29
|
-
if (req.payloadUploadSizes?.[key] && data.mimeType) {
|
|
30
|
-
files = files.concat([
|
|
31
|
-
{
|
|
32
|
-
filename: `${resizedFileData.filename}`,
|
|
33
|
-
mimeType: data.mimeType,
|
|
34
|
-
buffer: req.payloadUploadSizes[key],
|
|
35
|
-
filesize: req.payloadUploadSizes[key].length,
|
|
36
|
-
},
|
|
37
|
-
])
|
|
38
|
-
}
|
|
39
|
-
})
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return files
|
|
44
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import type { BlockBlobClient } from '@azure/storage-blob'
|
|
2
|
-
import parseRange from 'range-parser'
|
|
3
|
-
|
|
4
|
-
const getRangeFromHeader = async (
|
|
5
|
-
blockBlobClient: BlockBlobClient,
|
|
6
|
-
rangeHeader?: string,
|
|
7
|
-
): Promise<{ start: number; end: number | undefined }> => {
|
|
8
|
-
const fullRange = { start: 0, end: undefined }
|
|
9
|
-
|
|
10
|
-
if (!rangeHeader) {
|
|
11
|
-
return fullRange
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const size = await blockBlobClient.getProperties().then(props => props.contentLength)
|
|
15
|
-
if (size === undefined) {
|
|
16
|
-
return fullRange
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
const range = parseRange(size, rangeHeader)
|
|
20
|
-
if (range === -1 || range === -2 || range.type !== 'bytes' || range.length !== 1) {
|
|
21
|
-
return fullRange
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
return range[0]
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
export default getRangeFromHeader
|
package/src/webpack.ts
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import type { Config } from 'payload/config'
|
|
2
|
-
import type { Configuration as WebpackConfig } from 'webpack'
|
|
3
|
-
import type { GeneratedAdapter, PluginOptions } from './types'
|
|
4
|
-
|
|
5
|
-
interface Args {
|
|
6
|
-
config: Config
|
|
7
|
-
options: PluginOptions
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export const extendWebpackConfig =
|
|
11
|
-
({ config, options }: Args): ((webpackConfig: WebpackConfig) => WebpackConfig) =>
|
|
12
|
-
webpackConfig => {
|
|
13
|
-
const existingWebpackConfig =
|
|
14
|
-
typeof config.admin?.webpack === 'function'
|
|
15
|
-
? config.admin.webpack(webpackConfig)
|
|
16
|
-
: webpackConfig
|
|
17
|
-
|
|
18
|
-
const newConfig: WebpackConfig = {
|
|
19
|
-
...existingWebpackConfig,
|
|
20
|
-
resolve: {
|
|
21
|
-
...(existingWebpackConfig.resolve || {}),
|
|
22
|
-
alias: {
|
|
23
|
-
...(existingWebpackConfig.resolve?.alias ? existingWebpackConfig.resolve.alias : {}),
|
|
24
|
-
},
|
|
25
|
-
},
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
return Object.entries(options.collections).reduce(
|
|
29
|
-
(resultingWebpackConfig, [slug, collectionOptions]) => {
|
|
30
|
-
const matchedCollection = config.collections?.find(coll => coll.slug === slug)
|
|
31
|
-
|
|
32
|
-
if (matchedCollection && typeof collectionOptions.adapter === 'function') {
|
|
33
|
-
const adapter: GeneratedAdapter = collectionOptions.adapter({
|
|
34
|
-
collection: matchedCollection,
|
|
35
|
-
})
|
|
36
|
-
|
|
37
|
-
if (adapter.webpack) {
|
|
38
|
-
return adapter.webpack(resultingWebpackConfig)
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
return resultingWebpackConfig
|
|
43
|
-
},
|
|
44
|
-
newConfig,
|
|
45
|
-
)
|
|
46
|
-
}
|
package/tsconfig.json
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"lib": [
|
|
4
|
-
"dom",
|
|
5
|
-
"dom.iterable",
|
|
6
|
-
"esnext"
|
|
7
|
-
],
|
|
8
|
-
"target": "es5",
|
|
9
|
-
"outDir": "./dist",
|
|
10
|
-
"allowJs": true,
|
|
11
|
-
"module": "commonjs",
|
|
12
|
-
"sourceMap": true,
|
|
13
|
-
"jsx": "react",
|
|
14
|
-
"esModuleInterop": true,
|
|
15
|
-
"declaration": true,
|
|
16
|
-
"declarationDir": "./dist",
|
|
17
|
-
"skipLibCheck": true,
|
|
18
|
-
"strict": true,
|
|
19
|
-
},
|
|
20
|
-
"include": [
|
|
21
|
-
"src/**/*"
|
|
22
|
-
],
|
|
23
|
-
}
|