mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
modules
This commit is contained in:
parent
d06d6dae72
commit
07d00ebbfa
6
framework/events/.classpath
Executable file
6
framework/events/.classpath
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
framework/events/.project
Executable file
17
framework/events/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>framework-events</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
6
framework/ipc/.classpath
Executable file
6
framework/ipc/.classpath
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
framework/ipc/.project
Executable file
17
framework/ipc/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>framework-ipc</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
11
framework/ipc/.settings/org.eclipse.jdt.core.prefs
Executable file
11
framework/ipc/.settings/org.eclipse.jdt.core.prefs
Executable file
@ -0,0 +1,11 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7
|
||||
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
||||
org.eclipse.jdt.core.compiler.compliance=1.7
|
||||
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
||||
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
||||
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.source=1.7
|
||||
@ -0,0 +1,27 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.container;
|
||||
|
||||
/**
|
||||
* Container of different processes so it doesn't have to deal with message
|
||||
* to Java call.
|
||||
*/
|
||||
public interface ServerContainer {
|
||||
|
||||
}
|
||||
33
framework/ipc/src/org/apache/cloudstack/framework/ipc/Ipc.java
Executable file
33
framework/ipc/src/org/apache/cloudstack/framework/ipc/Ipc.java
Executable file
@ -0,0 +1,33 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
import java.lang.annotation.ElementType;
|
||||
import java.lang.annotation.Retention;
|
||||
import java.lang.annotation.RetentionPolicy;
|
||||
import java.lang.annotation.Target;
|
||||
|
||||
/**
|
||||
* Marks a method as an ipc mechanism
|
||||
*/
|
||||
@Retention(RetentionPolicy.RUNTIME)
|
||||
@Target(ElementType.METHOD)
|
||||
public @interface Ipc {
|
||||
String topic();
|
||||
}
|
||||
23
framework/ipc/src/org/apache/cloudstack/framework/ipc/IpcIntercepter.java
Executable file
23
framework/ipc/src/org/apache/cloudstack/framework/ipc/IpcIntercepter.java
Executable file
@ -0,0 +1,23 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
public class IpcIntercepter {
|
||||
|
||||
}
|
||||
22
framework/ipc/src/org/apache/cloudstack/framework/ipc/IpcParam.java
Executable file
22
framework/ipc/src/org/apache/cloudstack/framework/ipc/IpcParam.java
Executable file
@ -0,0 +1,22 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
public @interface IpcParam {
|
||||
}
|
||||
26
framework/ipc/src/org/apache/cloudstack/framework/ipc/Message.java
Executable file
26
framework/ipc/src/org/apache/cloudstack/framework/ipc/Message.java
Executable file
@ -0,0 +1,26 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
public interface Message {
|
||||
String getTopic();
|
||||
Map<String, Object> getContent();
|
||||
}
|
||||
43
framework/ipc/src/org/apache/cloudstack/framework/ipc/MessageSystem.java
Executable file
43
framework/ipc/src/org/apache/cloudstack/framework/ipc/MessageSystem.java
Executable file
@ -0,0 +1,43 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
public interface MessageSystem {
|
||||
/**
|
||||
* Creates the publisher
|
||||
* @param name of the publisher
|
||||
* @return publisher
|
||||
*/
|
||||
Publisher createPublisher(String name);
|
||||
|
||||
/**
|
||||
* Creates the subscriber
|
||||
* @param name of the subscriber
|
||||
* @return subscriber
|
||||
*/
|
||||
Subscriber createSubscriber(String name);
|
||||
|
||||
/**
|
||||
* registers the subscriber
|
||||
* @param subscriber subscriber
|
||||
* @param topic topic to listen to
|
||||
* @return subscriber
|
||||
*/
|
||||
boolean registerSubscriber(Subscriber subscriber, String topic);
|
||||
}
|
||||
42
framework/ipc/src/org/apache/cloudstack/framework/ipc/Publisher.java
Executable file
42
framework/ipc/src/org/apache/cloudstack/framework/ipc/Publisher.java
Executable file
@ -0,0 +1,42 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* Publish the Event
|
||||
*
|
||||
*/
|
||||
public interface Publisher {
|
||||
/**
|
||||
* Publish a topic
|
||||
*
|
||||
* @param topic topic being published
|
||||
* @param content content published
|
||||
* @return true if the topic has been picked up; false if not.
|
||||
*/
|
||||
boolean publish(String topic, Map<String, Object> content);
|
||||
|
||||
/**
|
||||
* @return the name of this publisher
|
||||
*/
|
||||
String getName();
|
||||
|
||||
}
|
||||
37
framework/ipc/src/org/apache/cloudstack/framework/ipc/Subscriber.java
Executable file
37
framework/ipc/src/org/apache/cloudstack/framework/ipc/Subscriber.java
Executable file
@ -0,0 +1,37 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.ipc;
|
||||
|
||||
/**
|
||||
* Event subscriber interface
|
||||
*
|
||||
*/
|
||||
public interface Subscriber {
|
||||
|
||||
/**
|
||||
* Message received
|
||||
*/
|
||||
Message receive();
|
||||
|
||||
/**
|
||||
* @return the name of the subscriber
|
||||
*/
|
||||
String getName();
|
||||
|
||||
}
|
||||
6
framework/jobs/.classpath
Executable file
6
framework/jobs/.classpath
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
framework/jobs/.project
Executable file
17
framework/jobs/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>framework-jobs</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
11
framework/jobs/.settings/org.eclipse.jdt.core.prefs
Executable file
11
framework/jobs/.settings/org.eclipse.jdt.core.prefs
Executable file
@ -0,0 +1,11 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7
|
||||
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
||||
org.eclipse.jdt.core.compiler.compliance=1.7
|
||||
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
||||
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
||||
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.source=1.7
|
||||
24
framework/jobs/src/org/apache/cloudstack/framework/job/Job.java
Executable file
24
framework/jobs/src/org/apache/cloudstack/framework/job/Job.java
Executable file
@ -0,0 +1,24 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.job;
|
||||
|
||||
public @interface Job {
|
||||
|
||||
|
||||
}
|
||||
27
framework/jobs/src/org/apache/cloudstack/framework/job/JobInterceptor.java
Executable file
27
framework/jobs/src/org/apache/cloudstack/framework/job/JobInterceptor.java
Executable file
@ -0,0 +1,27 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.framework.job;
|
||||
|
||||
/**
|
||||
* @author ahuang
|
||||
*
|
||||
*/
|
||||
public class JobInterceptor {
|
||||
|
||||
}
|
||||
8
platform/api/.classpath
Executable file
8
platform/api/.classpath
Executable file
@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/api"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/server"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/api/.project
Executable file
17
platform/api/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-api</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
@ -0,0 +1,29 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.service.api;
|
||||
|
||||
import java.net.URI;
|
||||
import java.util.List;
|
||||
|
||||
public interface DirectoryService {
|
||||
void registerService(String serviceName, URI endpoint);
|
||||
void unregisterService(String serviceName, URI endpoint);
|
||||
List<URI> getEndPoints(String serviceName);
|
||||
URI getLoadBalancedEndPoint(String serviceName);
|
||||
}
|
||||
@ -0,0 +1,45 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.service.api;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import com.cloud.network.Network;
|
||||
import com.cloud.storage.Volume;
|
||||
import com.cloud.vm.VirtualMachine;
|
||||
|
||||
/**
|
||||
* Service to retrieve CloudStack entities
|
||||
* very likely to change
|
||||
*/
|
||||
public interface EntityService {
|
||||
List<String> listVirtualMachines();
|
||||
List<String> listVolumes();
|
||||
List<String> listNetworks();
|
||||
List<String> listNics();
|
||||
List<String> listSnapshots();
|
||||
List<String> listTemplates();
|
||||
List<String> listStoragePools();
|
||||
List<String> listHosts();
|
||||
|
||||
VirtualMachine getVirtualMachine(String vm);
|
||||
Volume getVolume(String volume);
|
||||
Network getNetwork(String network);
|
||||
|
||||
}
|
||||
@ -0,0 +1,35 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.service.api;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import com.cloud.async.AsyncJob;
|
||||
|
||||
public interface JobsManagementService {
|
||||
List<AsyncJob> listJobs();
|
||||
|
||||
List<AsyncJob> listJobsInProgress();
|
||||
|
||||
List<AsyncJob> listJobsCompleted(Long from);
|
||||
|
||||
List<AsyncJob> listJobsInWaiting();
|
||||
|
||||
void cancelJob(String job);
|
||||
}
|
||||
@ -0,0 +1,64 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.service.api;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import com.cloud.dc.DataCenter;
|
||||
import com.cloud.dc.Pod;
|
||||
import com.cloud.host.Host;
|
||||
import com.cloud.host.Status;
|
||||
import com.cloud.storage.StoragePool;
|
||||
|
||||
|
||||
/**
|
||||
* ManagementService specifies the management aspects of the
|
||||
* Orchestration Platform.
|
||||
*/
|
||||
public interface ManagementService {
|
||||
|
||||
/**
|
||||
* Registers a storage to use
|
||||
* @param uuid
|
||||
* @return
|
||||
*/
|
||||
String registerStorage(String name, List<String> tags, Map<String, String> details);
|
||||
String registerZone(String name, List<String> tags, Map<String, String> details);
|
||||
String registerPod(String name, List<String> tags, Map<String, String> details);
|
||||
String registerCluster(String name, List<String> tags, Map<String, String> details);
|
||||
String registerHost(String name, List<String> tags, Map<String, String> details);
|
||||
|
||||
void deregisterStorage(String uuid);
|
||||
void deregisterZone();
|
||||
void deregisterPod();
|
||||
void deregisterCluster();
|
||||
void deregisterHost();
|
||||
|
||||
void changeState(String type, String entity, Status state);
|
||||
|
||||
List<Host> listHosts();
|
||||
|
||||
List<Pod> listPods();
|
||||
|
||||
List<DataCenter> listZones();
|
||||
|
||||
List<StoragePool> listStorage();
|
||||
|
||||
}
|
||||
@ -0,0 +1,127 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.service.api;
|
||||
|
||||
import java.net.URL;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import com.cloud.exception.InsufficientCapacityException;
|
||||
import com.cloud.hypervisor.Hypervisor;
|
||||
import com.cloud.vm.VirtualMachine;
|
||||
|
||||
public interface OrchestrationService {
|
||||
/**
|
||||
* Reserves a new virtual machine
|
||||
*
|
||||
* @param uuid externally unique name to reference the virtual machine
|
||||
* @param template reference to the template
|
||||
* @param hostName name of the host
|
||||
* @param cpu # of cpu cores
|
||||
* @param speed speed of the cpu core
|
||||
* @param memory memory to allocate in bytes
|
||||
* @param networks networks that this VM belongs in
|
||||
* @param rootDiskTags tags for the root disk
|
||||
* @param computeTags tags for the compute
|
||||
* @param details extra details to store for the VM
|
||||
* @return VirtualMachine
|
||||
*/
|
||||
VirtualMachine create(String uuid,
|
||||
String template,
|
||||
String hostName,
|
||||
int cpu,
|
||||
int speed,
|
||||
long memory,
|
||||
List<String> networks,
|
||||
List<String> rootDiskTags,
|
||||
List<String> computeTags,
|
||||
Map<String, String> details,
|
||||
String owner);
|
||||
|
||||
VirtualMachine createFromScratch(String uuid,
|
||||
String iso,
|
||||
String os,
|
||||
String hypervisor,
|
||||
String hostName,
|
||||
int cpu,
|
||||
int speed,
|
||||
long memory,
|
||||
List<String> networks,
|
||||
List<String> computeTags,
|
||||
Map<String, String> details,
|
||||
String owner);
|
||||
|
||||
/**
|
||||
* Make reservations for a VM
|
||||
* @param vm uuid of the VM
|
||||
* @param planner DeploymentPlanner to use
|
||||
* @param until time specified in seconds before reservation expires. null means to reserve forever.
|
||||
* @return reservation id
|
||||
*/
|
||||
String reserve(String vm, String planner, Long until) throws InsufficientCapacityException;
|
||||
|
||||
String cancel(String reservationId);
|
||||
|
||||
/**
|
||||
* Deploy the reservation
|
||||
* @param reservationId reservation id during the deployment
|
||||
* @return job Id
|
||||
* @throws CloudRuntimeException if error
|
||||
*/
|
||||
@Job(callback=)
|
||||
String deploy(String reservationId);
|
||||
|
||||
/**
|
||||
* Stops the vm
|
||||
* @param vm vm
|
||||
* @throws CloudRuntimeException if error
|
||||
*/
|
||||
String stop(String vm);
|
||||
|
||||
/**
|
||||
* destroys the vm
|
||||
* @param vm vm
|
||||
* @throws CloudRuntimeException if error
|
||||
*/
|
||||
void destroy(String vm);
|
||||
|
||||
void joinNetwork(String network1, String network2);
|
||||
|
||||
void attachNetwork(String network, String vm);
|
||||
|
||||
void detachNetwork(String network, String vm);
|
||||
|
||||
void attachVolume(String vm, String vol);
|
||||
|
||||
void createNetwork();
|
||||
|
||||
void destroyNetwork();
|
||||
|
||||
void createVolume();
|
||||
|
||||
void destroyVolume();
|
||||
|
||||
void snapshotVirtualMachine(String vm);
|
||||
|
||||
void snapshotVolume(String volume);
|
||||
|
||||
void backup(String snapshot);
|
||||
|
||||
void registerTemplate(String name, URL path, String os, Hypervisor hypervisor);
|
||||
}
|
||||
@ -0,0 +1,30 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.subsystem.api.hypervisor;
|
||||
|
||||
public interface ComputeSubsystem {
|
||||
|
||||
void start(String vm, String reservationId);
|
||||
|
||||
void cancel(String reservationId);
|
||||
|
||||
void stop(String vm, String reservationId);
|
||||
|
||||
void migrate(String vm, String reservationId);
|
||||
}
|
||||
@ -0,0 +1,47 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.subsystem.api.network;
|
||||
|
||||
public interface NetworkServiceProvider {
|
||||
/**
|
||||
* Plug your network elements into this network
|
||||
* @param network
|
||||
* @param reservationId
|
||||
*/
|
||||
void plugInto(String network, String reservationId);
|
||||
|
||||
/**
|
||||
* Unplug your network elements from this network
|
||||
* @param network
|
||||
* @param reservationId
|
||||
*/
|
||||
void unplugFrom(String network, String reservationId);
|
||||
|
||||
/**
|
||||
* Cancel a previous work
|
||||
* @param reservationId
|
||||
*/
|
||||
void cancel(String reservationId);
|
||||
|
||||
void provideServiceTo(String vm, String network, String reservationId);
|
||||
|
||||
void removeServiceFrom(String vm, String network, String reservationId);
|
||||
|
||||
void cleanUp(String network, String reservationId);
|
||||
}
|
||||
@ -0,0 +1,35 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.subsystem.api.network;
|
||||
|
||||
public interface NetworkSubsystem {
|
||||
String createNetwork();
|
||||
|
||||
String start(String network, String reservationId);
|
||||
|
||||
void shutdown(String nework, String reservationId);
|
||||
|
||||
void prepare(String vm, String network, String reservationId);
|
||||
|
||||
void release(String vm, String network, String reservationId);
|
||||
|
||||
void cancel(String reservationId);
|
||||
|
||||
void destroy(String network, String reservationId);
|
||||
}
|
||||
@ -0,0 +1,23 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.subsystem.api.storage;
|
||||
|
||||
public interface DataMigrationSubSystem {
|
||||
void migrate(String volume, String storagePool, String reservationId);
|
||||
}
|
||||
@ -0,0 +1,13 @@
|
||||
package org.apache.cloudstack.platform.subsystem.api.storage;
|
||||
|
||||
import java.net.URI;
|
||||
|
||||
import com.cloud.org.Grouping;
|
||||
|
||||
public interface StorageSubSystem {
|
||||
String getType();
|
||||
Class<? extends Grouping> getScope();
|
||||
|
||||
URI grantAccess(String vol, String reservationId);
|
||||
URI RemoveAccess(String vol, String reservationId);
|
||||
}
|
||||
7
platform/compute/.classpath
Executable file
7
platform/compute/.classpath
Executable file
@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/framework-ipc"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/compute/.project
Executable file
17
platform/compute/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-compute</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
38
platform/compute/src/org/apache/cloudstack/compute/ComputeOrchestrator.java
Executable file
38
platform/compute/src/org/apache/cloudstack/compute/ComputeOrchestrator.java
Executable file
@ -0,0 +1,38 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.compute;
|
||||
|
||||
import org.apache.cloudstack.framework.ipc.Ipc;
|
||||
import org.apache.cloudstack.framework.ipc.IpcParam;
|
||||
|
||||
public interface ComputeOrchestrator {
|
||||
/**
|
||||
* start the vm
|
||||
* @param vm vm
|
||||
* @param reservationId
|
||||
*/
|
||||
@Ipc(topic="cs.compute.start")
|
||||
void start(@IpcParam String vm, @IpcParam String reservationId);
|
||||
|
||||
@Ipc(topic="cs.compute.cancel")
|
||||
void cancel(@IpcParam String reservationId);
|
||||
|
||||
@Ipc(topic="cs.compute.stop")
|
||||
void stop(@IpcParam String vm, @IpcParam String reservationId);
|
||||
}
|
||||
@ -0,0 +1,41 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.compute;
|
||||
|
||||
|
||||
public class ComputeOrchestratorImpl implements ComputeOrchestrator {
|
||||
|
||||
@Override
|
||||
public void start(String vm, String reservationId) {
|
||||
// Retrieve the VM
|
||||
// Locate the HypervisorGuru based on the VM type
|
||||
// Call HypervisorGuru to start the VM
|
||||
}
|
||||
|
||||
@Override
|
||||
public void cancel(String reservationId) {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void stop(String vm, String reservationId) {
|
||||
// Retrieve the VM
|
||||
// Locate the HypervisorGuru based on the VM type
|
||||
// Call HypervisorGuru to stop the VM
|
||||
}
|
||||
}
|
||||
6
platform/network/.classpath
Executable file
6
platform/network/.classpath
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/network/.project
Executable file
17
platform/network/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-network</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
40
platform/network/src/org/apache/cloudstack/network/NetworkOrchestrator.java
Executable file
40
platform/network/src/org/apache/cloudstack/network/NetworkOrchestrator.java
Executable file
@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.network;
|
||||
|
||||
public interface NetworkOrchestrator {
|
||||
|
||||
/**
|
||||
* Prepares for a VM to join a network
|
||||
* @param vm vm
|
||||
* @param reservationId reservation id
|
||||
*/
|
||||
void prepare(String vm, String reservationId);
|
||||
|
||||
/**
|
||||
* Release all reservation
|
||||
*/
|
||||
void release(String vm, String reservationId);
|
||||
|
||||
/**
|
||||
* Cancel a previous reservation
|
||||
* @param reservationId
|
||||
*/
|
||||
void cancel(String reservationId);
|
||||
}
|
||||
10
platform/orchestration/.classpath
Executable file
10
platform/orchestration/.classpath
Executable file
@ -0,0 +1,10 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/api"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/platform-api"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/platform-planning"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/framework-ipc"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/orchestration/.project
Executable file
17
platform/orchestration/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-orchestration</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
11
platform/orchestration/.settings/org.eclipse.jdt.core.prefs
Executable file
11
platform/orchestration/.settings/org.eclipse.jdt.core.prefs
Executable file
@ -0,0 +1,11 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.7
|
||||
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
|
||||
org.eclipse.jdt.core.compiler.compliance=1.7
|
||||
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
|
||||
org.eclipse.jdt.core.compiler.debug.localVariable=generate
|
||||
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
|
||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.source=1.7
|
||||
@ -0,0 +1,164 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.orchestration;
|
||||
|
||||
import java.net.URL;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.cloudstack.framework.ipc.Publisher;
|
||||
import org.apache.cloudstack.platform.planning.Concierge;
|
||||
import org.apache.cloudstack.platform.service.api.OrchestrationService;
|
||||
|
||||
import com.cloud.exception.InsufficientCapacityException;
|
||||
import com.cloud.hypervisor.Hypervisor;
|
||||
import com.cloud.vm.VirtualMachine;
|
||||
|
||||
public class CloudOrchestrator implements OrchestrationService {
|
||||
int _retryCount = 5;
|
||||
Concierge _concierge = null; // These are injected
|
||||
Publisher _publisher = null;
|
||||
|
||||
@Override
|
||||
public VirtualMachine create(String uuid, String template, String hostName, int cpu, int speed, long memory, List<String> networks, List<String> rootDiskTags, List<String> computeTags, Map<String, String> details,
|
||||
String owner) {
|
||||
// creates a virtual machine and relevant work in database
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public VirtualMachine createFromScratch(String uuid, String iso, String os, String hypervisor, String hostName, int cpu, int speed, long memory, List<String> networks, List<String> computeTags,
|
||||
Map<String, String> details, String owner) {
|
||||
// creates a virtual machine and relevant work in database
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String reserve(String vm, String planner, Long until) throws InsufficientCapacityException {
|
||||
return _concierge.reserve(vm, planner);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String cancel(String reservationId) {
|
||||
// TODO Auto-generated method stub
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String deploy(String reservationId, String callback) {
|
||||
for (int i = 0; i < _retryCount; i++) {
|
||||
try {
|
||||
// Retrieves the reservation
|
||||
// Signals Network and Storage to prepare
|
||||
// Signals Compute
|
||||
_concierge.claim(reservationId);
|
||||
} catch (Exception e) {
|
||||
// Cancel reservations.
|
||||
}
|
||||
_concierge.reserveAnother(reservationId);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String stop(String vm) {
|
||||
|
||||
// TODO Auto-generated method stub
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void destroy(String vm) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void joinNetwork(String network1, String network2) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void attachNetwork(String network, String vm) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void detachNetwork(String network, String vm) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void attachVolume(String vm, String vol) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void createNetwork() {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void destroyNetwork() {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void createVolume() {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void destroyVolume() {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void snapshotVirtualMachine(String vm) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void snapshotVolume(String volume) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void backup(String snapshot) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void registerTemplate(String name, URL path, String os, Hypervisor hypervisor) {
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
8
platform/planning/.classpath
Executable file
8
platform/planning/.classpath
Executable file
@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/api"/>
|
||||
<classpathentry combineaccessrules="false" kind="src" path="/framework-ipc"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/planning/.project
Executable file
17
platform/planning/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-planning</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
36
platform/planning/src/org/apache/cloudstack/platform/planning/Concierge.java
Executable file
36
platform/planning/src/org/apache/cloudstack/platform/planning/Concierge.java
Executable file
@ -0,0 +1,36 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.platform.planning;
|
||||
|
||||
import org.apache.cloudstack.framework.ipc.Ipc;
|
||||
|
||||
public interface Concierge {
|
||||
@Ipc(topic="cs.concierge.reserve")
|
||||
String reserve(String vm, String planner, Long until);
|
||||
|
||||
@Ipc(topic="cs.concierge.cancel")
|
||||
String cancel(String reservationId);
|
||||
|
||||
@Ipc(topic="cs.concierge.claim")
|
||||
String claim(String reservationId);
|
||||
|
||||
@Ipc(topic="cs.concierge.reserveAnother")
|
||||
String reserveAnother(String reservationId);
|
||||
|
||||
}
|
||||
6
platform/storage/.classpath
Executable file
6
platform/storage/.classpath
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
17
platform/storage/.project
Executable file
17
platform/storage/.project
Executable file
@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>platform-storage</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
</projectDescription>
|
||||
52
platform/storage/src/org/apache/cloudstack/storage/StorageOrchestrator.java
Executable file
52
platform/storage/src/org/apache/cloudstack/storage/StorageOrchestrator.java
Executable file
@ -0,0 +1,52 @@
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you under the Apache License, Version 2.0 (the
|
||||
* "License"); you may not use this file except in compliance
|
||||
* with the License. You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing,
|
||||
* software distributed under the License is distributed on an
|
||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
* KIND, either express or implied. See the License for the
|
||||
* specific language governing permissions and limitations
|
||||
* under the License.
|
||||
*/
|
||||
package org.apache.cloudstack.storage;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
public interface StorageOrchestrator {
|
||||
|
||||
/**
|
||||
* Prepares all storage ready for a VM to start
|
||||
* @param vm
|
||||
* @param reservationId
|
||||
*/
|
||||
void prepare(String vm, String reservationId);
|
||||
|
||||
/**
|
||||
* Releases all storage that were used for a VM shutdown
|
||||
* @param vm
|
||||
* @param disks
|
||||
* @param reservationId
|
||||
*/
|
||||
void release(String vm, String reservationId);
|
||||
|
||||
/**
|
||||
* Destroy all disks
|
||||
* @param disks
|
||||
* @param reservationId
|
||||
*/
|
||||
void destroy(List<String> disks, String reservationId);
|
||||
|
||||
/**
|
||||
* Cancel a reservation
|
||||
* @param reservationId reservation to
|
||||
*/
|
||||
void cancel(String reservationId);
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user