CVS en linux

Instalación

Lo instalamos desde los repositorios. También tendremos que instalar el demonio xinetd que no viene por defecto en Centos 5. Ya que lo utilizaremos.

  yum install cvs
  yum install xinetd

Configuración

General

Usaremos el método de acceso pserver. Que es un protocolo propio de CVS para la gestión de los repositorios.

Lo primero que tenemos que hacer es crear un usuario y un grupo para el CVS. Ya que CVS no permite que root haga modificaciones en los repositorios.

  groupadd cvs -g 500
  useradd CVSWRITER -g 500

Creamos los repositorios que vayamos a utilizar. En este caso no los creamos desde cero, si no que copiamos los que ya existían en servidor Windows.

  mkdir -p /var/grecasadata/cvs
Hay que repetir este paso tantas veces como repositorios distintos tengamos.
  export CVSROOT=/var/grecasadata/cvs/<nombrereposito>
  cvs init

Pserver

Configuramos el servicio pserver. Puede llamarse cvs o cvspserver.

  vim /etc/xinetd.d/cvs

Lo dejamos de esta forma. Hay que tener en cuenta que hay que agregar un alinea “–allow-root=/var/grecasadata/cvs/<nombre repositorio>” por cada repositorio que tengamos. Si no no podremos acceder.

# default: off
# description: The CVS service can record the history of your source \
#              files. CVS stores all the versions of a file in a single \
#              file in a clever way that only stores the differences \
#              between versions.
service cvspserver
{
        disable                 = no
        port                    = 2401
        socket_type             = stream
        protocol                = tcp
        wait                    = no
        user                    = CVSWRITER
        passenv                 = PATH
        server                  = /usr/bin/cvs
#       env                     = HOME=/var/grecasadata/cvs
        server_args             = -f --allow-root=/var/grecasadata/cvs/cvsprueba --allow-root=/var/grecasadata/cvs/cvsrepo --allow-root=/var/grecasadata/cvs/cvstemp  --allow-root=/var/grecasadata/cvs/cvsejecutivapre --allow-root=/var/grecasadata/cvs/cvsejecutivaexp --allow-root=/var/grecasadata/cvs/cvsejecutivades --allow-root=/var/grecasadata/cvs/cvsejecutiva pserver
#       bind                    = 127.0.0.1
}

Iniciamos el servicio

service xinetd restart

Acceso

Una vez tengamos los repositorios copiados dentro de “/var/grecasadata/cvs”. Tenemos que modificar los archivos passwd que esta dentro de la carpeta CVSROOT dentro de cada repositorio.

El Archivo passwd

Lo dejamos con la siguiente sintaxis: “usuario1:passCifrada:usuarioLocal”. Donde usuario1 es el nombre del usuario remoto, passCifrada la contraseña del usuario previamente cifrada y usuarioLocal es el usuario dueño de la carpeta /var/grecasadata/cvs y que pertenece al grupo cvs. En este caso es CVSWRITER.

Ejemplo:

usuario1:$1$4lZbpW/X$MIkTbTVxGUmKKOIKqN8Y1.:CVSWRITER

Si lo que deseas es añadir un usuario nuevo

cd /var/grecasadata/cvs/<nombre reposito>/CVSROOT
htpasswd passwd <nombre usuario>
vim passwd

y añadimos a la nueva linea (del archivo passwd, con el vim) el nombre del usuario local siguiendo la sintaxis “usuario1:passCifrada:usuarioLocal”.

Para poder usar htpasswd hay que tener instalado apache.

Permisos

Toda la carpeta cvs debe pertenecer a CVSWRITER y al grupo cvs. Además solo debe tener todos los permisos el usuario CVSWRITER, los demás del grupo solo lectura y ejecución. El resto ninguno. Ademas de añadir el SGID para que los directorios nuevos hereden el grupo.

chown -R CVSWRITER:cvs /var/grecasadata/cvs
chmod -R 750 /var/grecasadata/cvs
chmod +s /var/grecasadata/cvs

Tipos de usuarios

Todos los usuarios remotos por defecto usaran los permisos que tenga CVSWRITER, es decir todos los permisos. Si queremos que los usuarios remotos se diferencien entre escritores y lectores debemos crear dos archivos dentro de CVSROOT

touch readers
touch writers

y poner dentro de cada archivo el nombre del usuario que queremos que lea o lea y escriba. Uno por linea.

usuario1
usuario2
...

Migracion CVSNT a CVS

CVSNT usa “kopb” para especificar que el archivo es binario, mientras que CVS usa “expand @b@;”. Asi que si usamos un repositorio de CVSNT en un servidor CVS todos los archivos aparecerá como ASCII. Para evitar esto ejecutamos el siguiente script en la carpeta donde estén los repositorios.

find . -not -name "*,v.bak" -exec grep -q "kopt.*b" \{\} \; -not -exec grep -q "expand.*@b@;" \{\} \; -print0  | xargs -0 -i sh -c  "echo conv {};cp \"{}\" \"{}.bak\";cat \"{}.bak\" | sed 2a\"expand  @b@;\" > \"{}\""

Para cada archivo modificado creara uno con el mismo nombre mas la extensión .bak.