@liflig/cdk-vy 2.0.0 → 2.2.0
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.
|
@@ -48,7 +48,14 @@ async function deleteAppClient(baseUrl, name) {
|
|
|
48
48
|
path: `/app-clients/${encodedName}`,
|
|
49
49
|
});
|
|
50
50
|
if (response.statusCode !== 200) {
|
|
51
|
-
|
|
51
|
+
const message = `Could not delete resource: ${response.statusCode} - ${response.body}`;
|
|
52
|
+
if (response.statusCode === 404) {
|
|
53
|
+
// Allow soft fail to avoid ROLLBACK_FAILED status
|
|
54
|
+
console.warn(message);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error(message);
|
|
58
|
+
}
|
|
52
59
|
}
|
|
53
60
|
}
|
|
54
61
|
export async function handler(event) {
|
|
@@ -111,4 +118,4 @@ export async function handler(event) {
|
|
|
111
118
|
return createFailureResponse(event.PhysicalResourceId || props.Name || "unknown", handleError(error));
|
|
112
119
|
}
|
|
113
120
|
}
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/cognito-app-client/handler.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,WAAW,GACZ,MAAM,mCAAmC,CAAA;AAC1C,OAAO,EAAE,wBAAwB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAA;AAQhF,MAAM,mBAAmB,GACvB,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,kBAAkB,CAAA;AAYvD,KAAK,UAAU,eAAe,CAC5B,OAAe,EACf,MAAiB;IAEjB,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC;QACnC,MAAM,EAAE,MAAM;QACd,QAAQ,EAAE,OAAO;QACjB,IAAI,EAAE,cAAc;QACpB,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;KAC7B,CAAC,CAAA;IAEF,IAAI,QAAQ,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CACb,8BAA8B,QAAQ,CAAC,UAAU,MAAM,QAAQ,CAAC,IAAI,EAAE,CACvE,CAAA;IACH,CAAC;IAED,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;AAClC,CAAC;AAED,KAAK,UAAU,aAAa,CAC1B,OAAe,EACf,IAAY;IAEZ,MAAM,WAAW,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC;QACnC,MAAM,EAAE,KAAK;QACb,QAAQ,EAAE,OAAO;QACjB,IAAI,EAAE,gBAAgB,WAAW,EAAE;KACpC,CAAC,CAAA;IAEF,IAAI,QAAQ,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CACb,4BAA4B,QAAQ,CAAC,UAAU,MAAM,QAAQ,CAAC,IAAI,EAAE,CACrE,CAAA;IACH,CAAC;IAED,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;AAClC,CAAC;AAED,KAAK,UAAU,eAAe,CAC5B,OAAe,EACf,MAA8B;IAE9B,MAAM,WAAW,GAAG,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACnD,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC;QACnC,MAAM,EAAE,KAAK;QACb,QAAQ,EAAE,OAAO;QACjB,IAAI,EAAE,gBAAgB,WAAW,EAAE;QACnC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;KAC7B,CAAC,CAAA;IAEF,IAAI,QAAQ,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CACb,8BAA8B,QAAQ,CAAC,UAAU,MAAM,QAAQ,CAAC,IAAI,EAAE,CACvE,CAAA;IACH,CAAC;AACH,CAAC;AAED,KAAK,UAAU,eAAe,CAAC,OAAe,EAAE,IAAY;IAC1D,MAAM,WAAW,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,QAAQ,GAAG,MAAM,aAAa,CAAC;QACnC,MAAM,EAAE,QAAQ;QAChB,QAAQ,EAAE,OAAO;QACjB,IAAI,EAAE,gBAAgB,WAAW,EAAE;KACpC,CAAC,CAAA;IAEF,IAAI,QAAQ,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;QAChC,MAAM,IAAI,KAAK,CACb,8BAA8B,QAAQ,CAAC,UAAU,MAAM,QAAQ,CAAC,IAAI,EAAE,CACvE,CAAA;IACH,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,KAA4B;IAE5B,MAAM,KAAK,GAAG,KAAK,CAAC,kBAAyC,CAAA;IAC7D,MAAM,OAAO,GAAG,wBAAwB,CACtC,mBAAmB,EACnB,WAAW,EACX,KAAK,CAAC,WAAW,CAClB,CAAA;IAED,IAAI,CAAC;QACH,QAAQ,KAAK,CAAC,WAAW,EAAE,CAAC;YAC1B,KAAK,QAAQ,CAAC,CAAC,CAAC;gBACd,sEAAsE;gBACtE,wFAAwF;gBACxF,MAAM,eAAe,GACnB,OAAO,KAAK,CAAC,cAAc,KAAK,SAAS;oBACvC,CAAC,CAAC,KAAK,CAAC,cAAc;oBACtB,CAAC,CAAC,KAAK,CAAC,cAAc,KAAK,MAAM,CAAA;gBAErC,MAAM,MAAM,GAAc;oBACxB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,EAAE;oBAC1B,aAAa,EAAE,KAAK,CAAC,YAAY,IAAI,EAAE;oBACvC,WAAW,EAAE,KAAK,CAAC,UAAU,IAAI,EAAE;oBACnC,eAAe;iBAChB,CAAA;gBAED,MAAM,OAAO,GAAG,MAAM,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;gBAEtD,OAAO,qBAAqB,CAAC,KAAK,CAAC,kBAAkB,IAAI,OAAO,CAAC,IAAI,EAAE;oBACrE,IAAI,EAAE,OAAO,CAAC,IAAI;oBAClB,QAAQ,EAAE,OAAO,CAAC,SAAS,IAAI,EAAE;oBACjC,YAAY,EAAE,OAAO,CAAC,aAAa,IAAI,EAAE;oBACzC,IAAI,EAAE,OAAO,CAAC,IAAI;iBACnB,CAA2B,CAAA;YAC9B,CAAC;YAED,KAAK,QAAQ,CAAC,CAAC,CAAC;gBACd,+CAA+C;gBAC/C,MAAM,QAAQ,GAAG,KAAK,CAAC,qBAA4C,CAAA;gBACnE,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,EAAE,CAAC;oBAC7C,MAAM,IAAI,KAAK,CACb,oEAAoE,CACrE,CAAA;gBACH,CAAC;gBAED,MAAM,MAAM,GAA2B;oBACrC,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,EAAE;oBAC1B,aAAa,EAAE,KAAK,CAAC,YAAY,IAAI,EAAE;oBACvC,WAAW,EAAE,KAAK,CAAC,UAAU,IAAI,EAAE;iBACpC,CAAA;gBAED,MAAM,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;gBACtC,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;gBAExD,OAAO,qBAAqB,CAAC,KAAK,CAAC,kBAAkB,IAAI,OAAO,CAAC,IAAI,EAAE;oBACrE,IAAI,EAAE,OAAO,CAAC,IAAI;oBAClB,QAAQ,EAAE,OAAO,CAAC,SAAS,IAAI,EAAE;oBACjC,YAAY,EAAE,OAAO,CAAC,aAAa,IAAI,EAAE;oBACzC,IAAI,EAAE,OAAO,CAAC,IAAI;iBACnB,CAA2B,CAAA;YAC9B,CAAC;YAED,KAAK,QAAQ,CAAC,CAAC,CAAC;gBACd,MAAM,IAAI,GAAG,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,IAAI,CAAA;gBACnD,MAAM,eAAe,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;gBAEpC,OAAO,qBAAqB,CAAC,IAAI,EAAE,EAAE,CAA2B,CAAA;YAClE,CAAC;QACH,CAAC;IACH,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAA;QAC9B,OAAO,qBAAqB,CAC1B,KAAK,CAAC,kBAAkB,IAAI,KAAK,CAAC,IAAI,IAAI,SAAS,EACnD,WAAW,CAAC,KAAK,CAAC,CACO,CAAA;IAC7B,CAAC;AACH,CAAC","sourcesContent":["/**\n * Lambda handler for CognitoAppClient custom resource\n */\n\nimport {\n  createFailureResponse,\n  createSuccessResponse,\n  handleError,\n} from \"../shared/custom-resource-handler\"\nimport { createUrlFromEnvironment, signedRequest } from \"../shared/sigv4-client\"\nimport type {\n  AppClient,\n  AppClientUpdateRequest,\n  CustomResourceRequest,\n  CustomResourceResponse,\n} from \"../shared/types\"\n\nconst COGNITO_BASE_DOMAIN =\n  process.env.COGNITO_BASE_DOMAIN || \"cognito.vydev.io\"\n\ninterface AppClientProperties {\n  Environment: string\n  Name: string\n  Type: \"frontend\" | \"backend\"\n  Scopes?: string[]\n  CallbackUrls?: string[]\n  LogoutUrls?: string[]\n  GenerateSecret?: boolean\n}\n\nasync function createAppClient(\n  baseUrl: string,\n  client: AppClient,\n): Promise<AppClient> {\n  const response = await signedRequest({\n    method: \"POST\",\n    hostname: baseUrl,\n    path: \"/app-clients\",\n    body: JSON.stringify(client),\n  })\n\n  if (response.statusCode !== 201) {\n    throw new Error(\n      `Could not create resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function readAppClient(\n  baseUrl: string,\n  name: string,\n): Promise<AppClient> {\n  const encodedName = encodeURIComponent(name)\n  const response = await signedRequest({\n    method: \"GET\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not read resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function updateAppClient(\n  baseUrl: string,\n  update: AppClientUpdateRequest,\n): Promise<void> {\n  const encodedName = encodeURIComponent(update.name)\n  const response = await signedRequest({\n    method: \"PUT\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n    body: JSON.stringify(update),\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not update resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nasync function deleteAppClient(baseUrl: string, name: string): Promise<void> {\n  const encodedName = encodeURIComponent(name)\n  const response = await signedRequest({\n    method: \"DELETE\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not delete resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nexport async function handler(\n  event: CustomResourceRequest,\n): Promise<CustomResourceResponse> {\n  const props = event.ResourceProperties as AppClientProperties\n  const baseUrl = createUrlFromEnvironment(\n    COGNITO_BASE_DOMAIN,\n    \"delegated\",\n    props.Environment,\n  )\n\n  try {\n    switch (event.RequestType) {\n      case \"Create\": {\n        // We receive a string value for GenerateSecret, but we need a boolean\n        // See https://github.com/aws-cloudformation/cloudformation-coverage-roadmap/issues/1037\n        const generate_secret: boolean =\n          typeof props.GenerateSecret === \"boolean\"\n            ? props.GenerateSecret\n            : props.GenerateSecret === \"true\"\n\n        const client: AppClient = {\n          name: props.Name,\n          type: props.Type,\n          scopes: props.Scopes || [],\n          callback_urls: props.CallbackUrls || [],\n          logout_urls: props.LogoutUrls || [],\n          generate_secret,\n        }\n\n        const created = await createAppClient(baseUrl, client)\n\n        return createSuccessResponse(event.PhysicalResourceId ?? created.name, {\n          Name: created.name,\n          ClientId: created.client_id || \"\",\n          ClientSecret: created.client_secret || \"\",\n          Type: created.type,\n        }) as CustomResourceResponse\n      }\n\n      case \"Update\": {\n        // Check if Type changed (requires replacement)\n        const oldProps = event.OldResourceProperties as AppClientProperties\n        if (oldProps && oldProps.Type !== props.Type) {\n          throw new Error(\n            \"Cannot change app client type. This requires resource replacement.\",\n          )\n        }\n\n        const update: AppClientUpdateRequest = {\n          name: props.Name,\n          scopes: props.Scopes || [],\n          callback_urls: props.CallbackUrls || [],\n          logout_urls: props.LogoutUrls || [],\n        }\n\n        await updateAppClient(baseUrl, update)\n        const updated = await readAppClient(baseUrl, props.Name)\n\n        return createSuccessResponse(event.PhysicalResourceId ?? updated.name, {\n          Name: updated.name,\n          ClientId: updated.client_id || \"\",\n          ClientSecret: updated.client_secret || \"\",\n          Type: updated.type,\n        }) as CustomResourceResponse\n      }\n\n      case \"Delete\": {\n        const name = event.PhysicalResourceId || props.Name\n        await deleteAppClient(baseUrl, name)\n\n        return createSuccessResponse(name, {}) as CustomResourceResponse\n      }\n    }\n  } catch (error) {\n    console.error(\"Error:\", error)\n    return createFailureResponse(\n      event.PhysicalResourceId || props.Name || \"unknown\",\n      handleError(error),\n    ) as CustomResourceResponse\n  }\n}\n"]}
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/cognito-app-client/handler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Lambda handler for CognitoAppClient custom resource\n */\n\nimport {\n  createFailureResponse,\n  createSuccessResponse,\n  handleError,\n} from \"../shared/custom-resource-handler\"\nimport { createUrlFromEnvironment, signedRequest } from \"../shared/sigv4-client\"\nimport type {\n  AppClient,\n  AppClientUpdateRequest,\n  CustomResourceRequest,\n  CustomResourceResponse,\n} from \"../shared/types\"\n\nconst COGNITO_BASE_DOMAIN =\n  process.env.COGNITO_BASE_DOMAIN || \"cognito.vydev.io\"\n\ninterface AppClientProperties {\n  Environment: string\n  Name: string\n  Type: \"frontend\" | \"backend\"\n  Scopes?: string[]\n  CallbackUrls?: string[]\n  LogoutUrls?: string[]\n  GenerateSecret?: boolean\n}\n\nasync function createAppClient(\n  baseUrl: string,\n  client: AppClient,\n): Promise<AppClient> {\n  const response = await signedRequest({\n    method: \"POST\",\n    hostname: baseUrl,\n    path: \"/app-clients\",\n    body: JSON.stringify(client),\n  })\n\n  if (response.statusCode !== 201) {\n    throw new Error(\n      `Could not create resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function readAppClient(\n  baseUrl: string,\n  name: string,\n): Promise<AppClient> {\n  const encodedName = encodeURIComponent(name)\n  const response = await signedRequest({\n    method: \"GET\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not read resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function updateAppClient(\n  baseUrl: string,\n  update: AppClientUpdateRequest,\n): Promise<void> {\n  const encodedName = encodeURIComponent(update.name)\n  const response = await signedRequest({\n    method: \"PUT\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n    body: JSON.stringify(update),\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not update resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nasync function deleteAppClient(baseUrl: string, name: string): Promise<void> {\n  const encodedName = encodeURIComponent(name)\n  const response = await signedRequest({\n    method: \"DELETE\",\n    hostname: baseUrl,\n    path: `/app-clients/${encodedName}`,\n  })\n\n  if (response.statusCode !== 200) {\n    const message = `Could not delete resource: ${response.statusCode} - ${response.body}`\n\n    if (response.statusCode === 404) {\n      // Allow soft fail to avoid ROLLBACK_FAILED status\n      console.warn(message)\n    } else {\n      throw new Error(message)\n    }\n  }\n}\n\nexport async function handler(\n  event: CustomResourceRequest,\n): Promise<CustomResourceResponse> {\n  const props = event.ResourceProperties as AppClientProperties\n  const baseUrl = createUrlFromEnvironment(\n    COGNITO_BASE_DOMAIN,\n    \"delegated\",\n    props.Environment,\n  )\n\n  try {\n    switch (event.RequestType) {\n      case \"Create\": {\n        // We receive a string value for GenerateSecret, but we need a boolean\n        // See https://github.com/aws-cloudformation/cloudformation-coverage-roadmap/issues/1037\n        const generate_secret: boolean =\n          typeof props.GenerateSecret === \"boolean\"\n            ? props.GenerateSecret\n            : props.GenerateSecret === \"true\"\n\n        const client: AppClient = {\n          name: props.Name,\n          type: props.Type,\n          scopes: props.Scopes || [],\n          callback_urls: props.CallbackUrls || [],\n          logout_urls: props.LogoutUrls || [],\n          generate_secret,\n        }\n\n        const created = await createAppClient(baseUrl, client)\n\n        return createSuccessResponse(event.PhysicalResourceId ?? created.name, {\n          Name: created.name,\n          ClientId: created.client_id || \"\",\n          ClientSecret: created.client_secret || \"\",\n          Type: created.type,\n        }) as CustomResourceResponse\n      }\n\n      case \"Update\": {\n        // Check if Type changed (requires replacement)\n        const oldProps = event.OldResourceProperties as AppClientProperties\n        if (oldProps && oldProps.Type !== props.Type) {\n          throw new Error(\n            \"Cannot change app client type. This requires resource replacement.\",\n          )\n        }\n\n        const update: AppClientUpdateRequest = {\n          name: props.Name,\n          scopes: props.Scopes || [],\n          callback_urls: props.CallbackUrls || [],\n          logout_urls: props.LogoutUrls || [],\n        }\n\n        await updateAppClient(baseUrl, update)\n        const updated = await readAppClient(baseUrl, props.Name)\n\n        return createSuccessResponse(event.PhysicalResourceId ?? updated.name, {\n          Name: updated.name,\n          ClientId: updated.client_id || \"\",\n          ClientSecret: updated.client_secret || \"\",\n          Type: updated.type,\n        }) as CustomResourceResponse\n      }\n\n      case \"Delete\": {\n        const name = event.PhysicalResourceId || props.Name\n        await deleteAppClient(baseUrl, name)\n\n        return createSuccessResponse(name, {}) as CustomResourceResponse\n      }\n    }\n  } catch (error) {\n    console.error(\"Error:\", error)\n    return createFailureResponse(\n      event.PhysicalResourceId || props.Name || \"unknown\",\n      handleError(error),\n    ) as CustomResourceResponse\n  }\n}\n"]}
|
|
@@ -48,7 +48,14 @@ async function deleteResourceServer(baseUrl, identifier) {
|
|
|
48
48
|
path: `/resource-servers/${encodedIdentifier}`,
|
|
49
49
|
});
|
|
50
50
|
if (response.statusCode !== 200) {
|
|
51
|
-
|
|
51
|
+
const message = `Could not delete resource: ${response.statusCode} - ${response.body}`;
|
|
52
|
+
if (response.statusCode === 404) {
|
|
53
|
+
// Allow soft fail to avoid ROLLBACK_FAILED status
|
|
54
|
+
console.warn(message);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error(message);
|
|
58
|
+
}
|
|
52
59
|
}
|
|
53
60
|
}
|
|
54
61
|
export async function handler(event) {
|
|
@@ -101,4 +108,4 @@ export async function handler(event) {
|
|
|
101
108
|
return createFailureResponse(event.PhysicalResourceId || props.Identifier || "unknown", handleError(error));
|
|
102
109
|
}
|
|
103
110
|
}
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/cognito-resource-server/handler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Lambda handler for CognitoResourceServer custom resource\n */\n\nimport {\n  createFailureResponse,\n  createSuccessResponse,\n  handleError,\n} from \"../shared/custom-resource-handler\"\nimport { createUrlFromEnvironment, signedRequest } from \"../shared/sigv4-client\"\nimport type {\n  CustomResourceRequest,\n  CustomResourceResponse,\n  ResourceServer,\n  ResourceServerUpdateRequest,\n} from \"../shared/types\"\n\nconst COGNITO_BASE_DOMAIN =\n  process.env.COGNITO_BASE_DOMAIN || \"cognito.vydev.io\"\n\ninterface ResourceServerProperties {\n  Environment: string\n  Name: string\n  Identifier: string\n  Scopes?: Array<{ Name: string; Description: string }>\n}\n\nasync function createResourceServer(\n  baseUrl: string,\n  server: ResourceServer,\n): Promise<ResourceServer> {\n  const response = await signedRequest({\n    method: \"POST\",\n    hostname: baseUrl,\n    path: \"/resource-servers\",\n    body: JSON.stringify(server),\n  })\n\n  if (response.statusCode !== 201) {\n    throw new Error(\n      `Could not create resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function readResourceServer(\n  baseUrl: string,\n  identifier: string,\n): Promise<ResourceServer> {\n  const encodedIdentifier = encodeURIComponent(identifier)\n  const response = await signedRequest({\n    method: \"GET\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not read resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function updateResourceServer(\n  baseUrl: string,\n  update: ResourceServerUpdateRequest,\n): Promise<void> {\n  const encodedIdentifier = encodeURIComponent(update.identifier)\n  const response = await signedRequest({\n    method: \"PUT\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n    body: JSON.stringify(update),\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not update resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nasync function deleteResourceServer(\n  baseUrl: string,\n  identifier: string,\n): Promise<void> {\n  const encodedIdentifier = encodeURIComponent(identifier)\n  const response = await signedRequest({\n    method: \"DELETE\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not delete resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nexport async function handler(\n  event: CustomResourceRequest,\n): Promise<CustomResourceResponse> {\n  const props = event.ResourceProperties as ResourceServerProperties\n  const baseUrl = createUrlFromEnvironment(\n    COGNITO_BASE_DOMAIN,\n    \"delegated\",\n    props.Environment,\n  )\n\n  try {\n    switch (event.RequestType) {\n      case \"Create\": {\n        const server: ResourceServer = {\n          identifier: props.Identifier,\n          name: props.Name,\n          scopes: props.Scopes?.map((s) => ({\n            name: s.Name,\n            description: s.Description,\n          })),\n        }\n\n        const created = await createResourceServer(baseUrl, server)\n\n        return createSuccessResponse(\n          event.PhysicalResourceId ?? created.identifier,\n          {\n            Identifier: created.identifier,\n            Name: created.name,\n            Scopes: created.scopes,\n          },\n        ) as CustomResourceResponse\n      }\n\n      case \"Update\": {\n        const update: ResourceServerUpdateRequest = {\n          identifier: props.Identifier,\n          name: props.Name,\n          scopes: props.Scopes?.map((s) => ({\n            name: s.Name,\n            description: s.Description,\n          })),\n        }\n\n        await updateResourceServer(baseUrl, update)\n        const updated = await readResourceServer(baseUrl, props.Identifier)\n\n        return createSuccessResponse(\n          event.PhysicalResourceId ?? updated.identifier,\n          {\n            Identifier: updated.identifier,\n            Name: updated.name,\n            Scopes: updated.scopes,\n          },\n        ) as CustomResourceResponse\n      }\n\n      case \"Delete\": {\n        const identifier = event.PhysicalResourceId || props.Identifier\n        await deleteResourceServer(baseUrl, identifier)\n\n        return createSuccessResponse(identifier, {}) as CustomResourceResponse\n      }\n    }\n  } catch (error) {\n    console.error(\"Error:\", error)\n    return createFailureResponse(\n      event.PhysicalResourceId || props.Identifier || \"unknown\",\n      handleError(error),\n    ) as CustomResourceResponse\n  }\n}\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handler.js","sourceRoot":"","sources":["../../src/cognito-resource-server/handler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Lambda handler for CognitoResourceServer custom resource\n */\n\nimport {\n  createFailureResponse,\n  createSuccessResponse,\n  handleError,\n} from \"../shared/custom-resource-handler\"\nimport { createUrlFromEnvironment, signedRequest } from \"../shared/sigv4-client\"\nimport type {\n  CustomResourceRequest,\n  CustomResourceResponse,\n  ResourceServer,\n  ResourceServerUpdateRequest,\n} from \"../shared/types\"\n\nconst COGNITO_BASE_DOMAIN =\n  process.env.COGNITO_BASE_DOMAIN || \"cognito.vydev.io\"\n\ninterface ResourceServerProperties {\n  Environment: string\n  Name: string\n  Identifier: string\n  Scopes?: Array<{ Name: string; Description: string }>\n}\n\nasync function createResourceServer(\n  baseUrl: string,\n  server: ResourceServer,\n): Promise<ResourceServer> {\n  const response = await signedRequest({\n    method: \"POST\",\n    hostname: baseUrl,\n    path: \"/resource-servers\",\n    body: JSON.stringify(server),\n  })\n\n  if (response.statusCode !== 201) {\n    throw new Error(\n      `Could not create resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function readResourceServer(\n  baseUrl: string,\n  identifier: string,\n): Promise<ResourceServer> {\n  const encodedIdentifier = encodeURIComponent(identifier)\n  const response = await signedRequest({\n    method: \"GET\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not read resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n\n  return JSON.parse(response.body)\n}\n\nasync function updateResourceServer(\n  baseUrl: string,\n  update: ResourceServerUpdateRequest,\n): Promise<void> {\n  const encodedIdentifier = encodeURIComponent(update.identifier)\n  const response = await signedRequest({\n    method: \"PUT\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n    body: JSON.stringify(update),\n  })\n\n  if (response.statusCode !== 200) {\n    throw new Error(\n      `Could not update resource: ${response.statusCode} - ${response.body}`,\n    )\n  }\n}\n\nasync function deleteResourceServer(\n  baseUrl: string,\n  identifier: string,\n): Promise<void> {\n  const encodedIdentifier = encodeURIComponent(identifier)\n  const response = await signedRequest({\n    method: \"DELETE\",\n    hostname: baseUrl,\n    path: `/resource-servers/${encodedIdentifier}`,\n  })\n\n  if (response.statusCode !== 200) {\n    const message = `Could not delete resource: ${response.statusCode} - ${response.body}`\n\n    if (response.statusCode === 404) {\n      // Allow soft fail to avoid ROLLBACK_FAILED status\n      console.warn(message)\n    } else {\n      throw new Error(message)\n    }\n  }\n}\n\nexport async function handler(\n  event: CustomResourceRequest,\n): Promise<CustomResourceResponse> {\n  const props = event.ResourceProperties as ResourceServerProperties\n  const baseUrl = createUrlFromEnvironment(\n    COGNITO_BASE_DOMAIN,\n    \"delegated\",\n    props.Environment,\n  )\n\n  try {\n    switch (event.RequestType) {\n      case \"Create\": {\n        const server: ResourceServer = {\n          identifier: props.Identifier,\n          name: props.Name,\n          scopes: props.Scopes?.map((s) => ({\n            name: s.Name,\n            description: s.Description,\n          })),\n        }\n\n        const created = await createResourceServer(baseUrl, server)\n\n        return createSuccessResponse(\n          event.PhysicalResourceId ?? created.identifier,\n          {\n            Identifier: created.identifier,\n            Name: created.name,\n            Scopes: created.scopes,\n          },\n        ) as CustomResourceResponse\n      }\n\n      case \"Update\": {\n        const update: ResourceServerUpdateRequest = {\n          identifier: props.Identifier,\n          name: props.Name,\n          scopes: props.Scopes?.map((s) => ({\n            name: s.Name,\n            description: s.Description,\n          })),\n        }\n\n        await updateResourceServer(baseUrl, update)\n        const updated = await readResourceServer(baseUrl, props.Identifier)\n\n        return createSuccessResponse(\n          event.PhysicalResourceId ?? updated.identifier,\n          {\n            Identifier: updated.identifier,\n            Name: updated.name,\n            Scopes: updated.scopes,\n          },\n        ) as CustomResourceResponse\n      }\n\n      case \"Delete\": {\n        const identifier = event.PhysicalResourceId || props.Identifier\n        await deleteResourceServer(baseUrl, identifier)\n\n        return createSuccessResponse(identifier, {}) as CustomResourceResponse\n      }\n    }\n  } catch (error) {\n    console.error(\"Error:\", error)\n    return createFailureResponse(\n      event.PhysicalResourceId || props.Identifier || \"unknown\",\n      handleError(error),\n    ) as CustomResourceResponse\n  }\n}\n"]}
|
package/lib/shared/types.d.ts
CHANGED
package/lib/shared/types.js
CHANGED
|
@@ -19,4 +19,4 @@ export var VyEnvironment;
|
|
|
19
19
|
*/
|
|
20
20
|
VyEnvironment["PROD"] = "prod";
|
|
21
21
|
})(VyEnvironment || (VyEnvironment = {}));
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2hhcmVkL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUg7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBWSxhQWVYO0FBZkQsV0FBWSxhQUFhO0lBQ3ZCOztPQUVHO0lBQ0gsOEJBQWEsQ0FBQTtJQUViOztPQUVHO0lBQ0gsZ0NBQWUsQ0FBQTtJQUVmOztPQUVHO0lBQ0gsOEJBQWEsQ0FBQTtBQUNmLENBQUMsRUFmVyxhQUFhLEtBQWIsYUFBYSxRQWV4QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU2hhcmVkIHR5cGUgZGVmaW5pdGlvbnMgZm9yIFZ5IGN1c3RvbSByZXNvdXJjZXNcbiAqL1xuXG4vKipcbiAqIFRoZSBkaWZmZXJlbnQgVnkgZW52aXJvbm1lbnRzXG4gKi9cbmV4cG9ydCBlbnVtIFZ5RW52aXJvbm1lbnQge1xuICAvKipcbiAgICogRGV2ZWxvcG1lbnQgZW52aXJvbm1lbnRcbiAgICovXG4gIFRFU1QgPSBcInRlc3RcIixcblxuICAvKipcbiAgICogUHJvZHVjdGlvbi1saWtlIGVudmlyb25tZW50XG4gICAqL1xuICBTVEFHRSA9IFwic3RhZ2VcIixcblxuICAvKipcbiAgICogUHJvZHVjdGlvbiBlbnZpcm9ubWVudFxuICAgKi9cbiAgUFJPRCA9IFwicHJvZFwiLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjb3BlIHtcbiAgbmFtZTogc3RyaW5nXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZXNvdXJjZVNlcnZlciB7XG4gIGlkZW50aWZpZXI6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2NvcGVzPzogU2NvcGVbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlc291cmNlU2VydmVyVXBkYXRlUmVxdWVzdCB7XG4gIGlkZW50aWZpZXI6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2NvcGVzPzogU2NvcGVbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFwcENsaWVudCB7XG4gIG5hbWU6IHN0cmluZ1xuICBzY29wZXM6IHN0cmluZ1tdXG4gIHR5cGU6IFwiZnJvbnRlbmRcIiB8IFwiYmFja2VuZFwiXG4gIGNhbGxiYWNrX3VybHM6IHN0cmluZ1tdXG4gIGxvZ291dF91cmxzOiBzdHJpbmdbXVxuICBnZW5lcmF0ZV9zZWNyZXQ/
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2hhcmVkL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUg7O0dBRUc7QUFDSCxNQUFNLENBQU4sSUFBWSxhQWVYO0FBZkQsV0FBWSxhQUFhO0lBQ3ZCOztPQUVHO0lBQ0gsOEJBQWEsQ0FBQTtJQUViOztPQUVHO0lBQ0gsZ0NBQWUsQ0FBQTtJQUVmOztPQUVHO0lBQ0gsOEJBQWEsQ0FBQTtBQUNmLENBQUMsRUFmVyxhQUFhLEtBQWIsYUFBYSxRQWV4QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogU2hhcmVkIHR5cGUgZGVmaW5pdGlvbnMgZm9yIFZ5IGN1c3RvbSByZXNvdXJjZXNcbiAqL1xuXG4vKipcbiAqIFRoZSBkaWZmZXJlbnQgVnkgZW52aXJvbm1lbnRzXG4gKi9cbmV4cG9ydCBlbnVtIFZ5RW52aXJvbm1lbnQge1xuICAvKipcbiAgICogRGV2ZWxvcG1lbnQgZW52aXJvbm1lbnRcbiAgICovXG4gIFRFU1QgPSBcInRlc3RcIixcblxuICAvKipcbiAgICogUHJvZHVjdGlvbi1saWtlIGVudmlyb25tZW50XG4gICAqL1xuICBTVEFHRSA9IFwic3RhZ2VcIixcblxuICAvKipcbiAgICogUHJvZHVjdGlvbiBlbnZpcm9ubWVudFxuICAgKi9cbiAgUFJPRCA9IFwicHJvZFwiLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjb3BlIHtcbiAgbmFtZTogc3RyaW5nXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZXNvdXJjZVNlcnZlciB7XG4gIGlkZW50aWZpZXI6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2NvcGVzPzogU2NvcGVbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlc291cmNlU2VydmVyVXBkYXRlUmVxdWVzdCB7XG4gIGlkZW50aWZpZXI6IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2NvcGVzPzogU2NvcGVbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFwcENsaWVudCB7XG4gIG5hbWU6IHN0cmluZ1xuICBzY29wZXM6IHN0cmluZ1tdXG4gIHR5cGU6IFwiZnJvbnRlbmRcIiB8IFwiYmFja2VuZFwiXG4gIGNhbGxiYWNrX3VybHM6IHN0cmluZ1tdXG4gIGxvZ291dF91cmxzOiBzdHJpbmdbXVxuICBnZW5lcmF0ZV9zZWNyZXQ/OiBib29sZWFuXG4gIGNsaWVudF9pZD86IHN0cmluZ1xuICBjbGllbnRfc2VjcmV0Pzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXBwQ2xpZW50VXBkYXRlUmVxdWVzdCB7XG4gIG5hbWU6IHN0cmluZ1xuICBzY29wZXM6IHN0cmluZ1tdXG4gIGNhbGxiYWNrX3VybHM6IHN0cmluZ1tdXG4gIGxvZ291dF91cmxzOiBzdHJpbmdbXVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlcGxveW1lbnRBY2NvdW50IHtcbiAgYWNjb3VudElkOiBzdHJpbmdcbiAgc2xhY2tDaGFubmVsOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnZpcm9ubWVudEFjY291bnQge1xuICBhY2NvdW50SWQ6IHN0cmluZ1xuICBvd25lckFjY291bnRJZDogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXJ0aWZhY3RWZXJzaW9uIHtcbiAgdXJpOiBzdHJpbmdcbiAgc3RvcmU6IHN0cmluZ1xuICBwYXRoOiBzdHJpbmdcbiAgdmVyc2lvbjogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29nbml0b0RldGFpbHMge1xuICAvKipcbiAgICogVGhlIFVSTCB3aGVyZSB1c2VycyBjYW4gYXV0aGVudGljYXRlXG4gICAqL1xuICBhdXRoVXJsOiBzdHJpbmdcblxuICAvKipcbiAgICogVGhlIFVSTCBmb3IgdGhlIC8ud2VsbC1rbm93bi9qd2tzLmpzb24gZW5kcG9pbnRcbiAgICovXG4gIGp3a3NVcmw6IHN0cmluZ1xuXG4gIC8qKlxuICAgKiBUaGUgVVJMIGZvciB0aGUgLy53ZWxsLWtub3duL29wZW5pZC1jb25maWd1cmF0aW9uIGVuZHBvaW50XG4gICAqL1xuICBvcGVuSWRVcmw6IHN0cmluZ1xuXG4gIC8qKlxuICAgKiBUaGUgVVJJIGZvciB0aGUgaXNzdWVyXG4gICAqL1xuICBpc3N1ZXI6IHN0cmluZ1xuXG4gIC8qKlxuICAgKiBUaGUgVnkgQ29nbml0byBVc2VycG9vbCBJZFxuICAgKi9cbiAgdXNlclBvb2xJZDogc3RyaW5nXG59XG5cbi8qKlxuICogQ3VzdG9tIFJlc291cmNlIGV2ZW50IHR5cGVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tUmVzb3VyY2VSZXF1ZXN0IHtcbiAgUmVxdWVzdFR5cGU6IFwiQ3JlYXRlXCIgfCBcIlVwZGF0ZVwiIHwgXCJEZWxldGVcIlxuICBSZXF1ZXN0SWQ6IHN0cmluZ1xuICBSZXNwb25zZVVSTDogc3RyaW5nXG4gIFJlc291cmNlVHlwZTogc3RyaW5nXG4gIExvZ2ljYWxSZXNvdXJjZUlkOiBzdHJpbmdcbiAgU3RhY2tJZDogc3RyaW5nXG4gIFBoeXNpY2FsUmVzb3VyY2VJZD86IHN0cmluZ1xuICBSZXNvdXJjZVByb3BlcnRpZXM6IFJlY29yZDxzdHJpbmcsIGFueT5cbiAgT2xkUmVzb3VyY2VQcm9wZXJ0aWVzPzogUmVjb3JkPHN0cmluZywgYW55PlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEN1c3RvbVJlc291cmNlUmVzcG9uc2Uge1xuICBTdGF0dXM6IFwiU1VDQ0VTU1wiIHwgXCJGQUlMRURcIlxuICBSZWFzb24/OiBzdHJpbmdcbiAgUGh5c2ljYWxSZXNvdXJjZUlkOiBzdHJpbmdcbiAgU3RhY2tJZDogc3RyaW5nXG4gIFJlcXVlc3RJZDogc3RyaW5nXG4gIExvZ2ljYWxSZXNvdXJjZUlkOiBzdHJpbmdcbiAgRGF0YT86IFJlY29yZDxzdHJpbmcsIGFueT5cbn1cbiJdfQ==
|
|
@@ -32,5 +32,5 @@ export declare class VyCognitoProvider extends Construct {
|
|
|
32
32
|
readonly appClientProvider: AppClientProvider;
|
|
33
33
|
readonly resourceServerProvider: ResourceServerProvider;
|
|
34
34
|
constructor(scope: Construct, id: string, props: VyCognitoProviderProps);
|
|
35
|
-
getCognitoDetailsForEnvironment(environment: VyEnvironment): CognitoDetails;
|
|
36
35
|
}
|
|
36
|
+
export declare function getCognitoDetailsForEnvironment(environment: VyEnvironment): CognitoDetails;
|
|
@@ -21,7 +21,7 @@ export class VyCognitoProvider extends Construct {
|
|
|
21
21
|
super(scope, id);
|
|
22
22
|
this.environment = props.environment;
|
|
23
23
|
this.cognitoBaseDomain = props.cognitoBaseDomain ?? "cognito.vydev.io";
|
|
24
|
-
this.details =
|
|
24
|
+
this.details = getCognitoDetailsForEnvironment(this.environment);
|
|
25
25
|
const appClientProvider = new LambdaProvider(this, "AppClientProvider", {
|
|
26
26
|
cognitoBaseDomain: this.cognitoBaseDomain,
|
|
27
27
|
runtime: lambda.Runtime.NODEJS_22_X,
|
|
@@ -46,13 +46,6 @@ export class VyCognitoProvider extends Construct {
|
|
|
46
46
|
serviceToken: resourceServerProvider.serviceToken,
|
|
47
47
|
};
|
|
48
48
|
}
|
|
49
|
-
getCognitoDetailsForEnvironment(environment) {
|
|
50
|
-
const config = envConfigs[environment];
|
|
51
|
-
if (!config) {
|
|
52
|
-
throw new Error(`Unknown environment: ${environment}. Valid values are: prod, stage, test`);
|
|
53
|
-
}
|
|
54
|
-
return config;
|
|
55
|
-
}
|
|
56
49
|
}
|
|
57
50
|
class LambdaProvider extends Construct {
|
|
58
51
|
/**
|
|
@@ -104,6 +97,13 @@ class LambdaProvider extends Construct {
|
|
|
104
97
|
this.serviceToken = provider.serviceToken;
|
|
105
98
|
}
|
|
106
99
|
}
|
|
100
|
+
export function getCognitoDetailsForEnvironment(environment) {
|
|
101
|
+
const config = envConfigs[environment];
|
|
102
|
+
if (!config) {
|
|
103
|
+
throw new Error(`Unknown environment: ${environment}. Valid values are: prod, stage, test`);
|
|
104
|
+
}
|
|
105
|
+
return config;
|
|
106
|
+
}
|
|
107
107
|
// Static config for each environment
|
|
108
108
|
const envConfigs = {
|
|
109
109
|
prod: {
|
|
@@ -111,18 +111,21 @@ const envConfigs = {
|
|
|
111
111
|
jwksUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/jwks.json",
|
|
112
112
|
openIdUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/openid-configuration",
|
|
113
113
|
issuer: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE",
|
|
114
|
+
userPoolId: "eu-west-1_e6o46c1oE",
|
|
114
115
|
},
|
|
115
116
|
stage: {
|
|
116
117
|
authUrl: "https://auth.stage.cognito.vydev.io",
|
|
117
118
|
jwksUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/jwks.json",
|
|
118
119
|
openIdUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/openid-configuration",
|
|
119
120
|
issuer: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW",
|
|
121
|
+
userPoolId: "eu-west-1_AUYQ679zW",
|
|
120
122
|
},
|
|
121
123
|
test: {
|
|
122
124
|
authUrl: "https://auth.test.cognito.vydev.io",
|
|
123
125
|
jwksUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/jwks.json",
|
|
124
126
|
openIdUrl: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/openid-configuration",
|
|
125
127
|
issuer: "https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT",
|
|
128
|
+
userPoolId: "eu-west-1_Z53b9AbeT",
|
|
126
129
|
},
|
|
127
130
|
};
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vy-cognito-provider.js","sourceRoot":"","sources":["../src/vy-cognito-provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { createRequire } from \"node:module\"\nimport path from \"node:path\"\nimport { fileURLToPath } from \"node:url\"\nimport * as cdk from \"aws-cdk-lib\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as lambda from \"aws-cdk-lib/aws-lambda\"\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\"\nimport * as logs from \"aws-cdk-lib/aws-logs\"\nimport * as cr from \"aws-cdk-lib/custom-resources\"\nimport { Construct } from \"constructs\"\nimport type { CognitoDetails, VyEnvironment } from \"./shared/types\"\n\nconst require = createRequire(import.meta.url)\nconst __filename = fileURLToPath(import.meta.url)\nconst __dirname = path.dirname(__filename)\n\nexport interface VyCognitoProviderProps {\n  /**\n   * The Vy Cognito environment to connect to (e.g., VyEnvironment.PROD, VyEnvironment.STAGE, VyEnvironment.TEST)\n   */\n  readonly environment: VyEnvironment\n\n  /**\n   * Base domain for Cognito service\n   * @default 'cognito.vydev.io'\n   */\n  readonly cognitoBaseDomain?: string\n\n  /**\n   * @default logs.RetentionDays.ONE_WEEK\n   */\n  readonly logsRetention?: logs.RetentionDays\n}\n\nexport interface AppClientProvider {\n  environment: VyEnvironment\n  serviceToken: string\n  auth_url: string\n}\n\nexport interface ResourceServerProvider {\n  environment: VyEnvironment\n  serviceToken: string\n}\n\nexport class VyCognitoProvider extends Construct {\n  public readonly environment: VyEnvironment\n  public readonly cognitoBaseDomain: string\n  public readonly details: CognitoDetails\n  public readonly appClientProvider: AppClientProvider\n  public readonly resourceServerProvider: ResourceServerProvider\n\n  constructor(scope: Construct, id: string, props: VyCognitoProviderProps) {\n    super(scope, id)\n\n    this.environment = props.environment\n    this.cognitoBaseDomain = props.cognitoBaseDomain ?? \"cognito.vydev.io\"\n    this.details = this.getCognitoDetailsForEnvironment(this.environment)\n\n    const appClientProvider = new LambdaProvider(this, \"AppClientProvider\", {\n      cognitoBaseDomain: this.cognitoBaseDomain,\n      runtime: lambda.Runtime.NODEJS_22_X,\n      handler: \"handler\",\n      entry: require.resolve(`${__dirname}/cognito-app-client/handler`),\n      logRetention: props.logsRetention,\n    })\n\n    this.appClientProvider = {\n      environment: this.environment,\n      serviceToken: appClientProvider.serviceToken,\n      auth_url: this.details.authUrl,\n    }\n\n    const resourceServerProvider = new LambdaProvider(\n      this,\n      \"ResourceServerProvider\",\n      {\n        cognitoBaseDomain: this.cognitoBaseDomain,\n        runtime: lambda.Runtime.NODEJS_22_X,\n        handler: \"handler\",\n        entry: require.resolve(`${__dirname}/cognito-resource-server/handler`),\n        logRetention: props.logsRetention,\n      },\n    )\n\n    this.resourceServerProvider = {\n      environment: this.environment,\n      serviceToken: resourceServerProvider.serviceToken,\n    }\n  }\n\n  getCognitoDetailsForEnvironment(environment: VyEnvironment): CognitoDetails {\n    const config = envConfigs[environment]\n\n    if (!config) {\n      throw new Error(\n        `Unknown environment: ${environment}. Valid values are: prod, stage, test`,\n      )\n    }\n\n    return config\n  }\n}\n\ninterface LambdaProviderProps {\n  readonly cognitoBaseDomain: string\n  readonly runtime: lambda.Runtime\n  readonly handler: string\n  readonly entry: string\n\n  /**\n   * @default cdk.Duration.minutes(2)\n   */\n  readonly timeout?: cdk.Duration\n\n  /**\n   * @default 256\n   */\n  readonly memorySize?: number\n\n  /**\n   * @default logs.RetentionDays.ONE_WEEK\n   */\n  readonly logRetention?: logs.RetentionDays\n}\n\nclass LambdaProvider extends Construct {\n  /**\n   * The logGroup for the event handler lambda\n   */\n  public readonly lambdaLogGroup: logs.LogGroup\n\n  /**\n   * The logGroup for the custom resource provider\n   */\n  public readonly providerLogGroup: logs.LogGroup\n\n  /**\n   * The service token for the provider\n   */\n  public readonly serviceToken: string\n\n  constructor(scope: Construct, id: string, props: LambdaProviderProps) {\n    super(scope, id)\n\n    this.lambdaLogGroup = new logs.LogGroup(this, \"LambdaLogGroup\", {\n      retention: props.logRetention ?? logs.RetentionDays.ONE_WEEK,\n    })\n\n    this.providerLogGroup = new logs.LogGroup(this, \"ProviderLogGroup\", {\n      retention: props.logRetention ?? logs.RetentionDays.ONE_WEEK,\n    })\n\n    const onEventHandler = new NodejsFunction(this, \"OnEventHandler\", {\n      runtime: props.runtime,\n      handler: props.handler,\n      entry: props.entry,\n      timeout: props.timeout ?? cdk.Duration.minutes(2),\n      memorySize: props.memorySize ?? 256,\n      logGroup: this.lambdaLogGroup,\n      environment: {\n        COGNITO_BASE_DOMAIN: props.cognitoBaseDomain,\n      },\n      bundling: {\n        minify: true,\n        sourceMap: true,\n        target: \"es2020\",\n        externalModules: [\"aws-sdk\"],\n      },\n    })\n\n    onEventHandler.addToRolePolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        actions: [\"execute-api:Invoke\"],\n        resources: [\"*\"], // Can be scoped down if API Gateway ARN is known\n      }),\n    )\n\n    const provider = new cr.Provider(this, \"Provider\", {\n      onEventHandler,\n      logGroup: this.providerLogGroup,\n    })\n\n    this.serviceToken = provider.serviceToken\n  }\n}\n\n// Static config for each environment\nconst envConfigs: Record<string, CognitoDetails> = {\n  prod: {\n    authUrl: \"https://auth.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE\",\n  },\n  stage: {\n    authUrl: \"https://auth.stage.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW\",\n  },\n  test: {\n    authUrl: \"https://auth.test.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT\",\n  },\n}\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vy-cognito-provider.js","sourceRoot":"","sources":["../src/vy-cognito-provider.ts"],"names":[],"mappings":"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","sourcesContent":["import { createRequire } from \"node:module\"\nimport path from \"node:path\"\nimport { fileURLToPath } from \"node:url\"\nimport * as cdk from \"aws-cdk-lib\"\nimport * as iam from \"aws-cdk-lib/aws-iam\"\nimport * as lambda from \"aws-cdk-lib/aws-lambda\"\nimport { NodejsFunction } from \"aws-cdk-lib/aws-lambda-nodejs\"\nimport * as logs from \"aws-cdk-lib/aws-logs\"\nimport * as cr from \"aws-cdk-lib/custom-resources\"\nimport { Construct } from \"constructs\"\nimport type { CognitoDetails, VyEnvironment } from \"./shared/types\"\n\nconst require = createRequire(import.meta.url)\nconst __filename = fileURLToPath(import.meta.url)\nconst __dirname = path.dirname(__filename)\n\nexport interface VyCognitoProviderProps {\n  /**\n   * The Vy Cognito environment to connect to (e.g., VyEnvironment.PROD, VyEnvironment.STAGE, VyEnvironment.TEST)\n   */\n  readonly environment: VyEnvironment\n\n  /**\n   * Base domain for Cognito service\n   * @default 'cognito.vydev.io'\n   */\n  readonly cognitoBaseDomain?: string\n\n  /**\n   * @default logs.RetentionDays.ONE_WEEK\n   */\n  readonly logsRetention?: logs.RetentionDays\n}\n\nexport interface AppClientProvider {\n  environment: VyEnvironment\n  serviceToken: string\n  auth_url: string\n}\n\nexport interface ResourceServerProvider {\n  environment: VyEnvironment\n  serviceToken: string\n}\n\nexport class VyCognitoProvider extends Construct {\n  public readonly environment: VyEnvironment\n  public readonly cognitoBaseDomain: string\n  public readonly details: CognitoDetails\n  public readonly appClientProvider: AppClientProvider\n  public readonly resourceServerProvider: ResourceServerProvider\n\n  constructor(scope: Construct, id: string, props: VyCognitoProviderProps) {\n    super(scope, id)\n\n    this.environment = props.environment\n    this.cognitoBaseDomain = props.cognitoBaseDomain ?? \"cognito.vydev.io\"\n    this.details = getCognitoDetailsForEnvironment(this.environment)\n\n    const appClientProvider = new LambdaProvider(this, \"AppClientProvider\", {\n      cognitoBaseDomain: this.cognitoBaseDomain,\n      runtime: lambda.Runtime.NODEJS_22_X,\n      handler: \"handler\",\n      entry: require.resolve(`${__dirname}/cognito-app-client/handler`),\n      logRetention: props.logsRetention,\n    })\n\n    this.appClientProvider = {\n      environment: this.environment,\n      serviceToken: appClientProvider.serviceToken,\n      auth_url: this.details.authUrl,\n    }\n\n    const resourceServerProvider = new LambdaProvider(\n      this,\n      \"ResourceServerProvider\",\n      {\n        cognitoBaseDomain: this.cognitoBaseDomain,\n        runtime: lambda.Runtime.NODEJS_22_X,\n        handler: \"handler\",\n        entry: require.resolve(`${__dirname}/cognito-resource-server/handler`),\n        logRetention: props.logsRetention,\n      },\n    )\n\n    this.resourceServerProvider = {\n      environment: this.environment,\n      serviceToken: resourceServerProvider.serviceToken,\n    }\n  }\n}\n\ninterface LambdaProviderProps {\n  readonly cognitoBaseDomain: string\n  readonly runtime: lambda.Runtime\n  readonly handler: string\n  readonly entry: string\n\n  /**\n   * @default cdk.Duration.minutes(2)\n   */\n  readonly timeout?: cdk.Duration\n\n  /**\n   * @default 256\n   */\n  readonly memorySize?: number\n\n  /**\n   * @default logs.RetentionDays.ONE_WEEK\n   */\n  readonly logRetention?: logs.RetentionDays\n}\n\nclass LambdaProvider extends Construct {\n  /**\n   * The logGroup for the event handler lambda\n   */\n  public readonly lambdaLogGroup: logs.LogGroup\n\n  /**\n   * The logGroup for the custom resource provider\n   */\n  public readonly providerLogGroup: logs.LogGroup\n\n  /**\n   * The service token for the provider\n   */\n  public readonly serviceToken: string\n\n  constructor(scope: Construct, id: string, props: LambdaProviderProps) {\n    super(scope, id)\n\n    this.lambdaLogGroup = new logs.LogGroup(this, \"LambdaLogGroup\", {\n      retention: props.logRetention ?? logs.RetentionDays.ONE_WEEK,\n    })\n\n    this.providerLogGroup = new logs.LogGroup(this, \"ProviderLogGroup\", {\n      retention: props.logRetention ?? logs.RetentionDays.ONE_WEEK,\n    })\n\n    const onEventHandler = new NodejsFunction(this, \"OnEventHandler\", {\n      runtime: props.runtime,\n      handler: props.handler,\n      entry: props.entry,\n      timeout: props.timeout ?? cdk.Duration.minutes(2),\n      memorySize: props.memorySize ?? 256,\n      logGroup: this.lambdaLogGroup,\n      environment: {\n        COGNITO_BASE_DOMAIN: props.cognitoBaseDomain,\n      },\n      bundling: {\n        minify: true,\n        sourceMap: true,\n        target: \"es2020\",\n        externalModules: [\"aws-sdk\"],\n      },\n    })\n\n    onEventHandler.addToRolePolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        actions: [\"execute-api:Invoke\"],\n        resources: [\"*\"], // Can be scoped down if API Gateway ARN is known\n      }),\n    )\n\n    const provider = new cr.Provider(this, \"Provider\", {\n      onEventHandler,\n      logGroup: this.providerLogGroup,\n    })\n\n    this.serviceToken = provider.serviceToken\n  }\n}\n\nexport function getCognitoDetailsForEnvironment(\n  environment: VyEnvironment,\n): CognitoDetails {\n  const config = envConfigs[environment]\n\n  if (!config) {\n    throw new Error(\n      `Unknown environment: ${environment}. Valid values are: prod, stage, test`,\n    )\n  }\n\n  return config\n}\n\n// Static config for each environment\nconst envConfigs: Record<string, CognitoDetails> = {\n  prod: {\n    authUrl: \"https://auth.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_e6o46c1oE\",\n    userPoolId: \"eu-west-1_e6o46c1oE\",\n  },\n  stage: {\n    authUrl: \"https://auth.stage.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_AUYQ679zW\",\n    userPoolId: \"eu-west-1_AUYQ679zW\",\n  },\n  test: {\n    authUrl: \"https://auth.test.cognito.vydev.io\",\n    jwksUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/jwks.json\",\n    openIdUrl:\n      \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT/.well-known/openid-configuration\",\n    issuer: \"https://cognito-idp.eu-west-1.amazonaws.com/eu-west-1_Z53b9AbeT\",\n    userPoolId: \"eu-west-1_Z53b9AbeT\",\n  },\n}\n"]}
|