// Copyright (c) 2010 Martin Knafve / hMailServer.com. // http://www.hmailserver.com #include "stdafx.h" #include "COMError.h" #include "InterfaceSSLCertificate.h" #include "..\Common\Persistence\PersistentSSLCertificate.h" #include "..\Common\BO\SSLCertificate.h" // InterfaceSSLCertificate STDMETHODIMP InterfaceSSLCertificate::Save() { try { if (!object_) return GetAccessDenied(); if (!authentication_->GetIsServerAdmin()) return authentication_->GetAccessDenied(); if (HM::PersistentSSLCertificate::SaveObject(object_)) { // Add to parent collection AddToParentCollection(); } return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::Delete() { try { if (!object_) return GetAccessDenied(); if (!authentication_->GetIsServerAdmin()) return authentication_->GetAccessDenied(); if (!parent_collection_) return HM::PersistentSSLCertificate::DeleteObject(object_) ? S_OK : S_FALSE; parent_collection_->DeleteItemByDBID(object_->GetID()); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::get_ID(long *pVal) { try { if (!object_) return GetAccessDenied(); *pVal = (long) object_->GetID(); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::put_Name(BSTR newVal) { try { if (!object_) return GetAccessDenied(); object_->SetName(newVal); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::get_Name(BSTR *pVal) { try { if (!object_) return GetAccessDenied(); *pVal = object_->GetName().AllocSysString(); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::put_CertificateFile(BSTR newVal) { try { if (!object_) return GetAccessDenied(); object_->SetCertificateFile(newVal); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::get_CertificateFile(BSTR *pVal) { try { if (!object_) return GetAccessDenied(); *pVal = object_->GetCertificateFile().AllocSysString(); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::put_PrivateKeyFile(BSTR newVal) { try { if (!object_) return GetAccessDenied(); object_->SetPrivateKeyFile(newVal); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } } STDMETHODIMP InterfaceSSLCertificate::get_PrivateKeyFile(BSTR *pVal) { try { if (!object_) return GetAccessDenied(); *pVal = object_->GetPrivateKeyFile().AllocSysString(); return S_OK; } catch (...) { return COMError::GenerateGenericMessage(); } }