{{tag> cvs}} ====== 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/ 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/" 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//CVSROOT htpasswd passwd 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. ===== Links ===== * http://www.chuidiang.com/chuwiki/index.php?title=Sesi%C3%B3n_con_CVS * http://firefang.net/english/converting-cvsnt-repository-format-to-cvs-repository-format