Merge pull request #3980 from matrix-org/jryans/cs-polish
Replace device with session in UI text
This commit is contained in:
commit
6a94d84630
38 changed files with 207 additions and 208 deletions
|
@ -139,7 +139,7 @@ function _setCallListeners(call) {
|
||||||
Modal.createTrackedDialog('Call Failed', '', QuestionDialog, {
|
Modal.createTrackedDialog('Call Failed', '', QuestionDialog, {
|
||||||
title: _t('Call Failed'),
|
title: _t('Call Failed'),
|
||||||
description: _t(
|
description: _t(
|
||||||
"There are unknown devices in this room: "+
|
"There are unknown sessions in this room: "+
|
||||||
"if you proceed without verifying them, it will be "+
|
"if you proceed without verifying them, it will be "+
|
||||||
"possible for someone to eavesdrop on your call.",
|
"possible for someone to eavesdrop on your call.",
|
||||||
),
|
),
|
||||||
|
|
|
@ -378,7 +378,7 @@ export function hydrateSession(credentials) {
|
||||||
|
|
||||||
const overwrite = credentials.userId !== oldUserId || credentials.deviceId !== oldDeviceId;
|
const overwrite = credentials.userId !== oldUserId || credentials.deviceId !== oldDeviceId;
|
||||||
if (overwrite) {
|
if (overwrite) {
|
||||||
console.warn("Clearing all data: Old session belongs to a different user/device");
|
console.warn("Clearing all data: Old session belongs to a different user/session");
|
||||||
}
|
}
|
||||||
|
|
||||||
return _doSetLoggedIn(credentials, overwrite);
|
return _doSetLoggedIn(credentials, overwrite);
|
||||||
|
|
|
@ -771,7 +771,7 @@ export const CommandMap = {
|
||||||
verify: new Command({
|
verify: new Command({
|
||||||
name: 'verify',
|
name: 'verify',
|
||||||
args: '<user-id> <device-id> <device-signing-key>',
|
args: '<user-id> <device-id> <device-signing-key>',
|
||||||
description: _td('Verifies a user, device, and pubkey tuple'),
|
description: _td('Verifies a user, session, and pubkey tuple'),
|
||||||
runFn: function(roomId, args) {
|
runFn: function(roomId, args) {
|
||||||
if (args) {
|
if (args) {
|
||||||
const matches = args.match(/^(\S+) +(\S+) +(\S+)$/);
|
const matches = args.match(/^(\S+) +(\S+) +(\S+)$/);
|
||||||
|
@ -785,22 +785,22 @@ export const CommandMap = {
|
||||||
return success((async () => {
|
return success((async () => {
|
||||||
const device = await cli.getStoredDevice(userId, deviceId);
|
const device = await cli.getStoredDevice(userId, deviceId);
|
||||||
if (!device) {
|
if (!device) {
|
||||||
throw new Error(_t('Unknown (user, device) pair:') + ` (${userId}, ${deviceId})`);
|
throw new Error(_t('Unknown (user, session) pair:') + ` (${userId}, ${deviceId})`);
|
||||||
}
|
}
|
||||||
const deviceTrust = await cli.checkDeviceTrust(userId, deviceId);
|
const deviceTrust = await cli.checkDeviceTrust(userId, deviceId);
|
||||||
|
|
||||||
if (deviceTrust.isVerified()) {
|
if (deviceTrust.isVerified()) {
|
||||||
if (device.getFingerprint() === fingerprint) {
|
if (device.getFingerprint() === fingerprint) {
|
||||||
throw new Error(_t('Device already verified!'));
|
throw new Error(_t('Session already verified!'));
|
||||||
} else {
|
} else {
|
||||||
throw new Error(_t('WARNING: Device already verified, but keys do NOT MATCH!'));
|
throw new Error(_t('WARNING: Session already verified, but keys do NOT MATCH!'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (device.getFingerprint() !== fingerprint) {
|
if (device.getFingerprint() !== fingerprint) {
|
||||||
const fprint = device.getFingerprint();
|
const fprint = device.getFingerprint();
|
||||||
throw new Error(
|
throw new Error(
|
||||||
_t('WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and device' +
|
_t('WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and session' +
|
||||||
' %(deviceId)s is "%(fprint)s" which does not match the provided key ' +
|
' %(deviceId)s is "%(fprint)s" which does not match the provided key ' +
|
||||||
'"%(fingerprint)s". This could mean your communications are being intercepted!',
|
'"%(fingerprint)s". This could mean your communications are being intercepted!',
|
||||||
{
|
{
|
||||||
|
@ -821,7 +821,7 @@ export const CommandMap = {
|
||||||
<p>
|
<p>
|
||||||
{
|
{
|
||||||
_t('The signing key you provided matches the signing key you received ' +
|
_t('The signing key you provided matches the signing key you received ' +
|
||||||
'from %(userId)s\'s device %(deviceId)s. Device marked as verified.',
|
'from %(userId)s\'s session %(deviceId)s. Session marked as verified.',
|
||||||
{userId, deviceId})
|
{userId, deviceId})
|
||||||
}
|
}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -191,7 +191,7 @@ export default createReactClass({
|
||||||
<h4>{ _t('Event information') }</h4>
|
<h4>{ _t('Event information') }</h4>
|
||||||
{ this._renderEventInfo() }
|
{ this._renderEventInfo() }
|
||||||
|
|
||||||
<h4>{ _t('Sender device information') }</h4>
|
<h4>{ _t('Sender session information') }</h4>
|
||||||
{ this._renderDeviceInfo() }
|
{ this._renderDeviceInfo() }
|
||||||
</div>
|
</div>
|
||||||
<div className="mx_Dialog_buttons">
|
<div className="mx_Dialog_buttons">
|
||||||
|
|
|
@ -495,7 +495,7 @@ export default class CreateKeyBackupDialog extends React.PureComponent {
|
||||||
return <div>
|
return <div>
|
||||||
{_t(
|
{_t(
|
||||||
"Without setting up Secure Message Recovery, you won't be able to restore your " +
|
"Without setting up Secure Message Recovery, you won't be able to restore your " +
|
||||||
"encrypted message history if you log out or use another device.",
|
"encrypted message history if you log out or use another session.",
|
||||||
)}
|
)}
|
||||||
<DialogButtons primaryButton={_t('Set up Secure Message Recovery')}
|
<DialogButtons primaryButton={_t('Set up Secure Message Recovery')}
|
||||||
onPrimaryButtonClick={this._onSetUpClick}
|
onPrimaryButtonClick={this._onSetUpClick}
|
||||||
|
|
|
@ -73,7 +73,7 @@ export default class NewRecoveryMethodDialog extends React.PureComponent {
|
||||||
content = <div>
|
content = <div>
|
||||||
{newMethodDetected}
|
{newMethodDetected}
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"This device is encrypting history using the new recovery method.",
|
"This session is encrypting history using the new recovery method.",
|
||||||
)}</p>
|
)}</p>
|
||||||
{hackWarning}
|
{hackWarning}
|
||||||
<DialogButtons
|
<DialogButtons
|
||||||
|
|
|
@ -55,12 +55,12 @@ export default class RecoveryMethodRemovedDialog extends React.PureComponent {
|
||||||
>
|
>
|
||||||
<div>
|
<div>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"This device has detected that your recovery passphrase and key " +
|
"This session has detected that your recovery passphrase and key " +
|
||||||
"for Secure Messages have been removed.",
|
"for Secure Messages have been removed.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"If you did this accidentally, you can setup Secure Messages on " +
|
"If you did this accidentally, you can setup Secure Messages on " +
|
||||||
"this device which will re-encrypt this device's message " +
|
"this session which will re-encrypt this session's message " +
|
||||||
"history with a new recovery method.",
|
"history with a new recovery method.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<p className="warning">{_t(
|
<p className="warning">{_t(
|
||||||
|
|
|
@ -424,7 +424,7 @@ export default class CreateSecretStorageDialog extends React.PureComponent {
|
||||||
|
|
||||||
return <form onSubmit={this._onMigrateFormSubmit}>
|
return <form onSubmit={this._onMigrateFormSubmit}>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Upgrade this device to allow it to verify other devices, " +
|
"Upgrade this session to allow it to verify other sessions, " +
|
||||||
"granting them access to encrypted messages and marking them " +
|
"granting them access to encrypted messages and marking them " +
|
||||||
"as trusted for other users.",
|
"as trusted for other users.",
|
||||||
)}</p>
|
)}</p>
|
||||||
|
@ -471,7 +471,7 @@ export default class CreateSecretStorageDialog extends React.PureComponent {
|
||||||
|
|
||||||
return <div>
|
return <div>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Set up encryption on this device to allow it to verify other devices, " +
|
"Set up encryption on this session to allow it to verify other sessions, " +
|
||||||
"granting them access to encrypted messages and marking them as trusted for other users.",
|
"granting them access to encrypted messages and marking them as trusted for other users.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
|
@ -665,7 +665,7 @@ export default class CreateSecretStorageDialog extends React.PureComponent {
|
||||||
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
||||||
return <div>
|
return <div>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"This device can now verify other devices, granting them access " +
|
"This session can now verify other sessions, granting them access " +
|
||||||
"to encrypted messages and marking them as trusted for other users.",
|
"to encrypted messages and marking them as trusted for other users.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
|
@ -682,7 +682,7 @@ export default class CreateSecretStorageDialog extends React.PureComponent {
|
||||||
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
||||||
return <div>
|
return <div>
|
||||||
{_t(
|
{_t(
|
||||||
"Without completing security on this device, it won’t have " +
|
"Without completing security on this session, it won’t have " +
|
||||||
"access to encrypted messages.",
|
"access to encrypted messages.",
|
||||||
)}
|
)}
|
||||||
<DialogButtons primaryButton={_t('Go back')}
|
<DialogButtons primaryButton={_t('Go back')}
|
||||||
|
|
|
@ -220,12 +220,12 @@ export default createReactClass({
|
||||||
});
|
});
|
||||||
|
|
||||||
if (hasUDE) {
|
if (hasUDE) {
|
||||||
title = _t("Message not sent due to unknown devices being present");
|
title = _t("Message not sent due to unknown sessions being present");
|
||||||
content = _t(
|
content = _t(
|
||||||
"<showDevicesText>Show devices</showDevicesText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.",
|
"<showSessionsText>Show sessions</showSessionsText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.",
|
||||||
{},
|
{},
|
||||||
{
|
{
|
||||||
'showDevicesText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="resend" onClick={this._onShowDevicesClick}>{ sub }</a>,
|
'showSessionsText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="resend" onClick={this._onShowDevicesClick}>{ sub }</a>,
|
||||||
'sendAnywayText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="sendAnyway" onClick={this._onSendWithoutVerifyingClick}>{ sub }</a>,
|
'sendAnywayText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="sendAnyway" onClick={this._onSendWithoutVerifyingClick}>{ sub }</a>,
|
||||||
'cancelText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="cancel" onClick={this._onCancelAllClick}>{ sub }</a>,
|
'cancelText': (sub) => <a className="mx_RoomStatusBar_resend_link" key="cancel" onClick={this._onCancelAllClick}>{ sub }</a>,
|
||||||
},
|
},
|
||||||
|
|
|
@ -820,7 +820,7 @@ export default createReactClass({
|
||||||
this.setState({
|
this.setState({
|
||||||
e2eStatus: "warning",
|
e2eStatus: "warning",
|
||||||
});
|
});
|
||||||
debuglog("e2e status set to warning as not all users trust all of their devices." +
|
debuglog("e2e status set to warning as not all users trust all of their sessions." +
|
||||||
" Aborted on user", userId);
|
" Aborted on user", userId);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -197,7 +197,7 @@ export default class CompleteSecurity extends React.Component {
|
||||||
body = (
|
body = (
|
||||||
<div>
|
<div>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Without completing security on this device, it won’t have " +
|
"Without completing security on this session, it won’t have " +
|
||||||
"access to encrypted messages.",
|
"access to encrypted messages.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<div className="mx_CompleteSecurity_actionRow">
|
<div className="mx_CompleteSecurity_actionRow">
|
||||||
|
|
|
@ -152,8 +152,8 @@ export default createReactClass({
|
||||||
<div>
|
<div>
|
||||||
{ _t(
|
{ _t(
|
||||||
"Changing your password will reset any end-to-end encryption keys " +
|
"Changing your password will reset any end-to-end encryption keys " +
|
||||||
"on all of your devices, making encrypted chat history unreadable. Set up " +
|
"on all of your sessions, making encrypted chat history unreadable. Set up " +
|
||||||
"Key Backup or export your room keys from another device before resetting your " +
|
"Key Backup or export your room keys from another session before resetting your " +
|
||||||
"password.",
|
"password.",
|
||||||
) }
|
) }
|
||||||
</div>,
|
</div>,
|
||||||
|
@ -358,7 +358,7 @@ export default createReactClass({
|
||||||
return <div>
|
return <div>
|
||||||
<p>{_t("Your password has been reset.")}</p>
|
<p>{_t("Your password has been reset.")}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"You have been logged out of all devices and will no longer receive " +
|
"You have been logged out of all sessions and will no longer receive " +
|
||||||
"push notifications. To re-enable notifications, sign in again on each " +
|
"push notifications. To re-enable notifications, sign in again on each " +
|
||||||
"device.",
|
"device.",
|
||||||
)}</p>
|
)}</p>
|
||||||
|
|
|
@ -83,7 +83,7 @@ export default class SoftLogout extends React.Component {
|
||||||
onFinished: (wipeData) => {
|
onFinished: (wipeData) => {
|
||||||
if (!wipeData) return;
|
if (!wipeData) return;
|
||||||
|
|
||||||
console.log("Clearing data from soft-logged-out device");
|
console.log("Clearing data from soft-logged-out session");
|
||||||
Lifecycle.logout();
|
Lifecycle.logout();
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -212,8 +212,8 @@ export default class SoftLogout extends React.Component {
|
||||||
let introText = null; // null is translated to something area specific in this function
|
let introText = null; // null is translated to something area specific in this function
|
||||||
if (this.state.keyBackupNeeded) {
|
if (this.state.keyBackupNeeded) {
|
||||||
introText = _t(
|
introText = _t(
|
||||||
"Regain access to your account and recover encryption keys stored on this device. " +
|
"Regain access to your account and recover encryption keys stored in this session. " +
|
||||||
"Without them, you won’t be able to read all of your secure messages on any device.");
|
"Without them, you won’t be able to read all of your secure messages in any session.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.state.loginView === LOGIN_VIEW.PASSWORD) {
|
if (this.state.loginView === LOGIN_VIEW.PASSWORD) {
|
||||||
|
@ -306,7 +306,7 @@ export default class SoftLogout extends React.Component {
|
||||||
<p>
|
<p>
|
||||||
{_t(
|
{_t(
|
||||||
"Warning: Your personal data (including encryption keys) is still stored " +
|
"Warning: Your personal data (including encryption keys) is still stored " +
|
||||||
"on this device. Clear it if you're finished using this device, or want to sign " +
|
"in this session. Clear it if you're finished using this session, or want to sign " +
|
||||||
"in to another account.",
|
"in to another account.",
|
||||||
)}
|
)}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -39,11 +39,11 @@ export default class ConfirmWipeDeviceDialog extends React.Component {
|
||||||
return (
|
return (
|
||||||
<BaseDialog className='mx_ConfirmWipeDeviceDialog' hasCancel={true}
|
<BaseDialog className='mx_ConfirmWipeDeviceDialog' hasCancel={true}
|
||||||
onFinished={this.props.onFinished}
|
onFinished={this.props.onFinished}
|
||||||
title={_t("Clear all data on this device?")}>
|
title={_t("Clear all data in this session?")}>
|
||||||
<div className='mx_ConfirmWipeDeviceDialog_content'>
|
<div className='mx_ConfirmWipeDeviceDialog_content'>
|
||||||
<p>
|
<p>
|
||||||
{_t(
|
{_t(
|
||||||
"Clearing all data from this device is permanent. Encrypted messages will be lost " +
|
"Clearing all data from this session is permanent. Encrypted messages will be lost " +
|
||||||
"unless their keys have been backed up.",
|
"unless their keys have been backed up.",
|
||||||
)}
|
)}
|
||||||
</p>
|
</p>
|
||||||
|
|
|
@ -172,7 +172,7 @@ export default class DeviceVerifyDialog extends React.Component {
|
||||||
const BaseDialog = sdk.getComponent("dialogs.BaseDialog");
|
const BaseDialog = sdk.getComponent("dialogs.BaseDialog");
|
||||||
return (
|
return (
|
||||||
<BaseDialog
|
<BaseDialog
|
||||||
title={_t("Verify device")}
|
title={_t("Verify session")}
|
||||||
onFinished={this._onCancelClick}
|
onFinished={this._onCancelClick}
|
||||||
>
|
>
|
||||||
{body}
|
{body}
|
||||||
|
@ -262,12 +262,12 @@ export default class DeviceVerifyDialog extends React.Component {
|
||||||
|
|
||||||
let text;
|
let text;
|
||||||
if (MatrixClientPeg.get().getUserId() === this.props.userId) {
|
if (MatrixClientPeg.get().getUserId() === this.props.userId) {
|
||||||
text = _t("To verify that this device can be trusted, please check that the key you see " +
|
text = _t("To verify that this session can be trusted, please check that the key you see " +
|
||||||
"in User Settings on that device matches the key below:");
|
"in User Settings on that device matches the key below:");
|
||||||
} else {
|
} else {
|
||||||
text = _t("To verify that this device can be trusted, please contact its owner using some other " +
|
text = _t("To verify that this session can be trusted, please contact its owner using some other " +
|
||||||
"means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings " +
|
"means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings " +
|
||||||
"for this device matches the key below:");
|
"for this session matches the key below:");
|
||||||
}
|
}
|
||||||
|
|
||||||
const key = FormattingUtils.formatCryptoKey(this.props.device.getFingerprint());
|
const key = FormattingUtils.formatCryptoKey(this.props.device.getFingerprint());
|
||||||
|
@ -283,14 +283,14 @@ export default class DeviceVerifyDialog extends React.Component {
|
||||||
</p>
|
</p>
|
||||||
<div className="mx_DeviceVerifyDialog_cryptoSection">
|
<div className="mx_DeviceVerifyDialog_cryptoSection">
|
||||||
<ul>
|
<ul>
|
||||||
<li><label>{ _t("Device name") }:</label> <span>{ this.props.device.getDisplayName() }</span></li>
|
<li><label>{ _t("Session name") }:</label> <span>{ this.props.device.getDisplayName() }</span></li>
|
||||||
<li><label>{ _t("Device ID") }:</label> <span><code>{ this.props.device.deviceId }</code></span></li>
|
<li><label>{ _t("Session ID") }:</label> <span><code>{ this.props.device.deviceId }</code></span></li>
|
||||||
<li><label>{ _t("Device key") }:</label> <span><code><b>{ key }</b></code></span></li>
|
<li><label>{ _t("Session key") }:</label> <span><code><b>{ key }</b></code></span></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<p>
|
<p>
|
||||||
{ _t("If it matches, press the verify button below. " +
|
{ _t("If it matches, press the verify button below. " +
|
||||||
"If it doesn't, then someone else is intercepting this device " +
|
"If it doesn't, then someone else is intercepting this session " +
|
||||||
"and you probably want to press the blacklist button instead.") }
|
"and you probably want to press the blacklist button instead.") }
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
@ -298,7 +298,7 @@ export default class DeviceVerifyDialog extends React.Component {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<QuestionDialog
|
<QuestionDialog
|
||||||
title={_t("Verify device")}
|
title={_t("Verify session")}
|
||||||
description={body}
|
description={body}
|
||||||
button={_t("I verify that the keys match")}
|
button={_t("I verify that the keys match")}
|
||||||
onFinished={this._onLegacyFinished}
|
onFinished={this._onLegacyFinished}
|
||||||
|
|
|
@ -157,10 +157,10 @@ export default class IncomingSasDialog extends React.Component {
|
||||||
"end-to-end encrypted messages.",
|
"end-to-end encrypted messages.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
// NB. Below wording adjusted to singular 'device' until we have
|
// NB. Below wording adjusted to singular 'session' until we have
|
||||||
// cross-signing
|
// cross-signing
|
||||||
"Verifying this user will mark their device as trusted, and " +
|
"Verifying this user will mark their session as trusted, and " +
|
||||||
"also mark your device as trusted to them.",
|
"also mark your session as trusted to them.",
|
||||||
)}</p>
|
)}</p>
|
||||||
<DialogButtons
|
<DialogButtons
|
||||||
primaryButton={_t('Continue')}
|
primaryButton={_t('Continue')}
|
||||||
|
|
|
@ -60,7 +60,7 @@ export default createReactClass({
|
||||||
const deviceInfo = r[userId][deviceId];
|
const deviceInfo = r[userId][deviceId];
|
||||||
|
|
||||||
if (!deviceInfo) {
|
if (!deviceInfo) {
|
||||||
console.warn(`No details found for device ${userId}:${deviceId}`);
|
console.warn(`No details found for session ${userId}:${deviceId}`);
|
||||||
|
|
||||||
this.props.onFinished(false);
|
this.props.onFinished(false);
|
||||||
return;
|
return;
|
||||||
|
@ -121,10 +121,10 @@ export default createReactClass({
|
||||||
|
|
||||||
let text;
|
let text;
|
||||||
if (this.state.wasNewDevice) {
|
if (this.state.wasNewDevice) {
|
||||||
text = _td("You added a new device '%(displayName)s', which is"
|
text = _td("You added a new session '%(displayName)s', which is"
|
||||||
+ " requesting encryption keys.");
|
+ " requesting encryption keys.");
|
||||||
} else {
|
} else {
|
||||||
text = _td("Your unverified device '%(displayName)s' is requesting"
|
text = _td("Your unverified session '%(displayName)s' is requesting"
|
||||||
+ " encryption keys.");
|
+ " encryption keys.");
|
||||||
}
|
}
|
||||||
text = _t(text, {displayName: displayName});
|
text = _t(text, {displayName: displayName});
|
||||||
|
@ -159,7 +159,7 @@ export default createReactClass({
|
||||||
} else {
|
} else {
|
||||||
content = (
|
content = (
|
||||||
<div id='mx_Dialog_content'>
|
<div id='mx_Dialog_content'>
|
||||||
<p>{ _t('Loading device info...') }</p>
|
<p>{ _t('Loading session info...') }</p>
|
||||||
<Spinner />
|
<Spinner />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -138,7 +138,7 @@ export default class LogoutDialog extends React.Component {
|
||||||
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
const DialogButtons = sdk.getComponent('views.elements.DialogButtons');
|
||||||
let setupButtonCaption;
|
let setupButtonCaption;
|
||||||
if (this.state.backupInfo) {
|
if (this.state.backupInfo) {
|
||||||
setupButtonCaption = _t("Connect this device to Key Backup");
|
setupButtonCaption = _t("Connect this session to Key Backup");
|
||||||
} else {
|
} else {
|
||||||
// if there's an error fetching the backup info, we'll just assume there's
|
// if there's an error fetching the backup info, we'll just assume there's
|
||||||
// no backup for the purpose of the button caption
|
// no backup for the purpose of the button caption
|
||||||
|
|
|
@ -114,7 +114,7 @@ export default createReactClass({
|
||||||
>
|
>
|
||||||
<div className="mx_Dialog_content">
|
<div className="mx_Dialog_content">
|
||||||
<p>
|
<p>
|
||||||
{ _t('This will allow you to return to your account after signing out, and sign in on other devices.') }
|
{ _t('This will allow you to return to your account after signing out, and sign in on other sessions.') }
|
||||||
</p>
|
</p>
|
||||||
<ChangePassword
|
<ChangePassword
|
||||||
className="mx_SetPasswordDialog_change_password"
|
className="mx_SetPasswordDialog_change_password"
|
||||||
|
|
|
@ -132,8 +132,8 @@ export default createReactClass({
|
||||||
if (SettingsStore.getValue("blacklistUnverifiedDevices", this.props.room.roomId)) {
|
if (SettingsStore.getValue("blacklistUnverifiedDevices", this.props.room.roomId)) {
|
||||||
warning = (
|
warning = (
|
||||||
<h4>
|
<h4>
|
||||||
{ _t("You are currently blacklisting unverified devices; to send " +
|
{ _t("You are currently blacklisting unverified sessions; to send " +
|
||||||
"messages to these devices you must verify them.") }
|
"messages to these sessions you must verify them.") }
|
||||||
</h4>
|
</h4>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
@ -141,7 +141,7 @@ export default createReactClass({
|
||||||
<div>
|
<div>
|
||||||
<p>
|
<p>
|
||||||
{ _t("We recommend you go through the verification process " +
|
{ _t("We recommend you go through the verification process " +
|
||||||
"for each device to confirm they belong to their legitimate owner, " +
|
"for each session to confirm they belong to their legitimate owner, " +
|
||||||
"but you can resend the message without verifying if you prefer.") }
|
"but you can resend the message without verifying if you prefer.") }
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
@ -165,15 +165,15 @@ export default createReactClass({
|
||||||
return (
|
return (
|
||||||
<BaseDialog className='mx_UnknownDeviceDialog'
|
<BaseDialog className='mx_UnknownDeviceDialog'
|
||||||
onFinished={this.props.onFinished}
|
onFinished={this.props.onFinished}
|
||||||
title={_t('Room contains unknown devices')}
|
title={_t('Room contains unknown sessions')}
|
||||||
contentId='mx_Dialog_content'
|
contentId='mx_Dialog_content'
|
||||||
>
|
>
|
||||||
<GeminiScrollbarWrapper autoshow={false} className="mx_Dialog_content" id='mx_Dialog_content'>
|
<GeminiScrollbarWrapper autoshow={false} className="mx_Dialog_content" id='mx_Dialog_content'>
|
||||||
<h4>
|
<h4>
|
||||||
{ _t('"%(RoomName)s" contains devices that you haven\'t seen before.', {RoomName: this.props.room.name}) }
|
{ _t('"%(RoomName)s" contains sessions that you haven\'t seen before.', {RoomName: this.props.room.name}) }
|
||||||
</h4>
|
</h4>
|
||||||
{ warning }
|
{ warning }
|
||||||
{ _t("Unknown devices") }:
|
{ _t("Unknown sessions") }:
|
||||||
|
|
||||||
<UnknownDeviceList devices={this.props.devices} />
|
<UnknownDeviceList devices={this.props.devices} />
|
||||||
</GeminiScrollbarWrapper>
|
</GeminiScrollbarWrapper>
|
||||||
|
|
|
@ -146,7 +146,7 @@ export default class AccessSecretStorageDialog extends React.PureComponent {
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Access your secure message history and your cross-signing " +
|
"Access your secure message history and your cross-signing " +
|
||||||
"identity for verifying other devices by entering your passphrase.",
|
"identity for verifying other sessions by entering your passphrase.",
|
||||||
)}</p>
|
)}</p>
|
||||||
|
|
||||||
<div className="mx_AccessSecretStorageDialog_primaryContainer">
|
<div className="mx_AccessSecretStorageDialog_primaryContainer">
|
||||||
|
@ -218,7 +218,7 @@ export default class AccessSecretStorageDialog extends React.PureComponent {
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Access your secure message history and your cross-signing " +
|
"Access your secure message history and your cross-signing " +
|
||||||
"identity for verifying other devices by entering your recovery key.",
|
"identity for verifying other sessions by entering your recovery key.",
|
||||||
)}</p>
|
)}</p>
|
||||||
|
|
||||||
<div className="mx_AccessSecretStorageDialog_primaryContainer">
|
<div className="mx_AccessSecretStorageDialog_primaryContainer">
|
||||||
|
|
|
@ -50,7 +50,7 @@ const EncryptionPanel = ({verificationRequest, member, onClose}) => {
|
||||||
<li>{_t("Your homeserver")}</li>
|
<li>{_t("Your homeserver")}</li>
|
||||||
<li>{_t("The homeserver the user you’re verifying is connected to")}</li>
|
<li>{_t("The homeserver the user you’re verifying is connected to")}</li>
|
||||||
<li>{_t("Yours, or the other users’ internet connection")}</li>
|
<li>{_t("Yours, or the other users’ internet connection")}</li>
|
||||||
<li>{_t("Yours, or the other users’ device")}</li>
|
<li>{_t("Yours, or the other users’ session")}</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>,
|
</div>,
|
||||||
onFinished: onClose,
|
onFinished: onClose,
|
||||||
|
|
|
@ -208,7 +208,7 @@ function DevicesSection({devices, userId, loading}) {
|
||||||
return <Spinner />;
|
return <Spinner />;
|
||||||
}
|
}
|
||||||
if (devices === null) {
|
if (devices === null) {
|
||||||
return _t("Unable to load device list");
|
return _t("Unable to load session list");
|
||||||
}
|
}
|
||||||
const isMe = userId === cli.getUserId();
|
const isMe = userId === cli.getUserId();
|
||||||
const deviceTrusts = devices.map(d => cli.checkDeviceTrust(userId, d.deviceId));
|
const deviceTrusts = devices.map(d => cli.checkDeviceTrust(userId, d.deviceId));
|
||||||
|
|
|
@ -32,23 +32,23 @@ export const E2E_STATE = {
|
||||||
};
|
};
|
||||||
|
|
||||||
const crossSigningUserTitles = {
|
const crossSigningUserTitles = {
|
||||||
[E2E_STATE.WARNING]: _td("This user has not verified all of their devices."),
|
[E2E_STATE.WARNING]: _td("This user has not verified all of their sessions."),
|
||||||
[E2E_STATE.NORMAL]: _td("You have not verified this user. This user has verified all of their devices."),
|
[E2E_STATE.NORMAL]: _td("You have not verified this user. This user has verified all of their sessions."),
|
||||||
[E2E_STATE.VERIFIED]: _td("You have verified this user. This user has verified all of their devices."),
|
[E2E_STATE.VERIFIED]: _td("You have verified this user. This user has verified all of their sessions."),
|
||||||
};
|
};
|
||||||
const crossSigningRoomTitles = {
|
const crossSigningRoomTitles = {
|
||||||
[E2E_STATE.WARNING]: _td("Someone is using an unknown device"),
|
[E2E_STATE.WARNING]: _td("Someone is using an unknown session"),
|
||||||
[E2E_STATE.NORMAL]: _td("This room is end-to-end encrypted"),
|
[E2E_STATE.NORMAL]: _td("This room is end-to-end encrypted"),
|
||||||
[E2E_STATE.VERIFIED]: _td("Everyone in this room is verified"),
|
[E2E_STATE.VERIFIED]: _td("Everyone in this room is verified"),
|
||||||
};
|
};
|
||||||
|
|
||||||
const legacyUserTitles = {
|
const legacyUserTitles = {
|
||||||
[E2E_STATE.WARNING]: _td("Some devices for this user are not trusted"),
|
[E2E_STATE.WARNING]: _td("Some sessions for this user are not trusted"),
|
||||||
[E2E_STATE.VERIFIED]: _td("All devices for this user are trusted"),
|
[E2E_STATE.VERIFIED]: _td("All sessions for this user are trusted"),
|
||||||
};
|
};
|
||||||
const legacyRoomTitles = {
|
const legacyRoomTitles = {
|
||||||
[E2E_STATE.WARNING]: _td("Some devices in this encrypted room are not trusted"),
|
[E2E_STATE.WARNING]: _td("Some sessions in this encrypted room are not trusted"),
|
||||||
[E2E_STATE.VERIFIED]: _td("All devices in this encrypted room are trusted"),
|
[E2E_STATE.VERIFIED]: _td("All sessions in this encrypted room are trusted"),
|
||||||
};
|
};
|
||||||
|
|
||||||
const E2EIcon = ({isUser, status, className, size, onClick}) => {
|
const E2EIcon = ({isUser, status, className, size, onClick}) => {
|
||||||
|
|
|
@ -733,15 +733,15 @@ export default createReactClass({
|
||||||
<div className="mx_EventTile_keyRequestInfo_tooltip_contents">
|
<div className="mx_EventTile_keyRequestInfo_tooltip_contents">
|
||||||
<p>
|
<p>
|
||||||
{ this.state.previouslyRequestedKeys ?
|
{ this.state.previouslyRequestedKeys ?
|
||||||
_t( 'Your key share request has been sent - please check your other devices ' +
|
_t( 'Your key share request has been sent - please check your other sessions ' +
|
||||||
'for key share requests.') :
|
'for key share requests.') :
|
||||||
_t( 'Key share requests are sent to your other devices automatically. If you ' +
|
_t( 'Key share requests are sent to your other sessions automatically. If you ' +
|
||||||
'rejected or dismissed the key share request on your other devices, click ' +
|
'rejected or dismissed the key share request on your other sessions, click ' +
|
||||||
'here to request the keys for this session again.')
|
'here to request the keys for this session again.')
|
||||||
}
|
}
|
||||||
</p>
|
</p>
|
||||||
<p>
|
<p>
|
||||||
{ _t( 'If your other devices do not have the key for this message you will not ' +
|
{ _t( 'If your other sessions do not have the key for this message you will not ' +
|
||||||
'be able to decrypt them.')
|
'be able to decrypt them.')
|
||||||
}
|
}
|
||||||
</p>
|
</p>
|
||||||
|
@ -749,7 +749,7 @@ export default createReactClass({
|
||||||
const keyRequestInfoContent = this.state.previouslyRequestedKeys ?
|
const keyRequestInfoContent = this.state.previouslyRequestedKeys ?
|
||||||
_t('Key request sent.') :
|
_t('Key request sent.') :
|
||||||
_t(
|
_t(
|
||||||
'<requestLink>Re-request encryption keys</requestLink> from your other devices.',
|
'<requestLink>Re-request encryption keys</requestLink> from your other sessions.',
|
||||||
{},
|
{},
|
||||||
{'requestLink': (sub) => <a onClick={this.onRequestKeysClick}>{ sub }</a>},
|
{'requestLink': (sub) => <a onClick={this.onRequestKeysClick}>{ sub }</a>},
|
||||||
);
|
);
|
||||||
|
@ -938,7 +938,7 @@ function E2ePadlockUndecryptable(props) {
|
||||||
|
|
||||||
function E2ePadlockUnverified(props) {
|
function E2ePadlockUnverified(props) {
|
||||||
return (
|
return (
|
||||||
<E2ePadlock title={_t("Encrypted by an unverified device")} icon="unverified" {...props} />
|
<E2ePadlock title={_t("Encrypted by an unverified session")} icon="unverified" {...props} />
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -950,7 +950,7 @@ function E2ePadlockUnencrypted(props) {
|
||||||
|
|
||||||
function E2ePadlockUnknown(props) {
|
function E2ePadlockUnknown(props) {
|
||||||
return (
|
return (
|
||||||
<E2ePadlock title={_t("Encrypted by a deleted device")} icon="unknown" {...props} />
|
<E2ePadlock title={_t("Encrypted by a deleted session")} icon="unknown" {...props} />
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -260,7 +260,7 @@ export default createReactClass({
|
||||||
e2eStatus: self._getE2EStatus(devices),
|
e2eStatus: self._getE2EStatus(devices),
|
||||||
});
|
});
|
||||||
}, function(err) {
|
}, function(err) {
|
||||||
console.log("Error downloading devices", err);
|
console.log("Error downloading sessions", err);
|
||||||
self.setState({devicesLoading: false});
|
self.setState({devicesLoading: false});
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
@ -766,9 +766,9 @@ export default createReactClass({
|
||||||
// still loading
|
// still loading
|
||||||
devComponents = <Spinner />;
|
devComponents = <Spinner />;
|
||||||
} else if (devices === null) {
|
} else if (devices === null) {
|
||||||
devComponents = _t("Unable to load device list");
|
devComponents = _t("Unable to load session list");
|
||||||
} else if (devices.length === 0) {
|
} else if (devices.length === 0) {
|
||||||
devComponents = _t("No devices with registered encryption keys");
|
devComponents = _t("No sessions with registered encryption keys");
|
||||||
} else {
|
} else {
|
||||||
devComponents = [];
|
devComponents = [];
|
||||||
for (let i = 0; i < devices.length; i++) {
|
for (let i = 0; i < devices.length; i++) {
|
||||||
|
@ -780,7 +780,7 @@ export default createReactClass({
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<h3>{ _t("Devices") }</h3>
|
<h3>{ _t("Sessions") }</h3>
|
||||||
<div className="mx_MemberInfo_devices">
|
<div className="mx_MemberInfo_devices">
|
||||||
{ devComponents }
|
{ devComponents }
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -124,7 +124,7 @@ export default class RoomRecoveryReminder extends React.PureComponent {
|
||||||
|
|
||||||
let setupCaption;
|
let setupCaption;
|
||||||
if (this.state.backupInfo) {
|
if (this.state.backupInfo) {
|
||||||
setupCaption = _t("Connect this device to Key Backup");
|
setupCaption = _t("Connect this session to Key Backup");
|
||||||
} else {
|
} else {
|
||||||
setupCaption = _t("Start using Key Backup");
|
setupCaption = _t("Start using Key Backup");
|
||||||
}
|
}
|
||||||
|
|
|
@ -113,7 +113,7 @@ export default createReactClass({
|
||||||
description:
|
description:
|
||||||
<div>
|
<div>
|
||||||
{ _t(
|
{ _t(
|
||||||
'Changing password will currently reset any end-to-end encryption keys on all devices, ' +
|
'Changing password will currently reset any end-to-end encryption keys on all sessions, ' +
|
||||||
'making encrypted chat history unreadable, unless you first export your room keys ' +
|
'making encrypted chat history unreadable, unless you first export your room keys ' +
|
||||||
'and re-import them afterwards. ' +
|
'and re-import them afterwards. ' +
|
||||||
'In future this will be improved.',
|
'In future this will be improved.',
|
||||||
|
|
|
@ -127,7 +127,7 @@ export default class CrossSigningPanel extends React.PureComponent {
|
||||||
} else if (crossSigningPrivateKeysInStorage) {
|
} else if (crossSigningPrivateKeysInStorage) {
|
||||||
summarisedStatus = <p>{_t(
|
summarisedStatus = <p>{_t(
|
||||||
"Your account has a cross-signing identity in secret storage, but it " +
|
"Your account has a cross-signing identity in secret storage, but it " +
|
||||||
"is not yet trusted by this device.",
|
"is not yet trusted by this session.",
|
||||||
)}</p>;
|
)}</p>;
|
||||||
} else {
|
} else {
|
||||||
summarisedStatus = <p>{_t(
|
summarisedStatus = <p>{_t(
|
||||||
|
@ -152,7 +152,7 @@ export default class CrossSigningPanel extends React.PureComponent {
|
||||||
<table className="mx_CrossSigningPanel_statusList"><tbody>
|
<table className="mx_CrossSigningPanel_statusList"><tbody>
|
||||||
<tr>
|
<tr>
|
||||||
<td>{_t("Cross-signing public keys:")}</td>
|
<td>{_t("Cross-signing public keys:")}</td>
|
||||||
<td>{crossSigningPublicKeysOnDevice ? _t("on device") : _t("not found")}</td>
|
<td>{crossSigningPublicKeysOnDevice ? _t("in memory") : _t("not found")}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>{_t("Cross-signing private keys:")}</td>
|
<td>{_t("Cross-signing private keys:")}</td>
|
||||||
|
|
|
@ -62,10 +62,10 @@ export default class DevicesPanel extends React.Component {
|
||||||
let errtxt;
|
let errtxt;
|
||||||
if (error.httpStatus == 404) {
|
if (error.httpStatus == 404) {
|
||||||
// 404 probably means the HS doesn't yet support the API.
|
// 404 probably means the HS doesn't yet support the API.
|
||||||
errtxt = _t("Your homeserver does not support device management.");
|
errtxt = _t("Your homeserver does not support session management.");
|
||||||
} else {
|
} else {
|
||||||
console.error("Error loading devices:", error);
|
console.error("Error loading sessions:", error);
|
||||||
errtxt = _t("Unable to load device list");
|
errtxt = _t("Unable to load session list");
|
||||||
}
|
}
|
||||||
this.setState({deviceLoadError: errtxt});
|
this.setState({deviceLoadError: errtxt});
|
||||||
},
|
},
|
||||||
|
@ -130,7 +130,7 @@ export default class DevicesPanel extends React.Component {
|
||||||
makeRequest: this._makeDeleteRequest.bind(this),
|
makeRequest: this._makeDeleteRequest.bind(this),
|
||||||
});
|
});
|
||||||
}).catch((e) => {
|
}).catch((e) => {
|
||||||
console.error("Error deleting devices", e);
|
console.error("Error deleting sessions", e);
|
||||||
if (this._unmounted) { return; }
|
if (this._unmounted) { return; }
|
||||||
}).finally(() => {
|
}).finally(() => {
|
||||||
this.setState({
|
this.setState({
|
||||||
|
@ -188,7 +188,7 @@ export default class DevicesPanel extends React.Component {
|
||||||
const deleteButton = this.state.deleting ?
|
const deleteButton = this.state.deleting ?
|
||||||
<Spinner w={22} h={22} /> :
|
<Spinner w={22} h={22} /> :
|
||||||
<AccessibleButton onClick={this._onDeleteClick} kind="danger_sm">
|
<AccessibleButton onClick={this._onDeleteClick} kind="danger_sm">
|
||||||
{ _t("Delete %(count)s devices", {count: this.state.selectedDevices.length}) }
|
{ _t("Delete %(count)s sessions", {count: this.state.selectedDevices.length}) }
|
||||||
</AccessibleButton>;
|
</AccessibleButton>;
|
||||||
|
|
||||||
const classes = classNames(this.props.className, "mx_DevicesPanel");
|
const classes = classNames(this.props.className, "mx_DevicesPanel");
|
||||||
|
|
|
@ -40,7 +40,7 @@ export default class DevicesPanelEntry extends React.Component {
|
||||||
return MatrixClientPeg.get().setDeviceDetails(device.device_id, {
|
return MatrixClientPeg.get().setDeviceDetails(device.device_id, {
|
||||||
display_name: value,
|
display_name: value,
|
||||||
}).catch((e) => {
|
}).catch((e) => {
|
||||||
console.error("Error setting device display name", e);
|
console.error("Error setting session display name", e);
|
||||||
throw new Error(_t("Failed to set display name"));
|
throw new Error(_t("Failed to set display name"));
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -186,23 +186,23 @@ export default class KeyBackupPanel extends React.PureComponent {
|
||||||
if (MatrixClientPeg.get().getKeyBackupEnabled()) {
|
if (MatrixClientPeg.get().getKeyBackupEnabled()) {
|
||||||
clientBackupStatus = <div>
|
clientBackupStatus = <div>
|
||||||
<p>{encryptedMessageAreEncrypted}</p>
|
<p>{encryptedMessageAreEncrypted}</p>
|
||||||
<p>✅ {_t("This device is backing up your keys. ")}</p>
|
<p>✅ {_t("This session is backing up your keys. ")}</p>
|
||||||
</div>;
|
</div>;
|
||||||
} else {
|
} else {
|
||||||
clientBackupStatus = <div>
|
clientBackupStatus = <div>
|
||||||
<p>{encryptedMessageAreEncrypted}</p>
|
<p>{encryptedMessageAreEncrypted}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"This device is <b>not backing up your keys</b>, " +
|
"This session is <b>not backing up your keys</b>, " +
|
||||||
"but you do have an existing backup you can restore from " +
|
"but you do have an existing backup you can restore from " +
|
||||||
"and add to going forward.", {},
|
"and add to going forward.", {},
|
||||||
{b: sub => <b>{sub}</b>},
|
{b: sub => <b>{sub}</b>},
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Connect this device to key backup before signing out to avoid " +
|
"Connect this session to key backup before signing out to avoid " +
|
||||||
"losing any keys that may only be on this device.",
|
"losing any keys that may only be on this session.",
|
||||||
)}</p>
|
)}</p>
|
||||||
</div>;
|
</div>;
|
||||||
restoreButtonCaption = _t("Connect this device to Key Backup");
|
restoreButtonCaption = _t("Connect this session to Key Backup");
|
||||||
}
|
}
|
||||||
|
|
||||||
let keyStatus;
|
let keyStatus;
|
||||||
|
@ -264,42 +264,42 @@ export default class KeyBackupPanel extends React.PureComponent {
|
||||||
);
|
);
|
||||||
} else if (!sig.device) {
|
} else if (!sig.device) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has a signature from <verify>unknown</verify> device with ID %(deviceId)s",
|
"Backup has a signature from <verify>unknown</verify> session with ID %(deviceId)s",
|
||||||
{ deviceId: sig.deviceId }, { verify },
|
{ deviceId: sig.deviceId }, { verify },
|
||||||
);
|
);
|
||||||
} else if (sig.valid && fromThisDevice) {
|
} else if (sig.valid && fromThisDevice) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has a <validity>valid</validity> signature from this device",
|
"Backup has a <validity>valid</validity> signature from this session",
|
||||||
{}, { validity },
|
{}, { validity },
|
||||||
);
|
);
|
||||||
} else if (!sig.valid && fromThisDevice) {
|
} else if (!sig.valid && fromThisDevice) {
|
||||||
// it can happen...
|
// it can happen...
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has an <validity>invalid</validity> signature from this device",
|
"Backup has an <validity>invalid</validity> signature from this session",
|
||||||
{}, { validity },
|
{}, { validity },
|
||||||
);
|
);
|
||||||
} else if (sig.valid && sig.device.isVerified()) {
|
} else if (sig.valid && sig.device.isVerified()) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has a <validity>valid</validity> signature from " +
|
"Backup has a <validity>valid</validity> signature from " +
|
||||||
"<verify>verified</verify> device <device></device>",
|
"<verify>verified</verify> session <device></device>",
|
||||||
{}, { validity, verify, device },
|
{}, { validity, verify, device },
|
||||||
);
|
);
|
||||||
} else if (sig.valid && !sig.device.isVerified()) {
|
} else if (sig.valid && !sig.device.isVerified()) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has a <validity>valid</validity> signature from " +
|
"Backup has a <validity>valid</validity> signature from " +
|
||||||
"<verify>unverified</verify> device <device></device>",
|
"<verify>unverified</verify> session <device></device>",
|
||||||
{}, { validity, verify, device },
|
{}, { validity, verify, device },
|
||||||
);
|
);
|
||||||
} else if (!sig.valid && sig.device.isVerified()) {
|
} else if (!sig.valid && sig.device.isVerified()) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has an <validity>invalid</validity> signature from " +
|
"Backup has an <validity>invalid</validity> signature from " +
|
||||||
"<verify>verified</verify> device <device></device>",
|
"<verify>verified</verify> session <device></device>",
|
||||||
{}, { validity, verify, device },
|
{}, { validity, verify, device },
|
||||||
);
|
);
|
||||||
} else if (!sig.valid && !sig.device.isVerified()) {
|
} else if (!sig.valid && !sig.device.isVerified()) {
|
||||||
sigStatus = _t(
|
sigStatus = _t(
|
||||||
"Backup has an <validity>invalid</validity> signature from " +
|
"Backup has an <validity>invalid</validity> signature from " +
|
||||||
"<verify>unverified</verify> device <device></device>",
|
"<verify>unverified</verify> session <device></device>",
|
||||||
{}, { validity, verify, device },
|
{}, { validity, verify, device },
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -309,12 +309,12 @@ export default class KeyBackupPanel extends React.PureComponent {
|
||||||
</div>;
|
</div>;
|
||||||
});
|
});
|
||||||
if (this.state.backupSigStatus.sigs.length === 0) {
|
if (this.state.backupSigStatus.sigs.length === 0) {
|
||||||
backupSigStatuses = _t("Backup is not signed by any of your devices");
|
backupSigStatuses = _t("Backup is not signed by any of your sessions");
|
||||||
}
|
}
|
||||||
|
|
||||||
let trustedLocally;
|
let trustedLocally;
|
||||||
if (this.state.backupSigStatus.trusted_locally) {
|
if (this.state.backupSigStatus.trusted_locally) {
|
||||||
trustedLocally = _t("This backup is trusted because it has been restored on this device");
|
trustedLocally = _t("This backup is trusted because it has been restored on this session");
|
||||||
}
|
}
|
||||||
|
|
||||||
let buttonRow = (
|
let buttonRow = (
|
||||||
|
@ -330,7 +330,7 @@ export default class KeyBackupPanel extends React.PureComponent {
|
||||||
if (this.state.backupKeyStored && !SettingsStore.isFeatureEnabled("feature_cross_signing")) {
|
if (this.state.backupKeyStored && !SettingsStore.isFeatureEnabled("feature_cross_signing")) {
|
||||||
buttonRow = <p>⚠️ {_t(
|
buttonRow = <p>⚠️ {_t(
|
||||||
"Backup key stored in secret storage, but this feature is not " +
|
"Backup key stored in secret storage, but this feature is not " +
|
||||||
"enabled on this device. Please enable cross-signing in Labs to " +
|
"enabled on this session. Please enable cross-signing in Labs to " +
|
||||||
"modify key backup state.",
|
"modify key backup state.",
|
||||||
)}</p>;
|
)}</p>;
|
||||||
}
|
}
|
||||||
|
@ -352,7 +352,7 @@ export default class KeyBackupPanel extends React.PureComponent {
|
||||||
return <div>
|
return <div>
|
||||||
<div>
|
<div>
|
||||||
<p>{_t(
|
<p>{_t(
|
||||||
"Your keys are <b>not being backed up from this device</b>.", {},
|
"Your keys are <b>not being backed up from this session</b>.", {},
|
||||||
{b: sub => <b>{sub}</b>},
|
{b: sub => <b>{sub}</b>},
|
||||||
)}</p>
|
)}</p>
|
||||||
<p>{encryptedMessageAreEncrypted}</p>
|
<p>{encryptedMessageAreEncrypted}</p>
|
||||||
|
|
|
@ -864,7 +864,7 @@ export default createReactClass({
|
||||||
|
|
||||||
<LabelledToggleSwitch value={SettingsStore.getValue("notificationsEnabled")}
|
<LabelledToggleSwitch value={SettingsStore.getValue("notificationsEnabled")}
|
||||||
onChange={this.onEnableDesktopNotificationsChange}
|
onChange={this.onEnableDesktopNotificationsChange}
|
||||||
label={_t('Enable desktop notifications for this device')} />
|
label={_t('Enable desktop notifications for this session')} />
|
||||||
|
|
||||||
<LabelledToggleSwitch value={SettingsStore.getValue("notificationBodyEnabled")}
|
<LabelledToggleSwitch value={SettingsStore.getValue("notificationBodyEnabled")}
|
||||||
onChange={this.onEnableDesktopNotificationBodyChange}
|
onChange={this.onEnableDesktopNotificationBodyChange}
|
||||||
|
@ -872,7 +872,7 @@ export default createReactClass({
|
||||||
|
|
||||||
<LabelledToggleSwitch value={SettingsStore.getValue("audioNotificationsEnabled")}
|
<LabelledToggleSwitch value={SettingsStore.getValue("audioNotificationsEnabled")}
|
||||||
onChange={this.onEnableAudioNotificationsChange}
|
onChange={this.onEnableAudioNotificationsChange}
|
||||||
label={_t('Enable audible notifications for this device')} />
|
label={_t('Enable audible notifications for this session')} />
|
||||||
|
|
||||||
{ emailNotificationsRows }
|
{ emailNotificationsRows }
|
||||||
|
|
||||||
|
|
|
@ -261,7 +261,7 @@ export default class GeneralUserSettingsTab extends React.Component {
|
||||||
title: _t("Success"),
|
title: _t("Success"),
|
||||||
description: _t(
|
description: _t(
|
||||||
"Your password was successfully changed. You will not receive " +
|
"Your password was successfully changed. You will not receive " +
|
||||||
"push notifications on other devices until you log back in to them",
|
"push notifications on other sessions until you log back in to them",
|
||||||
) + ".",
|
) + ".",
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
|
@ -185,11 +185,11 @@ export default class SecurityUserSettingsTab extends React.Component {
|
||||||
<span className='mx_SettingsTab_subheading'>{_t("Cryptography")}</span>
|
<span className='mx_SettingsTab_subheading'>{_t("Cryptography")}</span>
|
||||||
<ul className='mx_SettingsTab_subsectionText mx_SecurityUserSettingsTab_deviceInfo'>
|
<ul className='mx_SettingsTab_subsectionText mx_SecurityUserSettingsTab_deviceInfo'>
|
||||||
<li>
|
<li>
|
||||||
<label>{_t("Device ID:")}</label>
|
<label>{_t("Session ID:")}</label>
|
||||||
<span><code>{deviceId}</code></span>
|
<span><code>{deviceId}</code></span>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<label>{_t("Device key:")}</label>
|
<label>{_t("Session key:")}</label>
|
||||||
<span><code><b>{identityKey}</b></code></span>
|
<span><code><b>{identityKey}</b></code></span>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -285,9 +285,9 @@ export default class SecurityUserSettingsTab extends React.Component {
|
||||||
<div className="mx_SettingsTab mx_SecurityUserSettingsTab">
|
<div className="mx_SettingsTab mx_SecurityUserSettingsTab">
|
||||||
<div className="mx_SettingsTab_heading">{_t("Security & Privacy")}</div>
|
<div className="mx_SettingsTab_heading">{_t("Security & Privacy")}</div>
|
||||||
<div className="mx_SettingsTab_section">
|
<div className="mx_SettingsTab_section">
|
||||||
<span className="mx_SettingsTab_subheading">{_t("Devices")}</span>
|
<span className="mx_SettingsTab_subheading">{_t("Sessions")}</span>
|
||||||
<div className='mx_SettingsTab_subsectionText'>
|
<div className='mx_SettingsTab_subsectionText'>
|
||||||
{_t("A device's public name is visible to people you communicate with")}
|
{_t("A session's public name is visible to people you communicate with")}
|
||||||
<DevicesPanel />
|
<DevicesPanel />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -39,7 +39,7 @@ export default class SetupEncryptionToast extends React.PureComponent {
|
||||||
switch (this.props.kind) {
|
switch (this.props.kind) {
|
||||||
case 'set_up_encryption':
|
case 'set_up_encryption':
|
||||||
case 'upgrade_encryption':
|
case 'upgrade_encryption':
|
||||||
return _t('Verify your other devices easier');
|
return _t('Verify your other sessions easier');
|
||||||
case 'verify_this_session':
|
case 'verify_this_session':
|
||||||
return _t('Other users may not trust it');
|
return _t('Other users may not trust it');
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
"Unable to load! Check your network connectivity and try again.": "Unable to load! Check your network connectivity and try again.",
|
"Unable to load! Check your network connectivity and try again.": "Unable to load! Check your network connectivity and try again.",
|
||||||
"Dismiss": "Dismiss",
|
"Dismiss": "Dismiss",
|
||||||
"Call Failed": "Call Failed",
|
"Call Failed": "Call Failed",
|
||||||
"There are unknown devices in this room: if you proceed without verifying them, it will be possible for someone to eavesdrop on your call.": "There are unknown devices in this room: if you proceed without verifying them, it will be possible for someone to eavesdrop on your call.",
|
"There are unknown sessions in this room: if you proceed without verifying them, it will be possible for someone to eavesdrop on your call.": "There are unknown sessions in this room: if you proceed without verifying them, it will be possible for someone to eavesdrop on your call.",
|
||||||
"Review Devices": "Review Devices",
|
"Review Devices": "Review Devices",
|
||||||
"Call Anyway": "Call Anyway",
|
"Call Anyway": "Call Anyway",
|
||||||
"Answer Anyway": "Answer Anyway",
|
"Answer Anyway": "Answer Anyway",
|
||||||
|
@ -184,13 +184,13 @@
|
||||||
"Adds a custom widget by URL to the room": "Adds a custom widget by URL to the room",
|
"Adds a custom widget by URL to the room": "Adds a custom widget by URL to the room",
|
||||||
"Please supply a https:// or http:// widget URL": "Please supply a https:// or http:// widget URL",
|
"Please supply a https:// or http:// widget URL": "Please supply a https:// or http:// widget URL",
|
||||||
"You cannot modify widgets in this room.": "You cannot modify widgets in this room.",
|
"You cannot modify widgets in this room.": "You cannot modify widgets in this room.",
|
||||||
"Verifies a user, device, and pubkey tuple": "Verifies a user, device, and pubkey tuple",
|
"Verifies a user, session, and pubkey tuple": "Verifies a user, session, and pubkey tuple",
|
||||||
"Unknown (user, device) pair:": "Unknown (user, device) pair:",
|
"Unknown (user, session) pair:": "Unknown (user, session) pair:",
|
||||||
"Device already verified!": "Device already verified!",
|
"Session already verified!": "Session already verified!",
|
||||||
"WARNING: Device already verified, but keys do NOT MATCH!": "WARNING: Device already verified, but keys do NOT MATCH!",
|
"WARNING: Session already verified, but keys do NOT MATCH!": "WARNING: Session already verified, but keys do NOT MATCH!",
|
||||||
"WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and device %(deviceId)s is \"%(fprint)s\" which does not match the provided key \"%(fingerprint)s\". This could mean your communications are being intercepted!": "WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and device %(deviceId)s is \"%(fprint)s\" which does not match the provided key \"%(fingerprint)s\". This could mean your communications are being intercepted!",
|
"WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and session %(deviceId)s is \"%(fprint)s\" which does not match the provided key \"%(fingerprint)s\". This could mean your communications are being intercepted!": "WARNING: KEY VERIFICATION FAILED! The signing key for %(userId)s and session %(deviceId)s is \"%(fprint)s\" which does not match the provided key \"%(fingerprint)s\". This could mean your communications are being intercepted!",
|
||||||
"Verified key": "Verified key",
|
"Verified key": "Verified key",
|
||||||
"The signing key you provided matches the signing key you received from %(userId)s's device %(deviceId)s. Device marked as verified.": "The signing key you provided matches the signing key you received from %(userId)s's device %(deviceId)s. Device marked as verified.",
|
"The signing key you provided matches the signing key you received from %(userId)s's session %(deviceId)s. Session marked as verified.": "The signing key you provided matches the signing key you received from %(userId)s's session %(deviceId)s. Session marked as verified.",
|
||||||
"Displays action": "Displays action",
|
"Displays action": "Displays action",
|
||||||
"Forces the current outbound group session in an encrypted room to be discarded": "Forces the current outbound group session in an encrypted room to be discarded",
|
"Forces the current outbound group session in an encrypted room to be discarded": "Forces the current outbound group session in an encrypted room to be discarded",
|
||||||
"Sends the given message coloured as a rainbow": "Sends the given message coloured as a rainbow",
|
"Sends the given message coloured as a rainbow": "Sends the given message coloured as a rainbow",
|
||||||
|
@ -373,7 +373,7 @@
|
||||||
"Multiple integration managers": "Multiple integration managers",
|
"Multiple integration managers": "Multiple integration managers",
|
||||||
"Try out new ways to ignore people (experimental)": "Try out new ways to ignore people (experimental)",
|
"Try out new ways to ignore people (experimental)": "Try out new ways to ignore people (experimental)",
|
||||||
"Show a presence dot next to DMs in the room list": "Show a presence dot next to DMs in the room list",
|
"Show a presence dot next to DMs in the room list": "Show a presence dot next to DMs in the room list",
|
||||||
"Enable cross-signing to verify per-user instead of per-device (in development)": "Enable cross-signing to verify per-user instead of per-device (in development)",
|
"Enable cross-signing to verify per-user instead of per-session (in development)": "Enable cross-signing to verify per-user instead of per-session (in development)",
|
||||||
"Enable local event indexing and E2EE search (requires restart)": "Enable local event indexing and E2EE search (requires restart)",
|
"Enable local event indexing and E2EE search (requires restart)": "Enable local event indexing and E2EE search (requires restart)",
|
||||||
"Show info about bridges in room settings": "Show info about bridges in room settings",
|
"Show info about bridges in room settings": "Show info about bridges in room settings",
|
||||||
"Enable Emoji suggestions while typing": "Enable Emoji suggestions while typing",
|
"Enable Emoji suggestions while typing": "Enable Emoji suggestions while typing",
|
||||||
|
@ -398,8 +398,8 @@
|
||||||
"Match system theme": "Match system theme",
|
"Match system theme": "Match system theme",
|
||||||
"Allow Peer-to-Peer for 1:1 calls": "Allow Peer-to-Peer for 1:1 calls",
|
"Allow Peer-to-Peer for 1:1 calls": "Allow Peer-to-Peer for 1:1 calls",
|
||||||
"Send analytics data": "Send analytics data",
|
"Send analytics data": "Send analytics data",
|
||||||
"Never send encrypted messages to unverified devices from this device": "Never send encrypted messages to unverified devices from this device",
|
"Never send encrypted messages to unverified sessions from this session": "Never send encrypted messages to unverified sessions from this session",
|
||||||
"Never send encrypted messages to unverified devices in this room from this device": "Never send encrypted messages to unverified devices in this room from this device",
|
"Never send encrypted messages to unverified sessions in this room from this session": "Never send encrypted messages to unverified sessions in this room from this session",
|
||||||
"Enable inline URL previews by default": "Enable inline URL previews by default",
|
"Enable inline URL previews by default": "Enable inline URL previews by default",
|
||||||
"Enable URL previews for this room (only affects you)": "Enable URL previews for this room (only affects you)",
|
"Enable URL previews for this room (only affects you)": "Enable URL previews for this room (only affects you)",
|
||||||
"Enable URL previews by default for participants in this room": "Enable URL previews by default for participants in this room",
|
"Enable URL previews by default for participants in this room": "Enable URL previews by default for participants in this room",
|
||||||
|
@ -516,7 +516,7 @@
|
||||||
"Headphones": "Headphones",
|
"Headphones": "Headphones",
|
||||||
"Folder": "Folder",
|
"Folder": "Folder",
|
||||||
"Pin": "Pin",
|
"Pin": "Pin",
|
||||||
"Verify your other devices easier": "Verify your other devices easier",
|
"Verify your other sessions easier": "Verify your other sessions easier",
|
||||||
"Other users may not trust it": "Other users may not trust it",
|
"Other users may not trust it": "Other users may not trust it",
|
||||||
"Upgrade": "Upgrade",
|
"Upgrade": "Upgrade",
|
||||||
"Verify": "Verify",
|
"Verify": "Verify",
|
||||||
|
@ -538,7 +538,7 @@
|
||||||
"New passwords don't match": "New passwords don't match",
|
"New passwords don't match": "New passwords don't match",
|
||||||
"Passwords can't be empty": "Passwords can't be empty",
|
"Passwords can't be empty": "Passwords can't be empty",
|
||||||
"Warning!": "Warning!",
|
"Warning!": "Warning!",
|
||||||
"Changing password will currently reset any end-to-end encryption keys on all devices, making encrypted chat history unreadable, unless you first export your room keys and re-import them afterwards. In future this will be improved.": "Changing password will currently reset any end-to-end encryption keys on all devices, making encrypted chat history unreadable, unless you first export your room keys and re-import them afterwards. In future this will be improved.",
|
"Changing password will currently reset any end-to-end encryption keys on all sessions, making encrypted chat history unreadable, unless you first export your room keys and re-import them afterwards. In future this will be improved.": "Changing password will currently reset any end-to-end encryption keys on all sessions, making encrypted chat history unreadable, unless you first export your room keys and re-import them afterwards. In future this will be improved.",
|
||||||
"Export E2E room keys": "Export E2E room keys",
|
"Export E2E room keys": "Export E2E room keys",
|
||||||
"Do you want to set an email address?": "Do you want to set an email address?",
|
"Do you want to set an email address?": "Do you want to set an email address?",
|
||||||
"Current password": "Current password",
|
"Current password": "Current password",
|
||||||
|
@ -547,21 +547,20 @@
|
||||||
"Confirm password": "Confirm password",
|
"Confirm password": "Confirm password",
|
||||||
"Change Password": "Change Password",
|
"Change Password": "Change Password",
|
||||||
"Cross-signing and secret storage are enabled.": "Cross-signing and secret storage are enabled.",
|
"Cross-signing and secret storage are enabled.": "Cross-signing and secret storage are enabled.",
|
||||||
"Your account has a cross-signing identity in secret storage, but it is not yet trusted by this device.": "Your account has a cross-signing identity in secret storage, but it is not yet trusted by this device.",
|
"Your account has a cross-signing identity in secret storage, but it is not yet trusted by this session.": "Your account has a cross-signing identity in secret storage, but it is not yet trusted by this session.",
|
||||||
"Cross-signing and secret storage are not yet set up.": "Cross-signing and secret storage are not yet set up.",
|
"Cross-signing and secret storage are not yet set up.": "Cross-signing and secret storage are not yet set up.",
|
||||||
"Bootstrap cross-signing and secret storage": "Bootstrap cross-signing and secret storage",
|
"Bootstrap cross-signing and secret storage": "Bootstrap cross-signing and secret storage",
|
||||||
"Cross-signing public keys:": "Cross-signing public keys:",
|
"Cross-signing public keys:": "Cross-signing public keys:",
|
||||||
"on device": "on device",
|
"in memory": "in memory",
|
||||||
"not found": "not found",
|
"not found": "not found",
|
||||||
"Cross-signing private keys:": "Cross-signing private keys:",
|
"Cross-signing private keys:": "Cross-signing private keys:",
|
||||||
"in secret storage": "in secret storage",
|
"in secret storage": "in secret storage",
|
||||||
"Secret storage public key:": "Secret storage public key:",
|
"Secret storage public key:": "Secret storage public key:",
|
||||||
"in account data": "in account data",
|
"in account data": "in account data",
|
||||||
"Your homeserver does not support device management.": "Your homeserver does not support device management.",
|
"Your homeserver does not support session management.": "Your homeserver does not support session management.",
|
||||||
"Unable to load device list": "Unable to load device list",
|
"Unable to load session list": "Unable to load session list",
|
||||||
"Authentication": "Authentication",
|
"Authentication": "Authentication",
|
||||||
"Delete %(count)s devices|other": "Delete %(count)s devices",
|
"Delete %(count)s sessions|other": "Delete %(count)s sessions",
|
||||||
"Delete %(count)s devices|one": "Delete device",
|
|
||||||
"ID": "ID",
|
"ID": "ID",
|
||||||
"Public Name": "Public Name",
|
"Public Name": "Public Name",
|
||||||
"Last seen": "Last seen",
|
"Last seen": "Last seen",
|
||||||
|
@ -584,30 +583,30 @@
|
||||||
"Encrypted messages are secured with end-to-end encryption. Only you and the recipient(s) have the keys to read these messages.": "Encrypted messages are secured with end-to-end encryption. Only you and the recipient(s) have the keys to read these messages.",
|
"Encrypted messages are secured with end-to-end encryption. Only you and the recipient(s) have the keys to read these messages.": "Encrypted messages are secured with end-to-end encryption. Only you and the recipient(s) have the keys to read these messages.",
|
||||||
"Unable to load key backup status": "Unable to load key backup status",
|
"Unable to load key backup status": "Unable to load key backup status",
|
||||||
"Restore from Backup": "Restore from Backup",
|
"Restore from Backup": "Restore from Backup",
|
||||||
"This device is backing up your keys. ": "This device is backing up your keys. ",
|
"This session is backing up your keys. ": "This session is backing up your keys. ",
|
||||||
"This device is <b>not backing up your keys</b>, but you do have an existing backup you can restore from and add to going forward.": "This device is <b>not backing up your keys</b>, but you do have an existing backup you can restore from and add to going forward.",
|
"This session is <b>not backing up your keys</b>, but you do have an existing backup you can restore from and add to going forward.": "This session is <b>not backing up your keys</b>, but you do have an existing backup you can restore from and add to going forward.",
|
||||||
"Connect this device to key backup before signing out to avoid losing any keys that may only be on this device.": "Connect this device to key backup before signing out to avoid losing any keys that may only be on this device.",
|
"Connect this session to key backup before signing out to avoid losing any keys that may only be on this session.": "Connect this session to key backup before signing out to avoid losing any keys that may only be on this session.",
|
||||||
"Connect this device to Key Backup": "Connect this device to Key Backup",
|
"Connect this session to Key Backup": "Connect this session to Key Backup",
|
||||||
"not stored": "not stored",
|
"not stored": "not stored",
|
||||||
"Backing up %(sessionsRemaining)s keys...": "Backing up %(sessionsRemaining)s keys...",
|
"Backing up %(sessionsRemaining)s keys...": "Backing up %(sessionsRemaining)s keys...",
|
||||||
"All keys backed up": "All keys backed up",
|
"All keys backed up": "All keys backed up",
|
||||||
"Backup has a <validity>valid</validity> signature from this user": "Backup has a <validity>valid</validity> signature from this user",
|
"Backup has a <validity>valid</validity> signature from this user": "Backup has a <validity>valid</validity> signature from this user",
|
||||||
"Backup has a <validity>invalid</validity> signature from this user": "Backup has a <validity>invalid</validity> signature from this user",
|
"Backup has a <validity>invalid</validity> signature from this user": "Backup has a <validity>invalid</validity> signature from this user",
|
||||||
"Backup has a signature from <verify>unknown</verify> user with ID %(deviceId)s": "Backup has a signature from <verify>unknown</verify> user with ID %(deviceId)s",
|
"Backup has a signature from <verify>unknown</verify> user with ID %(deviceId)s": "Backup has a signature from <verify>unknown</verify> user with ID %(deviceId)s",
|
||||||
"Backup has a signature from <verify>unknown</verify> device with ID %(deviceId)s": "Backup has a signature from <verify>unknown</verify> device with ID %(deviceId)s",
|
"Backup has a signature from <verify>unknown</verify> session with ID %(deviceId)s": "Backup has a signature from <verify>unknown</verify> session with ID %(deviceId)s",
|
||||||
"Backup has a <validity>valid</validity> signature from this device": "Backup has a <validity>valid</validity> signature from this device",
|
"Backup has a <validity>valid</validity> signature from this session": "Backup has a <validity>valid</validity> signature from this session",
|
||||||
"Backup has an <validity>invalid</validity> signature from this device": "Backup has an <validity>invalid</validity> signature from this device",
|
"Backup has an <validity>invalid</validity> signature from this session": "Backup has an <validity>invalid</validity> signature from this session",
|
||||||
"Backup has a <validity>valid</validity> signature from <verify>verified</verify> device <device></device>": "Backup has a <validity>valid</validity> signature from <verify>verified</verify> device <device></device>",
|
"Backup has a <validity>valid</validity> signature from <verify>verified</verify> session <device></device>": "Backup has a <validity>valid</validity> signature from <verify>verified</verify> session <device></device>",
|
||||||
"Backup has a <validity>valid</validity> signature from <verify>unverified</verify> device <device></device>": "Backup has a <validity>valid</validity> signature from <verify>unverified</verify> device <device></device>",
|
"Backup has a <validity>valid</validity> signature from <verify>unverified</verify> session <device></device>": "Backup has a <validity>valid</validity> signature from <verify>unverified</verify> session <device></device>",
|
||||||
"Backup has an <validity>invalid</validity> signature from <verify>verified</verify> device <device></device>": "Backup has an <validity>invalid</validity> signature from <verify>verified</verify> device <device></device>",
|
"Backup has an <validity>invalid</validity> signature from <verify>verified</verify> session <device></device>": "Backup has an <validity>invalid</validity> signature from <verify>verified</verify> session <device></device>",
|
||||||
"Backup has an <validity>invalid</validity> signature from <verify>unverified</verify> device <device></device>": "Backup has an <validity>invalid</validity> signature from <verify>unverified</verify> device <device></device>",
|
"Backup has an <validity>invalid</validity> signature from <verify>unverified</verify> session <device></device>": "Backup has an <validity>invalid</validity> signature from <verify>unverified</verify> session <device></device>",
|
||||||
"Backup is not signed by any of your devices": "Backup is not signed by any of your devices",
|
"Backup is not signed by any of your sessions": "Backup is not signed by any of your sessions",
|
||||||
"This backup is trusted because it has been restored on this device": "This backup is trusted because it has been restored on this device",
|
"This backup is trusted because it has been restored on this session": "This backup is trusted because it has been restored on this session",
|
||||||
"Backup key stored in secret storage, but this feature is not enabled on this device. Please enable cross-signing in Labs to modify key backup state.": "Backup key stored in secret storage, but this feature is not enabled on this device. Please enable cross-signing in Labs to modify key backup state.",
|
"Backup key stored in secret storage, but this feature is not enabled on this session. Please enable cross-signing in Labs to modify key backup state.": "Backup key stored in secret storage, but this feature is not enabled on this session. Please enable cross-signing in Labs to modify key backup state.",
|
||||||
"Backup version: ": "Backup version: ",
|
"Backup version: ": "Backup version: ",
|
||||||
"Algorithm: ": "Algorithm: ",
|
"Algorithm: ": "Algorithm: ",
|
||||||
"Backup key stored: ": "Backup key stored: ",
|
"Backup key stored: ": "Backup key stored: ",
|
||||||
"Your keys are <b>not being backed up from this device</b>.": "Your keys are <b>not being backed up from this device</b>.",
|
"Your keys are <b>not being backed up from this session</b>.": "Your keys are <b>not being backed up from this session</b>.",
|
||||||
"Back up your keys before signing out to avoid losing them.": "Back up your keys before signing out to avoid losing them.",
|
"Back up your keys before signing out to avoid losing them.": "Back up your keys before signing out to avoid losing them.",
|
||||||
"Start using Key Backup": "Start using Key Backup",
|
"Start using Key Backup": "Start using Key Backup",
|
||||||
"Error saving email notification preferences": "Error saving email notification preferences",
|
"Error saving email notification preferences": "Error saving email notification preferences",
|
||||||
|
@ -631,9 +630,9 @@
|
||||||
"Advanced notification settings": "Advanced notification settings",
|
"Advanced notification settings": "Advanced notification settings",
|
||||||
"There are advanced notifications which are not shown here": "There are advanced notifications which are not shown here",
|
"There are advanced notifications which are not shown here": "There are advanced notifications which are not shown here",
|
||||||
"You might have configured them in a client other than Riot. You cannot tune them in Riot but they still apply": "You might have configured them in a client other than Riot. You cannot tune them in Riot but they still apply",
|
"You might have configured them in a client other than Riot. You cannot tune them in Riot but they still apply": "You might have configured them in a client other than Riot. You cannot tune them in Riot but they still apply",
|
||||||
"Enable desktop notifications for this device": "Enable desktop notifications for this device",
|
"Enable desktop notifications for this session": "Enable desktop notifications for this session",
|
||||||
"Show message in desktop notification": "Show message in desktop notification",
|
"Show message in desktop notification": "Show message in desktop notification",
|
||||||
"Enable audible notifications for this device": "Enable audible notifications for this device",
|
"Enable audible notifications for this session": "Enable audible notifications for this session",
|
||||||
"Off": "Off",
|
"Off": "Off",
|
||||||
"On": "On",
|
"On": "On",
|
||||||
"Noisy": "Noisy",
|
"Noisy": "Noisy",
|
||||||
|
@ -678,7 +677,7 @@
|
||||||
"Flair": "Flair",
|
"Flair": "Flair",
|
||||||
"Failed to change password. Is your password correct?": "Failed to change password. Is your password correct?",
|
"Failed to change password. Is your password correct?": "Failed to change password. Is your password correct?",
|
||||||
"Success": "Success",
|
"Success": "Success",
|
||||||
"Your password was successfully changed. You will not receive push notifications on other devices until you log back in to them": "Your password was successfully changed. You will not receive push notifications on other devices until you log back in to them",
|
"Your password was successfully changed. You will not receive push notifications on other sessions until you log back in to them": "Your password was successfully changed. You will not receive push notifications on other sessions until you log back in to them",
|
||||||
"Profile": "Profile",
|
"Profile": "Profile",
|
||||||
"Email addresses": "Email addresses",
|
"Email addresses": "Email addresses",
|
||||||
"Phone numbers": "Phone numbers",
|
"Phone numbers": "Phone numbers",
|
||||||
|
@ -763,8 +762,8 @@
|
||||||
"<not supported>": "<not supported>",
|
"<not supported>": "<not supported>",
|
||||||
"Import E2E room keys": "Import E2E room keys",
|
"Import E2E room keys": "Import E2E room keys",
|
||||||
"Cryptography": "Cryptography",
|
"Cryptography": "Cryptography",
|
||||||
"Device ID:": "Device ID:",
|
"Session ID:": "Session ID:",
|
||||||
"Device key:": "Device key:",
|
"Session key:": "Session key:",
|
||||||
"Bulk options": "Bulk options",
|
"Bulk options": "Bulk options",
|
||||||
"Accept all %(invitedRooms)s invites": "Accept all %(invitedRooms)s invites",
|
"Accept all %(invitedRooms)s invites": "Accept all %(invitedRooms)s invites",
|
||||||
"Reject all %(invitedRooms)s invites": "Reject all %(invitedRooms)s invites",
|
"Reject all %(invitedRooms)s invites": "Reject all %(invitedRooms)s invites",
|
||||||
|
@ -772,8 +771,8 @@
|
||||||
"Message search": "Message search",
|
"Message search": "Message search",
|
||||||
"Cross-signing": "Cross-signing",
|
"Cross-signing": "Cross-signing",
|
||||||
"Security & Privacy": "Security & Privacy",
|
"Security & Privacy": "Security & Privacy",
|
||||||
"Devices": "Devices",
|
"Sessions": "Sessions",
|
||||||
"A device's public name is visible to people you communicate with": "A device's public name is visible to people you communicate with",
|
"A session's public name is visible to people you communicate with": "A session's public name is visible to people you communicate with",
|
||||||
"Riot collects anonymous analytics to allow us to improve the application.": "Riot collects anonymous analytics to allow us to improve the application.",
|
"Riot collects anonymous analytics to allow us to improve the application.": "Riot collects anonymous analytics to allow us to improve the application.",
|
||||||
"Privacy is important to us, so we don't collect any personal or identifiable data for our analytics.": "Privacy is important to us, so we don't collect any personal or identifiable data for our analytics.",
|
"Privacy is important to us, so we don't collect any personal or identifiable data for our analytics.": "Privacy is important to us, so we don't collect any personal or identifiable data for our analytics.",
|
||||||
"Learn more about how we use analytics.": "Learn more about how we use analytics.",
|
"Learn more about how we use analytics.": "Learn more about how we use analytics.",
|
||||||
|
@ -898,30 +897,30 @@
|
||||||
" (unsupported)": " (unsupported)",
|
" (unsupported)": " (unsupported)",
|
||||||
"Join as <voiceText>voice</voiceText> or <videoText>video</videoText>.": "Join as <voiceText>voice</voiceText> or <videoText>video</videoText>.",
|
"Join as <voiceText>voice</voiceText> or <videoText>video</videoText>.": "Join as <voiceText>voice</voiceText> or <videoText>video</videoText>.",
|
||||||
"Ongoing conference call%(supportedText)s.": "Ongoing conference call%(supportedText)s.",
|
"Ongoing conference call%(supportedText)s.": "Ongoing conference call%(supportedText)s.",
|
||||||
"This user has not verified all of their devices.": "This user has not verified all of their devices.",
|
"This user has not verified all of their sessions.": "This user has not verified all of their sessions.",
|
||||||
"You have not verified this user. This user has verified all of their devices.": "You have not verified this user. This user has verified all of their devices.",
|
"You have not verified this user. This user has verified all of their sessions.": "You have not verified this user. This user has verified all of their sessions.",
|
||||||
"You have verified this user. This user has verified all of their devices.": "You have verified this user. This user has verified all of their devices.",
|
"You have verified this user. This user has verified all of their sessions.": "You have verified this user. This user has verified all of their sessions.",
|
||||||
"Someone is using an unknown device": "Someone is using an unknown device",
|
"Someone is using an unknown session": "Someone is using an unknown session",
|
||||||
"This room is end-to-end encrypted": "This room is end-to-end encrypted",
|
"This room is end-to-end encrypted": "This room is end-to-end encrypted",
|
||||||
"Everyone in this room is verified": "Everyone in this room is verified",
|
"Everyone in this room is verified": "Everyone in this room is verified",
|
||||||
"Some devices for this user are not trusted": "Some devices for this user are not trusted",
|
"Some sessions for this user are not trusted": "Some sessions for this user are not trusted",
|
||||||
"All devices for this user are trusted": "All devices for this user are trusted",
|
"All sessions for this user are trusted": "All sessions for this user are trusted",
|
||||||
"Some devices in this encrypted room are not trusted": "Some devices in this encrypted room are not trusted",
|
"Some sessions in this encrypted room are not trusted": "Some sessions in this encrypted room are not trusted",
|
||||||
"All devices in this encrypted room are trusted": "All devices in this encrypted room are trusted",
|
"All sessions in this encrypted room are trusted": "All sessions in this encrypted room are trusted",
|
||||||
"Edit message": "Edit message",
|
"Edit message": "Edit message",
|
||||||
"This event could not be displayed": "This event could not be displayed",
|
"This event could not be displayed": "This event could not be displayed",
|
||||||
"%(senderName)s sent an image": "%(senderName)s sent an image",
|
"%(senderName)s sent an image": "%(senderName)s sent an image",
|
||||||
"%(senderName)s sent a video": "%(senderName)s sent a video",
|
"%(senderName)s sent a video": "%(senderName)s sent a video",
|
||||||
"%(senderName)s uploaded a file": "%(senderName)s uploaded a file",
|
"%(senderName)s uploaded a file": "%(senderName)s uploaded a file",
|
||||||
"Your key share request has been sent - please check your other devices for key share requests.": "Your key share request has been sent - please check your other devices for key share requests.",
|
"Your key share request has been sent - please check your other sessions for key share requests.": "Your key share request has been sent - please check your other sessions for key share requests.",
|
||||||
"Key share requests are sent to your other devices automatically. If you rejected or dismissed the key share request on your other devices, click here to request the keys for this session again.": "Key share requests are sent to your other devices automatically. If you rejected or dismissed the key share request on your other devices, click here to request the keys for this session again.",
|
"Key share requests are sent to your other sessions automatically. If you rejected or dismissed the key share request on your other sessions, click here to request the keys for this session again.": "Key share requests are sent to your other sessions automatically. If you rejected or dismissed the key share request on your other sessions, click here to request the keys for this session again.",
|
||||||
"If your other devices do not have the key for this message you will not be able to decrypt them.": "If your other devices do not have the key for this message you will not be able to decrypt them.",
|
"If your other sessions do not have the key for this message you will not be able to decrypt them.": "If your other sessions do not have the key for this message you will not be able to decrypt them.",
|
||||||
"Key request sent.": "Key request sent.",
|
"Key request sent.": "Key request sent.",
|
||||||
"<requestLink>Re-request encryption keys</requestLink> from your other devices.": "<requestLink>Re-request encryption keys</requestLink> from your other devices.",
|
"<requestLink>Re-request encryption keys</requestLink> from your other sessions.": "<requestLink>Re-request encryption keys</requestLink> from your other sessions.",
|
||||||
"This message cannot be decrypted": "This message cannot be decrypted",
|
"This message cannot be decrypted": "This message cannot be decrypted",
|
||||||
"Encrypted by an unverified device": "Encrypted by an unverified device",
|
"Encrypted by an unverified session": "Encrypted by an unverified session",
|
||||||
"Unencrypted": "Unencrypted",
|
"Unencrypted": "Unencrypted",
|
||||||
"Encrypted by a deleted device": "Encrypted by a deleted device",
|
"Encrypted by a deleted session": "Encrypted by a deleted session",
|
||||||
"Please select the destination room for this message": "Please select the destination room for this message",
|
"Please select the destination room for this message": "Please select the destination room for this message",
|
||||||
"Invite only": "Invite only",
|
"Invite only": "Invite only",
|
||||||
"Scroll to bottom of page": "Scroll to bottom of page",
|
"Scroll to bottom of page": "Scroll to bottom of page",
|
||||||
|
@ -956,7 +955,7 @@
|
||||||
"Failed to change power level": "Failed to change power level",
|
"Failed to change power level": "Failed to change power level",
|
||||||
"You will not be able to undo this change as you are promoting the user to have the same power level as yourself.": "You will not be able to undo this change as you are promoting the user to have the same power level as yourself.",
|
"You will not be able to undo this change as you are promoting the user to have the same power level as yourself.": "You will not be able to undo this change as you are promoting the user to have the same power level as yourself.",
|
||||||
"Are you sure?": "Are you sure?",
|
"Are you sure?": "Are you sure?",
|
||||||
"No devices with registered encryption keys": "No devices with registered encryption keys",
|
"No sessions with registered encryption keys": "No sessions with registered encryption keys",
|
||||||
"Jump to read receipt": "Jump to read receipt",
|
"Jump to read receipt": "Jump to read receipt",
|
||||||
"Mention": "Mention",
|
"Mention": "Mention",
|
||||||
"Invite": "Invite",
|
"Invite": "Invite",
|
||||||
|
@ -1154,7 +1153,7 @@
|
||||||
"Your homeserver": "Your homeserver",
|
"Your homeserver": "Your homeserver",
|
||||||
"The homeserver the user you’re verifying is connected to": "The homeserver the user you’re verifying is connected to",
|
"The homeserver the user you’re verifying is connected to": "The homeserver the user you’re verifying is connected to",
|
||||||
"Yours, or the other users’ internet connection": "Yours, or the other users’ internet connection",
|
"Yours, or the other users’ internet connection": "Yours, or the other users’ internet connection",
|
||||||
"Yours, or the other users’ device": "Yours, or the other users’ device",
|
"Yours, or the other users’ session": "Yours, or the other users’ session",
|
||||||
"Members": "Members",
|
"Members": "Members",
|
||||||
"Files": "Files",
|
"Files": "Files",
|
||||||
"Trusted": "Trusted",
|
"Trusted": "Trusted",
|
||||||
|
@ -1422,8 +1421,8 @@
|
||||||
"Removing…": "Removing…",
|
"Removing…": "Removing…",
|
||||||
"Confirm Removal": "Confirm Removal",
|
"Confirm Removal": "Confirm Removal",
|
||||||
"Are you sure you wish to remove (delete) this event? Note that if you delete a room name or topic change, it could undo the change.": "Are you sure you wish to remove (delete) this event? Note that if you delete a room name or topic change, it could undo the change.",
|
"Are you sure you wish to remove (delete) this event? Note that if you delete a room name or topic change, it could undo the change.": "Are you sure you wish to remove (delete) this event? Note that if you delete a room name or topic change, it could undo the change.",
|
||||||
"Clear all data on this device?": "Clear all data on this device?",
|
"Clear all data in this session?": "Clear all data in this session?",
|
||||||
"Clearing all data from this device is permanent. Encrypted messages will be lost unless their keys have been backed up.": "Clearing all data from this device is permanent. Encrypted messages will be lost unless their keys have been backed up.",
|
"Clearing all data from this session is permanent. Encrypted messages will be lost unless their keys have been backed up.": "Clearing all data from this session is permanent. Encrypted messages will be lost unless their keys have been backed up.",
|
||||||
"Clear all data": "Clear all data",
|
"Clear all data": "Clear all data",
|
||||||
"Community IDs cannot be empty.": "Community IDs cannot be empty.",
|
"Community IDs cannot be empty.": "Community IDs cannot be empty.",
|
||||||
"Community IDs may only contain characters a-z, 0-9, or '=_-./'": "Community IDs may only contain characters a-z, 0-9, or '=_-./'",
|
"Community IDs may only contain characters a-z, 0-9, or '=_-./'": "Community IDs may only contain characters a-z, 0-9, or '=_-./'",
|
||||||
|
@ -1458,20 +1457,20 @@
|
||||||
"Message visibility in Matrix is similar to email. Our forgetting your messages means that messages you have sent will not be shared with any new or unregistered users, but registered users who already have access to these messages will still have access to their copy.": "Message visibility in Matrix is similar to email. Our forgetting your messages means that messages you have sent will not be shared with any new or unregistered users, but registered users who already have access to these messages will still have access to their copy.",
|
"Message visibility in Matrix is similar to email. Our forgetting your messages means that messages you have sent will not be shared with any new or unregistered users, but registered users who already have access to these messages will still have access to their copy.": "Message visibility in Matrix is similar to email. Our forgetting your messages means that messages you have sent will not be shared with any new or unregistered users, but registered users who already have access to these messages will still have access to their copy.",
|
||||||
"Please forget all messages I have sent when my account is deactivated (<b>Warning:</b> this will cause future users to see an incomplete view of conversations)": "Please forget all messages I have sent when my account is deactivated (<b>Warning:</b> this will cause future users to see an incomplete view of conversations)",
|
"Please forget all messages I have sent when my account is deactivated (<b>Warning:</b> this will cause future users to see an incomplete view of conversations)": "Please forget all messages I have sent when my account is deactivated (<b>Warning:</b> this will cause future users to see an incomplete view of conversations)",
|
||||||
"To continue, please enter your password:": "To continue, please enter your password:",
|
"To continue, please enter your password:": "To continue, please enter your password:",
|
||||||
"Verify device": "Verify device",
|
"Verify session": "Verify session",
|
||||||
"Use Legacy Verification (for older clients)": "Use Legacy Verification (for older clients)",
|
"Use Legacy Verification (for older clients)": "Use Legacy Verification (for older clients)",
|
||||||
"Verify by comparing a short text string.": "Verify by comparing a short text string.",
|
"Verify by comparing a short text string.": "Verify by comparing a short text string.",
|
||||||
"Begin Verifying": "Begin Verifying",
|
"Begin Verifying": "Begin Verifying",
|
||||||
"Waiting for partner to accept...": "Waiting for partner to accept...",
|
"Waiting for partner to accept...": "Waiting for partner to accept...",
|
||||||
"Nothing appearing? Not all clients support interactive verification yet. <button>Use legacy verification</button>.": "Nothing appearing? Not all clients support interactive verification yet. <button>Use legacy verification</button>.",
|
"Nothing appearing? Not all clients support interactive verification yet. <button>Use legacy verification</button>.": "Nothing appearing? Not all clients support interactive verification yet. <button>Use legacy verification</button>.",
|
||||||
"Waiting for %(userId)s to confirm...": "Waiting for %(userId)s to confirm...",
|
"Waiting for %(userId)s to confirm...": "Waiting for %(userId)s to confirm...",
|
||||||
"To verify that this device can be trusted, please check that the key you see in User Settings on that device matches the key below:": "To verify that this device can be trusted, please check that the key you see in User Settings on that device matches the key below:",
|
"To verify that this session can be trusted, please check that the key you see in User Settings on that device matches the key below:": "To verify that this session can be trusted, please check that the key you see in User Settings on that device matches the key below:",
|
||||||
"To verify that this device can be trusted, please contact its owner using some other means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings for this device matches the key below:": "To verify that this device can be trusted, please contact its owner using some other means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings for this device matches the key below:",
|
"To verify that this session can be trusted, please contact its owner using some other means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings for this session matches the key below:": "To verify that this session can be trusted, please contact its owner using some other means (e.g. in person or a phone call) and ask them whether the key they see in their User Settings for this session matches the key below:",
|
||||||
"Use two-way text verification": "Use two-way text verification",
|
"Use two-way text verification": "Use two-way text verification",
|
||||||
"Device name": "Device name",
|
"Session name": "Session name",
|
||||||
"Device ID": "Device ID",
|
"Session ID": "Session ID",
|
||||||
"Device key": "Device key",
|
"Session key": "Session key",
|
||||||
"If it matches, press the verify button below. If it doesn't, then someone else is intercepting this device and you probably want to press the blacklist button instead.": "If it matches, press the verify button below. If it doesn't, then someone else is intercepting this device and you probably want to press the blacklist button instead.",
|
"If it matches, press the verify button below. If it doesn't, then someone else is intercepting this session and you probably want to press the blacklist button instead.": "If it matches, press the verify button below. If it doesn't, then someone else is intercepting this session and you probably want to press the blacklist button instead.",
|
||||||
"I verify that the keys match": "I verify that the keys match",
|
"I verify that the keys match": "I verify that the keys match",
|
||||||
"Back": "Back",
|
"Back": "Back",
|
||||||
"Send Custom Event": "Send Custom Event",
|
"Send Custom Event": "Send Custom Event",
|
||||||
|
@ -1490,7 +1489,7 @@
|
||||||
"Developer Tools": "Developer Tools",
|
"Developer Tools": "Developer Tools",
|
||||||
"An error has occurred.": "An error has occurred.",
|
"An error has occurred.": "An error has occurred.",
|
||||||
"Verify this user to mark them as trusted. Trusting users gives you extra peace of mind when using end-to-end encrypted messages.": "Verify this user to mark them as trusted. Trusting users gives you extra peace of mind when using end-to-end encrypted messages.",
|
"Verify this user to mark them as trusted. Trusting users gives you extra peace of mind when using end-to-end encrypted messages.": "Verify this user to mark them as trusted. Trusting users gives you extra peace of mind when using end-to-end encrypted messages.",
|
||||||
"Verifying this user will mark their device as trusted, and also mark your device as trusted to them.": "Verifying this user will mark their device as trusted, and also mark your device as trusted to them.",
|
"Verifying this user will mark their session as trusted, and also mark your session as trusted to them.": "Verifying this user will mark their session as trusted, and also mark your session as trusted to them.",
|
||||||
"Waiting for partner to confirm...": "Waiting for partner to confirm...",
|
"Waiting for partner to confirm...": "Waiting for partner to confirm...",
|
||||||
"Incoming Verification Request": "Incoming Verification Request",
|
"Incoming Verification Request": "Incoming Verification Request",
|
||||||
"Integrations are disabled": "Integrations are disabled",
|
"Integrations are disabled": "Integrations are disabled",
|
||||||
|
@ -1509,12 +1508,12 @@
|
||||||
"If you can't find someone, ask them for their username, share your username (%(userId)s) or <a>profile link</a>.": "If you can't find someone, ask them for their username, share your username (%(userId)s) or <a>profile link</a>.",
|
"If you can't find someone, ask them for their username, share your username (%(userId)s) or <a>profile link</a>.": "If you can't find someone, ask them for their username, share your username (%(userId)s) or <a>profile link</a>.",
|
||||||
"Go": "Go",
|
"Go": "Go",
|
||||||
"If you can't find someone, ask them for their username (e.g. @user:server.com) or <a>share this room</a>.": "If you can't find someone, ask them for their username (e.g. @user:server.com) or <a>share this room</a>.",
|
"If you can't find someone, ask them for their username (e.g. @user:server.com) or <a>share this room</a>.": "If you can't find someone, ask them for their username (e.g. @user:server.com) or <a>share this room</a>.",
|
||||||
"You added a new device '%(displayName)s', which is requesting encryption keys.": "You added a new device '%(displayName)s', which is requesting encryption keys.",
|
"You added a new session '%(displayName)s', which is requesting encryption keys.": "You added a new session '%(displayName)s', which is requesting encryption keys.",
|
||||||
"Your unverified device '%(displayName)s' is requesting encryption keys.": "Your unverified device '%(displayName)s' is requesting encryption keys.",
|
"Your unverified session '%(displayName)s' is requesting encryption keys.": "Your unverified session '%(displayName)s' is requesting encryption keys.",
|
||||||
"Start verification": "Start verification",
|
"Start verification": "Start verification",
|
||||||
"Share without verifying": "Share without verifying",
|
"Share without verifying": "Share without verifying",
|
||||||
"Ignore request": "Ignore request",
|
"Ignore request": "Ignore request",
|
||||||
"Loading device info...": "Loading device info...",
|
"Loading session info...": "Loading session info...",
|
||||||
"Encryption key request": "Encryption key request",
|
"Encryption key request": "Encryption key request",
|
||||||
"You've previously used Riot on %(host)s with lazy loading of members enabled. In this version lazy loading is disabled. As the local cache is not compatible between these two settings, Riot needs to resync your account.": "You've previously used Riot on %(host)s with lazy loading of members enabled. In this version lazy loading is disabled. As the local cache is not compatible between these two settings, Riot needs to resync your account.",
|
"You've previously used Riot on %(host)s with lazy loading of members enabled. In this version lazy loading is disabled. As the local cache is not compatible between these two settings, Riot needs to resync your account.": "You've previously used Riot on %(host)s with lazy loading of members enabled. In this version lazy loading is disabled. As the local cache is not compatible between these two settings, Riot needs to resync your account.",
|
||||||
"If the other version of Riot is still open in another tab, please close it as using Riot on the same host with both lazy loading enabled and disabled simultaneously will cause issues.": "If the other version of Riot is still open in another tab, please close it as using Riot on the same host with both lazy loading enabled and disabled simultaneously will cause issues.",
|
"If the other version of Riot is still open in another tab, please close it as using Riot on the same host with both lazy loading enabled and disabled simultaneously will cause issues.": "If the other version of Riot is still open in another tab, please close it as using Riot on the same host with both lazy loading enabled and disabled simultaneously will cause issues.",
|
||||||
|
@ -1583,7 +1582,7 @@
|
||||||
"Remember, you can always set an email address in user settings if you change your mind.": "Remember, you can always set an email address in user settings if you change your mind.",
|
"Remember, you can always set an email address in user settings if you change your mind.": "Remember, you can always set an email address in user settings if you change your mind.",
|
||||||
"(HTTP status %(httpStatus)s)": "(HTTP status %(httpStatus)s)",
|
"(HTTP status %(httpStatus)s)": "(HTTP status %(httpStatus)s)",
|
||||||
"Please set a password!": "Please set a password!",
|
"Please set a password!": "Please set a password!",
|
||||||
"This will allow you to return to your account after signing out, and sign in on other devices.": "This will allow you to return to your account after signing out, and sign in on other devices.",
|
"This will allow you to return to your account after signing out, and sign in on other sessions.": "This will allow you to return to your account after signing out, and sign in on other sessions.",
|
||||||
"Share Room": "Share Room",
|
"Share Room": "Share Room",
|
||||||
"Link to most recent message": "Link to most recent message",
|
"Link to most recent message": "Link to most recent message",
|
||||||
"Share User": "Share User",
|
"Share User": "Share User",
|
||||||
|
@ -1606,11 +1605,11 @@
|
||||||
"Summary": "Summary",
|
"Summary": "Summary",
|
||||||
"Document": "Document",
|
"Document": "Document",
|
||||||
"Next": "Next",
|
"Next": "Next",
|
||||||
"You are currently blacklisting unverified devices; to send messages to these devices you must verify them.": "You are currently blacklisting unverified devices; to send messages to these devices you must verify them.",
|
"You are currently blacklisting unverified sessions; to send messages to these sessions you must verify them.": "You are currently blacklisting unverified sessions; to send messages to these sessions you must verify them.",
|
||||||
"We recommend you go through the verification process for each device to confirm they belong to their legitimate owner, but you can resend the message without verifying if you prefer.": "We recommend you go through the verification process for each device to confirm they belong to their legitimate owner, but you can resend the message without verifying if you prefer.",
|
"We recommend you go through the verification process for each session to confirm they belong to their legitimate owner, but you can resend the message without verifying if you prefer.": "We recommend you go through the verification process for each session to confirm they belong to their legitimate owner, but you can resend the message without verifying if you prefer.",
|
||||||
"Room contains unknown devices": "Room contains unknown devices",
|
"Room contains unknown sessions": "Room contains unknown sessions",
|
||||||
"\"%(RoomName)s\" contains devices that you haven't seen before.": "\"%(RoomName)s\" contains devices that you haven't seen before.",
|
"\"%(RoomName)s\" contains sessions that you haven't seen before.": "\"%(RoomName)s\" contains sessions that you haven't seen before.",
|
||||||
"Unknown devices": "Unknown devices",
|
"Unknown sessions": "Unknown sessions",
|
||||||
"Upload files (%(current)s of %(total)s)": "Upload files (%(current)s of %(total)s)",
|
"Upload files (%(current)s of %(total)s)": "Upload files (%(current)s of %(total)s)",
|
||||||
"Upload files": "Upload files",
|
"Upload files": "Upload files",
|
||||||
"Upload all": "Upload all",
|
"Upload all": "Upload all",
|
||||||
|
@ -1629,13 +1628,13 @@
|
||||||
"Enter secret storage passphrase": "Enter secret storage passphrase",
|
"Enter secret storage passphrase": "Enter secret storage passphrase",
|
||||||
"Unable to access secret storage. Please verify that you entered the correct passphrase.": "Unable to access secret storage. Please verify that you entered the correct passphrase.",
|
"Unable to access secret storage. Please verify that you entered the correct passphrase.": "Unable to access secret storage. Please verify that you entered the correct passphrase.",
|
||||||
"<b>Warning</b>: You should only access secret storage from a trusted computer.": "<b>Warning</b>: You should only access secret storage from a trusted computer.",
|
"<b>Warning</b>: You should only access secret storage from a trusted computer.": "<b>Warning</b>: You should only access secret storage from a trusted computer.",
|
||||||
"Access your secure message history and your cross-signing identity for verifying other devices by entering your passphrase.": "Access your secure message history and your cross-signing identity for verifying other devices by entering your passphrase.",
|
"Access your secure message history and your cross-signing identity for verifying other sessions by entering your passphrase.": "Access your secure message history and your cross-signing identity for verifying other sessions by entering your passphrase.",
|
||||||
"If you've forgotten your passphrase you can <button1>use your recovery key</button1> or <button2>set up new recovery options</button2>.": "If you've forgotten your passphrase you can <button1>use your recovery key</button1> or <button2>set up new recovery options</button2>.",
|
"If you've forgotten your passphrase you can <button1>use your recovery key</button1> or <button2>set up new recovery options</button2>.": "If you've forgotten your passphrase you can <button1>use your recovery key</button1> or <button2>set up new recovery options</button2>.",
|
||||||
"Enter secret storage recovery key": "Enter secret storage recovery key",
|
"Enter secret storage recovery key": "Enter secret storage recovery key",
|
||||||
"This looks like a valid recovery key!": "This looks like a valid recovery key!",
|
"This looks like a valid recovery key!": "This looks like a valid recovery key!",
|
||||||
"Unable to access secret storage. Please verify that you entered the correct recovery key.": "Unable to access secret storage. Please verify that you entered the correct recovery key.",
|
"Unable to access secret storage. Please verify that you entered the correct recovery key.": "Unable to access secret storage. Please verify that you entered the correct recovery key.",
|
||||||
"Not a valid recovery key": "Not a valid recovery key",
|
"Not a valid recovery key": "Not a valid recovery key",
|
||||||
"Access your secure message history and your cross-signing identity for verifying other devices by entering your recovery key.": "Access your secure message history and your cross-signing identity for verifying other devices by entering your recovery key.",
|
"Access your secure message history and your cross-signing identity for verifying other sessions by entering your recovery key.": "Access your secure message history and your cross-signing identity for verifying other sessions by entering your recovery key.",
|
||||||
"If you've forgotten your recovery key you can <button>set up new recovery options</button>.": "If you've forgotten your recovery key you can <button>set up new recovery options</button>.",
|
"If you've forgotten your recovery key you can <button>set up new recovery options</button>.": "If you've forgotten your recovery key you can <button>set up new recovery options</button>.",
|
||||||
"Unable to load backup status": "Unable to load backup status",
|
"Unable to load backup status": "Unable to load backup status",
|
||||||
"Recovery Key Mismatch": "Recovery Key Mismatch",
|
"Recovery Key Mismatch": "Recovery Key Mismatch",
|
||||||
|
@ -1863,8 +1862,8 @@
|
||||||
"Find a room… (e.g. %(exampleRoom)s)": "Find a room… (e.g. %(exampleRoom)s)",
|
"Find a room… (e.g. %(exampleRoom)s)": "Find a room… (e.g. %(exampleRoom)s)",
|
||||||
"If you can't find the room you're looking for, ask for an invite or <a>Create a new room</a>.": "If you can't find the room you're looking for, ask for an invite or <a>Create a new room</a>.",
|
"If you can't find the room you're looking for, ask for an invite or <a>Create a new room</a>.": "If you can't find the room you're looking for, ask for an invite or <a>Create a new room</a>.",
|
||||||
"Explore rooms": "Explore rooms",
|
"Explore rooms": "Explore rooms",
|
||||||
"Message not sent due to unknown devices being present": "Message not sent due to unknown devices being present",
|
"Message not sent due to unknown sessions being present": "Message not sent due to unknown sessions being present",
|
||||||
"<showDevicesText>Show devices</showDevicesText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.": "<showDevicesText>Show devices</showDevicesText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.",
|
"<showSessionsText>Show sessions</showSessionsText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.": "<showSessionsText>Show sessions</showSessionsText>, <sendAnywayText>send anyway</sendAnywayText> or <cancelText>cancel</cancelText>.",
|
||||||
"You can't send any messages until you review and agree to <consentLink>our terms and conditions</consentLink>.": "You can't send any messages until you review and agree to <consentLink>our terms and conditions</consentLink>.",
|
"You can't send any messages until you review and agree to <consentLink>our terms and conditions</consentLink>.": "You can't send any messages until you review and agree to <consentLink>our terms and conditions</consentLink>.",
|
||||||
"Your message wasn't sent because this homeserver has hit its Monthly Active User Limit. Please <a>contact your service administrator</a> to continue using the service.": "Your message wasn't sent because this homeserver has hit its Monthly Active User Limit. Please <a>contact your service administrator</a> to continue using the service.",
|
"Your message wasn't sent because this homeserver has hit its Monthly Active User Limit. Please <a>contact your service administrator</a> to continue using the service.": "Your message wasn't sent because this homeserver has hit its Monthly Active User Limit. Please <a>contact your service administrator</a> to continue using the service.",
|
||||||
"Your message wasn't sent because this homeserver has exceeded a resource limit. Please <a>contact your service administrator</a> to continue using the service.": "Your message wasn't sent because this homeserver has exceeded a resource limit. Please <a>contact your service administrator</a> to continue using the service.",
|
"Your message wasn't sent because this homeserver has exceeded a resource limit. Please <a>contact your service administrator</a> to continue using the service.": "Your message wasn't sent because this homeserver has exceeded a resource limit. Please <a>contact your service administrator</a> to continue using the service.",
|
||||||
|
@ -1912,13 +1911,13 @@
|
||||||
"Your new session is now verified. It has access to your encrypted messages, and other users will see it as trusted.": "Your new session is now verified. It has access to your encrypted messages, and other users will see it as trusted.",
|
"Your new session is now verified. It has access to your encrypted messages, and other users will see it as trusted.": "Your new session is now verified. It has access to your encrypted messages, and other users will see it as trusted.",
|
||||||
"Your new session is now verified. Other users will see it as trusted.": "Your new session is now verified. Other users will see it as trusted.",
|
"Your new session is now verified. Other users will see it as trusted.": "Your new session is now verified. Other users will see it as trusted.",
|
||||||
"Done": "Done",
|
"Done": "Done",
|
||||||
"Without completing security on this device, it won’t have access to encrypted messages.": "Without completing security on this device, it won’t have access to encrypted messages.",
|
"Without completing security on this session, it won’t have access to encrypted messages.": "Without completing security on this session, it won’t have access to encrypted messages.",
|
||||||
"Go Back": "Go Back",
|
"Go Back": "Go Back",
|
||||||
"Failed to send email": "Failed to send email",
|
"Failed to send email": "Failed to send email",
|
||||||
"The email address linked to your account must be entered.": "The email address linked to your account must be entered.",
|
"The email address linked to your account must be entered.": "The email address linked to your account must be entered.",
|
||||||
"A new password must be entered.": "A new password must be entered.",
|
"A new password must be entered.": "A new password must be entered.",
|
||||||
"New passwords must match each other.": "New passwords must match each other.",
|
"New passwords must match each other.": "New passwords must match each other.",
|
||||||
"Changing your password will reset any end-to-end encryption keys on all of your devices, making encrypted chat history unreadable. Set up Key Backup or export your room keys from another device before resetting your password.": "Changing your password will reset any end-to-end encryption keys on all of your devices, making encrypted chat history unreadable. Set up Key Backup or export your room keys from another device before resetting your password.",
|
"Changing your password will reset any end-to-end encryption keys on all of your sessions, making encrypted chat history unreadable. Set up Key Backup or export your room keys from another session before resetting your password.": "Changing your password will reset any end-to-end encryption keys on all of your sessions, making encrypted chat history unreadable. Set up Key Backup or export your room keys from another session before resetting your password.",
|
||||||
"Your Matrix account on %(serverName)s": "Your Matrix account on %(serverName)s",
|
"Your Matrix account on %(serverName)s": "Your Matrix account on %(serverName)s",
|
||||||
"Your Matrix account on <underlinedServerName />": "Your Matrix account on <underlinedServerName />",
|
"Your Matrix account on <underlinedServerName />": "Your Matrix account on <underlinedServerName />",
|
||||||
"No identity server is configured: add one in server settings to reset your password.": "No identity server is configured: add one in server settings to reset your password.",
|
"No identity server is configured: add one in server settings to reset your password.": "No identity server is configured: add one in server settings to reset your password.",
|
||||||
|
@ -1928,7 +1927,7 @@
|
||||||
"An email has been sent to %(emailAddress)s. Once you've followed the link it contains, click below.": "An email has been sent to %(emailAddress)s. Once you've followed the link it contains, click below.",
|
"An email has been sent to %(emailAddress)s. Once you've followed the link it contains, click below.": "An email has been sent to %(emailAddress)s. Once you've followed the link it contains, click below.",
|
||||||
"I have verified my email address": "I have verified my email address",
|
"I have verified my email address": "I have verified my email address",
|
||||||
"Your password has been reset.": "Your password has been reset.",
|
"Your password has been reset.": "Your password has been reset.",
|
||||||
"You have been logged out of all devices and will no longer receive push notifications. To re-enable notifications, sign in again on each device.": "You have been logged out of all devices and will no longer receive push notifications. To re-enable notifications, sign in again on each device.",
|
"You have been logged out of all sessions and will no longer receive push notifications. To re-enable notifications, sign in again on each device.": "You have been logged out of all sessions and will no longer receive push notifications. To re-enable notifications, sign in again on each device.",
|
||||||
"Return to login screen": "Return to login screen",
|
"Return to login screen": "Return to login screen",
|
||||||
"Set a new password": "Set a new password",
|
"Set a new password": "Set a new password",
|
||||||
"Invalid homeserver discovery response": "Invalid homeserver discovery response",
|
"Invalid homeserver discovery response": "Invalid homeserver discovery response",
|
||||||
|
@ -1966,14 +1965,14 @@
|
||||||
"Create your account": "Create your account",
|
"Create your account": "Create your account",
|
||||||
"Failed to re-authenticate due to a homeserver problem": "Failed to re-authenticate due to a homeserver problem",
|
"Failed to re-authenticate due to a homeserver problem": "Failed to re-authenticate due to a homeserver problem",
|
||||||
"Failed to re-authenticate": "Failed to re-authenticate",
|
"Failed to re-authenticate": "Failed to re-authenticate",
|
||||||
"Regain access to your account and recover encryption keys stored on this device. Without them, you won’t be able to read all of your secure messages on any device.": "Regain access to your account and recover encryption keys stored on this device. Without them, you won’t be able to read all of your secure messages on any device.",
|
"Regain access to your account and recover encryption keys stored in this session. Without them, you won’t be able to read all of your secure messages in any session.": "Regain access to your account and recover encryption keys stored in this session. Without them, you won’t be able to read all of your secure messages in any session.",
|
||||||
"Enter your password to sign in and regain access to your account.": "Enter your password to sign in and regain access to your account.",
|
"Enter your password to sign in and regain access to your account.": "Enter your password to sign in and regain access to your account.",
|
||||||
"Forgotten your password?": "Forgotten your password?",
|
"Forgotten your password?": "Forgotten your password?",
|
||||||
"Sign in and regain access to your account.": "Sign in and regain access to your account.",
|
"Sign in and regain access to your account.": "Sign in and regain access to your account.",
|
||||||
"You cannot sign in to your account. Please contact your homeserver admin for more information.": "You cannot sign in to your account. Please contact your homeserver admin for more information.",
|
"You cannot sign in to your account. Please contact your homeserver admin for more information.": "You cannot sign in to your account. Please contact your homeserver admin for more information.",
|
||||||
"You're signed out": "You're signed out",
|
"You're signed out": "You're signed out",
|
||||||
"Clear personal data": "Clear personal data",
|
"Clear personal data": "Clear personal data",
|
||||||
"Warning: Your personal data (including encryption keys) is still stored on this device. Clear it if you're finished using this device, or want to sign in to another account.": "Warning: Your personal data (including encryption keys) is still stored on this device. Clear it if you're finished using this device, or want to sign in to another account.",
|
"Warning: Your personal data (including encryption keys) is still stored in this session. Clear it if you're finished using this session, or want to sign in to another account.": "Warning: Your personal data (including encryption keys) is still stored in this session. Clear it if you're finished using this session, or want to sign in to another account.",
|
||||||
"Commands": "Commands",
|
"Commands": "Commands",
|
||||||
"Command Autocomplete": "Command Autocomplete",
|
"Command Autocomplete": "Command Autocomplete",
|
||||||
"Community Autocomplete": "Community Autocomplete",
|
"Community Autocomplete": "Community Autocomplete",
|
||||||
|
@ -1991,6 +1990,7 @@
|
||||||
"NOT verified": "NOT verified",
|
"NOT verified": "NOT verified",
|
||||||
"Blacklisted": "Blacklisted",
|
"Blacklisted": "Blacklisted",
|
||||||
"verified": "verified",
|
"verified": "verified",
|
||||||
|
"Device ID": "Device ID",
|
||||||
"Verification": "Verification",
|
"Verification": "Verification",
|
||||||
"Ed25519 fingerprint": "Ed25519 fingerprint",
|
"Ed25519 fingerprint": "Ed25519 fingerprint",
|
||||||
"User ID": "User ID",
|
"User ID": "User ID",
|
||||||
|
@ -2000,9 +2000,8 @@
|
||||||
"Algorithm": "Algorithm",
|
"Algorithm": "Algorithm",
|
||||||
"unencrypted": "unencrypted",
|
"unencrypted": "unencrypted",
|
||||||
"Decryption error": "Decryption error",
|
"Decryption error": "Decryption error",
|
||||||
"Session ID": "Session ID",
|
|
||||||
"Event information": "Event information",
|
"Event information": "Event information",
|
||||||
"Sender device information": "Sender device information",
|
"Sender session information": "Sender session information",
|
||||||
"Passphrases must match": "Passphrases must match",
|
"Passphrases must match": "Passphrases must match",
|
||||||
"Passphrase must not be empty": "Passphrase must not be empty",
|
"Passphrase must not be empty": "Passphrase must not be empty",
|
||||||
"Export room keys": "Export room keys",
|
"Export room keys": "Export room keys",
|
||||||
|
@ -2020,9 +2019,9 @@
|
||||||
"Restore": "Restore",
|
"Restore": "Restore",
|
||||||
"Enter your account password to confirm the upgrade:": "Enter your account password to confirm the upgrade:",
|
"Enter your account password to confirm the upgrade:": "Enter your account password to confirm the upgrade:",
|
||||||
"You'll need to authenticate with the server to confirm the upgrade.": "You'll need to authenticate with the server to confirm the upgrade.",
|
"You'll need to authenticate with the server to confirm the upgrade.": "You'll need to authenticate with the server to confirm the upgrade.",
|
||||||
"Upgrade this device to allow it to verify other devices, granting them access to encrypted messages and marking them as trusted for other users.": "Upgrade this device to allow it to verify other devices, granting them access to encrypted messages and marking them as trusted for other users.",
|
"Upgrade this session to allow it to verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.": "Upgrade this session to allow it to verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.",
|
||||||
"Great! This passphrase looks strong enough.": "Great! This passphrase looks strong enough.",
|
"Great! This passphrase looks strong enough.": "Great! This passphrase looks strong enough.",
|
||||||
"Set up encryption on this device to allow it to verify other devices, granting them access to encrypted messages and marking them as trusted for other users.": "Set up encryption on this device to allow it to verify other devices, granting them access to encrypted messages and marking them as trusted for other users.",
|
"Set up encryption on this session to allow it to verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.": "Set up encryption on this session to allow it to verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.",
|
||||||
"Secure your encryption keys with a passphrase. For maximum security this should be different to your account password:": "Secure your encryption keys with a passphrase. For maximum security this should be different to your account password:",
|
"Secure your encryption keys with a passphrase. For maximum security this should be different to your account password:": "Secure your encryption keys with a passphrase. For maximum security this should be different to your account password:",
|
||||||
"Enter a passphrase": "Enter a passphrase",
|
"Enter a passphrase": "Enter a passphrase",
|
||||||
"Back up my encryption keys, securing them with the same passphrase": "Back up my encryption keys, securing them with the same passphrase",
|
"Back up my encryption keys, securing them with the same passphrase": "Back up my encryption keys, securing them with the same passphrase",
|
||||||
|
@ -2044,7 +2043,7 @@
|
||||||
"<b>Print it</b> and store it somewhere safe": "<b>Print it</b> and store it somewhere safe",
|
"<b>Print it</b> and store it somewhere safe": "<b>Print it</b> and store it somewhere safe",
|
||||||
"<b>Save it</b> on a USB key or backup drive": "<b>Save it</b> on a USB key or backup drive",
|
"<b>Save it</b> on a USB key or backup drive": "<b>Save it</b> on a USB key or backup drive",
|
||||||
"<b>Copy it</b> to your personal cloud storage": "<b>Copy it</b> to your personal cloud storage",
|
"<b>Copy it</b> to your personal cloud storage": "<b>Copy it</b> to your personal cloud storage",
|
||||||
"This device can now verify other devices, granting them access to encrypted messages and marking them as trusted for other users.": "This device can now verify other devices, granting them access to encrypted messages and marking them as trusted for other users.",
|
"This session can now verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.": "This session can now verify other sessions, granting them access to encrypted messages and marking them as trusted for other users.",
|
||||||
"Verify other users in their profile.": "Verify other users in their profile.",
|
"Verify other users in their profile.": "Verify other users in their profile.",
|
||||||
"Upgrade your encryption": "Upgrade your encryption",
|
"Upgrade your encryption": "Upgrade your encryption",
|
||||||
"Recovery key": "Recovery key",
|
"Recovery key": "Recovery key",
|
||||||
|
@ -2063,7 +2062,7 @@
|
||||||
"As a safety net, you can use it to restore your encrypted message history if you forget your Recovery Passphrase.": "As a safety net, you can use it to restore your encrypted message history if you forget your Recovery Passphrase.",
|
"As a safety net, you can use it to restore your encrypted message history if you forget your Recovery Passphrase.": "As a safety net, you can use it to restore your encrypted message history if you forget your Recovery Passphrase.",
|
||||||
"As a safety net, you can use it to restore your encrypted message history.": "As a safety net, you can use it to restore your encrypted message history.",
|
"As a safety net, you can use it to restore your encrypted message history.": "As a safety net, you can use it to restore your encrypted message history.",
|
||||||
"Your keys are being backed up (the first backup could take a few minutes).": "Your keys are being backed up (the first backup could take a few minutes).",
|
"Your keys are being backed up (the first backup could take a few minutes).": "Your keys are being backed up (the first backup could take a few minutes).",
|
||||||
"Without setting up Secure Message Recovery, you won't be able to restore your encrypted message history if you log out or use another device.": "Without setting up Secure Message Recovery, you won't be able to restore your encrypted message history if you log out or use another device.",
|
"Without setting up Secure Message Recovery, you won't be able to restore your encrypted message history if you log out or use another session.": "Without setting up Secure Message Recovery, you won't be able to restore your encrypted message history if you log out or use another session.",
|
||||||
"Set up Secure Message Recovery": "Set up Secure Message Recovery",
|
"Set up Secure Message Recovery": "Set up Secure Message Recovery",
|
||||||
"Secure your backup with a passphrase": "Secure your backup with a passphrase",
|
"Secure your backup with a passphrase": "Secure your backup with a passphrase",
|
||||||
"Starting backup...": "Starting backup...",
|
"Starting backup...": "Starting backup...",
|
||||||
|
@ -2077,12 +2076,12 @@
|
||||||
"New Recovery Method": "New Recovery Method",
|
"New Recovery Method": "New Recovery Method",
|
||||||
"A new recovery passphrase and key for Secure Messages have been detected.": "A new recovery passphrase and key for Secure Messages have been detected.",
|
"A new recovery passphrase and key for Secure Messages have been detected.": "A new recovery passphrase and key for Secure Messages have been detected.",
|
||||||
"If you didn't set the new recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.": "If you didn't set the new recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.",
|
"If you didn't set the new recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.": "If you didn't set the new recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.",
|
||||||
"This device is encrypting history using the new recovery method.": "This device is encrypting history using the new recovery method.",
|
"This session is encrypting history using the new recovery method.": "This session is encrypting history using the new recovery method.",
|
||||||
"Go to Settings": "Go to Settings",
|
"Go to Settings": "Go to Settings",
|
||||||
"Set up Secure Messages": "Set up Secure Messages",
|
"Set up Secure Messages": "Set up Secure Messages",
|
||||||
"Recovery Method Removed": "Recovery Method Removed",
|
"Recovery Method Removed": "Recovery Method Removed",
|
||||||
"This device has detected that your recovery passphrase and key for Secure Messages have been removed.": "This device has detected that your recovery passphrase and key for Secure Messages have been removed.",
|
"This session has detected that your recovery passphrase and key for Secure Messages have been removed.": "This session has detected that your recovery passphrase and key for Secure Messages have been removed.",
|
||||||
"If you did this accidentally, you can setup Secure Messages on this device which will re-encrypt this device's message history with a new recovery method.": "If you did this accidentally, you can setup Secure Messages on this device which will re-encrypt this device's message history with a new recovery method.",
|
"If you did this accidentally, you can setup Secure Messages on this session which will re-encrypt this session's message history with a new recovery method.": "If you did this accidentally, you can setup Secure Messages on this session which will re-encrypt this session's message history with a new recovery method.",
|
||||||
"If you didn't remove the recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.": "If you didn't remove the recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.",
|
"If you didn't remove the recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.": "If you didn't remove the recovery method, an attacker may be trying to access your account. Change your account password and set a new recovery method immediately in Settings.",
|
||||||
"If disabled, messages from encrypted rooms won't appear in search results.": "If disabled, messages from encrypted rooms won't appear in search results.",
|
"If disabled, messages from encrypted rooms won't appear in search results.": "If disabled, messages from encrypted rooms won't appear in search results.",
|
||||||
"Disable": "Disable",
|
"Disable": "Disable",
|
||||||
|
|
|
@ -144,7 +144,7 @@ export const SETTINGS = {
|
||||||
},
|
},
|
||||||
"feature_cross_signing": {
|
"feature_cross_signing": {
|
||||||
isFeature: true,
|
isFeature: true,
|
||||||
displayName: _td("Enable cross-signing to verify per-user instead of per-device (in development)"),
|
displayName: _td("Enable cross-signing to verify per-user instead of per-session (in development)"),
|
||||||
supportedLevels: LEVELS_FEATURE,
|
supportedLevels: LEVELS_FEATURE,
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
|
@ -348,8 +348,8 @@ export const SETTINGS = {
|
||||||
supportedLevels: ['room-device', 'device'],
|
supportedLevels: ['room-device', 'device'],
|
||||||
supportedLevelsAreOrdered: true,
|
supportedLevelsAreOrdered: true,
|
||||||
displayName: {
|
displayName: {
|
||||||
"default": _td('Never send encrypted messages to unverified devices from this device'),
|
"default": _td('Never send encrypted messages to unverified sessions from this session'),
|
||||||
"room-device": _td('Never send encrypted messages to unverified devices in this room from this device'),
|
"room-session": _td('Never send encrypted messages to unverified sessions in this room from this session'),
|
||||||
},
|
},
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue