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
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
export CVSROOT=/var/grecasadata/cvs/<nombrereposito> cvs init
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
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.
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”.
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
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 ...
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.