Skip to content

Commit

Permalink
Add config for shadow user creation (#491)
Browse files Browse the repository at this point in the history
- Add UAA client to ccng
- Add `allow_user_creation_by_org_manager` config
  • Loading branch information
svkrieger authored Jan 9, 2025
1 parent 2fc757a commit 577b509
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 0 deletions.
5 changes: 5 additions & 0 deletions jobs/cloud_controller_ng/spec
Original file line number Diff line number Diff line change
Expand Up @@ -1006,6 +1006,9 @@ properties:
uaa.clients.cloud_controller_username_lookup.secret:
description: "Used for fetching usernames from UAA"

uaa.clients.cloud_controller_shadow_user_creation.secret:
description: "Used for creating UAA shadow users when `cc.allow_user_creation_by_org_manager` is enabled."

uaa.clients.cc_service_key_client.secret:
description: "Used for fetching service key values from CredHub"

Expand Down Expand Up @@ -1286,6 +1289,8 @@ properties:
description: "Use deprecated Thin webserver. Please note that when using Thin instead of Puma you miss out on the following benefits: Better resource utilization, well maintained and more performant. Thin will be removed in a future release. `cc.experimental.use_puma_webserver` takes precedence over this."
default: false

cc.allow_user_creation_by_org_manager:
description: "Allow org managers to explicitly create UAA shadow users through /v3/users and implicitly through /v3/roles. `uaa.clients.cloud_controller_shadow_user_creation.secret` must be set."

# deprecated configuration

Expand Down
10 changes: 10 additions & 0 deletions jobs/cloud_controller_ng/templates/cloud_controller_ng.yml.erb
Original file line number Diff line number Diff line change
Expand Up @@ -256,6 +256,12 @@ uaa:
<% if_p("uaa.cc.token_secret2") do |token_secret2| %>
symmetric_secret2: "<%= token_secret2 %>"
<% end %>
clients:
<% if_p("uaa.clients.cloud_controller_shadow_user_creation.secret") do |secret| %>
- name: "cloud_controller_shadow_user_creation"
id: "cloud_controller_shadow_user_creation"
secret: <%= secret %>
<% end %>

<% if p("routing_api.enabled") %>
routing_api:
Expand Down Expand Up @@ -562,3 +568,7 @@ threadpool_size: <%= p("cc.experimental.thin_server.thread_pool_size") %>
default_app_lifecycle: buildpack
custom_metric_tag_prefix_list: <%= p("cc.custom_metric_tag_prefix_list") %>
update_metric_tags_on_rename: <%= p("cc.update_metric_tags_on_rename") %>

<% if_p("cc.allow_user_creation_by_org_manager") do |allow_user_creation| %>
allow_user_creation_by_org_manager: <%= allow_user_creation %>
<% end %>
53 changes: 53 additions & 0 deletions spec/cloud_controller_ng/cloud_controller_ng_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -850,6 +850,59 @@ module Test
end
end
end

describe 'allow_user_creation_by_org_manager' do
context 'when it is not set' do
it 'does not render into the config' do
template_hash = YAML.safe_load(template.render(merged_manifest_properties, consumes: links))
expect(template_hash['allow_user_creation_by_org_manager']).to be_nil
end
end

context 'when it is set to false' do
before do
merged_manifest_properties['cc']['allow_user_creation_by_org_manager'] = false
end

it 'renders it as false' do
template_hash = YAML.safe_load(template.render(merged_manifest_properties, consumes: links))
expect(template_hash['allow_user_creation_by_org_manager']).to be(false)
end
end

context 'when it is set to true' do
before do
merged_manifest_properties['cc']['allow_user_creation_by_org_manager'] = true
end

it 'renders it as true' do
template_hash = YAML.safe_load(template.render(merged_manifest_properties, consumes: links))
expect(template_hash['allow_user_creation_by_org_manager']).to be(true)
end
end
end

describe 'uaa.clients.cloud_controller_shadow_user_creation.secret' do
context 'when it is not set' do
it 'does not render the client into the config' do
template_hash = YAML.safe_load(template.render(merged_manifest_properties, consumes: links))
expect(template_hash['uaa']['clients']).to be_nil
end
end

context 'when it is set' do
before do
merged_manifest_properties['uaa']['clients'].merge!({ 'cloud_controller_shadow_user_creation' => { 'secret' => 'super-secret' } })
end

it 'renders the client and secret into the config' do
template_hash = YAML.safe_load(template.render(merged_manifest_properties, consumes: links))
client = template_hash['uaa']['clients'].find { |client_config| client_config['name'] == 'cloud_controller_shadow_user_creation' }
expect(client['id']).to eq('cloud_controller_shadow_user_creation')
expect(client['secret']).to eq('super-secret')
end
end
end
end
end
end
Expand Down

0 comments on commit 577b509

Please sign in to comment.