| /** |
| * @license |
| * Copyright 2016 Google LLC |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| import '../../shared/gr-button/gr-button'; |
| import '../../shared/gr-copy-clipboard/gr-copy-clipboard'; |
| import {getAppContext} from '../../../services/app-context'; |
| import {grFormStyles} from '../../../styles/gr-form-styles'; |
| import {sharedStyles} from '../../../styles/shared-styles'; |
| import {LitElement, css, html} from 'lit'; |
| import {customElement, property, query} from 'lit/decorators.js'; |
| import {modalStyles} from '../../../styles/gr-modal-styles'; |
| |
| declare global { |
| interface HTMLElementTagNameMap { |
| 'gr-http-password': GrHttpPassword; |
| } |
| } |
| |
| @customElement('gr-http-password') |
| export class GrHttpPassword extends LitElement { |
| @query('#generatedPasswordModal') |
| generatedPasswordModal?: HTMLDialogElement; |
| |
| @property({type: String}) |
| _username?: string; |
| |
| @property({type: String}) |
| _generatedPassword?: string; |
| |
| @property({type: String}) |
| _passwordUrl: string | null = null; |
| |
| private readonly restApiService = getAppContext().restApiService; |
| |
| override connectedCallback() { |
| super.connectedCallback(); |
| this.loadData(); |
| } |
| |
| loadData() { |
| const promises = []; |
| |
| promises.push( |
| this.restApiService.getAccount().then(account => { |
| if (account) { |
| this._username = account.username; |
| } |
| }) |
| ); |
| |
| promises.push( |
| this.restApiService.getConfig().then(info => { |
| if (info) { |
| this._passwordUrl = info.auth.http_password_url || null; |
| } else { |
| this._passwordUrl = null; |
| } |
| }) |
| ); |
| |
| return Promise.all(promises); |
| } |
| |
| static override get styles() { |
| return [ |
| sharedStyles, |
| grFormStyles, |
| modalStyles, |
| css` |
| .password { |
| font-family: var(--monospace-font-family); |
| font-size: var(--font-size-mono); |
| line-height: var(--line-height-mono); |
| } |
| #generatedPasswordModal { |
| padding: var(--spacing-xxl); |
| width: 50em; |
| } |
| #generatedPasswordDisplay { |
| margin: var(--spacing-l) 0; |
| } |
| #generatedPasswordDisplay .title { |
| width: unset; |
| } |
| #generatedPasswordDisplay .value { |
| font-family: var(--monospace-font-family); |
| font-size: var(--font-size-mono); |
| line-height: var(--line-height-mono); |
| } |
| #passwordWarning { |
| font-style: italic; |
| text-align: center; |
| } |
| .closeButton { |
| bottom: 2em; |
| position: absolute; |
| right: 2em; |
| } |
| `, |
| ]; |
| } |
| |
| override render() { |
| return html` <div class="gr-form-styles"> |
| <div ?hidden=${!!this._passwordUrl}> |
| <section> |
| <span class="title">Username</span> |
| <span class="value">${this._username ?? ''}</span> |
| </section> |
| <gr-button id="generateButton" @click=${this._handleGenerateTap} |
| >Generate new password</gr-button |
| > |
| </div> |
| <span ?hidden=${!this._passwordUrl}> |
| <a |
| href=${this._passwordUrl!} |
| target="_blank" |
| rel="noopener noreferrer" |
| > |
| Obtain password</a |
| > |
| (opens in a new tab) |
| </span> |
| </div> |
| <dialog |
| tabindex="-1" |
| id="generatedPasswordModal" |
| @closed=${this._generatedPasswordModalClosed} |
| > |
| <div class="gr-form-styles"> |
| <section id="generatedPasswordDisplay"> |
| <span class="title">New Password:</span> |
| <span class="value">${this._generatedPassword}</span> |
| <gr-copy-clipboard |
| hasTooltip="" |
| buttonTitle="Copy password to clipboard" |
| hideInput="" |
| .text=${this._generatedPassword} |
| > |
| </gr-copy-clipboard> |
| </section> |
| <section id="passwordWarning"> |
| This password will not be displayed again.<br /> |
| If you lose it, you will need to generate a new one. |
| </section> |
| <gr-button link="" class="closeButton" @click=${this._closeModal} |
| >Close</gr-button |
| > |
| </div> |
| </dialog>`; |
| } |
| |
| _handleGenerateTap() { |
| this._generatedPassword = 'Generating...'; |
| this.generatedPasswordModal?.showModal(); |
| this.restApiService.generateAccountHttpPassword().then(newPassword => { |
| this._generatedPassword = newPassword; |
| }); |
| } |
| |
| _closeModal() { |
| this.generatedPasswordModal?.close(); |
| } |
| |
| _generatedPasswordModalClosed() { |
| this._generatedPassword = ''; |
| } |
| } |