/aws-java-sdk-directory/src/main/java/com/amazonaws/services/directory/model/CreateComputerRequest.java

https://github.com/aws/aws-sdk-java · Java · 380 lines · 142 code · 44 blank · 194 comment · 63 complexity · 21e337e84081db6e0b6f652d5529ef4a MD5 · raw file

  1. /*
  2. * Copyright 2016-2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
  5. * the License. A copy of the License is located at
  6. *
  7. * http://aws.amazon.com/apache2.0
  8. *
  9. * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
  10. * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
  11. * and limitations under the License.
  12. */
  13. package com.amazonaws.services.directory.model;
  14. import java.io.Serializable;
  15. import javax.annotation.Generated;
  16. import com.amazonaws.AmazonWebServiceRequest;
  17. /**
  18. * <p>
  19. * Contains the inputs for the <a>CreateComputer</a> operation.
  20. * </p>
  21. *
  22. * @see <a href="http://docs.aws.amazon.com/goto/WebAPI/ds-2015-04-16/CreateComputer" target="_top">AWS API
  23. * Documentation</a>
  24. */
  25. @Generated("com.amazonaws:aws-java-sdk-code-generator")
  26. public class CreateComputerRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {
  27. /**
  28. * <p>
  29. * The identifier of the directory in which to create the computer account.
  30. * </p>
  31. */
  32. private String directoryId;
  33. /**
  34. * <p>
  35. * The name of the computer account.
  36. * </p>
  37. */
  38. private String computerName;
  39. /**
  40. * <p>
  41. * A one-time password that is used to join the computer to the directory. You should generate a random, strong
  42. * password to use for this parameter.
  43. * </p>
  44. */
  45. private String password;
  46. /**
  47. * <p>
  48. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  49. * </p>
  50. */
  51. private String organizationalUnitDistinguishedName;
  52. /**
  53. * <p>
  54. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  55. * </p>
  56. */
  57. private com.amazonaws.internal.SdkInternalList<Attribute> computerAttributes;
  58. /**
  59. * <p>
  60. * The identifier of the directory in which to create the computer account.
  61. * </p>
  62. *
  63. * @param directoryId
  64. * The identifier of the directory in which to create the computer account.
  65. */
  66. public void setDirectoryId(String directoryId) {
  67. this.directoryId = directoryId;
  68. }
  69. /**
  70. * <p>
  71. * The identifier of the directory in which to create the computer account.
  72. * </p>
  73. *
  74. * @return The identifier of the directory in which to create the computer account.
  75. */
  76. public String getDirectoryId() {
  77. return this.directoryId;
  78. }
  79. /**
  80. * <p>
  81. * The identifier of the directory in which to create the computer account.
  82. * </p>
  83. *
  84. * @param directoryId
  85. * The identifier of the directory in which to create the computer account.
  86. * @return Returns a reference to this object so that method calls can be chained together.
  87. */
  88. public CreateComputerRequest withDirectoryId(String directoryId) {
  89. setDirectoryId(directoryId);
  90. return this;
  91. }
  92. /**
  93. * <p>
  94. * The name of the computer account.
  95. * </p>
  96. *
  97. * @param computerName
  98. * The name of the computer account.
  99. */
  100. public void setComputerName(String computerName) {
  101. this.computerName = computerName;
  102. }
  103. /**
  104. * <p>
  105. * The name of the computer account.
  106. * </p>
  107. *
  108. * @return The name of the computer account.
  109. */
  110. public String getComputerName() {
  111. return this.computerName;
  112. }
  113. /**
  114. * <p>
  115. * The name of the computer account.
  116. * </p>
  117. *
  118. * @param computerName
  119. * The name of the computer account.
  120. * @return Returns a reference to this object so that method calls can be chained together.
  121. */
  122. public CreateComputerRequest withComputerName(String computerName) {
  123. setComputerName(computerName);
  124. return this;
  125. }
  126. /**
  127. * <p>
  128. * A one-time password that is used to join the computer to the directory. You should generate a random, strong
  129. * password to use for this parameter.
  130. * </p>
  131. *
  132. * @param password
  133. * A one-time password that is used to join the computer to the directory. You should generate a random,
  134. * strong password to use for this parameter.
  135. */
  136. public void setPassword(String password) {
  137. this.password = password;
  138. }
  139. /**
  140. * <p>
  141. * A one-time password that is used to join the computer to the directory. You should generate a random, strong
  142. * password to use for this parameter.
  143. * </p>
  144. *
  145. * @return A one-time password that is used to join the computer to the directory. You should generate a random,
  146. * strong password to use for this parameter.
  147. */
  148. public String getPassword() {
  149. return this.password;
  150. }
  151. /**
  152. * <p>
  153. * A one-time password that is used to join the computer to the directory. You should generate a random, strong
  154. * password to use for this parameter.
  155. * </p>
  156. *
  157. * @param password
  158. * A one-time password that is used to join the computer to the directory. You should generate a random,
  159. * strong password to use for this parameter.
  160. * @return Returns a reference to this object so that method calls can be chained together.
  161. */
  162. public CreateComputerRequest withPassword(String password) {
  163. setPassword(password);
  164. return this;
  165. }
  166. /**
  167. * <p>
  168. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  169. * </p>
  170. *
  171. * @param organizationalUnitDistinguishedName
  172. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  173. */
  174. public void setOrganizationalUnitDistinguishedName(String organizationalUnitDistinguishedName) {
  175. this.organizationalUnitDistinguishedName = organizationalUnitDistinguishedName;
  176. }
  177. /**
  178. * <p>
  179. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  180. * </p>
  181. *
  182. * @return The fully-qualified distinguished name of the organizational unit to place the computer account in.
  183. */
  184. public String getOrganizationalUnitDistinguishedName() {
  185. return this.organizationalUnitDistinguishedName;
  186. }
  187. /**
  188. * <p>
  189. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  190. * </p>
  191. *
  192. * @param organizationalUnitDistinguishedName
  193. * The fully-qualified distinguished name of the organizational unit to place the computer account in.
  194. * @return Returns a reference to this object so that method calls can be chained together.
  195. */
  196. public CreateComputerRequest withOrganizationalUnitDistinguishedName(String organizationalUnitDistinguishedName) {
  197. setOrganizationalUnitDistinguishedName(organizationalUnitDistinguishedName);
  198. return this;
  199. }
  200. /**
  201. * <p>
  202. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  203. * </p>
  204. *
  205. * @return An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  206. */
  207. public java.util.List<Attribute> getComputerAttributes() {
  208. if (computerAttributes == null) {
  209. computerAttributes = new com.amazonaws.internal.SdkInternalList<Attribute>();
  210. }
  211. return computerAttributes;
  212. }
  213. /**
  214. * <p>
  215. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  216. * </p>
  217. *
  218. * @param computerAttributes
  219. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  220. */
  221. public void setComputerAttributes(java.util.Collection<Attribute> computerAttributes) {
  222. if (computerAttributes == null) {
  223. this.computerAttributes = null;
  224. return;
  225. }
  226. this.computerAttributes = new com.amazonaws.internal.SdkInternalList<Attribute>(computerAttributes);
  227. }
  228. /**
  229. * <p>
  230. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  231. * </p>
  232. * <p>
  233. * <b>NOTE:</b> This method appends the values to the existing list (if any). Use
  234. * {@link #setComputerAttributes(java.util.Collection)} or {@link #withComputerAttributes(java.util.Collection)} if
  235. * you want to override the existing values.
  236. * </p>
  237. *
  238. * @param computerAttributes
  239. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  240. * @return Returns a reference to this object so that method calls can be chained together.
  241. */
  242. public CreateComputerRequest withComputerAttributes(Attribute... computerAttributes) {
  243. if (this.computerAttributes == null) {
  244. setComputerAttributes(new com.amazonaws.internal.SdkInternalList<Attribute>(computerAttributes.length));
  245. }
  246. for (Attribute ele : computerAttributes) {
  247. this.computerAttributes.add(ele);
  248. }
  249. return this;
  250. }
  251. /**
  252. * <p>
  253. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  254. * </p>
  255. *
  256. * @param computerAttributes
  257. * An array of <a>Attribute</a> objects that contain any LDAP attributes to apply to the computer account.
  258. * @return Returns a reference to this object so that method calls can be chained together.
  259. */
  260. public CreateComputerRequest withComputerAttributes(java.util.Collection<Attribute> computerAttributes) {
  261. setComputerAttributes(computerAttributes);
  262. return this;
  263. }
  264. /**
  265. * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
  266. * redacted from this string using a placeholder value.
  267. *
  268. * @return A string representation of this object.
  269. *
  270. * @see java.lang.Object#toString()
  271. */
  272. @Override
  273. public String toString() {
  274. StringBuilder sb = new StringBuilder();
  275. sb.append("{");
  276. if (getDirectoryId() != null)
  277. sb.append("DirectoryId: ").append(getDirectoryId()).append(",");
  278. if (getComputerName() != null)
  279. sb.append("ComputerName: ").append(getComputerName()).append(",");
  280. if (getPassword() != null)
  281. sb.append("Password: ").append("***Sensitive Data Redacted***").append(",");
  282. if (getOrganizationalUnitDistinguishedName() != null)
  283. sb.append("OrganizationalUnitDistinguishedName: ").append(getOrganizationalUnitDistinguishedName()).append(",");
  284. if (getComputerAttributes() != null)
  285. sb.append("ComputerAttributes: ").append(getComputerAttributes());
  286. sb.append("}");
  287. return sb.toString();
  288. }
  289. @Override
  290. public boolean equals(Object obj) {
  291. if (this == obj)
  292. return true;
  293. if (obj == null)
  294. return false;
  295. if (obj instanceof CreateComputerRequest == false)
  296. return false;
  297. CreateComputerRequest other = (CreateComputerRequest) obj;
  298. if (other.getDirectoryId() == null ^ this.getDirectoryId() == null)
  299. return false;
  300. if (other.getDirectoryId() != null && other.getDirectoryId().equals(this.getDirectoryId()) == false)
  301. return false;
  302. if (other.getComputerName() == null ^ this.getComputerName() == null)
  303. return false;
  304. if (other.getComputerName() != null && other.getComputerName().equals(this.getComputerName()) == false)
  305. return false;
  306. if (other.getPassword() == null ^ this.getPassword() == null)
  307. return false;
  308. if (other.getPassword() != null && other.getPassword().equals(this.getPassword()) == false)
  309. return false;
  310. if (other.getOrganizationalUnitDistinguishedName() == null ^ this.getOrganizationalUnitDistinguishedName() == null)
  311. return false;
  312. if (other.getOrganizationalUnitDistinguishedName() != null
  313. && other.getOrganizationalUnitDistinguishedName().equals(this.getOrganizationalUnitDistinguishedName()) == false)
  314. return false;
  315. if (other.getComputerAttributes() == null ^ this.getComputerAttributes() == null)
  316. return false;
  317. if (other.getComputerAttributes() != null && other.getComputerAttributes().equals(this.getComputerAttributes()) == false)
  318. return false;
  319. return true;
  320. }
  321. @Override
  322. public int hashCode() {
  323. final int prime = 31;
  324. int hashCode = 1;
  325. hashCode = prime * hashCode + ((getDirectoryId() == null) ? 0 : getDirectoryId().hashCode());
  326. hashCode = prime * hashCode + ((getComputerName() == null) ? 0 : getComputerName().hashCode());
  327. hashCode = prime * hashCode + ((getPassword() == null) ? 0 : getPassword().hashCode());
  328. hashCode = prime * hashCode + ((getOrganizationalUnitDistinguishedName() == null) ? 0 : getOrganizationalUnitDistinguishedName().hashCode());
  329. hashCode = prime * hashCode + ((getComputerAttributes() == null) ? 0 : getComputerAttributes().hashCode());
  330. return hashCode;
  331. }
  332. @Override
  333. public CreateComputerRequest clone() {
  334. return (CreateComputerRequest) super.clone();
  335. }
  336. }