Skip to content

Commit

Permalink
Add permission evaluation logic and API
Browse files Browse the repository at this point in the history
Signed-off-by: Chang Liu <lc12251109@gmail.com>
  • Loading branch information
Chang Liu authored and cliu123 committed Jul 4, 2022
1 parent 100dbf0 commit 0399abf
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 1 deletion.
3 changes: 2 additions & 1 deletion src/core/server/http/router/router.ts
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,8 @@ export class Router implements IRouter {
opensearchDashboardsRequest,
opensearchDashboardsResponseFactory
);
return hapiResponseAdapter.handle(opensearchDashboardsResponse);
return hapiResponseAdapter.
handle(opensearchDashboardsResponse);
} catch (e) {
this.log.error(e);
// forward 401 errors from OpenSearch client
Expand Down
2 changes: 2 additions & 0 deletions src/plugins/permission_management/server/plugin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
import { PermissionManagementPluginSetup, PermissionManagementPluginStart } from './types';
import { defineRoutes } from './routes';
import { samplePermission } from './saved_objects';
import { evaluatePermissionRoute } from './routes/permission_evaluation';

export class PermissionManagementPlugin
implements Plugin<PermissionManagementPluginSetup, PermissionManagementPluginStart> {
Expand All @@ -26,6 +27,7 @@ export class PermissionManagementPlugin

// Register server side APIs
defineRoutes(router);
evaluatePermissionRoute(router);

return {};
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/*
* SPDX-License-Identifier: Apache-2.0
*
* The OpenSearch Contributors require contributions made to
* this file be licensed under the Apache-2.0 license or a
* compatible open source license.
*
* Any modifications Copyright OpenSearch Contributors. See
* GitHub history for details.
*/

/*
* Licensed to Elasticsearch B.V. under one or more contributor
* license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright
* ownership. Elasticsearch B.V. licenses this file to you 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.
*/

import { IRouter } from 'src/core/server';
import axios, { AxiosResponse } from 'axios';

export function evaluatePermissionRoute(router: IRouter): void {
router.get(
{
path: '/api/permission_management/hasPermission/{permission}',
validate: false,
},
async (context, request, response) => {
// TODO: Use parameter to get permissionRequired.
const pathSegments = request.route.path.split('/');
const permissionRequired = pathSegments[pathSegments.length - 1];
const axiosResponse: AxiosResponse = await axios.get(
`http://localhost:5601/api/saved_objects/_find?type=sample-permission`
);
const savedObjects = axiosResponse.data.saved_objects
let attributes = savedObjects.map(({ attributes }) => attributes);
let permissions = attributes.map(({ name }) => name);
const result = permissions.includes(permissionRequired);
return response.ok({
body: {
authorized: result.toString(),
},
});
}
);
}

0 comments on commit 0399abf

Please sign in to comment.