diff options
author | Kim Alvefur <zash@zash.se> | 2021-03-07 01:41:39 +0100 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2021-03-07 01:41:39 +0100 |
commit | 7cd2803161ee05303371cd681f8ae00a0838d07f (patch) | |
tree | c9c4cce37f9470109870f19cbc5c93c7db3674cf /teal-src | |
parent | d20ea9b87e6e4071aca1a6895041d9e82ebb8691 (diff) | |
download | prosody-7cd2803161ee05303371cd681f8ae00a0838d07f.tar.gz prosody-7cd2803161ee05303371cd681f8ae00a0838d07f.zip |
util.datamapper: Add logic for "boolean" tags here the presence means true
Diffstat (limited to 'teal-src')
-rw-r--r-- | teal-src/util/datamapper.tl | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/teal-src/util/datamapper.tl b/teal-src/util/datamapper.tl index 4db153da..9546809a 100644 --- a/teal-src/util/datamapper.tl +++ b/teal-src/util/datamapper.tl @@ -49,8 +49,10 @@ local function parse_object (schema : js.schema_t, s : st.stanza_t) : table if name_is_value then local c = s:get_child(nil, namespace); - if c then + if c and proptype == "string" then out[prop] = c.name; + elseif proptype == "boolean" and c then + out[prop] = true; end elseif is_attribute then local attr = name @@ -183,8 +185,12 @@ local function unparse ( schema : js.schema_t, t : table, current_name : string, if namespace ~= current_ns then propattr = { xmlns = namespace } end - if name_is_value and v is string then - out:tag(v, propattr):up(); + if name_is_value then + if proptype == "string" and v is string then + out:tag(v, propattr):up(); + elseif proptype == "boolean" and v == true then + out:tag(name, propattr):up(); + end elseif proptype == "string" and v is string then out:text_tag(name, v, propattr) elseif proptype == "number" and v is number then |