summary refs log tree commit diff stats
path: root/svc/init.go
blob: 01e119201b29a0edbac030af31751102e85dbddf (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
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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package svc // import "github.com/getwtxt/getwtxt/svc"

import (
	"html/template"
	"log"
	"os"
	"os/signal"
	"time"

	"github.com/getwtxt/registry"
	"github.com/spf13/pflag"
)

const getwtxt = "0.2.3"

var (
	flagVersion  *bool   = pflag.BoolP("version", "v", false, "Display version information, then exit.")
	flagHelp     *bool   = pflag.BoolP("help", "h", false, "Display the quick-help screen.")
	flagMan      *bool   = pflag.BoolP("manual", "m", false, "Display the configuration manual.")
	flagConfFile *string = pflag.StringP("config", "c", "", "The name/path of the configuration file you wish to use.")
	flagAssets   *string = pflag.StringP("assets", "a", "", "The location of the getwtxt assets directory")
	flagDBPath   *string = pflag.StringP("db", "d", "", "Path to the getwtxt database")
	flagDBType   *string = pflag.StringP("dbtype", "t", "", "Type of database being used")
)

var confObj = &Configuration{}

// signals to close the log file
var closeLog = make(chan bool, 1)

// used to transmit database pointer after
// initialization
var dbChan = make(chan dbase, 1)

var tmpls *template.Template

var twtxtCache = registry.NewIndex()

var remoteRegistries = &RemoteRegistries{}

var staticCache = &struct {
	index    []byte
	indexMod time.Time
	css      []byte
	cssMod   time.Time
}{
	index:    nil,
	indexMod: time.Time{},
	css:      nil,
	cssMod:   time.Time{},
}

// I'm not using init() because it runs
// even during testing and was causing
// problems.
func initSvc() {
	checkFlags()
	titleScreen()
	initConfig()
	initLogging()
	tmpls = initTemplates()
	initDatabase()
	go cacheAndPush()
	watchForInterrupt()
}

func checkFlags() {
	pflag.Parse()
	if *flagVersion {
		titleScreen()
		os.Exit(0)
	}
	if *flagHelp {
		titleScreen()
		helpScreen()
		os.Exit(0)
	}
	if *flagMan {
		titleScreen()
		helpScreen()
		manualScreen()
		os.Exit(0)
	}
}

// Watch for SIGINT aka ^C
// Close the log file then exit
func watchForInterrupt() {
	c := make(chan os.Signal, 1)
	signal.Notify(c, os.Interrupt)

	go func() {
		for sigint := range c {

			log.Printf("\n\nCaught %v. Cleaning up ...\n", sigint)
			confObj.Mu.RLock()
			log.Printf("Closing database connection to %v...\n", confObj.DBPath)

			db := <-dbChan

			switch dbType := db.(type) {

			case *dbLevel:
				lvl := dbType
				if err := lvl.db.Close(); err != nil {
					log.Printf("%v\n", err.Error())
				}

			}

			if !confObj.StdoutLogging {
				closeLog <- true
			}

			confObj.Mu.RUnlock()
			close(dbChan)
			close(closeLog)

			// Let everything catch up
			time.Sleep(100 * time.Millisecond)
			os.Exit(0)
		}
	}()
}
pan> assert_string_equal("it is a thing", result); free(result); } void replace_two_substr(void **state) { char *string = "it is a is string"; char *sub = "is"; char *new = "was"; char *result = str_replace(string, sub, new); assert_string_equal("it was a was string", result); free(result); } void replace_char(void **state) { char *string = "some & a thing & something else"; char *sub = "&"; char *new = "&amp;"; char *result = str_replace(string, sub, new); assert_string_equal("some &amp; a thing &amp; something else", result); free(result); } void replace_when_none(void **state) { char *string = "its another string"; char *sub = "haha"; char *new = "replaced"; char *result = str_replace(string, sub, new); assert_string_equal("its another string", result); free(result); } void replace_when_match(void **state) { char *string = "hello"; char *sub = "hello"; char *new = "goodbye"; char *result = str_replace(string, sub, new); assert_string_equal("goodbye", result); free(result); } void replace_when_string_empty(void **state) { char *string = ""; char *sub = "hello"; char *new = "goodbye"; char *result = str_replace(string, sub, new); assert_string_equal("", result); free(result); } void replace_when_string_null(void **state) { char *string = NULL; char *sub = "hello"; char *new = "goodbye"; char *result = str_replace(string, sub, new); assert_null(result); } void replace_when_sub_empty(void **state) { char *string = "hello"; char *sub = ""; char *new = "goodbye"; char *result = str_replace(string, sub, new); assert_string_equal("hello", result); free(result); } void replace_when_sub_null(void **state) { char *string = "hello"; char *sub = NULL; char *new = "goodbye"; char *result = str_replace(string, sub, new); assert_string_equal("hello", result); free(result); } void replace_when_new_empty(void **state) { char *string = "hello"; char *sub = "hello"; char *new = ""; char *result = str_replace(string, sub, new); assert_string_equal("", result); free(result); } void replace_when_new_null(void **state) { char *string = "hello"; char *sub = "hello"; char *new = NULL; char *result = str_replace(string, sub, new); assert_string_equal("hello", result); free(result); } void compare_win_nums_less(void **state) { gconstpointer a = GINT_TO_POINTER(2); gconstpointer b = GINT_TO_POINTER(3); int result = cmp_win_num(a, b); assert_true(result < 0); } void compare_win_nums_equal(void **state) { gconstpointer a = GINT_TO_POINTER(5); gconstpointer b = GINT_TO_POINTER(5); int result = cmp_win_num(a, b); assert_true(result == 0); } void compare_win_nums_greater(void **state) { gconstpointer a = GINT_TO_POINTER(7); gconstpointer b = GINT_TO_POINTER(6); int result = cmp_win_num(a, b); assert_true(result > 0); } void compare_0s_equal(void **state) { gconstpointer a = GINT_TO_POINTER(0); gconstpointer b = GINT_TO_POINTER(0); int result = cmp_win_num(a, b); assert_true(result == 0); } void compare_0_greater_than_1(void **state) { gconstpointer a = GINT_TO_POINTER(0); gconstpointer b = GINT_TO_POINTER(1); int result = cmp_win_num(a, b); assert_true(result > 0); } void compare_1_less_than_0(void **state) { gconstpointer a = GINT_TO_POINTER(1); gconstpointer b = GINT_TO_POINTER(0); int result = cmp_win_num(a, b); assert_true(result < 0); } void compare_0_less_than_11(void **state) { gconstpointer a = GINT_TO_POINTER(0); gconstpointer b = GINT_TO_POINTER(11); int result = cmp_win_num(a, b); assert_true(result < 0); } void compare_11_greater_than_0(void **state) { gconstpointer a = GINT_TO_POINTER(11); gconstpointer b = GINT_TO_POINTER(0); int result = cmp_win_num(a, b); assert_true(result > 0); } void compare_0_greater_than_9(void **state) { gconstpointer a = GINT_TO_POINTER(0); gconstpointer b = GINT_TO_POINTER(9); int result = cmp_win_num(a, b); assert_true(result > 0); } void compare_9_less_than_0(void **state) { gconstpointer a = GINT_TO_POINTER(9); gconstpointer b = GINT_TO_POINTER(0); int result = cmp_win_num(a, b); assert_true(result < 0); } void next_available_when_only_console(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); int result = get_next_available_win_num(used); assert_int_equal(2, result); } void next_available_3_at_end(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); int result = get_next_available_win_num(used); assert_int_equal(3, result); } void next_available_9_at_end(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); int result = get_next_available_win_num(used); assert_int_equal(9, result); } void next_available_0_at_end(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); used = g_list_append(used, GINT_TO_POINTER(9)); int result = get_next_available_win_num(used); assert_int_equal(0, result); } void next_available_2_in_first_gap(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(9)); used = g_list_append(used, GINT_TO_POINTER(0)); int result = get_next_available_win_num(used); assert_int_equal(2, result); } void next_available_9_in_first_gap(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); used = g_list_append(used, GINT_TO_POINTER(0)); used = g_list_append(used, GINT_TO_POINTER(11)); used = g_list_append(used, GINT_TO_POINTER(12)); used = g_list_append(used, GINT_TO_POINTER(13)); used = g_list_append(used, GINT_TO_POINTER(20)); int result = get_next_available_win_num(used); assert_int_equal(9, result); } void next_available_0_in_first_gap(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); used = g_list_append(used, GINT_TO_POINTER(9)); used = g_list_append(used, GINT_TO_POINTER(11)); used = g_list_append(used, GINT_TO_POINTER(12)); used = g_list_append(used, GINT_TO_POINTER(13)); used = g_list_append(used, GINT_TO_POINTER(20)); int result = get_next_available_win_num(used); assert_int_equal(0, result); } void next_available_11_in_first_gap(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); used = g_list_append(used, GINT_TO_POINTER(9)); used = g_list_append(used, GINT_TO_POINTER(0)); used = g_list_append(used, GINT_TO_POINTER(12)); used = g_list_append(used, GINT_TO_POINTER(13)); used = g_list_append(used, GINT_TO_POINTER(20)); int result = get_next_available_win_num(used); assert_int_equal(11, result); } void next_available_24_first_big_gap(void **state) { GList *used = NULL; used = g_list_append(used, GINT_TO_POINTER(1)); used = g_list_append(used, GINT_TO_POINTER(2)); used = g_list_append(used, GINT_TO_POINTER(3)); used = g_list_append(used, GINT_TO_POINTER(4)); used = g_list_append(used, GINT_TO_POINTER(5)); used = g_list_append(used, GINT_TO_POINTER(6)); used = g_list_append(used, GINT_TO_POINTER(7)); used = g_list_append(used, GINT_TO_POINTER(8)); used = g_list_append(used, GINT_TO_POINTER(9)); used = g_list_append(used, GINT_TO_POINTER(0)); used = g_list_append(used, GINT_TO_POINTER(11)); used = g_list_append(used, GINT_TO_POINTER(12)); used = g_list_append(used, GINT_TO_POINTER(13)); used = g_list_append(used, GINT_TO_POINTER(14)); used = g_list_append(used, GINT_TO_POINTER(15)); used = g_list_append(used, GINT_TO_POINTER(16)); used = g_list_append(used, GINT_TO_POINTER(17)); used = g_list_append(used, GINT_TO_POINTER(18)); used = g_list_append(used, GINT_TO_POINTER(19)); used = g_list_append(used, GINT_TO_POINTER(20)); used = g_list_append(used, GINT_TO_POINTER(21)); used = g_list_append(used, GINT_TO_POINTER(22)); used = g_list_append(used, GINT_TO_POINTER(23)); used = g_list_append(used, GINT_TO_POINTER(51)); used = g_list_append(used, GINT_TO_POINTER(52)); used = g_list_append(used, GINT_TO_POINTER(53)); used = g_list_append(used, GINT_TO_POINTER(89)); used = g_list_append(used, GINT_TO_POINTER(90)); used = g_list_append(used, GINT_TO_POINTER(100)); used = g_list_append(used, GINT_TO_POINTER(101)); used = g_list_append(used, GINT_TO_POINTER(102)); int result = get_next_available_win_num(used); assert_int_equal(24, result); } void test_online_is_valid_resource_presence_string(void **state) { assert_true(valid_resource_presence_string("online")); } void test_chat_is_valid_resource_presence_string(void **state) { assert_true(valid_resource_presence_string("chat")); } void test_away_is_valid_resource_presence_string(void **state) { assert_true(valid_resource_presence_string("away")); } void test_xa_is_valid_resource_presence_string(void **state) { assert_true(valid_resource_presence_string("xa")); } void test_dnd_is_valid_resource_presence_string(void **state) { assert_true(valid_resource_presence_string("dnd")); } void test_available_is_not_valid_resource_presence_string(void **state) { assert_false(valid_resource_presence_string("available")); } void test_unavailable_is_not_valid_resource_presence_string(void **state) { assert_false(valid_resource_presence_string("unavailable")); } void test_blah_is_not_valid_resource_presence_string(void **state) { assert_false(valid_resource_presence_string("blah")); }