diff options
author | Stas Vilchik <vilchiks@gmail.com> | 2017-01-31 13:46:14 +0100 |
---|---|---|
committer | Stas Vilchik <stas-vilchik@users.noreply.github.com> | 2017-02-01 09:43:03 +0100 |
commit | a14a5717cd31d3358d5ba09b36696caf08518546 (patch) | |
tree | 5d444c08b851dddd280496175f332e7d3e9049d1 /server/sonar-web | |
parent | 2bb7dc7da6a7fe958d24c233844f5944edbdaf8d (diff) | |
download | sonarqube-a14a5717cd31d3358d5ba09b36696caf08518546.tar.gz sonarqube-a14a5717cd31d3358d5ba09b36696caf08518546.zip |
SONAR-8658 Create organization's permission templates page
Diffstat (limited to 'server/sonar-web')
16 files changed, 175 insertions, 57 deletions
diff --git a/server/sonar-web/src/main/js/api/permissions.js b/server/sonar-web/src/main/js/api/permissions.js index e4d7f9b9b09..f498c3612d9 100644 --- a/server/sonar-web/src/main/js/api/permissions.js +++ b/server/sonar-web/src/main/js/api/permissions.js @@ -71,9 +71,9 @@ export function revokePermissionFromGroup (projectKey, groupName, permission) { * Get list of permission templates * @returns {Promise} */ -export function getPermissionTemplates () { +export function getPermissionTemplates (organization) { const url = '/api/permissions/search_templates'; - return getJSON(url); + return organization ? getJSON(url, { organization }) : getJSON(url); } export const createPermissionTemplate = data => ( @@ -90,13 +90,13 @@ export const deletePermissionTemplate = data => ( /** * Set default permission template for a given qualifier - * @param {string} templateName + * @param {string} templateId * @param {string} qualifier * @returns {Promise} */ -export function setDefaultPermissionTemplate (templateName, qualifier) { +export function setDefaultPermissionTemplate (templateId, qualifier) { const url = '/api/permissions/set_default_template'; - const data = { templateName, qualifier }; + const data = { templateId, qualifier }; return post(url, data); } @@ -110,39 +110,37 @@ export function bulkApplyTemplate (data) { return post(url, data); } -export function grantTemplatePermissionToUser (templateName, login, permission) { +export function grantTemplatePermissionToUser (templateId, login, permission) { const url = '/api/permissions/add_user_to_template'; - const data = { templateName, login, permission }; + const data = { templateId, login, permission }; return post(url, data); } -export function revokeTemplatePermissionFromUser (templateName, login, permission) { +export function revokeTemplatePermissionFromUser (templateId, login, permission) { const url = '/api/permissions/remove_user_from_template'; - const data = { templateName, login, permission }; + const data = { templateId, login, permission }; return post(url, data); } -export function grantTemplatePermissionToGroup (templateName, groupName, permission) { +export function grantTemplatePermissionToGroup (data) { const url = '/api/permissions/add_group_to_template'; - const data = { templateName, groupName, permission }; return post(url, data); } -export function revokeTemplatePermissionFromGroup (templateName, groupName, permission) { +export function revokeTemplatePermissionFromGroup (data) { const url = '/api/permissions/remove_group_from_template'; - const data = { templateName, groupName, permission }; return post(url, data); } -export function addProjectCreatorToTemplate (templateName, permission) { +export function addProjectCreatorToTemplate (templateId, permission) { const url = '/api/permissions/add_project_creator_to_template'; - const data = { templateName, permission }; + const data = { templateId, permission }; return post(url, data); } -export function removeProjectCreatorFromTemplate (templateName, permission) { +export function removeProjectCreatorFromTemplate (templateId, permission) { const url = '/api/permissions/remove_project_creator_from_template'; - const data = { templateName, permission }; + const data = { templateId, permission }; return post(url, data); } @@ -194,7 +192,7 @@ export function getGlobalPermissionsGroups (query = '', permission = null) { return getJSON(url, data).then(r => r.groups); } -export function getPermissionTemplateUsers (templateId, query = '', permission = null) { +export function getPermissionTemplateUsers (templateId, query = '', permission = null, organization = null) { const url = '/api/permissions/template_users'; const data = { templateId, ps: PAGE_SIZE }; if (query) { @@ -203,10 +201,13 @@ export function getPermissionTemplateUsers (templateId, query = '', permission = if (permission) { data.permission = permission; } + if (organization) { + Object.assign(data, { organization }); + } return getJSON(url, data).then(r => r.users); } -export function getPermissionTemplateGroups (templateId, query = '', permission = null) { +export function getPermissionTemplateGroups (templateId, query = '', permission = null, organization = null) { const url = '/api/permissions/template_groups'; const data = { templateId, ps: PAGE_SIZE }; if (query) { @@ -215,5 +216,8 @@ export function getPermissionTemplateGroups (templateId, query = '', permission if (permission) { data.permission = permission; } + if (organization) { + Object.assign(data, { organization }); + } return getJSON(url, data).then(r => r.groups); } diff --git a/server/sonar-web/src/main/js/app/components/nav/settings/SettingsNav.js b/server/sonar-web/src/main/js/app/components/nav/settings/SettingsNav.js index 417f89a1553..9879cec41d5 100644 --- a/server/sonar-web/src/main/js/app/components/nav/settings/SettingsNav.js +++ b/server/sonar-web/src/main/js/app/components/nav/settings/SettingsNav.js @@ -75,9 +75,9 @@ class SettingsNav extends React.Component { <div className="container"> <ul className="nav navbar-nav nav-crumbs"> <li> - <IndexLink to="/settings"> - {translate('layout.settings')} - </IndexLink> + <IndexLink to="/settings"> + {translate('layout.settings')} + </IndexLink> </li> </ul> @@ -138,11 +138,13 @@ class SettingsNav extends React.Component { {translate('global_permissions.page')} </IndexLink> </li> - <li> - <IndexLink to="/permission_templates" activeClassName="active"> - {translate('permission_templates')} - </IndexLink> - </li> + {!this.props.customOrganizations && ( + <li> + <IndexLink to="/permission_templates" activeClassName="active"> + {translate('permission_templates')} + </IndexLink> + </li> + )} </ul> </li> diff --git a/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPermissionTemplates.js b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPermissionTemplates.js new file mode 100644 index 00000000000..614e2ec376a --- /dev/null +++ b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPermissionTemplates.js @@ -0,0 +1,46 @@ +/* + * SonarQube + * Copyright (C) 2009-2016 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +// @flow +import React from 'react'; +import { connect } from 'react-redux'; +import AppContainer from '../../permission-templates/components/AppContainer'; +import { getOrganizationByKey } from '../../../store/rootReducer'; +import type { Organization } from '../../../store/organizations/duck'; + +class OrganizationPermissionTemplates extends React.Component { + props: { + location: {}, + organization: Organization + }; + + render () { + return ( + <AppContainer + location={this.props.location} + organization={this.props.organization}/> + ); + } +} + +const mapStateToProps = (state, ownProps) => ({ + organization: getOrganizationByKey(state, ownProps.params.organizationKey) +}); + +export default connect(mapStateToProps)(OrganizationPermissionTemplates); diff --git a/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js b/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js index d9cfafeb5eb..8590e0e192f 100644 --- a/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js +++ b/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js @@ -25,7 +25,8 @@ import { translate } from '../../../helpers/l10n'; const ADMIN_PATHS = [ 'edit', 'groups', - 'delete' + 'delete', + 'permission_templates' ]; export default class OrganizationNavigation extends React.Component { @@ -57,6 +58,11 @@ export default class OrganizationNavigation extends React.Component { </Link> </li> <li> + <Link to={`/organizations/${organization.key}/permission_templates`} activeClassName="active"> + {translate('permission_templates')} + </Link> + </li> + <li> <Link to={`/organizations/${organization.key}/edit`} activeClassName="active"> {translate('edit')} </Link> diff --git a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap index cd5ffee80cf..af802f0809d 100644 --- a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap +++ b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap @@ -54,6 +54,15 @@ exports[`test admin 1`] = ` activeClassName="active" onlyActiveOnIndex={false} style={Object {}} + to="/organizations/foo/permission_templates"> + permission_templates + </Link> + </li> + <li> + <Link + activeClassName="active" + onlyActiveOnIndex={false} + style={Object {}} to="/organizations/foo/edit"> edit </Link> diff --git a/server/sonar-web/src/main/js/apps/organizations/routes.js b/server/sonar-web/src/main/js/apps/organizations/routes.js index 3cf6dc9b3b1..909ffa400e3 100644 --- a/server/sonar-web/src/main/js/apps/organizations/routes.js +++ b/server/sonar-web/src/main/js/apps/organizations/routes.js @@ -23,6 +23,7 @@ import OrganizationPage from './components/OrganizationPage'; import OrganizationAdmin from './components/OrganizationAdmin'; import OrganizationEdit from './components/OrganizationEdit'; import OrganizationGroups from './components/OrganizationGroups'; +import OrganizationPermissionTemplates from './components/OrganizationPermissionTemplates'; import OrganizationDelete from './components/OrganizationDelete'; export default ( @@ -31,6 +32,7 @@ export default ( <Route path="delete" component={OrganizationDelete}/> <Route path="edit" component={OrganizationEdit}/> <Route path="groups" component={OrganizationGroups}/> + <Route path="permission_templates" component={OrganizationPermissionTemplates}/> </Route> </Route> ); diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/ActionsCell.js b/server/sonar-web/src/main/js/apps/permission-templates/components/ActionsCell.js index 88c034de322..1a0a97e38cf 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/ActionsCell.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/ActionsCell.js @@ -30,6 +30,7 @@ import { setDefaultPermissionTemplate } from '../../../api/permissions'; export default class ActionsCell extends React.Component { static propTypes = { + organization: React.PropTypes.object, permissionTemplate: PermissionTemplateType.isRequired, topQualifiers: React.PropTypes.array.isRequired, refresh: CallbackType, @@ -57,7 +58,10 @@ export default class ActionsCell extends React.Component { new DeleteView({ model: new Backbone.Model(this.props.permissionTemplate) }).on('done', () => { - this.context.router.replace('/permission_templates'); + const pathname = this.props.organization ? + `/organizations/${this.props.organization.key}/permission_templates` : + '/permission_templates'; + this.context.router.replace(pathname); this.props.refresh(); }).render(); } @@ -65,7 +69,7 @@ export default class ActionsCell extends React.Component { setDefault (qualifier, e) { e.preventDefault(); setDefaultPermissionTemplate( - this.props.permissionTemplate.name, + this.props.permissionTemplate.id, qualifier ).then(this.props.refresh); } @@ -137,7 +141,11 @@ export default class ActionsCell extends React.Component { } render () { - const { permissionTemplate: t } = this.props; + const { permissionTemplate: t, organization } = this.props; + + const pathname = organization ? + `/organizations/${organization.key}/permission_templates` : + '/permission_templates'; return ( <div className="dropdown"> @@ -151,12 +159,12 @@ export default class ActionsCell extends React.Component { {this.renderSetDefaultsControl()} {!this.props.fromDetails && ( - <li> - <Link to={{ pathname: '/permission_templates', query: { id: t.id } }}> - {this.renderDropdownIcon(<i className="icon-edit"/>)} - Edit Permissions - </Link> - </li> + <li> + <Link to={{ pathname, query: { id: t.id } }}> + {this.renderDropdownIcon(<i className="icon-edit"/>)} + Edit Permissions + </Link> + </li> )} <li> diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/App.js b/server/sonar-web/src/main/js/apps/permission-templates/components/App.js index 2263339753b..b5e494aa2ed 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/App.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/App.js @@ -30,6 +30,8 @@ import '../../permissions/styles.css'; export default class App extends React.Component { static propTypes = { + location: React.PropTypes.object.isRequired, + organization: React.PropTypes.object, topQualifiers: React.PropTypes.array.isRequired }; @@ -53,7 +55,9 @@ export default class App extends React.Component { } requestPermissions () { - return getPermissionTemplates().then(r => { + const { organization } = this.props; + const request = organization ? getPermissionTemplates(organization.key) : getPermissionTemplates(); + return request.then(r => { if (this.mounted) { const permissions = sortPermissions(r.permissions); const permissionTemplates = mergeDefaultsToTemplates( @@ -77,6 +81,7 @@ export default class App extends React.Component { const template = this.state.permissionTemplates.find(t => t.id === id); return ( <Template + organization={this.props.organization} template={template} refresh={this.requestPermissions} topQualifiers={this.props.topQualifiers}/> @@ -92,6 +97,7 @@ export default class App extends React.Component { return ( <Home + organization={this.props.organization} topQualifiers={this.props.topQualifiers} permissions={this.state.permissions} permissionTemplates={this.state.permissionTemplates} diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/Header.js b/server/sonar-web/src/main/js/apps/permission-templates/components/Header.js index b0f66504edd..e36a7e51570 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/Header.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/Header.js @@ -24,6 +24,7 @@ import { CallbackType } from '../propTypes'; export default class Header extends React.Component { static propTypes = { + organization: React.PropTypes.object, ready: React.PropTypes.bool.isRequired, refresh: CallbackType }; @@ -38,11 +39,15 @@ export default class Header extends React.Component { handleCreateClick (e) { e.preventDefault(); + const { organization } = this.props; - new CreateView().on('done', r => { + new CreateView({ organization }).on('done', r => { this.props.refresh().then(() => { + const pathname = organization ? + `/organizations/${organization.key}/permission_templates` : + '/permission_templates'; this.context.router.push({ - pathname: '/permission_templates', + pathname, query: { id: r.permissionTemplate.id } }); }); diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/Home.js b/server/sonar-web/src/main/js/apps/permission-templates/components/Home.js index c8871e2c4e7..516e1f28f76 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/Home.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/Home.js @@ -26,6 +26,7 @@ import { translate } from '../../../helpers/l10n'; export default class Home extends React.Component { static propTypes = { + organization: React.PropTypes.object, topQualifiers: React.PropTypes.array.isRequired, permissions: React.PropTypes.array.isRequired, permissionTemplates: React.PropTypes.array.isRequired, @@ -41,11 +42,13 @@ export default class Home extends React.Component { titleTemplate="SonarQube - %s"/> <Header + organization={this.props.organization} ready={this.props.ready} refresh={this.props.refresh}/> <TooltipsContainer> <List + organization={this.props.organization} permissionTemplates={this.props.permissionTemplates} permissions={this.props.permissions} topQualifiers={this.props.topQualifiers} diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/List.js b/server/sonar-web/src/main/js/apps/permission-templates/components/List.js index 11ad4cd42a9..8fda434904a 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/List.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/List.js @@ -24,6 +24,7 @@ import { PermissionTemplateType, CallbackType } from '../propTypes'; export default class List extends React.Component { static propTypes = { + organization: React.PropTypes.object, permissionTemplates: React.PropTypes.arrayOf( PermissionTemplateType).isRequired, permissions: React.PropTypes.array.isRequired, @@ -35,14 +36,14 @@ export default class List extends React.Component { const permissionTemplates = this.props.permissionTemplates.map(p => ( <ListItem key={p.id} + organization={this.props.organization} permissionTemplate={p} topQualifiers={this.props.topQualifiers} refresh={this.props.refresh}/> )); return ( - <table id="permission-templates" - className="data zebra permissions-table"> + <table id="permission-templates" className="data zebra permissions-table"> <ListHeader permissions={this.props.permissions}/> <tbody>{permissionTemplates}</tbody> </table> diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/ListItem.js b/server/sonar-web/src/main/js/apps/permission-templates/components/ListItem.js index 6c27462183b..3dd1986efed 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/ListItem.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/ListItem.js @@ -27,6 +27,7 @@ import { PermissionTemplateType, CallbackType } from '../propTypes'; export default class ListItem extends React.Component { static propTypes = { + organization: React.PropTypes.object, permissionTemplate: PermissionTemplateType.isRequired, topQualifiers: React.PropTypes.array.isRequired, refresh: CallbackType @@ -63,6 +64,7 @@ export default class ListItem extends React.Component { data-id={this.props.permissionTemplate.id} data-name={this.props.permissionTemplate.name}> <NameCell + organization={this.props.organization} permissionTemplate={this.props.permissionTemplate} topQualifiers={this.props.topQualifiers}/> @@ -70,6 +72,7 @@ export default class ListItem extends React.Component { <td className="nowrap thin text-right"> <ActionsCell + organization={this.props.organization} permissionTemplate={this.props.permissionTemplate} topQualifiers={this.props.topQualifiers} refresh={this.props.refresh}/> diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/NameCell.js b/server/sonar-web/src/main/js/apps/permission-templates/components/NameCell.js index 78d1ded45ab..41379178da2 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/NameCell.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/NameCell.js @@ -24,15 +24,20 @@ import { PermissionTemplateType } from '../propTypes'; export default class NameCell extends React.Component { static propTypes = { + organization: React.PropTypes.object, permissionTemplate: PermissionTemplateType.isRequired }; render () { - const { permissionTemplate: t } = this.props; + const { permissionTemplate: t, organization } = this.props; + + const pathname = organization ? + `/organizations/${organization.key}/permission_templates` : + '/permission_templates'; return ( <td> - <Link to={{ pathname: '/permission_templates', query: { id: t.id } }}> + <Link to={{ pathname, query: { id: t.id } }}> <strong className="js-name">{t.name}</strong> </Link> diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/Template.js b/server/sonar-web/src/main/js/apps/permission-templates/components/Template.js index 1639f5cb6c3..c37066308dc 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/Template.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/Template.js @@ -31,6 +31,7 @@ import withStore from '../../../store/utils/withStore'; class Template extends React.Component { static propTypes = { + organization: React.PropTypes.object, template: React.PropTypes.object.isRequired, refresh: React.PropTypes.func.isRequired, topQualifiers: React.PropTypes.array.isRequired @@ -95,9 +96,9 @@ class Template extends React.Component { const hasPermission = user.permissions.includes(permission); const request = hasPermission ? api.revokeTemplatePermissionFromUser( - template.name, user.login, permission) : + template.id, user.login, permission) : api.grantTemplatePermissionToUser( - template.name, user.login, permission); + template.id, user.login, permission); request.then(() => this.requestHolders()).then(this.props.refresh); } @@ -105,19 +106,25 @@ class Template extends React.Component { const { template } = this.props; const hasPermission = user.permissions.includes(permission); const request = hasPermission ? - api.removeProjectCreatorFromTemplate(template.name, permission) : - api.addProjectCreatorToTemplate(template.name, permission); + api.removeProjectCreatorFromTemplate(template.id, permission) : + api.addProjectCreatorToTemplate(template.id, permission); request.then(() => this.requestHolders()).then(this.props.refresh); } handleToggleGroup (group, permission) { - const { template } = this.props; + const { template, organization } = this.props; const hasPermission = group.permissions.includes(permission); + const data = { + templateId: template.id, + groupName: group.name, + permission + }; + if (organization) { + Object.assign(data, { organization: organization.key }); + } const request = hasPermission ? - api.revokeTemplatePermissionFromGroup( - template.name, group.name, permission) : - api.grantTemplatePermissionToGroup( - template.name, group.name, permission); + api.revokeTemplatePermissionFromGroup(data) : + api.grantTemplatePermissionToGroup(data); request.then(() => this.requestHolders()).then(this.props.refresh); } @@ -194,6 +201,7 @@ class Template extends React.Component { titleTemplate="SonarQube - %s"/> <TemplateHeader + organization={this.props.organization} template={this.props.template} loading={store.loading} refresh={this.props.refresh} diff --git a/server/sonar-web/src/main/js/apps/permission-templates/components/TemplateHeader.js b/server/sonar-web/src/main/js/apps/permission-templates/components/TemplateHeader.js index 57dd6349760..3de1362b3a4 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/components/TemplateHeader.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/components/TemplateHeader.js @@ -24,6 +24,7 @@ import { translate } from '../../../helpers/l10n'; export default class TemplateHeader extends React.Component { static propTypes = { + organization: React.PropTypes.object, template: React.PropTypes.object.isRequired, loading: React.PropTypes.bool.isRequired, refresh: React.PropTypes.func.isRequired, @@ -31,12 +32,16 @@ export default class TemplateHeader extends React.Component { }; render () { - const { template } = this.props; + const { template, organization } = this.props; + + const pathname = organization ? + `/organizations/${organization.key}/permission_templates` : + '/permission_templates'; return ( <header id="project-permissions-header" className="page-header"> <div className="note spacer-bottom"> - <Link to="/permission_templates" className="text-muted"> + <Link to={pathname} className="text-muted"> {translate('permission_templates.page')} </Link> </div> @@ -51,6 +56,7 @@ export default class TemplateHeader extends React.Component { <div className="pull-right"> <ActionsCell + organization={this.props.organization} permissionTemplate={this.props.template} topQualifiers={this.props.topQualifiers} refresh={this.props.refresh} diff --git a/server/sonar-web/src/main/js/apps/permission-templates/views/CreateView.js b/server/sonar-web/src/main/js/apps/permission-templates/views/CreateView.js index c444d48705d..a0cfc34da3a 100644 --- a/server/sonar-web/src/main/js/apps/permission-templates/views/CreateView.js +++ b/server/sonar-web/src/main/js/apps/permission-templates/views/CreateView.js @@ -24,11 +24,15 @@ import { parseError } from '../../code/utils'; export default FormView.extend({ sendRequest () { this.disableForm(); - createPermissionTemplate({ + const data = { name: this.$('#permission-template-name').val(), description: this.$('#permission-template-description').val(), projectKeyPattern: this.$('#permission-template-project-key-pattern').val() - }).then( + }; + if (this.options.organization) { + Object.assign(data, { organization: this.options.organization.key }); + } + createPermissionTemplate(data).then( r => { this.trigger('done', r); this.destroy(); |