Bodoconsult.Core.Web.Ftp 1.0.1

dotnet add package Bodoconsult.Core.Web.Ftp --version 1.0.1                
NuGet\Install-Package Bodoconsult.Core.Web.Ftp -Version 1.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Bodoconsult.Core.Web.Ftp" Version="1.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Bodoconsult.Core.Web.Ftp --version 1.0.1                
#r "nuget: Bodoconsult.Core.Web.Ftp, 1.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Bodoconsult.Core.Web.Ftp as a Cake Addin
#addin nuget:?package=Bodoconsult.Core.Web.Ftp&version=1.0.1

// Install Bodoconsult.Core.Web.Ftp as a Cake Tool
#tool nuget:?package=Bodoconsult.Core.Web.Ftp&version=1.0.1                

What does the library

Bodoconsult.Core.Database.Postgres library simplifies the access to Postgres based databases. It handles the most common database actions like getting datatables, running SQL statement or fetch scalar values from the database.

Additionally the library contains some tools for developers making the usage of the database layers derived from Bodoconsult.Core.Database as easy as possible. See below.

How to use the library

The source code contain a NUnit test classes, the following source code is extracted from. The samples below show the most helpful use cases for the library.

Overview

The main class in the library is the class SshHandler with the following methods:

  • Connect()
  • Disconnect()
  • Put(string localPath, string remotePath)
  • RemoveFile(string remotePath)
  • Exists(string path)
  • CreateDirectory(string remotePath)
  • RemoveDirectory(string remotePath)
  • GetDirectoryItems(string remotePath)
  • GetDirectoryItemsRaw(string remotePath)
  • DownloadFile(string remotePath, string localPath)

Samples

 [TestFixture]
	public class UnitTestSshHandler
	{

		private readonly SshCredentials _credentials = TestHelper.GetCredentials();

		[Test]
		public void TestConnect()
		{

			// Arrange
			var s = new SshHandler(_credentials);
			
			// Act
			s.Connect();

			var erg = s.IsConnected;

			s.Disconnect();

			// Assert
			Assert.IsTrue(erg);
		}


		[Test]
		public void TestPutMainDirectory()
		{

			// Arrange
			var localPath = TestHelper.FtpTestFilePath;

			const string remotePath = "/"+TestHelper.FtpTestFileName;

			var s = new SshHandler(_credentials);


			// Act
			s.Connect();

			var erg1 = s.IsConnected;

			
			s.Put(localPath, remotePath);

			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
		}


		[Test]
		public void TestPutDirectory()
		{

			// Arrange
			var localPath = TestHelper.FtpTestFilePath;

			var remotePath = $"{TestHelper.FtpSubDir}/{TestHelper.FtpTestFileName}";

			var s = new SshHandler(_credentials);


			// Act
			s.Connect();

			var erg1 = s.IsConnected;


			s.Put(localPath, remotePath);

			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
		}


		[Test]
		public void TestRemoveFile()
		{

			// Arrange
			var localPath = TestHelper.FtpTestFilePath;

			var remotePath = $"{TestHelper.FtpSubDir}/{TestHelper.FtpTestFileName}";

			var s = new SshHandler(_credentials);


			// Act
			s.Connect();

			var erg1 = s.IsConnected;

			s.Put(localPath, remotePath);

			Assert.IsTrue(s.Exists(remotePath));

			// Act
			s.RemoveFile(remotePath);
			var erg2 = s.Exists(remotePath);
			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsFalse(erg2);
		}


		[Test]
		public void TestRemoveFileFileNotExisting()
		{

			// Arrange
			var localPath = TestHelper.FtpTestFilePath;

			var remotePath = $"{TestHelper.FtpSubDir}/AAA{TestHelper.FtpTestFileName}";

			var s = new SshHandler(_credentials);

			s.Connect();

			var erg1 = s.IsConnected;

			s.Put(localPath, remotePath);

			// Act
			s.RemoveFile(remotePath);
			var erg2 = s.Exists(remotePath);
			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsFalse(erg2);
		}


		[Test]
		public void TestCreateDirectory()
		{

			// Arrange
			var remotePath = TestHelper.FtpSubDirCreate;

			var s = new SshHandler(_credentials);


			// Act
			s.Connect();

			var erg1 = s.IsConnected;

			s.RemoveDirectory(remotePath);
			Assert.IsFalse(s.Exists(remotePath));

			// Act
			s.CreateDirectory(remotePath);
			var erg2 = s.Exists(remotePath);
			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsTrue(erg2);
		}


		[Test]
		public void TestListDirectory()
		{

			// Arrange
			const string remotePath = TestHelper.FtpSubDir;

			var remotePath1 = TestHelper.FtpSubDirCreate;

			var s = new SshHandler(_credentials);

			s.Connect();

			if (!s.Exists(remotePath1)) s.CreateDirectory(remotePath1);

			var erg1 = s.IsConnected;

			var localPath = TestHelper.FtpTestFilePath;

			var remotePathFile = $"{TestHelper.FtpSubDir}/{TestHelper.FtpTestFileName}";

			if (!s.Exists(remotePathFile)) s.Put(localPath, remotePathFile);

			// Act
			var erg2 = s.GetDirectoryItems(remotePath).ToList();

			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsTrue(erg2.Any());
			Assert.IsTrue(erg2.Any(x => x.IsDirectory));
			Assert.IsTrue(erg2.Any(x => !x.IsDirectory));
		}



		[Test]
		public void TestListDirectoryRaw()
		{

			// Arrange
			const string remotePath = TestHelper.FtpSubDir;

			var remotePath1 = TestHelper.FtpSubDirCreate;

			var s = new SshHandler(_credentials);

			s.Connect();

			if (!s.Exists(remotePath1)) s.CreateDirectory(remotePath1);

			var erg1 = s.IsConnected;

			var localPath = TestHelper.FtpTestFilePath;

			var remotePathFile = $"{TestHelper.FtpSubDir}/{TestHelper.FtpTestFileName}";

			if (!s.Exists(remotePathFile)) s.Put(localPath, remotePathFile);

			// Act
			var erg2 = s.GetDirectoryItems(remotePath).ToList();

			s.Disconnect();

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsTrue(erg2.Any());
			Assert.IsTrue(erg2.Any(x => x.IsDirectory));
			Assert.IsTrue(erg2.Any(x => !x.IsDirectory));
		}

		[Test]
		public void TestDownloadFile()
		{

			// Arrange
			var remotePath = "/"+ TestHelper.FtpTestFileName;
			var localPath = Path.Combine(TestHelper.LocalTargetPath,"AAA.txt");

			var s = new SshHandler(_credentials);


			if (File.Exists(localPath))
			{
				File.Delete(localPath);
			}


			// Act
			s.Connect();

			var erg1 = s.IsConnected;

			// Act
			s.DownloadFile(remotePath, localPath);
			s.Disconnect();

			var erg2 = File.Exists(localPath);

			// Assert
			Assert.IsTrue(erg1);
			Assert.IsTrue(erg2);
		}


		[Test]
		public void TestRemoveDirectory()
		{

			// Arrange
			var remotePath1 = TestHelper.FtpSubDirCreate;

			var s = new SshHandler(_credentials);

			s.Connect();

			if (!s.Exists(remotePath1)) s.CreateDirectory(remotePath1);

			var erg1 = s.IsConnected;

			// Act
			s.RemoveDirectory(remotePath1);

			// Assert
			var erg2 = s.Exists(remotePath1);

			s.Disconnect();

			
			Assert.IsTrue(erg1);
			Assert.IsFalse(erg2);
		}

	}

About us

Bodoconsult (http://www.bodoconsult.de) is a Munich based software development company from Germany.

Robert Leisner is senior software developer at Bodoconsult. See his profile on http://www.bodoconsult.de/Curriculum_vitae_Robert_Leisner.pdf.

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.1 327 12/22/2022
1.0.0 546 11/26/2020

Migration to .NET 6, updated dependencies and add README.md