diff --git a/ballerina/Package.md b/ballerina/Package.md deleted file mode 100644 index 3d7dc3f9..00000000 --- a/ballerina/Package.md +++ /dev/null @@ -1,221 +0,0 @@ -## Package overview - -This package provides an FTP/SFTP client, and an FTP/SFTP server listener implementation to facilitate an FTP/SFTP connection connected to a remote location. - -### FTP client - -The `ftp:Client` connects to an FTP server and performs various operations on the files. Currently, it supports the -generic FTP operations; `get`, `delete`, `put`, `append`, `mkdir`, `rmdir`, `isDirectory`, `rename`, `size`, and -`list`. - -An FTP client is defined using the `protocol` and `host` parameters and optionally, the `port` and -`auth`. Authentication configuration can be configured using the `auth` parameter for Basic Auth and -private key. - -An authentication-related configuration can be given to the FTP client with the `auth` configuration. - -##### Create a client - -The following code creates an FTP client and performs the I/O operations, which connect to the FTP server with Basic Auth. -```ballerina -// Define the FTP client configuration. -ftp:ClientConfiguration ftpConfig = { - protocol: ftp:FTP, - host: "", - port: , - auth: { - credentials: { - username: "", - password: "" - } - } -}; - -// Create the FTP client. -ftp:Client|ftp:Error ftpClient = new(ftpConfig); -``` - -##### Create a directory - -The following code creates a directory in the remote FTP server. - -```ballerina -ftp:Error? mkdirResponse = ftpClient->mkdir(""); -``` - -##### Upload a file to a remote server - -The following code uploads a file to a remote FTP server. - -```ballerina -stream fileByteStream - = check io:fileReadBlocksAsStream(putFilePath, ); -ftp:Error? putResponse = ftpClient->put("", fileByteStream); -``` - -##### Compress and upload a file to a remote server - -The following code compresses and uploads a file to a remote FTP server. - -```ballerina -// Set the optional boolean flag as 'true' to compress before uploading -stream fileByteStream - = check io:fileReadBlocksAsStream(putFilePath, ); -ftp:Error? compressedPutResponse = ftpClient->put("", - fileByteStream, compressionType=ZIP); -``` - -##### Get the size of a remote file - -The following code gets the size of a file in a remote FTP server. - -```ballerina -int|ftp:Error sizeResponse = ftpClient->size(""); -``` - -##### Read the content of a remote file - -The following code reads the content of a file in a remote FTP server. - -```ballerina -stream|Error str = clientEP -> get(""); -if (str is stream) { - record {|byte[] value;|}|io:Error? arr1 = str.next(); - if (arr1 is record {|byte[] value;|}) { - string fileContent = check strings:fromBytes(arr1.value); - // `fileContent` is the `string` value of first byte array - record {|byte[] value;|}|io:Error? arr2 = str.next(); - // Similarly following content chunks can be iteratively read with `next` method. - // Final chunk will contain the terminal value which is `()`. - } - io:Error? closeResult = str.close(); -} -``` - -##### Rename/move a remote file - -The following code renames or moves a file to another location in the same remote FTP server. - -```ballerina -ftp:Error? renameResponse = ftpClient->rename("", - ""); -``` - -##### Delete a remote file - -The following code deletes a remote file in a remote FTP server. - -```ballerina -ftp:Error? deleteResponse = ftpClient->delete(""); -``` - -##### Remove a directory from a remote server - -The following code removes a directory in a remote FTP server. - -```ballerina -ftp:Error? rmdirResponse = ftpClient->rmdir(""); -``` - -### FTP listener - -The `ftp:Listener` is used to listen to a remote FTP location and trigger a `WatchEvent` type of event when new -files are added to or deleted from the directory. The `fileResource` function is invoked when a new file is added -and/or deleted. - -An FTP listener is defined using the mandatory `protocol`, `host`, and `path` parameters. The authentication -configuration can be done using the `auth` parameter and the polling interval can be configured using the `pollingInterval` parameter. -The default polling interval is 60 seconds. - -The `fileNamePattern` parameter can be used to define the type of files the FTP listener will listen to. -For instance, if the listener gets invoked for text files, the value `(.*).txt` can be given for the config. - -An authentication-related configuration can be given to the FTP listener with the `auth` configuration. - -##### Create a listener - -The FTP Listener can be used to listen to a remote directory. It will keep listening to the specified directory and -notify on file addition and deletion periodically. - -```ballerina -listener ftp:Listener remoteServer = check new({ - protocol: ftp:FTP, - host: "", - auth: { - credentials: { - username: "", - password: "" - } - }, - port: , - path: "", - pollingInterval: , - fileNamePattern: "" -}); - -service on remoteServer { - remote function onFileChange(ftp:WatchEvent fileEvent) { - - foreach ftp:FileInfo addedFile in fileEvent.addedFiles { - log:print("Added file path: " + addedFile.path); - } - foreach string deletedFile in fileEvent.deletedFiles { - log:print("Deleted file path: " + deletedFile); - } - } -} -``` - -### Secure access with SFTP - -SFTP is a secure protocol alternative to the FTP, which runs on top of the SSH protocol. -There are several ways to authenticate an SFTP server. One is using the username and the password. -Another way is using the client's private key. The Ballerina SFTP client and the listener support only those authentication standards. -An authentication-related configuration can be given to the SFTP client/listener with the `auth` configuration. -Password-based authentication is defined with the `credentials` configuration while the private key based authentication is defined with the `privateKey` configuration. - -#### SFTP client configuration - -```ballerina -ftp:ClientConfiguration sftpConfig = { - protocol: ftp:SFTP, - host: "", - port: , - auth: { - credentials: {username: "", password: ""}, - privateKey: { - path: "", - password: "" - } - } -}; -``` - -#### SFTP listener configuration - -```ballerina -listener ftp:Listener remoteServer = check new({ - protocol: ftp:SFTP, - host: "", - port: , - path: "", - pollingInterval: , - fileNamePattern: "", - auth: { - credentials: {username: "", password: ""}, - privateKey: { - path: "", - password: "" - } - } -}); -``` - -## Report issues - -To report bugs, request new features, start new discussions, view project boards, etc., go to the [Ballerina standard library parent repository](https://github.com/ballerina-platform/ballerina-standard-library). - -## Useful links - -- Chat live with us via our [Discord server](https://discord.gg/ballerinalang). -- Post all technical questions on Stack Overflow with the [#ballerina](https://stackoverflow.com/questions/tagged/ballerina) tag. diff --git a/ballerina/Module.md b/ballerina/README.md similarity index 100% rename from ballerina/Module.md rename to ballerina/README.md