Skip to content

apache subversion windows builds with httpd modules and java hl

Notifications You must be signed in to change notification settings

nono303/win-svn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 

Repository files navigation

Apache Subversion - Windows MSVC binaries

Including Apache httpd mod_X_svn and JavaHL Native Library Adapter


Version 1.14.5

2024-12-09 - commit

2024-12-10 - build

AVX, AVX2 or not (SSE2):

  • Check your cpu supported instructions with CPU-Z

⚠️ VC15 & x86 are now discontinued. Latest release for theses build is 1.14.3

Build & Runtime Dependencies

  • All dependencies are built from sources in the same context

Runtime Dependencies

Provided dll dependencies in /deps allow you to run subversion autonomously but depending to your runtime environment, all of them might NOT be used to run subversion - It can cause conflicts! ex. in case of an httpd module usage, most of them might already be present in the /httpd/bin folder.

Depending on your httpd distribution & version and how you manage your PATH environment (with or without /httpd/bin in) you might test - in case of trouble with a Dependency Walker or dumpbin /DEPENDENTS - which provided dll dependencies are required in your particular context.

Note that /httpd/bin dll dependencies are not built in the same way between standard distributions (Apache Lounge, Apache Haus, WampServer, XAMPP) and mine (configure & compile options, flags, etc.) and moreover, they may not be in the same version!

So... I don't have a good and unique answer on how manage this but in case of conflict, my advice would be:

  • hardlink needed provided dll dependencies in /deps to your subversion root folder
  • ⚠️ NOT changing PATH environment
  • 🚫 DO NOT RENAME FILES In any case

Note that libhttpd.dll - only required by the 3 mod_xxx.so - is not provided as httpd modules will be launch in **your httpd runtime context containing your own libhttpd.dll **

  • openssl - libcrypto-3-x64.dll libssl-3-x64.dll
  • apr - libapr-1.dll libaprutil-1.dll libapriconv-1.dll
  • expat - libexpat.dll
    • ⚠️ see this topic concerning naming
    • mandatory for svn as module in httpd standard distributions, see #6
  • serf - libserf-2.dll
  • sqlite3 - libsqlite3.dll
    • ⚠️ see this topic concerning naming
      • avoid conflict with sqlite3 shell with shared sqlite3.dll as it require a specific compilation flag for subversion and no dependency to ICU
  • zlib - zlib.dll

Install on Apache httpd

@nono303 method

easier to upgrade & httpd independent

- Add your  `/deps` directory name to Windows *PATH* environment variable, after your `/httpd/bin` entry, if setted 

    **OR** 

- just hardlink from`/deps` to `/` dll that are NOT present in your `/httpd/bin` folder (to avoid duplicate and/or version conflicts) 

    - ex. `mklink /h C:\XXX\win-svn\vs16\x64-avx\libexpat.dll C:\XXX\win-svn\vs16\x64-avx\deps\libexpat.dll`
  1. Load the modules needed by adding following lines, in httpd config, with absolute path:

    LoadModule dav_module modules/mod_dav.so # included in httpd distribution
    ...
    LoadModule dav_svn_module "C:/.../win-svn/vc15/(x64|x86)/mod_dav_svn.so"
    LoadModule authz_svn_module "C:/.../win-svn/vc15/(x64|x86)/mod_authz_svn.so"
    

@f-w method

need copy for upgrade, httpd integrated

  1. Add win-svn/vc15/(x64|x86) to PATH environment variable.

  2. Copy .so and all .dll files under win-svn/vc15/(x64|x86)/deps to /httpd/modules folder

  3. Load the modules needed by adding following lines, in httpd config:

    LoadModule dav_module modules/mod_dav.so # included in httpd distribution
    ...
    LoadModule dav_svn_module modules/mod_dav_svn.so
    LoadModule authz_svn_module modules/mod_authz_svn.so
    

Finally

Add svn directives to httpd config. If using mod_authn_ntlm for authentication, the directives will look like:

```
<Location /svn>
    NTLMAuth on
    NTLMUsernameCase  lower
    NTLMOfferBasic On
    DAV svn
    SVNPath "c:\svn_repo"
    SVNReposName "My Subversion Repository"
    AuthzSVNAccessFile "c:\svn_repo\conf\authz"
    Require valid-user
</Location>
```

mod_dotndothat config

mod_dontdothat is an Apache module that allows you to block specific types
of Subversion requests.  Specifically, it's designed to keep users from doing
things that are particularly hard on the server, like checking out the root
of the tree, or the tags or branches directories.  It works by sticking an
input filter in front of all REPORT requests and looking for dangerous types
of requests.  If it finds any, it returns a 403 Forbidden error.

It is enabled via single httpd.conf directive, DontDoThatConfigFile:
<Location /svn>
	DAV svn
	SVNParentPath /path/to/repositories
	DontDoThatConfigFile /path/to/config.file
	DontDoThatDisallowReplay off
</Location>
The file you give to DontDoThatConfigFile is a Subversion configuration file
that contains the following sections.
[recursive-actions]
/*/trunk = allow
/ = deny
/* = deny
/*/tags = deny
/*/branches = deny
/*/* = deny
/*/*/tags = deny
/*/*/branches = deny
As you might guess, this defines a set of patterns that control what the
user is not allowed to do.  Anything with a 'deny' after it is denied, and
as a fallback mechanism anything with an 'allow' after it is special cased
to be allowed, even if it matches something that is denied.

Note that the wildcard portions of a rule only swallow a single directory,
so /* will match /foo, but not /foo/bar.  They also must be at the end of
a directory segment, so /foo* or /* are valid, but /*foo is not.

These rules are applied to any recursive action, which basically means any
Subversion command that goes through the update-report, like update, diff,
checkout, merge, etc.

The DontDoThatDisallowReplay option makes mod_dontdothat disallow
replay requests, which is on by default.