Browse Source

Require admin permissions to view the filestore page

tags/v1.7.0
James Moger 8 years ago
parent
commit
6069be20b5

+ 17
- 27
src/main/java/com/gitblit/wicket/pages/FilestorePage.java View File

import org.apache.wicket.markup.repeater.data.ListDataProvider; import org.apache.wicket.markup.repeater.data.ListDataProvider;


import com.gitblit.Constants; import com.gitblit.Constants;
import com.gitblit.Keys;
import com.gitblit.models.FilestoreModel; import com.gitblit.models.FilestoreModel;
import com.gitblit.models.UserModel; import com.gitblit.models.UserModel;
import com.gitblit.wicket.FilestoreUI; import com.gitblit.wicket.FilestoreUI;
import com.gitblit.wicket.GitBlitWebSession;
import com.gitblit.wicket.RequiresAdminRole;
import com.gitblit.wicket.WicketUtils; import com.gitblit.wicket.WicketUtils;


/** /**
* Page to display the current status of the filestore. * Page to display the current status of the filestore.
* Certain errors also displayed to aid in fault finding
* Certain errors also displayed to aid in fault finding
* *
* @author Paul Martin * @author Paul Martin
*
*
*/ */
@RequiresAdminRole
public class FilestorePage extends RootPage { public class FilestorePage extends RootPage {


public FilestorePage() { public FilestorePage() {
super(); super();
setupPage("", ""); setupPage("", "");
// check to see if we should display a login message
boolean authenticateView = app().settings().getBoolean(Keys.web.authenticateViewPages, true);
if (authenticateView && !GitBlitWebSession.get().isLoggedIn()) {
String messageSource = app().settings().getString(Keys.web.loginMessage, "gitblit");
return;
}

final List<FilestoreModel> files = app().filestore().getAllObjects(); final List<FilestoreModel> files = app().filestore().getAllObjects();
final long nBytesUsed = app().filestore().getFilestoreUsedByteCount(); final long nBytesUsed = app().filestore().getFilestoreUsedByteCount();
final long nBytesAvailable = app().filestore().getFilestoreAvailableByteCount(); final long nBytesAvailable = app().filestore().getFilestoreAvailableByteCount();
// Load the markdown welcome message
String messageSource = app().settings().getString(Keys.web.repositoriesMessage, "gitblit");
String message = MessageFormat.format(getString("gb.filestoreStats"), files.size(),
FileUtils.byteCountToDisplaySize(nBytesUsed), FileUtils.byteCountToDisplaySize(nBytesAvailable) );

String message = MessageFormat.format(getString("gb.filestoreStats"), files.size(),
FileUtils.byteCountToDisplaySize(nBytesUsed), FileUtils.byteCountToDisplaySize(nBytesAvailable) );


Component repositoriesMessage = new Label("repositoriesMessage", message) Component repositoriesMessage = new Label("repositoriesMessage", message)
.setEscapeModelStrings(false).setVisible(message.length() > 0); .setEscapeModelStrings(false).setVisible(message.length() > 0);
add(repositoriesMessage); add(repositoriesMessage);
BookmarkablePageLink<Void> helpLink = new BookmarkablePageLink<Void>("filestoreHelp", FilestoreUsage.class); BookmarkablePageLink<Void> helpLink = new BookmarkablePageLink<Void>("filestoreHelp", FilestoreUsage.class);
helpLink.add(new Label("helpMessage", getString("gb.filestoreHelp"))); helpLink.add(new Label("helpMessage", getString("gb.filestoreHelp")));
add(helpLink); add(helpLink);


DataView<FilestoreModel> filesView = new DataView<FilestoreModel>("fileRow", DataView<FilestoreModel> filesView = new DataView<FilestoreModel>("fileRow",
new ListDataProvider<FilestoreModel>(files)) { new ListDataProvider<FilestoreModel>(files)) {
@Override @Override
public void populateItem(final Item<FilestoreModel> item) { public void populateItem(final Item<FilestoreModel> item) {
final FilestoreModel entry = item.getModelObject(); final FilestoreModel entry = item.getModelObject();
DateFormat dateFormater = new SimpleDateFormat(Constants.ISO8601); DateFormat dateFormater = new SimpleDateFormat(Constants.ISO8601);
UserModel user = app().users().getUserModel(entry.getChangedBy()); UserModel user = app().users().getUserModel(entry.getChangedBy());
user = user == null ? UserModel.ANONYMOUS : user; user = user == null ? UserModel.ANONYMOUS : user;
Label icon = FilestoreUI.getStatusIcon("status", entry); Label icon = FilestoreUI.getStatusIcon("status", entry);
item.add(icon); item.add(icon);
item.add(new Label("on", dateFormater.format(entry.getChangedOn()))); item.add(new Label("on", dateFormater.format(entry.getChangedOn())));
item.add(new Label("by", user.getDisplayName())); item.add(new Label("by", user.getDisplayName()));
item.add(new Label("oid", entry.oid)); item.add(new Label("oid", entry.oid));
item.add(new Label("size", FileUtils.byteCountToDisplaySize(entry.getSize())));
item.add(new Label("size", FileUtils.byteCountToDisplaySize(entry.getSize())));
WicketUtils.setAlternatingBackground(item, counter); WicketUtils.setAlternatingBackground(item, counter);
counter++; counter++;
} }


}; };
add(filesView); add(filesView);
} }
} }

+ 9
- 7
src/main/java/com/gitblit/wicket/pages/RootPage.java View File

// navigation links // navigation links
List<NavLink> navLinks = new ArrayList<NavLink>(); List<NavLink> navLinks = new ArrayList<NavLink>();
if (!authenticateView || (authenticateView && isLoggedIn)) { if (!authenticateView || (authenticateView && isLoggedIn)) {
UserModel user = UserModel.ANONYMOUS;
if (isLoggedIn) {
user = GitBlitWebSession.get().getUser();
}

navLinks.add(new PageNavLink(isLoggedIn ? "gb.myDashboard" : "gb.dashboard", MyDashboardPage.class, navLinks.add(new PageNavLink(isLoggedIn ? "gb.myDashboard" : "gb.dashboard", MyDashboardPage.class,
getRootPageParameters())); getRootPageParameters()));
if (isLoggedIn && app().tickets().isReady()) { if (isLoggedIn && app().tickets().isReady()) {
} }
navLinks.add(new PageNavLink("gb.repositories", RepositoriesPage.class, navLinks.add(new PageNavLink("gb.repositories", RepositoriesPage.class,
getRootPageParameters())); getRootPageParameters()));
navLinks.add(new PageNavLink("gb.filestore", FilestorePage.class, getRootPageParameters()));
if (user.canAdmin()) {
navLinks.add(new PageNavLink("gb.filestore", FilestorePage.class, getRootPageParameters()));
}
navLinks.add(new PageNavLink("gb.activity", ActivityPage.class, getRootPageParameters())); navLinks.add(new PageNavLink("gb.activity", ActivityPage.class, getRootPageParameters()));
if (allowLucene) { if (allowLucene) {
navLinks.add(new PageNavLink("gb.search", LuceneSearchPage.class)); navLinks.add(new PageNavLink("gb.search", LuceneSearchPage.class));
addDropDownMenus(navLinks); addDropDownMenus(navLinks);
} }


UserModel user = UserModel.ANONYMOUS;
if (isLoggedIn) {
user = GitBlitWebSession.get().getUser();
}

// add nav link extensions // add nav link extensions
List<NavLinkExtension> extensions = app().plugins().getExtensions(NavLinkExtension.class); List<NavLinkExtension> extensions = app().plugins().getExtensions(NavLinkExtension.class);
for (NavLinkExtension ext : extensions) { for (NavLinkExtension ext : extensions) {
char[] password = RootPage.this.password.getObject().toCharArray(); char[] password = RootPage.this.password.getObject().toCharArray();


HttpServletRequest request = ((WebRequest)RequestCycle.get().getRequest()).getHttpServletRequest(); HttpServletRequest request = ((WebRequest)RequestCycle.get().getRequest()).getHttpServletRequest();
UserModel user = app().authentication().authenticate(username, password, request.getRemoteAddr()); UserModel user = app().authentication().authenticate(username, password, request.getRemoteAddr());
if (user == null) { if (user == null) {
error(getString("gb.invalidUsernameOrPassword")); error(getString("gb.invalidUsernameOrPassword"));

Loading…
Cancel
Save