blob: 76c98f7a73b9209b3b0a7c6cc9ead7ea61f8a1c6 (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
 | module Reaktor.Nick where
import Data.Char (chr)
import Data.Char (isDigit)
import qualified Data.Text as T
import qualified Data.Text.Read as T (decimal)
import Prelude.Extended
import System.Random (getStdRandom, randomR)
getNext :: Text -> Text
getNext nick_ = nick'
  where
    splitNick :: Text -> (Text, Int)
    splitNick s =
           (prefix, either (const 0) fst (T.decimal suffix))
         where
           prefix = T.take (T.length s - T.length suffix) s
           suffix = T.reverse . T.takeWhile isDigit . T.reverse $ s
    (nickPrefix, nickSuffix) = splitNick nick_
    nick' = nickPrefix <> (T.pack . show $ nickSuffix + 1)
getRandom :: IO Text
getRandom = do
    h_chr <- getRandomChar nickhead
    t_len <- getStdRandom (randomR (4,8)) :: IO Int
    t_str <- mapM (const $ getRandomChar nicktail) [1..t_len]
    return $ T.pack (h_chr:t_str)
  where
    getRandomChar cs = (cs!!) <$> getStdRandom (randomR (0, length cs - 1))
    -- RFC2812 (doesn't work with charybdis)
    --nickhead  = letters <> specials
    --nicktail  = letters <> digits <> specials <> minus
    --letters   = map chr $ [0x41..0x5A] <> [0x61..0x7A]
    --digits    = map chr $ [0x30..0x39]
    --specials  = map chr $ [0x5B..0x60] <> [0x7B..0x7D]
    --minus     = map chr $ [0x2D]
    -- RFC1459
    nickhead  = letters
    nicktail  = letters <> number <> special
    letters   = map chr $ [0x41..0x5A] <> [0x61..0x7A]
    number    = map chr $ [0x30..0x39]
    special   = map chr $ [0x5B..0x60] <> [0x7B..0x7D] <> [0x2D]
 |