vcpe/srcs/vcpe_main.c

122 lines
3.1 KiB
C
Raw Normal View History

2022-05-10 06:43:27 +00:00
//
// Created by xajhu on 2021/6/29 0029.
//
#include <uv.h>
#include <stdlib.h>
#include <unistd.h>
2022-05-10 06:43:27 +00:00
#include "cmdline.h"
#include "task_manager.h"
#include "init.h"
#include "inet_misc.h"
#include "config.h"
2023-02-06 07:10:02 +00:00
#include "zlog_module.h"
2022-12-14 02:16:10 +00:00
#include "prj_config.h"
#include "user_errno.h"
2022-12-14 02:16:10 +00:00
2022-12-23 02:57:16 +00:00
#ifdef LWIP_ON
2022-05-10 06:43:27 +00:00
#include "user_info.h"
#include "lwip/tcpip.h"
2022-09-28 02:48:02 +00:00
#endif
#ifdef OPENDHCPD_ON
#include "proto.h"
#endif
#ifdef OPENDHCPDDNS_ON
#include "dual_server/dualsvr.h"
#endif
2022-05-10 06:43:27 +00:00
2022-12-23 02:57:16 +00:00
#ifdef LWIP_ON
2022-05-10 06:43:27 +00:00
static void test_init(void *arg) { /* remove compiler warning */
sys_sem_t *init_sem;
init_sem = (sys_sem_t *)arg;
srand((unsigned int)time(0));
sys_sem_signal(init_sem);
}
static void lwip_init_env() {
err_t err;
sys_sem_t init_sem;
err = sys_sem_new(&init_sem, 0);
2022-05-10 06:43:27 +00:00
LWIP_UNUSED_ARG(err);
tcpip_init(test_init, &init_sem);
sys_sem_wait(&init_sem);
sys_sem_free(&init_sem);
}
#endif
2022-05-27 07:49:45 +00:00
cJSON *create_app_process_status(int isStart) {
cJSON *pRspMsg = cJSON_CreateObject();
cJSON_AddNumberToObject(pRspMsg, "vni", cfg_get_user_vni_id());
cJSON_AddStringToObject(pRspMsg, "process", isStart ? "setup" : "exit");
return pRspMsg;
}
static void on_http_response_cb(void *pData,
unsigned int size,
const char *pReqUrl,
const char *pDlPath,
const char *pTaskUuid,
int iFinished,
void *pUserData) {
if (iFinished == 0) {
LOG_MOD(debug, ZLOG_MOD_MAIN, "Request(%s): [%s] Response: [%u] OK:\n", pTaskUuid, pReqUrl, size);
} else if (iFinished == 1) {
LOG_MOD(error, ZLOG_MOD_MAIN, "Request(%s): [%s] Response: [%u] Error\n", pTaskUuid, pReqUrl, size);
} else {
LOG_MOD(error, ZLOG_MOD_MAIN, "Download Error Code: %d\n", iFinished);
}
free(pUserData);
}
2022-05-10 06:43:27 +00:00
int main(int argc, char **argv) {
int ret;
#ifdef OPENDHCPDDNS_ON
return dual_server_main(argc, argv);
#else
2022-05-10 06:43:27 +00:00
uv_setup_args(argc, argv);
2022-12-14 02:16:10 +00:00
printf("Application %s version %s\n", VCPE_PROJECT_NAME, VCPE_PROJECT_VER);
2022-05-10 06:43:27 +00:00
setvbuf(stdout, NULL, _IONBF, 0);
ret = menu_run(argc, argv);
2022-12-06 03:08:29 +00:00
if (ret == ERR_MENU_EXIT) {
user_uninit();
exit(0);
} else if (ret != ERR_SUCCESS) {
printf("Application setup error(%d), please used --help to show usage, exited!!!\n", ret);
user_uninit();
exit(0);
}
2022-05-10 06:43:27 +00:00
2022-12-23 02:57:16 +00:00
#ifdef LWIP_ON
2022-05-27 07:49:45 +00:00
lwip_init_env();
2022-05-10 06:43:27 +00:00
user_info_init();
pppoe_session_init();
#endif
2022-05-10 06:43:27 +00:00
const char *pStrSetup = proto_create_new(create_app_process_status(1), 200);
inet_http_post_async(config_get_agent_moniter_report_url(), pStrSetup, on_http_response_cb, (void *)pStrSetup);
2022-05-10 06:43:27 +00:00
task_manager_run();
const char *pStrExit = proto_create_new(create_app_process_status(0), 200);
inet_http_post_async(config_get_agent_moniter_report_url(), pStrSetup, on_http_response_cb, (void *)pStrSetup);
2022-12-06 03:08:29 +00:00
while (!is_system_cleanup()) {
sleep(1);
}
2022-05-10 06:43:27 +00:00
user_uninit();
return ret;
#endif
2022-05-10 06:43:27 +00:00
}