2020-02-21 15:54:05 +00:00
|
|
|
// Copyright 2020 Damir Jelić
|
|
|
|
// Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2020-02-21 13:29:46 +00:00
|
|
|
//! This crate implements a [Matrix](https://matrix.org/) client library.
|
2020-03-19 12:55:58 +00:00
|
|
|
//!
|
2020-10-12 10:27:37 +00:00
|
|
|
//! # Enabling logging
|
|
|
|
//!
|
|
|
|
//! Users of the matrix-sdk crate can enable log output by depending on the `tracing-subscriber`
|
|
|
|
//! crate and including the following line in their application (e.g. at the start of `main`):
|
|
|
|
//!
|
|
|
|
//! ```rust
|
|
|
|
//! tracing_subscriber::fmt::init();
|
|
|
|
//! ```
|
|
|
|
//!
|
|
|
|
//! The log output is controlled via the `RUST_LOG` environment variable by setting it to one of
|
|
|
|
//! the `error`, `warn`, `info`, `debug` or `trace` levels. The output is printed to stdout.
|
|
|
|
//!
|
|
|
|
//! The `RUST_LOG` variable also supports a more advanced syntax for filtering log output more
|
|
|
|
//! precisely, for instance with crate-level granularity. For more information on this, check out
|
|
|
|
//! the [tracing_subscriber
|
|
|
|
//! documentation](https://tracing.rs/tracing_subscriber/filter/struct.envfilter).
|
|
|
|
//!
|
|
|
|
//! # Crate Feature Flags
|
2020-03-19 12:55:58 +00:00
|
|
|
//!
|
|
|
|
//! The following crate feature flags are available:
|
|
|
|
//!
|
|
|
|
//! * `encryption`: Enables end-to-end encryption support in the library.
|
2021-01-27 14:29:42 +00:00
|
|
|
//! * `sled_cryptostore`: Enables a Sled based store for the encryption
|
2020-03-19 12:55:58 +00:00
|
|
|
//! keys. If this is disabled and `encryption` support is enabled the keys will
|
|
|
|
//! by default be stored only in memory and thus lost after the client is
|
|
|
|
//! destroyed.
|
2021-01-21 17:21:00 +00:00
|
|
|
//! * `markdown`: Support for sending markdown formatted messages.
|
2020-08-26 13:17:41 +00:00
|
|
|
//! * `socks`: Enables SOCKS support in reqwest, the default HTTP client.
|
2021-03-23 14:30:40 +00:00
|
|
|
//! * `sso_login`: Enables SSO login with a local http server.
|
2021-04-26 15:31:25 +00:00
|
|
|
//! * `require_auth_for_profile_requests`: Whether to send the access token in the authentication
|
|
|
|
//! header when calling endpoints that retrieve profile data. This matches the synapse
|
|
|
|
//! configuration `require_auth_for_profile_requests`. Enabled by default.
|
2020-05-13 10:47:24 +00:00
|
|
|
|
|
|
|
#![deny(
|
|
|
|
missing_debug_implementations,
|
|
|
|
dead_code,
|
|
|
|
missing_docs,
|
|
|
|
trivial_casts,
|
|
|
|
trivial_numeric_casts,
|
|
|
|
unused_extern_crates,
|
|
|
|
unused_import_braces,
|
|
|
|
unused_qualifications
|
|
|
|
)]
|
2020-08-13 10:18:24 +00:00
|
|
|
#![cfg_attr(feature = "docs", feature(doc_cfg))]
|
2019-10-20 11:56:46 +00:00
|
|
|
|
2020-08-21 16:32:15 +00:00
|
|
|
#[cfg(not(any(feature = "native-tls", feature = "rustls-tls",)))]
|
|
|
|
compile_error!("one of 'native-tls' or 'rustls-tls' features must be enabled");
|
|
|
|
|
|
|
|
#[cfg(all(feature = "native-tls", feature = "rustls-tls",))]
|
|
|
|
compile_error!("only one of 'native-tls' or 'rustls-tls' features can be enabled");
|
|
|
|
|
2021-03-23 14:30:40 +00:00
|
|
|
#[cfg(all(feature = "sso_login", target_arch = "wasm32"))]
|
|
|
|
compile_error!("'sso_login' cannot be enabled on 'wasm32' arch");
|
|
|
|
|
2020-08-17 13:34:05 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
|
|
|
#[cfg_attr(feature = "docs", doc(cfg(encryption)))]
|
2021-02-16 08:42:23 +00:00
|
|
|
pub use matrix_sdk_base::crypto::{EncryptionInfo, LocalTrust};
|
2020-12-19 15:37:35 +00:00
|
|
|
pub use matrix_sdk_base::{
|
2021-04-02 17:49:43 +00:00
|
|
|
Error as BaseError, Room as BaseRoom, RoomInfo, RoomMember as BaseRoomMember, RoomType,
|
|
|
|
Session, StateChanges, StoreError,
|
2020-12-19 15:37:35 +00:00
|
|
|
};
|
2020-08-13 10:18:24 +00:00
|
|
|
|
2021-04-19 10:26:10 +00:00
|
|
|
pub use bytes::Bytes;
|
2020-05-07 06:51:59 +00:00
|
|
|
pub use matrix_sdk_common::*;
|
2020-08-26 12:47:43 +00:00
|
|
|
pub use reqwest;
|
2019-10-20 11:56:46 +00:00
|
|
|
|
2020-05-08 09:40:33 +00:00
|
|
|
mod client;
|
2020-05-08 10:39:36 +00:00
|
|
|
mod error;
|
2021-03-17 10:53:18 +00:00
|
|
|
mod event_handler;
|
2020-07-29 08:56:18 +00:00
|
|
|
mod http_client;
|
2021-03-05 13:55:06 +00:00
|
|
|
/// High-level room API
|
|
|
|
pub mod room;
|
2021-04-02 17:49:43 +00:00
|
|
|
/// High-level room API
|
|
|
|
mod room_member;
|
2020-08-04 09:41:20 +00:00
|
|
|
|
2020-08-17 13:34:05 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
|
|
|
mod device;
|
2020-08-04 09:41:20 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
2020-07-29 12:19:47 +00:00
|
|
|
mod sas;
|
2020-12-09 16:18:23 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
|
|
|
mod verification_request;
|
2020-07-29 12:19:47 +00:00
|
|
|
|
2021-04-01 17:25:31 +00:00
|
|
|
pub use client::{Client, ClientConfig, LoopCtrl, RequestConfig, SyncSettings};
|
2020-08-17 13:34:05 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
|
|
|
#[cfg_attr(feature = "docs", doc(cfg(encryption)))]
|
|
|
|
pub use device::Device;
|
2021-01-31 17:09:03 +00:00
|
|
|
pub use error::{Error, HttpError, Result};
|
2021-03-17 10:53:18 +00:00
|
|
|
pub use event_handler::{CustomEvent, EventHandler};
|
2020-08-11 15:25:33 +00:00
|
|
|
pub use http_client::HttpSend;
|
2021-04-02 17:49:43 +00:00
|
|
|
pub use room_member::RoomMember;
|
2020-07-29 12:19:47 +00:00
|
|
|
#[cfg(feature = "encryption")]
|
2020-08-13 10:18:24 +00:00
|
|
|
#[cfg_attr(feature = "docs", doc(cfg(encryption)))]
|
2020-07-29 12:19:47 +00:00
|
|
|
pub use sas::Sas;
|
2019-10-30 18:30:55 +00:00
|
|
|
|
2020-05-13 13:02:28 +00:00
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
2019-11-26 18:19:22 +00:00
|
|
|
pub(crate) const VERSION: &str = env!("CARGO_PKG_VERSION");
|