Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

400 lines
11 KiB

  1. /****************************************************************************
  2. Copyright information : Copyright (c) 1998-1999 Microsoft Corporation
  3. File Name : CommandSwitches.h
  4. Project Name : WMI Command Line
  5. Author Name : Ch. Sriramachandramurthy
  6. Date of Creation (dd/mm/yy) : 27th-September-2000
  7. Version Number : 1.0
  8. Brief Description : This file consist of class declaration of
  9. class GlobalSwitches
  10. Revision History :
  11. Last Modified by : Ch. Sriramachandramurthy
  12. Last Modified on : 17th-November-2000
  13. ****************************************************************************/
  14. /*-------------------------------------------------------------------
  15. Class Name : CGlobalSwitches
  16. Class Type : Concrete
  17. Brief Description : This class encapsulates the functionality needed
  18. for accessing and storing the global switches
  19. information, which will be used by Parsing,
  20. Execution and Format Engines depending upon the
  21. applicablity.
  22. Super Classes : None
  23. Sub Classes : None
  24. Classes Used : None
  25. Interfaces Used : None
  26. --------------------------------------------------------------------*/
  27. #pragma once
  28. class CGlobalSwitches
  29. {
  30. public:
  31. // Construction
  32. CGlobalSwitches();
  33. // Destruction
  34. ~CGlobalSwitches();
  35. // Restrict Assignment
  36. CGlobalSwitches& operator=(CGlobalSwitches& rGlblSwitches);
  37. // Attributes
  38. private:
  39. // Mapping b/w allowed strings for implevel and
  40. // the corresponding integer values.
  41. CHARINTMAP m_cimImpLevel;
  42. // Mapping b/w allowed strings for authlevel and
  43. // the corresponding integer values.
  44. CHARINTMAP m_cimAuthLevel;
  45. //String type, It stores Namespace specified in the command.
  46. _TCHAR* m_pszNameSpace;
  47. //String type, It stores Role specified in the command.
  48. _TCHAR* m_pszRole;
  49. //String type, It stores Node specified in the command.
  50. _TCHAR* m_pszNode;
  51. //CHARVECTOR type, It stores the Nodes specified in the command.
  52. CHARVECTOR m_cvNodesList;
  53. //String type, It stores User specified in the command.
  54. _TCHAR* m_pszUser;
  55. //String type, It stores Password specified in the command.
  56. _TCHAR* m_pszPassword;
  57. //String type, It stores Authority string specified in the command.
  58. _TCHAR* m_pszAuthorityPrinciple;
  59. //String type, It stores Locale value specified
  60. //in the command
  61. _TCHAR* m_pszLocale;
  62. //String type, It stores the Record specified in the command.
  63. _TCHAR* m_pszRecordPath;
  64. //Boolean type, It stores the value of the Privileges option specified
  65. //in the conmmand
  66. BOOL m_bPrivileges;
  67. //Boolean type, It stores the value of the Aggregate option specified
  68. //in the conmmand
  69. BOOL m_bAggregateFlag;
  70. //enumerated data type, It stores the value of the ImpersonationLevel
  71. //specified in the command.
  72. IMPLEVEL m_ImpLevel;
  73. //enumerated data type, It stores the value of the Authentication Level
  74. //specified in the command.
  75. AUTHLEVEL m_AuthLevel;
  76. // Boolean type, It specifies presence of the Interactive option
  77. //in the command
  78. BOOL m_bInteractive;
  79. //Boolean type, It specifies presence of the trace option in
  80. //the command
  81. BOOL m_bTrace;
  82. //Boolean type, It specifies Help(/?) option in the command
  83. BOOL m_bHelp;
  84. //HELPOPTION type, to specify type of help needed ( help option ).
  85. HELPOPTION m_HelpOption;
  86. //CONNECTION information flag
  87. UINT m_uConnInfoFlag;
  88. // role change flag
  89. BOOL m_bRoleFlag;
  90. // namespace change flag
  91. BOOL m_bNSFlag;
  92. // locale change flag
  93. BOOL m_bLocaleFlag;
  94. // prompt for password flag
  95. BOOL m_bAskForPassFlag;
  96. // change of recordpath flag
  97. BOOL m_bRPChange;
  98. // FailFast flag.
  99. BOOL m_bFailFast;
  100. // Output option.
  101. OUTPUTSPEC m_opsOutputOpt;
  102. // Append option.
  103. OUTPUTSPEC m_opsAppendOpt;
  104. // Output file name.
  105. _TCHAR* m_pszOutputFileName;
  106. // File pointer to output file stream..
  107. FILE* m_fpOutFile;
  108. // Append file name.
  109. _TCHAR* m_pszAppendFileName;
  110. // File pointer to append file stream..
  111. FILE* m_fpAppendFile;
  112. // type of file we append to
  113. FILETYPE m_eftFileType;
  114. WMICLIINT m_nSeqNum;
  115. _TCHAR* m_pszLoggedOnUser;
  116. _TCHAR* m_pszNodeName;
  117. _TCHAR* m_pszStartTime;
  118. // Operations
  119. public:
  120. //Sets the namespace passed in parameter to m_pszNameSpace.
  121. BOOL SetNameSpace(_TCHAR* pszNameSpace);
  122. //Sets the role passed in parameter to m_pszRole.
  123. BOOL SetRole(_TCHAR* pszRole);
  124. //Assigns the locale passed in parameter to m_pszLocale.
  125. BOOL SetLocale(_TCHAR* pszLocale);
  126. //Assigns the node passed in parameter to m_pszNode
  127. BOOL SetNode(_TCHAR* pszNode);
  128. //Adds the node passed in parameter to m_cvNodesList vector.
  129. BOOL AddToNodesList(_TCHAR* pszNode);
  130. //Assigns the user passed in parameter to m_pszUser
  131. BOOL SetUser(_TCHAR* pszUser);
  132. //Assigns the password passed in parameter to m_pszPassword
  133. BOOL SetPassword(_TCHAR* pszPassword);
  134. //Assigns the <authority principle> passed in parameter to m_pszAuthorityPrinciple
  135. BOOL SetAuthorityPrinciple(_TCHAR* pszAuthorityPrinciple);
  136. //Assigns the record file passed in parameter to m_pszRecordPath
  137. BOOL SetRecordPath(_TCHAR* pszRecordPath);
  138. //Assigns the bool value passed in parameter to m_bPrivileges
  139. void SetPrivileges(BOOL bEnable);
  140. //Assigns the impersonation level passed in parameter to
  141. //m_ImpLevel.
  142. BOOL SetImpersonationLevel(_TCHAR* const pszImpLevel);
  143. //Assigns the authentication level passed in parameter to
  144. //m_AuthLevel.
  145. BOOL SetAuthenticationLevel(_TCHAR* const pszAuthLevel);
  146. //This function sets the m_bTrace to TRUE,If Trace mode
  147. //is specified in the command
  148. void SetTraceMode(BOOL bTrace);
  149. //This function sets the m_bInteractive to TRUE,If
  150. //interactive mode is specified in the command
  151. void SetInteractiveMode(BOOL bInteractive);
  152. //sets the m_bHelp to TRUE, If /? is specified in the
  153. //command
  154. void SetHelpFlag(BOOL bHelp);
  155. // Sets the namespace change status flag with bNSFlag value
  156. void SetNameSpaceFlag(BOOL bNSFlag);
  157. // Sets the role change status flag with bRoleFlag value
  158. void SetRoleFlag(BOOL bRoleFlag);
  159. // Sets the locale change status flag with bLocaleFlag value
  160. void SetLocaleFlag(BOOL bLocaleFlag);
  161. // Sets the recordpath change status flag with bRPChange value
  162. void SetRPChangeStatus(BOOL bRPChange);
  163. //This function specifies whether the help should
  164. //be brief or full
  165. void SetHelpOption(HELPOPTION helpOption);
  166. //This function sets the Connection Info flag
  167. void SetConnInfoFlag(UINT uFlag);
  168. // Set AskForPass flag.
  169. void SetAskForPassFlag(BOOL bFlag);
  170. // Set m_bFailFast
  171. void SetFailFast(BOOL bFlag);
  172. //This function returns the Connection Info flag
  173. UINT GetConnInfoFlag();
  174. //Returns the string held in m_pszNameSpace
  175. _TCHAR* GetNameSpace();
  176. //Returns the string held in m_pszRole
  177. _TCHAR* GetRole();
  178. //Returns the string held in m_pszLocale
  179. _TCHAR* GetLocale();
  180. //Returns the string held in m_pszNode
  181. _TCHAR* GetNode();
  182. //Returns the referrence to m_cvNodesList.
  183. CHARVECTOR& GetNodesList();
  184. //Returns the string held in m_pszUser
  185. _TCHAR* GetUser();
  186. //Returns the string held in m_pszPassword
  187. _TCHAR* GetPassword();
  188. //Returns the string held in m_pszAuthority
  189. _TCHAR* GetAuthorityPrinciple();
  190. //Returns the string held in m_pszRecordPath
  191. _TCHAR* GetRecordPath();
  192. //Returns the m_bPrivileges value
  193. BOOL GetPrivileges();
  194. // Return the string equivalent of the boolean value
  195. // contained in m_bPrivilges flag
  196. void GetPrivilegesTextDesc(_bstr_t& bstrPriv);
  197. // Return the string equivalent of the boolean value
  198. // contained in m_bFailFast flag
  199. void GetFailFastTextDesc(_bstr_t& bstrFailFast);
  200. // Return the string equivalent of the OUTPUTSPEC value
  201. // contained in m_opsOutputOpt member.
  202. void GetOutputOrAppendTextDesc(_bstr_t& bstrOutputOpt,
  203. BOOL bIsOutput);
  204. // Return the string equivalent of the boolean value
  205. // contained in m_bTrace flag
  206. void GetTraceTextDesc(_bstr_t& bstrTrace);
  207. // Return the string equivalent of the boolean value
  208. // contained in m_bInteractive flag
  209. void GetInteractiveTextDesc(_bstr_t& bstrInteractive);
  210. // Returns the string equivalent of the implevel value
  211. // contained in m_ImpLevel
  212. void GetImpLevelTextDesc(_bstr_t& bstrImpLevel);
  213. // Returns the string equivalent of the authlevel value
  214. // contained in m_AuthLevel
  215. void GetAuthLevelTextDesc(_bstr_t& bstrAuthLevel);
  216. // Returns the ',' separated node string of the available
  217. // nodes
  218. void GetNodeString(_bstr_t& bstrNString);
  219. // Returns the content of the m_pszRecordPath
  220. // if NULL returns "N/A"
  221. void GetRecordPathDesc(_bstr_t& bstrRP);
  222. //Returns impersonation level held in m_ImpLevel
  223. LONG GetImpersonationLevel();
  224. //Returns authentication level held in m_AuthLevel
  225. LONG GetAuthenticationLevel();
  226. //Returns Trace status held in m_bTrace
  227. BOOL GetTraceStatus();
  228. //Returns Interactive status held in m_bInteractive
  229. BOOL GetInteractiveStatus();
  230. //Returns helpflag held in m_bHelp
  231. BOOL GetHelpFlag();
  232. // Returns the change of role status
  233. BOOL GetRoleFlag();
  234. // Returns the change of namespace status
  235. BOOL GetNameSpaceFlag();
  236. // Returns TRUE if message for password
  237. // needs to be prompted.
  238. BOOL GetAskForPassFlag();
  239. // Returns the change of locale status flag
  240. BOOL GetLocaleFlag();
  241. // Returns the change of recordpath status flag
  242. BOOL GetRPChangeStatus();
  243. //Returns helpflagOption held in m_bHelpOption
  244. HELPOPTION GetHelpOption();
  245. // Returns the m_bFailFast flag.
  246. BOOL GetFailFast();
  247. // Initialize the necessary member varialbes
  248. void Initialize();
  249. // General functions
  250. void Uninitialize();
  251. // Clears the Nodes List
  252. BOOL ClearNodesList();
  253. // Set file type
  254. void SetFileType ( FILETYPE aftOpt ) ;
  255. // Get file type
  256. FILETYPE GetFileType ( ) ;
  257. // Set Output option.
  258. void SetOutputOrAppendOption(OUTPUTSPEC opsOpt,
  259. BOOL bIsOutput);
  260. // Get Output option.
  261. OUTPUTSPEC GetOutputOrAppendOption(BOOL bIsOutput);
  262. // Set Output or append File Name, bOutput == TRUE for Output FALSE
  263. // for Append.
  264. BOOL SetOutputOrAppendFileName(const _TCHAR* pszFileName,
  265. BOOL bOutput);
  266. // Get Output or append file name, bOutput == TRUE for Output FALSE for
  267. // Append.
  268. _TCHAR* GetOutputOrAppendFileName(BOOL bOutput);
  269. // Set output or append file pointer, bOutput == TRUE for Output FALSE
  270. // for Append.
  271. void SetOutputOrAppendFilePointer(FILE* fpOutFile, BOOL bOutput);
  272. // Get output file pointer, bOutput == TRUE for Output FALSE for Append.
  273. FILE* GetOutputOrAppendFilePointer(BOOL bOutput);
  274. WMICLIINT GetSequenceNumber();
  275. _TCHAR* GetLoggedonUser();
  276. _TCHAR* GetMgmtStationName();
  277. _TCHAR* GetStartTime();
  278. BOOL SetStartTime();
  279. //Assigns the Aggregate flag passed in parameter to m_bAggregateFlag
  280. void SetAggregateFlag(BOOL bAggregateFlag);
  281. //Gets the agregate flag contained in m_bAggregateFlag
  282. BOOL GetAggregateFlag();
  283. // This function checks and Returns the string equivalent of the
  284. // boolean value contained in m_bAggregateFlag flag
  285. void GetAggregateTextDesc(_bstr_t& bstrAggregate);
  286. };