alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 1 | package com.savoirfairelinux.sflphone.loaders; |
| 2 | |
| 3 | import java.util.ArrayList; |
| 4 | import java.util.HashMap; |
| 5 | |
| 6 | import android.content.AsyncTaskLoader; |
| 7 | import android.content.Context; |
| 8 | import android.os.RemoteException; |
| 9 | import android.util.Log; |
| 10 | |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 11 | import com.savoirfairelinux.sflphone.model.Account; |
| 12 | import com.savoirfairelinux.sflphone.service.ISipService; |
| 13 | |
| 14 | public class AccountsLoader extends AsyncTaskLoader<ArrayList<Account>> { |
| 15 | |
| 16 | private static final String TAG = AccountsLoader.class.getSimpleName(); |
| 17 | |
| 18 | ISipService service; |
| 19 | |
| 20 | public AccountsLoader(Context context, ISipService ref) { |
| 21 | super(context); |
| 22 | service = ref; |
| 23 | } |
| 24 | |
| 25 | @Override |
| 26 | public ArrayList<Account> loadInBackground() { |
alision | 5cfc35d | 2013-07-11 15:11:39 -0400 | [diff] [blame] | 27 | |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 28 | ArrayList<Account> result = new ArrayList<Account>(); |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 29 | |
| 30 | ArrayList<String> accountIDs; |
| 31 | HashMap<String, String> details; |
| 32 | try { |
| 33 | accountIDs = (ArrayList<String>) service.getAccountList(); |
| 34 | for (String id : accountIDs) { |
alision | 5cfc35d | 2013-07-11 15:11:39 -0400 | [diff] [blame] | 35 | |
| 36 | if (id.contentEquals("IP2IP")) { |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 37 | continue; |
| 38 | } |
| 39 | details = (HashMap<String, String>) service.getAccountDetails(id); |
alision | 5cfc35d | 2013-07-11 15:11:39 -0400 | [diff] [blame] | 40 | result.add(new Account(id, details)); |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 41 | |
| 42 | } |
| 43 | } catch (RemoteException e) { |
| 44 | Log.e(TAG, e.toString()); |
alision | 5cfc35d | 2013-07-11 15:11:39 -0400 | [diff] [blame] | 45 | } catch (NullPointerException e1) { |
alision | df1dac9 | 2013-06-27 17:35:53 -0400 | [diff] [blame] | 46 | Log.e(TAG, e1.toString()); |
alision | 11e8e16 | 2013-05-28 10:33:14 -0400 | [diff] [blame] | 47 | } |
| 48 | |
| 49 | return result; |
| 50 | } |
| 51 | |
| 52 | } |