To install SVN server, run this command at the command prompt:
sudo apt-get install subversion apache2 libapache2-svn
data:image/s3,"s3://crabby-images/c2c0b/c2c0bcfb6fdc91a51e386a7d28f19ace1960bec7" alt="1"
Verify the installed version of Subversion software:
svn --version
data:image/s3,"s3://crabby-images/4fc59/4fc596538cb2e20be66eeade55a155bd55d7077b" alt="2"
We want to configure the apache in such a way that it’ll run on HTTPs and for this we need to enable ssl Apache2 module with a2enmod:
sudo a2enmod ssl
data:image/s3,"s3://crabby-images/40993/409937c9ff7d6c292bd0bce039bad732ceb95fac" alt="3"
It will suggest you to restart apache;ignore that message for now.
Create a directory inside the /etc/apache2/ directory,where we’ll save the server key and certificate:
sudo mkdir /etc/apache2/ssl
data:image/s3,"s3://crabby-images/4b2f3/4b2f3eb4b1c30512bb023f7c832d10b032a2e332" alt="4"
Use this command for creating the self-signed SSL certificate and the server key that protects it, and save them into the new directory (/etc/apache2/ssl/):
sudo openssl req -new -x509 -days 365 -nodes -out /etc/apache2/ssl/apache.pem -keyout /etc/apache2/ssl/apache.key
data:image/s3,"s3://crabby-images/9f430/9f43094455ac1512e3a65446ee86e18cc1a0b457" alt="5"
Note: Fill the information accordingly!
Edit the ports.conf file:
sudo nano /etc/apache2/ports.conf
data:image/s3,"s3://crabby-images/8e2f5/8e2f57bd68dd855e2b626c831d95bab309bc1145" alt="6"
Ensure that port 443 is defined as follows and add the NameVirtualHost for port 443:
NameVirtualHost *:443 Listen 443
data:image/s3,"s3://crabby-images/23022/23022560ea1db0546ffce52837bf308c88c1fd42" alt="7"
Open up the SSL config file:
sudo nano /etc/apache2/sites-available/default-ssl
data:image/s3,"s3://crabby-images/bec01/bec011289241d573b62b7ebe432974b509cc442f" alt="8"
Comment out the default certificate and key:
#SSLCertificateFile /etc/ssl/certs/ssl-cert-snakeoil.pem #SSLCertificateKeyFile /etc/ssl/private/ssl-cert-snakeoil.key
data:image/s3,"s3://crabby-images/463d5/463d5ab40a0036a7cab42fb38580881999533aeb" alt="9"
And add the newly created certificate and key:
SSLCertificateFile /etc/apache2/ssl/apache.pem SSLCertificateKeyFile /etc/apache2/ssl/apache.key
data:image/s3,"s3://crabby-images/d7e2b/d7e2b624beda3f709971e021785718b46eb92601" alt="10"
Now we need to configure the SSL site:
sudo a2ensite default-ssl
data:image/s3,"s3://crabby-images/d7752/d775279a43eb6010458e5f7f38ff0cea34073ea6" alt="11"
Restart the Apache service:
sudo /etc/init.d/apache2 restart
data:image/s3,"s3://crabby-images/fae24/fae24b184fb98212824e327cf95cd5641b060239" alt="12"
Now we should be able to connect to the server through SSL using Chrome or any other browser:
data:image/s3,"s3://crabby-images/699c7/699c78fd43b339b54b99a20981106b53320c0116" alt="13"
Verify the Certificate, that it’s the same that we created and configured:
data:image/s3,"s3://crabby-images/a72ab/a72ab9f2811ba136d9ecb6efae1df5033313f32b" alt="14"
Next, we need to configure the SVN Server for this, make a directory where you want to keep the svn repositories and edit the dav_svn.conf file:
sudo mkdir /svn sudo nano /etc/apache2/mods-enabled/dav_svn.conf
data:image/s3,"s3://crabby-images/8a9e0/8a9e08111b134c2098de459548af60c70b35c340" alt="15"
Delete all the data and make it simple like this:
<Location /svn> DAV svn SVNParentPath /svn AuthType Basic AuthName "Subversion Repository" AuthUserFile /etc/apache2/dav_svn.passwd Require valid-user SSLRequireSSL </Location>
data:image/s3,"s3://crabby-images/0a9c0/0a9c099019744ceb2487e48683ebc35befa8362c" alt="16"
To create a svn user , use the following command:
sudo htpasswd -cm /etc/apache2/dav_svn.passwd arbab
data:image/s3,"s3://crabby-images/9a85b/9a85b8575f64d9d7789240187355de7f22ed4314" alt="17"
We only need to use the -c option for the FIRST TIME, when you create a user, after that you will only use the -m option.
Move to the folder, where you want to keep your repositories and create your first repository:
cd /svn sudo svnadmin create myrepo
data:image/s3,"s3://crabby-images/57e36/57e361e7a0d3c961266d1069bdacff406f48322d" alt="18"
Make sure you set the permissions of the /svn directory to apache with the following command:
sudo chown -R www-data:www-data /svn
data:image/s3,"s3://crabby-images/bab7a/bab7aa6b0b8b8fa6a08c3024f59f4d570cd80f7b" alt="19"
Restart the apache2 service:
sudo /etc/init.d/apache2 restart
data:image/s3,"s3://crabby-images/83381/833817234596db39d1cee4996492c25e5a979457" alt="20"
Let’s test with the browser that our svn repository is accessible now through HTTPs at following url:
https://tendo.local/svn/myrepo
data:image/s3,"s3://crabby-images/d67cc/d67cc2dd681208a67dcf5a227b64eb0d5083345b" alt="21"
Click “Proceed anyway“, enter the username and password:
data:image/s3,"s3://crabby-images/f96f8/f96f887a47d45de251d971174c8761b7c9e0387d" alt="22"
Yes, It is working
data:image/s3,"s3://crabby-images/ea5aa/ea5aae57295519fb61febebb4e2e5e463041ea4d" alt=":-)"
data:image/s3,"s3://crabby-images/685a2/685a24a4db5d8ddc9cab9e45a4f002d6087b6460" alt="23"
Note: Our SVN Server is also working with http:
data:image/s3,"s3://crabby-images/c6501/c6501e834fba26084fcdf8d35d49c217ed64f96e" alt="http1"
data:image/s3,"s3://crabby-images/3e92d/3e92d43fc73ac3267ee5232b1e991d8887a8d60e" alt="http2"
But, we don’t want that users access it through http, we only want to access it through https. To fix this, we need to edit the ports.conf file:
sudo nano /etc/apache2/ports.conf
data:image/s3,"s3://crabby-images/c2082/c2082236ff0e88966adba16652c34901ba636d5d" alt="http3"
Comment these two lines:
#NameVirtualHost *:80 #Listen 80
data:image/s3,"s3://crabby-images/e71d2/e71d20bdedb33b5c95cf8dd9c9e79505eecb2335" alt="http4"
Restart the apache2 service:
sudo /etc/init.d/apache2 restart
data:image/s3,"s3://crabby-images/1ceab/1ceab50f0a97cb9cef50f5e6c30f4d1cebafd6fc" alt="http5"
Now, try to access it through http, it’ll give us the rejection error:
data:image/s3,"s3://crabby-images/69824/69824e3e39c41ee18d89a1dc13da841cf8a7796e" alt="http6"
But with https, we can still access the svn repositories:
data:image/s3,"s3://crabby-images/8d55d/8d55d069efce69d2bbb87657ae2e50a7365f2d9c" alt="https1"
More Details Click Here
Author by:-rbgeek.wordpress