| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 /** | 5 /** |
| 6 * @fileoverview settings-certificate-subentry represents an SSL certificate | 6 * @fileoverview settings-certificate-subentry represents an SSL certificate |
| 7 * sub-entry. | 7 * sub-entry. |
| 8 */ | 8 */ |
| 9 |
| 10 /** |
| 11 * The payload of the certificate-action event that is emitted from this |
| 12 * component. |
| 13 * @typedef {{ |
| 14 * action: !settings.CertificateAction, |
| 15 * subnode: !CertificateSubnode, |
| 16 * certificateType: !settings.CertificateType |
| 17 * }} |
| 18 */ |
| 19 var CertificateActionEventDetail; |
| 20 |
| 21 cr.define('settings', function() { |
| 22 /** |
| 23 * Enumeration of actions that require a popup menu to be shown to the user. |
| 24 * @enum {number} |
| 25 */ |
| 26 var CertificateAction = { |
| 27 DELETE: 0, |
| 28 EDIT: 1, |
| 29 EXPORT_PERSONAL: 2, |
| 30 IMPORT_CA: 3, |
| 31 IMPORT_PERSONAL: 4, |
| 32 }; |
| 33 |
| 34 /** |
| 35 * The name of the event that is fired when a menu item is tapped. |
| 36 * @type {string} |
| 37 */ |
| 38 var CertificateActionEvent = 'certificate-action'; |
| 39 |
| 40 return { |
| 41 CertificateAction: CertificateAction, |
| 42 CertificateActionEvent: CertificateActionEvent, |
| 43 }; |
| 44 }); |
| 45 |
| 9 Polymer({ | 46 Polymer({ |
| 10 is: 'settings-certificate-subentry', | 47 is: 'settings-certificate-subentry', |
| 11 | 48 |
| 12 properties: { | 49 properties: { |
| 13 /** @type {!CertificateSubnode>} */ | 50 /** @type {!CertificateSubnode>} */ |
| 14 model: Object, | 51 model: Object, |
| 15 | 52 |
| 16 /** @type {!settings.CertificateType} */ | 53 /** @type {!settings.CertificateType} */ |
| 17 certificateType: String, | 54 certificateType: String, |
| 18 }, | 55 }, |
| 19 | 56 |
| 20 /** @private {!settings.CertificatesManagerBrowserProxy} */ | 57 /** @private {!settings.CertificatesManagerBrowserProxy} */ |
| 21 browserProxy_: null, | 58 browserProxy_: null, |
| 22 | 59 |
| 23 /** @override */ | 60 /** @override */ |
| 24 ready: function() { | 61 created: function() { |
| 25 this.browserProxy_ = settings.CertificatesBrowserProxyImpl.getInstance(); | 62 this.browserProxy_ = settings.CertificatesBrowserProxyImpl.getInstance(); |
| 26 }, | 63 }, |
| 27 | 64 |
| 28 /** | 65 /** |
| 66 * Dispatches an event indicating which certificate action was tapped. It is |
| 67 * used by the parent of this element to display a modal dialog accordingly. |
| 68 * @param {!settings.CertificateAction} action |
| 69 * @private |
| 70 */ |
| 71 dispatchCertificateActionEvent_: function(action) { |
| 72 this.fire( |
| 73 settings.CertificateActionEvent, |
| 74 /** @type {!CertificateActionEventDetail} */ ({ |
| 75 action: action, |
| 76 subnode: this.model, |
| 77 certificateType: this.certificateType, |
| 78 })); |
| 79 }, |
| 80 |
| 81 /** |
| 82 * Handles the case where a call to the browser resulted in a rejected |
| 83 * promise. |
| 84 * @param {null|!CertificatesError|!CertificatesImportError} error |
| 85 * @private |
| 86 */ |
| 87 onRejected_: function(error) { |
| 88 if (error === null) { |
| 89 // Nothing to do here. Null indicates that the user clicked "cancel" on |
| 90 // the native file chooser dialog. |
| 91 return; |
| 92 } |
| 93 |
| 94 // Otherwise propagate the error to the parents, such that a dialog |
| 95 // displaying the error will be shown. |
| 96 this.fire('certificates-error', error); |
| 97 }, |
| 98 |
| 99 /** |
| 29 * @param {!Event} event | 100 * @param {!Event} event |
| 30 * @private | 101 * @private |
| 31 */ | 102 */ |
| 32 onViewTap_: function(event) { | 103 onViewTap_: function(event) { |
| 33 this.closePopupMenu_(); | 104 this.closePopupMenu_(); |
| 34 this.browserProxy_.viewCertificate(this.model.id); | 105 this.browserProxy_.viewCertificate(this.model.id); |
| 35 }, | 106 }, |
| 36 | 107 |
| 37 /** | 108 /** |
| 38 * @param {!Event} event | 109 * @param {!Event} event |
| 39 * @private | 110 * @private |
| 40 */ | 111 */ |
| 41 onEditTap_: function(event) { | 112 onEditTap_: function(event) { |
| 42 this.closePopupMenu_(); | 113 this.closePopupMenu_(); |
| 43 // TODO(dpapad): Open edit dialog. | 114 this.dispatchCertificateActionEvent_(settings.CertificateAction.EDIT); |
| 44 }, | 115 }, |
| 45 | 116 |
| 46 /** | 117 /** |
| 47 * @param {!Event} event | 118 * @param {!Event} event |
| 48 * @private | 119 * @private |
| 49 */ | 120 */ |
| 50 onDeleteTap_: function(event) { | 121 onDeleteTap_: function(event) { |
| 51 this.closePopupMenu_(); | 122 this.closePopupMenu_(); |
| 52 // TODO(dpapad): Open delete confirmation dialog. | 123 this.dispatchCertificateActionEvent_(settings.CertificateAction.DELETE); |
| 53 }, | 124 }, |
| 54 | 125 |
| 55 /** | 126 /** |
| 56 * @param {!Event} event | 127 * @param {!Event} event |
| 57 * @private | 128 * @private |
| 58 */ | 129 */ |
| 59 onExportTap_: function(event) { | 130 onExportTap_: function(event) { |
| 60 this.closePopupMenu_(); | 131 this.closePopupMenu_(); |
| 61 if (this.certificateType == settings.CertificateType.PERSONAL) { | 132 if (this.certificateType == settings.CertificateType.PERSONAL) { |
| 62 // TODO(dpapad): Open password encryption dialog. | 133 this.browserProxy_.exportPersonalCertificate(this.model.id).then( |
| 134 function() { |
| 135 this.dispatchCertificateActionEvent_( |
| 136 settings.CertificateAction.EXPORT_PERSONAL); |
| 137 }.bind(this), |
| 138 this.onRejected_.bind(this)); |
| 63 } else { | 139 } else { |
| 64 this.browserProxy_.exportCertificate(this.model.id); | 140 this.browserProxy_.exportCertificate(this.model.id); |
| 65 } | 141 } |
| 66 }, | 142 }, |
| 67 | 143 |
| 68 /** @private */ | 144 /** @private */ |
| 69 onImportTap_: function() { | 145 onImportTap_: function() { |
| 70 this.closePopupMenu_(); | 146 this.closePopupMenu_(); |
| 71 if (this.certificateType == settings.CertificateType.PERSONAL) { | 147 if (this.certificateType == settings.CertificateType.PERSONAL) { |
| 72 // TODO(dpapad): Figure out when to pass true (ChromeOS?). | 148 // TODO(dpapad): Figure out when to pass true (ChromeOS?). |
| 73 this.browserProxy_.importPersonalCertificate(false).then( | 149 this.browserProxy_.importPersonalCertificate(false).then( |
| 74 function(showPasswordPrompt) { | 150 function(showPasswordPrompt) { |
| 75 if (showPasswordPrompt) { | 151 if (showPasswordPrompt) { |
| 76 // TODO(dpapad): Show password decryption dialog. | 152 this.dispatchCertificateActionEvent_( |
| 153 settings.CertificateAction.IMPORT_PERSONAL); |
| 77 } | 154 } |
| 78 }.bind(this)); | 155 }.bind(this), |
| 156 this.onRejected_.bind(this)); |
| 79 } else if (this.certificateType == settings.CertificateType.CA) { | 157 } else if (this.certificateType == settings.CertificateType.CA) { |
| 80 this.browserProxy_.importCaCertificate().then( | 158 this.browserProxy_.importCaCertificate().then( |
| 81 function(certificateName) { | 159 function(certificateName) { |
| 82 // TODO(dpapad): Show import dialog. | 160 this.dispatchCertificateActionEvent_( |
| 83 }.bind(this)); | 161 settings.CertificateAction.IMPORT_CA); |
| 162 }.bind(this), |
| 163 this.onRejected_.bind(this)); |
| 84 } else if (this.certificateType == settings.CertificateType.SERVER) { | 164 } else if (this.certificateType == settings.CertificateType.SERVER) { |
| 85 this.browserProxy_.importServerCertificate(); | 165 this.browserProxy_.importServerCertificate().catch( |
| 166 this.onRejected_.bind(this)); |
| 86 } | 167 } |
| 87 }, | 168 }, |
| 88 | 169 |
| 89 /** | 170 /** |
| 90 * @param {string} certificateType The type of this certificate. | 171 * @param {string} certificateType The type of this certificate. |
| 91 * @return {boolean} Whether the certificate can be edited. | 172 * @return {boolean} Whether the certificate can be edited. |
| 92 * @private | 173 * @private |
| 93 */ | 174 */ |
| 94 canEdit_: function(certificateType) { | 175 canEdit_: function(certificateType) { |
| 95 return this.certificateType == settings.CertificateType.CA; | 176 return this.certificateType == settings.CertificateType.CA; |
| 96 }, | 177 }, |
| 97 | 178 |
| 98 /** | 179 /** |
| 99 * @param {string} certificateType The type of this certificate. | 180 * @param {string} certificateType The type of this certificate. |
| 100 * @return {boolean} Whether a certificate can be imported. | 181 * @return {boolean} Whether a certificate can be imported. |
| 101 * @private | 182 * @private |
| 102 */ | 183 */ |
| 103 canImport_: function(certificateType) { | 184 canImport_: function(certificateType) { |
| 104 return this.certificateType != settings.CertificateType.OTHER; | 185 return this.certificateType != settings.CertificateType.OTHER; |
| 105 }, | 186 }, |
| 106 | 187 |
| 107 /** @private */ | 188 /** @private */ |
| 108 closePopupMenu_: function() { | 189 closePopupMenu_: function() { |
| 109 this.$$('iron-dropdown').close(); | 190 this.$$('iron-dropdown').close(); |
| 110 }, | 191 }, |
| 111 }); | 192 }); |
| OLD | NEW |