aboutsummaryrefslogtreecommitdiffstats
path: root/unstable/prosody/prosody.cfg.lua
blob: 99df66add6aa36e3f2f4be052883e0db47b144fc (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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
-- Prosody Configuration File
--
-- If it wasn't already obvious, -- starts a comment, and all text after it on
-- a line is ignored by Prosody.
--
-- The config is split into sections, a global section, and one for each
-- defined host that we serve. You can add as many host sections as you like.
--
-- Lists are written { "like", "this", "one" }
-- Lists can also be of { 1, 2, 3 } numbers, etc.
-- Either commas, or semi-colons; may be used as seperators.
--
-- A table is a list of values, except each value has a name. An example would
-- be:
--
-- logging = { type = "html", directory = "/var/logs", rotate = "daily" }
--
-- Whitespace (that is tabs, spaces, line breaks) is mostly insignificant, so
-- can
-- be placed anywhere
-- that     you deem fitting.
--
-- Tip: You can check that the syntax of this file is correct when you have
-- finished by running: luac -p prosody.cfg.lua
-- If there are any errors, it will let you know what and where they are,
-- otherwise it will keep quiet.
--
-- Good luck, and happy Jabbering!

-- Global settings go in this section
Host "*"
    -- This is the list of modules Prosody will load on startup.
    -- It looks for mod_modulename.lua in the plugins folder, so make sure that
    -- exists too.
    modules_enabled = {
        -- Generally required
            "roster"; -- Allow users to have a roster. Recommended ;)
            "saslauth"; -- Authentication for clients and servers. Recommended
                        -- if you want to log in.
            "tls"; -- Add support for secure TLS on c2s/s2s connections
            "dialback"; -- s2s dialback support
            "disco"; -- Service discovery

        -- Not essential, but recommended
            "private"; -- Private XML storage (for room bookmarks, etc.)
            "vcard"; -- Allow users to set vCards

        -- Nice to have
            "legacyauth"; -- Legacy authentication. Only used by some old
                          -- clients and bots.
            "version"; -- Replies to server version requests
            "uptime"; -- Report how long server has been running
            "time"; -- Let others know the time here on this server
            "ping"; -- Replies to XMPP pings with pongs

        -- Required for daemonizing and logging
            "posix"; -- POSIX functionality, sends server to background,
                     -- enables syslog, etc.

        -- Other specific functionality
            "register"; -- Allow users to register on this server using a
                          -- client
            --"console"; -- telnet to port 5582 (needs console_enabled = true)
            --"bosh"; -- Enable BOSH clients, aka "Jabber over HTTP"
            --"httpserver"; -- Serve static files from a directory over HTTP
    }

    -- These are the SSL/TLS-related settings. If you don't want to use
    -- SSL/TLS, you may comment or remove this
    --ssl = {
    --    key = "/etc/prosody/certs/localhost.key";
    --    certificate = "/etc/prosody/certs/localhost.cert";
    --}

    log = {
        -- Log all error messages to prosody.err
        { levels = { min = "error" }, to = "file", timestamps = true,
        filename = "/var/log/prosody/prosody.err" };
        -- Log everything of level "info" and higher (that is, all except
        -- "debug" messages) to prosody.log
        { levels = { min = "info" }, to = "file", timestamps = true,
        filename = "/var/log/prosody/prosody.log" };
    }

    -- Required for proper daemonization support
    pidfile = "/var/run/prosody/prosody.pid"

-- This allows clients to connect to localhost. No harm in it.
Host "localhost"

-- Section for example.com
-- (replace example.com with your domain name)
Host "example.com"
    -- Assign this host a certificate for TLS, otherwise it would use the one
    -- set in the global section (if any).
    -- Note that old-style SSL on port 5223 only supports one certificate, and
    -- will always use the global one.
    --ssl = {
    --    key = "/etc/prosody/certs/example.com.key";
    --    certificate = "/etc/prosody/certs/example.com.crt";
    --}

    enabled = false -- This will disable the host, preserving the config, but
                    -- denying connections

-- Set up a MUC (multi-user chat) room server on conference.localhost:
Component "conference.localhost" "muc"