Android DownloadManager nie działa po przekierowaniu

Pracuję nad aplikacją, która pobierze plik zip przechowywany w Amazon S3 za pośrednictwem serwera Rails Heroku po uwierzytelnieniu przez oAuth 2. Oto przepływ:

Żądanie uwierzytelnienia na serwerze działającym na Heroku przez oAuth2.Odbierz token dostępu oAuth2.Żądanie pobrania pliku zip z serwera (przekazanie tokena oAuth jako nośnika).Serwer autoryzuje żądanie i przekierowuje do adresu URL Amazon S3 zawierającego podpis, który wygasa (aby uniemożliwić każdemu pobieranie treści bez uwierzytelnienia).

W tym momencie chcę, aby DownloadManager po prostu śledził przekierowanie i pobierał plik zip z S3, jednak to się nie udaje. Czy jest jakiś sposób, żeby to obejść? Czy jest to tylko ograniczenie DownloadManager?

Jestem nowicjuszem w Androidzie i wciąż nie w pełni sprawdzam najlepsze metody debugowania, więc nie mam zbyt wielu wyników, aby ci to pokazać. Wydaje się jednak, żeDownloadManager.COLUMN_STATUS == DownloadManager.STATUS_FAILED iDownloadManager.COLUMN_REASON zwraca „placeholder”!

EDIT - Oto kod, którego używam. Edytowane, aby ukryć klienta itp ...

    @Override
public void onListItemClick(ListView l, View v, int position, long id) {
    Log.i("ChapterListActivity", "Item clicked: " + id);


    final DownloadManager downloadManager = (DownloadManager)getSystemService(Context.DOWNLOAD_SERVICE);

    Uri uri = Uri.parse("http://myapphere.herokuapp.com/api/v1/volumes/2.zip");

    DownloadManager.Request request = new Request(uri);

    String accessToken = getSharedPreferences("keyhere", MODE_PRIVATE).getString("access_token", null); 

    Log.i("SLEChapterListActivity", "Getting file with access token... " + accessToken);

    request.addRequestHeader("Authorization", "Bearer " + accessToken);
    long reference = downloadManager.enqueue(request);

    IntentFilter filter = new IntentFilter(DownloadManager.ACTION_DOWNLOAD_COMPLETE);

    BroadcastReceiver receiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            long downloadReference = intent.getLongExtra(DownloadManager.EXTRA_DOWNLOAD_ID, -1);
            Log.i("ChapterListActivity", "Download completed");


            Query query = new Query();
            query.setFilterById(downloadReference);

            Cursor cur = downloadManager.query(query);

            if (cur.moveToFirst()) {
            int columnIndex = cur.getColumnIndex(DownloadManager.COLUMN_STATUS);
            if (DownloadManager.STATUS_SUCCESSFUL == cur.getInt(columnIndex)) {
                String uriString = cur.getString(cur.getColumnIndex(DownloadManager.COLUMN_LOCAL_URI));

                File mFile = new File(Uri.parse(uriString).getPath());

            } else if (DownloadManager.STATUS_FAILED == cur.getInt(columnIndex)){
                String statusResult = cur.getString(cur.getColumnIndex(DownloadManager.COLUMN_REASON));
                Toast.makeText(context, "FAILED " + statusResult, Toast.LENGTH_SHORT).show();
            } else if (DownloadManager.ERROR_TOO_MANY_REDIRECTS == cur.getInt(columnIndex)){
                String statusResult = cur.getString(cur.getColumnIndex(DownloadManager.COLUMN_REASON));
                Toast.makeText(context, "TOO MANY REDIRS " + statusResult, Toast.LENGTH_SHORT).show();
            }
        }
        }
    };

    registerReceiver(receiver, filter);

}   

questionAnswers(2)

yourAnswerToTheQuestion