This library is an evolution of the old vijava lib. The original README and release notes can be found in the files OLD_README.txt and rel-note.txt
This library is distributed under the BSD-3 License. The original license information is found in License.txt I cannot give any guaranty for this library, and you use it on your own risk.
The versioning is now changed, so you can see what API version is implemented.
Here an example:
7.0.1-2.5 -> 7.0.1 is the implemented API Version and 2.5 is the Version of the library itself
- API Version 8.0.1.0 (in vSphere 8.0.1) is fully implemented
- some rework of old Classes
- API Version 8.0.0.1 (in vSphere 8.0.0) is fully implemented
- some rework of old Classes
- some dependency updates
- some rework of old Classes
- some dependency updates
- logback updated to new version
- some rework of old classes
- API Version 7.0.3 first implementation
- minor changes in XML deserialization
- API Version 7.0.2 fully implemented
- some dependency updates
- socket and connect timeouts implemented
- changed the Version for the SoapAction Header in SOAP Calls (it has 4 digits from 7.0 and above)
- GuestInfo.hwVersion is now implemented
- VirtualMachineGuestSummary.hwVersion is now implemented
- Error in HostNetworkSystem.queryNetworkHint fixed
- XML generation can now handle Lists
- VirtualMachineConfigSummary.hwVersion is now implemented
- DateFormatter is now thread-safe handled
- a non-existing field is now only logged as Error Level Message and not throws a NoSuchFieldException
- API Version up to 7.0.1 is fully implemented, but not fully tested (i do not have enough features in test environment)
- migrating methods from the large VimStub class into the ManagedObjects itself, so handling is more intuitive and not much indirect
- the heavily used classes have now correct exception handling, no more throwing of only RemoteException
- renaming some methods with an illegal naming e.g. _Task suffix
- BREAKING_CHANGE: because of renaming and exception handling it is important to change the code that uses this library
- wrong ordering of the fields in the classes, the ordering is important on some DataObjects
- improved some methods and try to generify some of them
- use more than one HTTP library, automatically decide the fastest version (Apache HttpClient, Java11 HttpClient and the old Java HttpUrlConnection)
You can use this library for connecting to a ESX or vCenter Server. The entrypoint is the ServiceInstance class, there you find all other methods and classes. To use the library it is very helpful to look in the official API documentation, currently it is found under latest vSphere Web Services API
Here is a short code snippet
public class Test {
public void test() throws Exception {
final URL url = new URL("https://" + HOSTNAME + "/sdk");
instance = new ServiceInstance(url, USERNAME, PASSWORD, true);
final Capability capability = instance.getCapability();
LOGGER.debug(capability.toString());
instance.getServerConnection().logout();
}
}
the sample and samples folders are old ones that maybe not usable anymore, but it should be useful to imagine a normal usage.
- more rewriting of classes and convert to more modern code style
- convert more arrays to Lists, for input and output
- implement an alternative to dom4j, current measurements shows the implementation in Java11 is faster than dom4j
- implement the VMware Storage Policy API to also use storage profiles