orcli/src/import_tsv_command.sh

87 lines
2.4 KiB
Bash
Raw Normal View History

2023-01-12 11:18:06 +01:00
# shellcheck shell=bash disable=SC2154
2022-11-16 23:22:54 +01:00
# call init_import function to eval args and to set basic post data
init_import
# check if stdin is present if selected
2023-01-12 11:18:06 +01:00
if [[ ${file} == '-' ]] && ! read -u 0 -t 0; then
orcli_import_tsv_usage
exit 1
2022-11-16 23:22:54 +01:00
fi
# assemble specific post data (some options require json format)
data+=("format=text/line-based/*sv")
options='{ '
options+="\"separator\": \"\\t\""
if [[ ${args[--encoding]} ]]; then
options+=', '
options+="\"encoding\": \"${args[--encoding]}\""
fi
if [[ ${args[--blankCellsAsStrings]} ]]; then
options+=', '
options+='"storeBlankCellsAsNulls": false'
fi
if [[ ${args[--columnNames]} ]]; then
2023-01-09 11:42:51 +01:00
IFS=',' read -ra columnNames <<< "${args[--columnNames]}"
options+=', '
2023-01-09 11:42:51 +01:00
options+="\"columnNames\": [ $(printf ',"'%s'"' "${columnNames[@]}" | cut -c2-) ]"
fi
if [[ ${args[--guessCellValueTypes]} ]]; then
options+=', '
options+='"guessCellValueTypes": true'
fi
if [[ ${args[--headerLines]} ]]; then
options+=', '
options+="\"headerLines\": ${args[--headerLines]}"
fi
if [[ ${args[--ignoreLines]} ]]; then
options+=', '
options+="\"ignoreLines\": ${args[--ignoreLines]}"
fi
if [[ ${args[--ignoreQuoteCharacter]} ]]; then
options+=', '
options+='"processQuotes": false'
fi
if [[ ${args[--includeFileSources]} ]]; then
options+=', '
options+='includeFileSources: true'
fi
if [[ ${args[--includeArchiveFileName]} ]]; then
options+=', '
options+='"includeArchiveFileName": true'
fi
if [[ ${args[--limit]} ]]; then
options+=', '
options+="\"limit\": ${args[--limit]}"
fi
if [[ ${args[--quoteCharacter]} ]]; then
options+=', '
options+="\"quoteCharacter\": \"${args[--quoteCharacter]}\""
fi
if [[ ${args[--skipBlankRows]} ]]; then
options+=', '
options+='"storeBlankRows": false'
fi
if [[ ${args[--skipDataLines]} ]]; then
options+=', '
options+="\"skipDataLines\": ${args[--skipDataLines]}"
fi
2023-10-28 18:07:08 +02:00
if [[ ${args[--projectName]} ]]; then
2022-11-16 23:22:54 +01:00
options+=', '
2023-10-28 18:07:08 +02:00
options+="\"projectName\": \"${args[--projectName]}\""
fi
if [[ ${args[--projectTags]} ]]; then
2023-01-09 11:42:51 +01:00
IFS=',' read -ra projectTags <<< "${args[--projectTags]}"
options+=', '
2023-01-09 11:42:51 +01:00
options+="\"projectTags\": [ $(printf ',"'%s'"' "${projectTags[@]}" | cut -c2-) ]"
2022-11-16 23:22:54 +01:00
fi
2023-10-28 18:07:08 +02:00
if [[ ${args[--trimStrings]} ]]; then
options+=', '
options+='"trimStrings": true'
fi
2022-11-16 23:22:54 +01:00
options+=' }'
data+=("options=${options}")
# call post_import function to post data and validate results
post_import "${data[@]}"