Commit 99a2cf04 by Jason Song Committed by GitHub

Merge pull request #290 from lepdou/0620_27

cluster unique check
parents 083ed49b cafa690b
......@@ -127,7 +127,19 @@ public class AdminServiceAPI {
return Arrays.asList(clusterDTOs);
}
public ClusterDTO createOrUpdate(Env env, ClusterDTO cluster){
public ClusterDTO loadCluster(String appId, Env env, String clusterName) {
return restTemplate.getForObject("{host}/apps/{appId}/clusters/{clusterName}", ClusterDTO.class,
getAdminServiceHost(env), appId, clusterName);
}
public boolean isClusterUnique(String appId, Env env, String clusterName) {
return restTemplate
.getForObject("{host}/apps/{appId}/cluster/{clusterName}/unique", Boolean.class, getAdminServiceHost(env),
appId, clusterName);
}
public ClusterDTO createOrUpdate(Env env, ClusterDTO cluster) {
return restTemplate.postForObject("{host}/apps/{appId}/clusters", cluster, ClusterDTO.class,
getAdminServiceHost(env), cluster.getAppId());
}
......@@ -172,7 +184,8 @@ public class AdminServiceAPI {
CommitDTO[]
commitDTOs =
restTemplate.getForObject("{host}/apps/{appId}/clusters/{clusterName}/namespaces/{namespaceName}/commit?page={page}&size={size}",
restTemplate.getForObject(
"{host}/apps/{appId}/clusters/{clusterName}/namespaces/{namespaceName}/commit?page={page}&size={size}",
CommitDTO[].class,
getAdminServiceHost(env), appId, clusterName, namespaceName, page, size);
......
......@@ -2,6 +2,7 @@ package com.ctrip.framework.apollo.portal.service;
import com.ctrip.framework.apollo.core.enums.Env;
import com.ctrip.framework.apollo.core.dto.ClusterDTO;
import com.ctrip.framework.apollo.core.exception.BadRequestException;
import com.ctrip.framework.apollo.portal.api.AdminServiceAPI;
import org.springframework.beans.factory.annotation.Autowired;
......@@ -20,6 +21,9 @@ public class ClusterService {
}
public ClusterDTO createCluster(Env env, ClusterDTO cluster){
if (!clusterAPI.isClusterUnique(cluster.getAppId(), env, cluster.getName())){
throw new BadRequestException(String.format("cluster %s already exists.", cluster.getName()));
}
return clusterAPI.createOrUpdate(env, cluster);
}
......
......@@ -24,7 +24,10 @@ cluster_module.controller('ClusterController',
};
$scope.create = function () {
var noEnvChecked = true;
$scope.envs.forEach(function (env) {
if (env.checked) {
noEnvChecked = false;
ClusterService.create_cluster($scope.appId, env.name,
{
name: $scope.clusterName,
......@@ -34,9 +37,13 @@ cluster_module.controller('ClusterController',
}, function (result) {
toastr.error(AppUtil.errorMsg(result), "集群创建失败");
})
}
})
if (noEnvChecked){
toastr.warning("请选择环境");
}
};
}]);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment