001 /*
002 * The MIT License
003 * Copyright (c) 2012 Microsoft Corporation
004 *
005 * Permission is hereby granted, free of charge, to any person obtaining a copy
006 * of this software and associated documentation files (the "Software"), to deal
007 * in the Software without restriction, including without limitation the rights
008 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
009 * copies of the Software, and to permit persons to whom the Software is
010 * furnished to do so, subject to the following conditions:
011 *
012 * The above copyright notice and this permission notice shall be included in
013 * all copies or substantial portions of the Software.
014 *
015 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
016 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
017 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
018 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
019 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
020 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
021 * THE SOFTWARE.
022 */
023
024 package microsoft.exchange.webservices.data.misc;
025
026 import microsoft.exchange.webservices.data.core.EwsServiceXmlReader;
027 import microsoft.exchange.webservices.data.core.EwsUtilities;
028 import microsoft.exchange.webservices.data.core.PropertySet;
029 import microsoft.exchange.webservices.data.core.XmlElementNames;
030 import microsoft.exchange.webservices.data.core.service.item.Contact;
031 import microsoft.exchange.webservices.data.core.enumeration.misc.XmlNamespace;
032 import microsoft.exchange.webservices.data.property.complex.EmailAddress;
033
034 /**
035 * Represents a suggested name resolution.
036 */
037 public final class NameResolution {
038
039 /**
040 * The owner.
041 */
042 private NameResolutionCollection owner;
043
044 /**
045 * The mailbox.
046 */
047 private EmailAddress mailbox = new EmailAddress();
048
049 /**
050 * The contact.
051 */
052 private Contact contact;
053
054 /**
055 * Initializes a new instance of the class.
056 *
057 * @param owner the owner
058 */
059 protected NameResolution(NameResolutionCollection owner) {
060 EwsUtilities.ewsAssert(owner != null, "NameResolution.ctor", "owner is null.");
061
062 this.owner = owner;
063 }
064
065 /**
066 * Loads from XML.
067 *
068 * @param reader the reader
069 * @throws Exception the exception
070 */
071 protected void loadFromXml(EwsServiceXmlReader reader) throws Exception {
072 reader.readStartElement(XmlNamespace.Types, XmlElementNames.Resolution);
073 reader.readStartElement(XmlNamespace.Types, XmlElementNames.Mailbox);
074 this.mailbox.loadFromXml(reader, XmlElementNames.Mailbox);
075
076 reader.read();
077 if (reader.isStartElement(XmlNamespace.Types, XmlElementNames.Contact)) {
078 this.contact = new Contact(this.owner.getSession());
079 this.contact.loadFromXml(reader, true /* clearPropertyBag */,
080 PropertySet.FirstClassProperties,
081 false /* summaryPropertiesOnly */);
082
083 reader.readEndElement(XmlNamespace.Types,
084 XmlElementNames.Resolution);
085 } else {
086 reader.ensureCurrentNodeIsEndElement(XmlNamespace.Types,
087 XmlElementNames.Resolution);
088 }
089 }
090
091 /**
092 * Gets the mailbox of the suggested resolved name.
093 *
094 * @return the mailbox
095 */
096 public EmailAddress getMailbox() {
097 return this.mailbox;
098 }
099
100 /**
101 * Gets the contact information of the suggested resolved name. This
102 * property is only available when ResolveName is called with
103 * returnContactDetails = true.
104 *
105 * @return the contact
106 */
107 public Contact getContact() {
108 return this.contact;
109 }
110 }