-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathtransfer_BaseSpace_to_NGS_sequencer_dir.sh
168 lines (136 loc) · 7.77 KB
/
transfer_BaseSpace_to_NGS_sequencer_dir.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
#!/bin/bash
## USAGE: /ifs/data/scripts/transfer_BaseSpace_to_NGS_sequencer_dir.sh "ProjectID" "/path/to/BaseSpace_dir"
## DESCRIPTION: This script will copy .fastq.gz files from a cloud-based BaseSpace project
## directory to the 'NextSeq' directory which has been setup to hold DNA sequencer
## output.
##
## 'BaseSpace_dir' is a directory that has been mounted by BaseMount and contains
## data tied to your BaseSpace cloud account (sequencer projects & runs, etc.)
##
## 'ProjectID' is the ID of the project you are trying to copy files from, such as "ABC17-03"
##
## By default all fastq files will be copied to a single common directory, but
## the script will first check to make sure that all fastq files have unique filenames
## and that their parent directory names do not contain ID's which are not also
## included in the fastq filename. If either of these are true, then the parent
## directories will be preserved as the files are copied.
# ~~~~~ CUSTOM FUNCTIONS ~~~~~ #
copy_to_common_dir () {
# copy all files to a common output dir
local source_dir="$1"
local destination_dir="$2"
local file_type="$3"
find "${source_dir}" -name "${file_type}" -exec rsync -vctrPh {} "$destination_dir" \; # --dry-run
}
copy_with_parents () {
# copy files from BaseSpace BaseMount, keep parent dirs
# e.g.: /BaseSpace/Projects/ABC17-03/Samples/ABC17-009/Files/ABC17-009_S6_L002_R2_001.fastq.gz
# output_path=ABC17-009/ABC17-009_S6_L002_R2_001.fastq.gz
local source_dir="$1"
local destination_dir="$2"
local file_type="$3"
find "$source_dir" -name "${file_type}" | while read item; do
parent_dir="${item##*Samples/}"
parent_dir="${parent_dir%%/*}"
output_path="${destination_dir}/${parent_dir}"
printf "Copying to:\n%s\n\n" "${output_path}"
rsync -vctrPh "$item" "${output_path}/" #
done
}
print_copying () {
# print_copying "$source_dir" "$destination_dir" "$file_type" "$message"
local source_dir="$1"
local destination_dir="$2"
local file_type="$3"
local message="$4"
printf "\nCopying all %s files %s\n\nFrom:\n%s\n\nTo:\n%s\n\n" "$file_type" "$message" "$source_dir" "$destination_dir"
}
# ~~~~~ CHECK SCRIPT ARGS ~~~~~ #
if (( "$#" != "2" )); then
echo "ERROR: Wrong number of arguments supplied"
grep '^##' $0
exit
fi
# ~~~~~ GET SCRIPT ARGS ~~~~~ #
# project to be transfered from BaseSpace
project_ID="$1" # "ABC17-03"
# directory which has been mounted by BaseMount (user should have done this already)
basepace_dir="$2"
# ~~~~~ MISC PARAMS ~~~~~ #
# type of file we want to copy; pattern to be used in 'find'
file_type='*.fastq.gz'
# ~~~~~ SETUP DIRS ~~~~~ #
# parent directory for sequencer output
sequencer_dir="/ifs/data/NextSeq"
# location where the project data will be copied to; make the dir
project_sequencer_dir="${sequencer_dir}/${project_ID}"
mkdir -p "$project_sequencer_dir"
# location where the BaseSpace projects will appear
basepace_projects="${basepace_dir}/Projects"
# BaseSpace dir for the project we want
project_BaseSpace_dir="${basepace_projects}/${project_ID}"
# ~~~~~ VALIDATIONS ~~~~~ #
divider="------------------------------------------------------------"
printf "%s\nStarting BaseSpace copy script\n\nProject Id:\n%s\n\nBaseMount directory:\n%s\n\nFile type to transfer:\n%s\n\n" "$divider" "$project_ID" "$basepace_dir" "$file_type"
printf "%s\nValidating BaseMount directory....\n\n" "$divider"
# make sure project_BaseSpace_dir exists
[ ! -d "$project_BaseSpace_dir" ] && printf "ERROR: Item is not a valid directory:\n%s\n\nDoes it exist? Exiting...\n\n" "$project_BaseSpace_dir" && exit
# make sure project_BaseSpace_dir contains projects
num_entries="$(ls -1 "$project_BaseSpace_dir" | wc -l)"
(( "$num_entries" < 1 )) && printf "ERROR: Directory contains %s items:\n%s\n\nExiting...\n\n" "$num_entries" "$project_BaseSpace_dir" && exit
# make sure that fastq files are present in the project_BaseSpace_dir
num_fastqs="$(find "$project_BaseSpace_dir" -type f -name "$file_type" | wc -l)"
(( "$num_fastqs" < 1 )) && printf "ERROR: Directory contains %s %s files:\n%s\n\nExiting...\n\n" "$num_fastqs" "$file_type" "$project_BaseSpace_dir" && exit
# check to see if any filenames DO NOT contain the parent ID
# use a psuedo-boolean flag; "True" or "False"
some_filenames_lack_parentID="False"
printf "Checking to see if any %s files lack sample ID from their parent directory " "$file_type"
find "$project_BaseSpace_dir" -type f -name "$file_type" | while read item; do
# item="/ifs/home/kellys04/projects/Clinical_580_gene_panel/BaseSpace/Projects/ABC17-03/Samples/ABC17-0247/Files/ABC17-0247_S12_L004_R2_001.fastq.gz"
parent="${item##*Samples/}"
parent="${parent%%/*}" # ABC17-0247
file_base="$(basename "$item")" # ABC17-0247_S12_L004_R2_001.fastq.gz
# if boolean isn't already "True", then set it to "True" if "parent" is not found in "file_base"
if ! echo "$file_base" | grep -q "${parent}"; then
# echo "string ${parent} is in string $file_base"
[ "$some_filenames_lack_parentID" != "True" ] && some_filenames_lack_parentID="True"
fi
# printf "${parent}\t${file_base}\t${some_filenames_lack_parentID}\n"
printf "."
done
printf " %s\n" "$some_filenames_lack_parentID"
# the fastq files are currently in subdirs but we want to copy all of them to a common dir;
# check to make sure that none have duplicate names
num_all_fastq_files="$(find "${project_BaseSpace_dir}" -name "$file_type" | wc -l)"
num_unique_filenames="$(find "${project_BaseSpace_dir}" -name "$file_type" -exec basename {} \; | sort -u | wc -l)"
printf "\nNumber of %s files found: %s\n\n" "$file_type" "$num_all_fastq_files"
printf "\nChecking to make sure that all %s files have unique names...\n\n" "$file_type"
printf "\nNumber of unique %s filenames found: %s\n\n" "$file_type" "$num_unique_filenames"
# ~~~~~ COPY THE FILES ~~~~~ #
printf "%s\nStarting file transfer....\n\n" "$divider"
# if False, then check for duplicate file basenames; if True, keep parent dirs
if [ "$some_filenames_lack_parentID" == "False" ]; then
printf "\nNo %s filenames lacked parent directory ID's\n" "$file_type"
# if there are no duplicates, the values should be equal
if [ "$num_all_fastq_files" -eq "$num_unique_filenames" ]; then
# it is safe to copy all fastq files to a common dir
printf "\nNumber of %s files matches number of unique filenames\n" "$file_type"
print_copying "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type" "to common dir"
copy_to_common_dir "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type"
elif [ ! "$num_all_fastq_files" -eq "$num_unique_filenames" ]; then
# not equal; some fastq's have same filename, need to preserve parent dir's
printf "\nNumber of %s files does not match number of unique filenames\n" "$file_type"
print_copying "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type" ", preserving parent dirs"
copy_with_parents "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type"
fi
elif [ "$some_filenames_lack_parentID" == "True" ]; then
printf "\nSome %s filenames lacked parent directory ID's\n" "$file_type"
print_copying "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type" " to common dir"
copy_with_parents "$project_BaseSpace_dir" "$project_sequencer_dir" "$file_type"
fi
# ~~~~~ FINISHED ~~~~~ #
unmount_command="basemount --unmount $basepace_dir"
remount_command="basemount ${basepace_dir}/"
echo "BaseSpace copy script finished. Please check to make sure files were successfully transferred"
printf "If you are done transferring files, remember to unmount your BaseMount directory with this command:\n%s\n\n" "$unmount_command"
printf "If you need to remount your BaseMount directory, you can use this command:\n%s\n\n" "$remount_command"