@robhan-cdk-lib/aws_grafana 0.0.24 → 0.0.25
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/.jsii +1723 -461
- package/API.md +1528 -363
- package/lib/index.d.ts +2 -1
- package/lib/index.js +17 -10
- package/lib/workspace-base.d.ts +499 -0
- package/lib/workspace-base.js +150 -0
- package/lib/workspace.d.ts +89 -255
- package/lib/workspace.js +52 -138
- package/package.json +1 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.WorkspaceBase = exports.Status = exports.SamlConfigurationStatuses = exports.PermissionTypes = exports.NotificationDestinations = exports.AuthenticationProviders = exports.AccountAccessType = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
7
|
+
/**
|
|
8
|
+
* Specifies whether the workspace can access AWS resources in this AWS account only, or whether it
|
|
9
|
+
* can also access AWS resources in other accounts in the same organization. If this is
|
|
10
|
+
* ORGANIZATION, the OrganizationalUnits parameter specifies which organizational units the
|
|
11
|
+
* workspace can access.
|
|
12
|
+
*/
|
|
13
|
+
var AccountAccessType;
|
|
14
|
+
(function (AccountAccessType) {
|
|
15
|
+
/**
|
|
16
|
+
* Access is limited to the current AWS account only.
|
|
17
|
+
*/
|
|
18
|
+
AccountAccessType["CURRENT_ACCOUNT"] = "CURRENT_ACCOUNT";
|
|
19
|
+
/**
|
|
20
|
+
* Access is extended to the entire AWS organization.
|
|
21
|
+
*/
|
|
22
|
+
AccountAccessType["ORGANIZATION"] = "ORGANIZATION";
|
|
23
|
+
})(AccountAccessType || (exports.AccountAccessType = AccountAccessType = {}));
|
|
24
|
+
/**
|
|
25
|
+
* Specifies whether this workspace uses SAML 2.0, AWS IAM Identity Center, or both to authenticate
|
|
26
|
+
* users for using the Grafana console within a workspace.
|
|
27
|
+
*
|
|
28
|
+
* @see https://docs.aws.amazon.com/grafana/latest/APIReference/API_CreateWorkspace.html
|
|
29
|
+
*/
|
|
30
|
+
var AuthenticationProviders;
|
|
31
|
+
(function (AuthenticationProviders) {
|
|
32
|
+
/**
|
|
33
|
+
* AWS Single Sign-On authentication provider.
|
|
34
|
+
*/
|
|
35
|
+
AuthenticationProviders["AWS_SSO"] = "AWS_SSO";
|
|
36
|
+
/**
|
|
37
|
+
* Security Assertion Markup Language (SAML) authentication provider.
|
|
38
|
+
*/
|
|
39
|
+
AuthenticationProviders["SAML"] = "SAML";
|
|
40
|
+
})(AuthenticationProviders || (exports.AuthenticationProviders = AuthenticationProviders = {}));
|
|
41
|
+
/**
|
|
42
|
+
* The AWS notification channels that Amazon Managed Grafana can automatically create IAM roles and
|
|
43
|
+
* permissions for, to allow Amazon Managed Grafana to use these channels.
|
|
44
|
+
*/
|
|
45
|
+
var NotificationDestinations;
|
|
46
|
+
(function (NotificationDestinations) {
|
|
47
|
+
/**
|
|
48
|
+
* Amazon Simple Notification Service (SNS) as notification destination.
|
|
49
|
+
*/
|
|
50
|
+
NotificationDestinations["SNS"] = "SNS";
|
|
51
|
+
})(NotificationDestinations || (exports.NotificationDestinations = NotificationDestinations = {}));
|
|
52
|
+
/**
|
|
53
|
+
* If this is SERVICE_MANAGED, and the workplace was created through the Amazon Managed Grafana
|
|
54
|
+
* console, then Amazon Managed Grafana automatically creates the IAM roles and provisions the
|
|
55
|
+
* permissions that the workspace needs to use AWS data sources and notification channels.
|
|
56
|
+
*
|
|
57
|
+
* If this is CUSTOMER_MANAGED, you must manage those roles and permissions yourself.
|
|
58
|
+
|
|
59
|
+
* If you are working with a workspace in a member account of an organization and that account is
|
|
60
|
+
* not a delegated administrator account, and you want the workspace to access data sources in
|
|
61
|
+
* other AWS accounts in the organization, this parameter must be set to CUSTOMER_MANAGED.
|
|
62
|
+
*/
|
|
63
|
+
var PermissionTypes;
|
|
64
|
+
(function (PermissionTypes) {
|
|
65
|
+
/**
|
|
66
|
+
* Customer-managed permissions where you manage user access to Grafana.
|
|
67
|
+
*/
|
|
68
|
+
PermissionTypes["CUSTOMER_MANAGED"] = "CUSTOMER_MANAGED";
|
|
69
|
+
/**
|
|
70
|
+
* Service-managed permissions where AWS manages user access to Grafana.
|
|
71
|
+
*/
|
|
72
|
+
PermissionTypes["SERVICE_MANAGED"] = "SERVICE_MANAGED";
|
|
73
|
+
})(PermissionTypes || (exports.PermissionTypes = PermissionTypes = {}));
|
|
74
|
+
/**
|
|
75
|
+
* Status of SAML configuration for a Grafana workspace.
|
|
76
|
+
*/
|
|
77
|
+
var SamlConfigurationStatuses;
|
|
78
|
+
(function (SamlConfigurationStatuses) {
|
|
79
|
+
/**
|
|
80
|
+
* SAML is configured for the workspace.
|
|
81
|
+
*/
|
|
82
|
+
SamlConfigurationStatuses["CONFIGURED"] = "CONFIGURED";
|
|
83
|
+
/**
|
|
84
|
+
* SAML is not configured for the workspace.
|
|
85
|
+
*/
|
|
86
|
+
SamlConfigurationStatuses["NOT_CONFIGURED"] = "NOT_CONFIGURED";
|
|
87
|
+
})(SamlConfigurationStatuses || (exports.SamlConfigurationStatuses = SamlConfigurationStatuses = {}));
|
|
88
|
+
/**
|
|
89
|
+
* Status of a Grafana workspace.
|
|
90
|
+
*/
|
|
91
|
+
var Status;
|
|
92
|
+
(function (Status) {
|
|
93
|
+
/**
|
|
94
|
+
* Workspace is active and ready to use.
|
|
95
|
+
*/
|
|
96
|
+
Status["ACTIVE"] = "ACTIVE";
|
|
97
|
+
/**
|
|
98
|
+
* Workspace is being created.
|
|
99
|
+
*/
|
|
100
|
+
Status["CREATING"] = "CREATING";
|
|
101
|
+
/**
|
|
102
|
+
* Workspace is being deleted.
|
|
103
|
+
*/
|
|
104
|
+
Status["DELETING"] = "DELETING";
|
|
105
|
+
/**
|
|
106
|
+
* Workspace operation has failed.
|
|
107
|
+
*/
|
|
108
|
+
Status["FAILED"] = "FAILED";
|
|
109
|
+
/**
|
|
110
|
+
* Workspace is being updated.
|
|
111
|
+
*/
|
|
112
|
+
Status["UPDATING"] = "UPDATING";
|
|
113
|
+
/**
|
|
114
|
+
* Workspace is being upgraded.
|
|
115
|
+
*/
|
|
116
|
+
Status["UPGRADING"] = "UPGRADING";
|
|
117
|
+
/**
|
|
118
|
+
* Workspace deletion has failed.
|
|
119
|
+
*/
|
|
120
|
+
Status["DELETION_FAILED"] = "DELETION_FAILED";
|
|
121
|
+
/**
|
|
122
|
+
* Workspace creation has failed.
|
|
123
|
+
*/
|
|
124
|
+
Status["CREATION_FAILED"] = "CREATION_FAILED";
|
|
125
|
+
/**
|
|
126
|
+
* Workspace update has failed.
|
|
127
|
+
*/
|
|
128
|
+
Status["UPDATE_FAILED"] = "UPDATE_FAILED";
|
|
129
|
+
/**
|
|
130
|
+
* Workspace upgrade has failed.
|
|
131
|
+
*/
|
|
132
|
+
Status["UPGRADE_FAILED"] = "UPGRADE_FAILED";
|
|
133
|
+
/**
|
|
134
|
+
* License removal has failed.
|
|
135
|
+
*/
|
|
136
|
+
Status["LICENSE_REMOVAL_FAILED"] = "LICENSE_REMOVAL_FAILED";
|
|
137
|
+
})(Status || (exports.Status = Status = {}));
|
|
138
|
+
class WorkspaceBase extends aws_cdk_lib_1.Resource {
|
|
139
|
+
getWorkspaceArn(workspaceId) {
|
|
140
|
+
const stack = this.stack;
|
|
141
|
+
return `arn:${stack.partition}:grafana:${stack.region}:${stack.account}:/workspaces/${workspaceId}`;
|
|
142
|
+
}
|
|
143
|
+
getWorkspaceId(workspaceArn) {
|
|
144
|
+
return workspaceArn.substring(workspaceArn.lastIndexOf('/') + 1);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
exports.WorkspaceBase = WorkspaceBase;
|
|
148
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
149
|
+
WorkspaceBase[_a] = { fqn: "@robhan-cdk-lib/aws_grafana.WorkspaceBase", version: "0.0.25" };
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace-base.js","sourceRoot":"","sources":["../src/workspace-base.ts"],"names":[],"mappings":";;;;;AAAA,6CAAkD;AAIlD;;;;;GAKG;AACH,IAAY,iBAUX;AAVD,WAAY,iBAAiB;IAC3B;;OAEG;IACH,wDAAmC,CAAA;IAEnC;;OAEG;IACH,kDAA6B,CAAA;AAC/B,CAAC,EAVW,iBAAiB,iCAAjB,iBAAiB,QAU5B;AAED;;;;;GAKG;AACH,IAAY,uBAUX;AAVD,WAAY,uBAAuB;IACjC;;OAEG;IACH,8CAAmB,CAAA;IAEnB;;OAEG;IACH,wCAAa,CAAA;AACf,CAAC,EAVW,uBAAuB,uCAAvB,uBAAuB,QAUlC;AA2BD;;;GAGG;AACH,IAAY,wBAKX;AALD,WAAY,wBAAwB;IAClC;;OAEG;IACH,uCAAW,CAAA;AACb,CAAC,EALW,wBAAwB,wCAAxB,wBAAwB,QAKnC;AAED;;;;;;;;;;GAUG;AACH,IAAY,eAUX;AAVD,WAAY,eAAe;IACzB;;OAEG;IACH,wDAAqC,CAAA;IAErC;;OAEG;IACH,sDAAmC,CAAA;AACrC,CAAC,EAVW,eAAe,+BAAf,eAAe,QAU1B;AA4JD;;GAEG;AACH,IAAY,yBAUX;AAVD,WAAY,yBAAyB;IACnC;;OAEG;IACH,sDAAyB,CAAA;IAEzB;;OAEG;IACH,8DAAiC,CAAA;AACnC,CAAC,EAVW,yBAAyB,yCAAzB,yBAAyB,QAUpC;AAED;;GAEG;AACH,IAAY,MAuDX;AAvDD,WAAY,MAAM;IAChB;;OAEG;IACH,2BAAiB,CAAA;IAEjB;;OAEG;IACH,+BAAqB,CAAA;IAErB;;OAEG;IACH,+BAAqB,CAAA;IAErB;;OAEG;IACH,2BAAiB,CAAA;IAEjB;;OAEG;IACH,+BAAqB,CAAA;IAErB;;OAEG;IACH,iCAAuB,CAAA;IAEvB;;OAEG;IACH,6CAAmC,CAAA;IAEnC;;OAEG;IACH,6CAAmC,CAAA;IAEnC;;OAEG;IACH,yCAA+B,CAAA;IAE/B;;OAEG;IACH,2CAAiC,CAAA;IAEjC;;OAEG;IACH,2DAAiD,CAAA;AACnD,CAAC,EAvDW,MAAM,sBAAN,MAAM,QAuDjB;AA8ID,MAAsB,aAAc,SAAQ,sBAAQ;IAqGxC,eAAe,CAAC,WAAmB;QAC3C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,OAAO,OAAO,KAAK,CAAC,SAAS,YAAY,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,gBAAgB,WAAW,EAAE,CAAC;IACtG,CAAC;IAES,cAAc,CAAC,YAAoB;QAC3C,OAAO,YAAY,CAAC,SAAS,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IACnE,CAAC;;AA5GH,sCA6GC","sourcesContent":["import { IResource, Resource } from 'aws-cdk-lib';\nimport { IPrefixList, ISecurityGroup, ISubnet, IVpcEndpoint } from 'aws-cdk-lib/aws-ec2';\nimport { IRole } from 'aws-cdk-lib/aws-iam';\n\n/**\n * Specifies whether the workspace can access AWS resources in this AWS account only, or whether it\n * can also access AWS resources in other accounts in the same organization. If this is\n * ORGANIZATION, the OrganizationalUnits parameter specifies which organizational units the\n * workspace can access.\n */\nexport enum AccountAccessType {\n  /**\n   * Access is limited to the current AWS account only.\n   */\n  CURRENT_ACCOUNT = 'CURRENT_ACCOUNT',\n\n  /**\n   * Access is extended to the entire AWS organization.\n   */\n  ORGANIZATION = 'ORGANIZATION',\n}\n\n/**\n * Specifies whether this workspace uses SAML 2.0, AWS IAM Identity Center, or both to authenticate\n * users for using the Grafana console within a workspace.\n *\n * @see https://docs.aws.amazon.com/grafana/latest/APIReference/API_CreateWorkspace.html\n */\nexport enum AuthenticationProviders {\n  /**\n   * AWS Single Sign-On authentication provider.\n   */\n  AWS_SSO = 'AWS_SSO',\n\n  /**\n   * Security Assertion Markup Language (SAML) authentication provider.\n   */\n  SAML = 'SAML',\n}\n\n/**\n * The configuration settings for network access to your workspace.\n */\nexport interface NetworkAccessControl {\n  /**\n   * An array of prefix list IDs. A prefix list is a list of CIDR ranges of IP addresses. The IP\n   * addresses specified are allowed to access your workspace. If the list is not included in the\n   * configuration (passed an empty array) then no IP addresses are allowed to access the\n   * workspace.\n   *\n   * Maximum of 5 prefix lists allowed.\n   */\n  readonly prefixLists?: IPrefixList[];\n\n  /**\n   * An array of Amazon VPC endpoint IDs for the workspace. You can create VPC endpoints to your\n   * Amazon Managed Grafana workspace for access from within a VPC. If a NetworkAccessConfiguration\n   * is specified then only VPC endpoints specified here are allowed to access the workspace. If\n   * you pass in an empty array of strings, then no VPCs are allowed to access the workspace.\n   *\n   * Maximum of 5 VPC endpoints allowed.\n   */\n  readonly vpcEndpoints?: IVpcEndpoint[];\n}\n\n/**\n * The AWS notification channels that Amazon Managed Grafana can automatically create IAM roles and\n * permissions for, to allow Amazon Managed Grafana to use these channels.\n */\nexport enum NotificationDestinations {\n  /**\n   * Amazon Simple Notification Service (SNS) as notification destination.\n   */\n  SNS = 'SNS',\n}\n\n/**\n * If this is SERVICE_MANAGED, and the workplace was created through the Amazon Managed Grafana\n * console, then Amazon Managed Grafana automatically creates the IAM roles and provisions the\n * permissions that the workspace needs to use AWS data sources and notification channels.\n *\n * If this is CUSTOMER_MANAGED, you must manage those roles and permissions yourself.\n\n * If you are working with a workspace in a member account of an organization and that account is\n * not a delegated administrator account, and you want the workspace to access data sources in\n * other AWS accounts in the organization, this parameter must be set to CUSTOMER_MANAGED.\n */\nexport enum PermissionTypes {\n  /**\n   * Customer-managed permissions where you manage user access to Grafana.\n   */\n  CUSTOMER_MANAGED = 'CUSTOMER_MANAGED',\n\n  /**\n   * Service-managed permissions where AWS manages user access to Grafana.\n   */\n  SERVICE_MANAGED = 'SERVICE_MANAGED',\n}\n\n/**\n * A structure that defines which attributes in the IdP assertion are to be used to define\n * information about the users authenticated by the IdP to use the workspace.\n *\n * Each attribute must be a string with length between 1 and 256 characters.\n */\nexport interface SamlAssertionAttributes {\n  /**\n   * The name of the attribute within the SAML assertion to use as the email names for SAML users.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly email?: string;\n  /**\n   * The name of the attribute within the SAML assertion to use as the user full \"friendly\" names\n   * for user groups.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly groups?: string;\n  /**\n   * The name of the attribute within the SAML assertion to use as the login names for SAML users.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly login?: string;\n  /**\n   * The name of the attribute within the SAML assertion to use as the user full \"friendly\" names\n   * for SAML users.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly name?: string;\n  /**\n   * The name of the attribute within the SAML assertion to use as the user full \"friendly\" names\n   * for the users' organizations.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly org?: string;\n  /**\n   * The name of the attribute within the SAML assertion to use as the user roles.\n   *\n   * Must be between 1 and 256 characters long.\n   */\n  readonly role?: string;\n}\n\n/**\n * A structure containing the identity provider (IdP) metadata used to integrate the identity\n * provider with this workspace.\n */\nexport interface SamlIdpMetadata {\n  /**\n   * The URL of the location containing the IdP metadata.\n   *\n   * Must be a string with length between 1 and 2048 characters.\n   */\n  readonly url?: string;\n\n  /**\n   * The full IdP metadata, in XML format.\n   */\n  readonly xml?: string;\n}\n\n/**\n * A structure containing arrays that map group names in the SAML assertion to the Grafana Admin\n * and Editor roles in the workspace.\n */\nexport interface SamlRoleValues {\n  /**\n   * A list of groups from the SAML assertion attribute to grant the Grafana Admin role to.\n   *\n   * Maximum of 256 elements.\n   */\n  readonly admin?: string[];\n\n  /**\n   * A list of groups from the SAML assertion attribute to grant the Grafana Editor role to.\n   *\n   * Maximum of 256 elements.\n   */\n  readonly editor?: string[];\n}\n\n/**\n * If the workspace uses SAML, use this structure to map SAML assertion attributes to workspace\n * user information and define which groups in the assertion attribute are to have the Admin and\n * Editor roles in the workspace.\n */\nexport interface SamlConfiguration {\n  /**\n   * Lists which organizations defined in the SAML assertion are allowed to use the Amazon Managed\n   * Grafana workspace. If this is empty, all organizations in the assertion attribute have access.\n   *\n   * Must have between 1 and 256 elements.\n   */\n  readonly allowedOrganizations?: string[];\n\n  /**\n   * A structure that defines which attributes in the SAML assertion are to be used to define\n   * information about the users authenticated by that IdP to use the workspace.\n   */\n  readonly assertionAtrributes?: SamlAssertionAttributes;\n\n  /**\n   * A structure containing the identity provider (IdP) metadata used to integrate the identity\n   * provider with this workspace.\n   *\n   * Required field for SAML configuration.\n   */\n  readonly idpMetadata: SamlIdpMetadata;\n\n  /**\n   * How long a sign-on session by a SAML user is valid, before the user has to sign on again.\n   *\n   * Must be a positive number.\n   */\n  readonly loginValidityDuration?: number;\n\n  /**\n   * A structure containing arrays that map group names in the SAML assertion to the Grafana Admin\n   * and Editor roles in the workspace.\n   */\n  readonly roleValues?: SamlRoleValues;\n}\n\n/**\n * The configuration settings for an Amazon VPC that contains data sources for your Grafana\n * workspace to connect to.\n */\nexport interface VpcConfiguration {\n  /**\n   * The list of Amazon EC2 security groups attached to the Amazon VPC for your Grafana\n   * workspace to connect. Duplicates not allowed.\n   *\n   * Array Members: Minimum number of 1 items. Maximum number of 5 items.\n   *\n   * Required for VPC configuration.\n   */\n  readonly securityGroups: ISecurityGroup[];\n\n  /**\n   * The list of Amazon EC2 subnets created in the Amazon VPC for your Grafana workspace to\n   * connect. Duplicates not allowed.\n   *\n   * Array Members: Minimum number of 2 items. Maximum number of 6 items.\n   *\n   * Required for VPC configuration.\n   */\n  readonly subnets: ISubnet[];\n}\n\n/**\n * Status of SAML configuration for a Grafana workspace.\n */\nexport enum SamlConfigurationStatuses {\n  /**\n   * SAML is configured for the workspace.\n   */\n  CONFIGURED = 'CONFIGURED',\n\n  /**\n   * SAML is not configured for the workspace.\n   */\n  NOT_CONFIGURED = 'NOT_CONFIGURED',\n}\n\n/**\n * Status of a Grafana workspace.\n */\nexport enum Status {\n  /**\n   * Workspace is active and ready to use.\n   */\n  ACTIVE = 'ACTIVE',\n\n  /**\n   * Workspace is being created.\n   */\n  CREATING = 'CREATING',\n\n  /**\n   * Workspace is being deleted.\n   */\n  DELETING = 'DELETING',\n\n  /**\n   * Workspace operation has failed.\n   */\n  FAILED = 'FAILED',\n\n  /**\n   * Workspace is being updated.\n   */\n  UPDATING = 'UPDATING',\n\n  /**\n   * Workspace is being upgraded.\n   */\n  UPGRADING = 'UPGRADING',\n\n  /**\n   * Workspace deletion has failed.\n   */\n  DELETION_FAILED = 'DELETION_FAILED',\n\n  /**\n   * Workspace creation has failed.\n   */\n  CREATION_FAILED = 'CREATION_FAILED',\n\n  /**\n   * Workspace update has failed.\n   */\n  UPDATE_FAILED = 'UPDATE_FAILED',\n\n  /**\n   * Workspace upgrade has failed.\n   */\n  UPGRADE_FAILED = 'UPGRADE_FAILED',\n\n  /**\n   * License removal has failed.\n   */\n  LICENSE_REMOVAL_FAILED = 'LICENSE_REMOVAL_FAILED',\n}\n\n/**\n * Represents an Amazon Managed Service for Grafana workspace\n */\nexport interface IWorkspace extends IResource {\n\n  /**\n   * Specifies whether the workspace can access AWS resources in this AWS account only, or whether\n   * it can also access AWS resources in other accounts in the same organization. If this is\n   * ORGANIZATION, the OrganizationalUnits parameter specifies which organizational units the\n   * workspace can access.\n   * @attribute\n   */\n  readonly accountAccessType: AccountAccessType;\n\n  /**\n   * Specifies whether this workspace uses SAML 2.0, AWS IAM Identity Center, or both to\n   * authenticate users for using the Grafana console within a workspace.\n   * @attribute\n   */\n  readonly authenticationProviders: AuthenticationProviders[];\n\n  /**\n   * A unique, case-sensitive, user-provided identifier to ensure the idempotency of the request.\n   * @attribute\n   */\n  readonly clientToken?: string;\n\n  /**\n   * Specifies the AWS data sources that have been configured to have IAM roles and permissions\n   * created to allow Amazon Managed Grafana to read data from these sources.\n   *\n   * This list is only used when the workspace was created through the AWS console, and the\n   * permissionType is SERVICE_MANAGED.\n   * @attribute\n   */\n  readonly dataSources?: string[];\n\n  /**\n   * The user-defined description of the workspace.\n   * @attribute\n   */\n  readonly description?: string;\n\n  /**\n   * The name of the workspace.\n   * @attribute\n   */\n  readonly name?: string;\n\n  /**\n   * The configuration settings for network access to your workspace.\n   * @attribute\n   */\n  readonly networkAccessControl?: NetworkAccessControl;\n\n  /**\n   * The AWS notification channels that Amazon Managed Grafana can automatically create IAM roles\n   * and permissions for, to allow Amazon Managed Grafana to use these channels.\n   * @attribute\n   */\n  readonly notificationDestinations?: NotificationDestinations[];\n\n  /**\n   * Specifies the organizational units that this workspace is allowed to use data sources from, if\n   * this workspace is in an account that is part of an organization.\n   * @attribute\n   */\n  readonly organizationalUnits?: string[];\n\n  /**\n   * The name of the IAM role that is used to access resources through Organizations.\n   * @attribute\n   */\n  readonly organizationRoleName?: string;\n\n  /**\n   * If this is SERVICE_MANAGED, and the workplace was created through the Amazon Managed Grafana\n   * console, then Amazon Managed Grafana automatically creates the IAM roles and provisions the\n   * permissions that the workspace needs to use AWS data sources and notification channels.\n   *\n   * If this is CUSTOMER_MANAGED, you must manage those roles and permissions yourself.\n   *\n   * If you are working with a workspace in a member account of an organization and that account is\n   * not a delegated administrator account, and you want the workspace to access data sources in\n   * other AWS accounts in the organization, this parameter must be set to CUSTOMER_MANAGED.\n   * @attribute\n   */\n  readonly permissionType: PermissionTypes;\n\n  /**\n   * Whether plugin administration is enabled in the workspace. Setting to true allows workspace\n   * admins to install, uninstall, and update plugins from within the Grafana workspace.\n   *\n   * This option is only valid for workspaces that support Grafana version 9 or newer.\n   * @attribute\n   */\n  readonly pluginAdminEnabled?: boolean;\n\n  /**\n   * The IAM role that grants permissions to the AWS resources that the workspace will view data\n   * from.\n   * @attribute\n   */\n  readonly role?: IRole;\n\n  /**\n   * If the workspace uses SAML, use this structure to map SAML assertion attributes to workspace\n   * user information and define which groups in the assertion attribute are to have the Admin and\n   * Editor roles in the workspace.\n   * @attribute\n   */\n  readonly samlConfiguration?: SamlConfiguration;\n\n  /**\n   * The name of the AWS CloudFormation stack set that is used to generate IAM roles to be used for\n   * this workspace.\n   * @attribute\n   */\n  readonly stackSetName?: string;\n\n  /**\n   * The configuration settings for an Amazon VPC that contains data sources for your Grafana\n   * workspace to connect to.\n   * @attribute\n   */\n  readonly vpcConfiguration?: VpcConfiguration;\n\n  /**\n   * The unique ID of this workspace.\n   * @attribute\n   */\n  readonly workspaceId: string;\n\n  /**\n   * The ARN of this workspace\n   * @attribute\n   */\n  readonly workspaceArn: string;\n}\n\nexport abstract class WorkspaceBase extends Resource implements IWorkspace {\n\n  /**\n   * The account access type for the workspace.\n   */\n  public abstract readonly accountAccessType: AccountAccessType;\n\n  /**\n   * The authentication providers for the workspace.\n   */\n  public abstract readonly authenticationProviders: AuthenticationProviders[];\n\n  /**\n   * The client token for the workspace.\n   */\n  public abstract readonly clientToken?: string;\n\n  /**\n   * The data sources of this workspace\n   */\n  public abstract readonly dataSources?: string[];\n\n  /**\n   * The description of this workspace\n   */\n  public abstract readonly description?: string;\n\n  /**\n   * The name of this workspace\n   */\n  public abstract readonly name?: string;\n\n  /**\n   * The configuration settings for network access to your workspace.\n   */\n  public abstract readonly networkAccessControl?: NetworkAccessControl;\n\n  /**\n   * The notification destinations for the workspace.\n   */\n  public abstract readonly notificationDestinations?: NotificationDestinations[];\n\n  /**\n   * Specifies the organizational units that this workspace is allowed to use data sources from, if\n   * this workspace is in an account that is part of an organization.\n   */\n  public abstract readonly organizationalUnits?: string[];\n\n  /**\n   * The name of the IAM role that is used to access resources through Organizations.\n   */\n  public abstract readonly organizationRoleName?: string;\n\n  /**\n   * The permission type for the workspace.\n   */\n  public abstract readonly permissionType: PermissionTypes;\n\n  /**\n   * Whether plugin administration is enabled in the workspace. Setting to true allows workspace\n   * admins to install, uninstall, and update plugins from within the Grafana workspace.\n   *\n   * This option is only valid for workspaces that support Grafana version 9 or newer.\n   */\n  public abstract readonly pluginAdminEnabled?: boolean;\n\n  /**\n   * The IAM role that grants permissions to the AWS resources that the workspace will view data\n   * from.\n   */\n  public abstract readonly role?: IRole;\n\n  /**\n   * If the workspace uses SAML, use this structure to map SAML assertion attributes to workspace\n   * user information and define which groups in the assertion attribute are to have the Admin and\n   * Editor roles in the workspace.\n   */\n  public abstract readonly samlConfiguration?: SamlConfiguration;\n\n  /**\n   * The name of the AWS CloudFormation stack set that is used to generate IAM roles to be used for\n   * this workspace.\n   */\n  public abstract readonly stackSetName?: string;\n\n  /**\n   * The configuration settings for an Amazon VPC that contains data sources for your Grafana\n   * workspace to connect to.\n   */\n  public abstract readonly vpcConfiguration?: VpcConfiguration;\n\n  /**\n   * The unique ID of this workspace.\n   */\n  public abstract readonly workspaceId: string;\n\n  /**\n   * The ARN of this workspace\n   */\n  public abstract readonly workspaceArn: string;\n\n  protected getWorkspaceArn(workspaceId: string) {\n    const stack = this.stack;\n    return `arn:${stack.partition}:grafana:${stack.region}:${stack.account}:/workspaces/${workspaceId}`;\n  }\n\n  protected getWorkspaceId(workspaceArn: string) {\n    return workspaceArn.substring(workspaceArn.lastIndexOf('/') + 1);\n  }\n}"]}
|
package/lib/workspace.d.ts
CHANGED
|
@@ -1,238 +1,126 @@
|
|
|
1
|
-
import { IPrefixList, ISecurityGroup, ISubnet, IVpcEndpoint } from 'aws-cdk-lib/aws-ec2';
|
|
2
1
|
import { IRole } from 'aws-cdk-lib/aws-iam';
|
|
3
2
|
import { Construct } from 'constructs';
|
|
3
|
+
import { AccountAccessType, AuthenticationProviders, IWorkspace, NetworkAccessControl, NotificationDestinations, PermissionTypes, SamlConfiguration, SamlConfigurationStatuses, Status, VpcConfiguration, WorkspaceBase } from './workspace-base';
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
6
|
-
* can also access AWS resources in other accounts in the same organization. If this is
|
|
7
|
-
* ORGANIZATION, the OrganizationalUnits parameter specifies which organizational units the
|
|
8
|
-
* workspace can access.
|
|
9
|
-
*/
|
|
10
|
-
export declare enum AccountAccessType {
|
|
11
|
-
/**
|
|
12
|
-
* Access is limited to the current AWS account only.
|
|
13
|
-
*/
|
|
14
|
-
CURRENT_ACCOUNT = "CURRENT_ACCOUNT",
|
|
15
|
-
/**
|
|
16
|
-
* Access is extended to the entire AWS organization.
|
|
17
|
-
*/
|
|
18
|
-
ORGANIZATION = "ORGANIZATION"
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Specifies whether this workspace uses SAML 2.0, AWS IAM Identity Center, or both to authenticate
|
|
22
|
-
* users for using the Grafana console within a workspace.
|
|
23
|
-
*
|
|
24
|
-
* @see https://docs.aws.amazon.com/grafana/latest/APIReference/API_CreateWorkspace.html
|
|
25
|
-
*/
|
|
26
|
-
export declare enum AuthenticationProviders {
|
|
27
|
-
/**
|
|
28
|
-
* AWS Single Sign-On authentication provider.
|
|
29
|
-
*/
|
|
30
|
-
AWS_SSO = "AWS_SSO",
|
|
31
|
-
/**
|
|
32
|
-
* Security Assertion Markup Language (SAML) authentication provider.
|
|
33
|
-
*/
|
|
34
|
-
SAML = "SAML"
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* The configuration settings for network access to your workspace.
|
|
5
|
+
* Properties for creating an Amazon Managed Grafana workspace.
|
|
38
6
|
*/
|
|
39
|
-
export interface
|
|
7
|
+
export interface WorkspaceProps {
|
|
40
8
|
/**
|
|
41
|
-
*
|
|
42
|
-
*
|
|
43
|
-
*
|
|
44
|
-
* workspace.
|
|
9
|
+
* Specifies whether the workspace can access AWS resources in this AWS account only, or whether
|
|
10
|
+
* it can also access AWS resources in other accounts in the same organization. If this is
|
|
11
|
+
* ORGANIZATION, the OrganizationalUnits parameter specifies which organizational units the
|
|
12
|
+
* workspace can access.
|
|
45
13
|
*
|
|
46
|
-
*
|
|
14
|
+
* Required field.
|
|
47
15
|
*/
|
|
48
|
-
readonly
|
|
16
|
+
readonly accountAccessType: AccountAccessType;
|
|
49
17
|
/**
|
|
50
|
-
*
|
|
51
|
-
*
|
|
52
|
-
* is specified then only VPC endpoints specified here are allowed to access the workspace. If
|
|
53
|
-
* you pass in an empty array of strings, then no VPCs are allowed to access the workspace.
|
|
18
|
+
* Specifies whether this workspace uses SAML 2.0, AWS IAM Identity Center, or both to
|
|
19
|
+
* authenticate users for using the Grafana console within a workspace.
|
|
54
20
|
*
|
|
55
|
-
*
|
|
56
|
-
*/
|
|
57
|
-
readonly vpcEndpoints?: IVpcEndpoint[];
|
|
58
|
-
}
|
|
59
|
-
/**
|
|
60
|
-
* The AWS notification channels that Amazon Managed Grafana can automatically create IAM roles and
|
|
61
|
-
* permissions for, to allow Amazon Managed Grafana to use these channels.
|
|
62
|
-
*/
|
|
63
|
-
export declare enum NotificationDestinations {
|
|
64
|
-
/**
|
|
65
|
-
* Amazon Simple Notification Service (SNS) as notification destination.
|
|
66
|
-
*/
|
|
67
|
-
SNS = "SNS"
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* If this is SERVICE_MANAGED, and the workplace was created through the Amazon Managed Grafana
|
|
71
|
-
* console, then Amazon Managed Grafana automatically creates the IAM roles and provisions the
|
|
72
|
-
* permissions that the workspace needs to use AWS data sources and notification channels.
|
|
73
|
-
*
|
|
74
|
-
* If this is CUSTOMER_MANAGED, you must manage those roles and permissions yourself.
|
|
75
|
-
|
|
76
|
-
* If you are working with a workspace in a member account of an organization and that account is
|
|
77
|
-
* not a delegated administrator account, and you want the workspace to access data sources in
|
|
78
|
-
* other AWS accounts in the organization, this parameter must be set to CUSTOMER_MANAGED.
|
|
79
|
-
*/
|
|
80
|
-
export declare enum PermissionTypes {
|
|
81
|
-
/**
|
|
82
|
-
* Customer-managed permissions where you manage user access to Grafana.
|
|
21
|
+
* Required field.
|
|
83
22
|
*/
|
|
84
|
-
|
|
23
|
+
readonly authenticationProviders: AuthenticationProviders[];
|
|
85
24
|
/**
|
|
86
|
-
*
|
|
25
|
+
* A unique, case-sensitive, user-provided identifier to ensure the idempotency of the request.
|
|
26
|
+
*
|
|
27
|
+
* Must be 1-64 characters long and contain only printable ASCII characters.
|
|
87
28
|
*/
|
|
88
|
-
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* A structure that defines which attributes in the IdP assertion are to be used to define
|
|
92
|
-
* information about the users authenticated by the IdP to use the workspace.
|
|
93
|
-
*
|
|
94
|
-
* Each attribute must be a string with length between 1 and 256 characters.
|
|
95
|
-
*/
|
|
96
|
-
export interface SamlAssertionAttributes {
|
|
29
|
+
readonly clientToken?: string;
|
|
97
30
|
/**
|
|
98
|
-
*
|
|
99
|
-
*
|
|
100
|
-
*
|
|
31
|
+
* Specifies the AWS data sources that have been configured to have IAM roles and permissions
|
|
32
|
+
* created to allow Amazon Managed Grafana to read data from these sources.
|
|
33
|
+
* This list is only used when the workspace was created through the AWS console, and the
|
|
34
|
+
* permissionType is SERVICE_MANAGED.
|
|
101
35
|
*/
|
|
102
|
-
readonly
|
|
36
|
+
readonly dataSources?: string[];
|
|
103
37
|
/**
|
|
104
|
-
* The
|
|
105
|
-
* for user groups.
|
|
38
|
+
* The user-defined description of the workspace.
|
|
106
39
|
*
|
|
107
|
-
*
|
|
40
|
+
* Maximum length of 2048 characters.
|
|
108
41
|
*/
|
|
109
|
-
readonly
|
|
42
|
+
readonly description?: string;
|
|
110
43
|
/**
|
|
111
|
-
*
|
|
44
|
+
* Specifies the version of Grafana to support in the workspace. Defaults to the latest version
|
|
45
|
+
* on create (for example, 9.4), or the current version of the workspace on update.
|
|
46
|
+
* Can only be used to upgrade (for example, from 8.4 to 9.4), not downgrade (for example, from
|
|
47
|
+
* 9.4 to 8.4).
|
|
112
48
|
*
|
|
113
|
-
* Must be
|
|
49
|
+
* Must be 1-255 characters long.
|
|
114
50
|
*/
|
|
115
|
-
readonly
|
|
51
|
+
readonly grafanaVersion?: string;
|
|
116
52
|
/**
|
|
117
|
-
* The name of the
|
|
118
|
-
* for SAML users.
|
|
53
|
+
* The name of the workspace.
|
|
119
54
|
*
|
|
120
|
-
* Must be
|
|
55
|
+
* Must be 1-255 characters long and contain only alphanumeric characters, hyphens, dots,
|
|
56
|
+
* underscores, and tildes.
|
|
121
57
|
*/
|
|
122
58
|
readonly name?: string;
|
|
123
59
|
/**
|
|
124
|
-
* The
|
|
125
|
-
* for the users' organizations.
|
|
126
|
-
*
|
|
127
|
-
* Must be between 1 and 256 characters long.
|
|
60
|
+
* The configuration settings for network access to your workspace.
|
|
128
61
|
*/
|
|
129
|
-
readonly
|
|
62
|
+
readonly networkAccessControl?: NetworkAccessControl;
|
|
130
63
|
/**
|
|
131
|
-
* The
|
|
132
|
-
*
|
|
133
|
-
* Must be between 1 and 256 characters long.
|
|
64
|
+
* The AWS notification channels that Amazon Managed Grafana can automatically create IAM roles
|
|
65
|
+
* and permissions for, to allow Amazon Managed Grafana to use these channels.
|
|
134
66
|
*/
|
|
135
|
-
readonly
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* A structure containing the identity provider (IdP) metadata used to integrate the identity
|
|
139
|
-
* provider with this workspace.
|
|
140
|
-
*/
|
|
141
|
-
export interface SamlIdpMetadata {
|
|
67
|
+
readonly notificationDestinations?: NotificationDestinations[];
|
|
142
68
|
/**
|
|
143
|
-
*
|
|
144
|
-
*
|
|
145
|
-
* Must be a string with length between 1 and 2048 characters.
|
|
69
|
+
* Specifies the organizational units that this workspace is allowed to use data sources from, if
|
|
70
|
+
* this workspace is in an account that is part of an organization.
|
|
146
71
|
*/
|
|
147
|
-
readonly
|
|
72
|
+
readonly organizationalUnits?: string[];
|
|
148
73
|
/**
|
|
149
|
-
*
|
|
74
|
+
* Name of the IAM role to use for the organization.
|
|
75
|
+
* Maximum length of 2048 characters.
|
|
150
76
|
*/
|
|
151
|
-
readonly
|
|
152
|
-
}
|
|
153
|
-
/**
|
|
154
|
-
* A structure containing arrays that map group names in the SAML assertion to the Grafana Admin
|
|
155
|
-
* and Editor roles in the workspace.
|
|
156
|
-
*/
|
|
157
|
-
export interface SamlRoleValues {
|
|
77
|
+
readonly organizationRoleName?: string;
|
|
158
78
|
/**
|
|
159
|
-
*
|
|
79
|
+
* If this is SERVICE_MANAGED, and the workplace was created through the Amazon Managed Grafana
|
|
80
|
+
* console, then Amazon Managed Grafana automatically creates the IAM roles and provisions the
|
|
81
|
+
* permissions that the workspace needs to use AWS data sources and notification channels.
|
|
160
82
|
*
|
|
161
|
-
*
|
|
162
|
-
*/
|
|
163
|
-
readonly admin?: string[];
|
|
164
|
-
/**
|
|
165
|
-
* A list of groups from the SAML assertion attribute to grant the Grafana Editor role to.
|
|
83
|
+
* If this is CUSTOMER_MANAGED, you must manage those roles and permissions yourself.
|
|
166
84
|
*
|
|
167
|
-
*
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
}
|
|
171
|
-
/**
|
|
172
|
-
* If the workspace uses SAML, use this structure to map SAML assertion attributes to workspace
|
|
173
|
-
* user information and define which groups in the assertion attribute are to have the Admin and
|
|
174
|
-
* Editor roles in the workspace.
|
|
175
|
-
*/
|
|
176
|
-
export interface SamlConfiguration {
|
|
177
|
-
/**
|
|
178
|
-
* Lists which organizations defined in the SAML assertion are allowed to use the Amazon Managed
|
|
179
|
-
* Grafana workspace. If this is empty, all organizations in the assertion attribute have access.
|
|
85
|
+
* If you are working with a workspace in a member account of an organization and that account is
|
|
86
|
+
* not a delegated administrator account, and you want the workspace to access data sources in
|
|
87
|
+
* other AWS accounts in the organization, this parameter must be set to CUSTOMER_MANAGED.
|
|
180
88
|
*
|
|
181
|
-
*
|
|
182
|
-
*/
|
|
183
|
-
readonly allowedOrganizations?: string[];
|
|
184
|
-
/**
|
|
185
|
-
* A structure that defines which attributes in the SAML assertion are to be used to define
|
|
186
|
-
* information about the users authenticated by that IdP to use the workspace.
|
|
89
|
+
* Required field.
|
|
187
90
|
*/
|
|
188
|
-
readonly
|
|
91
|
+
readonly permissionType: PermissionTypes;
|
|
189
92
|
/**
|
|
190
|
-
*
|
|
191
|
-
*
|
|
93
|
+
* Whether plugin administration is enabled in the workspace. Setting to true allows workspace
|
|
94
|
+
* admins to install, uninstall, and update plugins from within the Grafana workspace.
|
|
95
|
+
*
|
|
96
|
+
* This option is only valid for workspaces that support Grafana version 9 or newer.
|
|
192
97
|
*
|
|
193
|
-
*
|
|
98
|
+
* Default: false
|
|
194
99
|
*/
|
|
195
|
-
readonly
|
|
100
|
+
readonly pluginAdminEnabled?: boolean;
|
|
196
101
|
/**
|
|
197
|
-
*
|
|
198
|
-
*
|
|
199
|
-
* Must be a positive number.
|
|
102
|
+
* The IAM role that grants permissions to the AWS resources that the workspace will view data
|
|
103
|
+
* from.
|
|
200
104
|
*/
|
|
201
|
-
readonly
|
|
105
|
+
readonly role?: IRole;
|
|
202
106
|
/**
|
|
203
|
-
*
|
|
204
|
-
* and
|
|
107
|
+
* If the workspace uses SAML, use this structure to map SAML assertion attributes to workspace
|
|
108
|
+
* user information and define which groups in the assertion attribute are to have the Admin and
|
|
109
|
+
* Editor roles in the workspace.
|
|
205
110
|
*/
|
|
206
|
-
readonly
|
|
207
|
-
}
|
|
208
|
-
/**
|
|
209
|
-
* The configuration settings for an Amazon VPC that contains data sources for your Grafana
|
|
210
|
-
* workspace to connect to.
|
|
211
|
-
*/
|
|
212
|
-
export interface VpcConfiguration {
|
|
111
|
+
readonly samlConfiguration?: SamlConfiguration;
|
|
213
112
|
/**
|
|
214
|
-
* The
|
|
215
|
-
* workspace
|
|
216
|
-
*
|
|
217
|
-
* Array Members: Minimum number of 1 items. Maximum number of 5 items.
|
|
218
|
-
*
|
|
219
|
-
* Required for VPC configuration.
|
|
113
|
+
* The name of the AWS CloudFormation stack set that is used to generate IAM roles to be used for
|
|
114
|
+
* this workspace.
|
|
220
115
|
*/
|
|
221
|
-
readonly
|
|
116
|
+
readonly stackSetName?: string;
|
|
222
117
|
/**
|
|
223
|
-
* The
|
|
224
|
-
*
|
|
225
|
-
*
|
|
226
|
-
* Array Members: Minimum number of 2 items. Maximum number of 6 items.
|
|
227
|
-
*
|
|
228
|
-
* Required for VPC configuration.
|
|
118
|
+
* The configuration settings for an Amazon VPC that contains data sources for your Grafana
|
|
119
|
+
* workspace to connect to.
|
|
229
120
|
*/
|
|
230
|
-
readonly
|
|
121
|
+
readonly vpcConfiguration?: VpcConfiguration;
|
|
231
122
|
}
|
|
232
|
-
|
|
233
|
-
* Properties for creating an Amazon Managed Grafana workspace.
|
|
234
|
-
*/
|
|
235
|
-
export interface WorkspaceProps {
|
|
123
|
+
export interface WorkspaceAttributes {
|
|
236
124
|
/**
|
|
237
125
|
* Specifies whether the workspace can access AWS resources in this AWS account only, or whether
|
|
238
126
|
* it can also access AWS resources in other accounts in the same organization. If this is
|
|
@@ -268,15 +156,6 @@ export interface WorkspaceProps {
|
|
|
268
156
|
* Maximum length of 2048 characters.
|
|
269
157
|
*/
|
|
270
158
|
readonly description?: string;
|
|
271
|
-
/**
|
|
272
|
-
* Specifies the version of Grafana to support in the workspace. Defaults to the latest version
|
|
273
|
-
* on create (for example, 9.4), or the current version of the workspace on update.
|
|
274
|
-
* Can only be used to upgrade (for example, from 8.4 to 9.4), not downgrade (for example, from
|
|
275
|
-
* 9.4 to 8.4).
|
|
276
|
-
*
|
|
277
|
-
* Must be 1-255 characters long.
|
|
278
|
-
*/
|
|
279
|
-
readonly grafanaVersion?: string;
|
|
280
159
|
/**
|
|
281
160
|
* The name of the workspace.
|
|
282
161
|
*
|
|
@@ -347,75 +226,26 @@ export interface WorkspaceProps {
|
|
|
347
226
|
* workspace to connect to.
|
|
348
227
|
*/
|
|
349
228
|
readonly vpcConfiguration?: VpcConfiguration;
|
|
350
|
-
}
|
|
351
|
-
/**
|
|
352
|
-
* Status of SAML configuration for a Grafana workspace.
|
|
353
|
-
*/
|
|
354
|
-
export declare enum SamlConfigurationStatuses {
|
|
355
|
-
/**
|
|
356
|
-
* SAML is configured for the workspace.
|
|
357
|
-
*/
|
|
358
|
-
CONFIGURED = "CONFIGURED",
|
|
359
|
-
/**
|
|
360
|
-
* SAML is not configured for the workspace.
|
|
361
|
-
*/
|
|
362
|
-
NOT_CONFIGURED = "NOT_CONFIGURED"
|
|
363
|
-
}
|
|
364
|
-
/**
|
|
365
|
-
* Status of a Grafana workspace.
|
|
366
|
-
*/
|
|
367
|
-
export declare enum Status {
|
|
368
|
-
/**
|
|
369
|
-
* Workspace is active and ready to use.
|
|
370
|
-
*/
|
|
371
|
-
ACTIVE = "ACTIVE",
|
|
372
229
|
/**
|
|
373
|
-
*
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
/**
|
|
377
|
-
* Workspace is being deleted.
|
|
378
|
-
*/
|
|
379
|
-
DELETING = "DELETING",
|
|
380
|
-
/**
|
|
381
|
-
* Workspace operation has failed.
|
|
382
|
-
*/
|
|
383
|
-
FAILED = "FAILED",
|
|
384
|
-
/**
|
|
385
|
-
* Workspace is being updated.
|
|
386
|
-
*/
|
|
387
|
-
UPDATING = "UPDATING",
|
|
388
|
-
/**
|
|
389
|
-
* Workspace is being upgraded.
|
|
390
|
-
*/
|
|
391
|
-
UPGRADING = "UPGRADING",
|
|
392
|
-
/**
|
|
393
|
-
* Workspace deletion has failed.
|
|
394
|
-
*/
|
|
395
|
-
DELETION_FAILED = "DELETION_FAILED",
|
|
396
|
-
/**
|
|
397
|
-
* Workspace creation has failed.
|
|
398
|
-
*/
|
|
399
|
-
CREATION_FAILED = "CREATION_FAILED",
|
|
400
|
-
/**
|
|
401
|
-
* Workspace update has failed.
|
|
402
|
-
*/
|
|
403
|
-
UPDATE_FAILED = "UPDATE_FAILED",
|
|
404
|
-
/**
|
|
405
|
-
* Workspace upgrade has failed.
|
|
230
|
+
* The arn of this workspace.
|
|
231
|
+
*
|
|
232
|
+
* Either this or the workspaceId must be provided.
|
|
406
233
|
*/
|
|
407
|
-
|
|
234
|
+
readonly workspaceArn?: string;
|
|
408
235
|
/**
|
|
409
|
-
*
|
|
236
|
+
* The unique ID of this workspace.
|
|
237
|
+
*
|
|
238
|
+
* Either this or the workspaceArn must be provided.
|
|
410
239
|
*/
|
|
411
|
-
|
|
240
|
+
readonly workspaceId?: string;
|
|
412
241
|
}
|
|
413
242
|
/**
|
|
414
243
|
* Specifies a workspace. In a workspace, you can create Grafana dashboards and visualizations to
|
|
415
244
|
* analyze your metrics, logs, and traces. You don't have to build, package, or deploy any hardware
|
|
416
245
|
* to run the Grafana server.
|
|
417
246
|
*/
|
|
418
|
-
export declare class Workspace extends
|
|
247
|
+
export declare class Workspace extends WorkspaceBase {
|
|
248
|
+
static fromWorkspaceAttributes(scope: Construct, id: string, attrs: WorkspaceAttributes): IWorkspace;
|
|
419
249
|
/**
|
|
420
250
|
* Validates the clientToken property.
|
|
421
251
|
*
|
|
@@ -656,7 +486,7 @@ export declare class Workspace extends Construct {
|
|
|
656
486
|
/**
|
|
657
487
|
* The unique ID of this workspace.
|
|
658
488
|
*/
|
|
659
|
-
readonly
|
|
489
|
+
readonly workspaceId: string;
|
|
660
490
|
/**
|
|
661
491
|
* The most recent date that the workspace was modified.
|
|
662
492
|
*/
|
|
@@ -674,5 +504,9 @@ export declare class Workspace extends Construct {
|
|
|
674
504
|
* The current status of the workspace.
|
|
675
505
|
*/
|
|
676
506
|
readonly status: Status;
|
|
507
|
+
/**
|
|
508
|
+
* The arn of this workspace.
|
|
509
|
+
*/
|
|
510
|
+
readonly workspaceArn: string;
|
|
677
511
|
constructor(scope: Construct, id: string, props: WorkspaceProps);
|
|
678
512
|
}
|