184 lines
6.9 KiB
Markdown
184 lines
6.9 KiB
Markdown
# FTP Upload Binding
|
|
|
|
This binding can be used to receive image files from FTP clients.
|
|
The binding acts as a FTP server.
|
|
Images stored on the FTP server are not saved to the file system, therefore the binding shouldn't cause any problems on flash based openHAB installations if files are uploaded to FTP server continuously (e.g. network camera images).
|
|
|
|
## Supported Things
|
|
|
|
This binding supports Things of type `ftpupload`.
|
|
Every Thing is identified by FTP user name.
|
|
Therefore, every thing should use unique user name to login FTP server.
|
|
|
|
## Discovery
|
|
|
|
Automatic discovery is not supported.
|
|
|
|
## Binding Configuration
|
|
|
|
The binding has the following configuration options:
|
|
|
|
| Parameter | Name | Description | Required | Default value |
|
|
|-------------|--------------|------------------------------------------------------------------------------------------------------------------------|----------|---------------|
|
|
| port | TCP Port | TCP port of the FTP server | no | 2121 |
|
|
| idleTimeout | Idle timeout | The number of seconds before an inactive client is disconnected. If this value is set to 0, the idle time is disabled. | no | 60 |
|
|
|
|
## Thing Configuration
|
|
|
|
The `ftpupload` Thing has the following configuration parameters:
|
|
|
|
| Parameter | Description | Required | Default value |
|
|
|-----------------------------|---------------------------------------------------------------------------------------------------------------------|----------|---------------|
|
|
| userName | User name to login to the FTP server. User name is used to identify the Thing, so it should be unique per Thing. | yes | |
|
|
| password | Password to login to the FTP server. | yes | |
|
|
|
|
|
|
## Channels
|
|
|
|
This binding currently supports the following channels:
|
|
|
|
| Channel | Channel Type Id | Item Type | Description |
|
|
|-----------------|-----------------|--------------|----------------------------------------------------------------------------------------|
|
|
| image | image-channel | Image | Image file received via FTP. |
|
|
|
|
Additionally user can introduce custom image-channel's to Thing (see examples).
|
|
When an image file is uploaded to FTP server, the binding tries to find the channel whose filename matches the uploaded image filename.
|
|
If no match is found, no channel is updated.
|
|
The filename parameter supports regular expression patterns.
|
|
See more details in the Things example.
|
|
|
|
Image channel supports following options:
|
|
|
|
| Parameter | Name | Description | Required | Default value |
|
|
|-------------|--------------|--------------------------------------------------------------------------|----------|---------------|
|
|
| filename | Filename | Filename to match received files. Supports regular expression patterns. | yes | .* |
|
|
|
|
|
|
### Trigger Channels
|
|
|
|
| Channel Type ID | Options | Description |
|
|
|-----------------|------------------------|-----------------------------------------------------|
|
|
| image-received | IMAGE_RECEIVED | Triggered when image file received from FTP client. |
|
|
|
|
When an image file is uploaded to FTP server, the binding tries to find the trigger channel whose filename matches the upload image filename.
|
|
If no match is found, no channel is updated.
|
|
The filename parameter supports regular expression patterns.
|
|
See more details in the Things example.
|
|
|
|
Trigger channels supports following options:
|
|
|
|
| Parameter | Name | Description | Required | Default value |
|
|
|-------------|--------------|--------------------------------------------------------------------------|----------|---------------|
|
|
| filename | Filename | Filename to match received files. Supports regular expression patterns. | yes | .* |
|
|
|
|
## Full Example
|
|
|
|
Things:
|
|
|
|
```
|
|
Thing ftpupload:imagereceiver:images1 [ userName="test1", password="12345" ] {
|
|
|
|
Thing ftpupload:imagereceiver:images2 [ userName="test2", password="12345" ] {
|
|
Channels:
|
|
Type image-channel : my_image1 "My Image channel 1" [
|
|
filename="test12[0-9]{2}.png" // match to filename test12xx.png, where xx can be numbers between 00-99
|
|
]
|
|
Type image-channel : my_image2 "My Image channel 2" [
|
|
filename="test.jpg"
|
|
]
|
|
Trigger String : my_image_trigger1 [
|
|
filename="test12[0-9]{2}.png"
|
|
]
|
|
Trigger String : my_image_trigger2 [
|
|
filename="test.jpg"
|
|
]
|
|
}
|
|
```
|
|
|
|
Items:
|
|
|
|
```
|
|
Image Image1 { channel="ftpupload:imagereceiver:images1:image" }
|
|
Image Image2 { channel="ftpupload:imagereceiver:images2:my_image1" }
|
|
```
|
|
|
|
Rules:
|
|
|
|
```
|
|
rule "example trigger rule 1"
|
|
when
|
|
Channel 'ftpupload:imagereceiver:images1:image-received' triggered IMAGE_RECEIVED
|
|
then
|
|
logInfo("Test","Image received")
|
|
end
|
|
|
|
rule "example trigger rule 2"
|
|
when
|
|
Channel 'ftpupload:imagereceiver:images2:my_image_trigger1' triggered IMAGE_RECEIVED
|
|
then
|
|
logInfo("Test","Image received")
|
|
end
|
|
|
|
```
|
|
|
|
Sitemap:
|
|
|
|
```
|
|
Frame label="FTP images" {
|
|
Image item=Image1
|
|
Image item=Image2
|
|
}
|
|
```
|
|
|
|
## Use case example
|
|
|
|
The binding can be used to receive images from network cameras that send images to a FTP server when motion or sound is detected.
|
|
|
|
Things:
|
|
|
|
```
|
|
Thing ftpupload:imagereceiver:garagecamera [ userName="garage", password="12345" ]
|
|
```
|
|
|
|
Items:
|
|
|
|
```
|
|
Image Garage_NetworkCamera_Motion_Image { channel="ftpupload:imagereceiver:garagecamera:image" }
|
|
```
|
|
|
|
Rules:
|
|
|
|
```
|
|
rule "example trigger rule"
|
|
when
|
|
Channel 'ftpupload:imagereceiver:garagecamera:image-received' triggered IMAGE_RECEIVED
|
|
then
|
|
logInfo("Test","Garage motion detected")
|
|
end
|
|
```
|
|
|
|
Sitemap:
|
|
|
|
```
|
|
Frame label="Garage network camera" icon="camera" {
|
|
Image item=Garage_NetworkCamera_Motion_Image
|
|
}
|
|
```
|
|
|
|
## Logging and Problem Solving
|
|
|
|
For problem solving, if binding logging is not enough, Apache FTP server logging can also be enabled by the following command in the Karaf console:
|
|
|
|
```
|
|
log:set DEBUG org.apache.ftpserver
|
|
```
|
|
|
|
and set back to default level:
|
|
|
|
```
|
|
log:set DEFAULT org.apache.ftpserver
|
|
```
|
|
|
|
If you meet any problems to receive images from the network cameras, you could test connection to binding with any FTP client.
|
|
You can send image files via FTP client and thing channels should be updated accordingly.
|