For the explanation below, just keep in mind that these assumption is true:-
- owner of file == yltan(uid=742)
- user that executes the script == icetools(uid=48102)
How to run a python script as the owner of the script.
1. Create any simple python script, eg a.py:-
#!/usr/bin/env python
import os
print "Before swap::" + str(os.getresuid())
os.system("whoami")
os.setreuid(os.geteuid(),os.getuid())
print "After Swap:" + str(os.getresuid())
os.system("whoami")
/* This binary is intended to be a setuid script wrapper for dbRsync.pl.
Example compilation on an hp machine: gcc dbRsync.c -o dbRsync
This compilation creates an executable called dbRsync. After compiling,
chmod +s dbRsync (or whatever the executable is) to set the sticky bit or
it won't work.
*/
int main(int ac, char **av) {
execv( "/path/to/your/a.py", av );
}
gcc setuid_swap.c -o wrapper_a
chmod 4755 wrapper_a
sudo su - icetools
./wrapper_a
Before swap::(48102, 742, 742)
icetools
After Swap:(742, 48102, 48102)
yltan
For a detail explanation of how setuid work,
https://drive.google.com/open?id=0B_HHt58thGk_MTVwQkhleWNmZE0Alternatively, you could swap the users in the compiled code itself by doing this:-
/* This binary is intended to be a setuid script wrapper for dbRsync.pl.
Example compilation on an hp machine: gcc dbRsync.c -o dbRsync
This compilation creates an executable called dbRsync. After compiling,
chmod +s dbRsync (or whatever the executable is) to set the sticky bit or
it won't work.
*/
int main(int ac, char **av) {
int uid;
uid = geteuid();
setreuid(uid, uid);
execv( "/path/to/your/a.py", av );
}