hc
2023-12-09 b22da3d8526a935aa31e086e63f60ff3246cb61c
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
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <stdbool.h>
#include <sys/types.h>
#include <unistd.h>
#include <ctype.h>
#include <inttypes.h>
#include <libgen.h>
 
#include <glib.h>
 
#include <pthread.h>
#include <gdbus.h>
 
#include "json-c/json.h"
#include "rkdb.h"
#include "network.h"
#include "storage.h"
#include "media.h"
#include "common.h"
#include "system.h"
#include "event.h"
#include "log.h"
#include "peripherals.h"
 
enum {
  LOG_ERROR,
  LOG_WARN,
  LOG_INFO,
  LOG_DEBUG
};
 
int enable_minilog = 0;
int dbserver_log_level = LOG_INFO;
 
int main(int argc , char ** argv)
{
    GMainLoop *main_loop;
    DBusError dbus_err;
    DBusConnection *dbus_conn;
    char *db_file = "/userdata/sysconfig.db";
    char *db_path;
#ifdef ENABLE_MINILOGGER
    enable_minilog = 1;
    __minilog_log_init(argv[0], NULL, false, false, "dbserver","1.0");
#endif
    if (argc == 2)
        db_file = argv[1];
 
    db_path = g_strdup(db_file);
    db_path = dirname(db_path);
 
    if (access(db_path, 0)) {
        LOG_INFO("dbserver: %s folder does not exist\n", db_path);
        return 0;
    }
 
    if (db_path)
        g_free(db_path);
 
    rkdb_init(db_file);
 
    network_init();
    storage_init();
    media_init();
    system_init();
    event_init();
    peripherals_init();
 
    LOG_INFO("dbserver init finish\n");
 
    dbus_error_init(&dbus_err);
    dbus_conn = g_dbus_setup_bus(DBUS_BUS_SYSTEM, DB_SERVER, &dbus_err);
 
    main_loop = g_main_loop_new(NULL, FALSE);
 
    network_dbus_register(dbus_conn);
    storage_dbus_register(dbus_conn);
    media_dbus_register(dbus_conn);
    system_dbus_register(dbus_conn);
    event_dbus_register(dbus_conn);
    peripherals_dbus_register(dbus_conn);
 
    LOG_INFO("dbserver dbus register finish\n");
 
    g_main_loop_run(main_loop);
    rkdb_deinit();
    if (main_loop)
        g_main_loop_unref(main_loop);
 
    return 0;
}