-
Notifications
You must be signed in to change notification settings - Fork 43
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
Autoinstallation for localization (l10n) settings #914
Conversation
7889153
to
da3c5e2
Compare
Before: > The profile is not valid. Please, check the following errors: > * null is not of type "string" > * null is not of type "string" After: > The profile is not valid. Please, check the following errors: > * null is not of type "string". ValidationError { instance: Null, kind: Type { kind: Single(String) }, instance_path: JSONPointer([Property("root"), Property("sshPublicKey")]), schema_path: JSONPointer([Keyword("properties"), Property("root"), Keyword("properties"), Property("sshPublicKey"), Keyword("type")]) } > * null is not of type "string". ValidationError { instance: Null, kind: Type { kind: Single(String) }, instance_path: JSONPointer([Property("storage"), Property("encryptionPassword")]), schema_path: JSONPointer([Keyword("properties"), Property("storage"), Keyword("properties"), Property("encryptionPassword"), Keyword("type")]) } Which is hard to read but does point to the invalid profile bits: `"sshPublicKey": null`, `"encryptionPassword": null`. BTW that profile is just the output of `agama config show`.
da3c5e2
to
6bfc692
Compare
actually localization::settings::LocalizationSettings
Same issue as in #712: zbus-xmlgen generates a proxy for setting a writable property but forgets to mark it as a property, generating a method call instead (I fixed zbus-xmlgen in August but they haven't released a crate since June)
include names of files that were not found
Before, "foo@#$%" was parsed as "foo" Also make the Regex more readable with (?x) verbose syntax
6bfc692
to
8c26e4c
Compare
pub async fn language(&self) -> Result<String, ServiceError> { | ||
let locales = self.localization_proxy.locales().await?; | ||
if locales.is_empty() { | ||
// FIXME is this right? |
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.
well, maybe more correct way is to use Result<Option<String>, ServiceError>
and return Ok(None)
here.
} else { | ||
// without clone: | ||
// error[E0507]: cannot move out of index of `Vec<std::string::String>` | ||
// but why, it's a Vec<String> I should be able to move it?! |
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.
I think reason is that you want to return just part of Vector that will be destructed. I think that if you return whole locales, then it should work as you move whole ownership.
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.
vec.into_iter().next()
does what I want, yay
pub async fn load(&self) -> Result<LocalizationSettings, ServiceError> { | ||
// TODO: we should use a single D-Bus call with Properties.GetAll | ||
// but LocaleProxy does not have it, only get_property for individual methods | ||
// and properties_proxy is private |
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.
Just use Property proxy instead of LocaleProxy for given object.
https://docs.rs/zbus/latest/zbus/fdo/struct.PropertiesProxy.html
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.
so basically you can construct proxy yourself...but it is usually not necessary as it is cached and zbus checking PropertiesChange signal for you, so in the end it is very efficient if property does not change too much.
rust/agama-lib/src/store.rs
Outdated
// TODO: use try_join here | ||
Ok(settings) | ||
} | ||
|
||
/// Stores the given installation settings in the D-Bus service | ||
pub async fn store(&self, settings: &InstallSettings) -> Result<(), ServiceError> { | ||
// ordering: localization before product |
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.
why it needs to be done before product? It is target system product and support for given localization can change between products, not?
Prepare for releasing Agama 8. It includes the following pull requests: * #884 * #886 * #914 * #918 * #956 * #957 * #958 * #959 * #960 * #961 * #962 * #963 * #964 * #965 * #966 * #969 * #970 * #976 * #977 * #978 * #979 * #980 * #981 * #983 * #984 * #985 * #986 * #988 * #991 * #992 * #995 * #996 * #997 * #999 * #1003 * #1004 * #1006 * #1007 * #1008 * #1009 * #1010 * #1011 * #1012 * #1014 * #1015 * #1016 * #1017 * #1020 * #1022 * #1023 * #1024 * #1025 * #1027 * #1028 * #1029 * #1030 * #1031 * #1032 * #1033 * #1034 * #1035 * #1036 * #1038 * #1039 * #1041 * #1042 * #1043 * #1045 * #1046 * #1047 * #1048 * #1052 * #1054 * #1056 * #1057 * #1060 * #1061 * #1062 * #1063 * #1064 * #1066 * #1067 * #1068 * #1069 * #1071 * #1072 * #1073 * #1074 * #1075 * #1079 * #1080 * #1081 * #1082 * #1085 * #1086 * #1087 * #1088 * #1089 * #1090 * #1091 * #1092 * #1093 * #1094 * #1095 * #1096 * #1097 * #1098 * #1099 * #1100 * #1102 * #1103 * #1104 * #1105 * #1106 * #1109 * #1110 * #1111 * #1112 * #1114 * #1116 * #1117 * #1118 * #1119 * #1120 * #1121 * #1122 * #1123 * #1125 * #1126 * #1127 * #1128 * #1129 * #1130 * #1131 * #1132 * #1133 * #1134 * #1135 * #1136 * #1138 * #1139 * #1140 * #1141 * #1142 * #1143 * #1144 * #1145 * #1146 * #1147 * #1148 * #1149 * #1151 * #1152 * #1153 * #1154 * #1155 * #1156 * #1157 * #1158 * #1160 * #1161 * #1162 * #1163 * #1164 * #1165 * #1166 * #1167 * #1168 * #1169 * #1170 * #1171 * #1172 * #1173 * #1174 * #1175 * #1177 * #1178 * #1180 * #1181 * #1182 * #1183 * #1184 * #1185 * #1187 * #1188 * #1189 * #1190 * #1191 * #1192 * #1193 * #1194 * #1195 * #1196 * #1198 * #1199 * #1200 * #1201 * #1203 * #1204 * #1205 * #1206 * #1207 * #1208 * #1209 * #1210 * #1211 * #1212 * #1213 * #1214 * #1215 * #1216 * #1217 * #1219 * #1220 * #1221 * #1222 * #1223 * #1224 * #1225 * #1226 * #1227 * #1229
Problem
In #881 localization was improved and works in the web UI.
This PR adds CLI and autoinstallation
Solution
Mimic the structure of the other configuration scopes.
TODO:
locale
and/orlocalization
in the code: mostly "localization" except the D-Bus proxy which is "locale"Testing
KeymapId
Screenshots
agama config show
now works forlocalization
: