Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

prepare 2.10.0 release #134

Closed
wants to merge 122 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
122 commits
Select commit Hold shift + click to select a range
8fd56bd
prepare release (#80) (#188)
sloloris Jan 20, 2022
aea6005
Do not allow 0% segment rule weights (#189)
ldhenry Jan 21, 2022
f1e972c
Fix flag trigger creation panic (#190)
ldhenry Jan 21, 2022
09a6fa3
Backmerge/release 2.4.1 (#191)
ldhenry Jan 21, 2022
e493b76
Add Slack webhooks to audit_log_subscription (#192)
ldhenry Feb 7, 2022
2512cf3
backmerge v2.5.0 (#193)
ldhenry Feb 8, 2022
f4332bc
Use jennifer to generate audit log subscription configs (#194)
ldhenry Feb 8, 2022
de0fe41
Run terraform provider acceptance tests daily and notify of failures …
ldhenry Feb 8, 2022
9a38dde
Update changelog branch (#195)
ldhenry Feb 9, 2022
d285706
[ sc-143291] update autogenerated audit_log_subscription configs (#197)
monsagri Mar 14, 2022
42d99ac
Increase checkpoint-api.harhicorp.com timeout to 10s (#198)
ldhenry Mar 17, 2022
04b73ff
Updated destination tests to use random env keys to avoid env conflic…
ctawiah Apr 6, 2022
b6bc3f2
Merge pull request #199 from launchdarkly/ctawiah/sc-148136/randomize…
ctawiah Apr 6, 2022
e722f06
[sc 148065] add approvals bypass to terraform docs (#200)
monsagri Apr 7, 2022
b88452a
Backmerge/release 2.6.0 (#201)
monsagri Apr 7, 2022
ae41bdb
fix doc issues (#202)
sloloris Apr 14, 2022
a402d11
[sc-149869] roll back documentation changes regarding (#203)
monsagri Apr 14, 2022
66d55a1
backmerge 2.6.1 (#204)
monsagri Apr 14, 2022
494df8f
Imiller/sc 151834/add base permissions to custom role resource (#205)
sloloris May 4, 2022
38d70bc
Backmerge/release 2.7.0 (#206)
sloloris May 5, 2022
6559f71
(bug-fix) Update modules to accept new API header
May 11, 2022
4795ea3
Merge pull request #207 from launchdarkly/fix-ci
lucywyman May 13, 2022
626aaae
Update circleci test timeout to 15 seconds
May 19, 2022
2c88570
Merge pull request #208 from launchdarkly/sunny/sc-153482/increase-ti…
lucywyman May 20, 2022
9084524
Regenerate auditlog configs to resolve CI failures (#211)
ldhenry Jun 30, 2022
54dbc29
Run make generate to supress CI failures (#212)
ldhenry Jul 11, 2022
b9a3419
added a check for environment and warning
Jul 12, 2022
c073a3b
fix go lint error
Jul 12, 2022
822f9d8
Merge branch 'main' into sunny/sc-158595/leftover-resources-cannot-be…
Jul 12, 2022
2ba884b
use environmentExists function
Jul 12, 2022
dd21dac
remove grafana
Jul 13, 2022
66c862c
fix: [sc-158595] leftover resources cannot be cleared out after launc…
Jul 13, 2022
88840f0
Update changelog with bug fix for datasource feature flag environment
Jul 13, 2022
33a1f9f
Merge pull request #215 from launchdarkly/sunny/update-changelog-data…
lucywyman Jul 14, 2022
7b218fe
added changes
Jul 26, 2022
c1a3b89
Merge pull request #216 from launchdarkly/backmerge/release-2.7.1
Jul 26, 2022
70c9c34
upgrade go version 1.18.1 (#217)
sloloris Jul 27, 2022
8bee33e
Backmerge public/release v2.7.1 3 (#219)
ldhenry Jul 27, 2022
402b508
Remove invalid integration configurations (#221)
ldhenry Jul 28, 2022
db398b8
Add blacklist to manifest codegen and remove Zapier. (#222)
ldhenry Jul 28, 2022
b9e966d
Backmerge release 2.7.2 (#223)
ldhenry Jul 28, 2022
e7d7f77
Update Go api client to 10.0.1
Jun 28, 2022
6a6345e
Fix up v10 migration PR
Jul 28, 2022
11e3b82
Merge pull request #225 from launchdarkly/migrate-terraform-to-v10
lucywyman Jul 28, 2022
e9c8d43
[SC-160359] Create Teams resource and datasource
Jun 28, 2022
1d1e3d3
Fix up documentation
Aug 3, 2022
70e838e
Make lists unsorted to avoid unnecessary change detection
Aug 3, 2022
8fb4544
Update website/docs/d/team.html.markdown
lucywyman Aug 3, 2022
a97b4ae
Make lists unsorted to avoid unnecessary change detection
Aug 3, 2022
1cd0737
Merge pull request #224 from launchdarkly/dominickagnello/sc-160359/u…
lucywyman Aug 4, 2022
da5dacd
prepare 2.6.0 release (#91)
monsagri Apr 7, 2022
43ee03b
prepare 2.6.1 release (#94)
monsagri Apr 14, 2022
519707a
Prepare 2.7.1 release (#103)
Jul 25, 2022
1d371d9
Prepare release 2.7.1 2 (#104)
sloloris Jul 27, 2022
6276ea6
fix merge issue in Circle config (#105)
ldhenry Jul 27, 2022
76f1bcf
Release 2.7.2 (#106)
ldhenry Jul 28, 2022
416ec8b
prepare 2.8.0 release
Aug 4, 2022
8569589
Merge pull request #227 from launchdarkly/backmerge/release-2.8.0
lucywyman Aug 4, 2022
f21dd2c
[SC-163244] Add no-access role for team member resource
Aug 5, 2022
aded53f
Merge pull request #228 from launchdarkly/lucyvoigt/sc-163244/add-no-…
lucywyman Aug 5, 2022
f8caaea
Backmerge 2.9.0 release
Aug 5, 2022
72236a5
[sc-147722] add codeowners file (#230)
monsagri Aug 9, 2022
fd4a7de
Merge pull request #229 from launchdarkly/backmerge/release-2.9.0
lucywyman Aug 10, 2022
c60959a
Dominickagnello/sc 163883/open a pr against the terraform provider (#…
Blugil Aug 10, 2022
8ceb94b
add conditional so that new action only runs in private repo
Aug 10, 2022
229b5b9
Remove example.com email addresses from acceptance tests (#234)
ldhenry Aug 10, 2022
d459813
Retry failed acceptance tests once
Aug 10, 2022
e23033f
Merge pull request #235 from launchdarkly/retry-failed-tests-once
lucywyman Aug 10, 2022
124c1da
Merge pull request #233 from launchdarkly/dominickagnello/sc-163883/o…
lucywyman Aug 11, 2022
362669f
[SC-163262] Suppress diff when value_type doesn't change
Aug 5, 2022
c1ff182
Update launchdarkly/clause_helper.go
lucywyman Aug 23, 2022
a83f848
Merge pull request #236 from launchdarkly/lucyvoigt/sc-163262/don-t-s…
lucywyman Aug 24, 2022
e7affce
[bot] Regenerate integration configs (#237)
github-actions[bot] Aug 24, 2022
b8c9085
Update feature_flag_environmewnt to only create patch statements when…
ldhenry Aug 24, 2022
07e3cc0
merge public/main (#239)
ldhenry Aug 24, 2022
8311a3a
Imiller/sc 166499/defaults for boolean flags do not apply to existing…
sloloris Sep 1, 2022
9e135b6
Backmerge public (#241)
ldhenry Sep 1, 2022
c65030c
Imiller/sc 168660/terraform issue importing project with environments…
sloloris Sep 13, 2022
628672e
[SC-169876] Correctly set bucketBy to nil when empty
Sep 20, 2022
a438dfa
[SC-168865] Print error message with API errors
Sep 13, 2022
c7c9269
Merge pull request #242 from launchdarkly/lucyvoigt/sc-168865/hi-team…
lucywyman Sep 26, 2022
3dcf1bc
Merge pull request #244 from launchdarkly/lucyvoigt/sc-169876/launchd…
lucywyman Sep 26, 2022
3a6f10e
[SC-170290] Add ignore_changes guide to Terraform docs
Sep 28, 2022
8134e76
Merge pull request #245 from launchdarkly/lucyvoigt/sc-170290/update-…
lucywyman Sep 30, 2022
5f2984c
Backmerge 2.9.3 release
Oct 3, 2022
384cfb9
Merge pull request #246 from launchdarkly/backmerge/release-2.9.3
lucywyman Oct 3, 2022
259ab96
[SC-174121] Docs bug fixes
Oct 26, 2022
f8d6a58
Merge pull request #247 from launchdarkly/lucyvoigt/sc-174121/fix-gui…
lucywyman Oct 26, 2022
fae2eba
Imiller/sc 162868/update documentation on using feature flag env sett…
sloloris Oct 31, 2022
94298b1
update links to docs.launchdarkly
mmrj Jan 9, 2023
0940048
Apply some additional copy suggestions from code review
mmrj Jan 9, 2023
b88eb72
add changelog entry
mmrj Jan 10, 2023
5eb15a1
Update CHANGELOG.md
sloloris Jan 10, 2023
7342d64
Merge pull request #251 from launchdarkly/mollyjones2723/sc-182866/in…
mmrj Jan 10, 2023
dfafc3b
should not be able to set targets with empty values (#252)
sloloris Jan 10, 2023
15ee255
fix test (#255)
sloloris Jan 10, 2023
33de477
fix retry command (#254)
sloloris Jan 10, 2023
3d214ef
Update generated audit log config (#267)
sloloris Jan 27, 2023
76a985f
merge main from public?
sloloris Jan 27, 2023
f792697
backmerge (#268)
sloloris Jan 30, 2023
a2b4c4a
[bot] Regenerate integration configs (#269)
github-actions[bot] Feb 1, 2023
2289644
Add optional targeting rule descriptions (#270)
ldhenry Feb 1, 2023
f240372
[bot] Regenerate integration configs
Blugil Feb 8, 2023
143d6d0
Merge pull request #272 from launchdarkly/regenerate-integration-conf…
lucywyman Feb 9, 2023
0d4a2e5
[bot] Regenerate integration configs
Blugil Feb 9, 2023
f6b2ccd
Merge pull request #273 from launchdarkly/regenerate-integration-conf…
lucywyman Feb 9, 2023
8d57914
add ldrelease metadata (#275)
monsagri Feb 16, 2023
4fd103c
[sc 189042] update project releaser config (#276)
monsagri Feb 21, 2023
30edd7c
Releasing version 2.9.6
Feb 21, 2023
98b5c1a
[sc 189042] update project releaser config permissions (#277)
monsagri Feb 21, 2023
a9cee2a
Releasing version 2.9.6
Feb 21, 2023
562f945
[sc 189042] update project releaser artifacts (#278)
monsagri Feb 21, 2023
81b0692
Releasing version 2.9.6
Feb 21, 2023
8233722
add update-version back in (#279)
monsagri Feb 21, 2023
7f383af
Releasing version 2.9.7
Feb 21, 2023
db1bbff
fix changelog (#280)
monsagri Feb 21, 2023
e3061c6
Releasing version 2.9.7
Feb 21, 2023
66c0c5b
(maint) Document 'archived' attribute of feature_flag
Feb 21, 2023
a834b44
[sc 189042] automate terraform provider releases 2 (#282)
monsagri Feb 22, 2023
23dcf51
Merge pull request #281 from launchdarkly/add-archive-docs
lucywyman Feb 22, 2023
0d0a853
Imiller/sc 189789/investigate workarounds for default CSA issue (#283)
sloloris Feb 27, 2023
e8c0052
Merge branch 'main' into release-2.10.0
sloloris Feb 27, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
## [2.9.5] (January 30, 2023)
## [2.9.5] - 2023-01-30

BUG FIXES:

Expand All @@ -21,7 +21,7 @@ BUG FIXES:
BUG FIXES:

- Correctly set bucketBy to nil when explicitly set to an empty string to avoid API errors [#120](https://github.com/launchdarkly/terraform-provider-launchdarkly/issues/120)
- Print error message from API response for Teams resource
- Print error message from API response for `launchdarkly_team` resource

NOTES:

Expand Down
24 changes: 24 additions & 0 deletions examples/tst/.terraform.lock.hcl

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

53 changes: 53 additions & 0 deletions examples/tst/flags.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
# resource "launchdarkly_feature_flag" "boolean_flag" {
# project_key = "default"
# key = "a-customer-test-flag"
# name = "A customer test flag"
# description = "An example boolean feature flag that can be turned either on or off"
# variation_type = "boolean"

# defaults {
# on_variation = 1
# off_variation = 1
# }

# client_side_availability {
# using_environment_id = true
# }
# }

# resource "launchdarkly_feature_flag" "completeTheLook" {
# project_key = launchdarkly_project.a_new_test_proj.key
# key = "completeTheLook"
# name = "Complete The Look"
# description = "Dunelm Web Complete The Look Flag"
# variation_type = "boolean"

# variations {
# value = true
# }

# variations {
# value = false
# }

# tags = [
# "terraform"
# ]

# }

# resource "launchdarkly_feature_flag_environment" "completeTheLook_dundev" {
# flag_id = launchdarkly_feature_flag.completeTheLook.id
# env_key = "production"
# off_variation = 0
# on = true

# fallthrough {
# variation = 0
# }
# # lifecycle {
# # ignore_changes = [
# # fallthrough
# # ]
# # }
# }
33 changes: 33 additions & 0 deletions examples/tst/project_with_multiple_envs.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# resource "launchdarkly_project" "a_new_test_proj" {
# key = "a-new-test-proj"
# name = "A New Test Project"
# tags = ["customer-test"]

# environments {
# key = "yet-another-environm"
# name = "Yet Another Environment"
# color = "121212"
# tags = []
# }

# environments {
# key = "another-environment"
# name = "Another Environment"
# color = "ABCABC"
# tags = []
# }

# environments {
# key = "test"
# name = "Test"
# color = "F5A623"
# tags = []
# }

# environments {
# key = "production"
# name = "Production"
# color = "417505"
# tags = []
# }
# }
9 changes: 9 additions & 0 deletions examples/tst/versions.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
terraform {
required_providers {
launchdarkly = {
source = "launchdarkly/launchdarkly"
version = ">= 2.9.4"
}
}
required_version = ">= 0.13"
}
26 changes: 26 additions & 0 deletions launchdarkly/audit_log_subscription_configs_generated.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,32 @@
package launchdarkly

var SUBSCRIPTION_CONFIGURATION_FIELDS = map[string]IntegrationConfig{
"cloudtrail": {
"accountId": {
AllowedValues: []string{},
DefaultValue: "",
Description: "Enter your [AWS account ID](https://docs.aws.amazon.com/IAM/latest/UserGuide/console_account-alias.html#FindingYourAWSId). The associated account must be configured to use CloudTrail Lake.",
IsOptional: true,
IsSecret: false,
Type: "string",
},
"externalId": {
AllowedValues: []string{},
DefaultValue: nil,
Description: "Use this [external id](https://docs.launchdarkly.com/integrations/cloudtrail) for your resource policy when setting up the integration in the AWS Console.",
IsOptional: false,
IsSecret: false,
Type: "generated",
},
"ingestionChannelArn": {
AllowedValues: []string{},
DefaultValue: nil,
Description: "Enter the Channel ARN for LaunchDarkly to use.",
IsOptional: false,
IsSecret: false,
Type: "string",
},
},
"datadog": {
"apiKey": {
AllowedValues: []string{},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,8 @@ func TestAccDataSourceFeatureFlagEnvironment_exists(t *testing.T) {

rules := []rule{
{
Variation: intPtr(1),
Description: strPtr("test rule"),
Variation: intPtr(1),
Clauses: []ldapi.Clause{
{
Attribute: "thing",
Expand Down Expand Up @@ -155,6 +156,7 @@ func TestAccDataSourceFeatureFlagEnvironment_exists(t *testing.T) {
resource.TestCheckResourceAttr(resourceName, ENV_KEY, envKey),
resource.TestCheckResourceAttr(resourceName, ON, fmt.Sprint(thisConfig.On)),
resource.TestCheckResourceAttr(resourceName, TRACK_EVENTS, fmt.Sprint(thisConfig.TrackEvents)),
resource.TestCheckResourceAttr(resourceName, "rules.0.description", *thisConfig.Rules[0].Description),
resource.TestCheckResourceAttr(resourceName, "rules.0.variation", fmt.Sprint(*thisConfig.Rules[0].Variation)),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.attribute", thisConfig.Rules[0].Clauses[0].Attribute),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.op", thisConfig.Rules[0].Clauses[0].Op),
Expand Down
70 changes: 5 additions & 65 deletions launchdarkly/resource_launchdarkly_feature_flag.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,54 +9,6 @@ import (
ldapi "github.com/launchdarkly/api-client-go/v10"
)

// We assign a custom diff in cases where the customer has not assigned CSA or IIS in config for a flag in order to respect project level defaults
func customizeFlagDiff(ctx context.Context, diff *schema.ResourceDiff, v interface{}) error {
config := diff.GetRawConfig()
client := v.(*Client)
projectKey := diff.Get(PROJECT_KEY).(string)

// Below values will exist due to the schema, we need to check if they are all null
snippetInConfig := config.GetAttr(INCLUDE_IN_SNIPPET)
csaInConfig := config.GetAttr(CLIENT_SIDE_AVAILABILITY)

// If we have no keys in the CSA block in the config (length is 0) we know the customer hasn't set any CSA values
csaKeys := csaInConfig.AsValueSlice()
if len(csaKeys) == 0 {
// When we have no values for either clienSideAvailability or includeInSnippet
// Force an UPDATE call by setting a new value for INCLUDE_IN_SNIPPET in the diff according to project defaults
if snippetInConfig.IsNull() {
defaultCSA, includeInSnippetByDefault, err := getProjectDefaultCSAandIncludeInSnippet(client, projectKey)
// We will fall into this block during the first config read when a user creates a flag at the same time they create the parent project
// (and during our tests)
// We can ignore the error here, as it is correctly handled during update/create (and doesn't occur then as the project will have been created)
if err != nil {
} else {
// We set our values to the project defaults in order to guarantee an update call happening
// If we don't do this, we can run into an edge case described below
// IF previous value of INCLUDE_IN_SNIPPET was false
// AND the project default value for INCLUDE_IN_SNIPPET is true
// AND the customer removes the INCLUDE_IN_SNIPPET key from the config without replacing with defaultCSA
// The read would assume no changes are needed, HOWEVER we need to jump back to project level set defaults
// Hence the setting below
err := diff.SetNew(INCLUDE_IN_SNIPPET, includeInSnippetByDefault)
if err != nil {
return err
}
err = diff.SetNew(CLIENT_SIDE_AVAILABILITY, []map[string]interface{}{{
USING_ENVIRONMENT_ID: defaultCSA.UsingEnvironmentId,
USING_MOBILE_KEY: defaultCSA.UsingMobileKey,
}})
if err != nil {
return err
}
}
}

}

return nil
}

func resourceFeatureFlag() *schema.Resource {
schemaMap := baseFeatureFlagSchema()
schemaMap[NAME] = &schema.Schema{
Expand All @@ -75,8 +27,7 @@ func resourceFeatureFlag() *schema.Resource {
Importer: &schema.ResourceImporter{
State: resourceFeatureFlagImport,
},
Schema: schemaMap,
CustomizeDiff: customizeFlagDiff,
Schema: schemaMap,
}
}

Expand Down Expand Up @@ -211,25 +162,14 @@ func resourceFeatureFlagUpdate(ctx context.Context, d *schema.ResourceData, meta
patchReplace("/archived", archived),
}}

// if it was previously set and then removed, we don't want to update it or revert to project defaults in this case
// because the LD API only sets it to project defaults upon flag creation and those defaults may have changed since
if clientSideAvailabilityOk && clientSideHasChange {
patch.Patch = append(patch.Patch, patchReplace("/clientSideAvailability", clientSideAvailability))
} else if includeInSnippetOk && snippetHasChange {
// If includeInSnippet is set, still use clientSideAvailability behind the scenes in order to switch UsingMobileKey to false if needed
patch.Patch = append(patch.Patch, patchReplace("/clientSideAvailability", &ldapi.ClientSideAvailabilityPost{
UsingEnvironmentId: includeInSnippet,
UsingMobileKey: false,
}))
} else {
// If the user doesn't set either CSA or IIS in config, we pull the defaults from their Project level settings and apply those
// IncludeInSnippetdefault is the same as defaultCSA.UsingEnvironmentId, so we can _ it
defaultCSA, _, err := getProjectDefaultCSAandIncludeInSnippet(client, projectKey)
if err != nil {
return diag.Errorf("failed to get project level client side availability defaults. %v", err)
}
patch.Patch = append(patch.Patch, patchReplace("/clientSideAvailability", &ldapi.ClientSideAvailabilityPost{
UsingEnvironmentId: *defaultCSA.UsingEnvironmentId,
UsingMobileKey: *defaultCSA.UsingMobileKey,
}))
clientSideAvailability.UsingEnvironmentId = includeInSnippet // overwrite with user-set value
patch.Patch = append(patch.Patch, patchReplace("/clientSideAvailability", clientSideAvailability))
}

variationPatches, err := variationPatchesFromResourceData(d)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,7 @@ resource "launchdarkly_feature_flag_environment" "basic" {
variation = 0
}
rules {
description = "names that start with 'h'"
clauses {
attribute = "name"
op = "startsWith"
Expand Down Expand Up @@ -539,6 +540,7 @@ func TestAccFeatureFlagEnvironment_Update(t *testing.T) {
resource.TestCheckResourceAttr(resourceName, "targets.0.variation", "1"),
resource.TestCheckResourceAttr(resourceName, "targets.0.values.1", "user2"),
resource.TestCheckResourceAttr(resourceName, "rules.#", "2"),
resource.TestCheckResourceAttr(resourceName, "rules.0.description", ""),
resource.TestCheckResourceAttr(resourceName, "rules.0.variation", "0"),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.#", "1"),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.attribute", "country"),
Expand All @@ -547,6 +549,7 @@ func TestAccFeatureFlagEnvironment_Update(t *testing.T) {
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.values.0", "great"),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.values.1", "amazing"),
resource.TestCheckResourceAttr(resourceName, "rules.0.clauses.0.negate", "false"),
resource.TestCheckResourceAttr(resourceName, "rules.1.description", "names that start with 'h'"),
resource.TestCheckResourceAttr(resourceName, "rules.1.rollout_weights.#", "3"),
resource.TestCheckResourceAttr(resourceName, "rules.1.rollout_weights.0", "90000"),
resource.TestCheckResourceAttr(resourceName, "rules.1.rollout_weights.1", "10000"),
Expand All @@ -560,6 +563,11 @@ func TestAccFeatureFlagEnvironment_Update(t *testing.T) {
resource.TestCheckResourceAttr(resourceName, OFF_VARIATION, "1"),
),
},
{
ResourceName: resourceName,
ImportState: true,
ImportStateVerify: true,
},
// After changes have been made to the resource, removing optional values should revert to their default / null values.
{
Config: withRandomProject(projectKey, testAccFeatureFlagEnvironmentEmpty),
Expand Down
Loading