mirror of
https://github.com/YunoHost/apps.git
synced 2024-09-03 20:06:07 +02:00
Merge pull request #5 from Psycojoker/helper_script
[enh] Add Python helper script
This commit is contained in:
commit
b1b46eb679
3 changed files with 80 additions and 8 deletions
12
README.md
12
README.md
|
@ -61,7 +61,15 @@ The integration will be discussed on the Pull Request.
|
|||
|
||||
**Important**: You will have to find a maintainer willing to take care of the package while published if you want your app to be validated.
|
||||
|
||||
---
|
||||
#### Helper script
|
||||
|
||||
You can use the <code>add_or_update.py</code> python script to add or update
|
||||
your app from one of the 2 json files.
|
||||
|
||||
Usage:
|
||||
|
||||
```bash
|
||||
python ./add_or_update.py [community.json OR official.json] [github url [github url [github url ...]]]
|
||||
```
|
||||
|
||||
#### More information on [yunohost.org/packaging_apps](https://yunohost.org/packaging_apps)
|
||||
|
||||
|
|
64
add_or_update.py
Normal file
64
add_or_update.py
Normal file
|
@ -0,0 +1,64 @@
|
|||
import os
|
||||
import sys
|
||||
import json
|
||||
|
||||
from urllib2 import urlopen
|
||||
|
||||
states = {
|
||||
1: "notworking",
|
||||
2: "inprogress",
|
||||
3: "working",
|
||||
}
|
||||
|
||||
if __name__ == '__main__':
|
||||
if not len(sys.argv[1:]):
|
||||
print("I need a json file as first argument and a list of github urls")
|
||||
sys.exit(0)
|
||||
|
||||
if len(sys.argv[1:]) < 2:
|
||||
print("I need a list of github urls after the json file")
|
||||
sys.exit(0)
|
||||
|
||||
if not os.path.exists(sys.argv[1]):
|
||||
print("The json file '%s' doesn't exist" % sys.argv[1])
|
||||
|
||||
content = json.load(open(sys.argv[1], "r"))
|
||||
|
||||
for url in sys.argv[2:]:
|
||||
if not url.startswith("https://github.com"):
|
||||
sys.stderr.write("WARNING: url '%s' doesn't starts with https://github.com, skip it\n" % url)
|
||||
|
||||
owner, repo = filter(None, url.split("/"))[-2:]
|
||||
project_name = filter(None, url.split("/"))[-1].replace("_ynh", "")
|
||||
|
||||
github_data = json.load(urlopen("https://api.github.com/repos/%(owner)s/%(repo)s/commits" % {"owner": owner, "repo": repo}))
|
||||
|
||||
if project_name not in content:
|
||||
content[project_name] = {}
|
||||
else:
|
||||
print("INFO: project already in '%s', I'm updating it" % sys.argv[1])
|
||||
|
||||
content[project_name]["url"] = url
|
||||
content[project_name]["revision"] = github_data[0]["sha"]
|
||||
content[project_name]["branch"] = "master"
|
||||
|
||||
if sys.argv[1] == "official.json":
|
||||
content[project_name]["state"] = "validated"
|
||||
|
||||
else:
|
||||
got_state = False
|
||||
while not got_state:
|
||||
answer = input("Give me a state for this repository (digit or name) in:\n%s\n\nState: " % "\n".join(["%s: %s" % x for x in sorted(states.items(), key=lambda x: x[0])]) + "\n")
|
||||
|
||||
if answer in states:
|
||||
answer = states[answer]
|
||||
got_state = True
|
||||
elif answer in states.values():
|
||||
got_state = True
|
||||
else:
|
||||
print("Invalid state.\n")
|
||||
|
||||
content[project_name]["state"] = answer
|
||||
|
||||
open(sys.argv[1], "w").write("\n".join(json.dumps(content, indent=4, sort_keys=True).split(" \n")) + "\n")
|
||||
os.system("git diff")
|
|
@ -1,16 +1,16 @@
|
|||
{
|
||||
"243": {
|
||||
"branch": "master",
|
||||
"revision": "b9d58efeac78feb7f74e723c999ff25ab7ab8b52",
|
||||
"state": "ready",
|
||||
"url": "https://github.com/M5oul/243_ynh"
|
||||
},
|
||||
"20euros": {
|
||||
"branch": "master",
|
||||
"revision": "c8d5fadc9f042a92f14b753eff3ffc948322cf2d",
|
||||
"state": "ready",
|
||||
"url": "https://github.com/M5oul/20euros_ynh"
|
||||
},
|
||||
"243": {
|
||||
"branch": "master",
|
||||
"revision": "b9d58efeac78feb7f74e723c999ff25ab7ab8b52",
|
||||
"state": "ready",
|
||||
"url": "https://github.com/M5oul/243_ynh"
|
||||
},
|
||||
"adhocserver": {
|
||||
"branch": "master",
|
||||
"revision": "d1a728b9b99608bac69b55372cddf1aa3f4a5557",
|
||||
|
|
Loading…
Add table
Reference in a new issue