@ingestkorea/client-sens 1.4.1 → 1.4.3
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 +8 -2
- package/dist-cjs/SensClient.js +4 -3
- package/dist-cjs/middleware/index.js +2 -1
- package/dist-cjs/middleware/metadata-ingestkorea.js +28 -0
- package/dist-cjs/middleware/{signer.js → signer-ncp.js} +5 -4
- package/dist-es/SensClient.js +5 -4
- package/dist-es/middleware/index.js +2 -1
- package/dist-es/middleware/metadata-ingestkorea.js +19 -0
- package/dist-es/middleware/{signer.js → signer-ncp.js} +3 -2
- package/dist-types/SensClient.d.ts +1 -1
- package/dist-types/middleware/index.d.ts +2 -1
- package/dist-types/middleware/metadata-ingestkorea.d.ts +3 -0
- package/dist-types/middleware/signer-ncp.d.ts +3 -0
- package/package.json +1 -1
- package/dist-types/middleware/signer.d.ts +0 -3
package/README.md
CHANGED
|
@@ -61,10 +61,16 @@ const client = new SensClient({
|
|
|
61
61
|
serviceId: {
|
|
62
62
|
sms: 'ncp:sms:kr:123456789xxx:your-service-name', // optional
|
|
63
63
|
kakao: 'ncp:kkobizmsg:kr:9876xxx:your-service-name' // optional
|
|
64
|
-
// at least one serviceId required
|
|
65
|
-
// if you call send operation without serviceId, sdk throw error
|
|
66
64
|
}
|
|
67
65
|
});
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* accessKey, secretKey: https://www.ncloud.com/mypage/manage/authkey
|
|
69
|
+
* serviceId: https://console.ncloud.com/sens/project
|
|
70
|
+
*
|
|
71
|
+
* at least one serviceId required
|
|
72
|
+
* if you call send operation without serviceId, sdk throw error
|
|
73
|
+
*/
|
|
68
74
|
```
|
|
69
75
|
|
|
70
76
|
#### SendAlimtalk
|
package/dist-cjs/SensClient.js
CHANGED
|
@@ -23,15 +23,16 @@ class SensClient {
|
|
|
23
23
|
credentials: Object.assign({}, resolvedCredentials),
|
|
24
24
|
serviceId: Object.assign({}, resolvedServiceId)
|
|
25
25
|
};
|
|
26
|
-
this.
|
|
26
|
+
this.requestHandler = new util_http_handler_1.NodeHttpHandler({ connectionTimeout: 3000, socketTimeout: 3000 });
|
|
27
27
|
}
|
|
28
28
|
;
|
|
29
29
|
send(command) {
|
|
30
30
|
return __awaiter(this, void 0, void 0, function* () {
|
|
31
31
|
let input = command.input;
|
|
32
32
|
let request = yield command.serialize(input, this.config);
|
|
33
|
-
request = yield (0, middleware_1.
|
|
34
|
-
|
|
33
|
+
request = yield (0, middleware_1.middlewareNcpSigner)(request, this.config);
|
|
34
|
+
request = yield (0, middleware_1.middlewareIngestkoreaMetadata)(request, this.config);
|
|
35
|
+
let { response } = yield this.requestHandler.handle(request);
|
|
35
36
|
let output = yield command.deserialize(response);
|
|
36
37
|
return output;
|
|
37
38
|
});
|
|
@@ -14,4 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./signer"), exports);
|
|
17
|
+
__exportStar(require("./signer-ncp"), exports);
|
|
18
|
+
__exportStar(require("./metadata-ingestkorea"), exports);
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.middlewareIngestkoreaMetadata = void 0;
|
|
13
|
+
const middlewareIngestkoreaMetadata = (request, config) => __awaiter(void 0, void 0, void 0, function* () {
|
|
14
|
+
const { longDate } = yield convertFormatDate(request.headers['x-ncp-apigw-timestamp']);
|
|
15
|
+
request.headers = Object.assign(Object.assign({}, request.headers), { ['x-ingestkorea-date']: longDate, ['x-ingestkorea-user-agent']: '@ingestkorea/client-sens/1.4.x' });
|
|
16
|
+
return request;
|
|
17
|
+
});
|
|
18
|
+
exports.middlewareIngestkoreaMetadata = middlewareIngestkoreaMetadata;
|
|
19
|
+
/**
|
|
20
|
+
* @param input milliseconds
|
|
21
|
+
*/
|
|
22
|
+
const convertFormatDate = (input) => __awaiter(void 0, void 0, void 0, function* () {
|
|
23
|
+
let milliseconds = input ? Number(input) : new Date().getTime();
|
|
24
|
+
let iso8601 = new Date(milliseconds).toISOString().replace(/\.\d{3}Z$/, "Z");
|
|
25
|
+
let longDate = iso8601.replace(/[\-:]/g, "");
|
|
26
|
+
let shortDate = longDate.slice(0, 8);
|
|
27
|
+
return { longDate, shortDate };
|
|
28
|
+
});
|
|
@@ -9,12 +9,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
9
9
|
});
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.
|
|
12
|
+
exports.middlewareNcpSigner = void 0;
|
|
13
13
|
const crypto_1 = require("crypto");
|
|
14
|
-
const
|
|
14
|
+
const util_http_handler_1 = require("@ingestkorea/util-http-handler");
|
|
15
|
+
const middlewareNcpSigner = (request, config) => __awaiter(void 0, void 0, void 0, function* () {
|
|
15
16
|
const { accessKey, secretKey } = config.credentials;
|
|
16
17
|
const method = request.method;
|
|
17
|
-
const queryString =
|
|
18
|
+
const queryString = (0, util_http_handler_1.buildQueryString)(request.query);
|
|
18
19
|
const path = queryString ? `${request.path}?${queryString}` : request.path;
|
|
19
20
|
const space = " ";
|
|
20
21
|
const newLine = "\n";
|
|
@@ -28,4 +29,4 @@ const middlewareSigner = (request, config) => __awaiter(void 0, void 0, void 0,
|
|
|
28
29
|
request.headers = Object.assign(Object.assign({}, request.headers), { ['x-ncp-iam-access-key']: accessKey, ['x-ncp-apigw-timestamp']: timestamp, ['x-ncp-apigw-signature-v2']: signature });
|
|
29
30
|
return request;
|
|
30
31
|
});
|
|
31
|
-
exports.
|
|
32
|
+
exports.middlewareNcpSigner = middlewareNcpSigner;
|
package/dist-es/SensClient.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NodeHttpHandler } from '@ingestkorea/util-http-handler';
|
|
2
2
|
import { IngestkoreaError } from '@ingestkorea/util-error-handler';
|
|
3
|
-
import {
|
|
3
|
+
import { middlewareNcpSigner, middlewareIngestkoreaMetadata } from './middleware';
|
|
4
4
|
;
|
|
5
5
|
;
|
|
6
6
|
export class SensClient {
|
|
@@ -11,14 +11,15 @@ export class SensClient {
|
|
|
11
11
|
credentials: { ...resolvedCredentials },
|
|
12
12
|
serviceId: { ...resolvedServiceId }
|
|
13
13
|
};
|
|
14
|
-
this.
|
|
14
|
+
this.requestHandler = new NodeHttpHandler({ connectionTimeout: 3000, socketTimeout: 3000 });
|
|
15
15
|
}
|
|
16
16
|
;
|
|
17
17
|
async send(command) {
|
|
18
18
|
let input = command.input;
|
|
19
19
|
let request = await command.serialize(input, this.config);
|
|
20
|
-
request = await
|
|
21
|
-
|
|
20
|
+
request = await middlewareNcpSigner(request, this.config);
|
|
21
|
+
request = await middlewareIngestkoreaMetadata(request, this.config);
|
|
22
|
+
let { response } = await this.requestHandler.handle(request);
|
|
22
23
|
let output = await command.deserialize(response);
|
|
23
24
|
return output;
|
|
24
25
|
}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export * from './signer';
|
|
1
|
+
export * from './signer-ncp';
|
|
2
|
+
export * from './metadata-ingestkorea';
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export const middlewareIngestkoreaMetadata = async (request, config) => {
|
|
2
|
+
const { longDate } = await convertFormatDate(request.headers['x-ncp-apigw-timestamp']);
|
|
3
|
+
request.headers = {
|
|
4
|
+
...request.headers,
|
|
5
|
+
['x-ingestkorea-date']: longDate,
|
|
6
|
+
['x-ingestkorea-user-agent']: '@ingestkorea/client-sens/1.4.x'
|
|
7
|
+
};
|
|
8
|
+
return request;
|
|
9
|
+
};
|
|
10
|
+
/**
|
|
11
|
+
* @param input milliseconds
|
|
12
|
+
*/
|
|
13
|
+
const convertFormatDate = async (input) => {
|
|
14
|
+
let milliseconds = input ? Number(input) : new Date().getTime();
|
|
15
|
+
let iso8601 = new Date(milliseconds).toISOString().replace(/\.\d{3}Z$/, "Z");
|
|
16
|
+
let longDate = iso8601.replace(/[\-:]/g, "");
|
|
17
|
+
let shortDate = longDate.slice(0, 8);
|
|
18
|
+
return { longDate, shortDate };
|
|
19
|
+
};
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { createHmac } from 'crypto';
|
|
2
|
-
|
|
2
|
+
import { buildQueryString } from '@ingestkorea/util-http-handler';
|
|
3
|
+
export const middlewareNcpSigner = async (request, config) => {
|
|
3
4
|
const { accessKey, secretKey } = config.credentials;
|
|
4
5
|
const method = request.method;
|
|
5
|
-
const queryString =
|
|
6
|
+
const queryString = buildQueryString(request.query);
|
|
6
7
|
const path = queryString ? `${request.path}?${queryString}` : request.path;
|
|
7
8
|
const space = " ";
|
|
8
9
|
const newLine = "\n";
|
|
@@ -19,7 +19,7 @@ export interface SensClientResolvedConfig {
|
|
|
19
19
|
}
|
|
20
20
|
export declare class SensClient {
|
|
21
21
|
config: SensClientResolvedConfig;
|
|
22
|
-
|
|
22
|
+
requestHandler: NodeHttpHandler;
|
|
23
23
|
constructor(config: SensClientConfig);
|
|
24
24
|
send<T, P>(command: SensCommand<T, P, SensClientResolvedConfig>): Promise<P>;
|
|
25
25
|
}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export * from './signer';
|
|
1
|
+
export * from './signer-ncp';
|
|
2
|
+
export * from './metadata-ingestkorea';
|
package/package.json
CHANGED