HostNetworkInterfaceImpl.cpp revision b6efb5481075b1e9528e608796f93094abae6180
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * VirtualBox COM class implementation
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Copyright (C) 2006-2008 Sun Microsystems, Inc.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * This file is part of VirtualBox Open Source Edition (OSE), as
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * available from http://www.virtualbox.org. This file is free software;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * you can redistribute it and/or modify it under the terms of the GNU
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * General Public License (GPL) as published by the Free Software
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Foundation, in version 2 as it comes in the "COPYING" file of the
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Clara, CA 95054 USA or visit http://www.sun.com if you need
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * additional information or have any questions.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster#endif /* RT_OS_WINDOWS */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// constructor / destructor
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster/////////////////////////////////////////////////////////////////////////////
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// public initializer/uninitializer for internal purposes only
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster/////////////////////////////////////////////////////////////////////////////
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Initializes the host object.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM result indicator
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aInterfaceName name of the network interface
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aGuid GUID of the host network interface
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterHRESULT HostNetworkInterface::init (Bstr aInterfaceName, Guid aGuid, HostNetworkInterfaceType_T ifType)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster LogFlowThisFunc (("aInterfaceName={%ls}, aGuid={%s}\n",
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster aInterfaceName.raw(), aGuid.toString().raw()));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster /* Enclose the state transition NotReady->InInit->Ready */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster /* Confirm a successful initialization */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.IPV6Address = composeIPv6Address(&info.IPv6Address);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.IPV6NetworkMaskPrefixLength = composeIPv6PrefixLenghFromAddress(&info.IPv6NetMask);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.hardwareAddress = composeHardwareAddress(&info.MACAddress);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.mediumType = (HostNetworkInterfaceMediumType)info.enmMediumType;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.status = (HostNetworkInterfaceStatus)info.enmStatus;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster#else /* !RT_OS_WINDOWS */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster#endif /* !RT_OS_WINDOWS */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster return rc == VERR_NOT_IMPLEMENTED ? E_NOTIMPL : E_FAIL;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Initializes the host object.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM result indicator
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aInterfaceName name of the network interface
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aGuid GUID of the host network interface
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterHRESULT HostNetworkInterface::init (Bstr aInterfaceName, HostNetworkInterfaceType_T ifType, PNETIFINFO pIf)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// LogFlowThisFunc (("aInterfaceName={%ls}, aGuid={%s}\n",
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// aInterfaceName.raw(), aGuid.toString().raw()));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// ComAssertRet (aInterfaceName, E_INVALIDARG);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// ComAssertRet (!aGuid.isEmpty(), E_INVALIDARG);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster /* Enclose the state transition NotReady->InInit->Ready */
dfd66b59213438477a47bebd7584799aa9c17d1bPeter Major m.IPV6Address = composeIPv6Address(&pIf->IPv6Address);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.IPV6NetworkMaskPrefixLength = composeIPv6PrefixLenghFromAddress(&pIf->IPv6NetMask);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.hardwareAddress = composeHardwareAddress(&pIf->MACAddress);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.mediumType = (HostNetworkInterfaceMediumType)pIf->enmMediumType;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster m.status = (HostNetworkInterfaceStatus)pIf->enmStatus;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster#else /* !RT_OS_WINDOWS */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster#endif /* !RT_OS_WINDOWS */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster /* Confirm a successful initialization */
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster// IHostNetworkInterface properties
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster/////////////////////////////////////////////////////////////////////////////
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the name of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aInterfaceName address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(Name) (BSTR *aInterfaceName)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the GUID of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aGuid address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(Id) (OUT_GUID aGuid)
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(DhcpEnabled) (BOOL *aDhcpEnabled)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the IP address of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aIPAddress address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(IPAddress) (BSTR *aIPAddress)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the netwok mask of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aNetworkMask address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(NetworkMask) (BSTR *aNetworkMask)
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(IPV6Supported) (BOOL *aIPV6Supported)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the IP V6 address of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aIPV6Address address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(IPV6Address) (BSTR *aIPV6Address)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the IP V6 network mask of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aIPV6Mask address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(IPV6NetworkMaskPrefixLength) (ULONG *aIPV6NetworkMaskPrefixLength)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster CheckComArgOutPointerValid(aIPV6NetworkMaskPrefixLength);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster *aIPV6NetworkMaskPrefixLength = m.IPV6NetworkMaskPrefixLength;
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the hardware address of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aHardwareAddress address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(HardwareAddress) (BSTR *aHardwareAddress)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the encapsulation protocol type of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aType address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(MediumType) (HostNetworkInterfaceMediumType_T *aType)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns the current state of the host network interface.
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aStatus address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(Status) (HostNetworkInterfaceStatus_T *aStatus)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * Returns network interface type
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @returns COM status code
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster * @param aType address of result pointer
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(InterfaceType) (HostNetworkInterfaceType_T *aType)
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::COMGETTER(NetworkName) (BSTR *aNetworkName)
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::EnableStaticIpConfig (IN_BSTR aIPAddress, IN_BSTR aNetMask)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster int rc = NetIfEnableStaticIpConfig(mVBox, this, m.IPAddress, ip, mask);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster LogRel(("Failed to EnableStaticIpConfig with rc=%Vrc\n", rc));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster return rc == VERR_NOT_IMPLEMENTED ? E_NOTIMPL : E_FAIL;
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::EnableStaticIpConfigV6 (IN_BSTR aIPV6Address, ULONG aIPV6MaskPrefixLength)
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster int rc = NetIfEnableStaticIpConfigV6(mVBox, this, m.IPV6Address, aIPV6Address, aIPV6MaskPrefixLength);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster LogRel(("Failed to EnableStaticIpConfigV6 with rc=%Vrc\n", rc));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster return rc == VERR_NOT_IMPLEMENTED ? E_NOTIMPL : E_FAIL;
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::EnableDynamicIpConfig ()
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster int rc = NetIfEnableDynamicIpConfig(mVBox, this);
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster LogRel(("Failed to EnableDynamicIpConfig with rc=%Vrc\n", rc));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster return rc == VERR_NOT_IMPLEMENTED ? E_NOTIMPL : E_FAIL;
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterSTDMETHODIMP HostNetworkInterface::DhcpRediscover ()
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster LogRel(("Failed to DhcpRediscover with rc=%Vrc\n", rc));
8af80418ba1ec431c8027fa9668e5678658d3611Allan Foster return rc == VERR_NOT_IMPLEMENTED ? E_NOTIMPL : E_FAIL;
8af80418ba1ec431c8027fa9668e5678658d3611Allan FosterHRESULT HostNetworkInterface::setVirtualBox(VirtualBox *pVBox)
return S_OK;