You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

54 lines
1.6 KiB

/*
* Copyright (c) 2017 - present Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
package codetoanalyze.java.quandary;
import android.app.Activity;
import android.content.ClipboardManager;
import android.text.Html;
import android.text.Spanned;
import android.widget.EditText;
import java.io.IOException;
import java.lang.Runtime;
import com.facebook.infer.builtins.InferTaint;
public class UserControlledStrings {
ClipboardManager clipboard;
void readClipboardSourcesBad() {
InferTaint.inferSensitiveSink(clipboard.getText());
InferTaint.inferSensitiveSink(clipboard.getPrimaryClip());
InferTaint.inferSensitiveSink(clipboard.getPrimaryClip().getItemAt(5));
InferTaint.inferSensitiveSink(clipboard.getPrimaryClip().getItemAt(5).getText());
InferTaint.inferSensitiveSink(clipboard.getPrimaryClip().toString());
// 5 reports
}
Spanned clipboardToHtmlBad() {
return Html.fromHtml(clipboard.getText().toString());
}
EditText mEditText;
Spanned editTextToHtmlBad() {
return Html.fromHtml(mEditText.getText().toString());
}
void clipboardToShellDirectBad() throws IOException {
Runtime.getRuntime().exec(clipboard.getText().toString());
}
void clipboardToShellArrayBad() throws IOException {
String[] cmds = new String[] { "ls", clipboard.getText().toString() };
Runtime.getRuntime().exec(cmds);
}
}