1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-11 18:24:43 +02:00

Desktop: Add an option to renew the API token (#4811)

This commit is contained in:
Helmut K. C. Tessarek 2021-04-07 14:27:16 -04:00 committed by GitHub
parent e3efe70bab
commit 2fc9c53ff0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 26 additions and 2 deletions

View File

@ -7,6 +7,7 @@ const ClipperServer = require('@joplin/lib/ClipperServer');
const Setting = require('@joplin/lib/models/Setting').default;
const { clipboard } = require('electron');
const ExtensionBadge = require('./ExtensionBadge.min');
const EncryptionService = require('@joplin/lib/services/EncryptionService').default;
class ClipperConfigScreenComponent extends React.Component {
constructor() {
@ -39,6 +40,16 @@ class ClipperConfigScreenComponent extends React.Component {
alert(_('Token has been copied to the clipboard!'));
}
renewToken_click() {
if (confirm(_('Are you sure you want to renew the authorisation token?'))) {
void EncryptionService.instance()
.generateApiToken()
.then((token: string) => {
Setting.setValue('api.token', token);
});
}
}
render() {
const theme = themeStyle(this.props.themeId);
@ -59,6 +70,10 @@ class ClipperConfigScreenComponent extends React.Component {
backgroundColor: theme.backgroundColor,
};
const tokenStyle = {
fontFamily: 'monospace',
};
const webClipperStatusComps = [];
if (this.props.clipperServerAutoStart) {
@ -131,12 +146,17 @@ class ClipperConfigScreenComponent extends React.Component {
<p style={theme.h1Style}>{_('Advanced options')}</p>
<p style={theme.textStyle}>{_('Authorisation token:')}</p>
<p style={apiTokenStyle}>
{this.props.apiToken}{' '}
<span style={tokenStyle}>{this.props.apiToken}{' '}</span>
<a style={theme.urlStyle} href="#" onClick={this.copyToken_click}>
{_('Copy token')}
</a>
</p>
<p style={theme.textStyle}>{_('This authorisation token is only needed to allow third-party applications to access Joplin.')}</p>
<div>
<button key="renew_button" style={buttonStyle} onClick={this.renewToken_click}>
{_('Renew token')}
</button>
</div>
</div>
</div>
</div>

View File

@ -776,7 +776,7 @@ export default class BaseApplication {
if (!Setting.value('api.token')) {
void EncryptionService.instance()
.randomHexString(64)
.generateApiToken()
.then((token: string) => {
Setting.setValue('api.token', token);
});

View File

@ -254,6 +254,10 @@ export default class EncryptionService {
// sjcl.random.addEntropy(hexSeed, 1024, 'shim.randomBytes');
// }
async generateApiToken() {
return await this.randomHexString(64);
}
async randomHexString(byteCount: number) {
const bytes: any[] = await shim.randomBytes(byteCount);
return bytes