Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
294 changed files
with
7,271 additions
and
6,139 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
#!/usr/bin/env bash | ||
|
||
# Change this variable if you are using another name for ckan/ckan's remote | ||
REMOTE=origin | ||
PR_ENDPOINT=https://api.github.com/repos/ckan/ckan/pulls | ||
|
||
prepare_branches() { | ||
echo List existing branches | ||
# awk filters out `master`, `release-something`, `dev-something` and `MAJOR.MINOR-something` branches | ||
custom_branches=$(git fetch $REMOTE && git branch -r --list $REMOTE/* | awk '{ if ($2 !~ /^[0-9]\.[0-9]|^release|^dev-|^master$|HEAD/) print $2}' FS=/) | ||
|
||
echo Calculate total amount of active PRs | ||
# github adds Link header, that contains reference to last page with results. And that helps us to define total number of pages | ||
last_page=$(curl -s -I $PR_ENDPOINT | grep '^Link' | sed -E 's/.*page=([[:digit:]]+).*rel="last".*/\1/') | ||
|
||
echo Compute branches that are in use by active PRs | ||
for ((i=1; i<=$last_page; i++)) | ||
do | ||
# Take JSON, get name of branch with feature, leave only those ones, that starts with `ckan:`. I think, that jq is much more nice way to process json, but i'm not sure, that every one has it. But if you do, | ||
# you can replace python's section with something like `| jq '.[] | .head.label' -r |` | ||
next_portion=$(curl -s "$PR_ENDPOINT?page=$i" | python -c 'import json, sys; raw=sys.stdin.read(); labels=[str(item["head"]["label"]) for item in json.loads(raw)]; print("\n".join(labels))' | grep '^ckan' | sed 's/^ckan://') | ||
used_branches="$used_branches\n$next_portion" | ||
echo [$i of $last_page parts processed] | ||
done; | ||
|
||
echo Compute list of branches that can be safetely removed | ||
tmp_file=$(mktemp) | ||
diff <(echo -e "$used_branches" | sort) <(echo -e "$custom_branches" | sort) --unchanged-line-format="" >> $tmp_file | ||
|
||
echo | ||
echo List of all branches that can be removed stored into $tmp_file. Review it\'s content and run \'$0 --apply $tmp_file\'. | ||
echo NOTE. This command requires write access to CKAN repository and will actually remove all branches that are listed in $tmp_file. | ||
} | ||
|
||
if [[ $# -gt 0 ]]; | ||
then | ||
case "$1" in | ||
-h|--help) | ||
echo Compute/remove unused branches | ||
echo Usage: $0 [--apply FILE_WITH_BRANCHES] | ||
;; | ||
--apply) | ||
shift | ||
if [[ -f $1 ]] | ||
then | ||
while read branch | ||
do | ||
git push $REMOTE --delete $branch | ||
done < $1 | ||
else | ||
echo File does not exist | ||
fi | ||
shift | ||
;; | ||
*) | ||
echo Check usage with: $0 --help | ||
;; | ||
esac | ||
else | ||
prepare_branches | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
# encoding: utf-8 | ||
|
||
import logging | ||
|
||
import click | ||
|
||
from ckan.cli import error_shout | ||
import ckan.lib.config_tool as ct | ||
|
||
log = logging.getLogger(__name__) | ||
|
||
|
||
class ConfigOption(click.ParamType): | ||
name = u'config-option' | ||
|
||
def convert(self, value, param, ctx): | ||
if u'=' not in value: | ||
self.fail( | ||
u'An option does not have an equals sign. ' | ||
u'It should be \'key=value\'. If there are spaces ' | ||
u'you\'ll need to quote the option.\n' | ||
) | ||
return value | ||
|
||
|
||
@click.command( | ||
name=u'config-tool', | ||
short_help=u'Tool for editing options in a CKAN config file.' | ||
) | ||
@click.option( | ||
u'--section', | ||
u'-s', | ||
default=u'app:main', | ||
help=u'Section of the config file' | ||
) | ||
@click.option( | ||
u'--edit', | ||
u'-e', | ||
is_flag=True, | ||
help=u'Checks the option already exists in the config file.' | ||
) | ||
@click.option( | ||
u'--file', | ||
u'-f', | ||
u'merge_filepath', | ||
help=u'Supply an options file to merge in.' | ||
) | ||
@click.argument(u'config_filepath', type=click.Path(exists=True)) | ||
@click.argument(u'options', nargs=-1, type=ConfigOption()) | ||
def config_tool(config_filepath, options, section, edit, merge_filepath): | ||
u'''Tool for editing options in a CKAN config file | ||
paster config-tool <default.ini> <key>=<value> [<key>=<value> ...] | ||
paster config-tool <default.ini> -f <custom_options.ini> | ||
Examples: | ||
paster config-tool default.ini sqlalchemy.url=123 'ckan.site_title=ABC' | ||
paster config-tool default.ini -s server:main -e port=8080 | ||
paster config-tool default.ini -f custom_options.ini | ||
''' | ||
|
||
if merge_filepath: | ||
ct.config_edit_using_merge_file( | ||
config_filepath, merge_filepath | ||
) | ||
if not (options or merge_filepath): | ||
return error_shout(u'No options provided') | ||
try: | ||
ct.config_edit_using_option_strings( | ||
config_filepath, options, section, edit=edit | ||
) | ||
except ct.ConfigToolError as e: | ||
error_shout(e) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.