|
|
@ -54,13 +54,26 @@ import java.util.List;
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public class ApplicationStorageManagerImpl implements ApplicationStorageManager {
|
|
|
|
public class ApplicationStorageManagerImpl implements ApplicationStorageManager {
|
|
|
|
private static final Log log = LogFactory.getLog(ApplicationStorageManagerImpl.class);
|
|
|
|
private static final Log log = LogFactory.getLog(ApplicationStorageManagerImpl.class);
|
|
|
|
|
|
|
|
private String storagePath;
|
|
|
|
|
|
|
|
private int screenShotMaxCount;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* Create a new ApplicationStorageManager Instance
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param storagePath Storage Path to save the binary and image files.
|
|
|
|
|
|
|
|
* @param screenShotMaxCount Maximum Screen-shots count
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
public ApplicationStorageManagerImpl(String storagePath, String screenShotMaxCount) {
|
|
|
|
|
|
|
|
this.storagePath = storagePath;
|
|
|
|
|
|
|
|
this.screenShotMaxCount = Integer.parseInt(screenShotMaxCount);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void uploadImageArtifacts(String applicationUUID, InputStream iconFileStream, InputStream bannerFileStream,
|
|
|
|
public void uploadImageArtifacts(String applicationUUID, InputStream iconFileStream, InputStream bannerFileStream,
|
|
|
|
List<InputStream> screenShotStreams) throws ApplicationStorageManagementException {
|
|
|
|
List<InputStream> screenShotStreams) throws ApplicationStorageManagementException {
|
|
|
|
int tenantId = PrivilegedCarbonContext.getThreadLocalCarbonContext().getTenantId(true);
|
|
|
|
int tenantId = PrivilegedCarbonContext.getThreadLocalCarbonContext().getTenantId(true);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
String artifactDirectoryPath = Constants.artifactPath + application.getId();
|
|
|
|
String artifactDirectoryPath = storagePath + application.getId();
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
log.debug("Artifact Directory Path for saving the artifacts related with application " + applicationUUID
|
|
|
|
log.debug("Artifact Directory Path for saving the artifacts related with application " + applicationUUID
|
|
|
|
+ " is " + artifactDirectoryPath);
|
|
|
|
+ " is " + artifactDirectoryPath);
|
|
|
@ -86,12 +99,29 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (screenShotStreams != null) {
|
|
|
|
if (screenShotStreams != null) {
|
|
|
|
int count = application.getScreenShotCount() + 1;
|
|
|
|
int count = application.getScreenShotCount() + 1;
|
|
|
|
|
|
|
|
boolean maxCountReached = false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (count > screenShotMaxCount) {
|
|
|
|
|
|
|
|
log.error("Maximum limit for the screen-shot is " + screenShotMaxCount
|
|
|
|
|
|
|
|
+ " Cannot upload another screenshot for the application with the UUID " + applicationUUID);
|
|
|
|
|
|
|
|
maxCountReached = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
String screenshotName;
|
|
|
|
String screenshotName;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (maxCountReached) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
for (InputStream screenshotStream : screenShotStreams) {
|
|
|
|
for (InputStream screenshotStream : screenShotStreams) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
screenshotName = Constants.IMAGE_ARTIFACTS[2] + count;
|
|
|
|
screenshotName = Constants.IMAGE_ARTIFACTS[2] + count;
|
|
|
|
saveFile(screenshotStream, artifactDirectoryPath + File.separator + screenshotName);
|
|
|
|
saveFile(screenshotStream, artifactDirectoryPath + File.separator + screenshotName);
|
|
|
|
count++;
|
|
|
|
count++;
|
|
|
|
|
|
|
|
if (count > screenShotMaxCount) {
|
|
|
|
|
|
|
|
log.error("Maximum limit for the screen-shot is " + screenShotMaxCount
|
|
|
|
|
|
|
|
+ " Cannot upload another screenshot for the application with the UUID "
|
|
|
|
|
|
|
|
+ applicationUUID);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
} catch (IOException e) {
|
|
|
|
} catch (IOException e) {
|
|
|
|
throw new ApplicationStorageManagementException(
|
|
|
|
throw new ApplicationStorageManagementException(
|
|
|
|
"IO Exception while saving the screens hots for the " + "application " + applicationUUID,
|
|
|
|
"IO Exception while saving the screens hots for the " + "application " + applicationUUID,
|
|
|
@ -127,7 +157,7 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
public void uploadReleaseArtifacts(String applicationUUID, String versionName, InputStream binaryFile)
|
|
|
|
public void uploadReleaseArtifacts(String applicationUUID, String versionName, InputStream binaryFile)
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
String artifactDirectoryPath = Constants.artifactPath + application.getId();
|
|
|
|
String artifactDirectoryPath = storagePath + application.getId();
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
log.debug("Artifact Directory Path for saving the application release related artifacts related with "
|
|
|
|
log.debug("Artifact Directory Path for saving the application release related artifacts related with "
|
|
|
|
+ "application " + applicationUUID + " is " + artifactDirectoryPath);
|
|
|
|
+ "application " + applicationUUID + " is " + artifactDirectoryPath);
|
|
|
@ -150,7 +180,7 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
public InputStream getReleasedArtifacts(String applicationUUID, String versionName)
|
|
|
|
public InputStream getReleasedArtifacts(String applicationUUID, String versionName)
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
String artifactPath = Constants.artifactPath + application.getId() + File.separator + versionName;
|
|
|
|
String artifactPath = storagePath + application.getId() + File.separator + versionName;
|
|
|
|
|
|
|
|
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
if (log.isDebugEnabled()) {
|
|
|
|
log.debug("ApplicationRelease artifacts are searched in the location " + artifactPath);
|
|
|
|
log.debug("ApplicationRelease artifacts are searched in the location " + artifactPath);
|
|
|
@ -173,7 +203,7 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void deleteApplicationArtifacts(String applicationUUID) throws ApplicationStorageManagementException {
|
|
|
|
public void deleteApplicationArtifacts(String applicationUUID) throws ApplicationStorageManagementException {
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
String artifactDirectoryPath = Constants.artifactPath + application.getId();
|
|
|
|
String artifactDirectoryPath = storagePath + application.getId();
|
|
|
|
File artifactDirectory = new File(artifactDirectoryPath);
|
|
|
|
File artifactDirectory = new File(artifactDirectoryPath);
|
|
|
|
|
|
|
|
|
|
|
|
if (artifactDirectory.exists()) {
|
|
|
|
if (artifactDirectory.exists()) {
|
|
|
@ -185,7 +215,7 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
public void deleteApplicationReleaseArtifacts(String applicationUUID, String version)
|
|
|
|
public void deleteApplicationReleaseArtifacts(String applicationUUID, String version)
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
throws ApplicationStorageManagementException {
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
String artifactPath = Constants.artifactPath + application.getId() + File.separator + version;
|
|
|
|
String artifactPath = storagePath + application.getId() + File.separator + version;
|
|
|
|
File artifact = new File(artifactPath);
|
|
|
|
File artifact = new File(artifactPath);
|
|
|
|
|
|
|
|
|
|
|
|
if (artifact.exists()) {
|
|
|
|
if (artifact.exists()) {
|
|
|
@ -215,7 +245,7 @@ public class ApplicationStorageManagerImpl implements ApplicationStorageManager
|
|
|
|
ApplicationStorageManagementException {
|
|
|
|
ApplicationStorageManagementException {
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
Application application = validateApplication(applicationUUID);
|
|
|
|
validateImageArtifactNames(name);
|
|
|
|
validateImageArtifactNames(name);
|
|
|
|
String imageArtifactPath = Constants.artifactPath + application.getId() + File.separator + name.toLowerCase();
|
|
|
|
String imageArtifactPath = storagePath + application.getId() + File.separator + name.toLowerCase();
|
|
|
|
|
|
|
|
|
|
|
|
if (name.equalsIgnoreCase(Constants.IMAGE_ARTIFACTS[2])) {
|
|
|
|
if (name.equalsIgnoreCase(Constants.IMAGE_ARTIFACTS[2])) {
|
|
|
|
imageArtifactPath += count;
|
|
|
|
imageArtifactPath += count;
|
|
|
|