aboutsummaryrefslogtreecommitdiff
path: root/src/com/juick/jabber/ws/Main.java
blob: a7aea54322a79703a4e32ae6eb06c65ed3e6f85b (plain) (blame)
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
/*
 * Juick
 * Copyright (C) 2008-2011, Ugnich Anton
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package com.juick.jabber.ws;

import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Properties;

/**
 *
 * @author Ugnich Anton
 */
public class Main {

    Connection sql;
    XMPPConnection xmpp;
    public static String STATSFILE = null;
    public final static ArrayList<SocketSubscribed> clients = new ArrayList<SocketSubscribed>();

    public static void main(String[] args) {
        new Main().start();
    }

    public void start() {
        try {
            Properties conf = new Properties();
            conf.load(new FileInputStream("/etc/juick/ws.conf"));

            STATSFILE = conf.getProperty("statsfile");

            setupSql(conf.getProperty("mysql_username", ""), conf.getProperty("mysql_password", ""));
            xmpp = new XMPPConnection(sql, conf.getProperty("xmpp_password", ""));
            new Thread(xmpp).start();

            //new Thread(new WSConnections()).start();
            new Thread(new WSData(sql)).start();
            new Thread(new WSKeepAlive(sql)).start();
        } catch (Exception e) {
            System.err.println(e);
        }
    }

    public void setupSql(String username, String password) {
        try {
            sql = DriverManager.getConnection("jdbc:mysql://localhost/juick?autoReconnect=true&user=" + username + "&password=" + password);
        } catch (SQLException e) {
            System.err.println(e);
        }
    }
}