Wanlong Gao
2012-Apr-12 07:26 UTC
[Libguestfs] [PATCH] sysprep: remove the bash history of users
Remove the bash history of users in home directory, and history of root. Signed-off-by: Wanlong Gao <gaowanlong at cn.fujitsu.com> --- sysprep/Makefile.am | 2 ++ sysprep/sysprep_operation_bash_history.ml | 44 +++++++++++++++++++++++++++++ 2 files changed, 46 insertions(+) create mode 100644 sysprep/sysprep_operation_bash_history.ml diff --git a/sysprep/Makefile.am b/sysprep/Makefile.am index 8730bc0..3a48702 100644 --- a/sysprep/Makefile.am +++ b/sysprep/Makefile.am @@ -33,6 +33,7 @@ SOURCES = \ main.ml \ sysprep_operation.ml \ sysprep_operation.mli \ + sysprep_operation_bash_history.ml \ sysprep_operation_cron_spool.ml \ sysprep_operation_dhcp_client_state.ml \ sysprep_operation_dhcp_server_state.ml \ @@ -56,6 +57,7 @@ if HAVE_OCAML OBJECTS = \ utils.cmx \ sysprep_operation.cmx \ + sysprep_operation_bash_history.cmx \ sysprep_operation_cron_spool.cmx \ sysprep_operation_dhcp_client_state.cmx \ sysprep_operation_dhcp_server_state.cmx \ diff --git a/sysprep/sysprep_operation_bash_history.ml b/sysprep/sysprep_operation_bash_history.ml new file mode 100644 index 0000000..1f33ab6 --- /dev/null +++ b/sysprep/sysprep_operation_bash_history.ml @@ -0,0 +1,44 @@ +(* virt-sysprep + * Copyright (C) 2012 Fujitsu Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program; if not, write to the Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + *) + +open Sysprep_operation + +module G = Guestfs + +let bash_history_perform g root + let typ = g#inspect_get_type root in + if typ <> "windows" then ( + let files = g#glob_expand "/home/*/.bash_history" in + Array.iter g#rm_rf files; + g#rm_rf "/root/.bash_history"; + [] + ) + else [] + +let bash_history_op = { + name = "bash-history"; + pod_description = "\ +Remove the bash history in the guest. + +Remove the bash history of user root and any other users +who have a bash history file in his home directory."; + extra_args = []; + perform = bash_history_perform; +} + +let () = register_operation bash_history_op -- 1.7.10.rc3
Richard W.M. Jones
2012-Apr-12 08:11 UTC
[Libguestfs] [PATCH] sysprep: remove the bash history of users
On Thu, Apr 12, 2012 at 03:26:48PM +0800, Wanlong Gao wrote:> Remove the bash history of users in home directory, > and history of root. > > Signed-off-by: Wanlong Gao <gaowanlong at cn.fujitsu.com> > --- > sysprep/Makefile.am | 2 ++ > sysprep/sysprep_operation_bash_history.ml | 44 +++++++++++++++++++++++++++++ > 2 files changed, 46 insertions(+) > create mode 100644 sysprep/sysprep_operation_bash_history.ml > > diff --git a/sysprep/Makefile.am b/sysprep/Makefile.am > index 8730bc0..3a48702 100644 > --- a/sysprep/Makefile.am > +++ b/sysprep/Makefile.am > @@ -33,6 +33,7 @@ SOURCES = \ > main.ml \ > sysprep_operation.ml \ > sysprep_operation.mli \ > + sysprep_operation_bash_history.ml \ > sysprep_operation_cron_spool.ml \ > sysprep_operation_dhcp_client_state.ml \ > sysprep_operation_dhcp_server_state.ml \ > @@ -56,6 +57,7 @@ if HAVE_OCAML > OBJECTS = \ > utils.cmx \ > sysprep_operation.cmx \ > + sysprep_operation_bash_history.cmx \ > sysprep_operation_cron_spool.cmx \ > sysprep_operation_dhcp_client_state.cmx \ > sysprep_operation_dhcp_server_state.cmx \ > diff --git a/sysprep/sysprep_operation_bash_history.ml b/sysprep/sysprep_operation_bash_history.ml > new file mode 100644 > index 0000000..1f33ab6 > --- /dev/null > +++ b/sysprep/sysprep_operation_bash_history.ml > @@ -0,0 +1,44 @@ > +(* virt-sysprep > + * Copyright (C) 2012 Fujitsu Inc. > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License as published by > + * the Free Software Foundation; either version 2 of the License, or > + * (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License along > + * with this program; if not, write to the Free Software Foundation, Inc., > + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. > + *) > + > +open Sysprep_operation > + > +module G = Guestfs > + > +let bash_history_perform g root > + let typ = g#inspect_get_type root in > + if typ <> "windows" then ( > + let files = g#glob_expand "/home/*/.bash_history" in > + Array.iter g#rm_rf files; > + g#rm_rf "/root/.bash_history";Since .bash_history isn't likely to be a directory, I think it's better to write: g#rm ... However you'll need to protect against missing files, so: try g#rm file with G.Error _ -> () (compare with sysprep/sysprep_operation_smolt_uuid.ml) The rest looks OK to me. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones virt-top is 'top' for virtual machines. Tiny program with many powerful monitoring features, net stats, disk stats, logging, etc. http://et.redhat.com/~rjones/virt-top
Reasonably Related Threads
- [PATCH 1/2] sysprep: remove ca certificates in the guest
- [PATCH] virt-sysprep:add logging feature
- [PATCH RFC] sysprep:add logging feature
- Re: [PATCH 1/3] sysprep, get-kernel: explicit the Guestfs parameter
- [PATCH 1/3] sysprep, get-kernel: explicit the Guestfs parameter