@azure-rest/confidential-ledger 1.0.0-alpha.20211130.1 → 1.0.0-alpha.20220131.1

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/dist/index.js CHANGED
@@ -26,7 +26,7 @@ function certificatePolicy(ledgerTlsCertificate, credential) {
26
26
  }
27
27
 
28
28
  // Copyright (c) Microsoft Corporation.
29
- function ConfidentialLedger(ledgerUri, credentials, options = {}) {
29
+ function ConfidentialLedger$1(ledgerUri, credentials, options = {}) {
30
30
  var _a, _b;
31
31
  const baseUrl = (_a = options.baseUrl) !== null && _a !== void 0 ? _a : `${ledgerUri}`;
32
32
  options.apiVersion = (_b = options.apiVersion) !== null && _b !== void 0 ? _b : "0.1-preview";
@@ -37,10 +37,10 @@ function ConfidentialLedger(ledgerUri, credentials, options = {}) {
37
37
  }
38
38
 
39
39
  // Copyright (c) Microsoft Corporation.
40
- function ConfidentialLedger$1(ledgerBaseUrl, ledgerTlsCertificate, credentials, options) {
40
+ function ConfidentialLedger(ledgerBaseUrl, ledgerTlsCertificate, credentials, options) {
41
41
  // If certificate credential is passed, we'll handle auth
42
42
  const creds = coreClient.isCertificateCredential(credentials) ? undefined : credentials;
43
- const confidentialLedger = ConfidentialLedger(ledgerBaseUrl, creds, options);
43
+ const confidentialLedger = ConfidentialLedger$1(ledgerBaseUrl, creds, options);
44
44
  confidentialLedger.pipeline.addPolicy(certificatePolicy(ledgerTlsCertificate, credentials));
45
45
  return confidentialLedger;
46
46
  }
@@ -60,6 +60,6 @@ function isLedgerIdentity(identity) {
60
60
 
61
61
  // Copyright (c) Microsoft Corporation.
62
62
 
63
- exports.default = ConfidentialLedger$1;
63
+ exports["default"] = ConfidentialLedger;
64
64
  exports.getLedgerIdentity = getLedgerIdentity;
65
65
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/certificatePolicy.ts","../src/generated/src/confidentialLedger.ts","../src/confidentialLedger.ts","../src/getLedgerIdentity.ts","../src/index.ts"],"sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport { TokenCredential } from \"@azure/core-auth\";\nimport { PipelinePolicy } from \"@azure/core-rest-pipeline\";\nimport { CertificateCredential, isCertificateCredential } from \"@azure-rest/core-client\";\nimport { Agent } from \"https\";\ninterface AgentOptions {\n /** Custom certificate authority to trust Self-Signed certificate */\n ca: string;\n /** Client certificate for authentication */\n cert?: string;\n /** Client private key for certificate authentication */\n key?: string;\n}\n\nexport function certificatePolicy(\n ledgerTlsCertificate: string,\n credential: TokenCredential | CertificateCredential\n): PipelinePolicy {\n // Create default agent and options if they don't exist\n let agentOptions: AgentOptions = {\n // Add CA to trust Confidential Ledger self signed certificate\n ca: ledgerTlsCertificate,\n };\n\n // Add certificate for authentication if one was provided\n if (isCertificateCredential(credential)) {\n agentOptions = { ...agentOptions, cert: credential.cert, key: credential.certKey };\n }\n\n return {\n name: \"ledgerTlsCertificatePolicy\",\n sendRequest: (request, next) => {\n request.agent = new Agent(agentOptions);\n return next(request);\n },\n };\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport {\n GetConstitutionParameters,\n GetConsortiumMembersParameters,\n GetEnclaveQuotesParameters,\n GetLedgerEntriesParameters,\n PostLedgerEntryParameters,\n GetLedgerEntryParameters,\n GetReceiptParameters,\n GetTransactionStatusParameters,\n GetCurrentLedgerEntryParameters,\n DeleteUserParameters,\n GetUserParameters,\n CreateOrUpdateUserParameters,\n} from \"./parameters\";\nimport {\n GetConstitution200Response,\n GetConstitutiondefaultResponse,\n GetConsortiumMembers200Response,\n GetConsortiumMembersdefaultResponse,\n GetEnclaveQuotes200Response,\n GetEnclaveQuotesdefaultResponse,\n GetLedgerEntries200Response,\n GetLedgerEntriesdefaultResponse,\n PostLedgerEntry200Response,\n PostLedgerEntrydefaultResponse,\n GetLedgerEntry200Response,\n GetLedgerEntrydefaultResponse,\n GetReceipt200Response,\n GetReceiptdefaultResponse,\n GetTransactionStatus200Response,\n GetTransactionStatusdefaultResponse,\n GetCurrentLedgerEntry200Response,\n GetCurrentLedgerEntrydefaultResponse,\n DeleteUser204Response,\n DeleteUserdefaultResponse,\n GetUser200Response,\n GetUserdefaultResponse,\n CreateOrUpdateUser200Response,\n CreateOrUpdateUserdefaultResponse,\n} from \"./responses\";\nimport { getClient, ClientOptions, Client } from \"@azure-rest/core-client\";\nimport { TokenCredential } from \"@azure/core-auth\";\n\nexport interface GetConstitution {\n /** The constitution is a script that assesses and applies proposals from consortium members. */\n get(\n options?: GetConstitutionParameters\n ): Promise<GetConstitution200Response | GetConstitutiondefaultResponse>;\n}\n\nexport interface GetConsortiumMembers {\n /** Consortium members can manage the Confidential Ledger. */\n get(\n options?: GetConsortiumMembersParameters\n ): Promise<GetConsortiumMembers200Response | GetConsortiumMembersdefaultResponse>;\n}\n\nexport interface GetEnclaveQuotes {\n /** A quote is an SGX enclave measurement that can be used to verify the validity of a node and its enclave. */\n get(\n options?: GetEnclaveQuotesParameters\n ): Promise<GetEnclaveQuotes200Response | GetEnclaveQuotesdefaultResponse>;\n}\n\nexport interface PostLedgerEntry {\n /** A sub-ledger id may optionally be specified. Only entries in the specified (or default) sub-ledger will be returned. */\n get(\n options?: GetLedgerEntriesParameters\n ): Promise<GetLedgerEntries200Response | GetLedgerEntriesdefaultResponse>;\n /** A sub-ledger id may optionally be specified. */\n post(\n options?: PostLedgerEntryParameters\n ): Promise<PostLedgerEntry200Response | PostLedgerEntrydefaultResponse>;\n}\n\nexport interface GetLedgerEntry {\n /** To return older ledger entries, the relevant sections of the ledger must be read from disk and validated. To prevent blocking within the enclave, the response will indicate whether the entry is ready and part of the response, or if the loading is still ongoing. */\n get(\n options?: GetLedgerEntryParameters\n ): Promise<GetLedgerEntry200Response | GetLedgerEntrydefaultResponse>;\n}\n\nexport interface GetReceipt {\n /** Gets a receipt certifying ledger contents at a particular transaction id. */\n get(options?: GetReceiptParameters): Promise<GetReceipt200Response | GetReceiptdefaultResponse>;\n}\n\nexport interface GetTransactionStatus {\n /** Gets the status of an entry identified by a transaction id. */\n get(\n options?: GetTransactionStatusParameters\n ): Promise<GetTransactionStatus200Response | GetTransactionStatusdefaultResponse>;\n}\n\nexport interface GetCurrentLedgerEntry {\n /** A sub-ledger id may optionally be specified. */\n get(\n options?: GetCurrentLedgerEntryParameters\n ): Promise<GetCurrentLedgerEntry200Response | GetCurrentLedgerEntrydefaultResponse>;\n}\n\nexport interface CreateOrUpdateUser {\n /** Deletes a user from the Confidential Ledger. */\n delete(\n options?: DeleteUserParameters\n ): Promise<DeleteUser204Response | DeleteUserdefaultResponse>;\n /** Gets a user. */\n get(options?: GetUserParameters): Promise<GetUser200Response | GetUserdefaultResponse>;\n /** A JSON merge patch is applied for existing users */\n patch(\n options: CreateOrUpdateUserParameters\n ): Promise<CreateOrUpdateUser200Response | CreateOrUpdateUserdefaultResponse>;\n}\n\nexport interface Routes {\n /** Resource for '/app/governance/constitution' has methods for the following verbs: get */\n (path: \"/app/governance/constitution\"): GetConstitution;\n /** Resource for '/app/governance/members' has methods for the following verbs: get */\n (path: \"/app/governance/members\"): GetConsortiumMembers;\n /** Resource for '/app/enclaveQuotes' has methods for the following verbs: get */\n (path: \"/app/enclaveQuotes\"): GetEnclaveQuotes;\n /** Resource for '/app/transactions' has methods for the following verbs: get, post */\n (path: \"/app/transactions\"): PostLedgerEntry;\n /** Resource for '/app/transactions/\\{transactionId\\}' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}\", transactionId: string): GetLedgerEntry;\n /** Resource for '/app/transactions/\\{transactionId\\}/receipt' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}/receipt\", transactionId: string): GetReceipt;\n /** Resource for '/app/transactions/\\{transactionId\\}/status' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}/status\", transactionId: string): GetTransactionStatus;\n /** Resource for '/app/transactions/current' has methods for the following verbs: get */\n (path: \"/app/transactions/current\"): GetCurrentLedgerEntry;\n /** Resource for '/app/users/\\{userId\\}' has methods for the following verbs: delete, get, patch */\n (path: \"/app/users/{userId}\", userId: string): CreateOrUpdateUser;\n}\n\nexport type ConfidentialLedgerRestClient = Client & {\n path: Routes;\n};\n\nexport default function ConfidentialLedger(\n ledgerUri: string,\n credentials?: TokenCredential,\n options: ClientOptions = {}\n): ConfidentialLedgerRestClient {\n const baseUrl = options.baseUrl ?? `${ledgerUri}`;\n options.apiVersion = options.apiVersion ?? \"0.1-preview\";\n options = {\n ...options,\n credentials: {\n scopes: [\"https://confidential-ledger.azure.com/.default\"],\n },\n };\n\n return getClient(baseUrl, credentials, options) as ConfidentialLedgerRestClient;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport {\n ClientOptions,\n CertificateCredential,\n isCertificateCredential,\n} from \"@azure-rest/core-client\";\nimport { TokenCredential } from \"@azure/core-auth\";\n\nimport { certificatePolicy } from \"./certificatePolicy\";\nimport GeneratedConfidentialLedger, {\n ConfidentialLedgerRestClient,\n} from \"./generated/src/confidentialLedger\";\n\nexport default function ConfidentialLedger(\n ledgerBaseUrl: string,\n ledgerTlsCertificate: string,\n credentials: TokenCredential | CertificateCredential,\n options?: ClientOptions\n): ConfidentialLedgerRestClient {\n // If certificate credential is passed, we'll handle auth\n const creds = isCertificateCredential(credentials) ? undefined : credentials;\n\n const confidentialLedger = GeneratedConfidentialLedger(ledgerBaseUrl, creds, options);\n\n confidentialLedger.pipeline.addPolicy(certificatePolicy(ledgerTlsCertificate, credentials));\n\n return confidentialLedger;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport { getClient } from \"@azure-rest/core-client\";\n\nexport interface LedgerIdentity {\n ledgerTlsCertificate: string;\n ledgerId: string;\n}\n\nexport async function getLedgerIdentity(\n ledgerId: string,\n identityServiceBaseUrl: string = \"https://identity.accledger.azure.com\"\n): Promise<LedgerIdentity> {\n const client = getClient(identityServiceBaseUrl);\n\n const cert = await client.pathUnchecked(\"/ledgerIdentity/{ledgerId}\", ledgerId).get();\n\n if (!isLedgerIdentity(cert.body)) {\n throw new Error(\n \"Body received from Confidential Ledger Identity is invalid. It must contain ledgerId and ledgerTlsCertificate\"\n );\n }\n\n return cert.body;\n}\n\nfunction isLedgerIdentity(identity: any): identity is LedgerIdentity {\n return identity.ledgerTlsCertificate && identity.ledgerId;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport ConfidentialLedger from \"./confidentialLedger\";\nexport * from \"./generated/src/confidentialLedger\";\nexport * from \"./generated/src/models\";\nexport * from \"./generated/src/parameters\";\nexport * from \"./generated/src/responses\";\nexport { LedgerIdentity, getLedgerIdentity } from \"./getLedgerIdentity\";\nexport default ConfidentialLedger;\n"],"names":["isCertificateCredential","Agent","getClient","ConfidentialLedger","GeneratedConfidentialLedger"],"mappings":";;;;;;;AAAA;SAgBgB,iBAAiB,CAC/B,oBAA4B,EAC5B,UAAmD;;IAGnD,IAAI,YAAY,GAAiB;;QAE/B,EAAE,EAAE,oBAAoB;KACzB,CAAC;;IAGF,IAAIA,kCAAuB,CAAC,UAAU,CAAC,EAAE;QACvC,YAAY,mCAAQ,YAAY,KAAE,IAAI,EAAE,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,GAAE,CAAC;KACpF;IAED,OAAO;QACL,IAAI,EAAE,4BAA4B;QAClC,WAAW,EAAE,CAAC,OAAO,EAAE,IAAI;YACzB,OAAO,CAAC,KAAK,GAAG,IAAIC,WAAK,CAAC,YAAY,CAAC,CAAC;YACxC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC;SACtB;KACF,CAAC;AACJ;;ACtCA;AACA,SA6IwB,kBAAkB,CACxC,SAAiB,EACjB,WAA6B,EAC7B,UAAyB,EAAE;;IAE3B,MAAM,OAAO,GAAG,MAAA,OAAO,CAAC,OAAO,mCAAI,GAAG,SAAS,EAAE,CAAC;IAClD,OAAO,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,aAAa,CAAC;IACzD,OAAO,mCACF,OAAO,KACV,WAAW,EAAE;YACX,MAAM,EAAE,CAAC,gDAAgD,CAAC;SAC3D,GACF,CAAC;IAEF,OAAOC,oBAAS,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAiC,CAAC;AAClF,CAAC;;AC7JD;AACA,SAcwBC,oBAAkB,CACxC,aAAqB,EACrB,oBAA4B,EAC5B,WAAoD,EACpD,OAAuB;;IAGvB,MAAM,KAAK,GAAGH,kCAAuB,CAAC,WAAW,CAAC,GAAG,SAAS,GAAG,WAAW,CAAC;IAE7E,MAAM,kBAAkB,GAAGI,kBAA2B,CAAC,aAAa,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAEtF,kBAAkB,CAAC,QAAQ,CAAC,SAAS,CAAC,iBAAiB,CAAC,oBAAoB,EAAE,WAAW,CAAC,CAAC,CAAC;IAE5F,OAAO,kBAAkB,CAAC;AAC5B,CAAC;;AC7BD;AACA,AASO,eAAe,iBAAiB,CACrC,QAAgB,EAChB,yBAAiC,sCAAsC;IAEvE,MAAM,MAAM,GAAGF,oBAAS,CAAC,sBAAsB,CAAC,CAAC;IAEjD,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,4BAA4B,EAAE,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;IAEtF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;QAChC,MAAM,IAAI,KAAK,CACb,+GAA+G,CAChH,CAAC;KACH;IAED,OAAO,IAAI,CAAC,IAAI,CAAC;AACnB,CAAC;AAED,SAAS,gBAAgB,CAAC,QAAa;IACrC,OAAO,QAAQ,CAAC,oBAAoB,IAAI,QAAQ,CAAC,QAAQ,CAAC;AAC5D,CAAC;;AC7BD,uCAAuC;;;;;"}
1
+ {"version":3,"file":"index.js","sources":["../src/certificatePolicy.ts","../src/generated/src/confidentialLedger.ts","../src/confidentialLedger.ts","../src/getLedgerIdentity.ts","../src/index.ts"],"sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport { TokenCredential } from \"@azure/core-auth\";\nimport { PipelinePolicy } from \"@azure/core-rest-pipeline\";\nimport { CertificateCredential, isCertificateCredential } from \"@azure-rest/core-client\";\nimport { Agent } from \"https\";\ninterface AgentOptions {\n /** Custom certificate authority to trust Self-Signed certificate */\n ca: string;\n /** Client certificate for authentication */\n cert?: string;\n /** Client private key for certificate authentication */\n key?: string;\n}\n\nexport function certificatePolicy(\n ledgerTlsCertificate: string,\n credential: TokenCredential | CertificateCredential\n): PipelinePolicy {\n // Create default agent and options if they don't exist\n let agentOptions: AgentOptions = {\n // Add CA to trust Confidential Ledger self signed certificate\n ca: ledgerTlsCertificate,\n };\n\n // Add certificate for authentication if one was provided\n if (isCertificateCredential(credential)) {\n agentOptions = { ...agentOptions, cert: credential.cert, key: credential.certKey };\n }\n\n return {\n name: \"ledgerTlsCertificatePolicy\",\n sendRequest: (request, next) => {\n request.agent = new Agent(agentOptions);\n return next(request);\n },\n };\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport {\n GetConstitutionParameters,\n GetConsortiumMembersParameters,\n GetEnclaveQuotesParameters,\n GetLedgerEntriesParameters,\n PostLedgerEntryParameters,\n GetLedgerEntryParameters,\n GetReceiptParameters,\n GetTransactionStatusParameters,\n GetCurrentLedgerEntryParameters,\n DeleteUserParameters,\n GetUserParameters,\n CreateOrUpdateUserParameters,\n} from \"./parameters\";\nimport {\n GetConstitution200Response,\n GetConstitutiondefaultResponse,\n GetConsortiumMembers200Response,\n GetConsortiumMembersdefaultResponse,\n GetEnclaveQuotes200Response,\n GetEnclaveQuotesdefaultResponse,\n GetLedgerEntries200Response,\n GetLedgerEntriesdefaultResponse,\n PostLedgerEntry200Response,\n PostLedgerEntrydefaultResponse,\n GetLedgerEntry200Response,\n GetLedgerEntrydefaultResponse,\n GetReceipt200Response,\n GetReceiptdefaultResponse,\n GetTransactionStatus200Response,\n GetTransactionStatusdefaultResponse,\n GetCurrentLedgerEntry200Response,\n GetCurrentLedgerEntrydefaultResponse,\n DeleteUser204Response,\n DeleteUserdefaultResponse,\n GetUser200Response,\n GetUserdefaultResponse,\n CreateOrUpdateUser200Response,\n CreateOrUpdateUserdefaultResponse,\n} from \"./responses\";\nimport { getClient, ClientOptions, Client } from \"@azure-rest/core-client\";\nimport { TokenCredential } from \"@azure/core-auth\";\n\nexport interface GetConstitution {\n /** The constitution is a script that assesses and applies proposals from consortium members. */\n get(\n options?: GetConstitutionParameters\n ): Promise<GetConstitution200Response | GetConstitutiondefaultResponse>;\n}\n\nexport interface GetConsortiumMembers {\n /** Consortium members can manage the Confidential Ledger. */\n get(\n options?: GetConsortiumMembersParameters\n ): Promise<GetConsortiumMembers200Response | GetConsortiumMembersdefaultResponse>;\n}\n\nexport interface GetEnclaveQuotes {\n /** A quote is an SGX enclave measurement that can be used to verify the validity of a node and its enclave. */\n get(\n options?: GetEnclaveQuotesParameters\n ): Promise<GetEnclaveQuotes200Response | GetEnclaveQuotesdefaultResponse>;\n}\n\nexport interface PostLedgerEntry {\n /** A sub-ledger id may optionally be specified. Only entries in the specified (or default) sub-ledger will be returned. */\n get(\n options?: GetLedgerEntriesParameters\n ): Promise<GetLedgerEntries200Response | GetLedgerEntriesdefaultResponse>;\n /** A sub-ledger id may optionally be specified. */\n post(\n options?: PostLedgerEntryParameters\n ): Promise<PostLedgerEntry200Response | PostLedgerEntrydefaultResponse>;\n}\n\nexport interface GetLedgerEntry {\n /** To return older ledger entries, the relevant sections of the ledger must be read from disk and validated. To prevent blocking within the enclave, the response will indicate whether the entry is ready and part of the response, or if the loading is still ongoing. */\n get(\n options?: GetLedgerEntryParameters\n ): Promise<GetLedgerEntry200Response | GetLedgerEntrydefaultResponse>;\n}\n\nexport interface GetReceipt {\n /** Gets a receipt certifying ledger contents at a particular transaction id. */\n get(options?: GetReceiptParameters): Promise<GetReceipt200Response | GetReceiptdefaultResponse>;\n}\n\nexport interface GetTransactionStatus {\n /** Gets the status of an entry identified by a transaction id. */\n get(\n options?: GetTransactionStatusParameters\n ): Promise<GetTransactionStatus200Response | GetTransactionStatusdefaultResponse>;\n}\n\nexport interface GetCurrentLedgerEntry {\n /** A sub-ledger id may optionally be specified. */\n get(\n options?: GetCurrentLedgerEntryParameters\n ): Promise<GetCurrentLedgerEntry200Response | GetCurrentLedgerEntrydefaultResponse>;\n}\n\nexport interface CreateOrUpdateUser {\n /** Deletes a user from the Confidential Ledger. */\n delete(\n options?: DeleteUserParameters\n ): Promise<DeleteUser204Response | DeleteUserdefaultResponse>;\n /** Gets a user. */\n get(options?: GetUserParameters): Promise<GetUser200Response | GetUserdefaultResponse>;\n /** A JSON merge patch is applied for existing users */\n patch(\n options: CreateOrUpdateUserParameters\n ): Promise<CreateOrUpdateUser200Response | CreateOrUpdateUserdefaultResponse>;\n}\n\nexport interface Routes {\n /** Resource for '/app/governance/constitution' has methods for the following verbs: get */\n (path: \"/app/governance/constitution\"): GetConstitution;\n /** Resource for '/app/governance/members' has methods for the following verbs: get */\n (path: \"/app/governance/members\"): GetConsortiumMembers;\n /** Resource for '/app/enclaveQuotes' has methods for the following verbs: get */\n (path: \"/app/enclaveQuotes\"): GetEnclaveQuotes;\n /** Resource for '/app/transactions' has methods for the following verbs: get, post */\n (path: \"/app/transactions\"): PostLedgerEntry;\n /** Resource for '/app/transactions/\\{transactionId\\}' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}\", transactionId: string): GetLedgerEntry;\n /** Resource for '/app/transactions/\\{transactionId\\}/receipt' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}/receipt\", transactionId: string): GetReceipt;\n /** Resource for '/app/transactions/\\{transactionId\\}/status' has methods for the following verbs: get */\n (path: \"/app/transactions/{transactionId}/status\", transactionId: string): GetTransactionStatus;\n /** Resource for '/app/transactions/current' has methods for the following verbs: get */\n (path: \"/app/transactions/current\"): GetCurrentLedgerEntry;\n /** Resource for '/app/users/\\{userId\\}' has methods for the following verbs: delete, get, patch */\n (path: \"/app/users/{userId}\", userId: string): CreateOrUpdateUser;\n}\n\nexport type ConfidentialLedgerRestClient = Client & {\n path: Routes;\n};\n\nexport default function ConfidentialLedger(\n ledgerUri: string,\n credentials?: TokenCredential,\n options: ClientOptions = {}\n): ConfidentialLedgerRestClient {\n const baseUrl = options.baseUrl ?? `${ledgerUri}`;\n options.apiVersion = options.apiVersion ?? \"0.1-preview\";\n options = {\n ...options,\n credentials: {\n scopes: [\"https://confidential-ledger.azure.com/.default\"],\n },\n };\n\n return getClient(baseUrl, credentials, options) as ConfidentialLedgerRestClient;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport {\n ClientOptions,\n CertificateCredential,\n isCertificateCredential,\n} from \"@azure-rest/core-client\";\nimport { TokenCredential } from \"@azure/core-auth\";\n\nimport { certificatePolicy } from \"./certificatePolicy\";\nimport GeneratedConfidentialLedger, {\n ConfidentialLedgerRestClient,\n} from \"./generated/src/confidentialLedger\";\n\nexport default function ConfidentialLedger(\n ledgerBaseUrl: string,\n ledgerTlsCertificate: string,\n credentials: TokenCredential | CertificateCredential,\n options?: ClientOptions\n): ConfidentialLedgerRestClient {\n // If certificate credential is passed, we'll handle auth\n const creds = isCertificateCredential(credentials) ? undefined : credentials;\n\n const confidentialLedger = GeneratedConfidentialLedger(ledgerBaseUrl, creds, options);\n\n confidentialLedger.pipeline.addPolicy(certificatePolicy(ledgerTlsCertificate, credentials));\n\n return confidentialLedger;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport { getClient } from \"@azure-rest/core-client\";\n\nexport interface LedgerIdentity {\n ledgerTlsCertificate: string;\n ledgerId: string;\n}\n\nexport async function getLedgerIdentity(\n ledgerId: string,\n identityServiceBaseUrl: string = \"https://identity.accledger.azure.com\"\n): Promise<LedgerIdentity> {\n const client = getClient(identityServiceBaseUrl);\n\n const cert = await client.pathUnchecked(\"/ledgerIdentity/{ledgerId}\", ledgerId).get();\n\n if (!isLedgerIdentity(cert.body)) {\n throw new Error(\n \"Body received from Confidential Ledger Identity is invalid. It must contain ledgerId and ledgerTlsCertificate\"\n );\n }\n\n return cert.body;\n}\n\nfunction isLedgerIdentity(identity: any): identity is LedgerIdentity {\n return identity.ledgerTlsCertificate && identity.ledgerId;\n}\n","// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT license.\n\nimport ConfidentialLedger from \"./confidentialLedger\";\nexport * from \"./generated/src/confidentialLedger\";\nexport * from \"./generated/src/models\";\nexport * from \"./generated/src/parameters\";\nexport * from \"./generated/src/responses\";\nexport { LedgerIdentity, getLedgerIdentity } from \"./getLedgerIdentity\";\nexport default ConfidentialLedger;\n"],"names":["isCertificateCredential","Agent","ConfidentialLedger","getClient","GeneratedConfidentialLedger"],"mappings":";;;;;;;AAAA;SAgBgB,iBAAiB,CAC/B,oBAA4B,EAC5B,UAAmD;;IAGnD,IAAI,YAAY,GAAiB;;QAE/B,EAAE,EAAE,oBAAoB;KACzB,CAAC;;IAGF,IAAIA,kCAAuB,CAAC,UAAU,CAAC,EAAE;QACvC,YAAY,mCAAQ,YAAY,KAAE,IAAI,EAAE,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC,OAAO,GAAE,CAAC;KACpF;IAED,OAAO;QACL,IAAI,EAAE,4BAA4B;QAClC,WAAW,EAAE,CAAC,OAAO,EAAE,IAAI;YACzB,OAAO,CAAC,KAAK,GAAG,IAAIC,WAAK,CAAC,YAAY,CAAC,CAAC;YACxC,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC;SACtB;KACF,CAAC;AACJ;;ACtCA;SA8IwBC,oBAAkB,CACxC,SAAiB,EACjB,WAA6B,EAC7B,UAAyB,EAAE;;IAE3B,MAAM,OAAO,GAAG,MAAA,OAAO,CAAC,OAAO,mCAAI,GAAG,SAAS,EAAE,CAAC;IAClD,OAAO,CAAC,UAAU,GAAG,MAAA,OAAO,CAAC,UAAU,mCAAI,aAAa,CAAC;IACzD,OAAO,mCACF,OAAO,KACV,WAAW,EAAE;YACX,MAAM,EAAE,CAAC,gDAAgD,CAAC;SAC3D,GACF,CAAC;IAEF,OAAOC,oBAAS,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAiC,CAAC;AAClF;;AC7JA;SAewB,kBAAkB,CACxC,aAAqB,EACrB,oBAA4B,EAC5B,WAAoD,EACpD,OAAuB;;IAGvB,MAAM,KAAK,GAAGH,kCAAuB,CAAC,WAAW,CAAC,GAAG,SAAS,GAAG,WAAW,CAAC;IAE7E,MAAM,kBAAkB,GAAGI,oBAA2B,CAAC,aAAa,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAEtF,kBAAkB,CAAC,QAAQ,CAAC,SAAS,CAAC,iBAAiB,CAAC,oBAAoB,EAAE,WAAW,CAAC,CAAC,CAAC;IAE5F,OAAO,kBAAkB,CAAC;AAC5B;;AC7BA;AAUO,eAAe,iBAAiB,CACrC,QAAgB,EAChB,yBAAiC,sCAAsC;IAEvE,MAAM,MAAM,GAAGD,oBAAS,CAAC,sBAAsB,CAAC,CAAC;IAEjD,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,4BAA4B,EAAE,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC;IAEtF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;QAChC,MAAM,IAAI,KAAK,CACb,+GAA+G,CAChH,CAAC;KACH;IAED,OAAO,IAAI,CAAC,IAAI,CAAC;AACnB,CAAC;AAED,SAAS,gBAAgB,CAAC,QAAa;IACrC,OAAO,QAAQ,CAAC,oBAAoB,IAAI,QAAQ,CAAC,QAAQ,CAAC;AAC5D;;AC7BA;;;;;"}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "sdk-type": "client",
4
4
  "author": "Microsoft Corporation",
5
5
  "description": "An isomorphic rest level client library for the Azure Confidential Ledger service.",
6
- "version": "1.0.0-alpha.20211130.1",
6
+ "version": "1.0.0-alpha.20220131.1",
7
7
  "keywords": [
8
8
  "node",
9
9
  "azure",
@@ -54,12 +54,12 @@
54
54
  },
55
55
  "scripts": {
56
56
  "audit": "node ../../../common/scripts/rush-audit.js && rimraf node_modules package-lock.json && npm i --package-lock-only 2>&1 && npm audit",
57
- "build:browser": "tsc -p . && cross-env ONLY_BROWSER=true rollup -c 2>&1",
58
- "build:node": "tsc -p . && cross-env ONLY_NODE=true rollup -c 2>&1",
57
+ "build:browser": "tsc -p . && dev-tool run bundle",
58
+ "build:node": "tsc -p . && dev-tool run bundle",
59
59
  "build:samples": "echo Obsolete.",
60
- "build:test": "tsc -p . && rollup -c 2>&1",
61
- "build": "npm run clean && tsc -p . && rollup -c 2>&1 && api-extractor run --local",
62
- "build:debug": "tsc -p . && rollup -c 2>&1 && api-extractor run --local",
60
+ "build:test": "tsc -p . && dev-tool run bundle",
61
+ "build": "npm run clean && tsc -p . && dev-tool run bundle && api-extractor run --local",
62
+ "build:debug": "tsc -p . && dev-tool run bundle && api-extractor run --local",
63
63
  "check-format": "prettier --list-different --config ../../../.prettierrc.json --ignore-path ../../../.prettierignore \"src/**/*.ts\" \"test/**/*.ts\" \"samples-dev/**/*.ts\" \"*.{js,json}\"",
64
64
  "clean": "rimraf dist dist-browser dist-esm test-dist temp types *.tgz *.log",
65
65
  "execute:samples": "dev-tool samples run samples-dev",
@@ -77,8 +77,7 @@
77
77
  "test": "npm run clean && npm run build:test && npm run unit-test",
78
78
  "unit-test:browser": "echo skip",
79
79
  "unit-test:node": "mocha -r esm --require ts-node/register --reporter ../../../common/tools/mocha-multi-reporter.js --timeout 1200000 --full-trace \"test/{,!(browser)/**/}*.spec.ts\"",
80
- "unit-test": "npm run unit-test:node && npm run unit-test:browser",
81
- "docs": "typedoc --excludePrivate --excludeExternals --out ./dist/docs ./src"
80
+ "unit-test": "npm run unit-test:node && npm run unit-test:browser"
82
81
  },
83
82
  "sideEffects": false,
84
83
  "autoPublish": false,
@@ -116,14 +115,12 @@
116
115
  "karma-source-map-support": "~1.4.0",
117
116
  "karma-sourcemap-loader": "^0.3.8",
118
117
  "karma": "^6.2.0",
119
- "mocha-junit-reporter": "^1.18.0",
118
+ "mocha-junit-reporter": "^2.0.0",
120
119
  "mocha": "^7.1.1",
121
- "nyc": "^14.0.0",
122
- "prettier": "2.2.1",
120
+ "nyc": "^15.0.0",
121
+ "prettier": "^2.5.1",
123
122
  "rimraf": "^3.0.0",
124
- "rollup": "^1.16.3",
125
123
  "source-map-support": "^0.5.9",
126
- "typedoc": "0.15.2",
127
124
  "typescript": "~4.2.0"
128
125
  }
129
126
  }