View Javadoc

1   /**
2    *
3    * Copyright (C) 2011 Cloud Conscious, LLC. <info@cloudconscious.com>
4    *
5    * ====================================================================
6    * Licensed under the Apache License, Version 2.0 (the "License");
7    * you may not use this file except in compliance with the License.
8    * You may obtain a copy of the License at
9    *
10   * http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing, software
13   * distributed under the License is distributed on an "AS IS" BASIS,
14   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15   * See the License for the specific language governing permissions and
16   * limitations under the License.
17   * ====================================================================
18   */
19  package org.jclouds.vcloud.domain;
20  
21  import java.util.Set;
22  
23  import javax.annotation.Nullable;
24  
25  import org.jclouds.cim.ResourceAllocationSettingData;
26  import org.jclouds.cim.VirtualSystemSettingData;
27  import org.jclouds.vcloud.domain.internal.VCloudExpressVAppImpl;
28  
29  import com.google.common.collect.ListMultimap;
30  import com.google.inject.ImplementedBy;
31  
32  /**
33   * A virtual application (vApp) is a software solution, packaged in OVF containing one or more
34   * virtual machines. A vApp can be authored by Developers at ISVs and VARs or by IT Administrators
35   * in Enterprises and Service Providers.
36   * 
37   * @author Adrian Cole
38   */
39  @ImplementedBy(VCloudExpressVAppImpl.class)
40  public interface VCloudExpressVApp extends ReferenceType {
41     ReferenceType getVDC();
42  
43     Status getStatus();
44  
45     Long getSize();
46  
47     ListMultimap<String, String> getNetworkToAddresses();
48  
49     /**
50      * 
51      * @return CIM OSType of the image or null, if this information isn't available yet
52      * @see <a href="http://dmtf.org/standards/cim/cim_schema_v2260">DMTF CIM model</a>
53      */
54     @Nullable
55     Integer getOsType();
56  
57     /**
58      * 
59      * @return description or null, if this information isn't available yet
60      */
61     @Nullable
62     String getOperatingSystemDescription();
63  
64     VirtualSystemSettingData getSystem();
65  
66     Set<ResourceAllocationSettingData> getResourceAllocations();
67  
68  }