@payloadcms/plugin-cloud-storage 1.0.15 → 1.0.16

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.
Files changed (210) hide show
  1. package/.eslintrc.js +14 -14
  2. package/LICENSE.md +22 -22
  3. package/README.md +178 -178
  4. package/azure.d.ts +1 -1
  5. package/azure.js +1 -1
  6. package/dist/adapters/azure/fileStub.d.ts +2 -2
  7. package/dist/adapters/azure/fileStub.js +3 -3
  8. package/dist/adapters/azure/generateURL.d.ts +7 -7
  9. package/dist/adapters/azure/generateURL.js +15 -15
  10. package/dist/adapters/azure/handleDelete.d.ts +9 -9
  11. package/dist/adapters/azure/handleDelete.js +63 -63
  12. package/dist/adapters/azure/handleUpload.d.ts +10 -10
  13. package/dist/adapters/azure/handleUpload.js +80 -80
  14. package/dist/adapters/azure/index.d.ts +8 -8
  15. package/dist/adapters/azure/index.js +42 -42
  16. package/dist/adapters/azure/index.js.map +1 -1
  17. package/dist/adapters/azure/mock.d.ts +13 -13
  18. package/dist/adapters/azure/mock.js +12 -12
  19. package/dist/adapters/azure/staticHandler.d.ts +9 -9
  20. package/dist/adapters/azure/staticHandler.js +81 -81
  21. package/dist/adapters/azure/webpack.d.ts +2 -2
  22. package/dist/adapters/azure/webpack.js +24 -24
  23. package/dist/adapters/azure/webpack.js.map +1 -1
  24. package/dist/adapters/gcs/generateURL.d.ts +8 -8
  25. package/dist/adapters/gcs/generateURL.js +15 -15
  26. package/dist/adapters/gcs/handleDelete.d.ts +8 -8
  27. package/dist/adapters/gcs/handleDelete.js +62 -62
  28. package/dist/adapters/gcs/handleUpload.d.ts +12 -12
  29. package/dist/adapters/gcs/handleUpload.js +72 -72
  30. package/dist/adapters/gcs/index.d.ts +8 -8
  31. package/dist/adapters/gcs/index.js +35 -35
  32. package/dist/adapters/gcs/mock.d.ts +1 -1
  33. package/dist/adapters/gcs/mock.js +4 -4
  34. package/dist/adapters/gcs/staticHandler.d.ts +10 -10
  35. package/dist/adapters/gcs/staticHandler.js +76 -76
  36. package/dist/adapters/gcs/webpack.d.ts +2 -2
  37. package/dist/adapters/gcs/webpack.js +24 -24
  38. package/dist/adapters/gcs/webpack.js.map +1 -1
  39. package/dist/adapters/s3/fileStub.d.ts +2 -2
  40. package/dist/adapters/s3/fileStub.js +3 -3
  41. package/dist/adapters/s3/generateURL.d.ts +8 -8
  42. package/dist/adapters/s3/generateURL.js +15 -15
  43. package/dist/adapters/s3/handleDelete.d.ts +8 -8
  44. package/dist/adapters/s3/handleDelete.js +63 -63
  45. package/dist/adapters/s3/handleUpload.d.ts +12 -12
  46. package/dist/adapters/s3/handleUpload.js +93 -93
  47. package/dist/adapters/s3/index.d.ts +8 -8
  48. package/dist/adapters/s3/index.js +59 -59
  49. package/dist/adapters/s3/mock.d.ts +8 -8
  50. package/dist/adapters/s3/mock.js +9 -9
  51. package/dist/adapters/s3/staticHandler.d.ts +10 -10
  52. package/dist/adapters/s3/staticHandler.js +81 -80
  53. package/dist/adapters/s3/staticHandler.js.map +1 -1
  54. package/dist/adapters/s3/webpack.d.ts +2 -2
  55. package/dist/adapters/s3/webpack.js +24 -24
  56. package/dist/adapters/s3/webpack.js.map +1 -1
  57. package/dist/fields/getFields.d.ts +11 -11
  58. package/dist/fields/getFields.js +118 -118
  59. package/dist/hooks/afterDelete.d.ts +10 -10
  60. package/dist/hooks/afterDelete.js +91 -88
  61. package/dist/hooks/afterDelete.js.map +1 -1
  62. package/dist/hooks/afterRead.d.ts +12 -12
  63. package/dist/hooks/afterRead.js +79 -79
  64. package/dist/hooks/beforeChange.d.ts +10 -10
  65. package/dist/hooks/beforeChange.js +105 -77
  66. package/dist/hooks/beforeChange.js.map +1 -1
  67. package/dist/index.d.ts +1 -1
  68. package/dist/index.js +5 -5
  69. package/dist/plugin.d.ts +3 -3
  70. package/dist/plugin.js +124 -124
  71. package/dist/plugin.js.map +1 -1
  72. package/dist/types.d.ts +62 -62
  73. package/dist/types.js +2 -2
  74. package/dist/utilities/getFilePrefix.d.ts +5 -5
  75. package/dist/utilities/getFilePrefix.js +80 -80
  76. package/dist/utilities/getIncomingFiles.d.ts +7 -7
  77. package/dist/utilities/getIncomingFiles.js +37 -37
  78. package/dist/utilities/getRangeFromHeader.d.ts +6 -6
  79. package/dist/utilities/getRangeFromHeader.js +66 -66
  80. package/dist/webpack.d.ts +9 -9
  81. package/dist/webpack.js +39 -39
  82. package/gcs.d.ts +1 -1
  83. package/gcs.js +1 -1
  84. package/package.json +67 -67
  85. package/s3.d.ts +1 -1
  86. package/s3.js +1 -1
  87. package/.editorconfig +0 -10
  88. package/.gitignore +0 -248
  89. package/.idea/.gitignore +0 -5
  90. package/.idea/httpRequests/2023-04-07T152957.206.png +0 -0
  91. package/.idea/httpRequests/2023-04-07T153025.403.html +0 -10
  92. package/.idea/httpRequests/2023-04-07T153146.200.png +0 -0
  93. package/.idea/httpRequests/http-client.cookies +0 -1
  94. package/.idea/httpRequests/http-requests-log.http +0 -74
  95. package/.idea/inspectionProfiles/Project_Default.xml +0 -6
  96. package/.idea/jsLinters/eslint.xml +0 -6
  97. package/.idea/modules.xml +0 -8
  98. package/.idea/plugin-cloud-storage.iml +0 -12
  99. package/.idea/vcs.xml +0 -6
  100. package/.idea/workspace.xml +0 -269
  101. package/.prettierignore +0 -1
  102. package/.prettierrc.js +0 -8
  103. package/.vscode/launch.json +0 -28
  104. package/.vscode/settings.json +0 -9
  105. package/dev/.env +0 -25
  106. package/dev/.env.example +0 -21
  107. package/dev/build/127.d2c2ffcfff69fabfdd1b.js +0 -1
  108. package/dev/build/16.17dbe03b1d0a96f3e564.js +0 -2
  109. package/dev/build/16.17dbe03b1d0a96f3e564.js.LICENSE.txt +0 -8
  110. package/dev/build/171.bbcbae3ea90468ad0cad.js +0 -2
  111. package/dev/build/171.bbcbae3ea90468ad0cad.js.LICENSE.txt +0 -8
  112. package/dev/build/18.e50c27edff6716f930d9.js +0 -1
  113. package/dev/build/205.33c7a29683ba98de93e0.js +0 -1
  114. package/dev/build/2211c49456cd07331ea9.woff +0 -0
  115. package/dev/build/234.79395f82c18207c13766.js +0 -1
  116. package/dev/build/266.9d4a240b3e0985bd7dd5.js +0 -1
  117. package/dev/build/296.4c5d646257b42c915834.js +0 -1
  118. package/dev/build/304.40dbe690de322c8f7c0d.js +0 -2
  119. package/dev/build/304.40dbe690de322c8f7c0d.js.LICENSE.txt +0 -37
  120. package/dev/build/349.446c12bffd3905085fdb.js +0 -1
  121. package/dev/build/354.5acd04b85b96a9839125.js +0 -1
  122. package/dev/build/40ad7515b8674bb854a1.woff2 +0 -0
  123. package/dev/build/422.086542466cdc9f6a2437.js +0 -2
  124. package/dev/build/422.086542466cdc9f6a2437.js.LICENSE.txt +0 -6
  125. package/dev/build/491.0bfe1bb0ecfe383179aa.js +0 -1
  126. package/dev/build/4d8845b830f4e8e2affb.png +0 -0
  127. package/dev/build/51922ceb71da289688d3.woff2 +0 -0
  128. package/dev/build/522443364fda49e9e0ed.woff2 +0 -0
  129. package/dev/build/531.1c6f53f3b44a3c45b444.js +0 -2
  130. package/dev/build/531.1c6f53f3b44a3c45b444.js.LICENSE.txt +0 -6
  131. package/dev/build/570.f2d9b99706765fbf0225.js +0 -1
  132. package/dev/build/599.570a04990d5806004f61.js +0 -1
  133. package/dev/build/5b718d9772de251a8c0a.woff2 +0 -0
  134. package/dev/build/778.41ae26bcd617861ad586.js +0 -1
  135. package/dev/build/783.0117995f2ff6036d6746.js +0 -1
  136. package/dev/build/787999a6af6a17efbc7c.woff +0 -0
  137. package/dev/build/78b8935fb481e11c92ce.woff +0 -0
  138. package/dev/build/860.7688681d3269f3f16e9a.js +0 -1
  139. package/dev/build/892.1a4ca5ac67d81038ceec.js +0 -1
  140. package/dev/build/896.d8cb1160388dc29d6364.js +0 -1
  141. package/dev/build/8b4ddd0d08500553efde.woff +0 -0
  142. package/dev/build/8f612153248094525d9d.woff +0 -0
  143. package/dev/build/995.cc11e738ff81a85821b4.js +0 -1
  144. package/dev/build/9c7dfd0036f7bd24b053.woff2 +0 -0
  145. package/dev/build/a1cfdc5b5250b7c4b481.woff2 +0 -0
  146. package/dev/build/d7aeda9e48ce098e7b48.woff +0 -0
  147. package/dev/build/e009f21405b4d7e89367.woff2 +0 -0
  148. package/dev/build/e7caa9e17af6ac87d182.woff +0 -0
  149. package/dev/build/ebcc1430049fddb274f8.svg +0 -15
  150. package/dev/build/efe8f6a3b46446cc9135.woff +0 -0
  151. package/dev/build/f53bb8d4b29adc903703.woff2 +0 -0
  152. package/dev/build/index.html +0 -1
  153. package/dev/build/main.a2003d502fbb9aaa3e8d.js +0 -2
  154. package/dev/build/main.a2003d502fbb9aaa3e8d.js.LICENSE.txt +0 -57
  155. package/dev/build/styles.css +0 -1
  156. package/dev/build/styles.fa29d16b0baf5b98a1cf.js +0 -1
  157. package/dev/nodemon.json +0 -8
  158. package/dev/package.json +0 -32
  159. package/dev/src/collections/Media.ts +0 -56
  160. package/dev/src/collections/Users.ts +0 -23
  161. package/dev/src/mocks/fsMock.js +0 -1
  162. package/dev/src/mocks/promisifyMock.js +0 -1
  163. package/dev/src/payload.config.ts +0 -111
  164. package/dev/src/server.ts +0 -26
  165. package/dev/tsconfig.json +0 -20
  166. package/docs/local-dev.md +0 -47
  167. package/eslint-config/index.js +0 -15
  168. package/eslint-config/rules/import.js +0 -38
  169. package/eslint-config/rules/prettier.js +0 -7
  170. package/eslint-config/rules/style.js +0 -21
  171. package/eslint-config/rules/typescript.js +0 -628
  172. package/src/adapters/azure/emulator/docker-compose.yml +0 -16
  173. package/src/adapters/azure/fileStub.js +0 -1
  174. package/src/adapters/azure/generateURL.ts +0 -13
  175. package/src/adapters/azure/handleDelete.ts +0 -16
  176. package/src/adapters/azure/handleUpload.ts +0 -41
  177. package/src/adapters/azure/index.ts +0 -47
  178. package/src/adapters/azure/mock.js +0 -13
  179. package/src/adapters/azure/staticHandler.ts +0 -38
  180. package/src/adapters/azure/webpack.ts +0 -20
  181. package/src/adapters/gcs/emulator/docker-compose.yml +0 -15
  182. package/src/adapters/gcs/generateURL.ts +0 -16
  183. package/src/adapters/gcs/handleDelete.ts +0 -16
  184. package/src/adapters/gcs/handleUpload.ts +0 -34
  185. package/src/adapters/gcs/index.ts +0 -37
  186. package/src/adapters/gcs/mock.js +0 -3
  187. package/src/adapters/gcs/staticHandler.ts +0 -34
  188. package/src/adapters/gcs/webpack.ts +0 -17
  189. package/src/adapters/s3/emulator/docker-compose.yml +0 -15
  190. package/src/adapters/s3/fileStub.js +0 -1
  191. package/src/adapters/s3/generateURL.ts +0 -14
  192. package/src/adapters/s3/handleDelete.ts +0 -17
  193. package/src/adapters/s3/handleUpload.ts +0 -62
  194. package/src/adapters/s3/index.ts +0 -38
  195. package/src/adapters/s3/mock.js +0 -9
  196. package/src/adapters/s3/staticHandler.ts +0 -40
  197. package/src/adapters/s3/webpack.ts +0 -19
  198. package/src/fields/getFields.ts +0 -155
  199. package/src/hooks/afterDelete.ts +0 -35
  200. package/src/hooks/afterRead.ts +0 -38
  201. package/src/hooks/beforeChange.ts +0 -30
  202. package/src/index.ts +0 -1
  203. package/src/plugin.ts +0 -94
  204. package/src/types.ts +0 -73
  205. package/src/utilities/getFilePrefix.ts +0 -26
  206. package/src/utilities/getIncomingFiles.ts +0 -44
  207. package/src/utilities/getRangeFromHeader.ts +0 -27
  208. package/src/webpack.ts +0 -46
  209. package/tsconfig.json +0 -23
  210. package/yarn.lock +0 -8155
package/.eslintrc.js CHANGED
@@ -1,14 +1,14 @@
1
- module.exports = {
2
- root: true,
3
- extends: ['./eslint-config'],
4
- overrides: [
5
- // Temporary overrides. Re-enable once platform is more mature
6
- {
7
- files: ['dev/**/*.ts'],
8
- rules: {
9
- 'import/no-relative-packages': 'off',
10
- 'no-process-env': 'off',
11
- },
12
- },
13
- ],
14
- }
1
+ module.exports = {
2
+ root: true,
3
+ extends: ['./eslint-config'],
4
+ overrides: [
5
+ // Temporary overrides. Re-enable once platform is more mature
6
+ {
7
+ files: ['dev/**/*.ts'],
8
+ rules: {
9
+ 'import/no-relative-packages': 'off',
10
+ 'no-process-env': 'off',
11
+ },
12
+ },
13
+ ],
14
+ }
package/LICENSE.md CHANGED
@@ -1,22 +1,22 @@
1
- (The MIT License)
2
-
3
- Copyright (c) 2018-20223 Payload CMS, INC <info@payloadcms.com>
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining
6
- a copy of this software and associated documentation files (the
7
- 'Software'), to deal in the Software without restriction, including
8
- without limitation the rights to use, copy, modify, merge, publish,
9
- distribute, sublicense, and/or sell copies of the Software, and to
10
- permit persons to whom the Software is furnished to do so, subject to
11
- the following conditions:
12
-
13
- The above copyright notice and this permission notice shall be
14
- included in all copies or substantial portions of the Software.
15
-
16
- THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
17
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19
- IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20
- CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21
- TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22
- SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
1
+ (The MIT License)
2
+
3
+ Copyright (c) 2018-20223 Payload CMS, INC <info@payloadcms.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ 'Software'), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19
+ IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20
+ CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21
+ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22
+ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/README.md CHANGED
@@ -1,178 +1,178 @@
1
- # Payload Cloud Storage Plugin
2
-
3
- This repository contains the officially supported Payload Cloud Storage plugin. It extends Payload to allow you to store all uploaded media in third-party permanent storage.
4
-
5
- #### Requirements
6
-
7
- - Payload version `1.0.19` or higher is required
8
-
9
- ## Installation
10
-
11
- `yarn add @payloadcms/plugin-cloud-storage` or `npm install @payloadcms/plugin-cloud-storage`
12
-
13
- ## Usage
14
-
15
- Add this package into your dependencies executing this code in your command line:
16
-
17
- `yarn add @payloadcms/plugin-cloud-storage`
18
-
19
- Now install this plugin within your Payload as follows:
20
-
21
- ```ts
22
- import { buildConfig } from 'payload/config';
23
- import path from 'path';
24
- import { cloudStorage } from '@payloadcms/plugin-cloud-storage';
25
-
26
- export default buildConfig({
27
- plugins: [
28
- cloudStorage({
29
- collections: {
30
- 'my-collection-slug': {
31
- adapter: theAdapterToUse, // see docs for the adapter you want to use
32
- },
33
- },
34
- }),
35
- ],
36
- // The rest of your config goes here
37
- });
38
- ```
39
-
40
- ## Features
41
-
42
- **Adapter-based Implementation**
43
-
44
- This plugin supports the following adapters:
45
-
46
- - [Azure Blob Storage](#azure-blob-storage-adapter)
47
- - [AWS S3-style Storage](#s3-adapter)
48
- - [Google Cloud Storage](#gcs-adapter)
49
-
50
- However, you can create your own adapter for any third-party service you would like to use.
51
-
52
- All adapters are implemented `dev` directory's [Payload Config](https://github.com/payloadcms/plugin-cloud-storage/blob/master/dev/src/payload.config.ts). See this file for examples.
53
-
54
- ## Plugin options
55
-
56
- This plugin is configurable to work across many different Payload collections. A `*` denotes that the property is required.
57
-
58
- | Option | Type | Description |
59
- |-------------------------|-----------------------------------------| ----------- |
60
- | `collections` * | Record<string, [CollectionOptions](https://github.com/payloadcms/plugin-cloud-storage/blob/c4a492a62abc2f21b4cd6a7c97778acd8e831212/src/types.ts#L48)> | Object with keys set to the slug of collections you want to enable the plugin for, and values set to collection-specific options. |
61
-
62
- **Collection-specific options:**
63
-
64
- | Option | Type | Description |
65
- |-------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
66
- | `adapter` * | [Adapter](https://github.com/payloadcms/plugin-cloud-storage/blob/master/src/types.ts#L51) | Pass in the adapter that you'd like to use for this collection. You can also set this field to `null` for local development if you'd like to bypass cloud storage in certain scenarios and use local storage. |
67
- | `disableLocalStorage` | `boolean` | Choose to disable local storage on this collection. Defaults to `true`. |
68
- | `disablePayloadAccessControl` | `true` | Set to `true` to disable Payload's access control. [More](#payload-access-control) |
69
- | `prefix` | `string` | Set to `media/images` to upload files inside `media/images` folder in the bucket. |
70
- | `generateFileURL` | [GenerateFileURL](https://github.com/payloadcms/plugin-cloud-storage/blob/master/src/types.ts#L53) | Override the generated file URL with one that you create. |
71
-
72
- ### Azure Blob Storage Adapter
73
-
74
- To use the Azure Blob Storage adapter, you need to have `@azure/storage-blob` installed in your project dependencies. To do so, run `yarn add @azure/storage-blob`.
75
-
76
- From there, create the adapter, passing in all of its required properties:
77
-
78
- ```js
79
- import { azureBlobStorageAdapter } from '@payloadcms/plugin-cloud-storage/azure';
80
-
81
- const adapter = azureBlobStorageAdapter({
82
- connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING,
83
- containerName: process.env.AZURE_STORAGE_CONTAINER_NAME,
84
- allowContainerCreate: process.env.AZURE_STORAGE_ALLOW_CONTAINER_CREATE === 'true',
85
- baseURL: process.env.AZURE_STORAGE_ACCOUNT_BASEURL,
86
- })
87
-
88
- // Now you can pass this adapter to the plugin
89
- ```
90
-
91
- ### S3 Adapter
92
-
93
- To use the S3 adapter, some peer dependencies need to be installed:
94
-
95
- `yarn add @aws-sdk/client-s3 @aws-sdk/lib-storage`.
96
-
97
- From there, create the adapter, passing in all of its required properties:
98
-
99
- ```js
100
- import { s3Adapter } from '@payloadcms/plugin-cloud-storage/s3';
101
-
102
- const adapter = s3Adapter({
103
- config: {
104
- credentials: {
105
- accessKeyId: process.env.S3_ACCESS_KEY_ID,
106
- secretAccessKey: process.env.S3_SECRET_ACCESS_KEY,
107
- }
108
- // ... Other S3 configuration
109
- },
110
- bucket: process.env.S3_BUCKET,
111
- })
112
-
113
- // Now you can pass this adapter to the plugin
114
- ```
115
-
116
- Other S3 Client configuration is documented [here](https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/clients/client-s3/interfaces/s3clientconfig.html).
117
-
118
- Any upload over 50MB will automatically be uploaded using S3's multi-part upload.
119
-
120
- #### Other S3-Compatible Storage
121
-
122
- If you're running an S3-compatible object storage such as MinIO or Digital Ocean Spaces, you'll have to set the `endpoint` appropriately for the provider.
123
-
124
- ```js
125
- import { s3Adapter } from '@payloadcms/plugin-cloud-storage/s3';
126
-
127
- const adapter = s3Adapter({
128
- config: {
129
- endpoint: process.env.S3_ENDPOINT, // Configure for your provider
130
- // ...
131
- },
132
- // ...
133
- })
134
- ```
135
-
136
- ### GCS Adapter
137
-
138
- To use the GCS adapter, you need to have `@google-cloud/storage` installed in your project dependencies. To do so, run `yarn add @google-cloud/storage`.
139
-
140
- From there, create the adapter, passing in all of its required properties:
141
-
142
- ```js
143
- import { gcsAdapter } from '@payloadcms/plugin-cloud-storage/gcs';
144
-
145
- const adapter = gcsAdapter({
146
- options: {
147
- // you can choose any method for authentication, and authorization which is being provided by `@google-cloud/storage`
148
- keyFilename: './gcs-credentials.json',
149
- //OR
150
- credentials: JSON.parse(process.env.GCS_CREDENTIALS) // this env variable will have stringify version of your credentials.json file
151
- },
152
- bucket: process.env.GCS_BUCKET,
153
- })
154
-
155
- // Now you can pass this adapter to the plugin
156
- ```
157
-
158
- ### Payload Access Control
159
-
160
- Payload ships with access control that runs _even on statically served files_. The same `read` access control property on your `upload`-enabled collections is used, and it allows you to restrict who can request your uploaded files.
161
-
162
- To preserve this feature, by default, this plugin _keeps all file URLs exactly the same_. Your file URLs won't be updated to point directly to your cloud storage source, as in that case, Payload's access control will be completely bypassed and you would need public readability on your cloud-hosted files.
163
-
164
- Instead, all uploads will still be reached from the default `/collectionSlug/staticURL/filename` path. This plugin will "pass through" all files that are hosted on your third-party cloud service—with the added benefit of keeping your existing access control in place.
165
-
166
- If this does not apply to you (your upload collection has `read: () => true` or similar) you can disable this functionality by setting `disablePayloadAccessControl` to `true`. When this setting is in place, this plugin will update your file URLs to point directly to your cloud host.
167
-
168
- ## Local development
169
-
170
- For instructions regarding how to develop with this plugin locally, [click here](https://github.com/payloadcms/plugin-cloud-storage/blob/master/docs/local-dev.md).
171
-
172
- ## Questions
173
-
174
- Please contact [Payload](dev@payloadcms.com) with any questions about using this plugin.
175
-
176
- ## Credit
177
-
178
- This plugin was created with significant help, and code, from [Alex Bechmann](https://github.com/alexbechmann) and [Richard VanBergen](https://github.com/richardvanbergen). Thank you!!
1
+ # Payload Cloud Storage Plugin
2
+
3
+ This repository contains the officially supported Payload Cloud Storage plugin. It extends Payload to allow you to store all uploaded media in third-party permanent storage.
4
+
5
+ #### Requirements
6
+
7
+ - Payload version `1.0.19` or higher is required
8
+
9
+ ## Installation
10
+
11
+ `yarn add @payloadcms/plugin-cloud-storage` or `npm install @payloadcms/plugin-cloud-storage`
12
+
13
+ ## Usage
14
+
15
+ Add this package into your dependencies executing this code in your command line:
16
+
17
+ `yarn add @payloadcms/plugin-cloud-storage`
18
+
19
+ Now install this plugin within your Payload as follows:
20
+
21
+ ```ts
22
+ import { buildConfig } from 'payload/config';
23
+ import path from 'path';
24
+ import { cloudStorage } from '@payloadcms/plugin-cloud-storage';
25
+
26
+ export default buildConfig({
27
+ plugins: [
28
+ cloudStorage({
29
+ collections: {
30
+ 'my-collection-slug': {
31
+ adapter: theAdapterToUse, // see docs for the adapter you want to use
32
+ },
33
+ },
34
+ }),
35
+ ],
36
+ // The rest of your config goes here
37
+ });
38
+ ```
39
+
40
+ ## Features
41
+
42
+ **Adapter-based Implementation**
43
+
44
+ This plugin supports the following adapters:
45
+
46
+ - [Azure Blob Storage](#azure-blob-storage-adapter)
47
+ - [AWS S3-style Storage](#s3-adapter)
48
+ - [Google Cloud Storage](#gcs-adapter)
49
+
50
+ However, you can create your own adapter for any third-party service you would like to use.
51
+
52
+ All adapters are implemented `dev` directory's [Payload Config](https://github.com/payloadcms/plugin-cloud-storage/blob/master/dev/src/payload.config.ts). See this file for examples.
53
+
54
+ ## Plugin options
55
+
56
+ This plugin is configurable to work across many different Payload collections. A `*` denotes that the property is required.
57
+
58
+ | Option | Type | Description |
59
+ |-------------------------|-----------------------------------------| ----------- |
60
+ | `collections` * | Record<string, [CollectionOptions](https://github.com/payloadcms/plugin-cloud-storage/blob/c4a492a62abc2f21b4cd6a7c97778acd8e831212/src/types.ts#L48)> | Object with keys set to the slug of collections you want to enable the plugin for, and values set to collection-specific options. |
61
+
62
+ **Collection-specific options:**
63
+
64
+ | Option | Type | Description |
65
+ |-------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
66
+ | `adapter` * | [Adapter](https://github.com/payloadcms/plugin-cloud-storage/blob/master/src/types.ts#L51) | Pass in the adapter that you'd like to use for this collection. You can also set this field to `null` for local development if you'd like to bypass cloud storage in certain scenarios and use local storage. |
67
+ | `disableLocalStorage` | `boolean` | Choose to disable local storage on this collection. Defaults to `true`. |
68
+ | `disablePayloadAccessControl` | `true` | Set to `true` to disable Payload's access control. [More](#payload-access-control) |
69
+ | `prefix` | `string` | Set to `media/images` to upload files inside `media/images` folder in the bucket. |
70
+ | `generateFileURL` | [GenerateFileURL](https://github.com/payloadcms/plugin-cloud-storage/blob/master/src/types.ts#L53) | Override the generated file URL with one that you create. |
71
+
72
+ ### Azure Blob Storage Adapter
73
+
74
+ To use the Azure Blob Storage adapter, you need to have `@azure/storage-blob` installed in your project dependencies. To do so, run `yarn add @azure/storage-blob`.
75
+
76
+ From there, create the adapter, passing in all of its required properties:
77
+
78
+ ```js
79
+ import { azureBlobStorageAdapter } from '@payloadcms/plugin-cloud-storage/azure';
80
+
81
+ const adapter = azureBlobStorageAdapter({
82
+ connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING,
83
+ containerName: process.env.AZURE_STORAGE_CONTAINER_NAME,
84
+ allowContainerCreate: process.env.AZURE_STORAGE_ALLOW_CONTAINER_CREATE === 'true',
85
+ baseURL: process.env.AZURE_STORAGE_ACCOUNT_BASEURL,
86
+ })
87
+
88
+ // Now you can pass this adapter to the plugin
89
+ ```
90
+
91
+ ### S3 Adapter
92
+
93
+ To use the S3 adapter, some peer dependencies need to be installed:
94
+
95
+ `yarn add @aws-sdk/client-s3 @aws-sdk/lib-storage`.
96
+
97
+ From there, create the adapter, passing in all of its required properties:
98
+
99
+ ```js
100
+ import { s3Adapter } from '@payloadcms/plugin-cloud-storage/s3';
101
+
102
+ const adapter = s3Adapter({
103
+ config: {
104
+ credentials: {
105
+ accessKeyId: process.env.S3_ACCESS_KEY_ID,
106
+ secretAccessKey: process.env.S3_SECRET_ACCESS_KEY,
107
+ }
108
+ // ... Other S3 configuration
109
+ },
110
+ bucket: process.env.S3_BUCKET,
111
+ })
112
+
113
+ // Now you can pass this adapter to the plugin
114
+ ```
115
+
116
+ Other S3 Client configuration is documented [here](https://docs.aws.amazon.com/AWSJavaScriptSDK/v3/latest/clients/client-s3/interfaces/s3clientconfig.html).
117
+
118
+ Any upload over 50MB will automatically be uploaded using S3's multi-part upload.
119
+
120
+ #### Other S3-Compatible Storage
121
+
122
+ If you're running an S3-compatible object storage such as MinIO or Digital Ocean Spaces, you'll have to set the `endpoint` appropriately for the provider.
123
+
124
+ ```js
125
+ import { s3Adapter } from '@payloadcms/plugin-cloud-storage/s3';
126
+
127
+ const adapter = s3Adapter({
128
+ config: {
129
+ endpoint: process.env.S3_ENDPOINT, // Configure for your provider
130
+ // ...
131
+ },
132
+ // ...
133
+ })
134
+ ```
135
+
136
+ ### GCS Adapter
137
+
138
+ To use the GCS adapter, you need to have `@google-cloud/storage` installed in your project dependencies. To do so, run `yarn add @google-cloud/storage`.
139
+
140
+ From there, create the adapter, passing in all of its required properties:
141
+
142
+ ```js
143
+ import { gcsAdapter } from '@payloadcms/plugin-cloud-storage/gcs';
144
+
145
+ const adapter = gcsAdapter({
146
+ options: {
147
+ // you can choose any method for authentication, and authorization which is being provided by `@google-cloud/storage`
148
+ keyFilename: './gcs-credentials.json',
149
+ //OR
150
+ credentials: JSON.parse(process.env.GCS_CREDENTIALS) // this env variable will have stringify version of your credentials.json file
151
+ },
152
+ bucket: process.env.GCS_BUCKET,
153
+ })
154
+
155
+ // Now you can pass this adapter to the plugin
156
+ ```
157
+
158
+ ### Payload Access Control
159
+
160
+ Payload ships with access control that runs _even on statically served files_. The same `read` access control property on your `upload`-enabled collections is used, and it allows you to restrict who can request your uploaded files.
161
+
162
+ To preserve this feature, by default, this plugin _keeps all file URLs exactly the same_. Your file URLs won't be updated to point directly to your cloud storage source, as in that case, Payload's access control will be completely bypassed and you would need public readability on your cloud-hosted files.
163
+
164
+ Instead, all uploads will still be reached from the default `/collectionSlug/staticURL/filename` path. This plugin will "pass through" all files that are hosted on your third-party cloud service—with the added benefit of keeping your existing access control in place.
165
+
166
+ If this does not apply to you (your upload collection has `read: () => true` or similar) you can disable this functionality by setting `disablePayloadAccessControl` to `true`. When this setting is in place, this plugin will update your file URLs to point directly to your cloud host.
167
+
168
+ ## Local development
169
+
170
+ For instructions regarding how to develop with this plugin locally, [click here](https://github.com/payloadcms/plugin-cloud-storage/blob/master/docs/local-dev.md).
171
+
172
+ ## Questions
173
+
174
+ Please contact [Payload](dev@payloadcms.com) with any questions about using this plugin.
175
+
176
+ ## Credit
177
+
178
+ This plugin was created with significant help, and code, from [Alex Bechmann](https://github.com/alexbechmann) and [Richard VanBergen](https://github.com/richardvanbergen). Thank you!!
package/azure.d.ts CHANGED
@@ -1 +1 @@
1
- export * from './dist/adapters/azure'
1
+ export * from './dist/adapters/azure'
package/azure.js CHANGED
@@ -1 +1 @@
1
- exports.azureBlobStorageAdapter = require('./dist/adapters/azure').azureBlobStorageAdapter
1
+ exports.azureBlobStorageAdapter = require('./dist/adapters/azure').azureBlobStorageAdapter
@@ -1,2 +1,2 @@
1
- declare const _default: "file-stub";
2
- export default _default;
1
+ declare const _default: "file-stub";
2
+ export default _default;
@@ -1,4 +1,4 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.default = 'file-stub';
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = 'file-stub';
4
4
  //# sourceMappingURL=fileStub.js.map
@@ -1,7 +1,7 @@
1
- import type { GenerateURL } from '../../types';
2
- interface Args {
3
- containerName: string;
4
- baseURL: string;
5
- }
6
- export declare const getGenerateURL: ({ containerName, baseURL }: Args) => GenerateURL;
7
- export {};
1
+ import type { GenerateURL } from '../../types';
2
+ interface Args {
3
+ containerName: string;
4
+ baseURL: string;
5
+ }
6
+ export declare const getGenerateURL: ({ containerName, baseURL }: Args) => GenerateURL;
7
+ export {};
@@ -1,16 +1,16 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getGenerateURL = void 0;
7
- var path_1 = __importDefault(require("path"));
8
- var getGenerateURL = function (_a) {
9
- var containerName = _a.containerName, baseURL = _a.baseURL;
10
- return function (_a) {
11
- var filename = _a.filename, _b = _a.prefix, prefix = _b === void 0 ? '' : _b;
12
- return "".concat(baseURL, "/").concat(containerName, "/").concat(path_1.default.posix.join(prefix, filename));
13
- };
14
- };
15
- exports.getGenerateURL = getGenerateURL;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getGenerateURL = void 0;
7
+ var path_1 = __importDefault(require("path"));
8
+ var getGenerateURL = function (_a) {
9
+ var containerName = _a.containerName, baseURL = _a.baseURL;
10
+ return function (_a) {
11
+ var filename = _a.filename, _b = _a.prefix, prefix = _b === void 0 ? '' : _b;
12
+ return "".concat(baseURL, "/").concat(containerName, "/").concat(path_1.default.posix.join(prefix, filename));
13
+ };
14
+ };
15
+ exports.getGenerateURL = getGenerateURL;
16
16
  //# sourceMappingURL=generateURL.js.map
@@ -1,9 +1,9 @@
1
- import type { CollectionConfig } from 'payload/types';
2
- import type { ContainerClient } from '@azure/storage-blob';
3
- import type { HandleDelete } from '../../types';
4
- interface Args {
5
- collection: CollectionConfig;
6
- getStorageClient: () => ContainerClient;
7
- }
8
- export declare const getHandleDelete: ({ getStorageClient }: Args) => HandleDelete;
9
- export {};
1
+ import type { CollectionConfig } from 'payload/types';
2
+ import type { ContainerClient } from '@azure/storage-blob';
3
+ import type { HandleDelete } from '../../types';
4
+ interface Args {
5
+ collection: CollectionConfig;
6
+ getStorageClient: () => ContainerClient;
7
+ }
8
+ export declare const getHandleDelete: ({ getStorageClient }: Args) => HandleDelete;
9
+ export {};