-
Notifications
You must be signed in to change notification settings - Fork 0
/
basespace.sh
182 lines (147 loc) · 5.63 KB
/
basespace.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
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
#!/usr/bin/env bash
# Maintained by: Jon Bråte ([email protected])
# Version: 1.0
# This script downloads fastq files from the BaseSpace server and transfers them to the NIPH N-drive.
# Define the script name and usage
SCRIPT_NAME=$(basename "$0")
usage() {
echo "Usage: $SCRIPT_NAME [OPTIONS]"
echo "Options:"
echo " -h, --help Display this help message"
echo " -p, --platform Can be either nextseq or miseq"
echo " -r, --run Specify the run name (e.g. NGS_SEQ-20240606-01)"
echo " -a, --agens Specify agens (only required for HCV and ROV)"
echo " -y, --year Specify the year the sequencing was performed (e.g. 2024)"
exit 1
}
# Initialize variables
PLATFORM=""
RUN=""
AGENS=""
YEAR=""
while getopts "hp:r:n:a:y:" opt; do
case "$opt" in
h) usage ;;
p) PLATFORM="$OPTARG" ;;
r) RUN="$OPTARG" ;;
a) AGENS="$OPTARG" ;;
y) YEAR="$OPTARG" ;;
?) usage ;;
esac
done
## Check if necessary software and files are present
# The script requires BaseSpace CLI installed (https://developer.basespace.illumina.com/docs/content/documentation/cli/cli-overview)
# Check if the bs command is available
if ! command -v /home/ngs/bin/bs &> /dev/null
then
echo "BaseSpace CLI could not be found"
exit 1
fi
# There also has to be a BaseSpace credentials file: $HOME/.basespace/default.cfg
# Check if the file exists
if ! test -f ~/.basespace/default.cfg; then
echo "BaseSpace credentials file does not exist."
exit 1
fi
# Check if credential file exists
if ! test -f ~/.smbcreds; then
echo "Credential file for transfer to N does not exist."
exit 1
fi
## Set up environment
BASE_DIR=/mnt/tempdata/
SMB_AUTH=/home/ngs/.smbcreds
SMB_HOST=//Pos1-fhi-svm01/styrt
SMB_DIR=NGS/3-Sekvenseringsbiblioteker/${YEAR}/Illumina_Run
echo "Getting the Run ID on the BaseSpace server"
# List Runs on BaseSpace and get the Run id (third column separated by | and whitespaces)
id=$(/home/ngs/bin/bs list projects | grep "${RUN}" | awk -F '|' '{print $3}' | awk '{$1=$1};1')
echo "Downloading fastq files"
# First clean up the tempdrive
DIRECTORY="$BASE_DIR/fastq"
if [ -d "$DIRECTORY" ]; then
echo "Directory $DIRECTORY exists. Deleting..."
rm -rf "$DIRECTORY"
echo "Directory $DIRECTORY has been deleted."
else
echo "Directory $DIRECTORY does not exist."
fi
# Download to a sub-directory for easier copying to N: later
mkdir -p $BASE_DIR/fastq
# Then download the fastq files
/home/ngs/bin/bs download project -i ${id} --extension=fastq.gz -o $BASE_DIR/fastq/$RUN
# Execute commands based on the platform specified
if [[ $PLATFORM == "miseq" ]]; then
echo "Running commands for MiSeq platform..."
# Clean up the folder names
RUN_DIR="$BASE_DIR/fastq/${RUN}"
# Find only directories in the current directory. Loop through them and rename
# mindepth 1 excludes the RUN_DIR directory. maxdepth 1 includes only the sudirectories of RUN_DIR
find "$RUN_DIR" -mindepth 1 -maxdepth 1 -type d -print0 | while IFS= read -r -d '' folder; do
# Extract the name of the subdirectory
dir_name=$(basename "$folder")
# Extract the sample number and add Agens name
new_name="${dir_name%%_*}"
# Rename the folder
mv "$folder" "$RUN_DIR/$new_name"
done
echo "Transferring files to N"
# Move to N:
smbclient $SMB_HOST -A $SMB_AUTH -D $SMB_DIR <<EOF
prompt OFF
recurse ON
lcd $BASE_DIR/fastq
mput *
EOF
## Clean up
rm -rf $BASE_DIR/fastq
elif [[ $PLATFORM == "nextseq" ]]; then
echo "Running commands for NextSeq platform..."
# Define output directory
OUTPUT_DIR=final/$RUN/merged
# Create the output directory if it doesn't exist
mkdir -p $BASE_DIR/$OUTPUT_DIR
# Loop through each sample directory, create new subdirectories for each sample and copy the fastq files to the corresponding directory
for fastq in "$BASE_DIR/fastq/$RUN"/*/*.fastq.gz; do
# Extract the basename
base=$(basename $fastq)
# Extract the sample name
sample_name=$(basename "$fastq" | cut -f 1 -d "_")
# Make directories for each sample
mkdir -p $BASE_DIR/$OUTPUT_DIR/$sample_name
# Move each fastq file
echo "Moving $base to directory $sample_name"
mv $fastq $BASE_DIR/$OUTPUT_DIR/$sample_name/$base
done
# Merge all R1 and R2 files for each sample
# Loop through each directory in the "merged" directory
for sample_dir in "$BASE_DIR/$OUTPUT_DIR"/*; do
if [ -d "$sample_dir" ]; then
# Extract the sample name
sample_name=$(basename "$sample_dir")
# Concatenate all R1 files into a single file
cat "$sample_dir"/*_R1_*.fastq.gz > "$sample_dir/${sample_name}_merged_R1_001.fastq.gz"
echo "Concatenated R1 files for sample $sample_name"
# Concatenate all R2 files into a single file
cat "$sample_dir"/*_R2_*.fastq.gz > "$sample_dir/${sample_name}_merged_R2_001.fastq.gz"
echo "Concatenated R2 files for sample $sample_name"
# Remove original files
rm "$sample_dir"/*_S*_L*_R*fastq.gz
fi
done
echo "All files merged successfully."
echo "Moving files to the N drive"
smbclient $SMB_HOST -A $SMB_AUTH -D $SMB_DIR <<EOF
prompt OFF
recurse ON
lcd $BASE_DIR/final/
mput *
EOF
## Clean up
rm -rf $BASE_DIR/fastq
rm -rf $BASE_DIR/final
echo "All done!"
else
echo "Error: Illumina NextSeq or MiSeq platform not supported or not specified"
usage
fi