aboutsummaryrefslogtreecommitdiff
path: root/src/com/android/tv/SetupPassthroughActivity.java
blob: 8a263a264908ea9b7d496a44fec5cec3350a237a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/*
 * Copyright (C) 2015 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.android.tv;

import android.app.Activity;
import android.content.ActivityNotFoundException;
import android.content.Intent;
import android.media.tv.TvInputInfo;
import android.os.Bundle;
import android.util.Log;

import com.android.tv.common.SoftPreconditions;
import com.android.tv.common.TvCommonConstants;
import com.android.tv.data.epg.EpgFetcher;
import com.android.tv.experiments.Experiments;
import com.android.tv.util.SetupUtils;
import com.android.tv.util.TvInputManagerHelper;
import com.android.tv.util.Utils;

/**
 * An activity to launch a TV input setup activity.
 *
 * <p> After setup activity is finished, all channels will be browsable.
 */
public class SetupPassthroughActivity extends Activity {
    private static final String TAG = "SetupPassthroughAct";
    private static final boolean DEBUG = false;

    private static final int REQUEST_START_SETUP_ACTIVITY = 200;

    private TvInputInfo mTvInputInfo;
    private Intent mActivityAfterCompletion;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Intent intent = getIntent();
        SoftPreconditions.checkState(
                intent.getAction().equals(TvCommonConstants.INTENT_ACTION_INPUT_SETUP));
        ApplicationSingletons appSingletons = TvApplication.getSingletons(this);
        TvInputManagerHelper inputManager = appSingletons.getTvInputManagerHelper();
        String inputId = intent.getStringExtra(TvCommonConstants.EXTRA_INPUT_ID);
        mTvInputInfo = inputManager.getTvInputInfo(inputId);
        if (DEBUG) Log.d(TAG, "TvInputId " + inputId + " / TvInputInfo " + mTvInputInfo);
        if (mTvInputInfo == null) {
            Log.w(TAG, "There is no input with the ID " + inputId + ".");
            finish();
            return;
        }
        Intent setupIntent = intent.getExtras().getParcelable(TvCommonConstants.EXTRA_SETUP_INTENT);
        if (DEBUG) Log.d(TAG, "Setup activity launch intent: " + setupIntent);
        if (setupIntent == null) {
            Log.w(TAG, "The input (" + mTvInputInfo.getId() + ") doesn't have setup.");
            finish();
            return;
        }
        SetupUtils.grantEpgPermission(this, mTvInputInfo.getServiceInfo().packageName);
        mActivityAfterCompletion = intent.getParcelableExtra(
                TvCommonConstants.EXTRA_ACTIVITY_AFTER_COMPLETION);
        if (DEBUG) Log.d(TAG, "Activity after completion " + mActivityAfterCompletion);
        // If EXTRA_SETUP_INTENT is not removed, an infinite recursion happens during
        // setupIntent.putExtras(intent.getExtras()).
        Bundle extras = intent.getExtras();
        extras.remove(TvCommonConstants.EXTRA_SETUP_INTENT);
        setupIntent.putExtras(extras);
        try {
            startActivityForResult(setupIntent, REQUEST_START_SETUP_ACTIVITY);
        } catch (ActivityNotFoundException e) {
            Log.e(TAG, "Can't find activity: " + setupIntent.getComponent());
            finish();
            return;
        }
        if (Utils.isInternalTvInput(this, mTvInputInfo.getId()) && Experiments.CLOUD_EPG.get()) {
            EpgFetcher.getInstance(this).stop();
        }
    }

    @Override
    protected void onDestroy() {
        if (mTvInputInfo != null && Utils.isInternalTvInput(this, mTvInputInfo.getId())
                && Experiments.CLOUD_EPG.get()) {
            EpgFetcher.getInstance(this).start();
        }
        super.onDestroy();
    }

    @Override
    public void onActivityResult(int requestCode, final int resultCode, final Intent data) {
        boolean setupComplete = requestCode == REQUEST_START_SETUP_ACTIVITY
                && resultCode == Activity.RESULT_OK;
        if (!setupComplete) {
            setResult(resultCode, data);
            finish();
            return;
        }
        SetupUtils.getInstance(this).onTvInputSetupFinished(mTvInputInfo.getId(), new Runnable() {
            @Override
            public void run() {
                if (mActivityAfterCompletion != null) {
                    try {
                        startActivity(mActivityAfterCompletion);
                    } catch (ActivityNotFoundException e) {
                        Log.w(TAG, "Activity launch failed", e);
                    }
                }
                setResult(resultCode, data);
                finish();
            }
        });
    }
}