Home | History | Annotate | Download | only in tpmtoken_init
      1 #! /usr/bin/expect -f
      2 #
      3 # Copyright (c) International Business Machines  Corp., 2005
      4 #
      5 # This program is free software;  you can redistribute it and#or modify
      6 # it under the terms of the GNU General Public License as published by
      7 # the Free Software Foundation; either version 2 of the License, or
      8 # (at your option) any later version.
      9 #
     10 # This program is distributed in the hope that it will be useful, but
     11 # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
     12 # or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
     13 # for more details.
     14 #
     15 # You should have received a copy of the GNU General Public License
     16 # along with this program;  if not, write to the Free Software
     17 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
     18 #
     19 
     20 set P11_SO_PWD $env(P11_SO_PWD)
     21 set P11_USER_PWD $env(P11_USER_PWD)
     22 set timeout 30
     23 
     24 # Initiate the tpmtoken_init command
     25 #   it should have been initialized at this point
     26 #   if it has not, it is an error
     27 spawn tpmtoken_init
     28 expect {
     29 	-re "Clear the TPM token data?" {
     30 		set reinit 1
     31 		send "y\n"
     32 	}
     33 	-re "A new TPM security officer password is needed." {
     34 		set reinit 0
     35 		send "$P11_SO_PWD\n"
     36 	}
     37 }
     38 
     39 if {$reinit == 1} {
     40 	expect -re "Enter the TPM security officer password: "
     41 	send "$P11_SO_PWD\n"
     42 }
     43 expect -re "Enter new password: "
     44 send "$P11_SO_PWD\n"
     45 expect -re "Confirm password: "
     46 send "$P11_SO_PWD\n"
     47 expect -re "A new TPM user password is needed."
     48 expect -re "Enter new password: "
     49 send "$P11_USER_PWD\n"
     50 expect -re "Confirm password: "
     51 send "$P11_USER_PWD\n"
     52 
     53 expect timeout
     54 
     55 set rc_list [wait -i $spawn_id]
     56 set rc [lindex $rc_list {3}]
     57 
     58 if {$reinit == 0} { set rc 1 }
     59 
     60 exit $rc
     61