emacs-bug-tracker
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

bug#49430: closed ([PATCH] doc: Add auto login to tty guide to the cookb


From: GNU bug Tracking System
Subject: bug#49430: closed ([PATCH] doc: Add auto login to tty guide to the cookbook.)
Date: Wed, 07 Jul 2021 09:30:02 +0000

Your message dated Wed, 07 Jul 2021 11:29:12 +0200
with message-id 
<29902d02d007a22b66037308e1f1a89fc6352918.camel@student.tugraz.at>
and subject line Re: [PATCH] doc: Add auto login a user to a specific tty guide 
to the cookbook.
has caused the debbugs.gnu.org bug report #49430,
regarding [PATCH] doc: Add auto login to tty guide to the cookbook.
to be marked as done.

(If you believe you have received this mail in error, please contact
help-debbugs@gnu.org.)


-- 
49430: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=49430
GNU Bug Tracking System
Contact help-debbugs@gnu.org with problems
--- Begin Message --- Subject: [PATCH] doc: Add auto login to tty guide to the cookbook. Date: Tue, 6 Jul 2021 02:20:04 -0400
From: Joshua Branson <jbranso@gnucode.me>

* doc/guix-cookbook.texi (System Configuration): Add a brief guide that
explains auto login to a TTY.  This is a follow up to bug 48974.
---
 doc/guix-cookbook.texi | 59 +++++++++++++++++++++++++++++++++++++++++-
 1 file changed, 58 insertions(+), 1 deletion(-)

diff --git a/doc/guix-cookbook.texi b/doc/guix-cookbook.texi
index 1cddaa7faf..47f8d60ade 100644
--- a/doc/guix-cookbook.texi
+++ b/doc/guix-cookbook.texi
@@ -17,6 +17,7 @@ Copyright @copyright{} 2020 Marcin Karpezo@*
 Copyright @copyright{} 2020 Brice Waegeneire@*
 Copyright @copyright{} 2020 Andr?? Batista@*
 Copyright @copyright{} 2020 Christopher Lemmer Webber
+Copyright @copyright{} 2021 Joshua Branson@*
 
 Permission is granted to copy, distribute and/or modify this document
 under the terms of the GNU Free Documentation License, Version 1.3 or
@@ -85,7 +86,7 @@ Packaging
 
 System Configuration
 
-* Customizing the Kernel::      Creating and using a custom Linux kernel
+* Auto Login to TTY::            Set up auto login via a TTY
 
 
 @end detailmenu
@@ -1353,6 +1354,7 @@ chapter is to demonstrate some advanced configuration 
concepts.
 reference.
 
 @menu
+* Auto Login to TTY::            Set up auto login via a TTY.
 * Customizing the Kernel::       Creating and using a custom Linux kernel on 
Guix System.
 * Guix System Image API::        Customizing images to target specific 
platforms.
 * Connecting to Wireguard VPN::  Connecting to a Wireguard VPN.
@@ -1363,6 +1365,61 @@ reference.
 * Setting up NGINX with Lua:: Configuring NGINX web-server to load Lua modules.
 @end menu
 
+@node Auto Login to TTY
+@section Auto Login to TTY
+
+Guix System currently offers auto login to a tty via @code{mingetty},
+but a newcomer to Guix System may be unfamiliar with setting up auto
+login.  First, a note of caution.  Setting up auto login to a tty, means
+that anyone can turn on your computer and run commands as your regular
+user. If you have encrypted your @code{/} partition, and thus need to
+enter in a passphrase at boot, then perhaps auto login is a secure and
+convenient option for you.
+
+Here is how one might go about setting up auto login to a tty:
+
+@lisp
+(define (auto-login-to-tty config tty user)
+  (if (string=? tty (mingetty-configuration-tty config))
+        (mingetty-configuration
+         (inherit config)
+         (auto-login user))
+        config))
+
+(define %my-base-services
+  (modify-services %base-services
+    (mingetty-service-type config =>
+                           (auto-login-to-tty config "tty3" "joshua"))))
+
+(operating-system
+    (host-name "dobby")
+    ...
+    (services
+     (append
+      (list (service dhcp-client-service-type))
+      %my-base-services)))
+@end lisp
+
+Note that the above code automatically logs the user into @code{tty3}.
+Any TTY will work, though perhaps it is best not to use @code{tty1},
+which is reserved for error messages.
+
+You could also start your graphical environment via your
+@code{~/.bash_profile}.  Here is an example script to auto start the
+sway window manager:
+
+@example shell
+# Honor per-interactive-shell startup file
+if [ -f ~/.bashrc ]; then . ~/.bashrc; fi
+
+if [[ -z $DISPLAY ]] && [[ $(tty) = /dev/tty3 ]]; then
+    exec dbus-run-session sway
+fi
+@end example
+
+When Guix Home is merged, the above bash script may be replaced by a
+@code{home.scm} file.
+
 @node Customizing the Kernel
 @section Customizing the Kernel
 
-- 
2.32.0




--- End Message ---
--- Begin Message --- Subject: Re: [PATCH] doc: Add auto login a user to a specific tty guide to the cookbook. Date: Wed, 07 Jul 2021 11:29:12 +0200 User-agent: Evolution 3.34.2
I've pushed your code with some slight cosmetic changes, which I'll
list below to master.

- I changed the title of the section to easier fit into a menu.
- I changed the example to mimic the one given in the manual
- I rephrased the bit about encrypted root.

Note, that applying the patch was a bit of a pain, as your send-email
setup appears to set the following:

Content-Type: text/plain; charset=y

Please use UTF-8 in the future ;P

Also, I'll probably receive a mail in a few hours stating that <
jbranso@gnucode.me> can not be reached.  Does this mail really satisfy
the conditions one would typically have for having it in AUTHORS?

Regards,
Leo

Am Dienstag, den 06.07.2021, 21:39 -0400 schrieb Joshua Branson:
> From: Joshua Branson <jbranso@gnucode.me>
> 
> * doc/guix-cookbook.texi (System Configuration): Add a brief guide
> that
> explains auto login a user to one TTY.  This is a follow up to bug
> 48974.
> 
> * doc/guix.texi (System Services): Add an texinfo anchor, so that the
> cookbook
> entry "Auto Login a User to a Specific TTY" can refer back to the
> precise
> point that the GNU Guix Reference manual.  Also add a reference to
> the
> cookbook that shows how to auto login a specific user to one TTY.
> ---
>  doc/guix-cookbook.texi | 58
> +++++++++++++++++++++++++++++++++++++++++-
>  doc/guix.texi          | 13 ++++++----
>  2 files changed, 65 insertions(+), 6 deletions(-)
> 
> diff --git a/doc/guix-cookbook.texi b/doc/guix-cookbook.texi
> index 1cddaa7faf..a9c3ef6407 100644
> --- a/doc/guix-cookbook.texi
> +++ b/doc/guix-cookbook.texi
> @@ -17,6 +17,7 @@ Copyright @copyright{} 2020 Marcin Karpezo@*
>  Copyright @copyright{} 2020 Brice Waegeneire@*
>  Copyright @copyright{} 2020 André Batista@*
>  Copyright @copyright{} 2020 Christopher Lemmer Webber
> +Copyright @copyright{} 2021 Joshua Branson@*
>  
>  Permission is granted to copy, distribute and/or modify this
> document
>  under the terms of the GNU Free Documentation License, Version 1.3
> or
> @@ -85,7 +86,7 @@ Packaging
>  
>  System Configuration
>  
> -* Customizing the Kernel::      Creating and using a custom Linux
> kernel
> +* Auto Login a User to a Specific TTY::   Automatically Login a User
> to a Specific TTY
>  
>  
>  @end detailmenu
> @@ -1353,6 +1354,7 @@ chapter is to demonstrate some advanced
> configuration concepts.
>  reference.
>  
>  @menu
> +* Auto Login a User to a Specific TTY::   Automatically Login a User
> to a Specific TTY
>  * Customizing the Kernel::       Creating and using a custom Linux
> kernel on Guix System.
>  * Guix System Image API::        Customizing images to target
> specific platforms.
>  * Connecting to Wireguard VPN::  Connecting to a Wireguard VPN.
> @@ -1363,6 +1365,60 @@ reference.
>  * Setting up NGINX with Lua:: Configuring NGINX web-server to load
> Lua modules.
>  @end menu
>  
> +@node Auto Login a User to a Specific TTY
> +@section Auto Login a User to a Specific TTY
> +
> +While the Guix manual explains auto-login one user to @emph{all}
> TTYs (
> +@pxref{auto-login to TTY,,, guix, GNU Guix Reference Manual}), some
> +might prefer a situation, in which one user is logged into one TTY
> with
> +the other TTYs either configured to login different users or no one
> at
> +all.  Note that one can auto-login one user to any TTY, but it is
> +usually advisable to avoid @code{tty1}, which, by default, is used
> to
> +log warnings and errors.
> +
> +Here is how one might set up auto login for one user to one tty:
> +
> +@lisp
> +(use-modules (gnu) (guix))
> +(use-service-modules avahi networking xorg)
> +
> +(define (auto-login-to-tty config tty user)
> +  (if (string=? tty (mingetty-configuration-tty config))
> +        (mingetty-configuration
> +         (inherit config)
> +         (auto-login user))
> +        config))
> +
> +(define %my-base-services
> +  (modify-services %base-services
> +    (mingetty-service-type config =>
> +                           (auto-login-to-tty
> +                            config "tty3" "alice"))))
> +
> +(operating-system
> +    (host-name "antelope")
> +    ...
> +    (services
> +     (append
> +      (list
> +       ;; additional services you might want, e.g
> +       ;; (service avahi-service-type)
> +       ;; (service gdm-service-type)
> +       (service dhcp-client-service-type))
> +      %my-base-services)))
> +@end lisp
> +
> +One could also @code{compose} (@pxref{Higher-Order Functions,,,
> guile,
> +The Guile Reference Manual}) @code{auto-login-to-tty} to login
> multiple
> +users to multiple ttys.
> +
> +Finally, here is a note of caution.  Setting up auto login to a TTY,
> +means that anyone can turn on your computer and run commands as your
> +regular user. If you have encrypted your @code{/} partition, and
> thus
> +need to enter in a passphrase at boot, then perhaps auto login to a
> TTY
> +is a secure and convenient option for you.
> +
> +
>  @node Customizing the Kernel
>  @section Customizing the Kernel
>  
> diff --git a/doc/guix.texi b/doc/guix.texi
> index 1086d3220b..0410225196 100644
> --- a/doc/guix.texi
> +++ b/doc/guix.texi
> @@ -13542,10 +13542,11 @@ Occasionally, instead of using the base
> services as is, you will want to
>  customize them.  To do this, use @code{modify-services}
> (@pxref{Service
>  Reference, @code{modify-services}}) to modify the list.
>  
> -For example, suppose you want to modify @code{guix-daemon} and
> Mingetty
> -(the console log-in) in the @code{%base-services} list (@pxref{Base
> -Services, @code{%base-services}}).  To do that, you can write the
> -following in your operating system declaration:
> +@anchor{auto-login to TTY} For example, suppose you want to modify
> +@code{guix-daemon} and Mingetty (the console log-in) in the
> +@code{%base-services} list (@pxref{Base Services,
> +@code{%base-services}}).  To do that, you can write the following in
> +your operating system declaration:
>  
>  @lisp
>  (define %my-services
> @@ -13571,7 +13572,9 @@ following in your operating system
> declaration:
>  
>  This changes the configuration---i.e., the service parameters---of
> the
>  @code{guix-service-type} instance, and that of all the
> -@code{mingetty-service-type} instances in the @code{%base-services}
> list.
> +@code{mingetty-service-type} instances in the @code{%base-services}
> list
> +(@pxref{Auto Login a User to a Specific TTY, see the cookbook for
> how to
> +auto-login one user to a specific TTY,, guix-cookbook, GNU Guix
> Cookbook})).
>  Observe how this is accomplished: first, we arrange for the original
>  configuration to be bound to the identifier @code{config} in the
>  @var{body}, and then we write the @var{body} so that it evaluates to
> the



--- End Message ---

reply via email to

[Prev in Thread] Current Thread [Next in Thread]