@fonoster/sipnet 0.6.2-alpha.0 → 0.6.6

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.
@@ -11,13 +11,13 @@ declare function buildService(clientOptions: ClientOptions): {
11
11
  request: import("@fonoster/types").CreateAclRequest;
12
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AclExtended) => void) => Promise<void>;
13
13
  updateAcl: (call: {
14
- request: import("@fonoster/types").UpdateAclRequest;
14
+ request: import("@fonoster/types/dist/utils").Flatten<import("@fonoster/types").BaseApiObject & Partial<import("@fonoster/types").CreateAclRequest>>;
15
15
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AclExtended) => void) => Promise<void>;
16
16
  getAcl: (call: {
17
17
  request: import("@fonoster/types").BaseApiObject;
18
18
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AclExtended) => void) => Promise<void>;
19
19
  listAcls: (call: {
20
- request: import("@fonoster/types").ListAclsRequest;
20
+ request: import("@fonoster/types").ListRequest;
21
21
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
22
22
  nextPageToken?: string;
23
23
  items: import("@fonoster/types").AclExtended[];
@@ -25,7 +25,7 @@ exports.buildService = buildService;
25
25
  const sdk_1 = __importDefault(require("@routr/sdk"));
26
26
  const operations_1 = require("./operations");
27
27
  function buildService(clientOptions) {
28
- const client = new sdk_1.default.ACL(clientOptions);
28
+ const client = new sdk_1.default.Acls(clientOptions);
29
29
  return {
30
30
  definition: {
31
31
  serviceName: "Acls",
@@ -1,15 +1,15 @@
1
- import { AclExtended, AclsApi, BaseApiObject, CreateAclRequest, ListAclsRequest, UpdateAclRequest } from "@fonoster/types";
1
+ import { AclExtended, AclsApi, BaseApiObject, CreateAclRequest } from "@fonoster/types";
2
2
  declare function createAcl(acls: AclsApi): (call: {
3
3
  request: CreateAclRequest;
4
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AclExtended) => void) => Promise<void>;
5
5
  declare function updateAcl(acls: AclsApi): (call: {
6
- request: UpdateAclRequest;
6
+ request: import("@fonoster/types/dist/utils").Flatten<BaseApiObject & Partial<CreateAclRequest>>;
7
7
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AclExtended) => void) => Promise<void>;
8
8
  declare function getAcl(acls: AclsApi): (call: {
9
9
  request: BaseApiObject;
10
10
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AclExtended) => void) => Promise<void>;
11
11
  declare function listAcls(acls: AclsApi): (call: {
12
- request: ListAclsRequest;
12
+ request: import("@fonoster/types").ListRequest;
13
13
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
14
14
  nextPageToken?: string;
15
15
  items: AclExtended[];
@@ -10,7 +10,7 @@ const deleteResource_1 = require("../resources/deleteResource");
10
10
  const getResource_1 = require("../resources/getResource");
11
11
  const listResources_1 = require("../resources/listResources");
12
12
  const updateResource_1 = require("../resources/updateResource");
13
- const RESOURCE = "ACL";
13
+ const RESOURCE = "Acl";
14
14
  function createAcl(acls) {
15
15
  return (0, createResource_1.createResource)(acls, RESOURCE);
16
16
  }
@@ -11,13 +11,13 @@ declare function buildService(clientOptions: ClientOptions): {
11
11
  request: import("@fonoster/types").CreateAgentRequestExtended;
12
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AgentExtended) => void) => Promise<void>;
13
13
  updateAgent: (call: {
14
- request: import("@fonoster/types").UpdateAgentRequest;
14
+ request: import("@fonoster/types/dist/utils").Flatten<import("@fonoster/types").BaseApiObject & Omit<Partial<import("@fonoster/types").CreateAgentRequest>, "username" | "extended">>;
15
15
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AgentExtended) => void) => Promise<void>;
16
16
  getAgent: (call: {
17
17
  request: import("@fonoster/types").BaseApiObject;
18
18
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").AgentExtended) => void) => Promise<void>;
19
19
  listAgents: (call: {
20
- request: import("@fonoster/types").ListAgentsRequest;
20
+ request: import("@fonoster/types").ListRequest;
21
21
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
22
22
  nextPageToken?: string;
23
23
  items: import("@fonoster/types").AgentExtended[];
@@ -1,15 +1,15 @@
1
- import { AgentExtended, AgentsApi, BaseApiObject, CreateAgentRequestExtended, ListAgentsRequest, UpdateAgentRequest } from "@fonoster/types";
1
+ import { AgentExtended, AgentsApi, BaseApiObject, CreateAgentRequestExtended } from "@fonoster/types";
2
2
  declare function createAgent(agents: AgentsApi): (call: {
3
3
  request: CreateAgentRequestExtended;
4
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AgentExtended) => void) => Promise<void>;
5
5
  declare function updateAgent(agents: AgentsApi): (call: {
6
- request: UpdateAgentRequest;
6
+ request: import("@fonoster/types/dist/utils").Flatten<BaseApiObject & Omit<Partial<import("@fonoster/types").CreateAgentRequest>, "username" | "extended">>;
7
7
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AgentExtended) => void) => Promise<void>;
8
8
  declare function getAgent(agents: AgentsApi): (call: {
9
9
  request: BaseApiObject;
10
10
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: AgentExtended) => void) => Promise<void>;
11
11
  declare function listAgents(agents: AgentsApi): (call: {
12
- request: ListAgentsRequest;
12
+ request: import("@fonoster/types").ListRequest;
13
13
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
14
14
  nextPageToken?: string;
15
15
  items: AgentExtended[];
@@ -11,13 +11,15 @@ declare function buildService(clientOptions: ClientOptions): {
11
11
  request: import("@fonoster/types").CreateCredentialsRequestExtended;
12
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").CredentialsExtended) => void) => Promise<void>;
13
13
  updateCredentials: (call: {
14
- request: import("@fonoster/types").UpdateCredentialsRequest;
14
+ request: import("@fonoster/types/dist/utils").Flatten<import("@fonoster/types").BaseApiObject & {
15
+ name: string;
16
+ }>;
15
17
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").CredentialsExtended) => void) => Promise<void>;
16
18
  getCredentials: (call: {
17
19
  request: import("@fonoster/types").BaseApiObject;
18
20
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").CredentialsExtended) => void) => Promise<void>;
19
21
  listCredentials: (call: {
20
- request: import("@fonoster/types").ListCredentialsRequest;
22
+ request: import("@fonoster/types").ListRequest;
21
23
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
22
24
  nextPageToken?: string;
23
25
  items: import("@fonoster/types").CredentialsExtended[];
@@ -1,15 +1,17 @@
1
- import { BaseApiObject, CreateCredentialsRequestExtended, CredentialsApi, CredentialsExtended, ListCredentialsRequest, UpdateCredentialsRequest } from "@fonoster/types";
1
+ import { BaseApiObject, CreateCredentialsRequestExtended, CredentialsApi, CredentialsExtended } from "@fonoster/types";
2
2
  declare function createCredentials(credentials: CredentialsApi): (call: {
3
3
  request: CreateCredentialsRequestExtended;
4
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: CredentialsExtended) => void) => Promise<void>;
5
5
  declare function updateCredentials(credentials: CredentialsApi): (call: {
6
- request: UpdateCredentialsRequest;
6
+ request: import("@fonoster/types/dist/utils").Flatten<BaseApiObject & {
7
+ name: string;
8
+ }>;
7
9
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: CredentialsExtended) => void) => Promise<void>;
8
10
  declare function getCredentials(credentials: CredentialsApi): (call: {
9
11
  request: BaseApiObject;
10
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: CredentialsExtended) => void) => Promise<void>;
11
13
  declare function listCredentials(credentials: CredentialsApi): (call: {
12
- request: ListCredentialsRequest;
14
+ request: import("@fonoster/types").ListRequest;
13
15
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
14
16
  nextPageToken?: string;
15
17
  items: CredentialsExtended[];
@@ -11,13 +11,13 @@ declare function buildService(clientOptions: ClientOptions): {
11
11
  request: import("@fonoster/types").CreateDomainRequestExtended;
12
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").DomainExtended) => void) => Promise<void>;
13
13
  updateDomain: (call: {
14
- request: import("@fonoster/types").UpdateDomainRequest;
14
+ request: import("@fonoster/types/dist/utils").Flatten<import("@fonoster/types").BaseApiObject & Omit<Partial<import("@fonoster/types").CreateDomainRequest>, "domainUri">>;
15
15
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").DomainExtended) => void) => Promise<void>;
16
16
  getDomain: (call: {
17
17
  request: import("@fonoster/types").BaseApiObject;
18
18
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").DomainExtended) => void) => Promise<void>;
19
19
  listDomains: (call: {
20
- request: import("@fonoster/types").ListDomainsRequest;
20
+ request: import("@fonoster/types").ListRequest;
21
21
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
22
22
  nextPageToken?: string;
23
23
  items: import("@fonoster/types").DomainExtended[];
@@ -1,15 +1,15 @@
1
- import { BaseApiObject, CreateDomainRequestExtended, DomainExtended, DomainsApi, ListDomainsRequest, UpdateDomainRequest } from "@fonoster/types";
1
+ import { BaseApiObject, CreateDomainRequestExtended, DomainExtended, DomainsApi } from "@fonoster/types";
2
2
  declare function createDomain(domains: DomainsApi): (call: {
3
3
  request: CreateDomainRequestExtended;
4
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: DomainExtended) => void) => Promise<void>;
5
5
  declare function updateDomain(domains: DomainsApi): (call: {
6
- request: UpdateDomainRequest;
6
+ request: import("@fonoster/types/dist/utils").Flatten<BaseApiObject & Omit<Partial<import("@fonoster/types").CreateDomainRequest>, "domainUri">>;
7
7
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: DomainExtended) => void) => Promise<void>;
8
8
  declare function getDomain(domains: DomainsApi): (call: {
9
9
  request: BaseApiObject;
10
10
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: DomainExtended) => void) => Promise<void>;
11
11
  declare function listDomains(domains: DomainsApi): (call: {
12
- request: ListDomainsRequest;
12
+ request: import("@fonoster/types").ListRequest;
13
13
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
14
14
  nextPageToken?: string;
15
15
  items: DomainExtended[];
@@ -9,20 +9,17 @@ declare function buildService(clientOptions: ClientOptions, checkNumberPrecondit
9
9
  };
10
10
  handlers: {
11
11
  createNumber: (call: {
12
- request: import("@fonoster/types").FCreateNumberRequest;
12
+ request: import("@fonoster/types").CreateNumberRequest;
13
13
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").BaseApiObject) => void) => Promise<void>;
14
14
  updateNumber: (call: {
15
- request: import("@fonoster/types").FUpdateNumberRequest;
15
+ request: import("@fonoster/types").UpdateNumberRequest;
16
16
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").BaseApiObject) => void) => Promise<void>;
17
17
  getNumber: (call: {
18
18
  request: import("@fonoster/types").BaseApiObject;
19
- }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").INumberExtended) => void) => Promise<void>;
19
+ }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").BaseApiObject) => void) => Promise<void>;
20
20
  listNumbers: (call: {
21
21
  request: import("@fonoster/types").ListNumbersRequest;
22
- }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
23
- nextPageToken?: string;
24
- items: import("@fonoster/types").INumberExtended[];
25
- }) => void) => Promise<void>;
22
+ }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").ListNumbersResponse) => void) => Promise<void>;
26
23
  deleteNumber: (call: {
27
24
  request: import("@fonoster/types").BaseApiObject;
28
25
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").INumberExtended) => void) => Promise<void>;
@@ -6,6 +6,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.buildService = buildService;
7
7
  const sdk_1 = __importDefault(require("@routr/sdk"));
8
8
  const createNumber_1 = require("./createNumber");
9
+ const getNumber_1 = require("./getNumber");
10
+ const listNumbers_1 = require("./listNumbers");
9
11
  const operations_1 = require("./operations");
10
12
  const updateNumber_1 = require("./updateNumber");
11
13
  function buildService(clientOptions, checkNumberPreconditions) {
@@ -20,8 +22,8 @@ function buildService(clientOptions, checkNumberPreconditions) {
20
22
  handlers: {
21
23
  createNumber: (0, createNumber_1.createNumber)(client, checkNumberPreconditions),
22
24
  updateNumber: (0, updateNumber_1.updateNumber)(client, checkNumberPreconditions),
23
- getNumber: (0, operations_1.getNumber)(client),
24
- listNumbers: (0, operations_1.listNumbers)(client),
25
+ getNumber: (0, getNumber_1.getNumber)(client),
26
+ listNumbers: (0, listNumbers_1.listNumbers)(client),
25
27
  deleteNumber: (0, operations_1.deleteNumber)(client)
26
28
  }
27
29
  };
@@ -0,0 +1,3 @@
1
+ import { INumber, INumberExtended } from "@fonoster/types";
2
+ declare function convertToFonosterNumber(number: INumberExtended): INumber;
3
+ export { convertToFonosterNumber };
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.convertToFonosterNumber = convertToFonosterNumber;
4
+ const constants_1 = require("../constants");
5
+ function convertToFonosterNumber(number) {
6
+ var _a, _b, _c;
7
+ const appRef = (_b = (_a = number.extraHeaders) === null || _a === void 0 ? void 0 : _a.find((header) => header.name === constants_1.APP_REF_HEADER)) === null || _b === void 0 ? void 0 : _b.value;
8
+ return {
9
+ ref: number.ref,
10
+ name: number.name,
11
+ telUrl: number.telUrl,
12
+ appRef,
13
+ agentAor: appRef ? undefined : number.aorLink,
14
+ city: number.city,
15
+ country: number.country,
16
+ countryIsoCode: number.countryIsoCode,
17
+ trunkRef: ((_c = number.trunk) === null || _c === void 0 ? void 0 : _c.ref) || undefined,
18
+ createdAt: new Date(number.createdAt * 1000),
19
+ updatedAt: new Date(number.updatedAt * 1000)
20
+ };
21
+ }
@@ -1,5 +1,5 @@
1
- import { FCreateNumberRequest } from "@fonoster/types";
2
- declare function convertToRoutrNumber(number: FCreateNumberRequest, accessKeyId: string): {
1
+ import { CreateNumberRequest, UpdateNumberRequest } from "@fonoster/types";
2
+ declare function convertToRoutrNumber(number: CreateNumberRequest, accessKeyId: string): {
3
3
  name: string;
4
4
  telUrl: string;
5
5
  aorLink: string;
@@ -10,9 +10,15 @@ declare function convertToRoutrNumber(number: FCreateNumberRequest, accessKeyId:
10
10
  name: string;
11
11
  value: string;
12
12
  }[];
13
- extended: {
14
- accessKeyId: string;
15
- };
16
- sessionAffinityHeader: string;
13
+ extended: Record<string, unknown>;
17
14
  };
18
- export { convertToRoutrNumber };
15
+ declare function convertToRoutrNumberUpdate(number: UpdateNumberRequest): {
16
+ ref: string;
17
+ name: string;
18
+ aorLink: string;
19
+ extraHeaders: {
20
+ name: string;
21
+ value: string;
22
+ }[];
23
+ };
24
+ export { convertToRoutrNumber, convertToRoutrNumberUpdate };
@@ -1,12 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.convertToRoutrNumber = convertToRoutrNumber;
4
+ exports.convertToRoutrNumberUpdate = convertToRoutrNumberUpdate;
4
5
  const constants_1 = require("../constants");
5
6
  function convertToRoutrNumber(number, accessKeyId) {
7
+ const aorLink = number.appRef ? constants_1.ROUTR_DEFAULT_PEER_AOR : number.agentAor;
6
8
  return {
7
9
  name: number.name,
8
10
  telUrl: number.telUrl,
9
- aorLink: number.agentAor || constants_1.ROUTR_DEFAULT_PEER_AOR,
11
+ aorLink,
10
12
  city: number.city,
11
13
  country: number.country,
12
14
  countryIsoCode: number.countryIsoCode,
@@ -18,8 +20,27 @@ function convertToRoutrNumber(number, accessKeyId) {
18
20
  }
19
21
  ]
20
22
  : [],
21
- extended: { accessKeyId },
22
- // TODO: Make this optional upstream in Routr
23
- sessionAffinityHeader: ""
23
+ extended: { accessKeyId }
24
+ };
25
+ }
26
+ function convertToRoutrNumberUpdate(number) {
27
+ let aorLink;
28
+ let extraHeaders = [];
29
+ if (number.appRef) {
30
+ aorLink = constants_1.ROUTR_DEFAULT_PEER_AOR;
31
+ extraHeaders.push({
32
+ name: constants_1.APP_REF_HEADER,
33
+ value: number.appRef
34
+ });
35
+ }
36
+ else if (number.agentAor) {
37
+ extraHeaders = null;
38
+ aorLink = number.agentAor;
39
+ }
40
+ return {
41
+ ref: number.ref,
42
+ name: number.name,
43
+ aorLink,
44
+ extraHeaders
24
45
  };
25
46
  }
@@ -1,6 +1,6 @@
1
1
  import { GrpcErrorMessage, NumberPreconditionsCheck } from "@fonoster/common";
2
- import { BaseApiObject, FCreateNumberRequest, NumbersApi } from "@fonoster/types";
2
+ import { BaseApiObject, CreateNumberRequest, NumbersApi } from "@fonoster/types";
3
3
  declare function createNumber(api: NumbersApi, checkNumberPreconditions: NumberPreconditionsCheck): (call: {
4
- request: FCreateNumberRequest;
4
+ request: CreateNumberRequest;
5
5
  }, callback: (error?: GrpcErrorMessage, response?: BaseApiObject) => void) => Promise<void>;
6
6
  export { createNumber };
@@ -42,7 +42,7 @@ function createNumber(api, checkNumberPreconditions) {
42
42
  // Validates that the appRef or agentAor exists in the system
43
43
  yield checkNumberPreconditions(request);
44
44
  const accessKeyId = (0, identity_1.getAccessKeyIdFromCall)(call);
45
- logger.verbose("call to createNumber", { request, accessKeyId });
45
+ logger.verbose("call to createNumber", Object.assign(Object.assign({}, request), { accessKeyId }));
46
46
  const response = yield api.createNumber((0, convertToRoutrNumber_1.convertToRoutrNumber)(request, accessKeyId));
47
47
  callback(null, response);
48
48
  }
@@ -0,0 +1,6 @@
1
+ import { GrpcErrorMessage } from "@fonoster/common";
2
+ import { BaseApiObject, NumbersApi } from "@fonoster/types";
3
+ declare function getNumber(api: NumbersApi): (call: {
4
+ request: BaseApiObject;
5
+ }, callback: (error?: GrpcErrorMessage, response?: BaseApiObject) => void) => Promise<void>;
6
+ export { getNumber };
@@ -0,0 +1,47 @@
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.getNumber = getNumber;
13
+ /*
14
+ * Copyright (C) 2024 by Fonoster Inc (https://fonoster.com)
15
+ * http://github.com/fonoster/fonoster
16
+ *
17
+ * This file is part of Fonoster
18
+ *
19
+ * Licensed under the MIT License (the "License");
20
+ * you may not use this file except in compliance with
21
+ * the License. You may obtain a copy of the License at
22
+ *
23
+ * https://opensource.org/licenses/MIT
24
+ *
25
+ * Unless required by applicable law or agreed to in writing, software
26
+ * distributed under the License is distributed on an "AS IS" BASIS,
27
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
28
+ * See the License for the specific language governing permissions and
29
+ * limitations under the License.
30
+ */
31
+ const common_1 = require("@fonoster/common");
32
+ const logger_1 = require("@fonoster/logger");
33
+ const convertToFonosterNumber_1 = require("./convertToFonosterNumber");
34
+ const logger = (0, logger_1.getLogger)({ service: "sipnet", filePath: __filename });
35
+ function getNumber(api) {
36
+ return (call, callback) => __awaiter(this, void 0, void 0, function* () {
37
+ const { ref } = call.request;
38
+ try {
39
+ logger.verbose("call to getNumber", { ref });
40
+ const response = yield api.getNumber(ref);
41
+ callback(null, (0, convertToFonosterNumber_1.convertToFonosterNumber)(response));
42
+ }
43
+ catch (e) {
44
+ (0, common_1.handleError)(e, callback);
45
+ }
46
+ });
47
+ }
@@ -0,0 +1,6 @@
1
+ import { GrpcErrorMessage } from "@fonoster/common";
2
+ import { ListNumbersRequest, ListNumbersResponse, NumbersApi } from "@fonoster/types";
3
+ declare function listNumbers(api: NumbersApi): (call: {
4
+ request: ListNumbersRequest;
5
+ }, callback: (error?: GrpcErrorMessage, response?: ListNumbersResponse) => void) => Promise<void>;
6
+ export { listNumbers };
@@ -0,0 +1,51 @@
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.listNumbers = listNumbers;
13
+ /*
14
+ * Copyright (C) 2024 by Fonoster Inc (https://fonoster.com)
15
+ * http://github.com/fonoster/fonoster
16
+ *
17
+ * This file is part of Fonoster
18
+ *
19
+ * Licensed under the MIT License (the "License");
20
+ * you may not use this file except in compliance with
21
+ * the License. You may obtain a copy of the License at
22
+ *
23
+ * https://opensource.org/licenses/MIT
24
+ *
25
+ * Unless required by applicable law or agreed to in writing, software
26
+ * distributed under the License is distributed on an "AS IS" BASIS,
27
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
28
+ * See the License for the specific language governing permissions and
29
+ * limitations under the License.
30
+ */
31
+ const common_1 = require("@fonoster/common");
32
+ const logger_1 = require("@fonoster/logger");
33
+ const convertToFonosterNumber_1 = require("./convertToFonosterNumber");
34
+ const logger = (0, logger_1.getLogger)({ service: "sipnet", filePath: __filename });
35
+ function listNumbers(api) {
36
+ return (call, callback) => __awaiter(this, void 0, void 0, function* () {
37
+ const { request } = call;
38
+ logger.verbose("call to listNumbers", Object.assign({}, request));
39
+ try {
40
+ const response = yield api.listNumbers(request);
41
+ const items = response.items.map(convertToFonosterNumber_1.convertToFonosterNumber);
42
+ callback(null, {
43
+ items: items,
44
+ nextPageToken: response.nextPageToken
45
+ });
46
+ }
47
+ catch (e) {
48
+ (0, common_1.handleError)(e, callback);
49
+ }
50
+ });
51
+ }
@@ -1,14 +1,5 @@
1
- import { BaseApiObject, INumberExtended, ListNumbersRequest, NumbersApi } from "@fonoster/types";
2
- declare function getNumber(numbers: NumbersApi): (call: {
3
- request: BaseApiObject;
4
- }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: INumberExtended) => void) => Promise<void>;
5
- declare function listNumbers(numbers: NumbersApi): (call: {
6
- request: ListNumbersRequest;
7
- }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
8
- nextPageToken?: string;
9
- items: INumberExtended[];
10
- }) => void) => Promise<void>;
1
+ import { BaseApiObject, INumberExtended, NumbersApi } from "@fonoster/types";
11
2
  declare function deleteNumber(numbers: NumbersApi): (call: {
12
3
  request: BaseApiObject;
13
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: INumberExtended) => void) => Promise<void>;
14
- export { getNumber, listNumbers, deleteNumber };
5
+ export { deleteNumber };
@@ -1,18 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getNumber = getNumber;
4
- exports.listNumbers = listNumbers;
5
3
  exports.deleteNumber = deleteNumber;
6
4
  const deleteResource_1 = require("../resources/deleteResource");
7
- const getResource_1 = require("../resources/getResource");
8
- const listResources_1 = require("../resources/listResources");
9
5
  const RESOURCE = "Number";
10
- function getNumber(numbers) {
11
- return (0, getResource_1.getResource)(numbers, RESOURCE);
12
- }
13
- function listNumbers(numbers) {
14
- return (0, listResources_1.listResources)(numbers, RESOURCE);
15
- }
16
6
  function deleteNumber(numbers) {
17
7
  return (0, deleteResource_1.deleteResource)(numbers, RESOURCE);
18
8
  }
@@ -1,6 +1,6 @@
1
1
  import { GrpcErrorMessage, NumberPreconditionsCheck } from "@fonoster/common";
2
- import { BaseApiObject, FUpdateNumberRequest, NumbersApi } from "@fonoster/types";
2
+ import { BaseApiObject, NumbersApi, UpdateNumberRequest } from "@fonoster/types";
3
3
  declare function updateNumber(api: NumbersApi, checkNumberPreconditions: NumberPreconditionsCheck): (call: {
4
- request: FUpdateNumberRequest;
4
+ request: UpdateNumberRequest;
5
5
  }, callback: (error?: GrpcErrorMessage, response?: BaseApiObject) => void) => Promise<void>;
6
6
  export { updateNumber };
@@ -30,6 +30,7 @@ exports.updateNumber = updateNumber;
30
30
  */
31
31
  const common_1 = require("@fonoster/common");
32
32
  const logger_1 = require("@fonoster/logger");
33
+ const convertToRoutrNumber_1 = require("./convertToRoutrNumber");
33
34
  const validation_1 = require("./validation");
34
35
  const logger = (0, logger_1.getLogger)({ service: "sipnet", filePath: __filename });
35
36
  function updateNumber(api, checkNumberPreconditions) {
@@ -39,8 +40,8 @@ function updateNumber(api, checkNumberPreconditions) {
39
40
  validation_1.updateNumberRequestSchema.parse(request);
40
41
  // Validates that the appRef or agentAor exists in the system
41
42
  yield checkNumberPreconditions(request);
42
- logger.verbose("call to updateNumber", { request });
43
- const response = yield api.updateNumber(request);
43
+ logger.verbose("call to updateNumber", Object.assign({}, request));
44
+ const response = yield api.updateNumber((0, convertToRoutrNumber_1.convertToRoutrNumberUpdate)(request));
44
45
  callback(null, response);
45
46
  }
46
47
  catch (e) {
@@ -5,35 +5,35 @@ declare const createNumberRequestSchema: z.ZodEffects<z.ZodObject<{
5
5
  countryIsoCode: z.ZodEffects<z.ZodString, string, string>;
6
6
  }, "strip", z.ZodTypeAny, {
7
7
  countryIsoCode?: string;
8
- agentAor?: string;
9
8
  appRef?: string;
9
+ agentAor?: string;
10
10
  }, {
11
11
  countryIsoCode?: string;
12
- agentAor?: string;
13
12
  appRef?: string;
13
+ agentAor?: string;
14
14
  }>, {
15
15
  countryIsoCode?: string;
16
- agentAor?: string;
17
16
  appRef?: string;
17
+ agentAor?: string;
18
18
  }, {
19
19
  countryIsoCode?: string;
20
- agentAor?: string;
21
20
  appRef?: string;
21
+ agentAor?: string;
22
22
  }>;
23
23
  declare const updateNumberRequestSchema: z.ZodEffects<z.ZodObject<{
24
24
  agentAor: z.ZodOptional<z.ZodString>;
25
25
  appRef: z.ZodOptional<z.ZodString>;
26
26
  }, "strip", z.ZodTypeAny, {
27
- agentAor?: string;
28
27
  appRef?: string;
29
- }, {
30
28
  agentAor?: string;
29
+ }, {
31
30
  appRef?: string;
32
- }>, {
33
31
  agentAor?: string;
32
+ }>, {
34
33
  appRef?: string;
35
- }, {
36
34
  agentAor?: string;
35
+ }, {
37
36
  appRef?: string;
37
+ agentAor?: string;
38
38
  }>;
39
39
  export { createNumberRequestSchema, updateNumberRequestSchema };
@@ -36,7 +36,7 @@ function createResource(api, resource) {
36
36
  return (call, callback) => __awaiter(this, void 0, void 0, function* () {
37
37
  const { request } = call;
38
38
  const accessKeyId = (0, identity_1.getAccessKeyIdFromCall)(call);
39
- logger.verbose(`call to create${resource}`, { request, accessKeyId });
39
+ logger.verbose(`call to create${resource}`, Object.assign(Object.assign({}, request), { accessKeyId }));
40
40
  try {
41
41
  const response = yield api[`create${resource}`](Object.assign(Object.assign({}, request), { extended: {
42
42
  accessKeyId
@@ -34,12 +34,7 @@ const logger = (0, logger_1.getLogger)({ service: "sipnet", filePath: __filename
34
34
  function updateResource(api, resource) {
35
35
  return (0, identity_1.withAccess)((call) => __awaiter(this, void 0, void 0, function* () {
36
36
  const { request } = call;
37
- const accessKeyId = (0, identity_1.getAccessKeyIdFromCall)(call);
38
- logger.verbose(`call to update${resource}`, { request });
39
- return yield api[`update${resource}`](Object.assign(Object.assign({}, request), {
40
- // FIXME: We should not have to pass the accessKeyId here. Fix upstream!
41
- extended: {
42
- accessKeyId
43
- } }));
37
+ logger.verbose(`call to update${resource}`, Object.assign({}, request));
38
+ return yield api[`update${resource}`](request);
44
39
  }), (ref) => api[`get${resource}`](ref));
45
40
  }
@@ -11,19 +11,19 @@ declare function buildService(clientOptions: ClientOptions): {
11
11
  request: import("@fonoster/types").CreateTrunkRequestExtended;
12
12
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").TrunkExtended) => void) => Promise<void>;
13
13
  updateTrunk: (call: {
14
- request: import("@fonoster/types").UpdateTrunkRequest;
14
+ request: import("@fonoster/types/dist/utils").Flatten<import("@fonoster/types").BaseApiObject & Partial<import("@fonoster/types").CreateTrunkRequest>>;
15
15
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").TrunkExtended) => void) => Promise<void>;
16
16
  getTrunk: (call: {
17
- request: import("@fonoster/types").GetTrunkRequest;
17
+ request: import("@fonoster/types").BaseApiObject;
18
18
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").TrunkExtended) => void) => Promise<void>;
19
19
  listTrunks: (call: {
20
- request: import("@fonoster/types").ListTrunksRequest;
20
+ request: import("@fonoster/types").ListRequest;
21
21
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
22
22
  nextPageToken?: string;
23
23
  items: import("@fonoster/types").TrunkExtended[];
24
24
  }) => void) => Promise<void>;
25
25
  deleteTrunk: (call: {
26
- request: import("@fonoster/types").DeleteTrunkRequest;
26
+ request: import("@fonoster/types").BaseApiObject;
27
27
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: import("@fonoster/types").TrunkExtended) => void) => Promise<void>;
28
28
  };
29
29
  };
@@ -1,20 +1,20 @@
1
- import { CreateTrunkRequestExtended, DeleteTrunkRequest, GetTrunkRequest, ListTrunksRequest, TrunkApi, TrunkExtended, UpdateTrunkRequest } from "@fonoster/types";
1
+ import { BaseApiObject, CreateTrunkRequestExtended, TrunkApi, TrunkExtended } from "@fonoster/types";
2
2
  declare function createTrunk(trunks: TrunkApi): (call: {
3
3
  request: CreateTrunkRequestExtended;
4
4
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: TrunkExtended) => void) => Promise<void>;
5
5
  declare function updateTrunk(trunks: TrunkApi): (call: {
6
- request: UpdateTrunkRequest;
6
+ request: import("@fonoster/types/dist/utils").Flatten<BaseApiObject & Partial<import("@fonoster/types").CreateTrunkRequest>>;
7
7
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: TrunkExtended) => void) => Promise<void>;
8
8
  declare function getTrunk(trunks: TrunkApi): (call: {
9
- request: GetTrunkRequest;
9
+ request: BaseApiObject;
10
10
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: TrunkExtended) => void) => Promise<void>;
11
11
  declare function listTrunks(trunks: TrunkApi): (call: {
12
- request: ListTrunksRequest;
12
+ request: import("@fonoster/types").ListRequest;
13
13
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: {
14
14
  nextPageToken?: string;
15
15
  items: TrunkExtended[];
16
16
  }) => void) => Promise<void>;
17
17
  declare function deleteTrunk(trunks: TrunkApi): (call: {
18
- request: DeleteTrunkRequest;
18
+ request: BaseApiObject;
19
19
  }, callback: (error?: import("@fonoster/common").GrpcErrorMessage, response?: TrunkExtended) => void) => Promise<void>;
20
20
  export { createTrunk, updateTrunk, getTrunk, listTrunks, deleteTrunk };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fonoster/sipnet",
3
- "version": "0.6.2-alpha.0",
3
+ "version": "0.6.6",
4
4
  "description": "Routr-based SIP stack",
5
5
  "author": "Pedro Sanders <psanders@fonoster.com>",
6
6
  "homepage": "https://github.com/fonoster/fonoster#readme",
@@ -20,12 +20,12 @@
20
20
  "fonoster": "./dist/index.js"
21
21
  },
22
22
  "dependencies": {
23
- "@fonoster/common": "^0.6.2-alpha.0",
24
- "@fonoster/identity": "^0.6.2-alpha.0",
25
- "@fonoster/logger": "^0.6.1",
26
- "@fonoster/types": "^0.6.2-alpha.0",
23
+ "@fonoster/common": "^0.6.6",
24
+ "@fonoster/identity": "^0.6.6",
25
+ "@fonoster/logger": "^0.6.2",
26
+ "@fonoster/types": "^0.6.6",
27
27
  "@grpc/grpc-js": "~1.10.6",
28
- "@routr/sdk": "2.12.0",
28
+ "@routr/sdk": "2.13.1",
29
29
  "zod": "^3.23.8"
30
30
  },
31
31
  "files": [
@@ -41,5 +41,5 @@
41
41
  "bugs": {
42
42
  "url": "https://github.com/fonoster/fonoster/issues"
43
43
  },
44
- "gitHead": "16ee05408eb3680afbf5ad2d313e889e89e3ef6d"
44
+ "gitHead": "258137711c4897a4bda49de369db1722da17ec3f"
45
45
  }