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

Last change on this file since 4114 was 4114, checked in by hectorgh, 2 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                for action in results.keys():
30                        if action in actions and not actionList[action]:
31                                if status['status']==0:
32                                        print (u"Results for "+action) 
33                                        for data in results[action]:
34                                                if action=='info':
35                                                        try:
36                                                                print(color.DARKCYAN+u'Package'+': '+color.END + data['package'])
37                                                                print(u'Name'+': '+data['name'])
38                                                                print(u'ID'+': '+data['id'])
39                                                                print(u'Version'+': '+data['version'])
40                                                                print(u'Size'+': '+data['size'])
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                                                                print(data['package']+" "+ u"installed"+" "+color.BOLD+ u"succesfully"+color.END)
78                                                elif action=='remove':
79                                                                print(data['package']+" "+ u"removed"+" "+color.BOLD+ u"succesfully"+color.END)
80                                                else:
81                                                        print(data)
82                                else:
83                                        msg=u"Package"
84                                        failed=parms[action]
85                                        if (action=='install' or action=='remove'):
86                                                        msg=u"Unable to"+' '+action
87                                        if action=='list':
88                                                        msg=u"Category"
89                                                        failed=', '.join(failed)
90
91                                        print (color.RED+u"Error"+": "+color.END+msg+' '+failed+' '+status['msg'])
92                                printed=True
93                return(printed)
94        #def print_results
95
96        CURSOR_UP='\033[F'
97        ERASE_LINE='\033[K'
98        actions=[]
99        parms={}
100        args=process_Args(sys.argv)
101        store=storeManager.StoreManager(args.debug)
102
103        '''     if args.debug:
104                        actions.append('debug')
105                        store.set_debug(args.debug)
106                        parms['debug']=args.debug'''
107        if args.info:
108                actions.append('info')
109                parms['info']=args.info
110        if args.search:
111                actions.append('search')
112                parms['search']=args.search
113        if args.install:
114                actions.append('install')
115                parms['install']=args.install
116        if args.remove:
117                actions.append('remove')
118                parms['remove']=args.remove
119        if args.list:
120                actions.append('list')
121                parms['list']=args.list
122                print(args.list,type(args.list))
123        if args.list_sections:
124                actions.append('list_sections')
125                parms['list_sections']=args.list_sections
126       
127        actionList={'search':False,'info':False,'pkgInfo':False,'install':False,'remove':False,'list':False,'list-sections':False}
128        start_time=time.time()
129        for action in actions:
130#               print(u"Launching: "+action)
131                store.execute_action(action,parms[action])
132                actionList[action]=False
133               
134#       print ("All actions launched: " +str(actions))
135        while store.is_action_running():
136                progressDic=store.get_progress()
137                progressArray=[]
138                for progress in progressDic:
139                        if progress!='load':
140                                progressArray.append(progress+': '+str(int(progressDic[progress]))+'%')
141                print(','.join(progressArray),end="\r")
142                time.sleep(0.1)
143                for key in actionList:
144                        progressDic=store.get_progress(key)
145                        if key in progressDic:
146                                if progressDic[key]==100 and not actionList[key]:
147                                        progressDic=store.get_progress(key)
148                                        progressArray=[]
149                                        for progress in progressDic:
150                                                if progress!='load':
151                                                        progressArray.append(progress+': '+str(progressDic[progress])+'%')
152                                        print(','.join(progressArray))
153                                        print (CURSOR_UP + ERASE_LINE)
154                                        actionList[key]=print_results(key)
155        print_results()
156
157def process_Args(args):
158        parser=argparse.ArgumentParser(description=(u'Lliurex Software Center'))
159        parser.add_argument('--list',metavar="Category",action='append',nargs='?',help=(u"List all packages, optionally list packages from a given category"))
160        parser.add_argument('--list-sections',action='store_true',help=(u"List all sections from the store"))
161        parser.add_argument('--search',metavar='Name',nargs='?',help=(u"Search a package"))
162        parser.add_argument('--info',metavar='Name',nargs='?',help=(u"Show all info from a package"))
163        parser.add_argument('--install',metavar='Package',help=(u"Install a package"))
164        parser.add_argument('--remove',metavar='Package',help=(u"Remove a package"))
165        parser.add_argument('--debug',action='store_true',help=(u"Prints debug information"))
166
167        args=parser.parse_args()
168        return args
169
170main()
Note: See TracBrowser for help on using the repository browser.