-
-
Notifications
You must be signed in to change notification settings - Fork 609
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Remove deprecated methods and attributes of MatrixClient
#4659
Remove deprecated methods and attributes of MatrixClient
#4659
Conversation
MatrixClient
MatrixClient
5140262
to
808f7ee
Compare
- `Embedded.spec.ts`: casting since `encryptAndSendToDevices` is removed from `MatrixClient`. - `room.spec.ts`: remove deprecated usage of `MatrixClient.crypto` - `matrix-client.spec.ts` & `matrix-client-methods.spec.ts`: remove calls of deprecated methods of `MatrixClient`
80891ce
to
0b31afd
Compare
65e8795
to
89ac700
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks sensible to me, will leave your question to the crypto experts. Looking forward to getting a lot of lines out of client.js.
Related: element-hq/element-web#17488 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
looks good to me in general
* Fetches the latest capabilities from the homeserver, ignoring any cached | ||
* versions. The newly returned version is cached. | ||
* | ||
* @returns A promise which resolves to the capabilities of the homeserver | ||
*/ | ||
public fetchCapabilities(): Promise<Capabilities> { | ||
return this.serverCapabilitiesService.fetchCapabilities(); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a shame that git's diff algorithm makes such a mess of this.
If you look at it from the commandline with git show --patience
, you get a much nicer diff, showing that fetchCapabilities
, initRustCrypto
and secretStorage
are unchanged. I think the problem is basically that the change is so large that we've exhausted the standard diff algorithm's ability to look ahead to match up lines.
For future reference, it might be nice to break down massive removals like this into separate commits, so that they can be reviewed via the github UI.
/** | ||
* Set the global override for whether the client should ever send encrypted | ||
* messages to unverified devices. This provides the default for rooms which | ||
* do not specify a value. | ||
* | ||
* @param value - whether to blacklist all unverified devices by default | ||
* | ||
* @deprecated Prefer direct access to {@link CryptoApi.globalBlacklistUnverifiedDevices}: | ||
* | ||
* ```javascript | ||
* client.getCrypto().globalBlacklistUnverifiedDevices = value; | ||
* ``` | ||
*/ | ||
public setGlobalBlacklistUnverifiedDevices(value: boolean): boolean { | ||
if (!this.cryptoBackend) { | ||
throw new Error("End-to-end encryption disabled"); | ||
} | ||
this.cryptoBackend.globalBlacklistUnverifiedDevices = value; | ||
return value; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might be worth calling out, for the record, that some of the removed methods in MatrixClient do actually work in Rust Crypto.
It's definitely a good time to clean these out, so not suggesting we change anything; just making a note.
// the prepare request should complete successfully. | ||
await p; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
isn't this still useful?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No it isn't, prepareToEncrypt
is not asynchronous.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[that looks like a bug, tbh]
`ICreateClientOpts.deviceToImport` was used in the legacy cryto. The rust crypto doesn't support to import devices in this way.
`globalErrorOnUnknownDevices` is not used in the rust-crypto. The API is marked as unstable, we can remove it.
04363e4
to
c5d6e35
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
lgtm
89cec0a
into
florianduros/rip-out-legacy-crypto/remove-legacy-crypto
Task element-hq/element-web#26922
Part of #4653
This PR removes the deprecated methods and attributes of the the
MatrixClient
. The legacy crypto relies on using deprecated methods of theMatrixClient
and theMatrixClient
is also using methods from the legacy crypto.In order to not have a gigantic PR where both the deprecated methods of the
MatrixClient
and the legacy crypto are removed, only theMatrixClient
is changed here (with the related tests). Accordingly, the legacy crypto tests and lint are in failure.Since the PR will be merged in
florianduros/rip-out-legacy-crypto/remove-legacy-crypto
and not indevelop
, we can accept that the lint and the legacy crypto tests are in failure in the feature branch until the legacy crypto is removed.The unit (not related to legacy crypto) and integ tests are updated to pass. However the cleaning of theses (remove
isNewBackendOnly
, run on eachbackend
etc) tests will be done in a dedicated PR.