mirror of
https://github.com/lxsang/silk.git
synced 2025-04-23 12:26:45 +02:00
Compare commits
No commits in common. "387f85c15d87f71ec611ed0eee9cf95b29661a14" and "824769dee2e89ef75b0c59e91d5ede5f2c815213" have entirely different histories.
387f85c15d
...
824769dee2
@ -1,93 +0,0 @@
|
|||||||
name: AntOS pipeline
|
|
||||||
run-name: Building AntOS binaries
|
|
||||||
on: [push]
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build-amd64:
|
|
||||||
uses: git.iohub.dev/dany/actions/autotools-cross.yml@master
|
|
||||||
with:
|
|
||||||
platform: amd64
|
|
||||||
build-arm64:
|
|
||||||
uses: git.iohub.dev/dany/actions/autotools-cross.yml@master
|
|
||||||
with:
|
|
||||||
platform: arm64
|
|
||||||
|
|
||||||
build-arm:
|
|
||||||
uses: git.iohub.dev/dany/actions/autotools-cross.yml@master
|
|
||||||
with:
|
|
||||||
platform: arm
|
|
||||||
|
|
||||||
publish-doc-on-tag:
|
|
||||||
runs-on: act-runner
|
|
||||||
if: gitea.event_name == 'push' && contains(gitea.ref, 'refs/tags/')
|
|
||||||
needs:
|
|
||||||
container:
|
|
||||||
image: iohubdev/ci-tools:latest
|
|
||||||
volumes:
|
|
||||||
- /opt/public/antos-release/:/public/
|
|
||||||
steps:
|
|
||||||
- name: Check out repository code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- name: Update submodule
|
|
||||||
run: git submodule update --init
|
|
||||||
- run: mkdir -p build
|
|
||||||
- name: Build and publish doc and SDK
|
|
||||||
run: |
|
|
||||||
make frontend
|
|
||||||
DOCDIR=/public/doc/ make doc
|
|
||||||
SDKDIR=/public/sdk/ make sdk
|
|
||||||
|
|
||||||
publish-package-on-tag:
|
|
||||||
runs-on: act-runner
|
|
||||||
if: gitea.event_name == 'push' && contains(gitea.ref, 'refs/tags/')
|
|
||||||
needs: [build-amd64, build-arm64, build-arm]
|
|
||||||
container:
|
|
||||||
image: catthehacker/ubuntu:act-latest
|
|
||||||
steps:
|
|
||||||
- name: Check out repository code
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
- run: mkdir -p build
|
|
||||||
- name: get build-amd64 artifacts
|
|
||||||
uses: actions/download-artifact@master
|
|
||||||
with:
|
|
||||||
name: build-amd64
|
|
||||||
path: build
|
|
||||||
- name: get build-arm64 artifacts
|
|
||||||
uses: actions/download-artifact@master
|
|
||||||
with:
|
|
||||||
name: build-arm64
|
|
||||||
path: build
|
|
||||||
- name: get build-arm artifacts
|
|
||||||
uses: actions/download-artifact@master
|
|
||||||
with:
|
|
||||||
name: build-arm
|
|
||||||
path: build
|
|
||||||
- name: Set up QEMU
|
|
||||||
uses: docker/setup-qemu-action@master
|
|
||||||
- name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@master
|
|
||||||
- name: Login to DockerHub
|
|
||||||
uses: docker/login-action@master
|
|
||||||
with:
|
|
||||||
username: ${{ secrets.DOCKER_USERNAME }}
|
|
||||||
password: ${{ secrets.DOCKER_PAT }}
|
|
||||||
- name: Env
|
|
||||||
run: |
|
|
||||||
printenv
|
|
||||||
docker info
|
|
||||||
ls . -al
|
|
||||||
ls build/ -al
|
|
||||||
- name: Build and push docker image
|
|
||||||
run: |
|
|
||||||
PKG_VERSION="${{ gitea.ref_name }}"
|
|
||||||
DOCKER_TAG=$PKG_VERSION DOCKER_IMAGE=iohubdev/antos make docker
|
|
||||||
- name: Publish packages
|
|
||||||
run: |
|
|
||||||
rm build/*/opt/ -rf
|
|
||||||
files=$(find ./build -type f)
|
|
||||||
PKG_VERSION="${{ gitea.ref_name }}"
|
|
||||||
URL="https://git.iohub.dev/api/packages/dany/generic/antos/$PKG_VERSION"
|
|
||||||
curl --request "DELETE" --header "Authorization: token ${{ secrets.GT_API_PAT }}" $URL/ || true
|
|
||||||
for file in $files; do
|
|
||||||
curl --header "Authorization: token ${{ secrets.GT_API_PAT }}" --upload-file $file $URL/$(basename $file)
|
|
||||||
done
|
|
98
Jenkinsfile
vendored
Normal file
98
Jenkinsfile
vendored
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
def build_lib()
|
||||||
|
{
|
||||||
|
sh '''
|
||||||
|
set -e
|
||||||
|
cd $WORKSPACE
|
||||||
|
mkdir -p build/$arch/
|
||||||
|
[ -f Makefile ] && make clean
|
||||||
|
case $arch in
|
||||||
|
amd64|x86_64)
|
||||||
|
HOST=
|
||||||
|
;;
|
||||||
|
aarch64|arm64)
|
||||||
|
HOST=--host=aarch64-linux-gnu
|
||||||
|
;;
|
||||||
|
armv7l|arm)
|
||||||
|
HOST=--host=arm-linux-gnueabihf
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unkown architecture"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
libtoolize
|
||||||
|
aclocal
|
||||||
|
autoconf
|
||||||
|
automake --add-missing
|
||||||
|
./configure $HOST --prefix=/usr
|
||||||
|
DESTDIR=$WORKSPACE/build/$arch make install
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
|
||||||
|
pipeline{
|
||||||
|
agent {
|
||||||
|
docker {
|
||||||
|
image 'xsangle/ci-tools:latest'
|
||||||
|
reuseNode true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
options {
|
||||||
|
// Limit build history with buildDiscarder option:
|
||||||
|
// daysToKeepStr: history is only kept up to this many days.
|
||||||
|
// numToKeepStr: only this many build logs are kept.
|
||||||
|
// artifactDaysToKeepStr: artifacts are only kept up to this many days.
|
||||||
|
// artifactNumToKeepStr: only this many builds have their artifacts kept.
|
||||||
|
buildDiscarder(logRotator(numToKeepStr: "1"))
|
||||||
|
// Enable timestamps in build log console
|
||||||
|
timestamps()
|
||||||
|
// Maximum time to run the whole pipeline before canceling it
|
||||||
|
timeout(time: 1, unit: 'HOURS')
|
||||||
|
// Use Jenkins ANSI Color Plugin for log console
|
||||||
|
ansiColor('xterm')
|
||||||
|
// Limit build concurrency to 1 per branch
|
||||||
|
disableConcurrentBuilds()
|
||||||
|
}
|
||||||
|
stages
|
||||||
|
{
|
||||||
|
stage('Prepare') {
|
||||||
|
steps {
|
||||||
|
sh'''
|
||||||
|
make clean || true
|
||||||
|
rm -rf build/* || true
|
||||||
|
mkdir build || true
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Build AMD64') {
|
||||||
|
steps {
|
||||||
|
script{
|
||||||
|
env.arch = "amd64"
|
||||||
|
}
|
||||||
|
build_lib()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Build ARM64') {
|
||||||
|
steps {
|
||||||
|
script{
|
||||||
|
env.arch = "arm64"
|
||||||
|
}
|
||||||
|
build_lib()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('Build ARM') {
|
||||||
|
steps {
|
||||||
|
script{
|
||||||
|
env.arch = "arm"
|
||||||
|
}
|
||||||
|
build_lib()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage("Archive") {
|
||||||
|
steps{
|
||||||
|
script {
|
||||||
|
archiveArtifacts artifacts: 'build/', fingerprint: true, onlyIfSuccessful: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
# initialise autoconf and set up some basic information about the program we’re packaging
|
# initialise autoconf and set up some basic information about the program we’re packaging
|
||||||
AC_INIT([silk], [1.0.0], [xsang.le@gmail.com])
|
AC_INIT([silk], [0.2.0], [xsang.le@gmail.com])
|
||||||
|
|
||||||
# We’re going to use automake for this project
|
# We’re going to use automake for this project
|
||||||
# [subdir-objects] if needed
|
# [subdir-objects] if needed
|
||||||
|
119
modules/ulib.c
119
modules/ulib.c
@ -23,6 +23,7 @@
|
|||||||
// zip library
|
// zip library
|
||||||
#include "3rd/zip/zip.h"
|
#include "3rd/zip/zip.h"
|
||||||
|
|
||||||
|
|
||||||
#define MAX_PATH_LEN 1024
|
#define MAX_PATH_LEN 1024
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -32,19 +33,16 @@
|
|||||||
*/
|
*/
|
||||||
static void trim(char* str, const char delim)
|
static void trim(char* str, const char delim)
|
||||||
{
|
{
|
||||||
if (!str || strlen(str) == 0)
|
if(!str || strlen(str) == 0) return;
|
||||||
return;
|
|
||||||
char * p = str;
|
char * p = str;
|
||||||
int l = strlen(p);
|
int l = strlen(p);
|
||||||
while(l > 0 && p[l - 1] == delim)
|
while(l > 0 && p[l - 1] == delim)
|
||||||
p[--l] = 0;
|
p[--l] = 0;
|
||||||
while (*p && (*p) == delim)
|
while(* p && (* p) == delim ) ++p, --l;
|
||||||
++p, --l;
|
|
||||||
memmove(str, p, l + 1);
|
memmove(str, p, l + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int l_check_login(lua_State *L)
|
static int l_check_login (lua_State *L) {
|
||||||
{
|
|
||||||
#ifdef LINUX
|
#ifdef LINUX
|
||||||
const char* username = luaL_checkstring(L,1);
|
const char* username = luaL_checkstring(L,1);
|
||||||
const char* password = luaL_checkstring(L,2);
|
const char* password = luaL_checkstring(L,2);
|
||||||
@ -90,8 +88,7 @@ static int l_check_login(lua_State *L)
|
|||||||
{
|
{
|
||||||
lua_pushboolean(L,1);
|
lua_pushboolean(L,1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
{
|
{
|
||||||
lua_pushboolean(L,0);
|
lua_pushboolean(L,0);
|
||||||
return 1;
|
return 1;
|
||||||
@ -111,8 +108,7 @@ static void get_userId(const char *name, uid_t *uid, gid_t *gid)
|
|||||||
char *endptr;
|
char *endptr;
|
||||||
if (name == NULL || *name == '\0')
|
if (name == NULL || *name == '\0')
|
||||||
{
|
{
|
||||||
*uid = -1;
|
*uid = -1; *gid=-1;
|
||||||
*gid = -1;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
u = strtol(name, &endptr, 10);
|
u = strtol(name, &endptr, 10);
|
||||||
@ -125,8 +121,7 @@ static void get_userId(const char *name, uid_t *uid, gid_t *gid)
|
|||||||
pwd = getpwnam(name);
|
pwd = getpwnam(name);
|
||||||
if (pwd == NULL)
|
if (pwd == NULL)
|
||||||
{
|
{
|
||||||
*uid = -1;
|
*uid = -1; *gid=-1;
|
||||||
*gid = -1;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
*uid = pwd->pw_uid;
|
*uid = pwd->pw_uid;
|
||||||
@ -159,8 +154,7 @@ static int l_waitpid(lua_State *L)
|
|||||||
static int l_kill(lua_State* L)
|
static int l_kill(lua_State* L)
|
||||||
{
|
{
|
||||||
int pid = luaL_checknumber(L,1);
|
int pid = luaL_checknumber(L,1);
|
||||||
if (pid == -1)
|
if(pid == -1) pid = getpid();
|
||||||
pid = getpid();
|
|
||||||
int status = kill(pid, SIGHUP);
|
int status = kill(pid, SIGHUP);
|
||||||
lua_pushnumber(L, status);
|
lua_pushnumber(L, status);
|
||||||
return 1;
|
return 1;
|
||||||
@ -234,12 +228,10 @@ static int l_getuid(lua_State *L)
|
|||||||
{
|
{
|
||||||
/* Retrieve group list */
|
/* Retrieve group list */
|
||||||
groups = malloc(ngroups * sizeof (gid_t));
|
groups = malloc(ngroups * sizeof (gid_t));
|
||||||
if (groups == NULL)
|
if (groups == NULL) {
|
||||||
{
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (getgrouplist(name, gid, groups, &ngroups) == -1)
|
if (getgrouplist(name, gid, groups, &ngroups) == -1) {
|
||||||
{
|
|
||||||
free(groups);
|
free(groups);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -247,8 +239,7 @@ static int l_getuid(lua_State *L)
|
|||||||
lua_pushstring(L,"groups");
|
lua_pushstring(L,"groups");
|
||||||
lua_newtable(L);
|
lua_newtable(L);
|
||||||
|
|
||||||
for (j = 0; j < ngroups; j++)
|
for (j = 0; j < ngroups; j++) {
|
||||||
{
|
|
||||||
gr = getgrgid(groups[j]);
|
gr = getgrgid(groups[j]);
|
||||||
if (gr != NULL)
|
if (gr != NULL)
|
||||||
{
|
{
|
||||||
@ -278,6 +269,7 @@ static void timestr(time_t time, char *buf, int len, char *format, int gmt)
|
|||||||
strftime(buf, len, format, &t);
|
strftime(buf, len, format, &t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int l_file_stat(lua_State* L, const char* path)
|
static int l_file_stat(lua_State* L, const char* path)
|
||||||
{
|
{
|
||||||
//const char* path = luaL_checkstring(L,-1);
|
//const char* path = luaL_checkstring(L,-1);
|
||||||
@ -434,8 +426,7 @@ static int l_send_file(lua_State *L)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
new = (char*)luaL_checkstring(L,2);
|
new = (char*)luaL_checkstring(L,2);
|
||||||
if (unlink(new) < 0 && errno != ENOENT)
|
if (unlink(new) < 0 && errno != ENOENT) {
|
||||||
{
|
|
||||||
lua_pushboolean(L,0);
|
lua_pushboolean(L,0);
|
||||||
goto end_send_file;
|
goto end_send_file;
|
||||||
}
|
}
|
||||||
@ -456,11 +447,13 @@ static int l_send_file(lua_State *L)
|
|||||||
while (
|
while (
|
||||||
sz > 0 &&
|
sz > 0 &&
|
||||||
read != sz &&
|
read != sz &&
|
||||||
(((ret = sendfile(tofd, fromfd, &off, sz - read)) >= 0) ||
|
(
|
||||||
(errno == EAGAIN)))
|
((ret = sendfile(tofd, fromfd, &off, sz - read)) >= 0) ||
|
||||||
|
(errno == EAGAIN)
|
||||||
|
)
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (ret < 0)
|
if(ret < 0) ret = 0;
|
||||||
ret = 0;
|
|
||||||
read += ret;
|
read += ret;
|
||||||
}
|
}
|
||||||
if(read != sz)
|
if(read != sz)
|
||||||
@ -497,8 +490,7 @@ static int l_read_dir(lua_State *L)
|
|||||||
{
|
{
|
||||||
//ignore curent directory, parent directory
|
//ignore curent directory, parent directory
|
||||||
if(strcmp(dir->d_name,".") == 0 ||
|
if(strcmp(dir->d_name,".") == 0 ||
|
||||||
strcmp(dir->d_name, "..") == 0 /*|| *(dir->d_name)=='.'*/)
|
strcmp(dir->d_name,"..")==0/*|| *(dir->d_name)=='.'*/) continue;
|
||||||
continue;
|
|
||||||
sprintf(buff,"%s/%s",path,dir->d_name);
|
sprintf(buff,"%s/%s",path,dir->d_name);
|
||||||
lua_pushnumber(L,id);
|
lua_pushnumber(L,id);
|
||||||
//lua_pushstring(L,buff);
|
//lua_pushstring(L,buff);
|
||||||
@ -538,24 +530,6 @@ static int l_chown(lua_State *L)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int l_chmod(lua_State *L)
|
|
||||||
{
|
|
||||||
const char *path = luaL_checkstring(L, 1);
|
|
||||||
const char *mode_str = luaL_checkstring(L, 2);
|
|
||||||
int mode = strtol(mode_str, 0, 8);
|
|
||||||
if (chmod(path, mode) < 0)
|
|
||||||
{
|
|
||||||
lua_pushboolean(L, 0);
|
|
||||||
lua_pushstring(L, strerror(errno));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
lua_pushboolean(L, 1);
|
|
||||||
lua_pushnil(L);
|
|
||||||
}
|
|
||||||
return 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int l_mkdir(lua_State* L)
|
static int l_mkdir(lua_State* L)
|
||||||
{
|
{
|
||||||
const char* path = luaL_checkstring(L,1);
|
const char* path = luaL_checkstring(L,1);
|
||||||
@ -600,26 +574,20 @@ static int _recursive_delete(const char *path)
|
|||||||
while ((dir = readdir(d)) != NULL)
|
while ((dir = readdir(d)) != NULL)
|
||||||
{
|
{
|
||||||
//ignore current & parent dir
|
//ignore current & parent dir
|
||||||
if (strcmp(dir->d_name, ".") == 0 || strcmp(dir->d_name, "..") == 0)
|
if(strcmp(dir->d_name,".") == 0 || strcmp(dir->d_name,"..")==0) continue;
|
||||||
continue;
|
|
||||||
// get the file
|
// get the file
|
||||||
sprintf(buff,"%s/%s",path,dir->d_name);
|
sprintf(buff,"%s/%s",path,dir->d_name);
|
||||||
if (_recursive_delete(buff) == -1)
|
if(_recursive_delete(buff) == -1) return -1;
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
closedir(d);
|
closedir(d);
|
||||||
// remove dir
|
// remove dir
|
||||||
if (rmdir(path) != 0)
|
if(rmdir(path) != 0) return -1;
|
||||||
return -1;
|
} else return -1;
|
||||||
}
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// file remove
|
// file remove
|
||||||
if (remove(path) != 0)
|
if(remove(path) != 0) return -1;
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -642,8 +610,7 @@ static int l_cmd_open(lua_State *L)
|
|||||||
|
|
||||||
/* Open the command for reading. */
|
/* Open the command for reading. */
|
||||||
fp = popen(cmd, "r");
|
fp = popen(cmd, "r");
|
||||||
if (fp == NULL)
|
if (fp == NULL) {
|
||||||
{
|
|
||||||
lua_pushnil(L);
|
lua_pushnil(L);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -668,11 +635,9 @@ static int l_cmd_read(lua_State *L)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
char buff[1024];
|
char buff[1024];
|
||||||
if (fgets(buff, sizeof(buff) - 1, fd) != NULL)
|
if(fgets(buff, sizeof(buff)-1, fd) != NULL) {
|
||||||
{
|
|
||||||
lua_pushstring(L,buff);
|
lua_pushstring(L,buff);
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
{
|
{
|
||||||
lua_pushnil(L);
|
lua_pushnil(L);
|
||||||
}
|
}
|
||||||
@ -716,8 +681,7 @@ static int l_unzip(lua_State *L)
|
|||||||
static int _add_to_zip(struct zip_t * zip, const char* path, const char* root)
|
static int _add_to_zip(struct zip_t * zip, const char* path, const char* root)
|
||||||
{
|
{
|
||||||
int st = is_dir(path);
|
int st = is_dir(path);
|
||||||
if (st == -1)
|
if(st == -1) return -1;
|
||||||
return -1;
|
|
||||||
char p1[MAX_PATH_LEN];
|
char p1[MAX_PATH_LEN];
|
||||||
char p2[MAX_PATH_LEN];
|
char p2[MAX_PATH_LEN];
|
||||||
if(st)
|
if(st)
|
||||||
@ -732,8 +696,7 @@ static int _add_to_zip(struct zip_t *zip, const char *path, const char *root)
|
|||||||
while ((dir = readdir(d)) != NULL)
|
while ((dir = readdir(d)) != NULL)
|
||||||
{
|
{
|
||||||
//ignore curent directory, parent directory
|
//ignore curent directory, parent directory
|
||||||
if (strcmp(dir->d_name, ".") == 0 || strcmp(dir->d_name, "..") == 0)
|
if(strcmp(dir->d_name,".") == 0 || strcmp(dir->d_name,"..")==0) continue;
|
||||||
continue;
|
|
||||||
// add file to zip
|
// add file to zip
|
||||||
snprintf(p1,MAX_PATH_LEN,"%s/%s", path, dir->d_name);
|
snprintf(p1,MAX_PATH_LEN,"%s/%s", path, dir->d_name);
|
||||||
snprintf(p2,MAX_PATH_LEN,"%s/%s",root,dir->d_name);
|
snprintf(p2,MAX_PATH_LEN,"%s/%s",root,dir->d_name);
|
||||||
@ -749,10 +712,8 @@ static int _add_to_zip(struct zip_t *zip, const char *path, const char *root)
|
|||||||
{
|
{
|
||||||
// if it is a file
|
// if it is a file
|
||||||
// add it to zip
|
// add it to zip
|
||||||
if (zip_entry_open(zip, root) == -1)
|
if(zip_entry_open(zip, root) == -1) return -1;
|
||||||
return -1;
|
if(zip_entry_fwrite(zip, path) == -1) return -1;
|
||||||
if (zip_entry_fwrite(zip, path) == -1)
|
|
||||||
return -1;
|
|
||||||
zip_entry_close(zip);
|
zip_entry_close(zip);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -766,11 +727,9 @@ static int l_zip(lua_State *L)
|
|||||||
// create a zip handler
|
// create a zip handler
|
||||||
struct zip_t *zip = zip_open(dest, ZIP_DEFAULT_COMPRESSION_LEVEL, 0);
|
struct zip_t *zip = zip_open(dest, ZIP_DEFAULT_COMPRESSION_LEVEL, 0);
|
||||||
|
|
||||||
if (zip == NULL)
|
if(zip == NULL) goto pfalse;
|
||||||
goto pfalse;
|
|
||||||
|
|
||||||
if (_add_to_zip(zip, src, "") == -1)
|
if(_add_to_zip(zip,src,"") == -1) goto pfalse;
|
||||||
goto pfalse;
|
|
||||||
|
|
||||||
zip_close(zip);
|
zip_close(zip);
|
||||||
|
|
||||||
@ -780,8 +739,7 @@ static int l_zip(lua_State *L)
|
|||||||
// return false
|
// return false
|
||||||
pfalse:
|
pfalse:
|
||||||
// TODO remove if filed is created
|
// TODO remove if filed is created
|
||||||
if (zip)
|
if(zip) zip_close(zip);
|
||||||
zip_close(zip);
|
|
||||||
lua_pushboolean(L,0);
|
lua_pushboolean(L,0);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -851,8 +809,7 @@ static int l_gethomedir(lua_State *L)
|
|||||||
}
|
}
|
||||||
struct passwd *pw = getpwuid(uid);
|
struct passwd *pw = getpwuid(uid);
|
||||||
|
|
||||||
if (pw == NULL)
|
if (pw == NULL) {
|
||||||
{
|
|
||||||
lua_pushnil(L);
|
lua_pushnil(L);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -884,7 +841,6 @@ static const struct luaL_Reg _lib[] = {
|
|||||||
{"waitpid", l_waitpid},
|
{"waitpid", l_waitpid},
|
||||||
{"trim", l_trim},
|
{"trim", l_trim},
|
||||||
{"chown",l_chown},
|
{"chown",l_chown},
|
||||||
{"chmod", l_chmod},
|
|
||||||
{"delete", l_delete},
|
{"delete", l_delete},
|
||||||
{"exists",l_exist},
|
{"exists",l_exist},
|
||||||
{"mkdir",l_mkdir},
|
{"mkdir",l_mkdir},
|
||||||
@ -900,7 +856,8 @@ static const struct luaL_Reg _lib[] = {
|
|||||||
{"home_dir",l_gethomedir},
|
{"home_dir",l_gethomedir},
|
||||||
{"send_file", l_send_file},
|
{"send_file", l_send_file},
|
||||||
{"is_dir", l_is_dir},
|
{"is_dir", l_is_dir},
|
||||||
{NULL, NULL}};
|
{NULL,NULL}
|
||||||
|
};
|
||||||
|
|
||||||
int luaopen_ulib(lua_State *L)
|
int luaopen_ulib(lua_State *L)
|
||||||
{
|
{
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
sqlite = require("sqlitedb")
|
sqlite = require("sqlitedb")
|
||||||
ulib = require("ulib")
|
|
||||||
if sqlite == nil then
|
if sqlite == nil then
|
||||||
return 0
|
return 0
|
||||||
end
|
end
|
||||||
@ -8,14 +8,7 @@ require("silk.core.OOP")
|
|||||||
|
|
||||||
sqlite.getdb = function(name)
|
sqlite.getdb = function(name)
|
||||||
if name:find("%.db$") then
|
if name:find("%.db$") then
|
||||||
local db = sqlite.db(name)
|
return sqlite.db(name)
|
||||||
if db then
|
|
||||||
ret,err = ulib.chmod(name,"0600")
|
|
||||||
if not ret then
|
|
||||||
LOG_WARN("Unable to change mode of database file %s: %s", name, err)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return db
|
|
||||||
elseif name:find("/") then
|
elseif name:find("/") then
|
||||||
LOG_ERROR("Invalid database name %s", name)
|
LOG_ERROR("Invalid database name %s", name)
|
||||||
return nil
|
return nil
|
||||||
@ -27,15 +20,7 @@ sqlite.getdb = function(name)
|
|||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local path = __api__.dbpath .. "/" .. name .. ".db"
|
return sqlite.db(__api__.dbpath .. "/" .. name .. ".db")
|
||||||
local db = sqlite.db(path)
|
|
||||||
if db then
|
|
||||||
local ret,err = ulib.chmod(path,"0600")
|
|
||||||
if not ret then
|
|
||||||
LOG_WARN("Unable to change mode of database file %s: %s", path)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return db
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user