-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathactivate-projects-rtd-branch.sh
executable file
·101 lines (84 loc) · 2.72 KB
/
activate-projects-rtd-branch.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
#!/bin/sh
# SPDX-License-Identifier: EPL-1.0
##############################################################################
# Copyright (c) 2019 The Linux Foundation and others.
#
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Eclipse Public License v1.0
# which accompanies this distribution, and is available at
# http://www.eclipse.org/legal/epl-v10.html
##############################################################################
#activate project docs versions for all supported ODL projects.
#This script needs to be run either manually by a docs maintainer with a valid RTD API token
#or automatically by Jenkins or any CI with a common hidden token.
usage() {
echo "Usage: $0 <token>"
echo
echo " token: RTD API Token"
echo
}
# Activate project docs version in RTD
activate_version() {
token=$1
project_name=$2
version_name=$3
echo "Activating $project_name $version_name"
curl -X PATCH "https://readthedocs.org/api/v3/projects/$project_name/versions/$version_name/" \
-H "Authorization: Token $token" \
-H "Content-Type: application/json" \
--data "{\"active\": true, \"hidden\": false}"
echo
}
# Build "latest" to force RTD to update available versions
update_available_versions() {
token=$1
project_name=$2
echo "Forcing RTD to update available versions"
curl -X POST "https://readthedocs.org/api/v3/projects/$project_name/versions/latest/builds/" \
-H "Authorization: Token $token" \
-H "Content-Length: 0"
echo
}
# Build to force RTD to update available versions
build_version() {
token=$1
project_name=$2
version_name=$3
echo "Forcing RTD to update available versions"
curl -X POST "https://readthedocs.org/api/v3/projects/$project_name/versions/$version_name/builds/" \
-H "Authorization: Token $token" \
-H "Content-Length: 0"
echo
}
while getopts :h: opts; do
case "$opts" in
h)
usage
exit 0
;;
[?])
usage
exit 1
;;
esac
done
if [ -z $1 ]; then
usage
exit 1
fi
################
# Start script #
################
token="$1"
for project in $(grep -v ^# projects_list.tsv | cut -f1); do
update_available_versions "$token" "odl-$project"
done
echo
echo "Waiting 60 seconds for available versions to update"
echo
sleep 60 # Wait a minute for RTD to update available versions
for project in $(grep -v ^# projects_list.tsv | cut -f1); do
version_name=$(grep $project projects_list.tsv | grep -v ^# | cut -f2)
activate_version "$token" "odl-$project" "$version_name"
build_version "$token" "odl-$project" "$version_name"
done