pg-mvc-service 2.0.10 → 2.0.11

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.
@@ -15,12 +15,17 @@ var __asyncValues = (this && this.__asyncValues) || function (o) {
15
15
  function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
16
16
  function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
17
17
  };
18
+ var __importDefault = (this && this.__importDefault) || function (mod) {
19
+ return (mod && mod.__esModule) ? mod : { "default": mod };
20
+ };
18
21
  Object.defineProperty(exports, "__esModule", { value: true });
19
22
  exports.AwsS3Client = void 0;
20
23
  const client_s3_1 = require("@aws-sdk/client-s3");
21
24
  const Base64Client_1 = require("./Base64Client");
25
+ const Exception_1 = require("../exceptions/Exception");
26
+ const axios_1 = __importDefault(require("axios"));
22
27
  class AwsS3Client {
23
- get urlPrefix() {
28
+ get UrlPrefix() {
24
29
  return `https://${this.bucketName}.s3.${this.region}.amazonaws.com`;
25
30
  }
26
31
  constructor(params) {
@@ -55,7 +60,7 @@ class AwsS3Client {
55
60
  }
56
61
  url(path, fileName = '') {
57
62
  path = path.replace(/^\/|\/$/g, '');
58
- let url = `${this.urlPrefix}`;
63
+ let url = `${this.UrlPrefix}`;
59
64
  if (path !== '') {
60
65
  url += '/' + path;
61
66
  }
@@ -122,7 +127,45 @@ class AwsS3Client {
122
127
  ContentType: type
123
128
  });
124
129
  yield this.client.send(command);
125
- return `${this.urlPrefix}/${key}`;
130
+ return `${this.UrlPrefix}/${key}`;
131
+ });
132
+ }
133
+ uploadFromUrl(path, fileName, url) {
134
+ return __awaiter(this, void 0, void 0, function* () {
135
+ try {
136
+ // URLからデータを取得
137
+ const response = yield axios_1.default.get(url, {
138
+ responseType: 'arraybuffer',
139
+ timeout: 30000,
140
+ });
141
+ // Content-Typeを取得
142
+ const contentType = response.headers['content-type'] || 'application/octet-stream';
143
+ const key = this.makeKey(path, fileName);
144
+ const command = new client_s3_1.PutObjectCommand({
145
+ Bucket: this.bucketName,
146
+ Key: key,
147
+ Body: Buffer.from(response.data),
148
+ ContentType: contentType,
149
+ ContentLength: response.data.length
150
+ });
151
+ yield this.client.send(command);
152
+ // アップロードされたファイルのURLを返す
153
+ return this.url(path, fileName);
154
+ }
155
+ catch (error) {
156
+ if (axios_1.default.isAxiosError(error)) {
157
+ if (error.response) {
158
+ throw new Exception_1.UnprocessableException(`Failed to download from URL. HTTP ${error.response.status}: ${error.response.statusText}`);
159
+ }
160
+ else if (error.request) {
161
+ throw new Exception_1.UnprocessableException('Failed to connect to the URL. Please check if the URL is accessible.');
162
+ }
163
+ else {
164
+ throw new Exception_1.UnprocessableException('Invalid URL format.');
165
+ }
166
+ }
167
+ throw new Exception_1.UnprocessableException('Failed to upload from URL.');
168
+ }
126
169
  });
127
170
  }
128
171
  uploadStackText(path, fileName, text) {
@@ -265,5 +308,27 @@ class AwsS3Client {
265
308
  }
266
309
  });
267
310
  }
311
+ deleteFromUrl(url_1) {
312
+ return __awaiter(this, arguments, void 0, function* (url, isFileUrl = true) {
313
+ const path = url.replace(this.UrlPrefix + '/', '');
314
+ if (url === path) {
315
+ throw new Exception_1.UnprocessableException('The specified URL cannot be deleted because the bucket and region do not match.');
316
+ }
317
+ if (path.trim() === "") {
318
+ throw new Exception_1.UnprocessableException('This URL is invalid.');
319
+ }
320
+ if (isFileUrl) {
321
+ const pathSplits = path.split('/');
322
+ const file = pathSplits.pop();
323
+ if (file === undefined) {
324
+ throw new Exception_1.UnprocessableException('This URL is invalid.');
325
+ }
326
+ yield this.deleteFile(pathSplits.join('/'), file);
327
+ }
328
+ else {
329
+ yield this.deleteDir(path);
330
+ }
331
+ });
332
+ }
268
333
  }
269
334
  exports.AwsS3Client = AwsS3Client;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pg-mvc-service",
3
- "version": "2.0.10",
3
+ "version": "2.0.11",
4
4
  "description": "",
5
5
  "homepage": "https://github.com/n-daira/npm-pack_mvc-service#readme",
6
6
  "bugs": {
@@ -1,12 +1,14 @@
1
1
  import { _Object, DeleteObjectsCommand, GetObjectCommand, ListObjectsV2Command, PutObjectCommand, S3Client, ScanRange } from '@aws-sdk/client-s3';
2
2
  import { Base64Client } from './Base64Client';
3
+ import { UnprocessableException } from '../exceptions/Exception';
4
+ import axios from 'axios';
3
5
 
4
6
  export class AwsS3Client {
5
7
  private client: S3Client;
6
8
 
7
9
  private readonly bucketName;
8
10
  private readonly region;
9
- get urlPrefix(): string {
11
+ get UrlPrefix(): string {
10
12
  return `https://${this.bucketName}.s3.${this.region}.amazonaws.com`;
11
13
  }
12
14
 
@@ -49,7 +51,7 @@ export class AwsS3Client {
49
51
 
50
52
  public url(path: string, fileName: string = '') {
51
53
  path = path.replace(/^\/|\/$/g, '');
52
- let url = `${this.urlPrefix}`;
54
+ let url = `${this.UrlPrefix}`;
53
55
  if (path !== '') {
54
56
  url += '/' + path;
55
57
  }
@@ -118,7 +120,46 @@ export class AwsS3Client {
118
120
  });
119
121
  await this.client.send(command);
120
122
 
121
- return `${this.urlPrefix}/${key}`;
123
+ return `${this.UrlPrefix}/${key}`;
124
+ }
125
+
126
+ public async uploadFromUrl(path: string, fileName: string, url: string): Promise<string> {
127
+ try {
128
+ // URLからデータを取得
129
+ const response = await axios.get(url, {
130
+ responseType: 'arraybuffer',
131
+ timeout: 30000,
132
+ });
133
+
134
+ // Content-Typeを取得
135
+ const contentType = response.headers['content-type'] || 'application/octet-stream';
136
+
137
+ const key = this.makeKey(path, fileName);
138
+ const command = new PutObjectCommand({
139
+ Bucket: this.bucketName,
140
+ Key: key,
141
+ Body: Buffer.from(response.data),
142
+ ContentType: contentType,
143
+ ContentLength: response.data.length
144
+ });
145
+
146
+ await this.client.send(command);
147
+
148
+ // アップロードされたファイルのURLを返す
149
+ return this.url(path, fileName);
150
+
151
+ } catch (error) {
152
+ if (axios.isAxiosError(error)) {
153
+ if (error.response) {
154
+ throw new UnprocessableException(`Failed to download from URL. HTTP ${error.response.status}: ${error.response.statusText}`);
155
+ } else if (error.request) {
156
+ throw new UnprocessableException('Failed to connect to the URL. Please check if the URL is accessible.');
157
+ } else {
158
+ throw new UnprocessableException('Invalid URL format.');
159
+ }
160
+ }
161
+ throw new UnprocessableException('Failed to upload from URL.');
162
+ }
122
163
  }
123
164
 
124
165
  public async uploadStackText(path: string, fileName: string, text: string) {
@@ -234,4 +275,26 @@ export class AwsS3Client {
234
275
  await this.client.send(deleteCommand);
235
276
  }
236
277
  }
278
+
279
+ public async deleteFromUrl(url: string, isFileUrl: boolean = true): Promise<void> {
280
+ const path = url.replace(this.UrlPrefix + '/', '');
281
+ if (url === path) {
282
+ throw new UnprocessableException('The specified URL cannot be deleted because the bucket and region do not match.');
283
+ }
284
+
285
+ if (path.trim() === "") {
286
+ throw new UnprocessableException('This URL is invalid.');
287
+ }
288
+
289
+ if (isFileUrl) {
290
+ const pathSplits = path.split('/');
291
+ const file = pathSplits.pop();
292
+ if (file === undefined) {
293
+ throw new UnprocessableException('This URL is invalid.');
294
+ }
295
+ await this.deleteFile(pathSplits.join('/'), file);
296
+ } else {
297
+ await this.deleteDir(path);
298
+ }
299
+ }
237
300
  }