@forge/util

2.0.12.0.1-experimental-7890858
packages/ari/chunk-R6X5WEVP.mjs
+packages/ari/chunk-R6X5WEVP.mjsNew file
+71
Index: package/packages/ari/chunk-R6X5WEVP.mjs
===================================================================
--- package/packages/ari/chunk-R6X5WEVP.mjs
+++ package/packages/ari/chunk-R6X5WEVP.mjs
@@ -0,0 +1,71 @@
+import {
+  PassionfruitPlanAriResourceOwner,
+  PassionfruitPlanAriResourceType
+} from "./chunk-MHOZU4NJ.mjs";
+import {
+  RegisteredAri
+} from "./chunk-AB4PPISI.mjs";
+import {
+  AriParser
+} from "./chunk-S7RIZVFI.mjs";
+
+// src/passionfruit/plan/manifest.ts
+var passionfruitPlanAriStaticOpts = {
+  qualifier: "ari",
+  platformQualifier: "cloud",
+  cloudId: new RegExp("^[a-zA-Z0-9_\\-.]{1,255}$"),
+  resourceOwner: PassionfruitPlanAriResourceOwner,
+  resourceType: PassionfruitPlanAriResourceType,
+  resourceIdSlug: "workspace/{activationId}/{planId}",
+  resourceIdSegmentFormats: {
+    activationId: /[a-zA-Z0-9\-]+/,
+    // eslint-disable-line no-useless-escape
+    planId: /[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/
+  }
+};
+
+// src/passionfruit/plan/index.ts
+var PassionfruitPlanAri = class _PassionfruitPlanAri extends RegisteredAri {
+  constructor(opts) {
+    super(opts), this._siteId = opts.cloudId || "", this._activationId = opts.resourceIdSegmentValues.activationId, this._planId = opts.resourceIdSegmentValues.planId;
+  }
+  get siteId() {
+    return this._siteId;
+  }
+  get activationId() {
+    return this._activationId;
+  }
+  get planId() {
+    return this._planId;
+  }
+  static create(opts) {
+    let derivedOpts = {
+      qualifier: passionfruitPlanAriStaticOpts.qualifier,
+      platformQualifier: passionfruitPlanAriStaticOpts.platformQualifier,
+      cloudId: opts.siteId,
+      resourceOwner: passionfruitPlanAriStaticOpts.resourceOwner,
+      resourceType: passionfruitPlanAriStaticOpts.resourceType,
+      resourceId: `workspace/${opts.activationId}/${opts.planId}`,
+      resourceIdSegmentValues: {
+        activationId: opts.activationId,
+        planId: opts.planId
+      }
+    }, ariOpts = AriParser.fromOpts(derivedOpts, passionfruitPlanAriStaticOpts);
+    return new _PassionfruitPlanAri(ariOpts);
+  }
+  static parse(maybeAri) {
+    let opts = AriParser.fromString(maybeAri, passionfruitPlanAriStaticOpts);
+    return new _PassionfruitPlanAri(opts);
+  }
+  getVariables() {
+    return {
+      siteId: this.siteId,
+      activationId: this.activationId,
+      planId: this.planId
+    };
+  }
+};
+
+export {
+  PassionfruitPlanAri
+};