b00ac16cb3
Shell/CNC: Moved line endings conversion from cnc to shell
...
- Also fixed DEBUG output for windows LaikaBot builds
2022-06-03 20:55:14 -05:00
fed78402a2
Bot: Obfuscated CNC public key
2022-05-27 17:51:10 -05:00
0fdca35f87
Shell: minor refactoring, cnc supports mutiple shells per auth clients
...
- while cnc supports multiple shells per auth client, the LaikaShell still only supports 1 concurrent shell at a time.
this feature is just preparing boilerplate for future features. shell treats all SHELL_* packets for the same shell, regardless of shellID
2022-05-20 14:10:53 -05:00
e3f6b76e35
Untracked .vscode
2022-05-20 01:03:43 -05:00
83c79ca662
TODO: Follow GNU GPL guidelines
2022-05-19 12:42:22 -05:00
64914a1eb1
Removed stale file
2022-05-19 12:37:45 -05:00
39417fb2ac
CI: Make windows build less fat
2022-05-19 12:33:47 -05:00
872641cc63
Lib: force to be compiled *after* VMBoxGen
2022-05-19 12:32:39 -05:00
778c9fb92a
CI: Test building for different release types & configs
2022-05-19 12:24:32 -05:00
b578f29168
added lconfig.h symbolic link
2022-05-19 12:15:22 -05:00
5aecc1b63f
VMBoxGen refactor, obfuscate static CNC ip & port strings
...
- VMBoxGen is built before shared lib
- VMBoxGen has no reliance on the shared lib, just the config file
- main config was moved to the root cmakelists
2022-05-19 01:42:40 -05:00
8afaa4d157
Lib: typo
2022-05-18 14:20:21 -05:00
f62363d4e4
Lib: MAX & MIN are now inlined functions
2022-05-18 14:12:20 -05:00
3e60cc3c0f
Lib: Minor refactoring, boilerplate content packet handlers
...
- content contexts now have events
- minor comments
2022-05-18 12:04:19 -05:00
83002faa62
Lib: minor refactoring, more lcontent.c boilerplate
2022-05-17 10:37:58 -05:00
b02f48c006
Lib: Added content stream boilerplate
...
- code is untested
2022-05-16 18:48:32 -05:00
81360a8072
Re-added lboxconfig.h
2022-05-16 17:23:45 -05:00
7175e2ec00
Win: winpersist.c now uses obfuscation
...
- The API was switched to force Ascii versions of the winapi
2022-05-16 11:02:56 -05:00
7f587f3df2
Bot: windows builds no longer open a console
2022-05-15 18:14:29 -05:00
134f1fee37
Bot: add VMBoxGen as a dependency
2022-05-15 15:27:54 -05:00
f649ca4a56
Win: Static builds & fixed winpersist.c
2022-05-14 13:24:20 -05:00
36aefba340
VMBoxGen: generate lboxconfig.h post build if LAIKA_OBFUSCATE
2022-05-11 14:50:42 -05:00
c4fc1a1fe6
misc. refactoring, updated comments and minor documentation
2022-05-10 21:03:23 -05:00
e3a1f51d60
added 'LAIKA_OBFUSCATE' cmake option
...
- if defined, enables LAIKA_BOX obfuscation for variables
- new macros (LAIKA_BOX_SKID_START & LAIKA_BOX_SKID_END), become no-ops if LAIKA_OBFUSCATE is undefined
- TODO: use cmake to automate the generation of lboxconfig.h
2022-05-10 20:28:54 -05:00
062d8f1dd6
update README
2022-05-09 17:02:48 -05:00
b190f5dd16
Removed leftovers
2022-05-09 16:42:09 -05:00
71db213261
Implemented VMBoxes, linux persistence related strings are obfuscated, added VMBoxGen tool
...
- lboxconfig.h holds obfuscated data, which is generated by VMBoxGen
- linpersist.c now uses obfuscated strings
2022-05-09 16:41:01 -05:00
7ca855410d
Box: added LAIKA_BOX_DATA_INDX & LAIKA_BOX_UNLOCKED_INDX macros
...
- they represent the indx in the constant list the box's unlocked & data pointers will be
2022-05-08 01:45:36 -05:00
63e36d1ebb
Bot: small shell.[ch] + native refactor
...
- `struct sLaika_shell` is now a shared struct, `struct sLaika_RAWshell` is the native implementation with `struct sLaika_shell` as it's first member
2022-05-08 01:21:37 -05:00
7d96f3252c
Major shell packet refactoring
...
- can now open multiple shells per peer (change LAIKA_MAX_SHELLS)
- more sanity checking for public keys (new peers with duplicate keys are killed
- misc. refactoring, added cnc/cpeer.[ch]
2022-05-07 20:09:42 -05:00
67f404dac6
removed unused macro
2022-05-03 15:54:42 -05:00
ead2f08c87
update README
2022-05-01 14:54:38 -05:00
a4239282b2
Box: added LAIKA_BOX_SKID, vmTest now uses the LAIKA_BOX_SKID box
...
- updated CONTRIB
2022-05-01 14:41:32 -05:00
f90c99ce64
Bot: Strip symbols
2022-05-01 14:21:44 -05:00
c63bfe00af
VM: added OP_DECPTR, minor refactoring of laikaB_unlock
2022-04-30 16:21:29 -05:00
c16cdf3644
Windows: Fix laikaV_execute for MSVC
2022-04-30 13:06:18 -05:00
a4e04297a7
Tool: added VM Test
...
- includes a tiny demo for decoding secret messages
2022-04-29 15:51:59 -05:00
36c3c8a65f
Box: implemented laikaB_unlock() & laikaB_lock()
2022-04-28 18:10:15 -05:00
4333d03a51
VM: minor refacotring, added OP_TESTJMP & OP_DEBUG
2022-04-28 11:57:32 -05:00
9cea98c86a
Forced inlining for both GCC/clang & MSVC
2022-04-28 11:07:11 -05:00
64f7e40fa0
Windows: Persistence via windows registry
2022-04-22 17:20:31 -05:00
e80f007df9
Bot: Minor refactoring, tell cnc if failed to open shell
2022-04-20 10:23:00 -05:00
c3c42e298f
Windows: use COMSPEC environment variable to grab the shell
...
- shells on windows are now opened from the COMSPEC env variable
- cnc will now ignore malformed shell packets from bots instead of killing them
2022-04-20 10:10:44 -05:00
cfe633f1d5
Windows: Added registry manipulation boilerplate
2022-04-18 17:05:26 -05:00
136d523607
CONTRIB: Documented packet handlers, added more smaller todos
2022-04-17 20:16:03 -05:00
2338e7215a
Added CONTRIBUTING.md
2022-04-17 01:12:01 -05:00
34dd36fb67
Windows: implemented laikaB_markRunning() & laikaB_unmarkRunning()
...
- use Sleep() for LAIKA_PERSISTENCE in main()
- use Mutex for checking existing LaikaBots
- switched to TEXT() for win32 strings
2022-04-16 23:54:07 -05:00
231881c960
Bot: Minor laikaB_freeShell refactoring
2022-04-16 23:08:21 -05:00
b60203d3f2
Linux: implemented laikaB_markRunning() & laikaB_unmarkRunning()
...
- switched to file locks as that's more discreet
- tied to LAIKA_PERSISTENCE being defined
2022-04-16 22:56:05 -05:00
d94a6a5e17
shellT_addChar(): Added ascii validation, ignore non-printable input
2022-04-15 15:40:25 -05:00