Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
E
embulk-input-filename
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Klaus Wölfel
embulk-input-filename
Commits
26fb4ecf
Commit
26fb4ecf
authored
Dec 14, 2017
by
Eteri
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
embulk-input-filename: add first_path and start_date options
parent
774b5abb
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
56 additions
and
17 deletions
+56
-17
src/main/java/org/embulk/input/filename/FilenameFileInputPlugin.java
...va/org/embulk/input/filename/FilenameFileInputPlugin.java
+56
-17
No files found.
src/main/java/org/embulk/input/filename/FilenameFileInputPlugin.java
View file @
26fb4ecf
...
...
@@ -5,6 +5,9 @@ import java.util.*;
import
java.util.Arrays
;
import
java.util.Comparator
;
import
java.util.Date
;
import
java.text.SimpleDateFormat
;
import
java.text.ParseException
;
import
java.nio.file.FileSystems
;
import
java.nio.file.attribute.FileTime
;
import
java.util.List
;
...
...
@@ -111,6 +114,14 @@ public class FilenameFileInputPlugin implements FileInputPlugin
@ConfigDefault
(
"null"
)
Optional
<
String
>
getFileNameSuffix
();
@Config
(
"start_date"
)
@ConfigDefault
(
"null"
)
Optional
<
String
>
getStartDate
();
@Config
(
"first_path"
)
@ConfigDefault
(
"null"
)
Optional
<
String
>
getFirstPath
();
@Config
(
"last_path"
)
@ConfigDefault
(
"null"
)
Optional
<
String
>
getLastPath
();
...
...
@@ -282,6 +293,20 @@ public class FilenameFileInputPlugin implements FileInputPlugin
}
final
ImmutableList
.
Builder
<
String
>
builder
=
ImmutableList
.
builder
();
final
SimpleDateFormat
format
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss zzz"
);
final
String
startDateString
=
task
.
getStartDate
().
orNull
();
final
Date
startDate
;
if
(
startDateString
!=
null
)
{
try
{
startDate
=
format
.
parse
(
startDateString
);
}
catch
(
ParseException
e
)
{
throw
new
RuntimeException
(
String
.
format
(
"Cannot parse start_date '%s'"
,
startDateString
),
e
);
}
}
else
{
startDate
=
null
;
}
final
String
firstPath
=
task
.
getFirstPath
().
orNull
();
final
String
lastPath
=
task
.
getLastPath
().
orNull
();
final
Integer
fileSize
=
task
.
getFileSize
().
orNull
();
final
String
fileNameSuffix
=
task
.
getFileNameSuffix
().
orNull
();
...
...
@@ -304,25 +329,24 @@ public class FilenameFileInputPlugin implements FileInputPlugin
@Override
public
FileVisitResult
preVisitDirectory
(
Path
path
,
BasicFileAttributes
attrs
)
{
if
(
useLastModified
)
{
FileTime
fileTime
;
long
file
Mod
Time
=
Long
.
MIN_VALUE
;
long
file
Change
Time
=
Long
.
MIN_VALUE
;
try
{
//fileTime = Files.getLastModifiedTime(path);
fileTime
=
(
FileTime
)
Files
.
getAttribute
(
path
,
"unix:ctime"
);
file
Mod
Time
=
fileTime
.
toMillis
();
file
Change
Time
=
fileTime
.
toMillis
();
}
catch
(
IOException
e
)
{
log
.
info
(
"Cannot get the last
modifi
ed time - {} "
,
e
);
log
.
info
(
"Cannot get the last
chang
ed time - {} "
,
e
);
}
// log.info("########################FROM REVISIT#############################################");
// log.info ("file = {}", path);
// log.info("last_Modified = {}, files time = {}", lastModified, file
Mod
Time);
// log.info("last_Modified = {}, files time = {}", lastModified, file
Change
Time);
if
(
path
.
equals
(
directory
)
||
Files
.
isDirectory
(
path
))
{
return
FileVisitResult
.
CONTINUE
;
}
else
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
>
fileModTime
)
{
//if file is older then lastModified
}
else
if
(
firstPath
!=
null
&&
path
.
toString
().
compareTo
(
firstPath
.
substring
(
0
,
path
.
toString
().
length
()))
<
0
)
{
return
FileVisitResult
.
SKIP_SUBTREE
;
}
else
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
>
fileChangeTime
)
{
//if file is older then lastModified
return
FileVisitResult
.
SKIP_SUBTREE
;
}
else
if
(
path
.
getFileName
().
toString
().
startsWith
(
"."
))
{
return
FileVisitResult
.
SKIP_SUBTREE
;
...
...
@@ -338,6 +362,8 @@ public class FilenameFileInputPlugin implements FileInputPlugin
else
{
if
(
path
.
equals
(
directory
))
{
return
FileVisitResult
.
CONTINUE
;
}
else
if
(
firstPath
!=
null
&&
path
.
toString
().
compareTo
(
firstPath
.
substring
(
0
,
path
.
toString
().
length
()))
<
0
)
{
return
FileVisitResult
.
SKIP_SUBTREE
;
}
else
if
(
lastPath
!=
null
&&
path
.
toString
().
compareTo
(
lastPath
.
substring
(
0
,
path
.
toString
().
length
()))
<
0
)
{
return
FileVisitResult
.
SKIP_SUBTREE
;
}
else
if
(
path
.
getFileName
().
toString
().
startsWith
(
"."
))
{
...
...
@@ -355,25 +381,38 @@ public class FilenameFileInputPlugin implements FileInputPlugin
@Override
public
FileVisitResult
visitFile
(
Path
path
,
BasicFileAttributes
attrs
)
{
FileTime
fileModifiedTime
;
Date
fileModifiedDate
=
null
;
try
{
fileModifiedTime
=
(
FileTime
)
Files
.
getLastModifiedTime
(
path
);
fileModifiedDate
=
new
Date
(
fileModifiedTime
.
toMillis
());
}
catch
(
IOException
e
)
{
log
.
info
(
"Cannot get the last modified time - {} "
,
e
);
}
if
(
firstPath
!=
null
&&
path
.
toString
().
compareTo
(
firstPath
)
<=
0
)
{
return
FileVisitResult
.
CONTINUE
;
}
if
(
startDate
!=
null
&&
startDate
.
compareTo
(
fileModifiedDate
)
>
0
)
{
return
FileVisitResult
.
CONTINUE
;
}
if
(
useLastModified
)
{
FileTime
fileTime
;
long
file
Mod
Time
=
Long
.
MIN_VALUE
;
long
file
Change
Time
=
Long
.
MIN_VALUE
;
try
{
//fileTime = Files.getLastModifiedTime(path);
fileTime
=
(
FileTime
)
Files
.
getAttribute
(
path
,
"unix:ctime"
);
file
Mod
Time
=
fileTime
.
toMillis
();
file
Change
Time
=
fileTime
.
toMillis
();
}
catch
(
IOException
e
)
{
log
.
info
(
"Cannot get the last
modifi
ed time - {} "
,
e
);
log
.
info
(
"Cannot get the last
chang
ed time - {} "
,
e
);
}
// log.info("########################FROM VISIT#############################################");
// log.info ("file = {}", path);
// log.info("last_Modified = {}, files time = {}", lastModified, file
Mod
Time);
// log.info("last_Modified = {}, files time = {}", lastModified, file
Change
Time);
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
>
file
Mod
Time
)
{
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
>
file
Change
Time
)
{
return
FileVisitResult
.
CONTINUE
;
}
else
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
==
file
Mod
Time
&&
lastPath
!=
null
&&
path
.
toString
().
compareTo
(
lastPath
)
<=
0
)
{
}
else
if
(
lastModified
!=
null
&&
Long
.
parseLong
(
lastModified
)
==
file
Change
Time
&&
lastPath
!=
null
&&
path
.
toString
().
compareTo
(
lastPath
)
<=
0
)
{
return
FileVisitResult
.
CONTINUE
;
}
else
if
(
path
.
getFileName
().
toString
().
startsWith
(
"."
))
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment