diff --git a/Cargo.lock b/Cargo.lock index ba847bbf2..3b2c59fd9 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -372,9 +372,9 @@ checksum = "7a40729d2133846d9ed0ea60a8b9541bccddab49cd30f0715a1da672fe9a2524" [[package]] name = "async-trait" -version = "0.1.63" +version = "0.1.64" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eff18d764974428cf3a9328e23fc5c986f5fbed46e6cd4cdf42544df5d297ec1" +checksum = "1cd7fce9ba8c3c042128ce72d8b2ddbf3a05747efb67ea0313c635e10bda47a2" dependencies = [ "proc-macro2", "quote", @@ -615,9 +615,9 @@ checksum = "14c189c53d098945499cdfa7ecc63567cf3886b3332b312a5b4585d8d3a6a610" [[package]] name = "bytes" -version = "1.3.0" +version = "1.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfb24e866b15a1af2a1b663f10c6b6b8f397a84aadb828f12e5b289ec23a3a3c" +checksum = "89b2fd2a0dcf38d7971e2194b6b6eebab45ae01067456a7fd93d5547a61b70be" [[package]] name = "cast" @@ -627,9 +627,9 @@ checksum = "37b2a672a2cb129a2e41c10b1224bb368f9f37a2b16b612598138befd7b37eb5" [[package]] name = "cc" -version = "1.0.78" +version = "1.0.79" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a20104e2335ce8a659d6dd92a51a767a0c062599c73b343fd152cb401e828c3d" +checksum = "50d30906286121d95be3d479533b458f87493b30a4b5f79a607db8f5d11aa91f" dependencies = [ "jobserver", ] @@ -1117,9 +1117,9 @@ dependencies = [ [[package]] name = "cxx" -version = "1.0.87" +version = "1.0.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b61a7545f753a88bcbe0a70de1fcc0221e10bfc752f576754fa91e663db1622e" +checksum = "322296e2f2e5af4270b54df9e85a02ff037e271af20ba3e7fe1575515dc840b8" dependencies = [ "cc", "cxxbridge-flags", @@ -1129,9 +1129,9 @@ dependencies = [ [[package]] name = "cxx-build" -version = "1.0.87" +version = "1.0.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f464457d494b5ed6905c63b0c4704842aba319084a0a3561cdc1359536b53200" +checksum = "017a1385b05d631e7875b1f151c9f012d37b53491e2a87f65bff5c262b2111d8" dependencies = [ "cc", "codespan-reporting", @@ -1144,15 +1144,15 @@ dependencies = [ [[package]] name = "cxxbridge-flags" -version = "1.0.87" +version = "1.0.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "43c7119ce3a3701ed81aca8410b9acf6fc399d2629d057b87e2efa4e63a3aaea" +checksum = "c26bbb078acf09bc1ecda02d4223f03bdd28bd4874edcb0379138efc499ce971" [[package]] name = "cxxbridge-macro" -version = "1.0.87" +version = "1.0.88" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "65e07508b90551e610910fa648a1878991d367064997a596135b86df30daf07e" +checksum = "357f40d1f06a24b60ae1fe122542c1fb05d28d32acb2aed064e84bc2ad1e252e" dependencies = [ "proc-macro2", "quote", @@ -1161,7 +1161,7 @@ dependencies = [ [[package]] name = "daemon" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "clap", "clap_complete", @@ -1360,9 +1360,9 @@ checksum = "c9b0705efd4599c15a38151f4721f7bc388306f61084d3bfd50bd07fbca5cb60" [[package]] name = "either" -version = "1.8.0" +version = "1.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "90e5c1c8368803113bf0c9584fc495a58b86dc8a29edbf8fe877d21d9507e797" +checksum = "7fcaabb2fef8c910e7f4c7ce9f67a1283a1715879a7c230ca9d6d1ae31f16d91" [[package]] name = "encode_unicode" @@ -1520,9 +1520,9 @@ checksum = "2022715d62ab30faffd124d40b76f4134a550a87792276512b18d63272333394" [[package]] name = "futures" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "38390104763dc37a5145a53c29c63c1290b5d316d6086ec32c293f6736051bb0" +checksum = "13e2792b0ff0340399d58445b88fd9770e3489eff258a4cbc1523418f12abf84" dependencies = [ "futures-channel", "futures-core", @@ -1535,9 +1535,9 @@ dependencies = [ [[package]] name = "futures-channel" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "52ba265a92256105f45b719605a571ffe2d1f0fea3807304b522c1d778f79eed" +checksum = "2e5317663a9089767a1ec00a487df42e0ca174b61b4483213ac24448e4664df5" dependencies = [ "futures-core", "futures-sink", @@ -1556,15 +1556,15 @@ dependencies = [ [[package]] name = "futures-core" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "04909a7a7e4633ae6c4a9ab280aeb86da1236243a77b694a49eacd659a4bd3ac" +checksum = "ec90ff4d0fe1f57d600049061dc6bb68ed03c7d2fbd697274c41805dcb3f8608" [[package]] name = "futures-executor" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7acc85df6714c176ab5edf386123fafe217be88c0840ec11f199441134a074e2" +checksum = "e8de0a35a6ab97ec8869e32a2473f4b1324459e14c29275d14b10cb1fd19b50e" dependencies = [ "futures-core", "futures-task", @@ -1573,9 +1573,9 @@ dependencies = [ [[package]] name = "futures-io" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "00f5fb52a06bdcadeb54e8d3671f8888a39697dcb0b81b23b55174030427f4eb" +checksum = "bfb8371b6fb2aeb2d280374607aeabfc99d95c72edfe51692e42d3d7f0d08531" [[package]] name = "futures-lite" @@ -1594,9 +1594,9 @@ dependencies = [ [[package]] name = "futures-macro" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bdfb8ce053d86b91919aad980c220b1fb8401a9394410e1c289ed7e66b61835d" +checksum = "95a73af87da33b5acf53acfebdc339fe592ecf5357ac7c0a7734ab9d8c876a70" dependencies = [ "proc-macro2", "quote", @@ -1605,21 +1605,21 @@ dependencies = [ [[package]] name = "futures-sink" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39c15cf1a4aa79df40f1bb462fb39676d0ad9e366c2a33b590d7c66f4f81fcf9" +checksum = "f310820bb3e8cfd46c80db4d7fb8353e15dfff853a127158425f31e0be6c8364" [[package]] name = "futures-task" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2ffb393ac5d9a6eaa9d3fdf37ae2776656b706e200c8e16b1bdb227f5198e6ea" +checksum = "dcf79a1bf610b10f42aea489289c5a2c478a786509693b80cd39c44ccd936366" [[package]] name = "futures-util" -version = "0.3.25" +version = "0.3.26" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "197676987abd2f9cadff84926f410af1c183608d36641465df73ae8211dc65d6" +checksum = "9c1d6de3acfef38d2be4b1f543f553131788603495be83da675e180c8d6b7bd1" dependencies = [ "futures-channel", "futures-core", @@ -2250,7 +2250,7 @@ dependencies = [ [[package]] name = "kanidm-ipa-sync" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "base64urlsafedata", "chrono", @@ -2274,7 +2274,7 @@ dependencies = [ [[package]] name = "kanidm_client" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "kanidm_proto", "reqwest", @@ -2291,7 +2291,7 @@ dependencies = [ [[package]] name = "kanidm_proto" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "base32", "base64urlsafedata", @@ -2310,7 +2310,7 @@ dependencies = [ [[package]] name = "kanidm_tools" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "clap", "clap_complete", @@ -2337,7 +2337,7 @@ dependencies = [ [[package]] name = "kanidm_unix_int" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "bytes", "clap", @@ -2369,7 +2369,7 @@ dependencies = [ [[package]] name = "kanidmd_core" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "async-trait", "chrono", @@ -2402,7 +2402,7 @@ dependencies = [ [[package]] name = "kanidmd_lib" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "async-std", "async-trait", @@ -2471,7 +2471,7 @@ dependencies = [ [[package]] name = "kanidmd_testkit" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "compact_jwt", "futures", @@ -2493,7 +2493,7 @@ dependencies = [ [[package]] name = "kanidmd_web_ui" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "compact_jwt", "gloo", @@ -2884,7 +2884,7 @@ dependencies = [ [[package]] name = "nss_kanidm" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "kanidm_unix_int", "lazy_static", @@ -3091,7 +3091,7 @@ dependencies = [ [[package]] name = "orca" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "clap", "crossbeam", @@ -3131,7 +3131,7 @@ checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" [[package]] name = "pam_kanidm" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "kanidm_unix_int", "libc", @@ -3420,7 +3420,7 @@ dependencies = [ [[package]] name = "profiles" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "base64 0.13.1", "serde", @@ -3873,9 +3873,9 @@ checksum = "ddccb15bcce173023b3fedd9436f882a0739b8dfb45e4f6b6002bee5929f61b2" [[package]] name = "security-framework" -version = "2.8.1" +version = "2.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7c4437699b6d34972de58652c68b98cb5b53a4199ab126db8e20ec8ded29a721" +checksum = "a332be01508d814fed64bf28f798a146d73792121129962fdf335bb3c49a4254" dependencies = [ "bitflags", "core-foundation", @@ -4126,7 +4126,7 @@ dependencies = [ [[package]] name = "sketching" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" dependencies = [ "async-trait", "num_enum", @@ -4554,9 +4554,9 @@ checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c" [[package]] name = "tokio" -version = "1.24.2" +version = "1.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "597a12a59981d9e3c38d216785b0c37399f6e415e8d0712047620f189371b0bb" +checksum = "c8e00990ebabbe4c14c08aca901caed183ecd5c09562a12c824bb53d3c3fd3af" dependencies = [ "autocfg", "bytes", @@ -4646,9 +4646,9 @@ checksum = "4553f467ac8e3d374bc9a177a26801e5d0f9b211aa1673fb137a403afd1c9cf5" [[package]] name = "toml_edit" -version = "0.18.0" +version = "0.18.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "729bfd096e40da9c001f778f5cdecbd2957929a24e10e5883d9392220a751581" +checksum = "56c59d8dd7d0dcbc6428bf7aa2f0e823e26e43b3c9aca15bbc9475d23e5fa12b" dependencies = [ "indexmap", "nom8", diff --git a/Cargo.toml b/Cargo.toml index b61e85fa4..37f55d293 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -25,12 +25,12 @@ members = [ ] [workspace.package] -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" authors = [ "William Brown ", "James Hodgkinson ", ] -rust-version = "1.64" +rust-version = "1.66" edition = "2021" license = "MPL-2.0" homepage = "https://github.com/kanidm/kanidm/" diff --git a/RELEASE_NOTES.md b/RELEASE_NOTES.md index 3aa00453e..1924934ce 100644 --- a/RELEASE_NOTES.md +++ b/RELEASE_NOTES.md @@ -14,6 +14,37 @@ report it to our [issue tracker]. # Release Notes +## 2023-02-01 - Kanidm 1.1.0-alpha11 + +This is the eleventh alpha series release of the Kanidm Identity Management project. Alpha releases are +to help get feedback and ideas from the community on how we can continue to make this project better +for a future supported release. + +The project is shaping up very nicely, and a beta will be coming soon! The main reason we haven't done +so yet is we haven't decided if we want to commit to the current API layout and freeze it yet. There +are still things we want to change there. Otherwise the server is stable and reliable. + +### Release Highlights + +- Support /etc/skel home dir templates in kanidm-unixd +- Improve warning messages for openssl when a cryptographic routine is not supported +- Support windows for server tests +- Add a kanidm tools container +- Initial support for live sync/import of users and groups from FreeIPA +- Oauth2 session logout and global logout support +- UI polish based on hint flags to dynamically enable/disable elements +- Oauth2 single sign on application portal +- Support dn=token for ldap client binds +- Trap more signals for daemons +- Mail read permission group +- Oauth2 add a groups claim +- LDAP support for mail primary and alternate address selectors in queries +- Fix handling of virtual attrs with '\*' searches in ldap +- Support multiple TOTP on accounts +- Add kanidmd healthcheck for containers +- Improve the access control module to evaluate access in a clearer way +- Allow synced users to correct modify their local sessions + ## 2022-11-01 - Kanidm 1.1.0-alpha10 This is the tenth alpha series release of the Kanidm Identity Management project. Alpha releases are diff --git a/kanidmd_web_ui/Cargo.toml b/kanidmd_web_ui/Cargo.toml index 7f929dfb9..4b58718c3 100644 --- a/kanidmd_web_ui/Cargo.toml +++ b/kanidmd_web_ui/Cargo.toml @@ -2,12 +2,12 @@ name = "kanidmd_web_ui" description = "Kanidm Server Web User Interface" documentation = "https://docs.rs/kanidm/latest/kanidm/" -version = "1.1.0-alpha.11-dev" +version = "1.1.0-alpha.11" authors = [ "William Brown ", "James Hodgkinson ", ] -rust-version = "1.59" +rust-version = "1.66" edition = "2021" license = "MPL-2.0" homepage = "https://github.com/kanidm/kanidm/" diff --git a/kanidmd_web_ui/pkg/README.md b/kanidmd_web_ui/pkg/README.md index c376d813a..51ed80e97 100644 --- a/kanidmd_web_ui/pkg/README.md +++ b/kanidmd_web_ui/pkg/README.md @@ -99,7 +99,9 @@ of resource overhead and difficulty for administration. Kanidm aims to have the features richness of FreeIPA, but without the resource and administration overheads. If you want a complete IDM package, but in a lighter footprint and easier to manage, then -Kanidm is probably for you. +Kanidm is probably for you. In testing with 3000 users + 1500 groups, Kanidm is 3 times faster for +search operations and 5 times faster for modification and addition of entries (your results may +differ however, but generally Kanidm is much faster than FreeIPA). ## Developer Getting Started diff --git a/kanidmd_web_ui/pkg/kanidmd_web_ui.js b/kanidmd_web_ui/pkg/kanidmd_web_ui.js index fc25f7ae0..2735d0d08 100644 --- a/kanidmd_web_ui/pkg/kanidmd_web_ui.js +++ b/kanidmd_web_ui/pkg/kanidmd_web_ui.js @@ -231,21 +231,21 @@ function addBorrowedObject(obj) { heap[--stack_pointer] = obj; return stack_pointer; } -function __wbg_adapter_50(arg0, arg1, arg2) { +function __wbg_adapter_48(arg0, arg1, arg2) { try { - wasm._dyn_core__ops__function__FnMut___A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h0984b1b8ad634c42(arg0, arg1, addBorrowedObject(arg2)); + wasm._dyn_core__ops__function__FnMut___A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hb3a2c74d38e7e9b9(arg0, arg1, addBorrowedObject(arg2)); } finally { heap[stack_pointer++] = undefined; } } -function __wbg_adapter_53(arg0, arg1, arg2) { - wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h721315d2d8351be6(arg0, arg1, addHeapObject(arg2)); +function __wbg_adapter_51(arg0, arg1, arg2) { + wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hbcd98e15d2cb3414(arg0, arg1, addHeapObject(arg2)); } -function __wbg_adapter_56(arg0, arg1, arg2) { +function __wbg_adapter_54(arg0, arg1, arg2) { try { - wasm._dyn_core__ops__function__FnMut___A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h6abde9f4b8744c87(arg0, arg1, addBorrowedObject(arg2)); + wasm._dyn_core__ops__function__FnMut___A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__ha2eb64c9ea080449(arg0, arg1, addBorrowedObject(arg2)); } finally { heap[stack_pointer++] = undefined; } @@ -404,7 +404,7 @@ function getImports() { const ret = false; return ret; }; - imports.wbg.__wbg_modalhidebyid_130cc6453fa7b55b = function(arg0, arg1) { + imports.wbg.__wbg_modalhidebyid_9076f9d79351b537 = function(arg0, arg1) { modal_hide_by_id(getStringFromWasm0(arg0, arg1)); }; imports.wbg.__wbg_subtreeid_e348577f7ef777e3 = function(arg0, arg1) { @@ -464,17 +464,6 @@ function getImports() { imports.wbg.__wbg_set_20cbc34131e76824 = function(arg0, arg1, arg2) { getObject(arg0)[takeObject(arg1)] = takeObject(arg2); }; - imports.wbg.__wbindgen_is_null = function(arg0) { - const ret = getObject(arg0) === null; - return ret; - }; - imports.wbg.__wbg_get_723f83ba0c34871a = function(arg0, arg1) { - const ret = getObject(arg0)[takeObject(arg1)]; - return addHeapObject(ret); - }; - imports.wbg.__wbg_set_ce5827ace4c694dc = function(arg0, arg1, arg2) { - getObject(arg0)[takeObject(arg1)] = takeObject(arg2); - }; imports.wbg.__wbg_debug_783a3d4910bc24c7 = function(arg0, arg1) { var v0 = getArrayJsValueFromWasm0(arg0, arg1).slice(); wasm.__wbindgen_free(arg0, arg1 * 4); @@ -1058,10 +1047,6 @@ function getImports() { const ret = result; return ret; }; - imports.wbg.__wbg_new_8d2af00bc1e329ee = function(arg0, arg1) { - const ret = new Error(getStringFromWasm0(arg0, arg1)); - return addHeapObject(ret); - }; imports.wbg.__wbg_message_fe2af63ccc8985bc = function(arg0) { const ret = getObject(arg0).message; return addHeapObject(ret); @@ -1159,16 +1144,16 @@ function getImports() { const ret = wasm.memory; return addHeapObject(ret); }; - imports.wbg.__wbindgen_closure_wrapper4757 = function(arg0, arg1, arg2) { - const ret = makeMutClosure(arg0, arg1, 1089, __wbg_adapter_50); + imports.wbg.__wbindgen_closure_wrapper4758 = function(arg0, arg1, arg2) { + const ret = makeMutClosure(arg0, arg1, 1090, __wbg_adapter_48); return addHeapObject(ret); }; - imports.wbg.__wbindgen_closure_wrapper5693 = function(arg0, arg1, arg2) { - const ret = makeMutClosure(arg0, arg1, 1437, __wbg_adapter_53); + imports.wbg.__wbindgen_closure_wrapper5638 = function(arg0, arg1, arg2) { + const ret = makeMutClosure(arg0, arg1, 1424, __wbg_adapter_51); return addHeapObject(ret); }; - imports.wbg.__wbindgen_closure_wrapper5763 = function(arg0, arg1, arg2) { - const ret = makeMutClosure(arg0, arg1, 1467, __wbg_adapter_56); + imports.wbg.__wbindgen_closure_wrapper5704 = function(arg0, arg1, arg2) { + const ret = makeMutClosure(arg0, arg1, 1450, __wbg_adapter_54); return addHeapObject(ret); }; diff --git a/kanidmd_web_ui/pkg/kanidmd_web_ui_bg.wasm b/kanidmd_web_ui/pkg/kanidmd_web_ui_bg.wasm index 32be2c839..22ca50213 100644 Binary files a/kanidmd_web_ui/pkg/kanidmd_web_ui_bg.wasm and b/kanidmd_web_ui/pkg/kanidmd_web_ui_bg.wasm differ diff --git a/kanidmd_web_ui/pkg/package.json b/kanidmd_web_ui/pkg/package.json index 831d0038d..a45b1e7f0 100644 --- a/kanidmd_web_ui/pkg/package.json +++ b/kanidmd_web_ui/pkg/package.json @@ -5,7 +5,7 @@ "James Hodgkinson " ], "description": "Kanidm Server Web User Interface", - "version": "1.1.0-alpha.11-dev", + "version": "1.1.0-alpha.11", "license": "MPL-2.0", "repository": { "type": "git",