# frozen_string_literal: true module Reality::Describers::Wikidata::Impl module Modules # Enumerate recent changes. # # The "submodule" (MediaWiki API term) is included in action after setting some param, providing # additional tweaking for this param. Example (for {Reality::Describers::Wikidata::Impl::Actions::Query} and # its submodules): # # ```ruby # api.query # returns Actions::Query # .prop(:revisions) # adds prop=revisions to action URL, and includes Modules::Revisions into action # .limit(10) # method of Modules::Revisions, adds rvlimit=10 to URL # ``` # # All submodule's parameters are documented as its public methods, see below. # module Recentchanges # The timestamp to start enumerating from. # # @param value [Time] # @return [self] def start(value) merge(rcstart: value.iso8601) end # The timestamp to end enumerating. # # @param value [Time] # @return [self] def end(value) merge(rcend: value.iso8601) end # In which direction to enumerate: # # @param value [String] One of "newer" (List oldest first. Note: rcstart has to be before rcend), "older" (List newest first (default). Note: rcstart has to be later than rcend). # @return [self] def dir(value) _dir(value) or fail ArgumentError, "Unknown value for dir: #{value}" end # @private def _dir(value) defined?(super) && super || ["newer", "older"].include?(value.to_s) && merge(rcdir: value.to_s) end # Filter changes to only these namespaces. # # @param values [Array] Allowed values: "-2", "-1", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "120", "121", "122", "123", "828", "829", "1198", "1199", "2300", "2301", "2302", "2303", "2600". # @return [self] def namespace(*values) values.inject(self) { |res, val| res._namespace(val) or fail ArgumentError, "Unknown value for namespace: #{val}" } end # @private def _namespace(value) defined?(super) && super || ["-2", "-1", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "120", "121", "122", "123", "828", "829", "1198", "1199", "2300", "2301", "2302", "2303", "2600"].include?(value.to_s) && merge(rcnamespace: value.to_s, replace: false) end # Only list changes by this user. # # @param value [String] # @return [self] def user(value) merge(rcuser: value.to_s) end # Don't list changes by this user. # # @param value [String] # @return [self] def excludeuser(value) merge(rcexcludeuser: value.to_s) end # Only list changes tagged with this tag. # # @param value [String] # @return [self] def tag(value) merge(rctag: value.to_s) end # Include additional pieces of information: # # @param values [Array] Allowed values: "user" (Adds the user responsible for the edit and tags if they are an IP), "userid" (Adds the user ID responsible for the edit), "comment" (Adds the comment for the edit), "parsedcomment" (Adds the parsed comment for the edit), "flags" (Adds flags for the edit), "timestamp" (Adds timestamp of the edit), "title" (Adds the page title of the edit), "ids" (Adds the page ID, recent changes ID and the new and old revision ID), "sizes" (Adds the new and old page length in bytes), "redirect" (Tags edit if page is a redirect), "patrolled" (Tags patrollable edits as being patrolled or unpatrolled), "loginfo" (Adds log information (log ID, log type, etc) to log entries), "tags" (Lists tags for the entry), "sha1" (Adds the content checksum for entries associated with a revision), "oresscores" (Adds ORES scores for the entry). # @return [self] def prop(*values) values.inject(self) { |res, val| res._prop(val) or fail ArgumentError, "Unknown value for prop: #{val}" } end # @private def _prop(value) defined?(super) && super || ["user", "userid", "comment", "parsedcomment", "flags", "timestamp", "title", "ids", "sizes", "redirect", "patrolled", "loginfo", "tags", "sha1", "oresscores"].include?(value.to_s) && merge(rcprop: value.to_s, replace: false) end # Use action=query&meta=tokens instead. # # @param values [Array] Allowed values: "patrol". # @return [self] def token(*values) values.inject(self) { |res, val| res._token(val) or fail ArgumentError, "Unknown value for token: #{val}" } end # @private def _token(value) defined?(super) && super || ["patrol"].include?(value.to_s) && merge(rctoken: value.to_s, replace: false) end # Show only items that meet these criteria. For example, to see only minor edits done by logged-in users, set rcshow=minor|!anon. # # @param values [Array] Allowed values: "minor", "!minor", "bot", "!bot", "anon", "!anon", "redirect", "!redirect", "patrolled", "!patrolled", "unpatrolled", "oresreview", "!oresreview". # @return [self] def show(*values) values.inject(self) { |res, val| res._show(val) or fail ArgumentError, "Unknown value for show: #{val}" } end # @private def _show(value) defined?(super) && super || ["minor", "!minor", "bot", "!bot", "anon", "!anon", "redirect", "!redirect", "patrolled", "!patrolled", "unpatrolled", "oresreview", "!oresreview"].include?(value.to_s) && merge(rcshow: value.to_s, replace: false) end # How many total changes to return. # # @param value [Integer, "max"] # @return [self] def limit(value) merge(rclimit: value.to_s) end # Which types of changes to show. # # @param values [Array] Allowed values: "edit", "new", "log", "external", "categorize". # @return [self] def type(*values) values.inject(self) { |res, val| res._type(val) or fail ArgumentError, "Unknown value for type: #{val}" } end # @private def _type(value) defined?(super) && super || ["edit", "new", "log", "external", "categorize"].include?(value.to_s) && merge(rctype: value.to_s, replace: false) end # Only list changes which are the latest revision. # # @return [self] def toponly() merge(rctoponly: 'true') end # When more results are available, use this to continue. # # @param value [String] # @return [self] def continue(value) merge(rccontinue: value.to_s) end # When being used as a generator, generate revision IDs rather than titles. Recent change entries without associated revision IDs (e.g. most log entries) will generate nothing. # # @return [self] def generaterevisions() merge(rcgeneraterevisions: 'true') end end end end