Skip to content

Commit

Permalink
Replace Lua with LuaJIT and restrict loaded libraries for auto splitt…
Browse files Browse the repository at this point in the history
…ers (#34)
  • Loading branch information
wins1ey authored Apr 11, 2024
2 parents 81e501f + 9eb6581 commit 37411d8
Show file tree
Hide file tree
Showing 9 changed files with 61 additions and 14 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
- name: "Install dependencies"
run: |
sudo apt -y update
sudo apt -y install libgtk-3-dev libx11-dev libjansson-dev liblua5.4-dev
sudo apt -y install libgtk-3-dev libx11-dev libjansson-dev libluajit-5.1-dev
- name: "Run make"
run: make -j
Expand Down
4 changes: 2 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
BIN := LAST

INC := `pkg-config --cflags gtk+-3.0 x11 jansson lua`
INC := `pkg-config --cflags gtk+-3.0 x11 jansson luajit`
CFLAGS := -std=gnu99 -O2 -pthread -Wall -Wno-unused-parameter
LDFLAGS := `pkg-config --libs gtk+-3.0 x11 jansson lua`
LDFLAGS := `pkg-config --libs gtk+-3.0 x11 jansson luajit`

SRC_DIR := ./src
OBJ_DIR := ./obj
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ LAST requires the following dependencies on your system to compile:
- `libgtk+-3.0`
- `x11`
- `libjansson`
- `lua`
- `luajit`

## Installation

Expand Down
2 changes: 1 addition & 1 deletion resources
51 changes: 49 additions & 2 deletions src/auto-splitter.c
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@
#include <sys/stat.h>
#include <string.h>

#include <lua.h>
#include <lauxlib.h>
#include <luajit.h>
#include <lualib.h>
#include <lauxlib.h>

#include "memory.h"
#include "auto-splitter.h"
Expand All @@ -26,6 +26,24 @@ atomic_bool toggle_loading = false;
atomic_bool call_reset = false;
bool prev_is_loading;

static const char* disabled_functions[] = {
"collectgarbage",
"dofile",
"getmetatable",
"setmetatable",
"getfenv",
"setfenv",
"load",
"loadfile",
"loadstring",
"rawequal",
"rawget",
"rawset",
"module",
"require",
"newproxy",
};

extern last_process process;

// I have no idea how this works
Expand Down Expand Up @@ -85,6 +103,34 @@ void check_directories()
}
}

static const luaL_Reg lj_lib_load[] = {
{ "", luaopen_base },
{ LUA_STRLIBNAME, luaopen_string },
{ LUA_MATHLIBNAME, luaopen_math },
{ LUA_BITLIBNAME, luaopen_bit },
{ LUA_JITLIBNAME, luaopen_jit },
{ NULL, NULL }
};

LUALIB_API void luaL_openlibs(lua_State *L)
{
const luaL_Reg *lib;
for (lib = lj_lib_load; lib->func; lib++) {
lua_pushcfunction(L, lib->func);
lua_pushstring(L, lib->name);
lua_call(L, 1, 0);
}
}

void disable_functions(lua_State* L, const char** functions)
{
for (int i = 0; functions[i] != NULL; i++)
{
lua_pushnil(L);
lua_setglobal(L, functions[i]);
}
}

/*
Generic function to call lua functions
Signatures are something like `disb>s`
Expand Down Expand Up @@ -257,6 +303,7 @@ void run_auto_splitter()
{
lua_State* L = luaL_newstate();
luaL_openlibs(L);
disable_functions(L, disabled_functions);
lua_pushcfunction(L, find_process_id);
lua_setglobal(L, "process");
lua_pushcfunction(L, read_address);
Expand Down
4 changes: 2 additions & 2 deletions src/memory.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
#include <string.h>
#include <sys/uio.h>

#include <lua.h>
#include <luajit.h>

#include "memory.h"
#include "process.h"
Expand Down Expand Up @@ -195,4 +195,4 @@ int read_address(lua_State* L)
}

return 1;
}
}
4 changes: 2 additions & 2 deletions src/memory.h
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
#ifndef __MEMORY_H__
#define __MEMORY_H__

#include <lua.h>
#include <luajit.h>
#include <sys/uio.h>
#include <stdlib.h>

ssize_t process_vm_readv(int pid, struct iovec *mem_local, int liovcnt, struct iovec *mem_remote, int riovcnt, int flags);

int read_address(lua_State* L);

#endif /* __MEMORY_H__ */
#endif /* __MEMORY_H__ */
2 changes: 1 addition & 1 deletion src/process.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
#include <unistd.h>
#include <signal.h>

#include <lua.h>
#include <luajit.h>

#include "process.h"
#include "auto-splitter.h"
Expand Down
4 changes: 2 additions & 2 deletions src/process.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

#include <stdint.h>

#include <lua.h>
#include <luajit.h>

struct last_process
{
Expand All @@ -19,4 +19,4 @@ int process_exists();
int find_process_id(lua_State* L);
int getPid(lua_State* L);

#endif /* __PROCESS_H__ */
#endif /* __PROCESS_H__ */

0 comments on commit 37411d8

Please sign in to comment.