@learncard/network-plugin 2.10.2 → 2.10.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.
@@ -13641,6 +13641,7 @@ var SentCredentialInfoValidator = external_exports.object({
13641
13641
  });
13642
13642
  var BoostPermissionsValidator = external_exports.object({
13643
13643
  role: external_exports.string(),
13644
+ canView: external_exports.boolean().default(true),
13644
13645
  canEdit: external_exports.boolean(),
13645
13646
  canIssue: external_exports.boolean(),
13646
13647
  canRevoke: external_exports.boolean(),
@@ -13655,6 +13656,7 @@ var BoostPermissionsValidator = external_exports.object({
13655
13656
  });
13656
13657
  var BoostPermissionsQueryValidator = external_exports.object({
13657
13658
  role: StringQuery,
13659
+ canView: external_exports.boolean(),
13658
13660
  canEdit: external_exports.boolean(),
13659
13661
  canIssue: external_exports.boolean(),
13660
13662
  canRevoke: external_exports.boolean(),
@@ -13780,7 +13782,13 @@ var AutoBoostConfigValidator = external_exports.object({
13780
13782
  var SendBoostTemplateValidator = BoostValidator.partial().omit({ uri: true, claimPermissions: true }).extend({
13781
13783
  credential: VCValidator.or(UnsignedVCValidator),
13782
13784
  claimPermissions: BoostPermissionsValidator.partial().optional(),
13783
- skills: external_exports.array(external_exports.object({ frameworkId: external_exports.string(), id: external_exports.string() })).min(1).optional()
13785
+ skills: external_exports.array(
13786
+ external_exports.object({
13787
+ frameworkId: external_exports.string(),
13788
+ id: external_exports.string(),
13789
+ proficiencyLevel: external_exports.number().optional()
13790
+ })
13791
+ ).min(1).optional()
13784
13792
  });
13785
13793
  var SendBrandingOptionsValidator = external_exports.object({
13786
13794
  issuerName: external_exports.string().optional().describe("Name of the issuing organization"),
@@ -15207,6 +15215,18 @@ async function getLearnCardNetworkPlugin(learnCard, url2, apiToken) {
15207
15215
  if (!userData) throw new Error("Please make an account first!");
15208
15216
  return userData;
15209
15217
  }, "ensureUser");
15218
+ const getBoostTemplateForIssuance = /* @__PURE__ */ __name(async (_learnCard, boostUri) => {
15219
+ try {
15220
+ const boostRecord = await client.boost.getBoost.query({ uri: boostUri });
15221
+ return boostRecord.boost;
15222
+ } catch (error46) {
15223
+ learnCard?.debug?.(
15224
+ "LCN: getBoost failed for template retrieval, falling back to resolveFromLCN",
15225
+ error46
15226
+ );
15227
+ return _learnCard.invoke.resolveFromLCN(boostUri);
15228
+ }
15229
+ }, "getBoostTemplateForIssuance");
15210
15230
  return {
15211
15231
  name: "LearnCard Network",
15212
15232
  displayName: "LearnCard Network",
@@ -15558,6 +15578,10 @@ async function getLearnCardNetworkPlugin(learnCard, url2, apiToken) {
15558
15578
  await ensureUser();
15559
15579
  return client.boost.getBoost.query({ uri });
15560
15580
  }, "getBoost"),
15581
+ getBoostSkills: /* @__PURE__ */ __name(async (_learnCard, uri) => {
15582
+ await ensureUser();
15583
+ return client.boost.getBoostSkills.query({ uri });
15584
+ }, "getBoostSkills"),
15561
15585
  getBoostFrameworks: /* @__PURE__ */ __name(async (_learnCard, uri, options = {}) => {
15562
15586
  if (!userData) throw new Error("Please make an account first!");
15563
15587
  const { limit, cursor, query } = options ?? {};
@@ -15697,10 +15721,13 @@ async function getLearnCardNetworkPlugin(learnCard, url2, apiToken) {
15697
15721
  }, "getBoostChildrenProfileManagers"),
15698
15722
  updateBoost: /* @__PURE__ */ __name(async (_learnCard, uri, updates, credential) => {
15699
15723
  await ensureUser();
15700
- return client.boost.updateBoost.mutate({
15724
+ const { skills, ...restUpdates } = updates ?? {};
15725
+ const payload = {
15701
15726
  uri,
15702
- updates: { ...credential && { credential }, ...updates }
15703
- });
15727
+ updates: { ...credential && { credential }, ...restUpdates }
15728
+ };
15729
+ if (Array.isArray(skills) && skills.length > 0) payload.skills = skills;
15730
+ return client.boost.updateBoost.mutate(payload);
15704
15731
  }, "updateBoost"),
15705
15732
  attachFrameworkToBoost: /* @__PURE__ */ __name(async (_learnCard, boostUri, frameworkId) => {
15706
15733
  if (!userData) throw new Error("Please make an account first!");
@@ -15756,7 +15783,7 @@ async function getLearnCardNetworkPlugin(learnCard, url2, apiToken) {
15756
15783
  }, "deleteBoost"),
15757
15784
  sendBoost: /* @__PURE__ */ __name(async (_learnCard, profileId, boostUri, options = { encrypt: true, skipNotification: false, templateData: {} }) => {
15758
15785
  await ensureUser();
15759
- const result = await _learnCard.invoke.resolveFromLCN(boostUri);
15786
+ const result = await getBoostTemplateForIssuance(_learnCard, boostUri);
15760
15787
  const data = await UnsignedVCValidator.spa(result);
15761
15788
  if (!data.success) throw new Error("Did not get a valid boost from URI");
15762
15789
  const targetProfile = await _learnCard.invoke.getProfile(profileId);
@@ -15864,7 +15891,10 @@ async function getLearnCardNetworkPlugin(learnCard, url2, apiToken) {
15864
15891
  const canIssueLocally = "issueCredential" in _learnCard.invoke;
15865
15892
  const isDirectRecipient = isDid || !isEmail && !isPhone;
15866
15893
  if (canIssueLocally && isDirectRecipient && input.templateUri) {
15867
- const result = await _learnCard.invoke.resolveFromLCN(input.templateUri);
15894
+ const result = await getBoostTemplateForIssuance(
15895
+ _learnCard,
15896
+ input.templateUri
15897
+ );
15868
15898
  const data = await UnsignedVCValidator.spa(result);
15869
15899
  if (data.success) {
15870
15900
  let targetDid;