rc.d and environment variables
Da Rock
freebsd-questions at herveybayaustralia.com.au
Fri Dec 24 04:39:42 UTC 2010
On 12/24/10 13:50, Victor Sudakov wrote:
> Polytropon wrote:
>
>>> Of course I can always write my own script or put something like
>>> su -l svn -c 'usr/local/bin/svnserve -d --listen-port=3690 bla bla'
>>> into /etc/rc.local, but the question was about the rc.d framework.
>>>
>> Environmental variables cannot be controlled by the rc.d
>> framework, as far as I understand. Using login classes to
>> define them should be the correct way.
>>
>> > From "man login.conf":
>>
>> setenv list A comma-separated list of
>> environment variables and
>> values to which they are to
>> be set.
>>
> I thought of that, and in fact I wrote about it in the very first
> message:
>
>
>>> I tried to do this via a login class for the svn user, but it did
>>> not work. If I first 'su -l svn' and then start the daemon
>>> manually, the environment variable is set all right, but not when
>>> it is started from /usr/local/etc/rc.d/svnserve.
>>>
>
>> What did you enter for the svnserve user in /etc/login.conf,
>>
> svn:\
> :setenv=KRB5_KTNAME=~/svn.keytab:\
> :tc=default:
>
>
>
>> and did you make sure there is no override setting in the
>> corresponding user's ~/.login.conf?
>>
> I am pretty sure because when I login interactively as svn, I see
>
> $ whoami
> svn
> $ printenv | grep KT
> KRB5_KTNAME=/home/svn/svn.keytab
> $
>
> But it does not work for the rc.d script.
>
>
Doesn't the rc.d script run as root initially and then a method (default
flags, etc) is used to change the owner to a nobody (restricted
privilege user)? Just my 2c, but please correct me if I'm wrong.
More information about the freebsd-questions
mailing list