Merge pull request #3691 from YevhenBondarenko/feature/access-validator-improvements
AccessValidator improvements
This commit is contained in:
commit
008e3d7b89
@ -55,6 +55,7 @@ import org.thingsboard.server.dao.customer.CustomerService;
|
|||||||
import org.thingsboard.server.dao.device.DeviceProfileService;
|
import org.thingsboard.server.dao.device.DeviceProfileService;
|
||||||
import org.thingsboard.server.dao.device.DeviceService;
|
import org.thingsboard.server.dao.device.DeviceService;
|
||||||
import org.thingsboard.server.dao.entityview.EntityViewService;
|
import org.thingsboard.server.dao.entityview.EntityViewService;
|
||||||
|
import org.thingsboard.server.dao.exception.IncorrectParameterException;
|
||||||
import org.thingsboard.server.dao.rule.RuleChainService;
|
import org.thingsboard.server.dao.rule.RuleChainService;
|
||||||
import org.thingsboard.server.dao.tenant.TenantService;
|
import org.thingsboard.server.dao.tenant.TenantService;
|
||||||
import org.thingsboard.server.dao.usagerecord.ApiUsageStateService;
|
import org.thingsboard.server.dao.usagerecord.ApiUsageStateService;
|
||||||
@ -158,7 +159,11 @@ public class AccessValidator {
|
|||||||
new FutureCallback<DeferredResult<ResponseEntity>>() {
|
new FutureCallback<DeferredResult<ResponseEntity>>() {
|
||||||
@Override
|
@Override
|
||||||
public void onSuccess(@Nullable DeferredResult<ResponseEntity> result) {
|
public void onSuccess(@Nullable DeferredResult<ResponseEntity> result) {
|
||||||
|
try {
|
||||||
onSuccess.accept(response, currentUser.getTenantId(), entityId);
|
onSuccess.accept(response, currentUser.getTenantId(), entityId);
|
||||||
|
} catch (Exception e) {
|
||||||
|
onFailure(e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -434,9 +439,9 @@ public class AccessValidator {
|
|||||||
|
|
||||||
public static void handleError(Throwable e, final DeferredResult<ResponseEntity> response, HttpStatus defaultErrorStatus) {
|
public static void handleError(Throwable e, final DeferredResult<ResponseEntity> response, HttpStatus defaultErrorStatus) {
|
||||||
ResponseEntity responseEntity;
|
ResponseEntity responseEntity;
|
||||||
if (e != null && e instanceof ToErrorResponseEntity) {
|
if (e instanceof ToErrorResponseEntity) {
|
||||||
responseEntity = ((ToErrorResponseEntity) e).toErrorResponseEntity();
|
responseEntity = ((ToErrorResponseEntity) e).toErrorResponseEntity();
|
||||||
} else if (e != null && e instanceof IllegalArgumentException) {
|
} else if (e instanceof IllegalArgumentException || e instanceof IncorrectParameterException) {
|
||||||
responseEntity = new ResponseEntity<>(e.getMessage(), HttpStatus.BAD_REQUEST);
|
responseEntity = new ResponseEntity<>(e.getMessage(), HttpStatus.BAD_REQUEST);
|
||||||
} else {
|
} else {
|
||||||
responseEntity = new ResponseEntity<>(defaultErrorStatus);
|
responseEntity = new ResponseEntity<>(defaultErrorStatus);
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user