SurenNeware | 6185909 | 2020-10-01 09:37:32 +0530 | [diff] [blame] | 1 | import api from '@/store/api'; |
| 2 | import i18n from '@/i18n'; |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 3 | |
Yoshie Muranaka | 532a4b0 | 2020-03-27 11:00:50 -0700 | [diff] [blame] | 4 | export const CERTIFICATE_TYPES = [ |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 5 | { |
| 6 | type: 'HTTPS Certificate', |
| 7 | location: '/redfish/v1/Managers/bmc/NetworkProtocol/HTTPS/Certificates/', |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 8 | label: i18n.t('pageSslCertificates.httpsCertificate'), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 9 | }, |
| 10 | { |
| 11 | type: 'LDAP Certificate', |
| 12 | location: '/redfish/v1/AccountService/LDAP/Certificates/', |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 13 | label: i18n.t('pageSslCertificates.ldapCertificate'), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 14 | }, |
| 15 | { |
| 16 | type: 'TrustStore Certificate', |
| 17 | location: '/redfish/v1/Managers/bmc/Truststore/Certificates/', |
| 18 | // Web UI will show 'CA Certificate' instead of |
| 19 | // 'TrustStore Certificate' after user testing revealed |
| 20 | // the term 'TrustStore Certificate' wasn't recognized/was unfamilar |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 21 | label: i18n.t('pageSslCertificates.caCertificate'), |
| 22 | }, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 23 | ]; |
| 24 | |
| 25 | const getCertificateProp = (type, prop) => { |
| 26 | const certificate = CERTIFICATE_TYPES.find( |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 27 | (certificate) => certificate.type === type |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 28 | ); |
| 29 | return certificate ? certificate[prop] : null; |
| 30 | }; |
| 31 | |
| 32 | const SslCertificatesStore = { |
| 33 | namespaced: true, |
| 34 | state: { |
| 35 | allCertificates: [], |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 36 | availableUploadTypes: [], |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 37 | }, |
| 38 | getters: { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 39 | allCertificates: (state) => state.allCertificates, |
| 40 | availableUploadTypes: (state) => state.availableUploadTypes, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 41 | }, |
| 42 | mutations: { |
| 43 | setCertificates(state, certificates) { |
| 44 | state.allCertificates = certificates; |
| 45 | }, |
| 46 | setAvailableUploadTypes(state, availableUploadTypes) { |
| 47 | state.availableUploadTypes = availableUploadTypes; |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 48 | }, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 49 | }, |
| 50 | actions: { |
Yoshie Muranaka | e5be9ba | 2020-04-30 10:13:40 -0700 | [diff] [blame] | 51 | async getCertificates({ commit }) { |
| 52 | return await api |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 53 | .get('/redfish/v1/CertificateService/CertificateLocations') |
| 54 | .then(({ data: { Links: { Certificates } } }) => |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 55 | Certificates.map((certificate) => certificate['@odata.id']) |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 56 | ) |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 57 | .then((certificateLocations) => { |
| 58 | const promises = certificateLocations.map((location) => |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 59 | api.get(location) |
| 60 | ); |
| 61 | api.all(promises).then( |
| 62 | api.spread((...responses) => { |
| 63 | const certificates = responses.map(({ data }) => { |
| 64 | const { |
| 65 | Name, |
| 66 | ValidNotAfter, |
| 67 | ValidNotBefore, |
| 68 | Issuer = {}, |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 69 | Subject = {}, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 70 | } = data; |
| 71 | return { |
| 72 | type: Name, |
| 73 | location: data['@odata.id'], |
| 74 | certificate: getCertificateProp(Name, 'label'), |
| 75 | issuedBy: Issuer.CommonName, |
| 76 | issuedTo: Subject.CommonName, |
| 77 | validFrom: new Date(ValidNotBefore), |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 78 | validUntil: new Date(ValidNotAfter), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 79 | }; |
| 80 | }); |
| 81 | const availableUploadTypes = CERTIFICATE_TYPES.filter( |
| 82 | ({ type }) => |
| 83 | !certificates |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 84 | .map((certificate) => certificate.type) |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 85 | .includes(type) |
| 86 | ); |
| 87 | |
| 88 | commit('setCertificates', certificates); |
| 89 | commit('setAvailableUploadTypes', availableUploadTypes); |
| 90 | }) |
| 91 | ); |
| 92 | }); |
| 93 | }, |
| 94 | async addNewCertificate({ dispatch }, { file, type }) { |
| 95 | return await api |
| 96 | .post(getCertificateProp(type, 'location'), file, { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 97 | headers: { 'Content-Type': 'application/x-pem-file' }, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 98 | }) |
| 99 | .then(() => dispatch('getCertificates')) |
| 100 | .then(() => |
| 101 | i18n.t('pageSslCertificates.toast.successAddCertificate', { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 102 | certificate: getCertificateProp(type, 'label'), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 103 | }) |
| 104 | ) |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 105 | .catch((error) => { |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 106 | console.log(error); |
| 107 | throw new Error( |
| 108 | i18n.t('pageSslCertificates.toast.errorAddCertificate') |
| 109 | ); |
| 110 | }); |
| 111 | }, |
| 112 | async replaceCertificate( |
| 113 | { dispatch }, |
| 114 | { certificateString, location, type } |
| 115 | ) { |
| 116 | const data = {}; |
| 117 | data.CertificateString = certificateString; |
| 118 | data.CertificateType = 'PEM'; |
| 119 | data.CertificateUri = { '@odata.id': location }; |
| 120 | |
| 121 | return await api |
| 122 | .post( |
| 123 | '/redfish/v1/CertificateService/Actions/CertificateService.ReplaceCertificate', |
| 124 | data |
| 125 | ) |
| 126 | .then(() => dispatch('getCertificates')) |
| 127 | .then(() => |
| 128 | i18n.t('pageSslCertificates.toast.successReplaceCertificate', { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 129 | certificate: getCertificateProp(type, 'label'), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 130 | }) |
| 131 | ) |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 132 | .catch((error) => { |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 133 | console.log(error); |
| 134 | throw new Error( |
| 135 | i18n.t('pageSslCertificates.toast.errorReplaceCertificate') |
| 136 | ); |
| 137 | }); |
| 138 | }, |
| 139 | async deleteCertificate({ dispatch }, { type, location }) { |
| 140 | return await api |
| 141 | .delete(location) |
| 142 | .then(() => dispatch('getCertificates')) |
| 143 | .then(() => |
| 144 | i18n.t('pageSslCertificates.toast.successDeleteCertificate', { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 145 | certificate: getCertificateProp(type, 'label'), |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 146 | }) |
| 147 | ) |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 148 | .catch((error) => { |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 149 | console.log(error); |
| 150 | throw new Error( |
| 151 | i18n.t('pageSslCertificates.toast.errorDeleteCertificate') |
| 152 | ); |
| 153 | }); |
Yoshie Muranaka | 532a4b0 | 2020-03-27 11:00:50 -0700 | [diff] [blame] | 154 | }, |
| 155 | async generateCsr(_, userData) { |
| 156 | const { |
| 157 | certificateType, |
| 158 | country, |
| 159 | state, |
| 160 | city, |
| 161 | companyName, |
| 162 | companyUnit, |
| 163 | commonName, |
| 164 | keyPairAlgorithm, |
| 165 | keyBitLength, |
| 166 | keyCurveId, |
| 167 | challengePassword, |
| 168 | contactPerson, |
| 169 | emailAddress, |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 170 | alternateName, |
Yoshie Muranaka | 532a4b0 | 2020-03-27 11:00:50 -0700 | [diff] [blame] | 171 | } = userData; |
| 172 | const data = {}; |
| 173 | |
| 174 | data.CertificateCollection = { |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 175 | '@odata.id': getCertificateProp(certificateType, 'location'), |
Yoshie Muranaka | 532a4b0 | 2020-03-27 11:00:50 -0700 | [diff] [blame] | 176 | }; |
| 177 | data.Country = country; |
| 178 | data.State = state; |
| 179 | data.City = city; |
| 180 | data.Organization = companyName; |
| 181 | data.OrganizationalUnit = companyUnit; |
| 182 | data.CommonName = commonName; |
| 183 | data.KeyPairAlgorithm = keyPairAlgorithm; |
| 184 | data.AlternativeNames = alternateName; |
| 185 | |
| 186 | if (keyCurveId) data.KeyCurveId = keyCurveId; |
| 187 | if (keyBitLength) data.KeyBitLength = keyBitLength; |
| 188 | if (challengePassword) data.ChallengePassword = challengePassword; |
| 189 | if (contactPerson) data.ContactPerson = contactPerson; |
| 190 | if (emailAddress) data.Email = emailAddress; |
| 191 | |
| 192 | return await api |
| 193 | .post( |
| 194 | '/redfish/v1/CertificateService/Actions/CertificateService.GenerateCSR', |
| 195 | data |
| 196 | ) |
| 197 | //TODO: Success response also throws error so |
| 198 | // can't accurately show legitimate error in UI |
Derick Montague | 602e98a | 2020-10-21 16:20:00 -0500 | [diff] [blame^] | 199 | .catch((error) => console.log(error)); |
| 200 | }, |
| 201 | }, |
Yoshie Muranaka | 3739381 | 2020-03-24 15:25:24 -0700 | [diff] [blame] | 202 | }; |
| 203 | |
| 204 | export default SslCertificatesStore; |