2. execute "cvs -d ~/cvsRepo init" to build a new cvs repository at ~/cvsRepo. This will build a CVSROOT structure inside it.
3. create a new group in your OS. Call it as "cvs". Add your user to this group.
4. reboot the machine so that group changes can take effect.
5. change group owner for ~/cvsRepo by using: chgrp -R cvs ~/cvsRepo/
6. chmod ug+rwx . CVSROOT
You may have noticed that the chgrp and chmod commands in that example gave write access to a user named anonymous, which is not what one would expect. The reason is that even anonymous, read-only repository users need system-level write access, so that their CVS processes can create temporary lockfiles inside the repository.
Before running through the steps needed to set up the password server, let's examine how such connections work in the abstract. When a remote CVS client uses the :pserver: method to connect to a repository, the client is actually contacting a specific port number on the server machine - specifically, port number 2401 (which is 49 squared, if you like that sort of thing). Port 2401 is the designated default port for the CVS pserver, although one could arrange for a different port to be used as long as both client and server agree on it.
The CVS server is not actually waiting for connections at that port - the server won't get started up until a connection actually arrives. Instead, the Unix inetd (InterNET Daemon) program is listening on that port, and needs to know that when it receives a connection request there, it should start up the CVS server and connect it to the incoming client.
This is accomplished by modifying inetd's configuration files: /etc/services and /etc/inetd.conf. The services file maps raw port numbers to service names and then inetd.conf tells inetd what to do for a given service name.
7. First, put a line like this into /etc/services (after checking to make sure it isn't already there):
cvspserver 2401/tcp
8. Then in /etc/inetd.conf, put this:
cvspserver stream tcp nowait root /usr/local/bin/cvs cvs \
--allow-root=/usr/local/newrepos pserver
9. reboot the machine
10. That's enough to permit connections, but you'll also want to set up special CVS passwords - separate from the users' regular login passwords - so people can access the repository without compromising overall system security. The CVS password file is CVSROOT/passwd in the repository. The format is as simple as it looks. Each line is:
11. create a new pearl file with .pl extension (e.g. genEncPass.pl) and paste the following in it:
#!/usr/bin/perl
srand (time());
my $randletter = "(int (rand (26)) + (int (rand (1) + .5) % 2 ? 65 : 97))";
my $salt = sprintf ("%c%c", eval $randletter, eval $randletter);
my $plaintext = shift;
my $crypttext = crypt ($plaintext, $salt);
print "${crypttext}\n";
12. chmod +x genEncPass.pl
./genEncPass.pl 1234
lsL5OOjG22QRk
13. create the following entry in CVSROOT/passwd
swapnil:lsL5OOjG22QRk
14. defining $CVSROOT varaible.
export CVSROOT=~/cvsRepo/
15. Import existing project Temp in repository
cvs import -m "initial import into CVS" Temp swapnil start
:pserver:jrandom@floss.red-bean.com:/usr/local/newrepos