source: lliurex-store/trunk/fuentes/python3-lliurex-store.install/usr/share/lliurexstore/plugins/searchManager.py @ 3653

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

WIP on CLI

File size: 4.3 KB
Line 
1import locale
2import gi
3gi.require_version('AppStreamGlib', '1.0')
4from gi.repository import AppStreamGlib as appstream
5
6class searchmanager:
7        def __init__(self):
8                self.locale=locale.getlocale()[0]
9                self.dbg=0
10                self.store=''
11                self.pluginInfo={'search':'*','list':'*','list_sections':'*'}
12                self.precision=10
13                self.applist=[]
14                self.progress=0
15                self.result={}
16                self.result['data']={}
17                self.result['status']={}
18        #def __init__
19
20        def __call__(self):
21                return (self.applist)
22
23        def set_debug(self,dbg='1'):
24                self.dbg=int(dbg)
25                self._debug ("Debug enabled")
26        #def set__debug
27
28        def _debug(self,msg=''):
29                if self.dbg==1:
30                        print ('DEBUG Search: '+msg)
31        #def _debug
32
33        def register(self):
34                return(self.pluginInfo)
35
36        def execute_action(self,appstreamStore,action,tokens):
37                if not type(tokens) is str:
38                        tokens=''
39                if len(tokens.split(' '))>1 or action=='list':
40                        self._debug("Tokenizing search items")
41                        tokens=appstream.utils_search_tokenize(tokens)
42                else:
43                        tokens=[tokens]
44                self.store=appstreamStore
45                self.result['status']={'status':-1,'msg':''}
46                self.result['data']=[]
47                if action=='list':
48                        self._list_category(tokens)
49                if action=='list_sections':
50                        self._list_sections()
51                if action=='search':
52                        self._search_app(tokens)
53                self.progress=100
54                return(self.result)
55
56        def _set_status(self,status,msg=''):
57                self.result['status']={'status':status,'msg':msg}
58
59        def set_precision(self,precision):
60                self.precision=precision
61
62        def _search_app(self,tokens):
63                self._debug("Searching app "+str(tokens))
64                applist=[]
65                app=None
66                if len(tokens)==1:
67                        app=self._app_exists(tokens[0])
68
69                if app:
70                        applist.append(app)
71                        self._debug("App direct match found: "+app.get_id())
72                else:
73                        for app in self._get_apps_by_match(tokens):
74                                applist.append(app)
75                self.result['data']=applist
76                if len(applist):
77                        self._set_status(0)
78                else:
79                        self._set_status(1)
80                return(applist)
81
82        def _list_sections(self):
83                applist=[]
84                catDict={}
85                for app in self.store.get_apps():
86                        for cat in app.get_categories():
87                                if cat not in catDict.keys():
88                                        catDict[cat]=1
89                                else:
90                                        catDict[cat]=catDict[cat]+1
91                for section in catDict:
92                        applist.append({str(section):catDict[section]})
93                self.result['data']=applist
94                if len(applist):
95                        self._set_status(0)
96                else:
97                        self._set_status(1)
98                return(applist)
99
100        def _list_category(self,tokens=[]):
101                applist=[]
102                self._debug("tokens: "+str(tokens))
103                if len(tokens)>=1:
104                        self._debug("Searching category "+str(tokens))
105                        setCategories=set(tokens)
106                        apps_in_store=self.store.get_apps()
107                        count_apps=len(apps_in_store)
108                        self.progress=0
109                        inc=100/count_apps
110                        for app in apps_in_store:
111                                self.progress=self.progress+inc
112                                if 'setCategories' in locals():
113                                        try:
114                                                appCategories=[cat.lower() for cat in app.get_categories()]
115                                        except:
116                                                pass
117                                        setAppCategories=set(appCategories)
118                                        if setCategories.issubset(setAppCategories):
119                                                self._debug("Found "+app.get_id())
120                                                applist.append(app)
121                else:
122                        self._debug("Loading all apps in store")
123                        applist=self.store.get_apps()
124#                       for app in applist:
125#                               self._debug("Added "+app.get_id())
126                self.result['data']=applist
127                if len(applist):
128                        self._set_status(0)
129                else:
130                        self._set_status(1)
131                return(applist)
132
133        def _app_exists(self,appName):
134                self._debug("Trying direct match for "+appName)
135                app=None
136                #1.- Try exact match
137                app=self.store.get_app_by_id(appName)
138                if not app:
139                #2.- Try exact match with org.lliurex
140                        app=self.store.get_app_by_id("org.lliurex."+appName)
141                        if not app:
142                #2.- Try exact match with .desktop
143                                app=self.store.get_app_by_id(appName+".desktop")
144                return(app)
145
146        def _get_apps_by_match(self,tokens):
147                        #Add items witch match >= self.precision
148                        applist=[]
149                        apps_in_store=self.store.get_apps()
150                        if apps_in_store:
151                                auxDict={}
152                                count_apps=len(apps_in_store)
153                                self.progress=0
154                                inc=100.0/count_apps
155                                for app in apps_in_store:
156                                        self.progress=self.progress+inc
157                                        if app not in self.applist:
158                                                for token in tokens:
159                                                        score=app.search_matches(token)
160                                                        if score>=self.precision:
161                                                                if score in auxDict:
162                                                                        auxDict[score].append(app)
163                                                                else:
164                                                                        auxDict[score]=[app]
165                                for match in sorted(auxDict):
166                                        for app in auxDict[match]:
167                                                self._debug("Adding app "+app.get_id() + " with score: "+str(match))
168                                                applist.insert(0,app)
169                        return(applist)
Note: See TracBrowser for help on using the repository browser.