#!/bin/sh # # CDDL HEADER START # # The contents of this file are subject to the terms of the # Common Development and Distribution License, Version 1.0 only # (the "License"). You may not use this file except in compliance # with the License. # # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE # or http://www.opensolaris.org/os/licensing. # See the License for the specific language governing permissions # and limitations under the License. # # When distributing Covered Code, include this CDDL HEADER in each # file and include the License file at usr/src/OPENSOLARIS.LICENSE. # If applicable, add the following below this CDDL HEADER, with the # fields enclosed by brackets "[]" replaced with your own identifying # information: Portions Copyright [yyyy] [name of copyright owner] # # CDDL HEADER END # # # Copyright 2004 Sun Microsystems, Inc. All rights reserved. # Use is subject to license terms. # #pragma ident "%Z%%M% %I% %E% SMI" # The -c and -u options are used by system configruation. USAGE="$0 [-c|-u]" TEXTDOMAIN="SUNW_OST_OSCMD" export TEXTDOMAIN # As of Oct. 1, 1995, any new system shipped will have root # property "energystar-v2" defined in its prom. ESTAR_PROP="energystar-v2" # Power Management configuration file PWR_CONF=/etc/power.conf SHUTDOWN_PATTERN="autoshutdown[ ]" TMP=/var/run/tmp1.$$ # If this flag is present, user will be asked the autoshutdown # question again even when autoshutdown is already configured. ASK_AGAIN_FLAG=/etc/.PM_RECONFIGURE # This is provided for auto-install. # If either of the files is present, autoshutdown will be configured # accordingly silently. SHUTDOWN_ENABLE_FLAG=/autoshutdown SHUTDOWN_DISABLE_FLAG=/noautoshutdown # Autoshutdown is not supported on diskless systems. IS_DISKLESS="" # Default autoshutdown setup. DEFAULT_IDLE_TIME="30" DEFAULT_START_TIME="9:00" DEFAULT_FINISH_TIME="9:00" # Currently autoshutdown setup in the configuration file. CURRENT_IDLE_TIME="" CURRENT_START_TIME="" CURRENT_FINISH_TIME="" CURRENT_BEHAVIOR="" # Autoshutdown confirmation message to be prompted in the question1. # In the following message, each escape sequence requires three # backslashes to prevent the interpretation by the shell and gettext # before being passed to ckyorn. In the message catalog, each message # will have two backslashes. MSG1=`gettext '\\\tAfter 30 minutes of idle time on this system, your system \ state\\\n\\\twill automatically be saved to disk, and the system will \ power-off.\\\n\\\n\\\tLater, when you want to use the system again, and \ you turn the power\\\n\\\tback on, your system will be restored to its \ previous state,\\\n\\\tincluding all the programs that you were running.\ \\\n\\\n\\\tDo you want this automatic power-saving shutdown?\\\n\ \\\t(If this system is used as a server, answer n)'` # Message to be prompted in question2. # In the following message, each escape sequence requires three # backslashes to prevent the interpretation by the shell and gettext # before being passed to ckyorn. In the message catalog, each message # will have two backslashes. MSG2=`gettext '\\\tDo you want the system to ask about this again, when \ you next reboot?\\\n\\\t(This gives you the chance to try it before deciding \ whether\\\n\\\tto keep it.)'` # The autoshutdown comment to be put into the power management config file. SHUTDOWN_COMMENT="# Auto-Shutdown\t\tIdle(min)\tStart/Finish(hh:mm)\tBehavior" # Set up path. PATH="/usr/bin:/usr/sbin:${PATH}" export PATH # # Get current autoshutdown setup. # get_behavior() { grep -s "$SHUTDOWN_PATTERN" $PWR_CONF > /dev/null if [ $? = 0 ]; then set - `grep "$SHUTDOWN_PATTERN" $PWR_CONF` CURRENT_IDLE_TIME=$2 CURRENT_START_TIME=$3 CURRENT_FINISH_TIME=$4 CURRENT_BEHAVIOR=$5 fi } # # Set the autoshutdown behavior in the configuration file. # The autoshutdown token can be preceded by spaces. # The resulting configuration will be based on the first autoshutdown # line if there is more than one in the configuration file. # set_behavior() { BEHAVIOR="$1" grep -s "$SHUTDOWN_PATTERN" $PWR_CONF > /dev/null if [ $? = 0 ]; then set - `grep "$SHUTDOWN_PATTERN" $PWR_CONF` CURRENT_IDLE_TIME=$2 CURRENT_START_TIME=$3 CURRENT_FINISH_TIME=$4 CURRENT_BEHAVIOR=$5 fi if [ "$BEHAVIOR" = "unconfigured" ]; then IDLE=$DEFAULT_IDLE_TIME START=$DEFAULT_START_TIME FINISH=$DEFAULT_FINISH_TIME else { if [ "$CURRENT_IDLE_TIME" = "" ]; then IDLE="$DEFAULT_IDLE_TIME" else IDLE="$CURRENT_IDLE_TIME" fi if [ "$CURRENT_START_TIME" = "" ]; then START="$DEFAULT_START_TIME" else START="$CURRENT_START_TIME" fi if [ "$CURRENT_FINISH_TIME" = "" ]; then FINISH="$DEFAULT_FINISH_TIME" else FINISH="$CURRENT_FINISH_TIME" fi } fi grep -v "# Auto-Shutdown[ ]" $PWR_CONF | grep -v "$SHUTDOWN_PATTERN" > $TMP echo $SHUTDOWN_COMMENT >> $TMP echo "autoshutdown\t\t${IDLE}\t\t${START} ${FINISH}\t\t${BEHAVIOR}" >> \ $TMP cp $TMP $PWR_CONF rm $TMP } # # Print out the Energystar guidelines. # print_estar_guidelines() { echo echo "`gettext '\t================================================================'`" echo "`gettext '\tThis system is configured to conserve energy.'`" echo "`gettext '\t================================================================'`" } # # Ask user for autoshutdown confirmation. # question1() { ans=`ckyorn -Q -d y -p "$1"` case $ans in y|yes|Y|Yes|YES) set_behavior shutdown echo echo "`gettext '\tAutoshutdown remains enabled.'`" break ;; n|no|N|No|NO) set_behavior noshutdown echo echo "`gettext '\tAutoshutdown has been disabled.'`" break ;; esac } # # Ask user whether they want to be asked about the question again during # next reboot. # question2() { ans=`ckyorn -Q -d n -p "$1"` case $ans in y|yes|Y|Yes|YES) touch $ASK_AGAIN_FLAG echo "`gettext '\n\tThe system will ask you about automatic shutdown at the next reboot.'`" break ;; n|no|N|No|NO) rm -f $ASK_AGAIN_FLAG echo "`gettext '\n\tThe system will not ask you again about automatic shutdown.'`" break ;; esac } ################ # Main # ################ # # Exit if /etc/power.conf does not exist or is not writable. # if [ ! -f $PWR_CONF -o ! -w $PWR_CONF ]; then exit 1 fi # # Usage: sysidpm [-c|-u] # if [ $# -gt 1 ]; then echo $USAGE exit 1 fi # # The postinstall script of some power management package should have # added this command into the application list in /etc/.sysidconfig.apps. # System configuration and unconfiguration will call those applications # with option -c and -u respectively. # if [ $# -eq 1 ]; then case $1 in -c) # Does not need to do anything. exit 0 ;; -u) # Reset the behavior back to unconfigured state. set_behavior unconfigured # Remove the statefile line too. grep -v statefile $PWR_CONF > $TMP cp $TMP $PWR_CONF rm $TMP exit 0 ;; *) echo $USAGE exit 1 ;; esac fi # # Get current autoshutdown setup. # get_behavior # # If this is a diskless system, silently disable autoshutdown and exit. # ROOT_FSTYPE=`df -n / | (read w1 w2 w3; echo $w3)` if [ $ROOT_FSTYPE != "ufs" ]; then set_behavior noshutdown exit 0 fi # # If /autoshutdown is present, silently enable autoshutdown and exit. # if [ -f $SHUTDOWN_ENABLE_FLAG ]; then set_behavior shutdown rm $SHUTDOWN_ENABLE_FLAG exit 0 fi # # If /noautoshutdown is present, silently disable autoshutdown and # exit. # if [ -f $SHUTDOWN_DISABLE_FLAG ]; then set_behavior noshutdown rm $SHUTDOWN_DISABLE_FLAG exit 0 fi # # If this is an EnergyStar compliant system, the default should # have autoshutdown enabled. However we don't want to surprise # users, so let's confirm with the user. # prtconf -vp | grep -s -w ${ESTAR_PROP} > /dev/null if [ $? = 0 ]; then if [ "$CURRENT_BEHAVIOR" = "unconfigured" -o -f $ASK_AGAIN_FLAG ]; then print_estar_guidelines question1 "$MSG1" question2 "$MSG2" echo "`gettext '\n\tThe \"Power Management\" chapter in the \"Solaris Common Desktop\n\tEnvironment: User Guide\" describes more about how to change\n\tand set workstation energy-saving features.'`" echo fi exit 0 fi # # The rest of the cases will have 'default' autoshutdown behavior. # if [ "$CURRENT_BEHAVIOR" = "unconfigured" ]; then set_behavior default exit 0 fi # # We are here because either the autoshutdown line has been # removed or the behavior has been configured. It can be a result # of upgrade. In that case, the configuration file should not # be changed. Let's exit. exit 0