From 73d8e161834f768bc772e38a7ebf1a140962c685 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Mon, 30 Sep 2013 10:10:47 -0400 Subject: [PATCH] Add recursive delete function to FileUtils --- src/main/java/com/gitblit/wicket/panels/RepositoryUrlPanel.java | 38 ++++++++++++++++++++------------------ 1 files changed, 20 insertions(+), 18 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/panels/RepositoryUrlPanel.java b/src/main/java/com/gitblit/wicket/panels/RepositoryUrlPanel.java index b28599f..0dae3cf 100644 --- a/src/main/java/com/gitblit/wicket/panels/RepositoryUrlPanel.java +++ b/src/main/java/com/gitblit/wicket/panels/RepositoryUrlPanel.java @@ -85,7 +85,7 @@ // grab primary url from the top of the list primaryUrl = repositoryUrls.size() == 0 ? null : repositoryUrls.get(0); - boolean canClone = ((primaryUrl.permission == null) || primaryUrl.permission.atLeast(AccessPermission.CLONE)); + boolean canClone = primaryUrl != null && ((primaryUrl.permission == null) || primaryUrl.permission.atLeast(AccessPermission.CLONE)); if (repositoryUrls.size() == 0 || !canClone) { // no urls, nothing to show. @@ -162,7 +162,7 @@ } // access restriction icon and tooltip - if (isGitblitServingRepositories()) { + if (GitBlit.isServingRepositories()) { switch (repository.accessRestriction) { case NONE: urlPanel.add(WicketUtils.newClearPixel("accessRestrictionIcon").setVisible(false)); @@ -228,18 +228,16 @@ final GitClientApplication clientApp = item.getModelObject(); // filter the urls for the client app - List<RepositoryUrl> urls; - if (clientApp.minimumPermission == null) { - // client app does not specify minimum access permission - urls = repositoryUrls; - } else { - urls = new ArrayList<RepositoryUrl>(); - for (RepositoryUrl repoUrl : repositoryUrls) { - if (repoUrl.permission == null) { - // external permissions, assume it is satisfactory + List<RepositoryUrl> urls = new ArrayList<RepositoryUrl>(); + for (RepositoryUrl repoUrl : repositoryUrls) { + if (clientApp.minimumPermission == null || repoUrl.permission == null) { + // no minimum permission or external permissions, assume it is satisfactory + if (clientApp.supportsTransport(repoUrl.url)) { urls.add(repoUrl); - } else if (repoUrl.permission.atLeast(clientApp.minimumPermission)) { - // repo url meets minimum permission requirement + } + } else if (repoUrl.permission.atLeast(clientApp.minimumPermission)) { + // repo url meets minimum permission requirement + if (clientApp.supportsTransport(repoUrl.url)) { urls.add(repoUrl); } } @@ -335,10 +333,6 @@ return pattern.replace("${repoUrl}", repoUrl).replace("${baseUrl}", baseUrl); } - protected boolean isGitblitServingRepositories() { - return GitBlit.getBoolean(Keys.git.enableGitServlet, true) || (GitBlit.getInteger(Keys.git.daemonPort, 0) > 0); - } - protected Label createPermissionBadge(String wicketId, RepositoryUrl repoUrl) { Label permissionLabel = new Label(wicketId, repoUrl.isExternal() ? externalPermission : repoUrl.permission.toString()); WicketUtils.setPermissionClass(permissionLabel, repoUrl.permission); @@ -371,7 +365,15 @@ if (!urlPermissionsMap.containsKey(repoUrl.url)) { String note; if (repoUrl.isExternal()) { - String protocol = repoUrl.url.substring(0, repoUrl.url.indexOf("://")); + String protocol; + int protocolIndex = repoUrl.url.indexOf("://"); + if (protocolIndex > -1) { + // explicit protocol specified + protocol = repoUrl.url.substring(0, protocolIndex); + } else { + // implicit SSH url + protocol = "ssh"; + } note = MessageFormat.format(getString("gb.externalPermissions"), protocol); } else { note = null; -- Gitblit v1.9.1