clean cache button

This commit is contained in:
Michele Artini 2022-01-31 14:35:21 +01:00
parent 3a3f24135d
commit ae7b483c90
5 changed files with 36 additions and 2 deletions

View File

@ -162,6 +162,16 @@ public class AdminController extends AbstractDnetController {
} }
} }
@GetMapping("/api/clearCache")
public List<String> clearCache(final Authentication authentication) {
if (UserInfo.isSuperAdmin(authentication)) {
dbUtils.clearCache();
return Arrays.asList("All caches are cleared");
} else {
throw new RuntimeException("User not authorized");
}
}
@GetMapping("/api/restartSuggestionsImport") @GetMapping("/api/restartSuggestionsImport")
public List<String> restartSuggestionsImport(final Authentication authentication) { public List<String> restartSuggestionsImport(final Authentication authentication) {
if (UserInfo.isSuperAdmin(authentication)) { if (UserInfo.isSuperAdmin(authentication)) {

View File

@ -23,6 +23,7 @@ import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log; import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory; import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.Cacheable; import org.springframework.cache.annotation.Cacheable;
import org.springframework.jdbc.core.BeanPropertyRowMapper; import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.JdbcTemplate;
@ -330,6 +331,13 @@ public class DatabaseUtils {
return jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(VocabularyTerm.class), name); return jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(VocabularyTerm.class), name);
} }
@CacheEvict(value = {
"vocs", "countries_for_user"
}, allEntries = true)
public void clearCache() {
log.info("All caches cleaned");
}
@Transactional @Transactional
public void saveUser(@RequestBody final UserView userView) { public void saveUser(@RequestBody final UserView userView) {
final User user = userRepository.findById(userView.getEmail()).orElseThrow(() -> new RuntimeException("User not found")); final User user = userRepository.findById(userView.getEmail()).orElseThrow(() -> new RuntimeException("User not found"));

View File

@ -4,8 +4,8 @@
<table class="table table-sm table-striped"> <table class="table table-sm table-striped">
<thead> <thead>
<tr> <tr>
<th style="width: 20%">Command</th> <th style="width: 30%">Command</th>
<th style="width: 80%">Status</th> <th style="width: 70%">Status</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
@ -25,6 +25,10 @@
<td><button class="btn btn-sm btn-link" ng-click="restartSuggestionsImport()" ng-disabled="suggestionImportMessage">Restart the import of the suggestions</button></td> <td><button class="btn btn-sm btn-link" ng-click="restartSuggestionsImport()" ng-disabled="suggestionImportMessage">Restart the import of the suggestions</button></td>
<td>{{suggestionImportMessage}}<span ng-show="suggestionImportMessage"> - to see the current import execution <a href="#!/lastImport">click here</a></span></td> <td>{{suggestionImportMessage}}<span ng-show="suggestionImportMessage"> - to see the current import execution <a href="#!/lastImport">click here</a></span></td>
</tr> </tr>
<tr>
<td><button class="btn btn-sm btn-link" ng-click="clearCache()" ng-disabled="cacheMessage">Clear all caches</button></td>
<td>{{cacheMessage}}<span ng-show="cacheMessage"></span></td>
</tr>
</tbody> </tbody>
</table> </table>

View File

@ -813,6 +813,7 @@ orgsModule.controller('utilsCtrl', function ($scope, $http) {
$scope.consistencyCheckMessage = ''; $scope.consistencyCheckMessage = '';
$scope.invalidSuggestedCountriesMessage = ''; $scope.invalidSuggestedCountriesMessage = '';
$scope.suggestionImportMessage = ''; $scope.suggestionImportMessage = '';
$scope.cacheMessage = '';
$scope.refreshFulltextIndex = function() { $scope.refreshFulltextIndex = function() {
$scope.fulltextIndexMessage = '...'; $scope.fulltextIndexMessage = '...';
@ -833,6 +834,12 @@ orgsModule.controller('utilsCtrl', function ($scope, $http) {
$scope.suggestionImportMessage = '...'; $scope.suggestionImportMessage = '...';
call_http_get($http, 'api/restartSuggestionsImport', function(res) { $scope.suggestionImportMessage = res.data[0]; }); call_http_get($http, 'api/restartSuggestionsImport', function(res) { $scope.suggestionImportMessage = res.data[0]; });
} }
$scope.clearCache = function() {
$scope.cacheMessage = '...';
call_http_get($http, 'api/clearCache', function(res) { $scope.cacheMessage = res.data[0]; });
}
}); });

View File

@ -42,6 +42,11 @@ fieldset > legend { font-size : 1.2rem !important; }
color: gray !important; color: gray !important;
text-decoration: line-through !important; text-decoration: line-through !important;
} }
.btn-link {
text-align: left !important;
}
</style> </style>