mirror of
				https://github.com/libssh2/libssh2.git
				synced 2025-11-03 22:13:11 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			320 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			320 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
*These are the porting notes to OpenVMS, as of 7 April 2010
 | 
						|
by Jose Baars. This file will be installed as 
 | 
						|
libssh2*.release_notes by the product install kit.
 | 
						|
 | 
						|
 | 
						|
LIBSSH2 
 | 
						|
-------
 | 
						|
 | 
						|
LIBSSH2 is a client-side library written in C that aims to 
 | 
						|
implement the SSH2 protocol. It is an open source project, 
 | 
						|
to be found at http://libssh2.org. 
 | 
						|
 | 
						|
GNV
 | 
						|
---
 | 
						|
 | 
						|
The library uses the GNV prefix, on advise of the kind supporter
 | 
						|
of the GNV project, John Malmberg.
 | 
						|
 | 
						|
Installing the PCSI kit
 | 
						|
=======================
 | 
						|
 | 
						|
Prerequisites 
 | 
						|
-------------
 | 
						|
- VMS version 8.3 minimal. 
 | 
						|
  See the remarks at prerequisites for building the kit
 | 
						|
- TCP/IP stack, both TCP/IP services and Multinet should work. 
 | 
						|
  See the remarks at prerequisites for building the kit
 | 
						|
- HP OPENSSL V1.3 minimal. 
 | 
						|
  See the remarks at prerequisites for building the kit
 | 
						|
- JEM  ZLIB V1.2-3E1 minimal. 
 | 
						|
  See the remarks at prerequisites for building the kit
 | 
						|
  
 | 
						|
The first three dependencies are tested at installation time, and 
 | 
						|
installation will fail if any these products are not installed.
 | 
						|
The ZLIB dependency is not tested by the product installation
 | 
						|
procedure, as libssh2 will probably be installed as part of 
 | 
						|
multiple libraries including zlib.
 | 
						|
 | 
						|
Install
 | 
						|
-------
 | 
						|
 | 
						|
 | 
						|
The kit will install gnv$libssh2.exe in a directory tree that might 
 | 
						|
already be available on your system if you have installed other gnv* 
 | 
						|
libraries or utilities. 
 | 
						|
 | 
						|
The directory tree for gnv$libssh2.exe will be like this:
 | 
						|
 | 
						|
[gnv] -- [usr] -- [include] -- [libssh2] include files for libssh2
 | 
						|
                  [lib] gnv$libssh2_x_y_z.exe
 | 
						|
                  [share]   -- [doc] -- [libssh2] libssh2.hlb, 
 | 
						|
                                        release notes (this file), 
 | 
						|
                                        libssh2 release notes   
 | 
						|
 | 
						|
optional:
 | 
						|
                                        [example] libssh2_examples-x_y_z.bck 
 | 
						|
                  [common_src] libssh2-x_y_z_src.bck
 | 
						|
 | 
						|
By default, it will install the shared image and include files to 
 | 
						|
SYS$COMMON:[GNV...].
 | 
						|
 | 
						|
You can override this destination by specifying the destination
 | 
						|
directory after /DESTINATION= on the product install command line.
 | 
						|
This is particularly of use when installing the library on a cluster
 | 
						|
without a common system disk.
 | 
						|
 | 
						|
Please ignore the following warnings, as the kit is not signed :
 | 
						|
 | 
						|
%PCSI-I-CANNOTVAL, cannot validate dev:[dir]JCB-AXPVMS-LIBSSH2-V0102-05D20100402-1.PCSI
 | 
						|
-PCSI-I-NOTSIGNED, product kit is not signed and therefore has no manifest file
 | 
						|
 | 
						|
Optionally, you can install a backup saveset with some programming examples,
 | 
						|
or a backupo saveset with the complete libssh2 source tree.
 | 
						|
 
 | 
						|
you will need to answer 'NO' to the question 
 | 
						|
'Do you want the default for all options'. 
 | 
						|
 | 
						|
and 'YES' to either or both the following questions:
 | 
						|
 | 
						|
    Do you want the libssh2 C programming examples ?  [NO]
 | 
						|
 | 
						|
    Do you want the complete libssh2 source tree ?  [NO]
 | 
						|
 | 
						|
 | 
						|
Post installation tasks
 | 
						|
-----------------------
 | 
						|
 | 
						|
Although we will try to maintain upward compatibility of libssh2,
 | 
						|
this can not be guaranteed by the libssh2 project itself for OpenVMS,
 | 
						|
nor eternally by us.
 | 
						|
 | 
						|
To use libssh2 effectively, you will have to define a system logical
 | 
						|
to point to the shared image. If you are willing to take the gamble,
 | 
						|
define this logical in your systartup like so:
 | 
						|
 | 
						|
$ define/system/executive gnv$libssh2 dev:[dir..]gnv$libssh2_x_y_z.exe
 | 
						|
 | 
						|
Optionally, you can install the executbale like so:
 | 
						|
 | 
						|
$ mc sysgen install dev:[dir..]gnv$libssh2_x_y_z.exe/open/share/header
 | 
						|
 | 
						|
Link your programs against gnv$libssh2, and when upgrading libssh2 
 | 
						|
test thoroughly.
 | 
						|
 | 
						|
If you want to be extra cautious define a system logical like this:
 | 
						|
 | 
						|
$ define/system/executive gnv$libssh2_x_y_z dev:[dir..]gnv$libssh2_x_y_z.exe
 | 
						|
 | 
						|
Link  programs against gnv$libssh2_x_y_z, and when upgrading libssh2 
 | 
						|
link against new versions. 
 | 
						|
 | 
						|
It is probably more convenient in the last case to link against the object 
 | 
						|
library provided in the source backup saveset. Both an uppercase and a
 | 
						|
mixed case object library, called libssh2.olb and libssh2_asis.olb 
 | 
						|
are provided.
 | 
						|
 | 
						|
 | 
						|
Compiling and linking against libssh2
 | 
						|
-------------------------------------
 | 
						|
 | 
						|
The  shared image library has a vector table with both uppercase and 
 | 
						|
mixed case entry points, allowing to link directly against the shared 
 | 
						|
image wether you need the /NAMES=AS_IS or not.
 | 
						|
 | 
						|
To link successfully, you MUST use /NAMES=shortened, as some function
 | 
						|
names in libssh2 are longer than the VMS maximum of 32 characters.
 | 
						|
 | 
						|
If you chose to install the examples, you can unpack the backup
 | 
						|
saveset by 
 | 
						|
 | 
						|
backup/sel=*.c device:[gnv.usr.share.doc.libssh2.examples]libssh2_examples-x_y_z.bck -
 | 
						|
 []
 | 
						|
 | 
						|
They can by compiled and linked by these commands ( provided you have defined
 | 
						|
the gnv$libssh2 logical) :
 | 
						|
 | 
						|
$ cc/include=dev:[gnv.usr.include.libssh2] xxx.c/names=shortened
 | 
						|
$ link/opt=sys$input: xxx.obj
 | 
						|
gnv$libssh2/share
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
Building gnv$libssh2
 | 
						|
====================
 | 
						|
 | 
						|
You can build gnv$libssh2 yourself, which may have advantages, as the library is
 | 
						|
in full development, very regularly new features are added.
 | 
						|
 | 
						|
For production use, it is probably advisable to use a stable version, and 
 | 
						|
link against that. To check out new features, statically linking against
 | 
						|
the object library is probably more practical, to avoid compatibility
 | 
						|
issues.
 | 
						|
 | 
						|
 | 
						|
Prerequisites
 | 
						|
-------------
 | 
						|
 | 
						|
You will need to have the following available:
 | 
						|
 | 
						|
- An Alpha or Itanium VMS system. Due to dependencies on zlib, ssl and ODS-5,
 | 
						|
  support on VAXen would be cumbersome at least.
 | 
						|
 | 
						|
- VMS version 8.3 minimal. This is a requirement of gnv$zlibshr.exe against 
 | 
						|
  which shared image library libssh2 is linked. If you use another zlib
 | 
						|
  to link against, you can make it work under lower versions of VMS.
 | 
						|
  I have made it work on VMS 7.3-2 with not a lot of difficulty.
 | 
						|
  Also, if you are not interested in compression, you can choose not
 | 
						|
  to link against zlib at all; in that case comment out the 
 | 
						|
  #define  LIBSSH2_HAVE_ZLIB in libssh2_config.h.
 | 
						|
 | 
						|
- TCP/IP services or Multinet for OpenVMS.
 | 
						|
  TCPWare has not been tested.
 | 
						|
 | 
						|
- The HP OpenSSL product. Of course, with tweaking, you can probably link 
 | 
						|
  it against the OpenSSL library, but that is not what I have used.
 | 
						|
 
 | 
						|
- A C compiler. I don't know any other working C compilers than 
 | 
						|
  the DEC/Compac/HP-C compiler on VMS.
 | 
						|
 | 
						|
- An ODS-5 disk. With tweaking you'll get it to work on an ODS-2
 | 
						|
  disk, but it is unpractical to do so.
 | 
						|
 | 
						|
- A version of VMSTAR that understands ODS-5 disks and extended
 | 
						|
  filenames. Look here:
 | 
						|
  http://ftp.process.com/ftp/vms-freeware/fileserv/vmstar.zip
 | 
						|
 | 
						|
- gunzip, available for instance at Steven M Schweda's website:
 | 
						|
  http://antinode.info/ftp/gzip/gzip-1_3_12b_vms/gzip-1_3_12b_vms.zip
 | 
						|
 | 
						|
Optional:
 | 
						|
 | 
						|
- curl, to be found at  http://curl.haxx.se
 | 
						|
  You might want to use curl to download the libssh2 kit directly
 | 
						|
  to you VMS machine. Interestingly, sftp in curl is implemented using
 | 
						|
  libssh2, soon to be expected on VMS as well, hopefully.
 | 
						|
 | 
						|
Downloading libssh2
 | 
						|
-------------------
 | 
						|
 | 
						|
At the website of libssh2, you can find stable and daily gzipped
 | 
						|
tarballs. if you have a computer connected to internet you can 
 | 
						|
download a daily build yourself by a procedure that looks a lot like
 | 
						|
this ( fill out your own proxy user/password, set up right symbols to
 | 
						|
gunzip, vmstar and curl and set up the libssh2 build version):
 | 
						|
 | 
						|
$ libssh2_version = "1.2.6"
 | 
						|
$!
 | 
						|
$ proxy_line = " ""-U"" ""''proxy_userpass'""  ""-x"" ""''proxy_hostport'"" "
 | 
						|
$!
 | 
						|
$ currentday = f$cvtime(,,"date") - "-" - "-"
 | 
						|
$!
 | 
						|
$ set def mydev:[mydir.libssh2]
 | 
						|
$!
 | 
						|
$ if f$search("libssh2-''libssh2_version'-''currentday'.tar.gz") .nes. "" 
 | 
						|
$ then 
 | 
						|
$   delete libssh2-'libssh2_version'-'currentday'.tar.gz;*
 | 
						|
$ endif
 | 
						|
$!
 | 
						|
$ curl 'proxy_line' "http://libssh2.org/snapshots/libssh2-''libssh2_version'-''currentday'.tar.gz" -
 | 
						|
                    -o libssh2-'libssh2_version'-'currentday'.tar.gz
 | 
						|
$!
 | 
						|
$!
 | 
						|
$ if f$search("libssh2-''libssh2_version'-''currentday'.tar.;") .nes. "" 
 | 
						|
$ then 
 | 
						|
$   delete libssh2-'libssh2_version'-'currentday'.tar.;*
 | 
						|
$ endif
 | 
						|
$!
 | 
						|
$ gunzip libssh2-'libssh2_version'-'currentday'.tar.gz
 | 
						|
$!
 | 
						|
$ tarfile = f$search("libssh2-''libssh2_version'-''currentday'.tar.;")
 | 
						|
$ vmstar xf 'tarfile' 
 | 
						|
 | 
						|
Downloading a stable build will need you to get rid of the currentday.
 | 
						|
 | 
						|
After the download, you should have a directory tree with a toplevel
 | 
						|
directory called [libssh2-x.y.z-yyyymmdd].
 | 
						|
One of the subdirectories is called vms.
 | 
						|
 | 
						|
Getting the libssh2 sources from the source backup in the binary kit
 | 
						|
--------------------------------------------------------------------
 | 
						|
 | 
						|
During installation of the binary kit, you are given the option
 | 
						|
of installing the sources. If chosen, a backup saveset with 
 | 
						|
the complete libssh2 directory is made available in 
 | 
						|
[gnv.common_src].
 | 
						|
 | 
						|
By restoring this backup saveset, you end up with the same
 | 
						|
set of files as by the direct download from libssh2.org.
 | 
						|
 | 
						|
 | 
						|
Building the library
 | 
						|
--------------------
 | 
						|
 | 
						|
To avoid all kinds of misunderstandings caused by firewalls thinking that
 | 
						|
a .com file must be an MS-DOS executable, all command procedures are called
 | 
						|
.dcl.
 | 
						|
 | 
						|
Go to the vms subdirectory in the download tree, and issue the following
 | 
						|
command:
 | 
						|
 | 
						|
@libssh2_make_lib.dcl
 | 
						|
 | 
						|
This should produce libssh2_x_y_z.exe in this same vms directory.
 | 
						|
 
 | 
						|
 | 
						|
 | 
						|
Building the examples
 | 
						|
---------------------
 | 
						|
 | 
						|
A number of examples are also part of the full libssh2 delivery.
 | 
						|
You can compile and link them either against the object library
 | 
						|
produced when building the shared image, or against the shared image
 | 
						|
produced in the step before.
 | 
						|
 | 
						|
You can compile only one of the examples by giving only the
 | 
						|
name part of the filename of the example as p1 to the 
 | 
						|
build procedure:
 | 
						|
 | 
						|
@libssh2_make_example.dcl 
 | 
						|
 | 
						|
or for instance
 | 
						|
 | 
						|
@libssh2_make_example.dcl sftp 
 | 
						|
 | 
						|
By default, libssh2_make_example.dcl links to the object libraries 
 | 
						|
produced by the libssh2_make_lib.dcl procedure. If you want to link
 | 
						|
against the shared image library made in the same procedure, invoke
 | 
						|
the procedure like so:
 | 
						|
 | 
						|
@libssh2_make_example.dcl sftp "SHARED"
 | 
						|
 | 
						|
The procdure defines a process logical gnv$libssh2 pointing to the shared
 | 
						|
image library in the directory, which obviously will not survive a logout. 
 | 
						|
 | 
						|
 | 
						|
Building the help library
 | 
						|
-------------------------
 | 
						|
 | 
						|
The man pages can be converted to a VMS help library by issuing
 | 
						|
this command :
 | 
						|
 | 
						|
@libssh2_make_help.dcl
 | 
						|
 | 
						|
It uses a simple but fairly effective c program man2help.c
 | 
						|
to achieve this.
 | 
						|
 | 
						|
Building a PCSI kit
 | 
						|
-------------------
 | 
						|
 | 
						|
When you have built the shared library and the help library,
 | 
						|
you can build a PCSI kit by issueing this command:
 | 
						|
 | 
						|
@libssh2_make_kit.dcl
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 |