126 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<!--
 | 
						|
  ~ JBoss, Home of Professional Open Source.
 | 
						|
  ~ Copyright 2021 Red Hat, Inc., and individual contributors
 | 
						|
  ~ as indicated by the @author tags.
 | 
						|
  ~
 | 
						|
  ~ Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
  ~ you may not use this file except in compliance with the License.
 | 
						|
  ~ You may obtain a copy of the License at
 | 
						|
  ~
 | 
						|
  ~     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
  ~
 | 
						|
  ~ Unless required by applicable law or agreed to in writing, software
 | 
						|
  ~ distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
  ~ See the License for the specific language governing permissions and
 | 
						|
  ~ limitations under the License.
 | 
						|
  -->
 | 
						|
 | 
						|
<div class="col-sm-9 col-md-10 col-sm-push-3 col-md-push-2">
 | 
						|
 | 
						|
    <ol class="breadcrumb">
 | 
						|
        <li><a href="#/realms/{{realm.realm}}/clients">{{:: 'clients' | translate}}</a></li>
 | 
						|
        <li><a href="#/realms/{{realm.realm}}/clients/{{client.id}}">{{client.clientId}}</a></li>
 | 
						|
        <li><a href="#/realms/{{realm.realm}}/clients/{{client.id}}/authz/resource-server">{{:: 'authz-authorization' |
 | 
						|
                translate}}</a></li>
 | 
						|
        <li><a href="#/realms/{{realm.realm}}/clients/{{client.id}}/authz/resource-server/policy">{{:: 'authz-policies'
 | 
						|
                | translate}}</a></li>
 | 
						|
        <li data-ng-show="policyState.state.policy.name != null && historyBackOnSaveOrCancel">{{policyState.state.policy.name}}</li>
 | 
						|
        <li data-ng-show="policyState.state.policy.name == null && historyBackOnSaveOrCancel">{{::
 | 
						|
            policyState.state.previousPage.name | translate}}</li>
 | 
						|
        <li data-ng-show="create">{{:: 'authz-add-client-scope-policy' | translate}}</li>
 | 
						|
        <li data-ng-hide="create">{{:: 'client-scopes' | translate}}</li>
 | 
						|
        <li data-ng-hide="create">{{originalPolicy.name}}</li>
 | 
						|
    </ol>
 | 
						|
 | 
						|
    <h1 data-ng-show="create">{{:: 'authz-add-client-scope-policy' | translate}}</h1>
 | 
						|
    <h1 data-ng-hide="create">
 | 
						|
        {{originalPolicy.name|capitalize}}<i class="pficon pficon-delete clickable" data-ng-show="!create"
 | 
						|
            data-ng-click="remove()"></i>
 | 
						|
    </h1>
 | 
						|
 | 
						|
    <form class="form-horizontal" name="clientForm" novalidate>
 | 
						|
        <fieldset class="border-top">
 | 
						|
            <div class="form-group">
 | 
						|
                <label class="col-md-2 control-label" for="name">{{:: 'name' | translate}} <span class="required">*</span></label>
 | 
						|
                <div class="col-sm-6">
 | 
						|
                    <input class="form-control" type="text" id="name" name="name" data-ng-model="policy.name" autofocus required
 | 
						|
                        data-ng-blur="checkNewNameAvailability()">
 | 
						|
                </div>
 | 
						|
                <kc-tooltip>{{:: 'authz-policy-name.tooltip' | translate}}</kc-tooltip>
 | 
						|
            </div>
 | 
						|
            <div class="form-group">
 | 
						|
                <label class="col-md-2 control-label" for="description">{{:: 'description' | translate}} </label>
 | 
						|
                <div class="col-sm-6">
 | 
						|
                    <input class="form-control" type="text" id="description" name="description"
 | 
						|
                        data-ng-model="policy.description">
 | 
						|
                </div>
 | 
						|
                <kc-tooltip>{{:: 'authz-policy-description.tooltip' | translate}}</kc-tooltip>
 | 
						|
            </div>
 | 
						|
            <div class="form-group clearfix">
 | 
						|
                <label class="col-md-2 control-label" for="clientScopes">{{:: 'client-scopes' | translate}} <span
 | 
						|
                    class="required">*</span></label>
 | 
						|
 | 
						|
                <div class="col-md-4">
 | 
						|
                    <select ui-select2="{ minimumInputLength: 1}" id="clientScopes" data-ng-model="selectedClientScope"
 | 
						|
                        data-ng-change="selectClientScope(selectedClientScope);"
 | 
						|
                        data-placeholder="{{:: 'select-a-client-scope' | translate}}..."
 | 
						|
                        ng-options="clientScope as clientScope.name for clientScope in clientScopes"
 | 
						|
                        data-ng-required="selectedClientScopes.length == 0">
 | 
						|
                        <option></option>
 | 
						|
                    </select>
 | 
						|
                </div>
 | 
						|
 | 
						|
                <kc-tooltip>{{:: 'authz-policy-client-scope-client-scopes.tooltip' | translate}}</kc-tooltip>
 | 
						|
            </div>
 | 
						|
            <div class="form-group clearfix" style="margin-top: -15px;">
 | 
						|
                <label class="col-md-2 control-label"></label>
 | 
						|
                <div class="col-sm-4">
 | 
						|
                    <table class="table table-striped table-bordered" id="selected-client-scopes">
 | 
						|
                        <thead>
 | 
						|
                            <tr>
 | 
						|
                                <th class="col-sm-5">{{:: 'name' | translate}}</th>
 | 
						|
                                <th>{{:: 'authz-required' | translate}}</th>
 | 
						|
                                <th>{{:: 'actions' | translate}}</th>
 | 
						|
                            </tr>
 | 
						|
                        </thead>
 | 
						|
                        <tbody>
 | 
						|
                            <tr ng-repeat="clientScope in selectedClientScopes | orderBy:'name'">
 | 
						|
                                <td>{{clientScope.name}}</td>
 | 
						|
                                <td><input type="checkbox" ng-model="clientScope.required" id="{{clientScope.id}}"></td>
 | 
						|
                                <td class="kc-action-cell">
 | 
						|
                                    <button class="btn btn-default btn-block btn-sm" ng-click="removeFromList(clientScope);">{{::
 | 
						|
                                        'remove' | translate}}</button>
 | 
						|
                                </td>
 | 
						|
                            </tr>
 | 
						|
                            <tr data-ng-show="!selectedClientScopes.length">
 | 
						|
                                <td class="text-muted" colspan="3">{{:: 'authz-no-client-scopes-assigned' | translate}}</td>
 | 
						|
                            </tr>
 | 
						|
                        </tbody>
 | 
						|
                    </table>
 | 
						|
                </div>
 | 
						|
            </div>
 | 
						|
            <div class="form-group clearfix">
 | 
						|
                <label class="col-md-2 control-label" for="logic">{{:: 'authz-policy-logic' | translate}}</label>
 | 
						|
 | 
						|
                <div class="col-sm-1">
 | 
						|
                    <select class="form-control" id="logic" data-ng-model="policy.logic">
 | 
						|
                        <option value="POSITIVE">{{:: 'authz-policy-logic-positive' | translate}}</option>
 | 
						|
                        <option value="NEGATIVE">{{:: 'authz-policy-logic-negative' | translate}}</option>
 | 
						|
                    </select>
 | 
						|
                </div>
 | 
						|
 | 
						|
                <kc-tooltip>{{:: 'authz-policy-logic.tooltip' | translate}}</kc-tooltip>
 | 
						|
            </div>
 | 
						|
            <input type="hidden" data-ng-model="policy.type" />
 | 
						|
        </fieldset>
 | 
						|
        <div class="form-group" data-ng-show="access.manageAuthorization">
 | 
						|
            <div class="col-md-10 col-md-offset-2">
 | 
						|
                <button kc-save data-ng-disabled="!changed">{{:: 'save' | translate}}</button>
 | 
						|
                <button kc-reset data-ng-disabled="!changed && !historyBackOnSaveOrCancel">{{:: 'cancel' | translate}}</button>
 | 
						|
            </div>
 | 
						|
        </div>
 | 
						|
    </form>
 | 
						|
</div>
 | 
						|
 | 
						|
<kc-menu></kc-menu> |