diff options
-rw-r--r-- | make-linux.mk | 4 | ||||
-rw-r--r-- | osdep/OSUtils.cpp | 18 |
2 files changed, 22 insertions, 0 deletions
diff --git a/make-linux.mk b/make-linux.mk index eb77326e..8073aa72 100644 --- a/make-linux.mk +++ b/make-linux.mk @@ -46,6 +46,10 @@ ifeq ($(ZT_SYNOLOGY), 1) DEFS+=-D__SYNOLOGY__ endif +ifeq ($(ZT_QNAP), 1) + DEFS+=-D__QNAP__ +endif + ifeq ($(ZT_TRACE),1) DEFS+=-DZT_TRACE endif diff --git a/osdep/OSUtils.cpp b/osdep/OSUtils.cpp index b7fce982..46c1a8ae 100644 --- a/osdep/OSUtils.cpp +++ b/osdep/OSUtils.cpp @@ -363,6 +363,24 @@ std::vector<std::string> OSUtils::split(const char *s,const char *const sep,cons std::string OSUtils::platformDefaultHomePath() { +#ifdef __QNAP__ + char *cmd = "/sbin/getcfg ZeroTier Install_Path -f /etc/config/qpkg.conf"; + char buf[128]; + FILE *fp; + if ((fp = popen(cmd, "r")) == NULL) { + printf("Error opening pipe!\n"); + return NULL; + } + while (fgets(buf, 128, fp) != NULL) { } + if(pclose(fp)) { + printf("Command not found or exited with error status\n"); + return NULL; + } + std::string homeDir = std::string(buf); + homeDir.erase(std::remove(homeDir.begin(), homeDir.end(), '\n'), homeDir.end()); + return homeDir; +#endif + #ifdef __UNIX_LIKE__ #ifdef __APPLE__ |