upd
This commit is contained in:
		
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,4 @@ | |||||||
| config.lua | config.lua | ||||||
| *.db | *.db | ||||||
| tg | tg | ||||||
|  | otouto-dev-1.rockspec | ||||||
|   | |||||||
							
								
								
									
										56
									
								
								otouto/plugins/dice.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								otouto/plugins/dice.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | local dice = {} | ||||||
|  |  | ||||||
|  | local utilities = require('otouto.utilities') | ||||||
|  |  | ||||||
|  | dice.command = 'roll <nDr>' | ||||||
|  |  | ||||||
|  | function dice:init(config) | ||||||
|  | 	dice.triggers = utilities.triggers(self.info.username, config.cmd_pat):t('roll', true).table | ||||||
|  | 	dice.doc = [[``` | ||||||
|  | ]]..config.cmd_pat..[[roll <nDr> | ||||||
|  | Returns a set of dice rolls, where n is the number of rolls and r is the range. If only a range is given, returns only one roll. | ||||||
|  | ```]] | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function dice:action(msg) | ||||||
|  |  | ||||||
|  | 	local input = utilities.input(msg.text_lower) | ||||||
|  | 	if not input then | ||||||
|  | 		utilities.send_message(self, msg.chat.id, dice.doc, true, msg.message_id, true) | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	local count, range | ||||||
|  | 	if input:match('^[%d]+d[%d]+$') then | ||||||
|  | 		count, range = input:match('([%d]+)d([%d]+)') | ||||||
|  | 	elseif input:match('^d?[%d]+$') then | ||||||
|  | 		count = 1 | ||||||
|  | 		range = input:match('^d?([%d]+)$') | ||||||
|  | 	else | ||||||
|  | 		utilities.send_message(self, msg.chat.id, dice.doc, true, msg.message_id, true) | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	count = tonumber(count) | ||||||
|  | 	range = tonumber(range) | ||||||
|  |  | ||||||
|  | 	if range < 2 then | ||||||
|  | 		utilities.send_reply(self, msg, 'The minimum range is 2.') | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  | 	if range > 1000 or count > 1000 then | ||||||
|  | 		utilities.send_reply(self, msg, 'The maximum range and count are 1000.') | ||||||
|  | 		return | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	local output = '*' .. count .. 'd' .. range .. '*\n`' | ||||||
|  | 	for _ = 1, count do | ||||||
|  | 		output = output .. math.random(range) .. '\t' | ||||||
|  | 	end | ||||||
|  | 	output = output .. '`' | ||||||
|  |  | ||||||
|  | 	utilities.send_message(self, msg.chat.id, output, true, msg.message_id, true) | ||||||
|  |  | ||||||
|  | end | ||||||
|  |  | ||||||
|  | return dice | ||||||
| @@ -1,11 +1,14 @@ | |||||||
| local Redis = require 'redis' | local Redis = require 'redis' | ||||||
| local FakeRedis = require 'fakeredis' | local FakeRedis = require 'fakeredis' | ||||||
|  |  | ||||||
|  |  | ||||||
| local params = { | local params = { | ||||||
|   'unix:///home/anditest/.redis/sock' |   host = os.getenv('REDIS_HOST') or '127.0.0.1', | ||||||
|  |   port = tonumber(os.getenv('REDIS_PORT') or 6379) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | local database = os.getenv('REDIS_DB') | ||||||
|  | local password = os.getenv('REDIS_PASSWORD') | ||||||
|  |  | ||||||
| -- Overwrite HGETALL | -- Overwrite HGETALL | ||||||
| Redis.commands.hgetall = Redis.command('hgetall', { | Redis.commands.hgetall = Redis.command('hgetall', { | ||||||
|   response = function(reply, command, ...) |   response = function(reply, command, ...) | ||||||
| @@ -19,7 +22,7 @@ local redis = nil | |||||||
|  |  | ||||||
| -- Won't launch an error if fails | -- Won't launch an error if fails | ||||||
| local ok = pcall(function() | local ok = pcall(function() | ||||||
|   redis = Redis.connect('unix:///home/anditest/.redis/sock') -- FUCKING FUCK REDIS LUA FUCK Y U NO WORK WITH PARAMS |   redis = Redis.connect(params) | ||||||
| end) | end) | ||||||
|  |  | ||||||
| if not ok then | if not ok then | ||||||
| @@ -41,6 +44,13 @@ if not ok then | |||||||
|     return fake[b] or fake_func |     return fake[b] or fake_func | ||||||
|   end }) |   end }) | ||||||
|  |  | ||||||
|  | else | ||||||
|  |   if password then | ||||||
|  |     redis:auth(password) | ||||||
|  |   end | ||||||
|  |   if database then | ||||||
|  |     redis:select(database) | ||||||
|  |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user