3 # mEveMon - A character monitor for EVE Online
4 # Copyright (c) 2010 Ryan and Danny Campbell, and the mEveMon Team
6 # mEveMon is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation; either version 3 of the License, or
9 # (at your option) any later version.
11 # mEveMon is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
23 from eveapi import eveapi
27 # we will store our preferences in gconf
30 #ugly hack to check maemo version. any better way?
31 if hasattr(hildon, "StackableWindow"):
32 from ui.fremantle import ui
35 from ui.diablo import ui
40 self.program = hildon.Program()
41 self.program.__init__()
42 self.gconf = gnome.gconf.client_get_default()
44 self.ui = ui.mEveMonUI(self)
49 def quit(self, *args):
52 def get_api_key(self):
53 return self.gconf.get_string("/apps/maemo/mevemon/eve_api_key") or ''
56 return self.gconf.get_string("/apps/maemo/mevemon/eve_uid") or ''
58 def set_api_key(self, key):
59 self.gconf.set_string("/apps/maemo/mevemon/eve_api_key", key)
61 def set_uid(self, uid):
62 self.gconf.set_string("/apps/maemo/mevemon/eve_uid", uid)
67 set self.auth to None if there was a problem. somehow later on we'll
68 have to pass the error to the UI, but for now I just want the program
69 to not be broken. --danny
72 api_key = self.get_api_key()
73 self.cached_api = eveapi.EVEAPIConnection( cacheHandler = \
74 apicache.cache_handler( debug = False ) )
76 self.auth = self.cached_api.auth( userID = uid, apiKey = api_key )
77 except eveapi.Error, e:
78 # we need to deal with this, so raise --danny
87 def get_char_sheet(self, charID):
88 if not self.auth: return None
90 sheet = self.auth.character(charID).CharacterSheet()
91 except eveapi.Error, e:
92 # we should really have a logger that logs this error somewhere
97 def char_id2name(self, charID):
98 # the api can take a comma-seperated list of ids, but we'll just take
101 chars = self.cached_api.eve.CharacterName(ids=charID).characters
102 name = chars[0].characterName
103 except eveapi.Error, e:
108 def char_name2id(self, name):
109 # the api can take a comma-seperated list of names, but we'll just take
110 # a single name for now
112 chars = self.cached_api.eve.CharacterID(names=name).characters
113 char_id = chars[0].characterID
114 except eveapi.Error, e:
120 def get_characters( self ):
122 returns a list containing a single character with an error message for a
123 name, if there's a problem. FIXME --danny
127 err_img = "/opt/mevemon/imgs/error.jpg"
129 err_img = "/usr/share/mevemon/imgs/error.jpg"
131 placeholder_chars = [("Please check your API settings.", err_img)]
132 if not self.auth: return placeholder_chars
134 api_char_list = self.auth.account.Characters()
135 # append each char we get to the list we'll return to the
137 for character in api_char_list.characters:
138 ui_char_list.append( ( character.name, fetchimg.portrait_filename( character.characterID, 64 ) ) )
139 except eveapi.Error, e:
140 # again, we need to handle this... --danny
145 def get_portrait(self, char_name, size):
147 returns the relative path of the retrieved portrait
149 charID = self.char_name2id(char_name)
150 return fetchimg.portrait_filename(charID, size)
152 def get_skill_tree(self):
154 tree = self.cached_api.eve.SkillTree()
155 except eveapi.Error, e:
161 def get_skill_in_training(self, charID):
163 skill = self.auth.character(charID).SkillInTraining()
171 if __name__ == "__main__":