summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--make-linux.mk4
-rw-r--r--osdep/OSUtils.cpp18
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__