How do I see what repositories each user or group has access to?

I need to find out what repositories and projects each user has access to and what level of access they have. Something similar to the Permission Helper in Jira but for Stash would work great. It would be ideal to see the repositories and/or projects on the user's profile page as an administrator (or maybe a link to acquire the list quickly).

Does this exist?

4 answers

1 accepted

3 votes
Accepted answer

I guess we may end up writing a plugin for this fundamental functionality...

Please publish it if you really do, I would use it too.

I haven't seen anything like this existing yet

A possible solution might be using the REST-API (https://developer.atlassian.com/static/rest/stash/3.0.1/stash-rest.html#idp788096) perfroming the following steps:

Hint: you have to be admin to get a comprehensive list of ALL repositories ...

I know the original question is old, but the following queries might help somebody:

 

select distinct(group_name) from sta_project_permission order by group_name;
select distinct(group_name) from sta_repo_permission order by group_name;
select distinct(group_name) from sta_global_permission order by group_name;

 

According to postgres, these appear to be all the tables with a group_name column:

  • cwd_app_dir_group_mapping
  • cwd_group
  • sta_global_permission
  • sta_project_permission
  • sta_repo_permission

I also searched for group_id and got:

  • cwd_group_attribute

 

So while the three queries above may not be complete, the column name searches lead me to believe I'm good.

Just an update for something a little more informative.

 

Repository permissions:

SELECT
  group_name as "Group",
  project_key as "Project Key",
  repo_name as "Repository Name",
  project_name as "Project Name"
FROM
  sta_repo_permission srp
  INNER JOIN (
    SELECT
      repository.id, repository.name as repo_name, project.name as project_name, project.project_key
    FROM repository
    INNER JOIN project on repository.project_id = project.id) repo on srp.repo_id = repo.id
WHERE
  group_name is not null;

 

Project permissions:

SELECT
  group_name as "Group",
  name as "Project Name",
  project_key as "Project Key"
FROM
  sta_project_permission spp
  INNER JOIN project on spp.project_id = project.id
WHERE
  group_name is not null;

Do we still not have this feature?

Nope, as often with Atlassian essential tools are not provided.

Suggest an answer

Log in or Sign up to answer
Community showcase
Published Nov 06, 2018 in Bitbucket

Upgrade Best Practices

Hello! My name is Mark Askew and I am a Premier Support Engineer for products Bitbucket Server/Data Center, Fisheye & Crucible. Today, I want to bring the discussion that Jennifer, Matt, and ...

194 views 3 6
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you