#' listPathSMB
#' @description Use python SMBConnection to retrieve the list of files/folders at a `path`
#' @param username Your SMB user name
#' @param password Your SMB user password, do not store this in your code!
#' @param my_name The machine you are running this operation on (Default : `Sys.info()[["nodename"]]`)
#' @param remote_name The smb server name
#' @param service_name The service_name name i.e. `'service_name'`
#' @param path The SMB folder path where your file is e.g. `'Files/Reporting/'`
#' @param pattern string filtering results (Default : `'*'`)
#' @param domain SMB server domain
#' @param port Common port (Default : `445`)
#' @param timeout How long to keep the connection open before timeout (Default : `30`)
#' @param python_location The location of your python installation
#'
#' @importFrom reticulate use_python
#' @importFrom reticulate import
#' @return Retrieve a directory listing of files/folders at `path`
#' @export
#'
listPathSMB <-
function(username,
password,
my_name = Sys.info()[["nodename"]],
remote_name,
service_name,
path,
pattern,
domain,
port = 445,
timeout = 30,
python_location) {
use_python(python_location)
smb <- import("smb.SMBConnection")
smb <-
smb$SMBConnection(
username,
password,
my_name,
remote_name,
domain = domain,
use_ntlm_v2 = 'True',
is_direct_tcp = 'True'
)
connected <- smb$connect(ip = remote_name, port = as.integer(port),timeout = as.integer(timeout))
service_namedfiles <-
smb$listPath(service_name, path = path, pattern = pattern)
smb$close()
return(sapply(
service_namedfiles,
FUN = function(x)
x$filename
))
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.