Module:WikidataCheck: Difference between revisions

From Random Island Wiki
Jump to navigation Jump to search
>Rschen7754
m (Changed protection level of Module:WikidataCheck: Highly visible template ([Edit=Allow only autoconfirmed users] (indefinite) [Move=Block all non-admin users] (indefinite)))
>Legoktm
(documentation)
Line 10: Line 10:
     local catbase = config.category
     local catbase = config.category
     local namespaces = config.namespaces
     local namespaces = config.namespaces
     local ok = false
     local ok = false -- one-way flag to check if we're in a good namespace
     local ns = mw.title.getCurrentTitle().namespace
     local ns = mw.title.getCurrentTitle().namespace
     for v in mw.text.gsplit( namespaces, ",", true) do
     for v in mw.text.gsplit( namespaces, ",", true) do
Line 17: Line 17:
         end
         end
     end
     end
     if not ok then
     if not ok then -- not in one of the approved namespaces
         return ""
         return ""
     end
     end
     local entity = mw.wikibase.getEntity()
     local entity = mw.wikibase.getEntity()
     if not entity then
     if not entity then -- no Wikidata item
         return "[[Category:" .. catbase .. " not in Wikidata]]"
         return "[[Category:" .. catbase .. " not in Wikidata]]"
     end
     end
     local hasProp = entity.claims[property]
     local hasProp = entity.claims[property]
     if not hasProp then
     if not hasProp then -- no claim of that property
         return "[[Category:" .. catbase .. " not in Wikidata]]"
         return "[[Category:" .. catbase .. " not in Wikidata]]" -- bad. Bot needs to add the property
     end
     end
     local propValue = hasProp[0].mainsnak.datavalue.value
     local propValue = hasProp[0].mainsnak.datavalue.value -- This should eventually iterate over all possible values?
     if propValue == value then
     if propValue == value then
         return "[[Category:" .. catbase .. " same as Wikidata]]"
         return "[[Category:" .. catbase .. " same as Wikidata]]" -- yay!
     else
     else
         return "[[Category:" .. catbase .. " different from Wikidata]]"
         return "[[Category:" .. catbase .. " different from Wikidata]]" -- needs human review :(
     end
     end
end
end


return p
return p

Revision as of 03:10, 30 April 2013

Documentation for this module may be created at Module:WikidataCheck/doc

local p = {}

function p.wikidatacheck(frame)
    local pframe = frame:getParent()
    local config = frame.args -- the arguments passed BY the template, in the wikitext of the template itself
    local args = pframe.args -- the arguments passed TO the template, in the wikitext that transcludes the template
    
    local property = config.property
    local value = config.value
    local catbase = config.category
    local namespaces = config.namespaces
    local ok = false -- one-way flag to check if we're in a good namespace
    local ns = mw.title.getCurrentTitle().namespace
    for v in mw.text.gsplit( namespaces, ",", true) do
        if tonumber(v) == ns then
            ok = true
        end
    end
    if not ok then -- not in one of the approved namespaces
        return ""
    end
    local entity = mw.wikibase.getEntity()
    if not entity then -- no Wikidata item
        return "[[Category:" .. catbase .. " not in Wikidata]]"
    end
    local hasProp = entity.claims[property]
    if not hasProp then -- no claim of that property
        return "[[Category:" .. catbase .. " not in Wikidata]]" -- bad. Bot needs to add the property
    end
    local propValue = hasProp[0].mainsnak.datavalue.value -- This should eventually iterate over all possible values?
    if propValue == value then
        return "[[Category:" .. catbase .. " same as Wikidata]]" -- yay!
    else
        return "[[Category:" .. catbase .. " different from Wikidata]]" -- needs human review :(
    end
end

return p