source: lliurex-store/trunk/fuentes/lliurex-store-cli/usr/share/lliurex-store/lliurex-store-cli.py @ 3844

Last change on this file since 3844 was 3844, checked in by Juanma, 3 years ago

wip

  • Property svn:executable set to *
File size: 5.7 KB
Line 
1#!/usr/bin/python3
2import sys
3import argparse
4#sys.path.append('/usr/share/lliurex-store')
5#sys.path.append('/home/lliurex/lliurex-store/trunk/fuentes/lliurex-appstore.install/usr/share/lliurex-store')
6import lliurexstore.storeManager as storeManager
7import time
8from bs4 import BeautifulSoup
9
10class color:
11   PURPLE = '\033[95m'
12   CYAN = '\033[96m'
13   DARKCYAN = '\033[36m'
14   BLUE = '\033[94m'
15   GREEN = '\033[92m'
16   YELLOW = '\033[93m'
17   RED = '\033[91m'
18   BOLD = '\033[1m'
19   UNDERLINE = '\033[4m'
20   END = '\033[0m'
21
22def main():
23        def print_results(action=None):
24                printed=False
25                results=store.get_result(action)
26                status=store.get_status(action)
27                processed=[]
28                print ("")
29                data=store.get_result(action)
30                for action in results.keys():
31                        if action in actions and not actionList[action]:
32                                print (u"Results for "+action) 
33                                if status['status']==0:
34                                        for data in results[action]:
35                                                if action=='info':
36                                                        try:
37                                                                print(color.DARKCYAN+u'Package'+': '+color.END + data['package'])
38                                                                print(u'Name'+': '+data['name'])
39                                                                print(u'ID'+': '+data['id'])
40                                                                print(u'Version'+': '+data['version'])
41                                                                print(u'License'+': '+data['license'])
42                                                                print(u'Categories'+': '+','.join(data['categories']))
43                                                                print(u'Status'+': '+data['state'])
44                                                                print(u'Summary'+': '+data['summary'])
45                                                                desc=(BeautifulSoup(data['description'],"lxml")).get_text()
46#                                                               print(u'Description'+': '+data['description'])
47                                                                print(u'Description'+': '+desc)
48                                                                pkgString=[]
49                                                                for dependency in data['depends']:
50                                                                                pkgName=dependency.split(';')[0]
51                                                                                pkgString.append(pkgName)
52                                                                print(u'Depends'+': '+', '.join(pkgString))
53                                                                print("")
54                                                        except Exception as e:
55                                                                print(e)
56                                                                pass
57                                                elif action=='search':
58                                                        #Only print name and summary
59                                                        if data['package'] not in data['id'] or data['package'] in processed:
60                                                                print(color.DARKCYAN+data['package']+color.END+" ("+data['id']+"): "+data['summary'])
61                                                        else:
62                                                                print(color.DARKCYAN+data['package']+color.END+": "+data['summary'])
63                                                                processed.append(data['package'])
64
65                                                elif action=='list':
66                                                        #Print package, summary and status
67                                                        try:
68                                                                if data['package']:
69                                                                        package=data['package']
70                                                                else:
71                                                                        package=data['name']
72                                                                print(color.DARKCYAN+package+color.END+": "+data['summary']+' ('+','.join(data['categories'])+')'+' ('+data['state']+')')
73                                                        except Exception as e:
74                                                                print('Error listing :'+str(e))
75                                                                pass
76                                                elif action=='install':
77                                                                listData=data.split(';')
78                                                                print(listData[0]+" "+ u"installed"+" "+color.BOLD+ u"succesfully"+color.END)
79                                                elif action=='remove':
80                                                                listData=data.split(';')
81                                                                print(listData[0]+" "+ u"removed"+" "+color.BOLD+ u"succesfully"+color.END)
82                                                else:
83                                                        print(data)
84                                else:
85                                        msg=u"Package"
86                                        failed=parms[action]
87                                        if (action=='install' or action=='remove'):
88                                                        msg=u"Unable to"+' '+action
89                                        if action=='list':
90                                                        msg=u"Category"
91                                                        failed=', '.join(failed)
92
93                                        print (color.RED+u"Error"+": "+color.END+msg+' '+failed+' '+status['msg'])
94                                printed=True
95                return(printed)
96        #def print_results
97
98        CURSOR_UP='\033[F'
99        ERASE_LINE='\033[K'
100        actions=[]
101        parms={}
102        args=process_Args(sys.argv)
103        store=storeManager.StoreManager(args.debug)
104
105        '''     if args.debug:
106                        actions.append('debug')
107                        store.set_debug(args.debug)
108                        parms['debug']=args.debug'''
109        if args.info:
110                actions.append('info')
111                parms['info']=args.info+",True"
112                print(str(type(parms['info'])))
113        if args.search:
114                actions.append('search')
115                parms['search']=args.search
116        if args.install:
117                actions.append('install')
118                parms['install']=args.install
119        if args.remove:
120                actions.append('remove')
121                parms['remove']=args.remove
122        if args.list:
123                actions.append('list')
124                parms['list']=args.list
125        if args.list_sections:
126                actions.append('list_sections')
127                parms['list_sections']=args.list_sections
128       
129        actionList={'search':False,'info':False,'pkgInfo':False,'install':False,'remove':False,'list':False,'list-sections':False}
130        start_time=time.time()
131        for action in actions:
132                print(u"Launching: "+action)
133                store.execute_action(action,parms[action])
134                actionList[action]=False
135               
136#       print ("All actions launched: " +str(actions))
137        while store.is_action_running():
138                progressDic=store.get_progress()
139                progressArray=[]
140                for progress in progressDic:
141                        if progress!='load':
142                                progressArray.append(progress+': '+str(int(progressDic[progress]))+'%')
143                print(','.join(progressArray),end="\r")
144                time.sleep(0.1)
145                for key in actionList:
146                        progressDic=store.get_progress(key)
147                        if key in progressDic:
148                                if progressDic[key]==100 and not actionList[key]:
149                                        progressDic=store.get_progress(key)
150                                        progressArray=[]
151                                        for progress in progressDic:
152                                                if progress!='load':
153                                                        progressArray.append(progress+': '+str(progressDic[progress])+'%')
154                                        print(','.join(progressArray))
155                                        print (CURSOR_UP + ERASE_LINE)
156                                        actionList[key]=print_results(key)
157        print_results()
158
159def process_Args(args):
160        parser=argparse.ArgumentParser(description=(u'Lliurex Software Center'))
161        parser.add_argument('--list',metavar="Category",action='append',nargs='?',help=(u"List all packages, optionally list packages from a given category"))
162        parser.add_argument('--list-sections',action='store_true',help=(u"List all sections from the store"))
163        parser.add_argument('--search',metavar='Name',nargs='?',help=(u"Search a package"))
164        parser.add_argument('--info',metavar='Name',nargs='?',help=(u"Show all info from a package"))
165        parser.add_argument('--install',metavar='Package',help=(u"Install a package"))
166        parser.add_argument('--remove',metavar='Package',help=(u"Remove a package"))
167        parser.add_argument('--debug',action='store_true',help=(u"Prints debug information"))
168
169        args=parser.parse_args()
170        return args
171
172main()
Note: See TracBrowser for help on using the repository browser.