import api from '@/store/api'; import i18n from '@/i18n'; export const CERTIFICATE_TYPES = [ { type: 'HTTPS Certificate', location: '/redfish/v1/Managers/bmc/NetworkProtocol/HTTPS/Certificates/', label: i18n.t('pageCertificates.httpsCertificate'), }, { type: 'LDAP Certificate', location: '/redfish/v1/AccountService/LDAP/Certificates/', label: i18n.t('pageCertificates.ldapCertificate'), }, { type: 'TrustStore Certificate', location: '/redfish/v1/Managers/bmc/Truststore/Certificates/', // Web UI will show 'CA Certificate' instead of // 'TrustStore Certificate' after user testing revealed // the term 'TrustStore Certificate' wasn't recognized/was unfamilar label: i18n.t('pageCertificates.caCertificate'), }, ]; const getCertificateProp = (type, prop) => { const certificate = CERTIFICATE_TYPES.find( (certificate) => certificate.type === type, ); return certificate ? certificate[prop] : null; }; const CertificatesStore = { namespaced: true, state: { allCertificates: [], availableUploadTypes: [], }, getters: { allCertificates: (state) => state.allCertificates, availableUploadTypes: (state) => state.availableUploadTypes, }, mutations: { setCertificates(state, certificates) { state.allCertificates = certificates; }, setAvailableUploadTypes(state, availableUploadTypes) { state.availableUploadTypes = availableUploadTypes; }, }, actions: { async getCertificates({ commit }) { return await api .get('/redfish/v1/CertificateService/CertificateLocations') .then( ({ data: { Links: { Certificates }, }, }) => Certificates.map((certificate) => certificate['@odata.id']), ) .then((certificateLocations) => { const promises = certificateLocations.map((location) => api.get(location), ); api.all(promises).then( api.spread((...responses) => { const certificates = responses.map(({ data }) => { const { Name, ValidNotAfter, ValidNotBefore, Issuer = {}, Subject = {}, } = data; return { type: Name, location: data['@odata.id'], certificate: getCertificateProp(Name, 'label'), issuedBy: Issuer.CommonName, issuedTo: Subject.CommonName, validFrom: new Date(ValidNotBefore), validUntil: new Date(ValidNotAfter), }; }); const availableUploadTypes = CERTIFICATE_TYPES.filter( ({ type }) => !certificates .map((certificate) => certificate.type) .includes(type), ); commit('setCertificates', certificates); commit('setAvailableUploadTypes', availableUploadTypes); }), ); }); }, async addNewCertificate({ dispatch }, { file, type }) { return await api .post(getCertificateProp(type, 'location'), file, { headers: { 'Content-Type': 'application/x-pem-file' }, }) .then(() => dispatch('getCertificates')) .then(() => i18n.t('pageCertificates.toast.successAddCertificate', { certificate: getCertificateProp(type, 'label'), }), ) .catch((error) => { console.log(error); throw new Error(i18n.t('pageCertificates.toast.errorAddCertificate')); }); }, async replaceCertificate( { dispatch }, { certificateString, location, type }, ) { const data = {}; data.CertificateString = certificateString; data.CertificateType = 'PEM'; data.CertificateUri = { '@odata.id': location }; return await api .post( '/redfish/v1/CertificateService/Actions/CertificateService.ReplaceCertificate', data, ) .then(() => dispatch('getCertificates')) .then(() => i18n.t('pageCertificates.toast.successReplaceCertificate', { certificate: getCertificateProp(type, 'label'), }), ) .catch((error) => { console.log(error); throw new Error( i18n.t('pageCertificates.toast.errorReplaceCertificate'), ); }); }, async deleteCertificate({ dispatch }, { type, location }) { return await api .delete(location) .then(() => dispatch('getCertificates')) .then(() => i18n.t('pageCertificates.toast.successDeleteCertificate', { certificate: getCertificateProp(type, 'label'), }), ) .catch((error) => { console.log(error); throw new Error( i18n.t('pageCertificates.toast.errorDeleteCertificate'), ); }); }, async generateCsr(_, userData) { const { certificateType, country, state, city, companyName, companyUnit, commonName, keyPairAlgorithm, keyBitLength, keyCurveId, challengePassword, contactPerson, emailAddress, alternateName, } = userData; const data = {}; data.CertificateCollection = { '@odata.id': getCertificateProp(certificateType, 'location'), }; data.Country = country; data.State = state; data.City = city; data.Organization = companyName; data.OrganizationalUnit = companyUnit; data.CommonName = commonName; data.KeyPairAlgorithm = keyPairAlgorithm; data.AlternativeNames = alternateName; if (keyCurveId) data.KeyCurveId = keyCurveId; if (keyBitLength) data.KeyBitLength = keyBitLength; if (challengePassword) data.ChallengePassword = challengePassword; if (contactPerson) data.ContactPerson = contactPerson; if (emailAddress) data.Email = emailAddress; return await api .post( '/redfish/v1/CertificateService/Actions/CertificateService.GenerateCSR', data, ) //TODO: Success response also throws error so // can't accurately show legitimate error in UI .catch((error) => console.log(error)); }, }, }; export default CertificatesStore;