GuestSessionImpl.cpp revision ac5279f2dfaee3605ede93c424a1e35338f6655f
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/* $Id$ */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/** @file
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * VirtualBox Main - Guest session handling.
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/*
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Copyright (C) 2012-2013 Oracle Corporation
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync *
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * available from http://www.virtualbox.org. This file is free software;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * you can redistribute it and/or modify it under the terms of the GNU
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * General Public License (GPL) as published by the Free Software
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/*******************************************************************************
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync* Header Files *
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync*******************************************************************************/
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync#include "GuestImpl.h"
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#include "GuestSessionImpl.h"
7b9f0c34e9ea328981c99e97054bdf8684d9d620vboxsync#include "GuestCtrlImplPrivate.h"
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync#include "VirtualBoxErrorInfoImpl.h"
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#include "Global.h"
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#include "AutoCaller.h"
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#include "ProgressImpl.h"
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#include "VBoxEvents.h"
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#include "VMMDev.h"
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
b1cc3e87518139898395f96974ecff9e6bf228fbvboxsync#include <memory> /* For auto_ptr. */
b1cc3e87518139898395f96974ecff9e6bf228fbvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#include <iprt/cpp/utils.h> /* For unconst(). */
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync#include <iprt/env.h>
388b6b190a5407548753b7fde12fa58134ec3563vboxsync#include <iprt/file.h> /* For CopyTo/From. */
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#include <VBox/com/array.h>
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#include <VBox/com/listeners.h>
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync#include <VBox/version.h>
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync#ifdef LOG_GROUP
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync #undef LOG_GROUP
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync#endif
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync#define LOG_GROUP LOG_GROUP_GUEST_CONTROL
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync#include <VBox/log.h>
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync/**
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync * Base class representing an internal
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync * asynchronous session task.
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncclass GuestSessionTaskInternal
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncpublic:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync GuestSessionTaskInternal(GuestSession *pSession)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync : mSession(pSession),
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mRC(VINF_SUCCESS) { }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync virtual ~GuestSessionTaskInternal(void) { }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int rc(void) const { return mRC; }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync bool isOk(void) const { return RT_SUCCESS(mRC); }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync const ComObjPtr<GuestSession> &Session(void) const { return mSession; }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncprotected:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync const ComObjPtr<GuestSession> mSession;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int mRC;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync};
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync/**
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync * Class for asynchronously opening a guest session.
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncclass GuestSessionTaskInternalOpen : public GuestSessionTaskInternal
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncpublic:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync GuestSessionTaskInternalOpen(GuestSession *pSession)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync : GuestSessionTaskInternal(pSession) { }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync};
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync/**
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync * Internal listener class to serve events in an
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync * active manner, e.g. without polling delays.
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsyncclass GuestSessionListener
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync{
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsyncpublic:
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync GuestSessionListener(void)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync HRESULT init(GuestSession *pSession)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync mSession = pSession;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return S_OK;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync void uninit(void)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync mSession.setNull();
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync STDMETHOD(HandleEvent)(VBoxEventType_T aType, IEvent *aEvent)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync switch (aType)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync case VBoxEventType_OnGuestSessionStateChanged:
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync Assert(!mSession.isNull());
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int rc2 = mSession->signalWaitEvents(aType, aEvent);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync#ifdef DEBUG_andy
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync LogFlowFunc(("Signalling events of type=%ld, session=%p resulted in rc=%Rrc\n",
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync aType, mSession, rc2));
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync#endif
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync break;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync default:
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync AssertMsgFailed(("Unhandled event %ld\n", aType));
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync break;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return S_OK;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsyncprivate:
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync ComObjPtr<GuestSession> mSession;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync};
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsynctypedef ListenerImpl<GuestSessionListener, GuestSession*> GuestSessionListenerImpl;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
581f0625e43a928987623d7cf59e1b1ab61ca6c8vboxsyncVBOX_LISTENER_DECLARE(GuestSessionListenerImpl)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync// constructor / destructor
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/////////////////////////////////////////////////////////////////////////////
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncDEFINE_EMPTY_CTOR_DTOR(GuestSession)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncHRESULT GuestSession::FinalConstruct(void)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFunc(("\n"));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return BaseFinalConstruct();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncvoid GuestSession::FinalRelease(void)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync uninit();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync BaseFinalRelease();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync// public initializer/uninitializer for internal purposes only
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/////////////////////////////////////////////////////////////////////////////
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync/**
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * Initializes a guest session but does *not* open in on the guest side
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync * yet. This needs to be done via the openSession() / openSessionAsync calls.
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync *
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * @return IPRT status code.
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync ** @todo Docs!
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncint GuestSession::init(Guest *pGuest, const GuestSessionStartupInfo &ssInfo,
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync const GuestCredentials &guestCreds)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFunc(("pGuest=%p, ssInfo=%p, guestCreds=%p\n",
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync pGuest, &ssInfo, &guestCreds));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync /* Enclose the state transition NotReady->InInit->Ready. */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoInitSpan autoInitSpan(this);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync AssertReturn(autoInitSpan.isOk(), VERR_OBJECT_DESTROYED);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync autoInitSpan.setSucceeded();
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync return VINF_SUCCESS;
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#else
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync AssertPtrReturn(pGuest, VERR_INVALID_POINTER);
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mParent = pGuest;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Copy over startup info. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /** @todo Use an overloaded copy operator. Later. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mID = ssInfo.mID;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mIsInternal = ssInfo.mIsInternal;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mName = ssInfo.mName;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mOpenFlags = ssInfo.mOpenFlags;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mOpenTimeoutMS = ssInfo.mOpenTimeoutMS;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /** @todo Use an overloaded copy operator. Later. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mCredentials.mUser = guestCreds.mUser;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mCredentials.mPassword = guestCreds.mPassword;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mCredentials.mDomain = guestCreds.mDomain;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync mData.mRC = VINF_SUCCESS;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mStatus = GuestSessionStatus_Undefined;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync mData.mNumObjects = 0;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync HRESULT hr;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int rc = queryInfo();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_SUCCESS(rc))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync hr = unconst(mEventSource).createObject();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (FAILED(hr))
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync rc = VERR_NO_MEMORY;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync else
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync hr = mEventSource->init(static_cast<IGuestSession*>(this));
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync if (FAILED(hr))
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync rc = VERR_COM_UNEXPECTED;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (RT_SUCCESS(rc))
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync try
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync GuestSessionListener *pListener = new GuestSessionListener();
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync ComObjPtr<GuestSessionListenerImpl> thisListener;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync hr = thisListener.createObject();
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (SUCCEEDED(hr))
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync hr = thisListener->init(pListener, this);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (SUCCEEDED(hr))
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync com::SafeArray <VBoxEventType_T> eventTypes;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes.push_back(VBoxEventType_OnGuestSessionStateChanged);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync hr = mEventSource->RegisterListener(thisListener,
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync ComSafeArrayAsInParam(eventTypes),
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync TRUE /* Active listener */);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (SUCCEEDED(hr))
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync mLocalListener = thisListener;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync rc = RTCritSectInit(&mWaitEventCritSect);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync AssertRC(rc);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync else
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync rc = VERR_COM_UNEXPECTED;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync else
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync rc = VERR_COM_UNEXPECTED;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync catch(std::bad_alloc &)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync rc = VERR_NO_MEMORY;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (RT_SUCCESS(rc))
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Confirm a successful initialization when it's the case. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync autoInitSpan.setSucceeded();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync else
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync autoInitSpan.setFailed();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowThisFunc(("mName=%s, mID=%RU32, mIsInternal=%RTbool, rc=%Rrc\n",
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync mData.mSession.mName.c_str(), mData.mSession.mID, mData.mSession.mIsInternal, rc));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return rc;
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/**
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * Uninitializes the instance.
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync * Called from FinalRelease().
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncvoid GuestSession::uninit(void)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync /* Enclose the state transition Ready->InUninit->NotReady. */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoUninitSpan autoUninitSpan(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (autoUninitSpan.uninitDone())
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return;
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync int rc = VINF_SUCCESS;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#ifdef VBOX_WITH_GUEST_CONTROL
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowThisFunc(("Closing directories (%RU64 total)\n",
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync mData.mDirectories.size()));
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync for (SessionDirectories::iterator itDirs = mData.mDirectories.begin();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync itDirs != mData.mDirectories.end(); ++itDirs)
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync (*itDirs)->Release();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mDirectories.clear();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowThisFunc(("Closing files (%RU64 total)\n",
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync mData.mFiles.size()));
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync for (SessionFiles::iterator itFiles = mData.mFiles.begin();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync itFiles != mData.mFiles.end(); ++itFiles)
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync itFiles->second->Release();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mFiles.clear();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowThisFunc(("Closing processes (%RU64 total)\n",
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync mData.mProcesses.size()));
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync for (SessionProcesses::iterator itProcs = mData.mProcesses.begin();
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync itProcs != mData.mProcesses.end(); ++itProcs)
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync itProcs->second->Release();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mProcesses.clear();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowThisFunc(("mNumObjects=%RU32\n", mData.mNumObjects));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync baseUninit();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync mEventSource->UnregisterListener(mLocalListener);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync unconst(mEventSource).setNull();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowFuncLeaveRC(rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync// implementation of public getters/setters for attributes
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync/////////////////////////////////////////////////////////////////////////////
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsyncSTDMETHODIMP GuestSession::COMGETTER(User)(BSTR *aUser)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aUser);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync mData.mCredentials.mUser.cloneTo(aUser);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Domain)(BSTR *aDomain)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aDomain);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync mData.mCredentials.mDomain.cloneTo(aDomain);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Name)(BSTR *aName)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aName);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mName.cloneTo(aName);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Id)(ULONG *aId)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aId);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync *aId = mData.mSession.mID;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFuncLeave();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return S_OK;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Status)(GuestSessionStatus_T *aStatus)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync ReturnComNotImplemented();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#else
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFuncEnter();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync CheckComArgOutPointerValid(aStatus);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync AutoCaller autoCaller(this);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync *aStatus = mData.mStatus;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Timeout)(ULONG *aTimeout)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aTimeout);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync *aTimeout = mData.mTimeout;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
7e8ef90d3160234df0f254131b87af4243d79476vboxsyncSTDMETHODIMP GuestSession::COMSETTER(Timeout)(ULONG aTimeout)
7e8ef90d3160234df0f254131b87af4243d79476vboxsync{
7e8ef90d3160234df0f254131b87af4243d79476vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
7e8ef90d3160234df0f254131b87af4243d79476vboxsync ReturnComNotImplemented();
7e8ef90d3160234df0f254131b87af4243d79476vboxsync#else
7e8ef90d3160234df0f254131b87af4243d79476vboxsync LogFlowThisFuncEnter();
7e8ef90d3160234df0f254131b87af4243d79476vboxsync
7e8ef90d3160234df0f254131b87af4243d79476vboxsync AutoCaller autoCaller(this);
7e8ef90d3160234df0f254131b87af4243d79476vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
7e8ef90d3160234df0f254131b87af4243d79476vboxsync
7e8ef90d3160234df0f254131b87af4243d79476vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
7e8ef90d3160234df0f254131b87af4243d79476vboxsync
7e8ef90d3160234df0f254131b87af4243d79476vboxsync mData.mTimeout = aTimeout;
7e8ef90d3160234df0f254131b87af4243d79476vboxsync
7e8ef90d3160234df0f254131b87af4243d79476vboxsync LogFlowThisFuncLeave();
7e8ef90d3160234df0f254131b87af4243d79476vboxsync return S_OK;
7e8ef90d3160234df0f254131b87af4243d79476vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
7e8ef90d3160234df0f254131b87af4243d79476vboxsync}
7e8ef90d3160234df0f254131b87af4243d79476vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsyncSTDMETHODIMP GuestSession::COMGETTER(ProtocolVersion)(ULONG *aVersion)
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync{
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync ReturnComNotImplemented();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync#else
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowThisFuncEnter();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync CheckComArgOutPointerValid(aVersion);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync AutoCaller autoCaller(this);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync *aVersion = mData.mProtocolVersion;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowThisFuncLeave();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync return S_OK;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync}
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Environment)(ComSafeArrayOut(BSTR, aEnvironment))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutSafeArrayPointerValid(aEnvironment);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync size_t cEnvVars = mData.mEnvironment.Size();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFunc(("[%s]: cEnvVars=%RU32\n",
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mName.c_str(), cEnvVars));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync com::SafeArray<BSTR> environment(cEnvVars);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync for (size_t i = 0; i < cEnvVars; i++)
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync {
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync Bstr strEnv(mData.mEnvironment.Get(i));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync strEnv.cloneTo(&environment[i]);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync environment.detachTo(ComSafeArrayOutArg(aEnvironment));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsyncSTDMETHODIMP GuestSession::COMSETTER(Environment)(ComSafeArrayIn(IN_BSTR, aValues))
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync{
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync ReturnComNotImplemented();
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync#else
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync LogFlowThisFuncEnter();
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync AutoCaller autoCaller(this);
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync com::SafeArray<IN_BSTR> environment(ComSafeArrayInArg(aValues));
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync int rc = VINF_SUCCESS;
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync for (size_t i = 0; i < environment.size() && RT_SUCCESS(rc); i++)
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync {
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync Utf8Str strEnv(environment[i]);
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync if (!strEnv.isEmpty()) /* Silently skip empty entries. */
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync rc = mData.mEnvironment.Set(strEnv);
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync }
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync HRESULT hr = RT_SUCCESS(rc) ? S_OK : VBOX_E_IPRT_ERROR;
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync LogFlowFuncLeaveRC(hr);
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync return hr;
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync}
1cd59fdf671ca60c64d77e3f7046aaecf7003824vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Processes)(ComSafeArrayOut(IGuestProcess *, aProcesses))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutSafeArrayPointerValid(aProcesses);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync SafeIfaceArray<IGuestProcess> collection(mData.mProcesses);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync collection.detachTo(ComSafeArrayOutArg(aProcesses));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowFunc(("mProcesses=%zu\n", collection.size()));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Directories)(ComSafeArrayOut(IGuestDirectory *, aDirectories))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutSafeArrayPointerValid(aDirectories);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync SafeIfaceArray<IGuestDirectory> collection(mData.mDirectories);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync collection.detachTo(ComSafeArrayOutArg(aDirectories));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowFunc(("mDirectories=%zu\n", collection.size()));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::COMGETTER(Files)(ComSafeArrayOut(IGuestFile *, aFiles))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutSafeArrayPointerValid(aFiles);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync SafeIfaceArray<IGuestFile> collection(mData.mFiles);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync collection.detachTo(ComSafeArrayOutArg(aFiles));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowFunc(("mFiles=%zu\n", collection.size()));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncSTDMETHODIMP GuestSession::COMGETTER(EventSource)(IEventSource ** aEventSource)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync ReturnComNotImplemented();
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#else
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync LogFlowThisFuncEnter();
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync CheckComArgOutPointerValid(aEventSource);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AutoCaller autoCaller(this);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync // no need to lock - lifetime constant
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mEventSource.queryInterfaceTo(aEventSource);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync LogFlowThisFuncLeave();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return S_OK;
fb41ad77bcfbdb3aaa1fc9503a37ee6a70dc6461vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync// private methods
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync///////////////////////////////////////////////////////////////////////////////
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::closeSession(uint32_t uFlags, uint32_t uTimeoutMS, int *pGuestRc)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("uFlags=%x, uTimeoutMS=%RU32\n", uFlags, uTimeoutMS));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync /* Guest Additions < 4.3 don't support closing dedicated
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync guest sessions, skip. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (mData.mProtocolVersion < 2)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFunc(("Installed Guest Additions don't support closing dedicated sessions, skipping\n"));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return VINF_SUCCESS;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /** @todo uFlags validation. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (mData.mStatus != GuestSessionStatus_Started)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("Session ID=%RU32 not started (anymore), status now is: %ld\n",
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync mData.mSession.mID, mData.mStatus));
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return VINF_SUCCESS;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int vrc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync GuestWaitEvent *pEvent = NULL;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync std::list < VBoxEventType_T > eventTypes;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync try
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes.push_back(VBoxEventType_OnGuestSessionStateChanged);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = registerWaitEvent(mData.mSession.mID, 0 /* Object ID */,
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes, &pEvent);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync catch (std::bad_alloc)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = VERR_NO_MEMORY;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (RT_FAILURE(vrc))
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return vrc;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync LogFlowThisFunc(("Sending closing request to guest session ID=%RU32, uFlags=%x\n",
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync mData.mSession.mID, uFlags));
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync VBOXHGCMSVCPARM paParms[4];
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int i = 0;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setUInt32(pEvent->ContextID());
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setUInt32(uFlags);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync alock.release(); /* Drop the write lock before waiting. */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = sendCommand(HOST_SESSION_CLOSE, i, paParms);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_SUCCESS(vrc))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync vrc = waitForStatusChange(pEvent, GuestSessionWaitForFlag_Terminate, uTimeoutMS,
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync NULL /* Session status */, pGuestRc);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync unregisterWaitEvent(pEvent);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(vrc);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync return vrc;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync}
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsyncint GuestSession::directoryRemoveFromList(GuestDirectory *pDirectory)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync{
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync for (SessionDirectories::iterator itDirs = mData.mDirectories.begin();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync itDirs != mData.mDirectories.end(); ++itDirs)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync {
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync if (pDirectory == (*itDirs))
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync {
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync Bstr strName;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync HRESULT hr = (*itDirs)->COMGETTER(DirectoryName)(strName.asOutParam());
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync ComAssertComRC(hr);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync Assert(mData.mDirectories.size());
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync LogFlowFunc(("Removing directory \"%s\" (Session: %RU32) (now total %ld directories)\n",
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync Utf8Str(strName).c_str(), mData.mSession.mID, mData.mDirectories.size() - 1));
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mDirectories.erase(itDirs);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync return VINF_SUCCESS;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync return VERR_NOT_FOUND;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsyncint GuestSession::directoryCreateInternal(const Utf8Str &strPath, uint32_t uMode, uint32_t uFlags, int *pGuestRc)
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync{
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync /* pGuestRc is optional. */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync LogFlowThisFunc(("strPath=%s, uMode=%x, uFlags=%x\n",
5366e994777f9d9391cf809dc77610f57270d75dvboxsync strPath.c_str(), uMode, uFlags));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessStartupInfo procInfo;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync procInfo.mCommand = Utf8Str(VBOXSERVICE_TOOL_MKDIR);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mFlags = ProcessCreateFlag_Hidden;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync int vrc = VINF_SUCCESS;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync /* Construct arguments. */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (uFlags & DirectoryCreateFlag_Parents)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync procInfo.mArguments.push_back(Utf8Str("--parents")); /* We also want to create the parent directories. */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (uMode)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync procInfo.mArguments.push_back(Utf8Str("--mode")); /* Set the creation mode. */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync char szMode[16];
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (RTStrPrintf(szMode, sizeof(szMode), "%o", uMode))
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync procInfo.mArguments.push_back(Utf8Str(szMode));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync else
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync vrc = VERR_BUFFER_OVERFLOW;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mArguments.push_back(strPath); /* The directory we want to create. */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessTool procTool;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync vrc = procTool.Init(this, procInfo, false /* Async */, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (RT_SUCCESS(guestRc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync vrc = procTool.Wait(GUESTPROCESSTOOL_FLAG_NONE, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(guestRc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync guestRc = procTool.TerminatedOk(NULL /* Exit code */);
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync }
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync if ( vrc == VERR_GSTCTL_GUEST_ERROR
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync && pGuestRc)
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync *pGuestRc = guestRc;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync LogFlowFuncLeaveRC(vrc);
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync return vrc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsyncint GuestSession::directoryQueryInfoInternal(const Utf8Str &strPath, GuestFsObjData &objData, int *pGuestRc)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync{
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFunc(("strPath=%s\n", strPath.c_str()));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync int vrc = fsQueryInfoInternal(strPath, objData, pGuestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync vrc = objData.mType == FsObjType_Directory
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync ? VINF_SUCCESS : VERR_NOT_A_DIRECTORY;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync LogFlowFuncLeaveRC(vrc);
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync return vrc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsyncint GuestSession::objectCreateTempInternal(const Utf8Str &strTemplate, const Utf8Str &strPath,
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync bool fDirectory, const Utf8Str &strName, int *pGuestRc)
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync{
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessStartupInfo procInfo;
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mCommand = Utf8Str(VBOXSERVICE_TOOL_MKTEMP);
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mFlags = ProcessCreateFlag_WaitForStdOut;
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mArguments.push_back(Utf8Str("--machinereadable"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (fDirectory)
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mArguments.push_back(Utf8Str("-d"));
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync if (strPath.length()) /* Otherwise use /tmp or equivalent. */
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync {
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mArguments.push_back(Utf8Str("-t"));
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync procInfo.mArguments.push_back(strPath);
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mArguments.push_back(strTemplate);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessTool procTool; int guestRc;
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync int vrc = procTool.Init(this, procInfo, false /* Async */, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync if (RT_SUCCESS(guestRc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync vrc = procTool.Wait(GUESTPROCESSTOOL_FLAG_NONE, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync if (RT_SUCCESS(guestRc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync guestRc = procTool.TerminatedOk(NULL /* Exit code */);
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync if ( vrc == VERR_GSTCTL_GUEST_ERROR
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync && pGuestRc)
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync *pGuestRc = guestRc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync LogFlowFuncLeaveRC(vrc);
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync return vrc;
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync}
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsyncint GuestSession::directoryOpenInternal(const Utf8Str &strPath, const Utf8Str &strFilter,
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync uint32_t uFlags, ComObjPtr<GuestDirectory> &pDirectory)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync{
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync LogFlowThisFunc(("strPath=%s, strPath=%s, uFlags=%x\n",
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync strPath.c_str(), strFilter.c_str(), uFlags));
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync /* Create the directory object. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync HRESULT hr = pDirectory.createObject();
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (FAILED(hr))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return VERR_COM_UNEXPECTED;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = pDirectory->init(this /* Parent */,
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync strPath, strFilter, uFlags);
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (RT_FAILURE(vrc))
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync return vrc;
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync /* Add the created directory to our vector. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync mData.mDirectories.push_back(pDirectory);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync LogFlowFunc(("Added new directory \"%s\" (Session: %RU32)\n",
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync strPath.c_str(), mData.mSession.mID));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync LogFlowFuncLeaveRC(vrc);
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync return vrc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::dispatchToFile(PVBOXGUESTCTRLHOSTCBCTX pCtxCb, PVBOXGUESTCTRLHOSTCALLBACK pSvcCb)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFunc(("pCtxCb=%p, pSvcCb=%p\n", pCtxCb, pSvcCb));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync AssertPtrReturn(pCtxCb, VERR_INVALID_POINTER);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync AssertPtrReturn(pSvcCb, VERR_INVALID_POINTER);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint32_t uFileID = VBOX_GUESTCTRL_CONTEXTID_GET_OBJECT(pCtxCb->uContextID);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#ifdef DEBUG
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFunc(("uFileID=%RU32 (%RU32 total)\n",
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uFileID, mData.mFiles.size()));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#endif
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync SessionFiles::const_iterator itFile
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync = mData.mFiles.find(uFileID);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (itFile != mData.mFiles.end())
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ComObjPtr<GuestFile> pFile(itFile->second);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Assert(!pFile.isNull());
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync alock.release();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync rc = pFile->callbackDispatcher(pCtxCb, pSvcCb);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync else
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync rc = VERR_NOT_FOUND;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(rc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::dispatchToProcess(PVBOXGUESTCTRLHOSTCBCTX pCtxCb, PVBOXGUESTCTRLHOSTCALLBACK pSvcCb)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFunc(("pCtxCb=%p, pSvcCb=%p\n", pCtxCb, pSvcCb));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pCtxCb, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pSvcCb, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync uint32_t uProcessID = VBOX_GUESTCTRL_CONTEXTID_GET_OBJECT(pCtxCb->uContextID);
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync#ifdef DEBUG
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync LogFlowFunc(("uProcessID=%RU32 (%RU32 total)\n",
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync uProcessID, mData.mProcesses.size()));
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync#endif
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync int rc;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync SessionProcesses::const_iterator itProc
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync = mData.mProcesses.find(uProcessID);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (itProc != mData.mProcesses.end())
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync {
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ComObjPtr<GuestProcess> pProcess(itProc->second);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Assert(!pProcess.isNull());
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Set protocol version so that pSvcCb can
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * be interpreted right. */
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync pCtxCb->uProtocol = mData.mProtocolVersion;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync alock.release();
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync rc = pProcess->callbackDispatcher(pCtxCb, pSvcCb);
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync }
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync else
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync rc = VERR_NOT_FOUND;
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync LogFlowFuncLeaveRC(rc);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::dispatchToThis(PVBOXGUESTCTRLHOSTCBCTX pCbCtx, PVBOXGUESTCTRLHOSTCALLBACK pSvcCb)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pCbCtx, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pSvcCb, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#ifdef DEBUG
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("sessionID=%RU32, CID=%RU32, uFunction=%RU32, pSvcCb=%p\n",
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync mData.mSession.mID, pCbCtx->uContextID, pCbCtx->uFunction, pSvcCb));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#endif
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = VINF_SUCCESS;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync switch (pCbCtx->uFunction)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case GUEST_DISCONNECTED:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /** @todo Handle closing all guest objects. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync break;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GUEST_SESSION_NOTIFY:
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync rc = onSessionStatusChange(pCbCtx, pSvcCb);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync break;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync default:
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Silently skip unknown callbacks. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync rc = VERR_NOT_SUPPORTED;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync break;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(rc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncinline bool GuestSession::fileExists(uint32_t uFileID, ComObjPtr<GuestFile> *pFile)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync SessionFiles::const_iterator it = mData.mFiles.find(uFileID);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (it != mData.mFiles.end())
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (pFile)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync *pFile = it->second;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return true;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return false;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync}
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsyncint GuestSession::fileRemoveFromList(GuestFile *pFile)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync{
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync for (SessionFiles::iterator itFiles = mData.mFiles.begin();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync itFiles != mData.mFiles.end(); ++itFiles)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (pFile == itFiles->second)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Make sure to consume the pointer before the one of thfe
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync * iterator gets released. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ComObjPtr<GuestFile> pCurFile = pFile;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync Bstr strName;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync HRESULT hr = pCurFile->COMGETTER(FileName)(strName.asOutParam());
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync ComAssertComRC(hr);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync Assert(mData.mNumObjects);
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync LogFlowThisFunc(("Removing guest file \"%s\" (Session: %RU32) (now total %ld files, %ld objects)\n",
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync Utf8Str(strName).c_str(), mData.mSession.mID, mData.mFiles.size() - 1, mData.mNumObjects - 1));
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync itFiles->second->Release();
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mFiles.erase(itFiles);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync mData.mNumObjects--;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync alock.release(); /* Release lock before firing off event. */
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync fireGuestFileRegisteredEvent(mEventSource, this, pCurFile,
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync false /* Unregistered */);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return VINF_SUCCESS;
004d74842597dacc4009803171296dfcf9398c69vboxsync }
004d74842597dacc4009803171296dfcf9398c69vboxsync }
004d74842597dacc4009803171296dfcf9398c69vboxsync
004d74842597dacc4009803171296dfcf9398c69vboxsync return VERR_NOT_FOUND;
004d74842597dacc4009803171296dfcf9398c69vboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
004d74842597dacc4009803171296dfcf9398c69vboxsyncint GuestSession::fileRemoveInternal(const Utf8Str &strPath, int *pGuestRc)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync{
004d74842597dacc4009803171296dfcf9398c69vboxsync GuestProcessStartupInfo procInfo;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessStream streamOut;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mCommand = Utf8Str(VBOXSERVICE_TOOL_RM);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mFlags = ProcessCreateFlag_WaitForStdOut;
004d74842597dacc4009803171296dfcf9398c69vboxsync procInfo.mArguments.push_back(Utf8Str("--machinereadable"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mArguments.push_back(strPath); /* The file we want to remove. */
004d74842597dacc4009803171296dfcf9398c69vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessTool procTool; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = procTool.Init(this, procInfo, false /* Async */, &guestRc);
004d74842597dacc4009803171296dfcf9398c69vboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync vrc = procTool.Wait(GUESTPROCESSTOOL_FLAG_NONE, &guestRc);
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_SUCCESS(vrc))
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(guestRc))
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync guestRc = procTool.TerminatedOk(NULL /* Exit code */);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if ( vrc == VERR_GSTCTL_GUEST_ERROR
004d74842597dacc4009803171296dfcf9398c69vboxsync && pGuestRc)
004d74842597dacc4009803171296dfcf9398c69vboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync *pGuestRc = guestRc;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync }
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(vrc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return vrc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::fileOpenInternal(const GuestFileOpenInfo &openInfo, ComObjPtr<GuestFile> &pFile, int *pGuestRc)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("strPath=%s, strOpenMode=%s, strDisposition=%s, uCreationMode=%x, iOffset=%RI64\n",
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync openInfo.mFileName.c_str(), openInfo.mOpenMode.c_str(), openInfo.mDisposition.c_str(),
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync openInfo.mCreationMode, openInfo.mInitialOffset));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int rc = VERR_MAX_PROCS_REACHED;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (mData.mNumObjects >= VBOX_GUESTCTRL_MAX_OBJECTS)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Create a new (host-based) file ID and assign it. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uint32_t uNewFileID = 0;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ULONG uTries = 0;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync for (;;)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Is the file ID already used? */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (!fileExists(uNewFileID, NULL /* pProgress */))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Callback with context ID was not found. This means
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * we can use this context ID for our new callback we want
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync * to add below. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync rc = VINF_SUCCESS;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync break;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uNewFileID++;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (uNewFileID == VBOX_GUESTCTRL_MAX_OBJECTS)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync uNewFileID = 0;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync if (++uTries == UINT32_MAX)
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync break; /* Don't try too hard. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync }
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync if (RT_FAILURE(rc))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return rc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync /* Create the directory object. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync HRESULT hr = pFile.createObject();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (FAILED(hr))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return VERR_COM_UNEXPECTED;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Console *pConsole = mParent->getConsole();
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync AssertPtr(pConsole);
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync rc = pFile->init(pConsole, this /* GuestSession */,
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync uNewFileID, openInfo);
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync if (RT_FAILURE(rc))
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync return rc;
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync int guestRc;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync rc = pFile->openFile(&guestRc);
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync if (RT_SUCCESS(rc))
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync {
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync /* Add the created file to our vector. */
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync mData.mFiles[uNewFileID] = pFile;
15c6c4ce0082362b8b81e15c3605f2d3aca69a21vboxsync mData.mNumObjects++;
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync Assert(mData.mNumObjects <= VBOX_GUESTCTRL_MAX_OBJECTS);
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync LogFlowFunc(("Added new guest file \"%s\" (Session: %RU32) (now total %ld files, %ld objects)\n",
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync openInfo.mFileName.c_str(), mData.mSession.mID, mData.mFiles.size(), mData.mNumObjects));
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync alock.release(); /* Release lock before firing off event. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync fireGuestFileRegisteredEvent(mEventSource, this, pFile,
5366e994777f9d9391cf809dc77610f57270d75dvboxsync true /* Registered */);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync if (pGuestRc)
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync *pGuestRc = guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowFuncLeaveRC(rc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync return rc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsyncint GuestSession::fileQueryInfoInternal(const Utf8Str &strPath, GuestFsObjData &objData, int *pGuestRc)
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync{
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFunc(("strPath=%s\n", strPath.c_str()));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync int vrc = fsQueryInfoInternal(strPath, objData, pGuestRc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync vrc = objData.mType == FsObjType_File
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync ? VINF_SUCCESS : VERR_NOT_A_FILE;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowFuncLeaveRC(vrc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return vrc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsyncint GuestSession::fileQuerySizeInternal(const Utf8Str &strPath, int64_t *pllSize, int *pGuestRc)
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync{
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync AssertPtrReturn(pllSize, VERR_INVALID_POINTER);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync GuestFsObjData objData;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync int vrc = fileQueryInfoInternal(strPath, objData, pGuestRc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_SUCCESS(vrc))
3ff8aa7d3c74cfbe8da5f77b8ea6c748cc79213avboxsync *pllSize = objData.mObjectSize;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync return vrc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsyncint GuestSession::fsQueryInfoInternal(const Utf8Str &strPath, GuestFsObjData &objData, int *pGuestRc)
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync{
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync LogFlowThisFunc(("strPath=%s\n", strPath.c_str()));
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync /** @todo Merge this with IGuestFile::queryInfo(). */
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessStartupInfo procInfo;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mCommand = Utf8Str(VBOXSERVICE_TOOL_STAT);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mFlags = ProcessCreateFlag_WaitForStdOut;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync /* Construct arguments. */
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mArguments.push_back(Utf8Str("--machinereadable"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync procInfo.mArguments.push_back(strPath);
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestProcessTool procTool; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = procTool.Init(this, procInfo, false /* Async */, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync vrc = procTool.Wait(GUESTPROCESSTOOL_FLAG_NONE, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync {
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync guestRc = procTool.TerminatedOk(NULL /* Exit code */);
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync if (RT_SUCCESS(guestRc))
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync GuestProcessStreamBlock curBlock;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync vrc = procTool.GetCurrentBlock(OUTPUT_HANDLE_ID_STDOUT, curBlock);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync /** @todo Check for more / validate blocks! */
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync if (RT_SUCCESS(vrc))
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync vrc = objData.FromStat(curBlock);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync if ( vrc == VERR_GSTCTL_GUEST_ERROR
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync && pGuestRc)
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync {
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync *pGuestRc = guestRc;
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync }
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync LogFlowFuncLeaveRC(vrc);
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync return vrc;
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync}
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsyncconst GuestCredentials& GuestSession::getCredentials(void)
40c1a23e86c79b24a917a43c186b2e54504d12c1vboxsync{
40c1a23e86c79b24a917a43c186b2e54504d12c1vboxsync return mData.mCredentials;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncconst GuestEnvironment& GuestSession::getEnvironment(void)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return mData.mEnvironment;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncUtf8Str GuestSession::getName(void)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return mData.mSession.mName;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync/* static */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncUtf8Str GuestSession::guestErrorToString(int guestRc)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync Utf8Str strError;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /** @todo pData->u32Flags: int vs. uint32 -- IPRT errors are *negative* !!! */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync switch (guestRc)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_INVALID_VM_HANDLE:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("VMM device is not available (is the VM running?)"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_HGCM_SERVICE_NOT_FOUND:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("The guest execution service is not available"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_AUTHENTICATION_FAILURE:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("The specified user was not able to logon on guest"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_TIMEOUT:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("The guest did not respond within time"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case VERR_CANCELLED:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("The session operation was canceled"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_PERMISSION_DENIED:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("Invalid user/password credentials"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_MAX_PROCS_REACHED:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("Maximum number of concurrent guest processes has been reached"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_NOT_EQUAL: /** @todo Imprecise to the user; can mean anything and all. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync strError += Utf8StrFmt(tr("Unable to retrieve requested information"));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case VERR_NOT_FOUND:
40c1a23e86c79b24a917a43c186b2e54504d12c1vboxsync strError += Utf8StrFmt(tr("The guest execution service is not ready (yet)"));
40c1a23e86c79b24a917a43c186b2e54504d12c1vboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync default:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync strError += Utf8StrFmt("%Rrc", guestRc);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return strError;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync/**
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync * Checks if this session is ready state where it can handle
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync * all session-bound actions (like guest processes, guest files).
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync * Only used by official API methods. Will set an external
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync * error when not ready.
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncHRESULT GuestSession::isReadyExternal(void)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /** @todo Be a bit more informative. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (mData.mStatus != GuestSessionStatus_Started)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return setError(E_UNEXPECTED, tr("Session is not in started state"));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return S_OK;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync/** No locking! */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::onSessionStatusChange(PVBOXGUESTCTRLHOSTCBCTX pCbCtx, PVBOXGUESTCTRLHOSTCALLBACK pSvcCbData)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pCbCtx, VERR_INVALID_POINTER);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* pCallback is optional. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtrReturn(pSvcCbData, VERR_INVALID_POINTER);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (pSvcCbData->mParms < 3)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return VERR_INVALID_PARAMETER;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync CALLBACKDATA_SESSION_NOTIFY dataCb;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /* pSvcCb->mpaParms[0] always contains the context ID. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync pSvcCbData->mpaParms[1].getUInt32(&dataCb.uType);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync pSvcCbData->mpaParms[2].getUInt32(&dataCb.uResult);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFunc(("ID=%RU32, uType=%RU32, guestRc=%Rrc\n",
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync mData.mSession.mID, dataCb.uType, dataCb.uResult));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int vrc = VINF_SUCCESS;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync GuestSessionStatus_T sessionStatus = GuestSessionStatus_Undefined;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync int guestRc = dataCb.uResult; /** @todo uint32_t vs. int. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync switch (dataCb.uType)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GUEST_SESSION_NOTIFYTYPE_ERROR:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync sessionStatus = GuestSessionStatus_Error;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GUEST_SESSION_NOTIFYTYPE_STARTED:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync sessionStatus = GuestSessionStatus_Started;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GUEST_SESSION_NOTIFYTYPE_TEN:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GUEST_SESSION_NOTIFYTYPE_TES:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GUEST_SESSION_NOTIFYTYPE_TEA:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync sessionStatus = GuestSessionStatus_Terminated;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GUEST_SESSION_NOTIFYTYPE_TOK:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync sessionStatus = GuestSessionStatus_TimedOutKilled;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case GUEST_SESSION_NOTIFYTYPE_TOA:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync sessionStatus = GuestSessionStatus_TimedOutAbnormally;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync case GUEST_SESSION_NOTIFYTYPE_DWN:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync sessionStatus = GuestSessionStatus_Down;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GUEST_SESSION_NOTIFYTYPE_UNDEFINED:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync default:
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync vrc = VERR_NOT_SUPPORTED;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_SUCCESS(vrc))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_FAILURE(guestRc))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync sessionStatus = GuestSessionStatus_Error;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Set the session status. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_SUCCESS(vrc))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync vrc = setSessionStatus(sessionStatus, guestRc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("ID=%RU32, guestRc=%Rrc\n", mData.mSession.mID, guestRc));
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(vrc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return vrc;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncint GuestSession::startSessionInternal(int *pGuestRc)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFunc(("mID=%RU32, mName=%s, uProtocolVersion=%RU32, openFlags=%x, openTimeoutMS=%RU32\n",
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync mData.mSession.mID, mData.mSession.mName.c_str(), mData.mProtocolVersion,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync mData.mSession.mOpenFlags, mData.mSession.mOpenTimeoutMS));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Guest Additions < 4.3 don't support opening dedicated
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync guest sessions. Simply return success here. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (mData.mProtocolVersion < 2)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync mData.mStatus = GuestSessionStatus_Started;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync LogFlowThisFunc(("Installed Guest Additions don't support opening dedicated sessions, skipping\n"));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return VINF_SUCCESS;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (mData.mStatus != GuestSessionStatus_Undefined)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return VINF_SUCCESS;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync /** @todo mData.mSession.uFlags validation. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync /* Set current session status. */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync mData.mStatus = GuestSessionStatus_Starting;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int vrc;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync GuestWaitEvent *pEvent = NULL;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync std::list < VBoxEventType_T > eventTypes;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync try
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes.push_back(VBoxEventType_OnGuestSessionStateChanged);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = registerWaitEvent(mData.mSession.mID, 0 /* Object ID */,
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync eventTypes, &pEvent);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync catch (std::bad_alloc)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = VERR_NO_MEMORY;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (RT_FAILURE(vrc))
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return vrc;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync VBOXHGCMSVCPARM paParms[8];
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int i = 0;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setUInt32(pEvent->ContextID());
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setUInt32(mData.mProtocolVersion);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setPointer((void*)mData.mCredentials.mUser.c_str(),
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync (ULONG)mData.mCredentials.mUser.length() + 1);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync paParms[i++].setPointer((void*)mData.mCredentials.mPassword.c_str(),
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync (ULONG)mData.mCredentials.mPassword.length() + 1);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync paParms[i++].setPointer((void*)mData.mCredentials.mDomain.c_str(),
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync (ULONG)mData.mCredentials.mDomain.length() + 1);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync paParms[i++].setUInt32(mData.mSession.mOpenFlags);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync alock.release(); /* Drop write lock before sending. */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = sendCommand(HOST_SESSION_CREATE, i, paParms);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_SUCCESS(vrc))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync vrc = waitForStatusChange(pEvent, GuestSessionWaitForFlag_Start,
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync 30 * 1000 /* 30s timeout */,
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync NULL /* Session status */, pGuestRc);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync unregisterWaitEvent(pEvent);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowFuncLeaveRC(vrc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return vrc;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncint GuestSession::startSessionAsync(void)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowThisFuncEnter();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int vrc;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync try
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Asynchronously open the session on the guest by kicking off a
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync * worker thread. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync std::auto_ptr<GuestSessionTaskInternalOpen> pTask(new GuestSessionTaskInternalOpen(this));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync AssertReturn(pTask->isOk(), pTask->rc());
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync vrc = RTThreadCreate(NULL, GuestSession::startSessionThread,
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync (void *)pTask.get(), 0,
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync RTTHREADTYPE_MAIN_WORKER, 0,
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync "gctlSesStart");
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (RT_SUCCESS(vrc))
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* pTask is now owned by openSessionThread(), so release it. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync pTask.release();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync catch(std::bad_alloc &)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync {
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync vrc = VERR_NO_MEMORY;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowFuncLeaveRC(vrc);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return vrc;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync/* static */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncDECLCALLBACK(int) GuestSession::startSessionThread(RTTHREAD Thread, void *pvUser)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowFunc(("pvUser=%p\n", pvUser));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync std::auto_ptr<GuestSessionTaskInternalOpen> pTask(static_cast<GuestSessionTaskInternalOpen*>(pvUser));
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync AssertPtr(pTask.get());
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync const ComObjPtr<GuestSession> pSession(pTask->Session());
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync Assert(!pSession.isNull());
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync AutoCaller autoCaller(pSession);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int vrc = pSession->startSessionInternal(NULL /* Guest rc, ignored */);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* Nothing to do here anymore. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowFuncLeaveRC(vrc);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync return vrc;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncint GuestSession::processRemoveFromList(GuestProcess *pProcess)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync AssertPtrReturn(pProcess, VERR_INVALID_POINTER);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync LogFlowThisFunc(("pProcess=%p\n", pProcess));
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync int rc = VERR_NOT_FOUND;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync ULONG uPID;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync HRESULT hr = pProcess->COMGETTER(PID)(&uPID);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync ComAssertComRC(hr);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync LogFlowFunc(("Closing process (PID=%RU32) ...\n", uPID));
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync SessionProcesses::iterator itProcs = mData.mProcesses.begin();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync while (itProcs != mData.mProcesses.end())
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync {
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync if (pProcess == itProcs->second)
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync {
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync /* Make sure to consume the pointer before the one of thfe
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync * iterator gets released. */
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync ComObjPtr<GuestProcess> pCurProcess = pProcess;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync hr = pCurProcess->COMGETTER(PID)(&uPID);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync ComAssertComRC(hr);
6b9d50a0f466bd5a61458ed53925480ab28a3c17vboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync Assert(mData.mNumObjects);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync LogFlowFunc(("Removing process ID=%RU32 (Session: %RU32), guest PID=%RU32 (now total %ld processes, %ld objects)\n",
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync pProcess->getObjectID(), mData.mSession.mID, uPID, mData.mProcesses.size() - 1, mData.mNumObjects - 1));
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync pProcess->cancelWaitEvents();
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync pProcess->Release();
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mProcesses.erase(itProcs);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mNumObjects--;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync alock.release(); /* Release lock before firing off event. */
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync fireGuestProcessRegisteredEvent(mEventSource, this /* Session */, pCurProcess,
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync uPID, false /* Process unregistered */);
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync rc = VINF_SUCCESS;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync break;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync }
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync itProcs++;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync LogFlowFuncLeaveRC(rc);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync return rc;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync}
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync/**
5366e994777f9d9391cf809dc77610f57270d75dvboxsync * Creates but does *not* start the process yet. See GuestProcess::startProcess() or
5366e994777f9d9391cf809dc77610f57270d75dvboxsync * GuestProcess::startProcessAsync() for that.
5366e994777f9d9391cf809dc77610f57270d75dvboxsync *
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync * @return IPRT status code.
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync * @param procInfo
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync * @param pProcess
5366e994777f9d9391cf809dc77610f57270d75dvboxsync */
5366e994777f9d9391cf809dc77610f57270d75dvboxsyncint GuestSession::processCreateExInteral(GuestProcessStartupInfo &procInfo, ComObjPtr<GuestProcess> &pProcess)
5366e994777f9d9391cf809dc77610f57270d75dvboxsync{
5366e994777f9d9391cf809dc77610f57270d75dvboxsync LogFlowFunc(("mCmd=%s, mFlags=%x, mTimeoutMS=%RU32\n",
5366e994777f9d9391cf809dc77610f57270d75dvboxsync procInfo.mCommand.c_str(), procInfo.mFlags, procInfo.mTimeoutMS));
5366e994777f9d9391cf809dc77610f57270d75dvboxsync#ifdef DEBUG
5366e994777f9d9391cf809dc77610f57270d75dvboxsync if (procInfo.mArguments.size())
5366e994777f9d9391cf809dc77610f57270d75dvboxsync {
5366e994777f9d9391cf809dc77610f57270d75dvboxsync LogFlowFunc(("Arguments:"));
5366e994777f9d9391cf809dc77610f57270d75dvboxsync ProcessArguments::const_iterator it = procInfo.mArguments.begin();
5366e994777f9d9391cf809dc77610f57270d75dvboxsync while (it != procInfo.mArguments.end())
5366e994777f9d9391cf809dc77610f57270d75dvboxsync {
5366e994777f9d9391cf809dc77610f57270d75dvboxsync LogFlow((" %s", (*it).c_str()));
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync it++;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync LogFlow(("\n"));
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync#endif
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync /* Validate flags. */
7e8ef90d3160234df0f254131b87af4243d79476vboxsync if (procInfo.mFlags)
7e8ef90d3160234df0f254131b87af4243d79476vboxsync {
7e8ef90d3160234df0f254131b87af4243d79476vboxsync if ( !(procInfo.mFlags & ProcessCreateFlag_IgnoreOrphanedProcesses)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync && !(procInfo.mFlags & ProcessCreateFlag_WaitForProcessStartOnly)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync && !(procInfo.mFlags & ProcessCreateFlag_Hidden)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync && !(procInfo.mFlags & ProcessCreateFlag_NoProfile)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync && !(procInfo.mFlags & ProcessCreateFlag_WaitForStdOut)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync && !(procInfo.mFlags & ProcessCreateFlag_WaitForStdErr))
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync {
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync return VERR_INVALID_PARAMETER;
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync }
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync }
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync if ( (procInfo.mFlags & ProcessCreateFlag_WaitForProcessStartOnly)
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync && ( (procInfo.mFlags & ProcessCreateFlag_WaitForStdOut)
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync || (procInfo.mFlags & ProcessCreateFlag_WaitForStdErr)
e2489bd9ef063ae006feaebc3318ffa4143f6e16vboxsync )
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync )
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync {
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync return VERR_INVALID_PARAMETER;
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync }
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync /* Adjust timeout. If set to 0, we define
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync * an infinite timeout. */
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync if (procInfo.mTimeoutMS == 0)
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync procInfo.mTimeoutMS = UINT32_MAX;
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync /** @tood Implement process priority + affinity. */
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
6b9d50a0f466bd5a61458ed53925480ab28a3c17vboxsync int rc = VERR_MAX_PROCS_REACHED;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (mData.mNumObjects >= VBOX_GUESTCTRL_MAX_OBJECTS)
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync return rc;
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync /* Create a new (host-based) process ID and assign it. */
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync uint32_t uNewProcessID = 0;
6b9d50a0f466bd5a61458ed53925480ab28a3c17vboxsync ULONG uTries = 0;
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync for (;;)
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync {
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync /* Is the context ID already used? */
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync if (!processExists(uNewProcessID, NULL /* pProgress */))
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync {
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync /* Callback with context ID was not found. This means
6b9d50a0f466bd5a61458ed53925480ab28a3c17vboxsync * we can use this context ID for our new callback we want
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync * to add below. */
6b9d50a0f466bd5a61458ed53925480ab28a3c17vboxsync rc = VINF_SUCCESS;
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync break;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync }
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync uNewProcessID++;
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync if (uNewProcessID == VBOX_GUESTCTRL_MAX_OBJECTS)
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync uNewProcessID = 0;
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync if (++uTries == VBOX_GUESTCTRL_MAX_OBJECTS)
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync break; /* Don't try too hard. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync }
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync if (RT_FAILURE(rc))
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync return rc;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /* Create the process object. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync HRESULT hr = pProcess.createObject();
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync if (FAILED(hr))
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync return VERR_COM_UNEXPECTED;
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync rc = pProcess->init(mParent->getConsole() /* Console */, this /* Session */,
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync uNewProcessID, procInfo);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync if (RT_FAILURE(rc))
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync return rc;
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /* Add the created process to our map. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mProcesses[uNewProcessID] = pProcess;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mNumObjects++;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync Assert(mData.mNumObjects <= VBOX_GUESTCTRL_MAX_OBJECTS);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync fireGuestProcessRegisteredEvent(mEventSource, this /* Session */, pProcess,
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync 0 /* PID */, true /* Process registered */);
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync LogFlowFunc(("Added new process (Session: %RU32) with process ID=%RU32 (now total %ld processes, %ld objects)\n",
ccbdc11833996cb9f3be7868f1ebaefcacafb94dvboxsync mData.mSession.mID, uNewProcessID, mData.mProcesses.size(), mData.mNumObjects));
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return rc;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync}
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsyncinline bool GuestSession::processExists(uint32_t uProcessID, ComObjPtr<GuestProcess> *pProcess)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync{
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync SessionProcesses::const_iterator it = mData.mProcesses.find(uProcessID);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (it != mData.mProcesses.end())
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync {
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (pProcess)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync *pProcess = it->second;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return true;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync }
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return false;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync}
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsyncinline int GuestSession::processGetByPID(ULONG uPID, ComObjPtr<GuestProcess> *pProcess)
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync{
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync AssertReturn(uPID, false);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync /* pProcess is optional. */
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync SessionProcesses::iterator itProcs = mData.mProcesses.begin();
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync for (; itProcs != mData.mProcesses.end(); itProcs++)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync {
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync ComObjPtr<GuestProcess> pCurProc = itProcs->second;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync AutoCaller procCaller(pCurProc);
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync if (procCaller.rc())
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync return VERR_COM_INVALID_OBJECT_STATE;
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ULONG uCurPID;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync HRESULT hr = pCurProc->COMGETTER(PID)(&uCurPID);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ComAssertComRC(hr);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (uCurPID == uPID)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync {
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (pProcess)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync *pProcess = pCurProc;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync return VINF_SUCCESS;
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return VERR_NOT_FOUND;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync}
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsyncint GuestSession::sendCommand(uint32_t uFunction,
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync uint32_t uParms, PVBOXHGCMSVCPARM paParms)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFuncEnter();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#ifndef VBOX_GUESTCTRL_TEST_CASE
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync ComObjPtr<Console> pConsole = mParent->getConsole();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync Assert(!pConsole.isNull());
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Forward the information to the VMM device. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync VMMDev *pVMMDev = pConsole->getVMMDev();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync AssertPtr(pVMMDev);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFunc(("uFunction=%RU32, uParms=%RU32\n", uFunction, uParms));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int vrc = pVMMDev->hgcmHostCall(HGCMSERVICE_NAME, uFunction, uParms, paParms);
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (RT_FAILURE(vrc))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /** @todo What to do here? */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#else
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Not needed within testcases. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync int vrc = VINF_SUCCESS;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#endif
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync LogFlowFuncLeaveRC(vrc);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync return vrc;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync}
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync/* static */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsyncHRESULT GuestSession::setErrorExternal(VirtualBoxBase *pInterface, int guestRc)
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync{
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync AssertPtr(pInterface);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AssertMsg(RT_FAILURE(guestRc), ("Guest rc does not indicate a failure when setting error\n"));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return pInterface->setError(VBOX_E_IPRT_ERROR, GuestSession::guestErrorToString(guestRc).c_str());
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync/* Does not do locking; caller is responsible for that! */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncint GuestSession::setSessionStatus(GuestSessionStatus_T sessionStatus, int sessionRc)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync LogFlowThisFunc(("oldStatus=%ld, newStatus=%ld, sessionRc=%Rrc\n",
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mStatus, sessionStatus, sessionRc));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (sessionStatus == GuestSessionStatus_Error)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AssertMsg(RT_FAILURE(sessionRc), ("Guest rc must be an error (%Rrc)\n", sessionRc));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /* Do not allow overwriting an already set error. If this happens
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync * this means we forgot some error checking/locking somewhere. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AssertMsg(RT_SUCCESS(mData.mRC), ("Guest rc already set (to %Rrc)\n", mData.mRC));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync else
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AssertMsg(RT_SUCCESS(sessionRc), ("Guest rc must not be an error (%Rrc)\n", sessionRc));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync if (mData.mStatus != sessionStatus)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mStatus = sessionStatus;
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync mData.mRC = sessionRc;
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync ComObjPtr<VirtualBoxErrorInfo> errorInfo;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync HRESULT hr = errorInfo.createObject();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync ComAssertComRC(hr);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync int rc2 = errorInfo->initEx(VBOX_E_IPRT_ERROR, sessionRc,
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync COM_IIDOF(IGuestSession), getComponentName(),
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync guestErrorToString(sessionRc));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AssertRC(rc2);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync fireGuestSessionStateChangedEvent(mEventSource, this,
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync mData.mSession.mID, sessionStatus, errorInfo);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return VINF_SUCCESS;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync}
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsyncint GuestSession::signalWaiters(GuestSessionWaitResult_T enmWaitResult, int rc /*= VINF_SUCCESS */)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /*LogFlowThisFunc(("enmWaitResult=%d, rc=%Rrc, mWaitCount=%RU32, mWaitEvent=%p\n",
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync enmWaitResult, rc, mData.mWaitCount, mData.mWaitEvent));*/
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /* Note: No write locking here -- already done in the caller. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync int vrc = VINF_SUCCESS;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync /*if (mData.mWaitEvent)
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync vrc = mData.mWaitEvent->Signal(enmWaitResult, rc);*/
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync LogFlowFuncLeaveRC(vrc);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return vrc;
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync}
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsyncint GuestSession::startTaskAsync(const Utf8Str &strTaskDesc,
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync GuestSessionTask *pTask, ComObjPtr<Progress> &pProgress)
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync{
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync LogFlowThisFunc(("strTaskDesc=%s, pTask=%p\n", strTaskDesc.c_str(), pTask));
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync AssertPtrReturn(pTask, VERR_INVALID_POINTER);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync /* Create the progress object. */
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync HRESULT hr = pProgress.createObject();
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync if (FAILED(hr))
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync return VERR_COM_UNEXPECTED;
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync hr = pProgress->init(static_cast<IGuestSession*>(this),
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync Bstr(strTaskDesc).raw(),
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync TRUE /* aCancelable */);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (FAILED(hr))
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync return VERR_COM_UNEXPECTED;
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync /* Initialize our worker task. */
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync std::auto_ptr<GuestSessionTask> task(pTask);
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync
88cc9bf61296bc5526344415167bb2625ae1dd99vboxsync int rc = task->RunAsync(strTaskDesc, pProgress);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (RT_FAILURE(rc))
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return rc;
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync /* Don't destruct on success. */
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync task.release();
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync LogFlowFuncLeaveRC(rc);
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync return rc;
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync}
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync/**
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * Queries/collects information prior to establishing a guest session.
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * This is necessary to know which guest control protocol version to use,
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * among other things (later).
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync *
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * @return IPRT status code.
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync */
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsyncint GuestSession::queryInfo(void)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync{
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync /*
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * Try querying the guest control protocol version running on the guest.
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync * This is done using the Guest Additions version
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync ComObjPtr<Guest> pGuest = mParent;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync Assert(!pGuest.isNull());
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync uint32_t uVerAdditions = pGuest->getAdditionsVersion();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync uint32_t uVBoxMajor = VBOX_FULL_VERSION_GET_MAJOR(uVerAdditions);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync uint32_t uVBoxMinor = VBOX_FULL_VERSION_GET_MINOR(uVerAdditions);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync#if 0
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /* Hardcode the to-used protocol version; nice for testing side effects. */
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync mData.mProtocolVersion = 2;
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync#else
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync mData.mProtocolVersion = (
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync /* VBox 5.0 and up. */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync uVBoxMajor >= 5
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync /* VBox 4.3 and up. */
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync || (uVBoxMajor == 4 && uVBoxMinor >= 3))
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync ? 2 /* Guest control 2.0. */
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync : 1; /* Legacy guest control (VBox < 4.3). */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync /* Build revision is ignored. */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync#endif
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync LogFlowThisFunc(("uVerAdditions=%RU32 (%RU32.%RU32), mProtocolVersion=%RU32\n",
f9ce005e61f0fbb51a2cabc53d58c3485151faa9vboxsync uVerAdditions, uVBoxMajor, uVBoxMinor, mData.mProtocolVersion));
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /* Tell the user but don't bitch too often. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync static short s_gctrlLegacyWarning = 0;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if ( mData.mProtocolVersion < 2
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync && s_gctrlLegacyWarning++ < 3) /** @todo Find a bit nicer text. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogRel((tr("Warning: Guest Additions are older (%ld.%ld) than host capabilities for guest control, please upgrade them. Using protocol version %ld now\n"),
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync uVBoxMajor, uVBoxMinor, mData.mProtocolVersion));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return VINF_SUCCESS;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync}
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsyncint GuestSession::waitFor(uint32_t fWaitFlags, ULONG uTimeoutMS, GuestSessionWaitResult_T &waitResult, int *pGuestRc)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync{
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowThisFuncEnter();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AssertReturn(fWaitFlags, VERR_INVALID_PARAMETER);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /*LogFlowThisFunc(("fWaitFlags=0x%x, uTimeoutMS=%RU32, mStatus=%RU32, mWaitCount=%RU32, mWaitEvent=%p, pGuestRc=%p\n",
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync fWaitFlags, uTimeoutMS, mData.mStatus, mData.mWaitCount, mData.mWaitEvent, pGuestRc));*/
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync /* Did some error occur before? Then skip waiting and return. */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync if (mData.mStatus == GuestSessionStatus_Error)
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync {
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync waitResult = GuestSessionWaitResult_Error;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync AssertMsg(RT_FAILURE(mData.mRC), ("No error rc (%Rrc) set when guest session indicated an error\n", mData.mRC));
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync if (pGuestRc)
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync *pGuestRc = mData.mRC; /* Return last set error. */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync return VERR_GSTCTL_GUEST_ERROR;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /* Guest Additions < 4.3 don't support session handling, skip. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (mData.mProtocolVersion < 2)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_WaitFlagNotSupported;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowThisFunc(("Installed Guest Additions don't support waiting for dedicated sessions, skipping\n"));
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return VINF_SUCCESS;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_None;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (fWaitFlags & GuestSessionWaitForFlag_Terminate)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync switch (mData.mStatus)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Terminated:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Down:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Terminate;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_TimedOutKilled:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_TimedOutAbnormally:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Timeout;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Error:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /* Handled above. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Started:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Start;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Undefined:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Starting:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /* Do the waiting below. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync default:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AssertMsgFailed(("Unhandled session status %ld\n", mData.mStatus));
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return VERR_NOT_IMPLEMENTED;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync else if (fWaitFlags & GuestSessionWaitForFlag_Start)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync switch (mData.mStatus)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Started:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Terminating:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Terminated:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Down:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Start;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Error:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Error;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_TimedOutKilled:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_TimedOutAbnormally:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Timeout;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Undefined:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case GuestSessionStatus_Starting:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /* Do the waiting below. */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync default:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AssertMsgFailed(("Unhandled session status %ld\n", mData.mStatus));
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return VERR_NOT_IMPLEMENTED;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync LogFlowThisFunc(("sessionStatus=%ld, sessionRc=%Rrc, waitResult=%ld\n",
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync mData.mStatus, mData.mRC, waitResult));
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync /* No waiting needed? Return immediately using the last set error. */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (waitResult != GuestSessionWaitResult_None)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (pGuestRc)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync *pGuestRc = mData.mRC; /* Return last set error (if any). */
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return RT_SUCCESS(mData.mRC) ? VINF_SUCCESS : VERR_GSTCTL_GUEST_ERROR;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync int vrc;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync GuestWaitEvent *pEvent = NULL;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync std::list < VBoxEventType_T > eventTypes;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync try
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes.push_back(VBoxEventType_OnGuestSessionStateChanged);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync vrc = registerWaitEvent(mData.mSession.mID, 0 /* Object ID */,
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync eventTypes, &pEvent);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync catch (std::bad_alloc)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync vrc = VERR_NO_MEMORY;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_FAILURE(vrc))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return vrc;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync alock.release(); /* Release lock before waiting. */
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync GuestSessionStatus_T sessionStatus;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync vrc = waitForStatusChange(pEvent, fWaitFlags,
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync uTimeoutMS, &sessionStatus, pGuestRc);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_SUCCESS(vrc))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync switch (sessionStatus)
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync {
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GuestSessionStatus_Started:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync waitResult = GuestSessionWaitResult_Start;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GuestSessionStatus_Terminated:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync waitResult = GuestSessionWaitResult_Terminate;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GuestSessionStatus_TimedOutKilled:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GuestSessionStatus_TimedOutAbnormally:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync waitResult = GuestSessionWaitResult_Timeout;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync case GuestSessionStatus_Down:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync waitResult = GuestSessionWaitResult_Terminate;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync case GuestSessionStatus_Error:
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync waitResult = GuestSessionWaitResult_Error;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync default:
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync waitResult = GuestSessionWaitResult_Status;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync break;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync }
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync }
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync unregisterWaitEvent(pEvent);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync LogFlowFuncLeaveRC(vrc);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync return vrc;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync}
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsyncint GuestSession::waitForStatusChange(GuestWaitEvent *pEvent, uint32_t fWaitFlags, uint32_t uTimeoutMS,
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync GuestSessionStatus_T *pSessionStatus, int *pGuestRc)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync{
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync AssertPtrReturn(pEvent, VERR_INVALID_POINTER);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync VBoxEventType_T evtType;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync ComPtr<IEvent> pIEvent;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync int vrc = waitForEvent(pEvent, uTimeoutMS,
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync &evtType, pIEvent.asOutParam());
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (RT_SUCCESS(vrc))
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync {
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync Assert(evtType == VBoxEventType_OnGuestSessionStateChanged);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ComPtr<IGuestSessionStateChangedEvent> pChangedEvent = pIEvent;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync Assert(!pChangedEvent.isNull());
9e7e0b61d29309a0ed7af9472c8d6d865f9e8a2dvboxsync
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync GuestSessionStatus_T sessionStatus;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync pChangedEvent->COMGETTER(Status)(&sessionStatus);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync if (pSessionStatus)
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync *pSessionStatus = sessionStatus;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ComPtr<IVirtualBoxErrorInfo> errorInfo;
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync HRESULT hr = pChangedEvent->COMGETTER(Error)(errorInfo.asOutParam());
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync ComAssertComRC(hr);
ecf100db90e8e3af96312908282d3c20e754fbe8vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LONG lGuestRc;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync hr = errorInfo->COMGETTER(ResultDetail)(&lGuestRc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ComAssertComRC(hr);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (RT_FAILURE((int)lGuestRc))
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync vrc = VERR_GSTCTL_GUEST_ERROR;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (pGuestRc)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync *pGuestRc = (int)lGuestRc;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFunc(("Status changed event for session ID=%RU32, new status is: %ld (%Rrc)\n",
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync mData.mSession.mID, sessionStatus,
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync RT_SUCCESS((int)lGuestRc) ? VINF_SUCCESS : (int)lGuestRc));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowFuncLeaveRC(vrc);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return vrc;
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync// implementation of public methods
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync/////////////////////////////////////////////////////////////////////////////
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsyncSTDMETHODIMP GuestSession::Close(void)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync{
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync ReturnComNotImplemented();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync#else
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync LogFlowThisFuncEnter();
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync AutoCaller autoCaller(this);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync /* Close session on guest. */
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync int guestRc = VINF_SUCCESS;
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync int rc = closeSession(0 /* Flags */, 30 * 1000 /* Timeout */,
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync &guestRc);
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync /* On failure don't return here, instead do all the cleanup
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync * work first and then return an error. */
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync /* Remove ourselves from the session list. */
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync int rc2 = mParent->sessionRemove(this);
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_SUCCESS(rc))
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync rc = rc2;
3fb3de312d1ff675e0f7cc62a7d46cbb1d5d9353vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync LogFlowThisFunc(("Returning rc=%Rrc, guestRc=%Rrc\n",
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync rc, guestRc));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (RT_FAILURE(rc))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync {
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (rc == VERR_GSTCTL_GUEST_ERROR)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return GuestSession::setErrorExternal(this, guestRc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return setError(VBOX_E_IPRT_ERROR,
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync tr("Closing guest session failed with %Rrc"), rc);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync }
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return S_OK;
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsyncSTDMETHODIMP GuestSession::CopyFrom(IN_BSTR aSource, IN_BSTR aDest, ComSafeArrayIn(CopyFileFlag_T, aFlags), IProgress **aProgress)
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync{
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync ReturnComNotImplemented();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgStrNotEmptyOrNull(aSource);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgStrNotEmptyOrNull(aDest);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aProgress);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync LogFlowThisFuncEnter();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (RT_UNLIKELY((aSource) == NULL || *(aSource) == '\0'))
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return setError(E_INVALIDARG, tr("No source specified"));
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (RT_UNLIKELY((aDest) == NULL || *(aDest) == '\0'))
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return setError(E_INVALIDARG, tr("No destination specified"));
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync AutoCaller autoCaller(this);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync uint32_t fFlags = CopyFileFlag_None;
c99b597540585068d22dde4c9f74730305f24097vboxsync if (aFlags)
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync com::SafeArray<CopyFileFlag_T> flags(ComSafeArrayInArg(aFlags));
c99b597540585068d22dde4c9f74730305f24097vboxsync for (size_t i = 0; i < flags.size(); i++)
c99b597540585068d22dde4c9f74730305f24097vboxsync fFlags |= flags[i];
c99b597540585068d22dde4c9f74730305f24097vboxsync }
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync HRESULT hr = S_OK;
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync try
c99b597540585068d22dde4c9f74730305f24097vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync ComObjPtr<Progress> pProgress;
c99b597540585068d22dde4c9f74730305f24097vboxsync SessionTaskCopyFrom *pTask = new SessionTaskCopyFrom(this /* GuestSession */,
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync Utf8Str(aSource), Utf8Str(aDest), fFlags);
c99b597540585068d22dde4c9f74730305f24097vboxsync int rc = startTaskAsync(Utf8StrFmt(tr("Copying \"%ls\" from guest to \"%ls\" on the host"), aSource, aDest),
c99b597540585068d22dde4c9f74730305f24097vboxsync pTask, pProgress);
c99b597540585068d22dde4c9f74730305f24097vboxsync if (RT_SUCCESS(rc))
c99b597540585068d22dde4c9f74730305f24097vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync /* Return progress to the caller. */
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync hr = pProgress.queryInterfaceTo(aProgress);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR,
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync tr("Starting task for copying file \"%ls\" from guest to \"%ls\" on the host failed: %Rrc"), rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync catch(std::bad_alloc &)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync {
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = E_OUTOFMEMORY;
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync }
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return hr;
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsyncSTDMETHODIMP GuestSession::CopyTo(IN_BSTR aSource, IN_BSTR aDest, ComSafeArrayIn(CopyFileFlag_T, aFlags), IProgress **aProgress)
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync{
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync ReturnComNotImplemented();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgStrNotEmptyOrNull(aSource);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgStrNotEmptyOrNull(aDest);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync CheckComArgOutPointerValid(aProgress);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync LogFlowThisFuncEnter();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (RT_UNLIKELY((aSource) == NULL || *(aSource) == '\0'))
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return setError(E_INVALIDARG, tr("No source specified"));
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (RT_UNLIKELY((aDest) == NULL || *(aDest) == '\0'))
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync return setError(E_INVALIDARG, tr("No destination specified"));
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync AutoCaller autoCaller(this);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync uint32_t fFlags = CopyFileFlag_None;
c99b597540585068d22dde4c9f74730305f24097vboxsync if (aFlags)
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync com::SafeArray<CopyFileFlag_T> flags(ComSafeArrayInArg(aFlags));
c99b597540585068d22dde4c9f74730305f24097vboxsync for (size_t i = 0; i < flags.size(); i++)
c99b597540585068d22dde4c9f74730305f24097vboxsync fFlags |= flags[i];
02651f98b4320e70a300ba1ebe95270096ebfd4dvboxsync }
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync HRESULT hr = S_OK;
c99b597540585068d22dde4c9f74730305f24097vboxsync
c99b597540585068d22dde4c9f74730305f24097vboxsync try
c99b597540585068d22dde4c9f74730305f24097vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync ComObjPtr<Progress> pProgress;
c99b597540585068d22dde4c9f74730305f24097vboxsync SessionTaskCopyTo *pTask = new SessionTaskCopyTo(this /* GuestSession */,
c99b597540585068d22dde4c9f74730305f24097vboxsync Utf8Str(aSource), Utf8Str(aDest), fFlags);
0fd108a555ae02f2fb557d5f2c40281999b60d15vboxsync AssertPtrReturn(pTask, E_OUTOFMEMORY);
c99b597540585068d22dde4c9f74730305f24097vboxsync int rc = startTaskAsync(Utf8StrFmt(tr("Copying \"%ls\" from host to \"%ls\" on the guest"), aSource, aDest),
c99b597540585068d22dde4c9f74730305f24097vboxsync pTask, pProgress);
c99b597540585068d22dde4c9f74730305f24097vboxsync if (RT_SUCCESS(rc))
c99b597540585068d22dde4c9f74730305f24097vboxsync {
c99b597540585068d22dde4c9f74730305f24097vboxsync /* Return progress to the caller. */
c99b597540585068d22dde4c9f74730305f24097vboxsync hr = pProgress.queryInterfaceTo(aProgress);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR,
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync tr("Starting task for copying file \"%ls\" from host to \"%ls\" on the guest failed: %Rrc"), rc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync catch(std::bad_alloc &)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync {
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = E_OUTOFMEMORY;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return hr;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync}
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryCreate(IN_BSTR aPath, ULONG aMode,
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ComSafeArrayIn(DirectoryCreateFlag_T, aFlags))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync ReturnComNotImplemented();
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync#else
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync LogFlowThisFuncEnter();
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync return setError(E_INVALIDARG, tr("No directory to create specified"));
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync AutoCaller autoCaller(this);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync uint32_t fFlags = DirectoryCreateFlag_None;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (aFlags)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync com::SafeArray<DirectoryCreateFlag_T> flags(ComSafeArrayInArg(aFlags));
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync for (size_t i = 0; i < flags.size(); i++)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync fFlags |= flags[i];
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (fFlags)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (!(fFlags & DirectoryCreateFlag_Parents))
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync return setError(E_INVALIDARG, tr("Unknown flags (%#x)"), fFlags);
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync HRESULT hr = S_OK;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync ComObjPtr <GuestDirectory> pDirectory; int guestRc;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync int rc = directoryCreateInternal(Utf8Str(aPath), (uint32_t)aMode, fFlags, &guestRc);
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync if (RT_FAILURE(rc))
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync switch (rc)
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync {
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync case VERR_GSTCTL_GUEST_ERROR:
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync break;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync case VERR_INVALID_PARAMETER:
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Directory creation failed: Invalid parameters given"));
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync break;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync case VERR_BROKEN_PIPE:
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Directory creation failed: Unexpectedly aborted"));
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync break;
35e6d303696e46d969aaf9a59cc381333a483b0bvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync case VERR_CANT_CREATE:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Directory creation failed: Could not create directory"));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
3641904508e6a0671c21a083a2ed03ebad8d976cvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Directory creation failed: %Rrc"), rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync return hr;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsyncSTDMETHODIMP GuestSession::DirectoryCreateTemp(IN_BSTR aTemplate, ULONG aMode, IN_BSTR aPath, BOOL aSecure, BSTR *aDirectory)
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aTemplate) == NULL || *(aTemplate) == '\0'))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return setError(E_INVALIDARG, tr("No template specified"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return setError(E_INVALIDARG, tr("No directory name specified"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync CheckComArgOutPointerValid(aDirectory);
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync
ca3db470494a8b6eaec69ea37468a5cda65e2da8vboxsync AutoCaller autoCaller(this);
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync HRESULT hr = S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync Utf8Str strName; int guestRc;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync int rc = objectCreateTempInternal(Utf8Str(aTemplate),
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync Utf8Str(aPath),
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync true /* Directory */, strName, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(rc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync strName.cloneTo(aDirectory);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync switch (rc)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync case VERR_GSTCTL_GUEST_ERROR:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Temporary directory creation \"%s\" with template \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(), Utf8Str(aTemplate).c_str(), rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync return hr;
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync}
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryExists(IN_BSTR aPath, BOOL *aExists)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync ReturnComNotImplemented();
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync return setError(E_INVALIDARG, tr("No directory to check existence for specified"));
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync CheckComArgOutPointerValid(aExists);
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync AutoCaller autoCaller(this);
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync HRESULT hr = S_OK;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestFsObjData objData; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int rc = directoryQueryInfoInternal(Utf8Str(aPath), objData, &guestRc);
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync if (RT_SUCCESS(rc))
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync *aExists = objData.mType == FsObjType_Directory;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync else
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync {
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync switch (rc)
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync {
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync case VERR_GSTCTL_GUEST_ERROR:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Querying directory existence \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(), rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync return hr;
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsyncSTDMETHODIMP GuestSession::DirectoryOpen(IN_BSTR aPath, IN_BSTR aFilter, ComSafeArrayIn(DirectoryOpenFlag_T, aFlags), IGuestDirectory **aDirectory)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync LogFlowThisFuncEnter();
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync return setError(E_INVALIDARG, tr("No directory to open specified"));
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (RT_UNLIKELY((aFilter) != NULL && *(aFilter) != '\0'))
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync return setError(E_INVALIDARG, tr("Directory filters are not implemented yet"));
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync CheckComArgOutPointerValid(aDirectory);
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync AutoCaller autoCaller(this);
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync uint32_t fFlags = DirectoryOpenFlag_None;
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync if (aFlags)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync {
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync com::SafeArray<DirectoryOpenFlag_T> flags(ComSafeArrayInArg(aFlags));
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync for (size_t i = 0; i < flags.size(); i++)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync fFlags |= flags[i];
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (fFlags)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync return setError(E_INVALIDARG, tr("Open flags (%#x) not implemented yet"), fFlags);
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync }
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync HRESULT hr = S_OK;
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync ComObjPtr <GuestDirectory> pDirectory;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int rc = directoryOpenInternal(Utf8Str(aPath), Utf8Str(aFilter), fFlags, pDirectory);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(rc))
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync {
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync /* Return directory object to the caller. */
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync hr = pDirectory.queryInterfaceTo(aDirectory);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync else
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync {
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync switch (rc)
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync {
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync case VERR_INVALID_PARAMETER:
8bc8d66f188d5357155b8340e2d489573be2b607vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Opening directory \"%s\" failed; invalid parameters given",
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str()));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Opening directory \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(),rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync return hr;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync}
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryQueryInfo(IN_BSTR aPath, IGuestFsObjInfo **aInfo)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync ReturnComNotImplemented();
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync return setError(E_INVALIDARG, tr("No directory to query information for specified"));
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync CheckComArgOutPointerValid(aInfo);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync AutoCaller autoCaller(this);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync HRESULT hr = S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync GuestFsObjData objData; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = directoryQueryInfoInternal(Utf8Str(aPath), objData, &guestRc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (objData.mType == FsObjType_Directory)
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync ComObjPtr<GuestFsObjInfo> pFsObjInfo;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync hr = pFsObjInfo.createObject();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (FAILED(hr)) return hr;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync vrc = pFsObjInfo->init(objData);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_SUCCESS(vrc))
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync hr = pFsObjInfo.queryInterfaceTo(aInfo);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (FAILED(hr)) return hr;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_FAILURE(vrc))
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync switch (vrc)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync case VERR_GSTCTL_GUEST_ERROR:
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync break;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync case VERR_NOT_A_DIRECTORY:
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Element \"%s\" exists but is not a directory",
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str()));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Querying directory information for \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(), vrc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return hr;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryRemove(IN_BSTR aPath)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryRemoveRecursive(IN_BSTR aPath, ComSafeArrayIn(DirectoryRemoveRecFlag_T, aFlags), IProgress **aProgress)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectoryRename(IN_BSTR aSource, IN_BSTR aDest, ComSafeArrayIn(PathRenameFlag_T, aFlags))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::DirectorySetACL(IN_BSTR aPath, IN_BSTR aACL)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsyncSTDMETHODIMP GuestSession::EnvironmentClear(void)
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync{
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync ReturnComNotImplemented();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync mData.mEnvironment.Clear();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return S_OK;
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsyncSTDMETHODIMP GuestSession::EnvironmentGet(IN_BSTR aName, BSTR *aValue)
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync{
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync ReturnComNotImplemented();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#else
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (RT_UNLIKELY((aName) == NULL || *(aName) == '\0'))
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return setError(E_INVALIDARG, tr("No value name specified"));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync CheckComArgOutPointerValid(aValue);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Bstr strValue(mData.mEnvironment.Get(Utf8Str(aName)));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync strValue.cloneTo(aValue);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return S_OK;
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::EnvironmentSet(IN_BSTR aName, IN_BSTR aValue)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync ReturnComNotImplemented();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#else
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync LogFlowThisFuncEnter();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (RT_UNLIKELY((aName) == NULL || *(aName) == '\0'))
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync return setError(E_INVALIDARG, tr("No value name specified"));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync int rc = mData.mEnvironment.Set(Utf8Str(aName), Utf8Str(aValue));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync HRESULT hr = RT_SUCCESS(rc) ? S_OK : VBOX_E_IPRT_ERROR;
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowFuncLeaveRC(hr);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return hr;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsyncSTDMETHODIMP GuestSession::EnvironmentUnset(IN_BSTR aName)
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync{
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync ReturnComNotImplemented();
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
92e624e40b06b4dc6d0a8222e1de33bd3e879a63vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync mData.mEnvironment.Unset(Utf8Str(aName));
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFuncLeave();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return S_OK;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileCreateTemp(IN_BSTR aTemplate, ULONG aMode, IN_BSTR aPath, BOOL aSecure, IGuestFile **aFile)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync ReturnComNotImplemented();
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync}
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileExists(IN_BSTR aPath, BOOL *aExists)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync ReturnComNotImplemented();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return setError(E_INVALIDARG, tr("No file to check existence for specified"));
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync CheckComArgOutPointerValid(aExists);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync AutoCaller autoCaller(this);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync GuestFsObjData objData; int guestRc;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync int vrc = fileQueryInfoInternal(Utf8Str(aPath), objData, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync *aExists = TRUE;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync HRESULT hr = S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync switch (vrc)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync case VERR_GSTCTL_GUEST_ERROR:
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync break;
58c0567dee3cc3ebe62dec1e27f8e35bac4ddeb0vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync case VERR_NOT_A_FILE:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync *aExists = FALSE;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
36f3c24e4ad9c6b813767db1faeabbe7e2ecc057vboxsync
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync default:
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Querying file information for \"%s\" failed: %Rrc"),
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync Utf8Str(aPath).c_str(), vrc);
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync break;
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync }
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync return hr;
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync}
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsyncSTDMETHODIMP GuestSession::FileRemove(IN_BSTR aPath)
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync{
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync ReturnComNotImplemented();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync return setError(E_INVALIDARG, tr("No file to remove specified"));
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync AutoCaller autoCaller(this);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync HRESULT hr = S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = fileRemoveInternal(Utf8Str(aPath), &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_FAILURE(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync switch (vrc)
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync case VERR_GSTCTL_GUEST_ERROR:
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync break;
9e17ca2e9d797e845e3284141dd4086a4b817ae5vboxsync
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Removing file \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(), vrc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync return hr;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
5366e994777f9d9391cf809dc77610f57270d75dvboxsync}
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsyncSTDMETHODIMP GuestSession::FileOpen(IN_BSTR aPath, IN_BSTR aOpenMode, IN_BSTR aDisposition, ULONG aCreationMode, LONG64 aOffset, IGuestFile **aFile)
5366e994777f9d9391cf809dc77610f57270d75dvboxsync{
5366e994777f9d9391cf809dc77610f57270d75dvboxsync#ifndef VBOX_WITH_GUEST_CONTROL
5366e994777f9d9391cf809dc77610f57270d75dvboxsync ReturnComNotImplemented();
5366e994777f9d9391cf809dc77610f57270d75dvboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return setError(E_INVALIDARG, tr("No file to open specified"));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_UNLIKELY((aOpenMode) == NULL || *(aOpenMode) == '\0'))
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync return setError(E_INVALIDARG, tr("No open mode specified"));
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync if (RT_UNLIKELY((aDisposition) == NULL || *(aDisposition) == '\0'))
5366e994777f9d9391cf809dc77610f57270d75dvboxsync return setError(E_INVALIDARG, tr("No disposition mode specified"));
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync CheckComArgOutPointerValid(aFile);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync AutoCaller autoCaller(this);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync HRESULT hr = isReadyExternal();
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync if (FAILED(hr))
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync return hr;
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /** @todo Validate open mode. */
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /** @todo Validate disposition mode. */
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync /** @todo Validate creation mode. */
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync uint32_t uCreationMode = 0;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync GuestFileOpenInfo openInfo;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync openInfo.mFileName = Utf8Str(aPath);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync openInfo.mOpenMode = Utf8Str(aOpenMode);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync openInfo.mDisposition = Utf8Str(aDisposition);
5366e994777f9d9391cf809dc77610f57270d75dvboxsync openInfo.mCreationMode = aCreationMode;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync openInfo.mInitialOffset = aOffset;
5366e994777f9d9391cf809dc77610f57270d75dvboxsync
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync ComObjPtr <GuestFile> pFile; int guestRc;
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync int vrc = fileOpenInternal(openInfo, pFile, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
5366e994777f9d9391cf809dc77610f57270d75dvboxsync {
5366e994777f9d9391cf809dc77610f57270d75dvboxsync /* Return directory object to the caller. */
d8e12fa5dd1c35282b98cb165e42b6b395cf971bvboxsync hr = pFile.queryInterfaceTo(aFile);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync }
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync else
5366e994777f9d9391cf809dc77610f57270d75dvboxsync {
5366e994777f9d9391cf809dc77610f57270d75dvboxsync switch (vrc)
5366e994777f9d9391cf809dc77610f57270d75dvboxsync {
5366e994777f9d9391cf809dc77610f57270d75dvboxsync case VERR_GSTCTL_GUEST_ERROR:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = GuestFile::setErrorExternal(this, guestRc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Opening guest file \"%s\" failed: %Rrc"),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync Utf8Str(aPath).c_str(), vrc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync return hr;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync}
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileQueryInfo(IN_BSTR aPath, IGuestFsObjInfo **aInfo)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync ReturnComNotImplemented();
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync return setError(E_INVALIDARG, tr("No file to query information for specified"));
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync CheckComArgOutPointerValid(aInfo);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync AutoCaller autoCaller(this);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync HRESULT hr = S_OK;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync GuestFsObjData objData; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = fileQueryInfoInternal(Utf8Str(aPath), objData, &guestRc);
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_SUCCESS(vrc))
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync ComObjPtr<GuestFsObjInfo> pFsObjInfo;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync hr = pFsObjInfo.createObject();
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (FAILED(hr)) return hr;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync vrc = pFsObjInfo->init(objData);
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync if (RT_SUCCESS(vrc))
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync hr = pFsObjInfo.queryInterfaceTo(aInfo);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (FAILED(hr)) return hr;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync }
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync if (RT_FAILURE(vrc))
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync switch (vrc)
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync {
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync case VERR_GSTCTL_GUEST_ERROR:
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync break;
4121d226ac899f17e13aff3aff42b603c8b5c1fevboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync case VERR_NOT_A_FILE:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Element exists but is not a file"));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Querying file information failed: %Rrc"), vrc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync return hr;
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync}
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileQuerySize(IN_BSTR aPath, LONG64 *aSize)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync ReturnComNotImplemented();
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync#else
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync LogFlowThisFuncEnter();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync if (RT_UNLIKELY((aPath) == NULL || *(aPath) == '\0'))
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync return setError(E_INVALIDARG, tr("No file to query size for specified"));
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync CheckComArgOutPointerValid(aSize);
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync AutoCaller autoCaller(this);
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync HRESULT hr = S_OK;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int64_t llSize; int guestRc;
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync int vrc = fileQuerySizeInternal(Utf8Str(aPath), &llSize, &guestRc);
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync if (RT_SUCCESS(vrc))
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync {
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync *aSize = llSize;
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync }
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync else
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync {
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync switch (vrc)
e378dfdadd62aadc0a012c9953322d979d7606e6vboxsync {
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync case VERR_GSTCTL_GUEST_ERROR:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = GuestProcess::setErrorExternal(this, guestRc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Querying file size failed: %Rrc"), vrc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync }
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return hr;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileRename(IN_BSTR aSource, IN_BSTR aDest, ComSafeArrayIn(PathRenameFlag_T, aFlags))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::FileSetACL(IN_BSTR aPath, IN_BSTR aACL)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync ReturnComNotImplemented();
cd5df721f068659172f3bf95de8fedeb465f057dvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
45655563f818c5d5bbf4b3d14aa48cbd92a871f1vboxsync}
5050fc8de0b121eab1b738d7c1007cde4903284dvboxsync
cd5df721f068659172f3bf95de8fedeb465f057dvboxsyncSTDMETHODIMP GuestSession::ProcessCreate(IN_BSTR aCommand, ComSafeArrayIn(IN_BSTR, aArguments), ComSafeArrayIn(IN_BSTR, aEnvironment),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ComSafeArrayIn(ProcessCreateFlag_T, aFlags), ULONG aTimeoutMS, IGuestProcess **aProcess)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync#else
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync LogFlowThisFuncEnter();
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync com::SafeArray<LONG> affinityIgnored;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return ProcessCreateEx(aCommand, ComSafeArrayInArg(aArguments), ComSafeArrayInArg(aEnvironment),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ComSafeArrayInArg(aFlags), aTimeoutMS, ProcessPriority_Default, ComSafeArrayAsInParam(affinityIgnored), aProcess);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync}
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsyncSTDMETHODIMP GuestSession::ProcessCreateEx(IN_BSTR aCommand, ComSafeArrayIn(IN_BSTR, aArguments), ComSafeArrayIn(IN_BSTR, aEnvironment),
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ComSafeArrayIn(ProcessCreateFlag_T, aFlags), ULONG aTimeoutMS,
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ProcessPriority_T aPriority, ComSafeArrayIn(LONG, aAffinity),
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync IGuestProcess **aProcess)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync ReturnComNotImplemented();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync#else
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync LogFlowThisFuncEnter();
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
5366e994777f9d9391cf809dc77610f57270d75dvboxsync if (RT_UNLIKELY((aCommand) == NULL || *(aCommand) == '\0'))
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync return setError(E_INVALIDARG, tr("No command to execute specified"));
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync CheckComArgOutPointerValid(aProcess);
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync AutoCaller autoCaller(this);
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync HRESULT hr = isReadyExternal();
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync if (FAILED(hr))
45655563f818c5d5bbf4b3d14aa48cbd92a871f1vboxsync return hr;
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync GuestProcessStartupInfo procInfo;
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync procInfo.mCommand = Utf8Str(aCommand);
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync if (aArguments)
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync {
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync com::SafeArray<IN_BSTR> arguments(ComSafeArrayInArg(aArguments));
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync for (size_t i = 0; i < arguments.size(); i++)
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync procInfo.mArguments.push_back(Utf8Str(arguments[i]));
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync int rc = VINF_SUCCESS;
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync /*
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync * Create the process environment:
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync * - Apply the session environment in a first step, and
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync * - Apply environment variables specified by this call to
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync * have the chance of overwriting/deleting session entries.
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync */
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync procInfo.mEnvironment = mData.mEnvironment; /* Apply original session environment. */
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync if (aEnvironment)
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync {
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync com::SafeArray<IN_BSTR> environment(ComSafeArrayInArg(aEnvironment));
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync for (size_t i = 0; i < environment.size() && RT_SUCCESS(rc); i++)
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync rc = procInfo.mEnvironment.Set(Utf8Str(environment[i]));
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync }
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync if (RT_SUCCESS(rc))
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync {
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync if (aFlags)
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync {
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync com::SafeArray<ProcessCreateFlag_T> flags(ComSafeArrayInArg(aFlags));
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync for (size_t i = 0; i < flags.size(); i++)
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync procInfo.mFlags |= flags[i];
462e60a19d02a99b2b1a5c08dff74bb0808d707cvboxsync }
907b6adfa052386a0666d5557bee9bdbc100c2e5vboxsync
5f2b03bf7695dabd71222dba123532a3f76828c1vboxsync procInfo.mTimeoutMS = aTimeoutMS;
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync
45655563f818c5d5bbf4b3d14aa48cbd92a871f1vboxsync if (aAffinity)
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync com::SafeArray<LONG> affinity(ComSafeArrayInArg(aAffinity));
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync for (size_t i = 0; i < affinity.size(); i++)
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync if (affinity[i])
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync procInfo.mAffinity |= (uint64_t)1 << i;
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync procInfo.mPriority = aPriority;
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync ComObjPtr<GuestProcess> pProcess;
7862f4bd000f1eb6c86289f5ac2849e9cf943ca9vboxsync rc = processCreateExInteral(procInfo, pProcess);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (RT_SUCCESS(rc))
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync /* Return guest session to the caller. */
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync HRESULT hr2 = pProcess.queryInterfaceTo(aProcess);
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync if (FAILED(hr2))
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync rc = VERR_COM_OBJECT_NOT_FOUND;
c55bf74b54ecdfb5ebc4e5d90b620d0fee31737evboxsync
c10a6f0c7041e4d1ee50ad38425aab9d43c55522vboxsync if (RT_SUCCESS(rc))
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync rc = pProcess->startProcessAsync();
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync }
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
cc1ef2ef9bbc6a0ff964928d61b7298e5bfcce5fvboxsync if (RT_FAILURE(rc))
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync switch (rc)
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync {
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync case VERR_MAX_PROCS_REACHED:
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Maximum number of concurrent guest processes per session (%ld) reached"),
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync VBOX_GUESTCTRL_MAX_OBJECTS);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync /** @todo Add more errors here. */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
d4a9d525e6f2111d462d2d96462dced6b9ec00efvboxsync default:
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(VBOX_E_IPRT_ERROR, tr("Could not create guest process, rc=%Rrc"), rc);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync break;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync }
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync LogFlowFuncLeaveRC(rc);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return hr;
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync}
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::ProcessGet(ULONG aPID, IGuestProcess **aProcess)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ReturnComNotImplemented();
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync#else
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync LogFlowThisFunc(("aPID=%RU32\n", aPID));
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync CheckComArgOutPointerValid(aProcess);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (aPID == 0)
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync return setError(E_INVALIDARG, tr("No valid process ID (PID) specified"));
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync AutoCaller autoCaller(this);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS);
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync HRESULT hr = S_OK;
ed9d3db07648c7e3a979105c15ad752ee9ea18devboxsync
687794577e2e35c3cae67e692a7f2130d1262a82vboxsync ComObjPtr<GuestProcess> pProcess;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync int rc = processGetByPID(aPID, &pProcess);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (RT_FAILURE(rc))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = setError(E_INVALIDARG, tr("No process with PID %RU32 found"), aPID);
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync /* This will set (*aProcess) to NULL if pProgress is NULL. */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync HRESULT hr2 = pProcess.queryInterfaceTo(aProcess);
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync if (SUCCEEDED(hr))
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync hr = hr2;
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync LogFlowThisFunc(("aProcess=%p, hr=%Rhrc\n", *aProcess, hr));
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync return hr;
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::SymlinkCreate(IN_BSTR aSource, IN_BSTR aTarget, SymlinkType_T aType)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::SymlinkExists(IN_BSTR aSymlink, BOOL *aExists)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
06ea6bcf23874b662d499b3f130024c98b2dd7a6vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::SymlinkRead(IN_BSTR aSymlink, ComSafeArrayIn(SymlinkReadFlag_T, aFlags), BSTR *aTarget)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::SymlinkRemoveDirectory(IN_BSTR aPath)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9523921c89c66f4bececdbd5ac95aed0039eda1bvboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#else
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync LogFlowThisFuncEnter();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync AutoCaller autoCaller(this);
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
702a8ee2dc1de96f2f77e97135015d3e243186fdvboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync ReturnComNotImplemented();
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync}
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync
2f3883b126a405f92b19e829472f614c7352b4f9vboxsyncSTDMETHODIMP GuestSession::SymlinkRemoveFile(IN_BSTR aFile)
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync{
2f3883b126a405f92b19e829472f614c7352b4f9vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ReturnComNotImplemented();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#else
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowThisFuncEnter();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AutoCaller autoCaller(this);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ReturnComNotImplemented();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync}
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsyncSTDMETHODIMP GuestSession::WaitFor(ULONG aWaitFlags, ULONG aTimeoutMS, GuestSessionWaitResult_T *aReason)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync{
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ReturnComNotImplemented();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#else
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowThisFuncEnter();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync CheckComArgOutPointerValid(aReason);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AutoCaller autoCaller(this);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /*
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync * Note: Do not hold any locks here while waiting!
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync HRESULT hr = S_OK;
b8bb9c9f6b8ebfd0a7d6df0c0289f9fe80241750vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync int guestRc; GuestSessionWaitResult_T waitResult;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync int vrc = waitFor(aWaitFlags, aTimeoutMS, waitResult, &guestRc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (RT_SUCCESS(vrc))
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync *aReason = waitResult;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync else
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync switch (vrc)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case VERR_GSTCTL_GUEST_ERROR:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync hr = GuestSession::setErrorExternal(this, guestRc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync case VERR_TIMEOUT:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync *aReason = GuestSessionWaitResult_Timeout;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync default:
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync {
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync const char *pszSessionName = mData.mSession.mName.c_str();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync hr = setError(VBOX_E_IPRT_ERROR,
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync tr("Waiting for guest session \"%s\" failed: %Rrc"),
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync pszSessionName ? pszSessionName : tr("Unnamed"), vrc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync break;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync }
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowFuncLeaveRC(vrc);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync return hr;
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#endif /* VBOX_WITH_GUEST_CONTROL */
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync}
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsyncSTDMETHODIMP GuestSession::WaitForArray(ComSafeArrayIn(GuestSessionWaitForFlag_T, aFlags), ULONG aTimeoutMS, GuestSessionWaitResult_T *aReason)
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync{
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#ifndef VBOX_WITH_GUEST_CONTROL
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync ReturnComNotImplemented();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync#else
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync LogFlowThisFuncEnter();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync CheckComArgOutPointerValid(aReason);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync AutoCaller autoCaller(this);
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync if (FAILED(autoCaller.rc())) return autoCaller.rc();
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync
9bff17fe6983cfda2ddd98f1979841bcb48e78e7vboxsync /*
* Note: Do not hold any locks here while waiting!
*/
uint32_t fWaitFor = GuestSessionWaitForFlag_None;
com::SafeArray<GuestSessionWaitForFlag_T> flags(ComSafeArrayInArg(aFlags));
for (size_t i = 0; i < flags.size(); i++)
fWaitFor |= flags[i];
return WaitFor(fWaitFor, aTimeoutMS, aReason);
#endif /* VBOX_WITH_GUEST_CONTROL */
}