Url validation for Ota Package and tests
This commit is contained in:
parent
633ab7d3f0
commit
f1216c9720
@ -34,10 +34,10 @@ import org.thingsboard.server.common.data.OtaPackage;
|
||||
import org.thingsboard.server.common.data.OtaPackageInfo;
|
||||
import org.thingsboard.server.common.data.audit.ActionType;
|
||||
import org.thingsboard.server.common.data.exception.ThingsboardException;
|
||||
import org.thingsboard.server.common.data.ota.ChecksumAlgorithm;
|
||||
import org.thingsboard.server.common.data.ota.OtaPackageType;
|
||||
import org.thingsboard.server.common.data.id.DeviceProfileId;
|
||||
import org.thingsboard.server.common.data.id.OtaPackageId;
|
||||
import org.thingsboard.server.common.data.ota.ChecksumAlgorithm;
|
||||
import org.thingsboard.server.common.data.ota.OtaPackageType;
|
||||
import org.thingsboard.server.common.data.page.PageData;
|
||||
import org.thingsboard.server.common.data.page.PageLink;
|
||||
import org.thingsboard.server.queue.util.TbCoreComponent;
|
||||
@ -109,12 +109,12 @@ public class OtaPackageController extends BaseController {
|
||||
@PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
|
||||
@RequestMapping(value = "/otaPackage", method = RequestMethod.POST)
|
||||
@ResponseBody
|
||||
public OtaPackageInfo saveOtaPackageInfo(@RequestBody OtaPackageInfo otaPackageInfo) throws ThingsboardException {
|
||||
public OtaPackageInfo saveOtaPackageInfo(@RequestBody OtaPackageInfo otaPackageInfo, @RequestParam boolean isUrl) throws ThingsboardException {
|
||||
boolean created = otaPackageInfo.getId() == null;
|
||||
try {
|
||||
otaPackageInfo.setTenantId(getTenantId());
|
||||
checkEntity(otaPackageInfo.getId(), otaPackageInfo, Resource.OTA_PACKAGE);
|
||||
OtaPackageInfo savedOtaPackageInfo = otaPackageService.saveOtaPackageInfo(otaPackageInfo);
|
||||
OtaPackageInfo savedOtaPackageInfo = otaPackageService.saveOtaPackageInfo(otaPackageInfo, isUrl);
|
||||
logEntityAction(savedOtaPackageInfo.getId(), savedOtaPackageInfo,
|
||||
null, created ? ActionType.ADDED : ActionType.UPDATED, null);
|
||||
return savedOtaPackageInfo;
|
||||
|
||||
@ -98,7 +98,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
Assert.assertNotNull(savedFirmwareInfo);
|
||||
Assert.assertNotNull(savedFirmwareInfo.getId());
|
||||
@ -109,7 +109,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
|
||||
savedFirmwareInfo.setAdditionalInfo(JacksonUtil.newObjectNode());
|
||||
|
||||
save(savedFirmwareInfo);
|
||||
save(savedFirmwareInfo, false);
|
||||
|
||||
OtaPackageInfo foundFirmwareInfo = doGet("/api/otaPackage/info/" + savedFirmwareInfo.getId().getId().toString(), OtaPackageInfo.class);
|
||||
Assert.assertEquals(foundFirmwareInfo.getTitle(), savedFirmwareInfo.getTitle());
|
||||
@ -123,7 +123,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
Assert.assertNotNull(savedFirmwareInfo);
|
||||
Assert.assertNotNull(savedFirmwareInfo.getId());
|
||||
@ -134,7 +134,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
|
||||
savedFirmwareInfo.setAdditionalInfo(JacksonUtil.newObjectNode());
|
||||
|
||||
save(savedFirmwareInfo);
|
||||
save(savedFirmwareInfo, false);
|
||||
|
||||
OtaPackageInfo foundFirmwareInfo = doGet("/api/otaPackage/info/" + savedFirmwareInfo.getId().getId().toString(), OtaPackageInfo.class);
|
||||
Assert.assertEquals(foundFirmwareInfo.getTitle(), savedFirmwareInfo.getTitle());
|
||||
@ -157,10 +157,10 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
loginDifferentTenant();
|
||||
doPost("/api/otaPackage", savedFirmwareInfo, OtaPackageInfo.class, status().isForbidden());
|
||||
doPost("/api/otaPackage?isUrl=false", savedFirmwareInfo, OtaPackageInfo.class, status().isForbidden());
|
||||
deleteDifferentTenant();
|
||||
}
|
||||
|
||||
@ -172,7 +172,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
OtaPackageInfo foundFirmware = doGet("/api/otaPackage/info/" + savedFirmwareInfo.getId().getId().toString(), OtaPackageInfo.class);
|
||||
Assert.assertNotNull(foundFirmware);
|
||||
@ -187,7 +187,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
MockMultipartFile testData = new MockMultipartFile("file", FILE_NAME, CONTENT_TYPE, DATA.array());
|
||||
|
||||
@ -207,7 +207,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
doDelete("/api/otaPackage/" + savedFirmwareInfo.getId().getId().toString())
|
||||
.andExpect(status().isOk());
|
||||
@ -226,7 +226,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION + i);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
if (i > 100) {
|
||||
MockMultipartFile testData = new MockMultipartFile("file", FILE_NAME, CONTENT_TYPE, DATA.array());
|
||||
@ -269,7 +269,7 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION + i);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = save(firmwareInfo, false);
|
||||
|
||||
if (i > 100) {
|
||||
MockMultipartFile testData = new MockMultipartFile("file", FILE_NAME, CONTENT_TYPE, DATA.array());
|
||||
@ -316,9 +316,8 @@ public abstract class BaseOtaPackageControllerTest extends AbstractControllerTes
|
||||
Assert.assertEquals(allOtaPackages, allLoadedOtaPackages);
|
||||
}
|
||||
|
||||
|
||||
private OtaPackageInfo save(OtaPackageInfo firmwareInfo) throws Exception {
|
||||
return doPost("/api/otaPackage", firmwareInfo, OtaPackageInfo.class);
|
||||
private OtaPackageInfo save(OtaPackageInfo firmwareInfo, boolean isUrl) throws Exception {
|
||||
return doPost("/api/otaPackage?isUrl=" + isUrl, firmwareInfo, OtaPackageInfo.class);
|
||||
}
|
||||
|
||||
protected OtaPackageInfo savaData(String urlTemplate, MockMultipartFile content, String... params) throws Exception {
|
||||
|
||||
@ -18,11 +18,11 @@ package org.thingsboard.server.dao.ota;
|
||||
import com.google.common.util.concurrent.ListenableFuture;
|
||||
import org.thingsboard.server.common.data.OtaPackage;
|
||||
import org.thingsboard.server.common.data.OtaPackageInfo;
|
||||
import org.thingsboard.server.common.data.ota.ChecksumAlgorithm;
|
||||
import org.thingsboard.server.common.data.ota.OtaPackageType;
|
||||
import org.thingsboard.server.common.data.id.DeviceProfileId;
|
||||
import org.thingsboard.server.common.data.id.OtaPackageId;
|
||||
import org.thingsboard.server.common.data.id.TenantId;
|
||||
import org.thingsboard.server.common.data.ota.ChecksumAlgorithm;
|
||||
import org.thingsboard.server.common.data.ota.OtaPackageType;
|
||||
import org.thingsboard.server.common.data.page.PageData;
|
||||
import org.thingsboard.server.common.data.page.PageLink;
|
||||
|
||||
@ -30,7 +30,7 @@ import java.nio.ByteBuffer;
|
||||
|
||||
public interface OtaPackageService {
|
||||
|
||||
OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo);
|
||||
OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo, boolean isUrl);
|
||||
|
||||
OtaPackage saveOtaPackage(OtaPackage otaPackage);
|
||||
|
||||
|
||||
@ -77,8 +77,11 @@ public class BaseOtaPackageService implements OtaPackageService {
|
||||
private TbTenantProfileCache tenantProfileCache;
|
||||
|
||||
@Override
|
||||
public OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo) {
|
||||
public OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo, boolean isUrl) {
|
||||
log.trace("Executing saveOtaPackageInfo [{}]", otaPackageInfo);
|
||||
if(isUrl && (StringUtils.isEmpty(otaPackageInfo.getUrl()) || otaPackageInfo.getUrl().trim().length() == 0)) {
|
||||
throw new DataValidationException("Ota package URL should be specified!");
|
||||
}
|
||||
otaPackageInfoValidator.validate(otaPackageInfo, OtaPackageInfo::getTenantId);
|
||||
try {
|
||||
OtaPackageId otaPackageId = otaPackageInfo.getId();
|
||||
@ -277,7 +280,9 @@ public class BaseOtaPackageService implements OtaPackageService {
|
||||
throw new DataValidationException("Wrong otaPackage file!");
|
||||
}
|
||||
} else {
|
||||
//TODO: validate url
|
||||
if(otaPackage.getData() != null) {
|
||||
throw new DataValidationException("File can't be saved if URL present!");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -336,6 +341,9 @@ public class BaseOtaPackageService implements OtaPackageService {
|
||||
if (otaPackageOld.getDataSize() != null && !otaPackageOld.getDataSize().equals(otaPackage.getDataSize())) {
|
||||
throw new DataValidationException("Updating otaPackage data size is prohibited!");
|
||||
}
|
||||
if(otaPackageOld.getUrl() != null && !otaPackageOld.getUrl().equals(otaPackage.getUrl())) {
|
||||
throw new DataValidationException("Updating otaPackage URL is prohibited!");
|
||||
}
|
||||
}
|
||||
|
||||
private void validateImpl(OtaPackageInfo otaPackageInfo) {
|
||||
|
||||
@ -163,7 +163,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmware.setVersion(VERSION);
|
||||
firmware.setUrl(URL);
|
||||
firmware.setDataSize(0L);
|
||||
OtaPackageInfo savedFirmware = otaPackageService.saveOtaPackageInfo(firmware);
|
||||
OtaPackageInfo savedFirmware = otaPackageService.saveOtaPackageInfo(firmware, true);
|
||||
|
||||
Assert.assertNotNull(savedFirmware);
|
||||
Assert.assertNotNull(savedFirmware.getId());
|
||||
@ -174,7 +174,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
Assert.assertEquals(firmware.getContentType(), savedFirmware.getContentType());
|
||||
|
||||
savedFirmware.setAdditionalInfo(JacksonUtil.newObjectNode());
|
||||
otaPackageService.saveOtaPackageInfo(savedFirmware);
|
||||
otaPackageService.saveOtaPackageInfo(savedFirmware, true);
|
||||
|
||||
OtaPackage foundFirmware = otaPackageService.findOtaPackageById(tenantId, savedFirmware.getId());
|
||||
Assert.assertEquals(foundFirmware.getTitle(), savedFirmware.getTitle());
|
||||
@ -190,7 +190,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmwareInfo.setType(FIRMWARE);
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
OtaPackageInfo savedFirmwareInfo = otaPackageService.saveOtaPackageInfo(firmwareInfo);
|
||||
OtaPackageInfo savedFirmwareInfo = otaPackageService.saveOtaPackageInfo(firmwareInfo, false);
|
||||
|
||||
Assert.assertNotNull(savedFirmwareInfo);
|
||||
Assert.assertNotNull(savedFirmwareInfo.getId());
|
||||
@ -216,7 +216,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
|
||||
savedFirmwareInfo = otaPackageService.findOtaPackageInfoById(tenantId, savedFirmwareInfo.getId());
|
||||
savedFirmwareInfo.setAdditionalInfo(JacksonUtil.newObjectNode());
|
||||
otaPackageService.saveOtaPackageInfo(savedFirmwareInfo);
|
||||
otaPackageService.saveOtaPackageInfo(savedFirmwareInfo, false);
|
||||
|
||||
OtaPackage foundFirmware = otaPackageService.findOtaPackageById(tenantId, firmware.getId());
|
||||
firmware.setAdditionalInfo(JacksonUtil.newObjectNode());
|
||||
@ -399,7 +399,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmwareInfo.setType(FIRMWARE);
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
otaPackageService.saveOtaPackageInfo(firmwareInfo);
|
||||
otaPackageService.saveOtaPackageInfo(firmwareInfo, false);
|
||||
|
||||
OtaPackageInfo newFirmwareInfo = new OtaPackageInfo();
|
||||
newFirmwareInfo.setTenantId(tenantId);
|
||||
@ -410,7 +410,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
|
||||
thrown.expect(DataValidationException.class);
|
||||
thrown.expectMessage("OtaPackage with such title and version already exists!");
|
||||
otaPackageService.saveOtaPackageInfo(newFirmwareInfo);
|
||||
otaPackageService.saveOtaPackageInfo(newFirmwareInfo, false);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -506,7 +506,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmware.setType(FIRMWARE);
|
||||
firmware.setTitle(TITLE);
|
||||
firmware.setVersion(VERSION);
|
||||
OtaPackageInfo savedFirmware = otaPackageService.saveOtaPackageInfo(firmware);
|
||||
OtaPackageInfo savedFirmware = otaPackageService.saveOtaPackageInfo(firmware, false);
|
||||
|
||||
OtaPackageInfo foundFirmware = otaPackageService.findOtaPackageInfoById(tenantId, savedFirmware.getId());
|
||||
Assert.assertNotNull(foundFirmware);
|
||||
@ -543,7 +543,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmwareWithUrl.setUrl(URL);
|
||||
firmwareWithUrl.setDataSize(0L);
|
||||
|
||||
OtaPackageInfo savedFwWithUrl = otaPackageService.saveOtaPackageInfo(firmwareWithUrl);
|
||||
OtaPackageInfo savedFwWithUrl = otaPackageService.saveOtaPackageInfo(firmwareWithUrl, true);
|
||||
savedFwWithUrl.setHasData(true);
|
||||
|
||||
firmwares.add(savedFwWithUrl);
|
||||
@ -588,7 +588,7 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
firmwareWithUrl.setUrl(URL);
|
||||
firmwareWithUrl.setDataSize(0L);
|
||||
|
||||
OtaPackageInfo savedFwWithUrl = otaPackageService.saveOtaPackageInfo(firmwareWithUrl);
|
||||
OtaPackageInfo savedFwWithUrl = otaPackageService.saveOtaPackageInfo(firmwareWithUrl, true);
|
||||
savedFwWithUrl.setHasData(true);
|
||||
|
||||
firmwares.add(savedFwWithUrl);
|
||||
@ -627,6 +627,40 @@ public abstract class BaseOtaPackageServiceTest extends AbstractServiceTest {
|
||||
Assert.assertTrue(pageData.getData().isEmpty());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSaveOtaPackageInfoWithBlankAndEmptyUrl() {
|
||||
OtaPackageInfo firmwareInfo = new OtaPackageInfo();
|
||||
firmwareInfo.setDeviceProfileId(deviceProfileId);
|
||||
firmwareInfo.setType(FIRMWARE);
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
firmwareInfo.setUrl(" ");
|
||||
thrown.expect(DataValidationException.class);
|
||||
thrown.expectMessage("Ota package URL should be specified!");
|
||||
otaPackageService.saveOtaPackageInfo(firmwareInfo, true);
|
||||
firmwareInfo.setUrl("");
|
||||
otaPackageService.saveOtaPackageInfo(firmwareInfo, true);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSaveOtaPackageUrlCantBeUpdated() {
|
||||
OtaPackageInfo firmwareInfo = new OtaPackageInfo();
|
||||
firmwareInfo.setDeviceProfileId(deviceProfileId);
|
||||
firmwareInfo.setType(FIRMWARE);
|
||||
firmwareInfo.setTitle(TITLE);
|
||||
firmwareInfo.setVersion(VERSION);
|
||||
firmwareInfo.setUrl(URL);
|
||||
firmwareInfo.setTenantId(tenantId);
|
||||
|
||||
OtaPackageInfo savedFirmwareInfo = otaPackageService.saveOtaPackageInfo(firmwareInfo, true);
|
||||
|
||||
thrown.expect(DataValidationException.class);
|
||||
thrown.expectMessage("Updating otaPackage URL is prohibited!");
|
||||
|
||||
savedFirmwareInfo.setUrl("https://newurl.com");
|
||||
otaPackageService.saveOtaPackageInfo(savedFirmwareInfo, true);
|
||||
}
|
||||
|
||||
private OtaPackage createFirmware(TenantId tenantId, String version) {
|
||||
OtaPackage firmware = new OtaPackage();
|
||||
firmware.setTenantId(tenantId);
|
||||
|
||||
@ -2967,8 +2967,10 @@ public class RestClient implements ClientHttpRequestInterceptor, Closeable {
|
||||
).getBody();
|
||||
}
|
||||
|
||||
public OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo) {
|
||||
return restTemplate.postForEntity(baseURL + "/api/otaPackage", otaPackageInfo, OtaPackageInfo.class).getBody();
|
||||
public OtaPackageInfo saveOtaPackageInfo(OtaPackageInfo otaPackageInfo, boolean isUrl) {
|
||||
Map<String, String> params = new HashMap<>();
|
||||
params.put("isUrl", Boolean.toString(isUrl));
|
||||
return restTemplate.postForEntity(baseURL + "/api/otaPackage?isUrl={isUrl}", otaPackageInfo, OtaPackageInfo.class, params).getBody();
|
||||
}
|
||||
|
||||
public OtaPackageInfo saveOtaPackageData(OtaPackageId otaPackageId, String checkSum, ChecksumAlgorithm checksumAlgorithm, MultipartFile file) throws Exception {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user