Skip to content

Commit

Permalink
Merge pull request #3678 from Countly/docker-changes
Browse files Browse the repository at this point in the history
[dbviewer] allow filtering collections by apps
  • Loading branch information
ar2rsawseen authored Nov 21, 2022
2 parents dd131af + 5da35aa commit b0a50f9
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 6 deletions.
18 changes: 13 additions & 5 deletions api/utils/rights.js
Original file line number Diff line number Diff line change
Expand Up @@ -573,11 +573,16 @@ exports.dbLoadEventsData = dbLoadEventsData;
* Check user has access to collection
* @param {object} params - {@link params} object
* @param {string} collection - collection will be checked for access
* @param {string} app_id - app_id to which to restrict access
* @param {function} callback - callback method includes boolean variable as argument
* @returns {function} returns callback
**/
exports.dbUserHasAccessToCollection = function(params, collection, callback) {
if (params.member.global_admin) {
exports.dbUserHasAccessToCollection = function(params, collection, app_id, callback) {
if (typeof app_id === "function") {
callback = app_id;
app_id = null;
}
if (params.member.global_admin && !app_id) {
//global admin without app_id restriction just has access to everything
return callback(true);
}
Expand All @@ -588,12 +593,15 @@ exports.dbUserHasAccessToCollection = function(params, collection, callback) {
apps = userApps || [];
// also check for app based restrictions
if (params.member.app_restrict) {
for (var app_id in params.member.app_restrict) {
if (params.member.app_restrict[app_id].indexOf("#/manage/db") !== -1 && apps.indexOf(app_id) !== -1) {
apps.splice(apps.indexOf(app_id), 1);
for (var appid in params.member.app_restrict) {
if (params.member.app_restrict[appid].indexOf("#/manage/db") !== -1 && apps.indexOf(appid) !== -1) {
apps.splice(apps.indexOf(appid), 1);
}
}
}
if (app_id) {
apps = apps.filter(id => id + "" === app_id + "");
}
var appList = [];
if (collection.indexOf("events") === 0 || collection.indexOf("drill_events") === 0) {
for (let i = 0; i < apps.length; i++) {
Expand Down
2 changes: 1 addition & 1 deletion plugins/dbviewer/api/api.js
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,7 @@ var spawn = require('child_process').spawn,
var db = { name: name, collections: {} };
async.each(results, function(col, done) {
if (col.collectionName.indexOf("system.indexes") === -1 && col.collectionName.indexOf("sessions_") === -1) {
dbUserHasAccessToCollection(params, col.collectionName, function(hasAccess) {
dbUserHasAccessToCollection(params, col.collectionName, params.qstring.app_id, function(hasAccess) {
if (hasAccess) {
ob = parseCollectionName(col.collectionName, lookup, eventList, viewList);
db.collections[ob.pretty] = ob.name;
Expand Down

0 comments on commit b0a50f9

Please sign in to comment.