• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2014 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.email.activity.setup;
18 
19 import android.app.AlertDialog;
20 import android.app.Dialog;
21 import android.app.DialogFragment;
22 import android.content.Context;
23 import android.content.DialogInterface;
24 import android.os.Bundle;
25 
26 import com.android.email.R;
27 
28 /**
29  * The "security required" error dialog.  This is presented whenever an exchange account
30  * reports that it will require security policy control, and provide the user with the
31  * opportunity to accept or deny this.
32  *
33  * If the user clicks OK, calls onSecurityRequiredDialogResultOk(true) which reports back
34  * to the target as if the settings check was "ok".  If the user clicks "cancel", calls
35  * onSecurityRequiredDialogResultOk(false) which simply closes the checker (this is the
36  * same as any other failed check.)
37  */
38 
39 public class SecurityRequiredDialogFragment extends DialogFragment {
40     public final static String TAG = "SecurityRequiredDialog";
41 
42     // Bundle keys for arguments
43     private final static String ARGS_HOST_NAME = "SecurityRequiredDialog.HostName";
44 
45     public interface Callback {
46 
47         /**
48          * Callback for the result of this dialog fragment
49          * @param ok True for OK pressed, false for cancel
50          */
onSecurityRequiredDialogResult(boolean ok)51         void onSecurityRequiredDialogResult(boolean ok);
52     }
53 
54     // Public no-args constructor needed for fragment re-instantiation
SecurityRequiredDialogFragment()55     public SecurityRequiredDialogFragment() {}
56 
newInstance(String hostName)57     public static SecurityRequiredDialogFragment newInstance(String hostName) {
58         final SecurityRequiredDialogFragment fragment = new SecurityRequiredDialogFragment();
59         final Bundle arguments = new Bundle(1);
60         arguments.putString(ARGS_HOST_NAME, hostName);
61         fragment.setArguments(arguments);
62         return fragment;
63     }
64 
65     @Override
onCreateDialog(Bundle savedInstanceState)66     public Dialog onCreateDialog(Bundle savedInstanceState) {
67         final Context context = getActivity();
68         final Bundle arguments = getArguments();
69         final String hostName = arguments.getString(ARGS_HOST_NAME);
70 
71         setCancelable(true);
72 
73         return new AlertDialog.Builder(context)
74                 .setIconAttribute(android.R.attr.alertDialogIcon)
75                 .setTitle(context.getString(R.string.account_setup_security_required_title))
76                 .setMessage(context.getString(
77                         R.string.account_setup_security_policies_required_fmt, hostName))
78                 .setPositiveButton(
79                         context.getString(android.R.string.ok),
80                         new DialogInterface.OnClickListener() {
81                             @Override
82                             public void onClick(DialogInterface dialog, int which) {
83                                 dismiss();
84                                 final Callback callback = (Callback) getActivity();
85                                 callback.onSecurityRequiredDialogResult(true);
86                             }
87                         })
88                 .setNegativeButton(
89                         context.getString(android.R.string.cancel),
90                         new DialogInterface.OnClickListener() {
91                             @Override
92                             public void onClick(DialogInterface dialog, int which) {
93                                 dialog.cancel();
94                             }
95                         })
96                 .create();
97     }
98 
99     @Override
100     public void onCancel(DialogInterface dialog) {
101         super.onCancel(dialog);
102         final Callback callback = (Callback) getActivity();
103         if (callback != null) {
104             callback.onSecurityRequiredDialogResult(false);
105         }
106     }
107 }
108