{"message": {"transcript": [{"chunks": [{"end": 6.32, "start": 0.0, "text": "Good"}, {"end": 6.96, "start": 6.32, "text": "afternoon"}, {"end": 7.4, "start": 6.96, "text": "everybody."}, {"end": 7.96, "start": 7.4, "text": "My"}, {"end": 8.4, "start": 7.96, "text": "name"}, {"end": 8.76, "start": 8.4, "text": "is"}, {"end": 8.88, "start": 8.76, "text": "Simon"}, {"end": 9.52, "start": 8.88, "text": "Alonso"}, {"end": 10.04, "start": 9.52, "text": "and"}, {"end": 10.04, "start": 10.04, "text": "I'm"}, {"end": 10.08, "start": 10.04, "text": "a"}, {"end": 10.48, "start": 10.08, "text": "PhD"}, {"end": 10.88, "start": 10.48, "text": "student"}, {"end": 11.12, "start": 10.88, "text": "from"}, {"end": 11.36, "start": 11.12, "text": "the"}, {"end": 11.72, "start": 11.36, "text": "University"}, {"end": 11.8, "start": 11.72, "text": "of"}, {"end": 12.28, "start": 11.8, "text": "Genova"}, {"end": 12.8, "start": 12.28, "text": "and"}, {"end": 12.96, "start": 12.8, "text": "I"}, {"end": 13.28, "start": 12.96, "text": "will"}, {"end": 13.68, "start": 13.28, "text": "present"}, {"end": 14.16, "start": 13.68, "text": "Fishing"}, {"end": 14.56, "start": 14.16, "text": "Attacks"}, {"end": 14.8, "start": 14.56, "text": "on"}, {"end": 15.32, "start": 14.8, "text": "Modern"}, {"end": 15.68, "start": 15.32, "text": "Android"}, {"end": 16.04, "start": 15.68, "text": "that"}, {"end": 16.16, "start": 16.04, "text": "is"}, {"end": 16.56, "start": 16.16, "text": "the"}, {"end": 17.12, "start": 16.56, "text": "result"}, {"end": 17.36, "start": 17.12, "text": "of"}, {"end": 17.48, "start": 17.36, "text": "a"}, {"end": 17.84, "start": 17.48, "text": "joint"}, {"end": 18.08, "start": 17.84, "text": "work"}, {"end": 18.32, "start": 18.08, "text": "with"}, {"end": 18.4, "start": 18.32, "text": "the"}, {"end": 19.04, "start": 18.4, "text": "University"}, {"end": 19.08, "start": 19.04, "text": "of"}, {"end": 19.44, "start": 19.08, "text": "Genova"}, {"end": 19.8, "start": 19.44, "text": "and"}, {"end": 20.6, "start": 19.8, "text": "Eurecom."}, {"end": 20.88, "start": 20.6, "text": "And"}, {"end": 21.28, "start": 20.88, "text": "I"}, {"end": 21.76, "start": 21.28, "text": "would"}, {"end": 22.16, "start": 21.76, "text": "like"}, {"end": 22.2, "start": 22.16, "text": "to"}, {"end": 22.52, "start": 22.2, "text": "thank"}, {"end": 22.72, "start": 22.52, "text": "my"}, {"end": 23.44, "start": 22.72, "text": "co-authors"}, {"end": 23.76, "start": 23.44, "text": "for"}, {"end": 24.08, "start": 23.76, "text": "this"}, {"end": 25.48, "start": 24.08, "text": "opportunity."}, {"end": 26.04, "start": 25.48, "text": "So,"}, {"end": 27.88, "start": 26.04, "text": "obviously"}, {"end": 28.16, "start": 27.88, "text": "this"}, {"end": 28.68, "start": 28.16, "text": "work"}, {"end": 29.44, "start": 28.68, "text": "is"}, {"end": 29.96, "start": 29.44, "text": "about"}], "text": " Good afternoon everybody. My name is Simon Alonso and I'm a PhD student from the University of Genova and I will present Fishing Attacks on Modern Android that is the result of a joint work with the University of Genova and Eurecom. And I would like to thank my co-authors for this opportunity. So, obviously this work is about"}, {"chunks": [{"end": 30.36, "start": 30.0, "text": "phishing"}, {"end": 30.8, "start": 30.36, "text": "attack"}, {"end": 31.64, "start": 30.8, "text": "on"}, {"end": 32.16, "start": 31.64, "text": "Android"}, {"end": 33.08, "start": 32.16, "text": "operating"}, {"end": 33.36, "start": 33.08, "text": "system."}, {"end": 33.68, "start": 33.36, "text": "And"}, {"end": 33.96, "start": 33.68, "text": "please"}, {"end": 34.2, "start": 33.96, "text": "keep"}, {"end": 34.28, "start": 34.2, "text": "it"}, {"end": 34.480000000000004, "start": 34.28, "text": "in"}, {"end": 34.96, "start": 34.480000000000004, "text": "mind"}, {"end": 35.16, "start": 34.96, "text": "that"}, {"end": 35.519999999999996, "start": 35.16, "text": "our"}, {"end": 35.92, "start": 35.519999999999996, "text": "final"}, {"end": 36.24, "start": 35.92, "text": "goal"}, {"end": 36.44, "start": 36.24, "text": "is"}, {"end": 36.519999999999996, "start": 36.44, "text": "to"}, {"end": 36.96, "start": 36.519999999999996, "text": "craft"}, {"end": 37.2, "start": 36.96, "text": "a"}, {"end": 37.64, "start": 37.2, "text": "phishing"}, {"end": 38.88, "start": 37.64, "text": "attack."}, {"end": 39.2, "start": 38.88, "text": "So,"}, {"end": 39.28, "start": 39.2, "text": "um,"}, {"end": 39.84, "start": 39.28, "text": "we,"}, {"end": 40.04, "start": 39.84, "text": "uh,"}, {"end": 40.12, "start": 40.04, "text": "I"}, {"end": 40.72, "start": 40.12, "text": "mean"}, {"end": 41.64, "start": 40.72, "text": "with"}, {"end": 42.28, "start": 41.64, "text": "modern,"}, {"end": 42.6, "start": 42.28, "text": "the"}, {"end": 43.04, "start": 42.6, "text": "rest"}, {"end": 43.56, "start": 43.04, "text": "and"}, {"end": 44.28, "start": 43.56, "text": "features"}, {"end": 44.6, "start": 44.28, "text": "that"}, {"end": 44.96, "start": 44.6, "text": "was"}, {"end": 45.519999999999996, "start": 44.96, "text": "introduced"}, {"end": 45.72, "start": 45.519999999999996, "text": "in"}, {"end": 46.120000000000005, "start": 45.72, "text": "Android"}, {"end": 46.239999999999995, "start": 46.120000000000005, "text": "in"}, {"end": 46.519999999999996, "start": 46.239999999999995, "text": "the"}, {"end": 47.08, "start": 46.519999999999996, "text": "name"}, {"end": 47.08, "start": 47.08, "text": "of"}, {"end": 47.879999999999995, "start": 47.08, "text": "convenience,"}, {"end": 48.04, "start": 47.879999999999995, "text": "and"}, {"end": 48.480000000000004, "start": 48.04, "text": "I"}, {"end": 48.879999999999995, "start": 48.480000000000004, "text": "will"}, {"end": 49.28, "start": 48.879999999999995, "text": "show"}, {"end": 49.44, "start": 49.28, "text": "how"}, {"end": 49.68, "start": 49.44, "text": "we"}, {"end": 50.04, "start": 49.68, "text": "will"}, {"end": 50.480000000000004, "start": 50.04, "text": "abuse"}, {"end": 50.96, "start": 50.480000000000004, "text": "them"}, {"end": 51.2, "start": 50.96, "text": "to"}, {"end": 51.480000000000004, "start": 51.2, "text": "make"}, {"end": 52.08, "start": 51.480000000000004, "text": "such"}, {"end": 52.480000000000004, "start": 52.08, "text": "phishing"}, {"end": 52.72, "start": 52.480000000000004, "text": "attack"}, {"end": 53.04, "start": 52.72, "text": "more"}, {"end": 54.56, "start": 53.04, "text": "practical."}, {"end": 54.8, "start": 54.56, "text": "So,"}, {"end": 54.84, "start": 54.8, "text": "uh,"}, {"end": 55.4, "start": 54.84, "text": "the"}, {"end": 56.239999999999995, "start": 55.4, "text": "recent"}, {"end": 56.8, "start": 56.239999999999995, "text": "features"}, {"end": 57.2, "start": 56.8, "text": "are"}, {"end": 57.32, "start": 57.2, "text": "the"}, {"end": 57.92, "start": 57.32, "text": "credential"}, {"end": 58.239999999999995, "start": 57.92, "text": "autofill."}, {"end": 58.44, "start": 58.239999999999995, "text": "It"}, {"end": 59.239999999999995, "start": 58.44, "text": "is,"}, {"end": 59.96, "start": 59.239999999999995, "text": "uh,"}], "text": " phishing attack on Android operating system. And please keep it in mind that our final goal is to craft a phishing attack. So, um, we, uh, I mean with modern, the rest and features that was introduced in Android in the name of convenience, and I will show how we will abuse them to make such phishing attack more practical. So, uh, the recent features are the credential autofill. It is, uh,"}, {"chunks": [{"end": 60.36, "start": 60.0, "text": "A"}, {"end": 61.0, "start": 60.36, "text": "useful"}, {"end": 61.52, "start": 61.0, "text": "feature"}, {"end": 61.8, "start": 61.52, "text": "for"}, {"end": 62.44, "start": 61.8, "text": "password"}, {"end": 62.96, "start": 62.44, "text": "manager"}, {"end": 63.72, "start": 62.96, "text": "and"}, {"end": 64.08, "start": 63.72, "text": "as"}, {"end": 64.56, "start": 64.08, "text": "you"}, {"end": 65.16, "start": 64.56, "text": "know,"}, {"end": 65.44, "start": 65.16, "text": "the"}, {"end": 65.8, "start": 65.44, "text": "password"}, {"end": 66.36, "start": 65.8, "text": "manager"}, {"end": 66.68, "start": 66.36, "text": "were"}, {"end": 67.12, "start": 66.68, "text": "born"}, {"end": 67.44, "start": 67.12, "text": "for"}, {"end": 67.68, "start": 67.44, "text": "the"}, {"end": 68.08, "start": 67.68, "text": "web"}, {"end": 68.52, "start": 68.08, "text": "world"}, {"end": 69.03999999999999, "start": 68.52, "text": "and"}, {"end": 69.32, "start": 69.03999999999999, "text": "now"}, {"end": 69.56, "start": 69.32, "text": "they"}, {"end": 69.6, "start": 69.56, "text": "are"}, {"end": 69.92, "start": 69.6, "text": "trying"}, {"end": 70.44, "start": 69.92, "text": "to"}, {"end": 70.56, "start": 70.44, "text": "move"}, {"end": 70.76, "start": 70.56, "text": "in"}, {"end": 71.03999999999999, "start": 70.76, "text": "the"}, {"end": 71.64, "start": 71.03999999999999, "text": "mobile"}, {"end": 72.6, "start": 71.64, "text": "world."}, {"end": 72.88, "start": 72.6, "text": "And"}, {"end": 72.96000000000001, "start": 72.88, "text": "the"}, {"end": 73.32, "start": 72.96000000000001, "text": "other"}, {"end": 73.72, "start": 73.32, "text": "feature"}, {"end": 74.24, "start": 73.72, "text": "is"}, {"end": 74.72, "start": 74.24, "text": "the"}, {"end": 75.2, "start": 74.72, "text": "instant"}, {"end": 76.08, "start": 75.2, "text": "apps"}, {"end": 76.36, "start": 76.08, "text": "that"}, {"end": 76.64, "start": 76.36, "text": "allow"}, {"end": 76.68, "start": 76.64, "text": "the"}, {"end": 77.44, "start": 76.68, "text": "users"}, {"end": 77.64, "start": 77.44, "text": "to"}, {"end": 78.28, "start": 77.64, "text": "try"}, {"end": 78.72, "start": 78.28, "text": "Android"}, {"end": 79.44, "start": 78.72, "text": "application"}, {"end": 79.96000000000001, "start": 79.44, "text": "without"}, {"end": 80.48, "start": 79.96000000000001, "text": "installing"}, {"end": 80.8, "start": 80.48, "text": "them"}, {"end": 81.08, "start": 80.8, "text": "on"}, {"end": 81.2, "start": 81.08, "text": "their"}, {"end": 81.52, "start": 81.2, "text": "phone."}, {"end": 81.76, "start": 81.52, "text": "So"}, {"end": 82.03999999999999, "start": 81.76, "text": "as"}, {"end": 82.4, "start": 82.03999999999999, "text": "you"}, {"end": 83.56, "start": 82.4, "text": "can"}, {"end": 83.6, "start": 83.56, "text": "see"}, {"end": 83.72, "start": 83.6, "text": "in"}, {"end": 84.03999999999999, "start": 83.72, "text": "the"}, {"end": 84.8, "start": 84.03999999999999, "text": "image,"}, {"end": 85.52, "start": 84.8, "text": "here"}, {"end": 85.92, "start": 85.52, "text": "we"}, {"end": 86.28, "start": 85.92, "text": "have"}, {"end": 86.68, "start": 86.28, "text": "the"}, {"end": 87.16, "start": 86.68, "text": "Facebook"}, {"end": 87.64, "start": 87.16, "text": "Android"}, {"end": 87.96000000000001, "start": 87.64, "text": "app"}, {"end": 88.52, "start": 87.96000000000001, "text": "and"}, {"end": 88.88, "start": 88.52, "text": "the"}, {"end": 89.32, "start": 88.88, "text": "autofill"}, {"end": 89.96000000000001, "start": 89.32, "text": "technology"}], "text": " A useful feature for password manager and as you know, the password manager were born for the web world and now they are trying to move in the mobile world. And the other feature is the instant apps that allow the users to try Android application without installing them on their phone. So as you can see in the image, here we have the Facebook Android app and the autofill technology"}, {"chunks": [{"end": 90.8, "start": 90.0, "text": "...kicks"}, {"end": 91.88, "start": 90.8, "text": "in"}, {"end": 92.12, "start": 91.88, "text": "and"}, {"end": 92.48, "start": 92.12, "text": "password"}, {"end": 93.08, "start": 92.48, "text": "manager,"}, {"end": 93.4, "start": 93.08, "text": "this"}, {"end": 93.68, "start": 93.4, "text": "is"}, {"end": 94.28, "start": 93.68, "text": "Lespas,"}, {"end": 94.76, "start": 94.28, "text": "is"}, {"end": 95.6, "start": 94.76, "text": "suggesting"}, {"end": 95.68, "start": 95.6, "text": "to"}, {"end": 95.72, "start": 95.68, "text": "the"}, {"end": 96.32, "start": 95.72, "text": "user"}, {"end": 96.52, "start": 96.32, "text": "the"}, {"end": 97.12, "start": 96.52, "text": "Facebook"}, {"end": 98.6, "start": 97.12, "text": "credential."}, {"end": 98.92, "start": 98.6, "text": "But"}, {"end": 99.52, "start": 98.92, "text": "how"}, {"end": 100.52, "start": 99.52, "text": "can"}, {"end": 100.76, "start": 100.52, "text": "a"}, {"end": 101.12, "start": 100.76, "text": "password"}, {"end": 101.88, "start": 101.12, "text": "manager"}, {"end": 102.36, "start": 101.88, "text": "know"}, {"end": 102.52, "start": 102.36, "text": "that"}, {"end": 103.08, "start": 102.52, "text": "this"}, {"end": 103.6, "start": 103.08, "text": "is"}, {"end": 104.0, "start": 103.6, "text": "the"}, {"end": 104.2, "start": 104.0, "text": "real"}, {"end": 104.52, "start": 104.2, "text": "Facebook"}, {"end": 104.6, "start": 104.52, "text": "app?"}, {"end": 105.92, "start": 104.6, "text": "Because"}, {"end": 106.32, "start": 105.92, "text": "here,"}, {"end": 106.88, "start": 106.32, "text": "I"}, {"end": 107.12, "start": 106.88, "text": "mean,"}, {"end": 107.6, "start": 107.12, "text": "we"}, {"end": 107.8, "start": 107.6, "text": "are"}, {"end": 108.64, "start": 107.8, "text": "no"}, {"end": 109.28, "start": 108.64, "text": "more"}, {"end": 109.68, "start": 109.28, "text": "in"}, {"end": 109.92, "start": 109.68, "text": "the"}, {"end": 110.44, "start": 109.92, "text": "web"}, {"end": 110.8, "start": 110.44, "text": "world."}, {"end": 111.12, "start": 110.8, "text": "We"}, {"end": 111.52, "start": 111.12, "text": "don't"}, {"end": 111.8, "start": 111.52, "text": "have"}, {"end": 112.32, "start": 111.8, "text": "domain,"}, {"end": 112.64, "start": 112.32, "text": "we"}, {"end": 113.08, "start": 112.64, "text": "don't"}, {"end": 113.12, "start": 113.08, "text": "have"}, {"end": 113.8, "start": 113.12, "text": "certificates"}, {"end": 114.08, "start": 113.8, "text": "and"}, {"end": 114.16, "start": 114.08, "text": "we"}, {"end": 114.92, "start": 114.16, "text": "don't"}, {"end": 115.08, "start": 114.92, "text": "have"}, {"end": 115.16, "start": 115.08, "text": "a"}, {"end": 115.72, "start": 115.16, "text": "certification"}, {"end": 116.03999999999999, "start": 115.72, "text": "authority."}, {"end": 116.36, "start": 116.03999999999999, "text": "So"}, {"end": 116.44, "start": 116.36, "text": "in"}, {"end": 116.92, "start": 116.44, "text": "the"}, {"end": 117.48, "start": 116.92, "text": "web"}, {"end": 118.08, "start": 117.48, "text": "world,"}, {"end": 118.44, "start": 118.08, "text": "the"}, {"end": 118.96000000000001, "start": 118.44, "text": "mobile,"}, {"end": 119.16, "start": 118.96000000000001, "text": "sorry,"}, {"end": 119.36, "start": 119.16, "text": "in"}, {"end": 119.68, "start": 119.36, "text": "the"}, {"end": 119.68, "start": 119.68, "text": "web"}, {"end": 119.96000000000001, "start": 119.68, "text": "world,"}], "text": " ...kicks in and password manager, this is Lespas, is suggesting to the user the Facebook credential. But how can a password manager know that this is the real Facebook app? Because here, I mean, we are no more in the web world. We don't have domain, we don't have certificates and we don't have a certification authority. So in the web world, the mobile, sorry, in the web world,"}, {"chunks": [{"end": 120.04, "start": 120.0, "text": "In"}, {"end": 120.12, "start": 120.04, "text": "that"}, {"end": 120.36, "start": 120.12, "text": "word,"}, {"end": 120.52, "start": 120.36, "text": "the"}, {"end": 120.88, "start": 120.52, "text": "password"}, {"end": 121.64, "start": 120.88, "text": "manager"}, {"end": 122.04, "start": 121.64, "text": "helps"}, {"end": 122.76, "start": 122.04, "text": "prevent"}, {"end": 123.24, "start": 122.76, "text": "phishing"}, {"end": 124.72, "start": 123.24, "text": "attacks"}, {"end": 125.72, "start": 124.72, "text": "because"}, {"end": 126.08, "start": 125.72, "text": "they"}, {"end": 127.12, "start": 126.08, "text": "suggest"}, {"end": 127.44, "start": 127.12, "text": "the"}, {"end": 127.84, "start": 127.44, "text": "user"}, {"end": 128.08, "start": 127.84, "text": "the"}, {"end": 128.84, "start": 128.08, "text": "credential"}, {"end": 129.12, "start": 128.84, "text": "just"}, {"end": 129.48, "start": 129.12, "text": "if"}, {"end": 129.84, "start": 129.48, "text": "they"}, {"end": 129.96, "start": 129.84, "text": "are"}, {"end": 130.04, "start": 129.96, "text": "in"}, {"end": 130.72, "start": 130.04, "text": "the"}, {"end": 131.04, "start": 130.72, "text": "right"}, {"end": 132.72, "start": 131.04, "text": "domain."}, {"end": 132.92, "start": 132.72, "text": "Let's"}, {"end": 133.08, "start": 132.92, "text": "have"}, {"end": 133.96, "start": 133.08, "text": "a"}, {"end": 134.4, "start": 133.96, "text": "look"}, {"end": 134.64, "start": 134.4, "text": "under"}, {"end": 134.76, "start": 134.64, "text": "the"}, {"end": 135.08, "start": 134.76, "text": "hood"}, {"end": 135.32, "start": 135.08, "text": "of"}, {"end": 135.76, "start": 135.32, "text": "the"}, {"end": 136.28, "start": 135.76, "text": "Android"}, {"end": 136.92000000000002, "start": 136.28, "text": "AutoFill"}, {"end": 138.28, "start": 136.92000000000002, "text": "technologies."}, {"end": 139.04, "start": 138.28, "text": "So,"}, {"end": 139.24, "start": 139.04, "text": "as"}, {"end": 139.8, "start": 139.24, "text": "you"}, {"end": 140.07999999999998, "start": 139.8, "text": "know,"}, {"end": 140.6, "start": 140.07999999999998, "text": "every"}, {"end": 140.76, "start": 140.6, "text": "Android"}, {"end": 140.84, "start": 140.76, "text": "app"}, {"end": 141.32, "start": 140.84, "text": "runs"}, {"end": 141.36, "start": 141.32, "text": "in"}, {"end": 141.44, "start": 141.36, "text": "a"}, {"end": 142.04, "start": 141.44, "text": "sandboxed"}, {"end": 143.07999999999998, "start": 142.04, "text": "environment."}, {"end": 143.44, "start": 143.07999999999998, "text": "So"}, {"end": 143.44, "start": 143.44, "text": "the"}, {"end": 143.84, "start": 143.44, "text": "password"}, {"end": 144.36, "start": 143.84, "text": "manager"}, {"end": 144.88, "start": 144.36, "text": "needs"}, {"end": 145.32, "start": 144.88, "text": "an"}, {"end": 146.0, "start": 145.32, "text": "external"}, {"end": 146.52, "start": 146.0, "text": "entity"}, {"end": 147.07999999999998, "start": 146.52, "text": "to"}, {"end": 147.68, "start": 147.07999999999998, "text": "ask"}, {"end": 148.36, "start": 147.68, "text": "for"}, {"end": 149.2, "start": 148.36, "text": "inspect,"}, {"end": 149.96, "start": 149.2, "text": "identify"}], "text": " In that word, the password manager helps prevent phishing attacks because they suggest the user the credential just if they are in the right domain. Let's have a look under the hood of the Android AutoFill technologies. So, as you know, every Android app runs in a sandboxed environment. So the password manager needs an external entity to ask for inspect, identify"}, {"chunks": [{"end": 150.28, "start": 150.0, "text": "and"}, {"end": 150.88, "start": 150.28, "text": "inject"}, {"end": 151.28, "start": 150.88, "text": "the"}, {"end": 152.24, "start": 151.28, "text": "credential"}, {"end": 152.48, "start": 152.24, "text": "in"}, {"end": 153.24, "start": 152.48, "text": "the"}, {"end": 153.52, "start": 153.24, "text": "other"}, {"end": 154.0, "start": 153.52, "text": "application"}, {"end": 154.12, "start": 154.0, "text": "with"}, {"end": 154.48, "start": 154.12, "text": "login"}, {"end": 155.04, "start": 154.48, "text": "forms."}, {"end": 155.16, "start": 155.04, "text": "The"}, {"end": 155.8, "start": 155.16, "text": "first"}, {"end": 155.88, "start": 155.8, "text": "one"}, {"end": 156.16, "start": 155.88, "text": "is"}, {"end": 156.64, "start": 156.16, "text": "the"}, {"end": 157.4, "start": 156.64, "text": "accessibility"}, {"end": 158.0, "start": 157.4, "text": "service."}, {"end": 158.24, "start": 158.0, "text": "It"}, {"end": 158.68, "start": 158.24, "text": "was"}, {"end": 159.08, "start": 158.68, "text": "created"}, {"end": 159.56, "start": 159.08, "text": "for"}, {"end": 159.88, "start": 159.56, "text": "help"}, {"end": 160.44, "start": 159.88, "text": "users"}, {"end": 160.68, "start": 160.44, "text": "with"}, {"end": 161.16, "start": 160.68, "text": "disabilities"}, {"end": 161.48, "start": 161.16, "text": "to"}, {"end": 162.0, "start": 161.48, "text": "interact"}, {"end": 162.12, "start": 162.0, "text": "with"}, {"end": 162.24, "start": 162.12, "text": "the"}, {"end": 163.08, "start": 162.24, "text": "device"}, {"end": 163.48, "start": 163.08, "text": "and"}, {"end": 163.84, "start": 163.48, "text": "the"}, {"end": 164.52, "start": 163.84, "text": "password"}, {"end": 164.88, "start": 164.52, "text": "manager"}, {"end": 165.84, "start": 164.88, "text": "uses"}, {"end": 165.92, "start": 165.84, "text": "it"}, {"end": 166.92000000000002, "start": 165.92, "text": "for"}, {"end": 167.44, "start": 166.92000000000002, "text": "outfilling"}, {"end": 168.12, "start": 167.44, "text": "purposes."}, {"end": 168.36, "start": 168.12, "text": "But"}, {"end": 168.8, "start": 168.36, "text": "this"}, {"end": 169.4, "start": 168.8, "text": "is"}, {"end": 169.52, "start": 169.4, "text": "a"}, {"end": 169.8, "start": 169.52, "text": "dirty"}, {"end": 170.28, "start": 169.8, "text": "way"}, {"end": 170.88, "start": 170.28, "text": "because"}, {"end": 170.92000000000002, "start": 170.88, "text": "the"}, {"end": 171.07999999999998, "start": 170.92000000000002, "text": "state"}, {"end": 171.32, "start": 171.07999999999998, "text": "of"}, {"end": 171.68, "start": 171.32, "text": "the"}, {"end": 171.84, "start": 171.68, "text": "art"}, {"end": 172.92000000000002, "start": 171.84, "text": "shows"}, {"end": 173.36, "start": 172.92000000000002, "text": "how"}, {"end": 173.36, "start": 173.36, "text": "the"}, {"end": 174.6, "start": 173.36, "text": "accessibility"}, {"end": 175.12, "start": 174.6, "text": "service"}, {"end": 175.32, "start": 175.12, "text": "can"}, {"end": 175.48, "start": 175.32, "text": "be"}, {"end": 175.92000000000002, "start": 175.48, "text": "abused"}, {"end": 176.07999999999998, "start": 175.92000000000002, "text": "to"}, {"end": 176.68, "start": 176.07999999999998, "text": "perform"}, {"end": 177.2, "start": 176.68, "text": "malicious"}, {"end": 177.68, "start": 177.2, "text": "operations."}, {"end": 178.12, "start": 177.68, "text": "So"}, {"end": 178.36, "start": 178.12, "text": "Google"}, {"end": 178.56, "start": 178.36, "text": "is"}, {"end": 178.92000000000002, "start": 178.56, "text": "trying"}, {"end": 179.24, "start": 178.92000000000002, "text": "to"}, {"end": 179.96, "start": 179.24, "text": "move"}], "text": " and inject the credential in the other application with login forms. The first one is the accessibility service. It was created for help users with disabilities to interact with the device and the password manager uses it for outfilling purposes. But this is a dirty way because the state of the art shows how the accessibility service can be abused to perform malicious operations. So Google is trying to move"}, {"chunks": [{"end": 180.24, "start": 180.0, "text": "away"}, {"end": 180.52, "start": 180.24, "text": "from"}, {"end": 180.88, "start": 180.52, "text": "the"}, {"end": 181.48, "start": 180.88, "text": "accessibility"}, {"end": 182.04, "start": 181.48, "text": "service"}, {"end": 182.04, "start": 182.04, "text": "and"}, {"end": 182.4, "start": 182.04, "text": "they"}, {"end": 182.44, "start": 182.4, "text": "have"}, {"end": 183.04, "start": 182.44, "text": "developed"}, {"end": 183.2, "start": 183.04, "text": "a"}, {"end": 183.68, "start": 183.2, "text": "protocol"}, {"end": 184.16, "start": 183.68, "text": "named"}, {"end": 185.12, "start": 184.16, "text": "OpenYolo"}, {"end": 185.36, "start": 185.12, "text": "in"}, {"end": 186.08, "start": 185.36, "text": "collaboration"}, {"end": 186.44, "start": 186.08, "text": "with"}, {"end": 186.92, "start": 186.44, "text": "Dashlane"}, {"end": 187.12, "start": 186.92, "text": "and"}, {"end": 187.76, "start": 187.12, "text": "this"}, {"end": 188.12, "start": 187.76, "text": "is"}, {"end": 188.4, "start": 188.12, "text": "a"}, {"end": 189.56, "start": 188.4, "text": "client"}, {"end": 190.04, "start": 189.56, "text": "server"}, {"end": 191.52, "start": 190.04, "text": "architecture"}, {"end": 192.0, "start": 191.52, "text": "so"}, {"end": 192.4, "start": 192.0, "text": "the"}, {"end": 193.08, "start": 192.4, "text": "application"}, {"end": 193.32, "start": 193.08, "text": "the"}, {"end": 193.44, "start": 193.32, "text": "Android"}, {"end": 193.88, "start": 193.44, "text": "application"}, {"end": 193.92, "start": 193.88, "text": "with"}, {"end": 194.08, "start": 193.92, "text": "the"}, {"end": 194.36, "start": 194.08, "text": "login"}, {"end": 194.88, "start": 194.36, "text": "form"}, {"end": 194.92, "start": 194.88, "text": "is"}, {"end": 194.92, "start": 194.92, "text": "the"}, {"end": 195.44, "start": 194.92, "text": "client"}, {"end": 195.48, "start": 195.44, "text": "and"}, {"end": 195.64, "start": 195.48, "text": "the"}, {"end": 196.12, "start": 195.64, "text": "password"}, {"end": 196.68, "start": 196.12, "text": "manager"}, {"end": 196.96, "start": 196.68, "text": "is"}, {"end": 197.48, "start": 196.96, "text": "the"}, {"end": 197.96, "start": 197.48, "text": "server"}, {"end": 198.64, "start": 197.96, "text": "and"}, {"end": 198.84, "start": 198.64, "text": "it"}, {"end": 199.12, "start": 198.84, "text": "is"}, {"end": 200.07999999999998, "start": 199.12, "text": "distributed"}, {"end": 200.48, "start": 200.07999999999998, "text": "like"}, {"end": 200.68, "start": 200.48, "text": "as"}, {"end": 201.04, "start": 200.68, "text": "an"}, {"end": 201.52, "start": 201.04, "text": "open"}, {"end": 201.88, "start": 201.52, "text": "source"}, {"end": 202.32, "start": 201.88, "text": "library"}, {"end": 202.56, "start": 202.32, "text": "so"}, {"end": 202.92000000000002, "start": 202.56, "text": "the"}, {"end": 203.56, "start": 202.92000000000002, "text": "client"}, {"end": 203.92000000000002, "start": 203.56, "text": "needs"}, {"end": 204.16, "start": 203.92000000000002, "text": "a"}, {"end": 204.76, "start": 204.16, "text": "modification"}, {"end": 204.92000000000002, "start": 204.76, "text": "to"}, {"end": 205.24, "start": 204.92000000000002, "text": "be"}, {"end": 205.68, "start": 205.24, "text": "included."}, {"end": 205.68, "start": 205.68, "text": "The"}, {"end": 205.84, "start": 205.68, "text": "last"}, {"end": 206.92000000000002, "start": 205.84, "text": "technology"}, {"end": 207.0, "start": 206.92000000000002, "text": "is"}, {"end": 207.07999999999998, "start": 207.0, "text": "the"}, {"end": 208.07999999999998, "start": 207.07999999999998, "text": "autofill"}, {"end": 208.68, "start": 208.07999999999998, "text": "framework"}, {"end": 208.68, "start": 208.68, "text": "as"}, {"end": 208.72, "start": 208.68, "text": "I"}, {"end": 208.96, "start": 208.72, "text": "said"}, {"end": 209.44, "start": 208.96, "text": "it"}, {"end": 209.76, "start": 209.44, "text": "was"}, {"end": 209.96, "start": 209.76, "text": "introduced"}], "text": " away from the accessibility service and they have developed a protocol named OpenYolo in collaboration with Dashlane and this is a client server architecture so the application the Android application with the login form is the client and the password manager is the server and it is distributed like as an open source library so the client needs a modification to be included. The last technology is the autofill framework as I said it was introduced"}, {"chunks": [{"end": 210.28, "start": 210.0, "text": "used"}, {"end": 210.48, "start": 210.28, "text": "in"}, {"end": 210.88, "start": 210.48, "text": "Android"}, {"end": 211.28, "start": 210.88, "text": "8,"}, {"end": 211.64, "start": 211.28, "text": "and"}, {"end": 211.92, "start": 211.64, "text": "it"}, {"end": 212.6, "start": 211.92, "text": "implements"}, {"end": 213.28, "start": 212.6, "text": "the"}, {"end": 213.8, "start": 213.28, "text": "core"}, {"end": 214.48, "start": 213.8, "text": "functionality"}, {"end": 214.68, "start": 214.48, "text": "of"}, {"end": 215.32, "start": 214.68, "text": "Password"}, {"end": 215.76, "start": 215.32, "text": "Managers."}, {"end": 216.28, "start": 215.76, "text": "And"}, {"end": 217.56, "start": 216.28, "text": "it's"}, {"end": 217.88, "start": 217.56, "text": "a"}, {"end": 218.28, "start": 217.88, "text": "normal"}, {"end": 219.6, "start": 218.28, "text": "Android"}, {"end": 220.2, "start": 219.6, "text": "service."}, {"end": 220.68, "start": 220.2, "text": "They"}, {"end": 221.28, "start": 220.68, "text": "are"}, {"end": 222.28, "start": 221.28, "text": "different,"}, {"end": 222.52, "start": 222.28, "text": "but"}, {"end": 222.88, "start": 222.52, "text": "they"}, {"end": 223.16, "start": 222.88, "text": "have"}, {"end": 223.76, "start": 223.16, "text": "something"}, {"end": 223.76, "start": 223.76, "text": "in"}, {"end": 224.96, "start": 223.76, "text": "common."}, {"end": 225.24, "start": 224.96, "text": "They"}, {"end": 225.32, "start": 225.24, "text": "all"}, {"end": 225.88, "start": 225.32, "text": "use"}, {"end": 226.12, "start": 225.88, "text": "the"}, {"end": 226.4, "start": 226.12, "text": "package"}, {"end": 226.8, "start": 226.4, "text": "name"}, {"end": 227.04, "start": 226.8, "text": "to"}, {"end": 227.8, "start": 227.04, "text": "identify"}, {"end": 228.12, "start": 227.8, "text": "the"}, {"end": 228.28, "start": 228.12, "text": "Android"}, {"end": 228.72, "start": 228.28, "text": "application."}, {"end": 228.8, "start": 228.72, "text": "And"}, {"end": 229.24, "start": 228.8, "text": "this"}, {"end": 229.68, "start": 229.24, "text": "is"}, {"end": 229.92000000000002, "start": 229.68, "text": "really"}, {"end": 230.36, "start": 229.92000000000002, "text": "bad"}, {"end": 230.84, "start": 230.36, "text": "because"}, {"end": 231.2, "start": 230.84, "text": "the"}, {"end": 231.56, "start": 231.2, "text": "package"}, {"end": 231.64, "start": 231.56, "text": "name"}, {"end": 232.04, "start": 231.64, "text": "is"}, {"end": 232.88, "start": 232.04, "text": "attacker-controlled."}, {"end": 233.32, "start": 232.88, "text": "So"}, {"end": 233.8, "start": 233.32, "text": "anyone"}, {"end": 233.96, "start": 233.8, "text": "can"}, {"end": 234.4, "start": 233.96, "text": "create"}, {"end": 234.6, "start": 234.4, "text": "an"}, {"end": 234.84, "start": 234.6, "text": "Android"}, {"end": 235.8, "start": 234.84, "text": "application"}, {"end": 236.32, "start": 235.8, "text": "with"}, {"end": 236.64, "start": 236.32, "text": "any"}, {"end": 237.12, "start": 236.64, "text": "package"}, {"end": 237.52, "start": 237.12, "text": "name."}, {"end": 237.96, "start": 237.52, "text": "There"}, {"end": 238.4, "start": 237.96, "text": "are"}, {"end": 238.6, "start": 238.4, "text": "some"}, {"end": 239.2, "start": 238.6, "text": "restrictions,"}, {"end": 239.4, "start": 239.2, "text": "so"}, {"end": 239.6, "start": 239.4, "text": "for"}, {"end": 239.96, "start": 239.6, "text": "example,"}], "text": " used in Android 8, and it implements the core functionality of Password Managers. And it's a normal Android service. They are different, but they have something in common. They all use the package name to identify the Android application. And this is really bad because the package name is attacker-controlled. So anyone can create an Android application with any package name. There are some restrictions, so for example,"}, {"chunks": [{"end": 240.12, "start": 240.0, "text": "The"}, {"end": 240.64, "start": 240.12, "text": "package"}, {"end": 240.76, "start": 240.64, "text": "name"}, {"end": 241.56, "start": 240.76, "text": "uniquely"}, {"end": 242.4, "start": 241.56, "text": "identifies"}, {"end": 242.76, "start": 242.4, "text": "an"}, {"end": 243.48, "start": 242.76, "text": "application"}, {"end": 243.68, "start": 243.48, "text": "on"}, {"end": 243.92, "start": 243.68, "text": "your"}, {"end": 244.76, "start": 243.92, "text": "device."}, {"end": 245.36, "start": 244.76, "text": "So"}, {"end": 245.76, "start": 245.36, "text": "on"}, {"end": 246.08, "start": 245.76, "text": "your"}, {"end": 246.48, "start": 246.08, "text": "device,"}, {"end": 246.48, "start": 246.48, "text": "it"}, {"end": 246.92, "start": 246.48, "text": "cannot"}, {"end": 247.68, "start": 246.92, "text": "coexist"}, {"end": 247.92, "start": 247.68, "text": "the"}, {"end": 248.0, "start": 247.92, "text": "two"}, {"end": 248.56, "start": 248.0, "text": "applications"}, {"end": 248.64, "start": 248.56, "text": "with"}, {"end": 248.84, "start": 248.64, "text": "the"}, {"end": 249.12, "start": 248.84, "text": "same"}, {"end": 250.6, "start": 249.12, "text": "package"}, {"end": 251.0, "start": 250.6, "text": "name."}, {"end": 251.36, "start": 251.0, "text": "And"}, {"end": 252.0, "start": 251.36, "text": "moreover,"}, {"end": 252.56, "start": 252.0, "text": "in"}, {"end": 253.16, "start": 252.56, "text": "the"}, {"end": 253.24, "start": 253.16, "text": "Google"}, {"end": 253.6, "start": 253.24, "text": "Play"}, {"end": 254.08, "start": 253.6, "text": "Store,"}, {"end": 254.24, "start": 254.08, "text": "the"}, {"end": 254.24, "start": 254.24, "text": "apps"}, {"end": 254.24, "start": 254.24, "text": "are"}, {"end": 254.4, "start": 254.24, "text": "indexed"}, {"end": 255.16, "start": 254.4, "text": "by"}, {"end": 255.76, "start": 255.16, "text": "the"}, {"end": 256.32, "start": 255.76, "text": "package"}, {"end": 256.68, "start": 256.32, "text": "name."}, {"end": 257.52, "start": 256.68, "text": "But"}, {"end": 257.76, "start": 257.52, "text": "as"}, {"end": 259.4, "start": 257.76, "text": "I"}, {"end": 259.92, "start": 259.4, "text": "said,"}, {"end": 260.08, "start": 259.92, "text": "we"}, {"end": 260.24, "start": 260.08, "text": "can't"}, {"end": 260.68, "start": 260.24, "text": "trust"}, {"end": 260.8, "start": 260.68, "text": "the"}, {"end": 261.12, "start": 260.8, "text": "package"}, {"end": 262.28, "start": 261.12, "text": "names"}, {"end": 262.88, "start": 262.28, "text": "because"}, {"end": 263.04, "start": 262.88, "text": "I"}, {"end": 263.48, "start": 263.04, "text": "say"}, {"end": 263.6, "start": 263.48, "text": "it's"}, {"end": 263.88, "start": 263.6, "text": "attacker"}, {"end": 264.4, "start": 263.88, "text": "controlled."}, {"end": 264.56, "start": 264.4, "text": "There"}, {"end": 265.16, "start": 264.56, "text": "isn't"}, {"end": 265.52, "start": 265.16, "text": "a"}, {"end": 265.96, "start": 265.52, "text": "trust"}, {"end": 266.68, "start": 265.96, "text": "relation"}, {"end": 266.76, "start": 266.68, "text": "between"}, {"end": 267.12, "start": 266.76, "text": "the"}, {"end": 267.68, "start": 267.12, "text": "package"}, {"end": 268.16, "start": 267.68, "text": "and"}, {"end": 268.64, "start": 268.16, "text": "the"}, {"end": 268.88, "start": 268.64, "text": "sub"}, {"end": 269.4, "start": 268.88, "text": "package."}, {"end": 269.68, "start": 269.4, "text": "So"}, {"end": 269.96, "start": 269.68, "text": "if"}], "text": " The package name uniquely identifies an application on your device. So on your device, it cannot coexist the two applications with the same package name. And moreover, in the Google Play Store, the apps are indexed by the package name. But as I said, we can't trust the package names because I say it's attacker controlled. There isn't a trust relation between the package and the sub package. So if"}, {"chunks": [{"end": 270.36, "start": 270.0, "text": "You"}, {"end": 270.52, "start": 270.36, "text": "are"}, {"end": 270.6, "start": 270.52, "text": "in"}, {"end": 271.04, "start": 270.6, "text": "the"}, {"end": 271.16, "start": 271.04, "text": "web"}, {"end": 271.48, "start": 271.16, "text": "world,"}, {"end": 272.0, "start": 271.48, "text": "you're"}, {"end": 272.56, "start": 272.0, "text": "visiting"}, {"end": 273.88, "start": 272.56, "text": "mail.google.com."}, {"end": 274.12, "start": 273.88, "text": "You"}, {"end": 274.44, "start": 274.12, "text": "are"}, {"end": 274.64, "start": 274.44, "text": "sure"}, {"end": 274.68, "start": 274.64, "text": "that"}, {"end": 275.52, "start": 274.68, "text": "mail"}, {"end": 276.4, "start": 275.52, "text": "is"}, {"end": 276.88, "start": 276.4, "text": "a"}, {"end": 277.64, "start": 276.88, "text": "subdomain"}, {"end": 278.04, "start": 277.64, "text": "of"}, {"end": 279.12, "start": 278.04, "text": "Google.com."}, {"end": 279.6, "start": 279.12, "text": "Here"}, {"end": 280.0, "start": 279.6, "text": "you"}, {"end": 280.28, "start": 280.0, "text": "don't"}, {"end": 280.64, "start": 280.28, "text": "have"}, {"end": 281.12, "start": 280.64, "text": "this"}, {"end": 281.76, "start": 281.12, "text": "relation."}, {"end": 282.2, "start": 281.76, "text": "The"}, {"end": 282.6, "start": 282.2, "text": "Google"}, {"end": 282.8, "start": 282.6, "text": "Play"}, {"end": 283.12, "start": 282.8, "text": "Store"}, {"end": 283.56, "start": 283.12, "text": "doesn't"}, {"end": 284.04, "start": 283.56, "text": "enforce"}, {"end": 284.2, "start": 284.04, "text": "any"}, {"end": 284.76, "start": 284.2, "text": "restriction."}, {"end": 284.84, "start": 284.76, "text": "And"}, {"end": 285.32, "start": 284.84, "text": "we"}, {"end": 286.12, "start": 285.32, "text": "were"}, {"end": 286.44, "start": 286.12, "text": "able"}, {"end": 286.52, "start": 286.44, "text": "to"}, {"end": 286.76, "start": 286.52, "text": "upload"}, {"end": 287.32, "start": 286.76, "text": "an"}, {"end": 287.76, "start": 287.32, "text": "Android"}, {"end": 288.44, "start": 287.76, "text": "application"}, {"end": 288.8, "start": 288.44, "text": "named"}, {"end": 290.64, "start": 288.8, "text": "cam.facebook.fake"}, {"end": 290.96, "start": 290.64, "text": "on"}, {"end": 291.0, "start": 290.96, "text": "the"}, {"end": 291.44, "start": 291.0, "text": "Google"}, {"end": 291.76, "start": 291.44, "text": "Play"}, {"end": 292.24, "start": 291.76, "text": "Store."}, {"end": 292.56, "start": 292.24, "text": "And"}, {"end": 292.88, "start": 292.56, "text": "this"}, {"end": 293.04, "start": 292.88, "text": "is"}, {"end": 294.4, "start": 293.04, "text": "the"}, {"end": 294.88, "start": 294.4, "text": "beginning."}, {"end": 295.16, "start": 294.88, "text": "So"}, {"end": 295.2, "start": 295.16, "text": "the"}, {"end": 295.72, "start": 295.2, "text": "password"}, {"end": 297.2, "start": 295.72, "text": "manager"}, {"end": 297.44, "start": 297.2, "text": "on"}, {"end": 298.2, "start": 297.44, "text": "the"}, {"end": 298.84, "start": 298.2, "text": "mobile"}, {"end": 299.36, "start": 298.84, "text": "world"}, {"end": 299.52, "start": 299.36, "text": "are"}, {"end": 299.96, "start": 299.52, "text": "facing"}], "text": " You are in the web world, you're visiting mail.google.com. You are sure that mail is a subdomain of Google.com. Here you don't have this relation. The Google Play Store doesn't enforce any restriction. And we were able to upload an Android application named cam.facebook.fake on the Google Play Store. And this is the beginning. So the password manager on the mobile world are facing"}, {"chunks": [{"end": 300.28, "start": 300.0, "text": "a"}, {"end": 300.96, "start": 300.28, "text": "mapping"}, {"end": 301.6, "start": 300.96, "text": "problem."}, {"end": 302.2, "start": 301.6, "text": "So,"}, {"end": 302.24, "start": 302.2, "text": "in"}, {"end": 302.76, "start": 302.24, "text": "the"}, {"end": 303.08, "start": 302.76, "text": "web"}, {"end": 303.6, "start": 303.08, "text": "world,"}, {"end": 304.28, "start": 303.6, "text": "credential"}, {"end": 305.12, "start": 304.28, "text": "and"}, {"end": 305.36, "start": 305.12, "text": "domain"}, {"end": 305.48, "start": 305.36, "text": "are"}, {"end": 305.92, "start": 305.48, "text": "safe"}, {"end": 306.4, "start": 305.92, "text": "to"}, {"end": 307.08, "start": 306.4, "text": "map,"}, {"end": 307.36, "start": 307.08, "text": "but"}, {"end": 307.76, "start": 307.36, "text": "the"}, {"end": 308.04, "start": 307.76, "text": "point"}, {"end": 308.48, "start": 308.04, "text": "is"}, {"end": 308.52, "start": 308.48, "text": "that"}, {"end": 308.76, "start": 308.52, "text": "how"}, {"end": 309.48, "start": 308.76, "text": "can"}, {"end": 309.68, "start": 309.48, "text": "the"}, {"end": 310.24, "start": 309.68, "text": "password"}, {"end": 310.6, "start": 310.24, "text": "manager,"}, {"end": 310.76, "start": 310.6, "text": "despite"}, {"end": 311.08, "start": 310.76, "text": "I"}, {"end": 311.44, "start": 311.08, "text": "said"}, {"end": 311.64, "start": 311.44, "text": "the"}, {"end": 311.96, "start": 311.64, "text": "package"}, {"end": 312.44, "start": 311.96, "text": "name"}, {"end": 312.72, "start": 312.44, "text": "is"}, {"end": 313.08, "start": 312.72, "text": "attacker"}, {"end": 313.76, "start": 313.08, "text": "controlled,"}, {"end": 313.8, "start": 313.76, "text": "how"}, {"end": 314.12, "start": 313.8, "text": "they"}, {"end": 314.12, "start": 314.12, "text": "can"}, {"end": 314.12, "start": 314.12, "text": "map"}, {"end": 314.28, "start": 314.12, "text": "the"}, {"end": 314.84, "start": 314.28, "text": "package"}, {"end": 315.48, "start": 314.84, "text": "name"}, {"end": 315.72, "start": 315.48, "text": "with"}, {"end": 315.84, "start": 315.72, "text": "a"}, {"end": 316.4, "start": 315.84, "text": "domain"}, {"end": 316.76, "start": 316.4, "text": "in"}, {"end": 317.84, "start": 316.76, "text": "a"}, {"end": 318.2, "start": 317.84, "text": "secure"}, {"end": 319.36, "start": 318.2, "text": "way?"}, {"end": 319.72, "start": 319.36, "text": "So,"}, {"end": 319.88, "start": 319.72, "text": "we"}, {"end": 320.24, "start": 319.88, "text": "have"}, {"end": 321.12, "start": 320.24, "text": "investigated"}, {"end": 321.32, "start": 321.12, "text": "the"}, {"end": 321.68, "start": 321.32, "text": "five"}, {"end": 322.0, "start": 321.68, "text": "leading"}, {"end": 323.8, "start": 322.0, "text": "password"}, {"end": 324.64, "start": 323.8, "text": "managers"}, {"end": 325.16, "start": 324.64, "text": "to"}, {"end": 325.72, "start": 325.16, "text": "discover"}, {"end": 326.36, "start": 325.72, "text": "how"}, {"end": 326.72, "start": 326.36, "text": "they"}, {"end": 327.16, "start": 326.72, "text": "work"}, {"end": 327.68, "start": 327.16, "text": "under"}, {"end": 327.88, "start": 327.68, "text": "the"}, {"end": 328.68, "start": 327.88, "text": "hood."}, {"end": 329.04, "start": 328.68, "text": "We"}, {"end": 329.6, "start": 329.04, "text": "reverse"}, {"end": 329.96, "start": 329.6, "text": "engineered"}], "text": " a mapping problem. So, in the web world, credential and domain are safe to map, but the point is that how can the password manager, despite I said the package name is attacker controlled, how they can map the package name with a domain in a secure way? So, we have investigated the five leading password managers to discover how they work under the hood. We reverse engineered"}, {"chunks": [{"end": 330.52, "start": 330.0, "text": "all"}, {"end": 331.08, "start": 330.52, "text": "of"}, {"end": 331.64, "start": 331.08, "text": "them"}, {"end": 332.36, "start": 331.64, "text": "and,"}, {"end": 332.48, "start": 332.36, "text": "um,"}, {"end": 332.76, "start": 332.48, "text": "sorry,"}, {"end": 333.08, "start": 332.76, "text": "forgot"}, {"end": 333.76, "start": 333.08, "text": "to"}, {"end": 334.16, "start": 333.76, "text": "say"}, {"end": 334.2, "start": 334.16, "text": "that,"}, {"end": 334.52, "start": 334.2, "text": "uh,"}, {"end": 334.96, "start": 334.52, "text": "all"}, {"end": 334.96, "start": 334.96, "text": "of"}, {"end": 335.0, "start": 334.96, "text": "them"}, {"end": 335.08, "start": 335.0, "text": "have"}, {"end": 335.48, "start": 335.08, "text": "10"}, {"end": 335.68, "start": 335.48, "text": "of"}, {"end": 336.36, "start": 335.68, "text": "millions"}, {"end": 336.4, "start": 336.36, "text": "of"}, {"end": 337.0, "start": 336.4, "text": "installation"}, {"end": 337.16, "start": 337.0, "text": "on"}, {"end": 337.2, "start": 337.16, "text": "the"}, {"end": 337.52, "start": 337.2, "text": "Google"}, {"end": 337.72, "start": 337.52, "text": "play"}, {"end": 338.2, "start": 337.72, "text": "store."}, {"end": 339.12, "start": 338.2, "text": "And"}, {"end": 339.24, "start": 339.12, "text": "now"}, {"end": 339.84, "start": 339.24, "text": "I"}, {"end": 340.44, "start": 339.84, "text": "will"}, {"end": 340.8, "start": 340.44, "text": "show"}, {"end": 340.96, "start": 340.8, "text": "how"}, {"end": 341.48, "start": 340.96, "text": "they"}, {"end": 342.0, "start": 341.48, "text": "behave"}, {"end": 342.36, "start": 342.0, "text": "when"}, {"end": 342.6, "start": 342.36, "text": "they"}, {"end": 343.68, "start": 342.6, "text": "receive"}, {"end": 343.96, "start": 343.68, "text": "the"}, {"end": 344.64, "start": 343.96, "text": "package"}, {"end": 345.16, "start": 344.64, "text": "name."}, {"end": 345.4, "start": 345.16, "text": "So"}, {"end": 346.12, "start": 345.4, "text": "please,"}, {"end": 346.56, "start": 346.12, "text": "this"}, {"end": 347.12, "start": 346.56, "text": "doesn't"}, {"end": 347.64, "start": 347.12, "text": "matter"}, {"end": 347.88, "start": 347.64, "text": "how"}, {"end": 348.04, "start": 347.88, "text": "they"}, {"end": 348.44, "start": 348.04, "text": "receive"}, {"end": 348.56, "start": 348.44, "text": "the"}, {"end": 349.0, "start": 348.56, "text": "packer"}, {"end": 349.12, "start": 349.0, "text": "and"}, {"end": 349.24, "start": 349.12, "text": "the"}, {"end": 349.6, "start": 349.24, "text": "package"}, {"end": 350.12, "start": 349.6, "text": "name."}, {"end": 350.6, "start": 350.12, "text": "This"}, {"end": 350.72, "start": 350.6, "text": "is"}, {"end": 351.12, "start": 350.72, "text": "independent"}, {"end": 351.76, "start": 351.12, "text": "from"}, {"end": 351.92, "start": 351.76, "text": "the"}, {"end": 352.64, "start": 351.92, "text": "underlying"}, {"end": 352.68, "start": 352.64, "text": "out"}, {"end": 352.96, "start": 352.68, "text": "to"}, {"end": 353.04, "start": 352.96, "text": "fill"}, {"end": 353.92, "start": 353.04, "text": "technology."}, {"end": 354.4, "start": 353.92, "text": "Now"}, {"end": 354.64, "start": 354.4, "text": "every"}, {"end": 354.84, "start": 354.64, "text": "pack"}, {"end": 355.28, "start": 354.84, "text": "pack,"}, {"end": 355.68, "start": 355.28, "text": "every"}, {"end": 356.04, "start": 355.68, "text": "password"}, {"end": 356.56, "start": 356.04, "text": "manager"}, {"end": 356.96, "start": 356.56, "text": "has"}, {"end": 357.36, "start": 356.96, "text": "just"}, {"end": 358.32, "start": 357.36, "text": "received"}, {"end": 358.52, "start": 358.32, "text": "the"}, {"end": 358.84, "start": 358.52, "text": "package"}, {"end": 359.2, "start": 358.84, "text": "name."}, {"end": 359.2, "start": 359.2, "text": "It"}, {"end": 359.44, "start": 359.2, "text": "doesn't"}, {"end": 359.96, "start": 359.44, "text": "matter."}], "text": " all of them and, um, sorry, forgot to say that, uh, all of them have 10 of millions of installation on the Google play store. And now I will show how they behave when they receive the package name. So please, this doesn't matter how they receive the packer and the package name. This is independent from the underlying out to fill technology. Now every pack pack, every password manager has just received the package name. It doesn't matter."}, {"chunks": [{"end": 360.36, "start": 360.0, "text": "So"}, {"end": 360.88, "start": 360.36, "text": "this"}, {"end": 361.28, "start": 360.88, "text": "is"}, {"end": 361.4, "start": 361.28, "text": "the"}, {"end": 361.64, "start": 361.4, "text": "first"}, {"end": 361.8, "start": 361.64, "text": "one"}, {"end": 361.96, "start": 361.8, "text": "is"}, {"end": 362.88, "start": 361.96, "text": "LastPass."}, {"end": 363.4, "start": 362.88, "text": "It"}, {"end": 363.96, "start": 363.4, "text": "uses"}, {"end": 364.44, "start": 363.96, "text": "a"}, {"end": 364.88, "start": 364.44, "text": "heuristic"}, {"end": 365.48, "start": 364.88, "text": "based"}, {"end": 366.8, "start": 365.48, "text": "mapping."}, {"end": 367.32, "start": 366.8, "text": "So"}, {"end": 367.44, "start": 367.32, "text": "you"}, {"end": 367.68, "start": 367.44, "text": "receive"}, {"end": 367.8, "start": 367.68, "text": "the"}, {"end": 368.2, "start": 367.8, "text": "package"}, {"end": 368.64, "start": 368.2, "text": "name,"}, {"end": 368.84, "start": 368.64, "text": "is"}, {"end": 369.12, "start": 368.84, "text": "split"}, {"end": 369.52, "start": 369.12, "text": "in"}, {"end": 370.16, "start": 369.52, "text": "several"}, {"end": 371.12, "start": 370.16, "text": "components"}, {"end": 371.32, "start": 371.12, "text": "by"}, {"end": 371.36, "start": 371.32, "text": "the"}, {"end": 371.84, "start": 371.36, "text": "dots"}, {"end": 371.92, "start": 371.84, "text": "and"}, {"end": 372.28, "start": 371.92, "text": "the"}, {"end": 372.68, "start": 372.28, "text": "domain"}, {"end": 373.72, "start": 372.68, "text": "name"}, {"end": 373.84, "start": 373.72, "text": "in"}, {"end": 374.04, "start": 373.84, "text": "the"}, {"end": 374.44, "start": 374.04, "text": "reverse"}, {"end": 374.88, "start": 374.44, "text": "order."}, {"end": 375.24, "start": 374.88, "text": "So"}, {"end": 375.6, "start": 375.24, "text": "for"}, {"end": 376.28, "start": 375.6, "text": "example,"}, {"end": 377.84, "start": 376.28, "text": "com.facebook.katana"}, {"end": 378.12, "start": 377.84, "text": "is"}, {"end": 378.36, "start": 378.12, "text": "the"}, {"end": 378.6, "start": 378.36, "text": "original"}, {"end": 379.2, "start": 378.6, "text": "package"}, {"end": 379.44, "start": 379.2, "text": "name"}, {"end": 379.44, "start": 379.44, "text": "of"}, {"end": 379.44, "start": 379.44, "text": "the"}, {"end": 380.24, "start": 379.44, "text": "Facebook"}, {"end": 380.36, "start": 380.24, "text": "app"}, {"end": 380.44, "start": 380.36, "text": "and"}, {"end": 380.88, "start": 380.44, "text": "this"}, {"end": 381.64, "start": 380.88, "text": "maps"}, {"end": 382.24, "start": 381.64, "text": "to"}, {"end": 383.8, "start": 382.24, "text": "facebook.com."}, {"end": 384.12, "start": 383.8, "text": "But"}, {"end": 384.96, "start": 384.12, "text": "as"}, {"end": 385.36, "start": 384.96, "text": "I"}, {"end": 386.12, "start": 385.36, "text": "said"}, {"end": 387.04, "start": 386.12, "text": "before,"}, {"end": 387.92, "start": 387.04, "text": "we"}, {"end": 388.16, "start": 387.92, "text": "have"}, {"end": 388.68, "start": 388.16, "text": "created"}, {"end": 389.08, "start": 388.68, "text": "an"}, {"end": 389.6, "start": 389.08, "text": "application"}, {"end": 389.96, "start": 389.6, "text": "named"}], "text": " So this is the first one is LastPass. It uses a heuristic based mapping. So you receive the package name, is split in several components by the dots and the domain name in the reverse order. So for example, com.facebook.katana is the original package name of the Facebook app and this maps to facebook.com. But as I said before, we have created an application named"}, {"chunks": [{"end": 391.56, "start": 390.0, "text": "come.facebook.fake"}, {"end": 391.56, "start": 391.56, "text": "and"}, {"end": 391.56, "start": 391.56, "text": "as"}, {"end": 391.6, "start": 391.56, "text": "you"}, {"end": 392.12, "start": 391.6, "text": "can"}, {"end": 392.44, "start": 392.12, "text": "see"}, {"end": 392.88, "start": 392.44, "text": "from"}, {"end": 393.16, "start": 392.88, "text": "the"}, {"end": 393.32, "start": 393.16, "text": "image"}, {"end": 393.6, "start": 393.32, "text": "last"}, {"end": 393.88, "start": 393.6, "text": "past"}, {"end": 394.2, "start": 393.88, "text": "will"}, {"end": 394.6, "start": 394.2, "text": "auto"}, {"end": 394.88, "start": 394.6, "text": "suggest"}, {"end": 395.0, "start": 394.88, "text": "the"}, {"end": 395.4, "start": 395.0, "text": "Facebook"}, {"end": 396.04, "start": 395.4, "text": "credential"}, {"end": 396.48, "start": 396.04, "text": "to"}, {"end": 397.12, "start": 396.48, "text": "our"}, {"end": 397.76, "start": 397.12, "text": "application."}, {"end": 397.8, "start": 397.76, "text": "And"}, {"end": 398.24, "start": 397.8, "text": "this"}, {"end": 398.88, "start": 398.24, "text": "is"}, {"end": 399.4, "start": 398.88, "text": "really,"}, {"end": 399.68, "start": 399.4, "text": "really"}, {"end": 399.96, "start": 399.68, "text": "bad"}, {"end": 400.44, "start": 399.96, "text": "for"}, {"end": 400.76, "start": 400.44, "text": "the"}, {"end": 400.8, "start": 400.76, "text": "user"}, {"end": 401.16, "start": 400.8, "text": "because"}, {"end": 401.76, "start": 401.16, "text": "the"}, {"end": 402.24, "start": 401.76, "text": "user"}, {"end": 403.16, "start": 402.24, "text": "that"}, {"end": 403.72, "start": 403.16, "text": "think"}, {"end": 403.96, "start": 403.72, "text": "in"}, {"end": 404.24, "start": 403.96, "text": "the"}, {"end": 404.6, "start": 404.24, "text": "web"}, {"end": 405.6, "start": 404.6, "text": "world"}, {"end": 405.92, "start": 405.6, "text": "way"}, {"end": 406.32, "start": 405.92, "text": "think"}, {"end": 406.36, "start": 406.32, "text": "that"}, {"end": 406.72, "start": 406.36, "text": "this"}, {"end": 407.04, "start": 406.72, "text": "is"}, {"end": 407.04, "start": 407.04, "text": "the"}, {"end": 407.44, "start": 407.04, "text": "legitimate"}, {"end": 408.0, "start": 407.44, "text": "Facebook"}, {"end": 409.28, "start": 408.0, "text": "app."}, {"end": 409.72, "start": 409.28, "text": "Dashlane"}, {"end": 410.32, "start": 409.72, "text": "behave"}, {"end": 410.72, "start": 410.32, "text": "quite"}, {"end": 410.84, "start": 410.72, "text": "in"}, {"end": 410.92, "start": 410.84, "text": "the"}, {"end": 411.36, "start": 410.92, "text": "same"}, {"end": 411.8, "start": 411.36, "text": "way"}, {"end": 412.32, "start": 411.8, "text": "with"}, {"end": 412.8, "start": 412.32, "text": "the"}, {"end": 413.52, "start": 412.8, "text": "difference"}, {"end": 413.8, "start": 413.52, "text": "that"}, {"end": 414.32, "start": 413.8, "text": "since"}, {"end": 414.64, "start": 414.32, "text": "you"}, {"end": 415.2, "start": 414.64, "text": "split"}, {"end": 415.48, "start": 415.2, "text": "the"}, {"end": 415.92, "start": 415.48, "text": "domain"}, {"end": 416.72, "start": 415.92, "text": "name"}, {"end": 417.04, "start": 416.72, "text": "by"}, {"end": 417.28, "start": 417.04, "text": "the"}, {"end": 417.6, "start": 417.28, "text": "dots,"}, {"end": 417.92, "start": 417.6, "text": "it"}, {"end": 418.52, "start": 417.92, "text": "checks"}, {"end": 418.52, "start": 418.52, "text": "if"}, {"end": 418.56, "start": 418.52, "text": "at"}, {"end": 419.12, "start": 418.56, "text": "least"}, {"end": 419.32, "start": 419.12, "text": "the"}, {"end": 419.96, "start": 419.32, "text": "free"}], "text": " come.facebook.fake and as you can see from the image last past will auto suggest the Facebook credential to our application. And this is really, really bad for the user because the user that think in the web world way think that this is the legitimate Facebook app. Dashlane behave quite in the same way with the difference that since you split the domain name by the dots, it checks if at least the free"}, {"chunks": [{"end": 420.12, "start": 420.0, "text": "the"}, {"end": 420.8, "start": 420.12, "text": "consecutive"}, {"end": 421.56, "start": 420.8, "text": "characters"}, {"end": 421.88, "start": 421.56, "text": "are"}, {"end": 421.96, "start": 421.88, "text": "in"}, {"end": 422.0, "start": 421.96, "text": "the"}, {"end": 422.52, "start": 422.0, "text": "domain."}, {"end": 422.64, "start": 422.52, "text": "And"}, {"end": 423.12, "start": 422.64, "text": "here"}, {"end": 423.52, "start": 423.12, "text": "the"}, {"end": 424.12, "start": 423.52, "text": "exploitation"}, {"end": 424.24, "start": 424.12, "text": "is"}, {"end": 425.0, "start": 424.24, "text": "more"}, {"end": 425.52, "start": 425.0, "text": "powerful,"}, {"end": 425.68, "start": 425.52, "text": "is"}, {"end": 426.0, "start": 425.68, "text": "more"}, {"end": 426.68, "start": 426.0, "text": "effective"}, {"end": 427.08, "start": 426.68, "text": "because"}, {"end": 427.4, "start": 427.08, "text": "with"}, {"end": 427.68, "start": 427.4, "text": "the"}, {"end": 428.36, "start": 427.68, "text": "package"}, {"end": 428.92, "start": 428.36, "text": "name"}, {"end": 429.12, "start": 428.92, "text": "like"}, {"end": 429.44, "start": 429.12, "text": "FAC,"}, {"end": 430.12, "start": 429.44, "text": "TAG,"}, {"end": 430.84, "start": 430.12, "text": "B"}, {"end": 431.2, "start": 430.84, "text": "E"}, {"end": 431.68, "start": 431.2, "text": "R,"}, {"end": 432.0, "start": 431.68, "text": "you"}, {"end": 432.2, "start": 432.0, "text": "are"}, {"end": 432.64, "start": 432.2, "text": "able"}, {"end": 432.88, "start": 432.64, "text": "to"}, {"end": 433.56, "start": 432.88, "text": "make"}, {"end": 434.64, "start": 433.56, "text": "several,"}, {"end": 435.12, "start": 434.64, "text": "um,"}, {"end": 435.84, "start": 435.12, "text": "credential"}, {"end": 436.28, "start": 435.84, "text": "suggested."}, {"end": 436.32, "start": 436.28, "text": "The"}, {"end": 436.32, "start": 436.32, "text": "other"}, {"end": 436.56, "start": 436.32, "text": "one"}, {"end": 436.6, "start": 436.56, "text": "is"}, {"end": 437.4, "start": 436.6, "text": "keeper."}, {"end": 438.04, "start": 437.4, "text": "So"}, {"end": 438.36, "start": 438.04, "text": "as"}, {"end": 438.68, "start": 438.36, "text": "I"}, {"end": 438.88, "start": 438.68, "text": "say"}, {"end": 440.04, "start": 438.88, "text": "that"}, {"end": 440.4, "start": 440.04, "text": "the"}, {"end": 441.16, "start": 440.4, "text": "package"}, {"end": 441.36, "start": 441.16, "text": "name"}, {"end": 442.24, "start": 441.36, "text": "uniquely"}, {"end": 442.96, "start": 442.24, "text": "identified"}, {"end": 443.48, "start": 442.96, "text": "Android"}, {"end": 443.64, "start": 443.48, "text": "app"}, {"end": 443.64, "start": 443.64, "text": "on"}, {"end": 443.84, "start": 443.64, "text": "the"}, {"end": 444.2, "start": 443.84, "text": "Google"}, {"end": 444.48, "start": 444.2, "text": "play"}, {"end": 444.92, "start": 444.48, "text": "store."}, {"end": 445.32, "start": 444.92, "text": "So"}, {"end": 445.48, "start": 445.32, "text": "it"}, {"end": 445.88, "start": 445.48, "text": "builds"}, {"end": 446.24, "start": 445.88, "text": "a"}, {"end": 446.72, "start": 446.24, "text": "U"}, {"end": 447.36, "start": 446.72, "text": "and"}, {"end": 447.56, "start": 447.36, "text": "URL"}, {"end": 447.76, "start": 447.56, "text": "starting"}, {"end": 448.04, "start": 447.76, "text": "from"}, {"end": 448.2, "start": 448.04, "text": "the"}, {"end": 448.48, "start": 448.2, "text": "package"}, {"end": 448.8, "start": 448.48, "text": "name"}, {"end": 449.4, "start": 448.8, "text": "and"}, {"end": 449.76, "start": 449.4, "text": "it"}, {"end": 449.96, "start": 449.76, "text": "down"}], "text": " the consecutive characters are in the domain. And here the exploitation is more powerful, is more effective because with the package name like FAC, TAG, B E R, you are able to make several, um, credential suggested. The other one is keeper. So as I say that the package name uniquely identified Android app on the Google play store. So it builds a U and URL starting from the package name and it down"}, {"chunks": [{"end": 450.88, "start": 450.0, "text": "loads"}, {"end": 451.28, "start": 450.88, "text": "and"}, {"end": 451.72, "start": 451.28, "text": "the"}, {"end": 452.08, "start": 451.72, "text": "web,"}, {"end": 453.12, "start": 452.08, "text": "the"}, {"end": 453.48, "start": 453.12, "text": "web"}, {"end": 454.12, "start": 453.48, "text": "page"}, {"end": 454.36, "start": 454.12, "text": "of"}, {"end": 454.56, "start": 454.36, "text": "the"}, {"end": 454.8, "start": 454.56, "text": "Android"}, {"end": 455.32, "start": 454.8, "text": "application"}, {"end": 455.6, "start": 455.32, "text": "from"}, {"end": 455.6, "start": 455.6, "text": "the"}, {"end": 455.92, "start": 455.6, "text": "Google"}, {"end": 456.24, "start": 455.92, "text": "Play"}, {"end": 456.56, "start": 456.24, "text": "Store"}, {"end": 457.12, "start": 456.56, "text": "and"}, {"end": 457.72, "start": 457.12, "text": "it"}, {"end": 458.92, "start": 457.72, "text": "trusts"}, {"end": 459.12, "start": 458.92, "text": "the"}, {"end": 460.28, "start": 459.12, "text": "domain."}, {"end": 461.0, "start": 460.28, "text": "Sorry."}, {"end": 461.24, "start": 461.0, "text": "Yes."}, {"end": 461.36, "start": 461.24, "text": "The"}, {"end": 461.84, "start": 461.36, "text": "domain"}, {"end": 461.88, "start": 461.84, "text": "that"}, {"end": 463.04, "start": 461.88, "text": "defined"}, {"end": 463.44, "start": 463.04, "text": "in"}, {"end": 463.84, "start": 463.44, "text": "the"}, {"end": 464.76, "start": 463.84, "text": "developer"}, {"end": 465.4, "start": 464.76, "text": "website"}, {"end": 465.92, "start": 465.4, "text": "field."}, {"end": 466.84, "start": 465.92, "text": "But"}, {"end": 467.88, "start": 466.84, "text": "again,"}, {"end": 468.04, "start": 467.88, "text": "it's"}, {"end": 468.32, "start": 468.04, "text": "attacker"}, {"end": 469.48, "start": 468.32, "text": "controlled."}, {"end": 469.96, "start": 469.48, "text": "So"}, {"end": 470.32, "start": 469.96, "text": "we,"}, {"end": 471.08, "start": 470.32, "text": "when"}, {"end": 471.6, "start": 471.08, "text": "we"}, {"end": 471.8, "start": 471.6, "text": "uploaded"}, {"end": 471.8, "start": 471.8, "text": "that"}, {"end": 472.32, "start": 471.8, "text": "application"}, {"end": 472.6, "start": 472.32, "text": "that"}, {"end": 472.88, "start": 472.6, "text": "come"}, {"end": 474.08, "start": 472.88, "text": "facebook.fake,"}, {"end": 474.24, "start": 474.08, "text": "we"}, {"end": 474.92, "start": 474.24, "text": "also"}, {"end": 475.4, "start": 474.92, "text": "set"}, {"end": 475.68, "start": 475.4, "text": "in"}, {"end": 475.84, "start": 475.68, "text": "the"}, {"end": 476.08, "start": 475.84, "text": "field,"}, {"end": 477.8, "start": 476.08, "text": "facebook.com"}, {"end": 478.08, "start": 477.8, "text": "as"}, {"end": 478.76, "start": 478.08, "text": "the"}, {"end": 479.24, "start": 478.76, "text": "developer,"}, {"end": 479.96, "start": 479.24, "text": "uh,"}], "text": " loads and the web, the web page of the Android application from the Google Play Store and it trusts the domain. Sorry. Yes. The domain that defined in the developer website field. But again, it's attacker controlled. So we, when we uploaded that application that come facebook.fake, we also set in the field, facebook.com as the developer, uh,"}, {"chunks": [{"end": 481.04, "start": 480.0, "text": "developer"}, {"end": 484.2, "start": 481.04, "text": "website."}, {"end": 484.44, "start": 484.2, "text": "One"}, {"end": 485.08, "start": 484.44, "text": "password"}, {"end": 485.64, "start": 485.08, "text": "doesn't"}, {"end": 486.28, "start": 485.64, "text": "provide"}, {"end": 486.76, "start": 486.28, "text": "any"}, {"end": 487.2, "start": 486.76, "text": "mapping,"}, {"end": 487.52, "start": 487.2, "text": "so"}, {"end": 488.12, "start": 487.52, "text": "it"}, {"end": 488.8, "start": 488.12, "text": "trivially"}, {"end": 489.32, "start": 488.8, "text": "suggests"}, {"end": 489.68, "start": 489.32, "text": "every"}, {"end": 490.16, "start": 489.68, "text": "previously"}, {"end": 490.64, "start": 490.16, "text": "saved"}, {"end": 491.24, "start": 490.64, "text": "credential"}, {"end": 491.48, "start": 491.24, "text": "to"}, {"end": 492.28, "start": 491.48, "text": "the"}, {"end": 493.12, "start": 492.28, "text": "user."}, {"end": 493.44, "start": 493.12, "text": "But"}, {"end": 493.72, "start": 493.44, "text": "for"}, {"end": 493.92, "start": 493.72, "text": "the"}, {"end": 494.2, "start": 493.92, "text": "sake"}, {"end": 494.32, "start": 494.2, "text": "of"}, {"end": 495.04, "start": 494.32, "text": "precision,"}, {"end": 495.4, "start": 495.04, "text": "this"}, {"end": 495.76, "start": 495.4, "text": "is"}, {"end": 496.12, "start": 495.76, "text": "a"}, {"end": 496.64, "start": 496.12, "text": "screenshot"}, {"end": 496.92, "start": 496.64, "text": "that"}, {"end": 497.28, "start": 496.92, "text": "is"}, {"end": 497.64, "start": 497.28, "text": "taken"}, {"end": 497.88, "start": 497.64, "text": "from"}, {"end": 497.88, "start": 497.88, "text": "a"}, {"end": 498.52, "start": 497.88, "text": "conversation"}, {"end": 498.76, "start": 498.52, "text": "with"}, {"end": 498.92, "start": 498.76, "text": "the"}, {"end": 499.12, "start": 498.92, "text": "one"}, {"end": 499.84, "start": 499.12, "text": "password"}, {"end": 500.24, "start": 499.84, "text": "developers."}, {"end": 500.72, "start": 500.24, "text": "If"}, {"end": 501.68, "start": 500.72, "text": "you"}, {"end": 502.04, "start": 501.68, "text": "are"}, {"end": 502.44, "start": 502.04, "text": "trying"}, {"end": 503.6, "start": 502.44, "text": "to"}, {"end": 505.28, "start": 503.6, "text": "fill"}, {"end": 505.52, "start": 505.28, "text": "a"}, {"end": 506.16, "start": 505.52, "text": "form"}, {"end": 506.4, "start": 506.16, "text": "of"}, {"end": 506.92, "start": 506.4, "text": "an"}, {"end": 507.64, "start": 506.92, "text": "application"}, {"end": 508.04, "start": 507.64, "text": "and"}, {"end": 508.44, "start": 508.04, "text": "you"}, {"end": 508.56, "start": 508.44, "text": "have"}, {"end": 509.08, "start": 508.56, "text": "already"}, {"end": 509.6, "start": 509.08, "text": "used"}, {"end": 509.96, "start": 509.6, "text": "those"}], "text": " developer website. One password doesn't provide any mapping, so it trivially suggests every previously saved credential to the user. But for the sake of precision, this is a screenshot that is taken from a conversation with the one password developers. If you are trying to fill a form of an application and you have already used those"}, {"chunks": [{"end": 510.64, "start": 510.0, "text": "credential"}, {"end": 511.04, "start": 510.64, "text": "for"}, {"end": 511.4, "start": 511.04, "text": "another"}, {"end": 512.32, "start": 511.4, "text": "application,"}, {"end": 512.56, "start": 512.32, "text": "one"}, {"end": 513.8, "start": 512.56, "text": "password"}, {"end": 514.0, "start": 513.8, "text": "is"}, {"end": 514.52, "start": 514.0, "text": "warning"}, {"end": 514.64, "start": 514.52, "text": "you"}, {"end": 514.76, "start": 514.64, "text": "that,"}, {"end": 515.48, "start": 514.76, "text": "hey,"}, {"end": 516.16, "start": 515.48, "text": "I"}, {"end": 516.76, "start": 516.16, "text": "can't"}, {"end": 517.24, "start": 516.76, "text": "securely"}, {"end": 517.32, "start": 517.24, "text": "map"}, {"end": 517.6, "start": 517.32, "text": "this."}, {"end": 517.76, "start": 517.6, "text": "You"}, {"end": 517.8, "start": 517.76, "text": "have"}, {"end": 518.16, "start": 517.8, "text": "already"}, {"end": 518.44, "start": 518.16, "text": "used"}, {"end": 519.12, "start": 518.44, "text": "those"}, {"end": 520.08, "start": 519.12, "text": "credentials"}, {"end": 520.32, "start": 520.08, "text": "for"}, {"end": 520.64, "start": 520.32, "text": "another"}, {"end": 521.2, "start": 520.64, "text": "application."}, {"end": 521.4, "start": 521.2, "text": "Do"}, {"end": 521.48, "start": 521.4, "text": "you"}, {"end": 521.76, "start": 521.48, "text": "want"}, {"end": 522.08, "start": 521.76, "text": "to"}, {"end": 524.04, "start": 522.08, "text": "fill"}, {"end": 524.32, "start": 524.04, "text": "it"}, {"end": 524.76, "start": 524.32, "text": "anyway?"}, {"end": 525.32, "start": 524.76, "text": "Google"}, {"end": 525.64, "start": 525.32, "text": "Smart"}, {"end": 526.2, "start": 525.64, "text": "Lock"}, {"end": 527.08, "start": 526.2, "text": "is"}, {"end": 527.64, "start": 527.08, "text": "securely"}, {"end": 528.88, "start": 527.64, "text": "implemented."}, {"end": 529.28, "start": 528.88, "text": "We"}, {"end": 530.28, "start": 529.28, "text": "found"}, {"end": 530.6, "start": 530.28, "text": "no"}, {"end": 531.6, "start": 530.6, "text": "vulnerabilities,"}, {"end": 532.32, "start": 531.6, "text": "but"}, {"end": 532.8, "start": 532.32, "text": "we"}, {"end": 533.0, "start": 532.8, "text": "also"}, {"end": 533.68, "start": 533.0, "text": "discovered"}, {"end": 533.92, "start": 533.68, "text": "that"}, {"end": 534.12, "start": 533.92, "text": "the"}, {"end": 534.68, "start": 534.12, "text": "burden"}, {"end": 534.92, "start": 534.68, "text": "of"}, {"end": 535.2, "start": 534.92, "text": "the"}, {"end": 535.6, "start": 535.2, "text": "mapping"}, {"end": 535.8, "start": 535.6, "text": "is"}, {"end": 536.28, "start": 535.8, "text": "delegated"}, {"end": 536.44, "start": 536.28, "text": "to"}, {"end": 536.48, "start": 536.44, "text": "the"}, {"end": 536.72, "start": 536.48, "text": "user."}, {"end": 537.2, "start": 536.72, "text": "So"}, {"end": 537.44, "start": 537.2, "text": "if"}, {"end": 537.52, "start": 537.44, "text": "you"}, {"end": 538.04, "start": 537.52, "text": "are"}, {"end": 538.36, "start": 538.04, "text": "an"}, {"end": 538.64, "start": 538.36, "text": "Android"}, {"end": 538.92, "start": 538.64, "text": "developer"}, {"end": 539.28, "start": 538.92, "text": "and"}, {"end": 539.6, "start": 539.28, "text": "you"}, {"end": 539.96, "start": 539.6, "text": "want"}], "text": " credential for another application, one password is warning you that, hey, I can't securely map this. You have already used those credentials for another application. Do you want to fill it anyway? Google Smart Lock is securely implemented. We found no vulnerabilities, but we also discovered that the burden of the mapping is delegated to the user. So if you are an Android developer and you want"}, {"chunks": [{"end": 540.16, "start": 540.0, "text": "that"}, {"end": 540.64, "start": 540.16, "text": "your"}, {"end": 541.16, "start": 540.64, "text": "application"}, {"end": 541.4, "start": 541.16, "text": "will"}, {"end": 541.68, "start": 541.4, "text": "be"}, {"end": 543.16, "start": 541.68, "text": "compliant"}, {"end": 543.48, "start": 543.16, "text": "with"}, {"end": 543.72, "start": 543.48, "text": "the"}, {"end": 544.08, "start": 543.72, "text": "Google"}, {"end": 544.36, "start": 544.08, "text": "Smart"}, {"end": 544.36, "start": 544.36, "text": "Lock,"}, {"end": 544.4, "start": 544.36, "text": "you"}, {"end": 544.72, "start": 544.4, "text": "have"}, {"end": 544.96, "start": 544.72, "text": "to"}, {"end": 545.6, "start": 544.96, "text": "fill"}, {"end": 546.12, "start": 545.6, "text": "a"}, {"end": 546.88, "start": 546.12, "text": "Google"}, {"end": 547.44, "start": 546.88, "text": "form"}, {"end": 548.04, "start": 547.44, "text": "in"}, {"end": 548.4, "start": 548.04, "text": "which"}, {"end": 548.72, "start": 548.4, "text": "you"}, {"end": 549.92, "start": 548.72, "text": "specify"}, {"end": 550.32, "start": 549.92, "text": "the"}, {"end": 551.64, "start": 550.32, "text": "application"}, {"end": 552.56, "start": 551.64, "text": "package"}, {"end": 553.16, "start": 552.56, "text": "name"}, {"end": 554.0, "start": 553.16, "text": "and"}, {"end": 554.28, "start": 554.0, "text": "your"}, {"end": 554.64, "start": 554.28, "text": "website,"}, {"end": 554.92, "start": 554.64, "text": "and"}, {"end": 555.24, "start": 554.92, "text": "then"}, {"end": 556.2, "start": 555.24, "text": "Google"}, {"end": 556.64, "start": 556.2, "text": "uses"}, {"end": 557.16, "start": 556.64, "text": "a"}, {"end": 557.48, "start": 557.16, "text": "protocol."}, {"end": 557.96, "start": 557.48, "text": "I"}, {"end": 558.28, "start": 557.96, "text": "will"}, {"end": 558.56, "start": 558.28, "text": "explain"}, {"end": 558.56, "start": 558.56, "text": "you"}, {"end": 559.08, "start": 558.56, "text": "this"}, {"end": 559.56, "start": 559.08, "text": "protocol"}, {"end": 560.6, "start": 559.56, "text": "later."}, {"end": 560.92, "start": 560.6, "text": "And"}, {"end": 561.56, "start": 560.92, "text": "yes,"}, {"end": 561.76, "start": 561.56, "text": "it"}, {"end": 562.2, "start": 561.76, "text": "works,"}, {"end": 562.44, "start": 562.2, "text": "but"}, {"end": 562.8, "start": 562.44, "text": "this"}, {"end": 563.2, "start": 562.8, "text": "mapping"}, {"end": 563.48, "start": 563.2, "text": "is"}, {"end": 563.72, "start": 563.48, "text": "not"}, {"end": 564.4, "start": 563.72, "text": "public."}, {"end": 564.56, "start": 564.4, "text": "So"}, {"end": 564.96, "start": 564.56, "text": "Google"}, {"end": 566.0, "start": 564.96, "text": "doesn't"}, {"end": 566.44, "start": 566.0, "text": "share"}, {"end": 568.92, "start": 566.44, "text": "this"}, {"end": 569.44, "start": 568.92, "text": "mapping."}, {"end": 569.96, "start": 569.44, "text": "Okay."}], "text": " that your application will be compliant with the Google Smart Lock, you have to fill a Google form in which you specify the application package name and your website, and then Google uses a protocol. I will explain you this protocol later. And yes, it works, but this mapping is not public. So Google doesn't share this mapping. Okay."}, {"chunks": [{"end": 570.24, "start": 570.0, "text": "the"}, {"end": 570.68, "start": 570.24, "text": "situation"}, {"end": 571.0, "start": 570.68, "text": "can"}, {"end": 571.12, "start": 571.0, "text": "get"}, {"end": 571.96, "start": 571.12, "text": "worse."}, {"end": 574.56, "start": 571.96, "text": "We"}, {"end": 575.04, "start": 574.56, "text": "were"}, {"end": 575.36, "start": 575.04, "text": "able"}, {"end": 575.64, "start": 575.36, "text": "to"}, {"end": 576.56, "start": 575.64, "text": "hide"}, {"end": 577.16, "start": 576.56, "text": "with"}, {"end": 577.64, "start": 577.16, "text": "several"}, {"end": 578.2, "start": 577.64, "text": "techniques"}, {"end": 578.84, "start": 578.2, "text": "the"}, {"end": 579.6, "start": 578.84, "text": "username"}, {"end": 580.16, "start": 579.6, "text": "field"}, {"end": 580.36, "start": 580.16, "text": "and"}, {"end": 580.72, "start": 580.36, "text": "this"}, {"end": 581.12, "start": 580.72, "text": "in"}, {"end": 581.6, "start": 581.12, "text": "the"}, {"end": 581.6, "start": 581.6, "text": "web"}, {"end": 581.64, "start": 581.6, "text": "world"}, {"end": 582.12, "start": 581.64, "text": "is"}, {"end": 583.04, "start": 582.12, "text": "no"}, {"end": 583.32, "start": 583.04, "text": "more"}, {"end": 584.0, "start": 583.32, "text": "possible,"}, {"end": 584.2, "start": 584.0, "text": "but"}, {"end": 584.88, "start": 584.2, "text": "here,"}, {"end": 586.12, "start": 584.88, "text": "yes,"}, {"end": 586.6, "start": 586.12, "text": "here"}, {"end": 586.96, "start": 586.6, "text": "it"}, {"end": 587.28, "start": 586.96, "text": "still"}, {"end": 587.72, "start": 587.28, "text": "works."}, {"end": 588.0, "start": 587.72, "text": "Every"}, {"end": 588.36, "start": 588.0, "text": "password"}, {"end": 588.88, "start": 588.36, "text": "manager,"}, {"end": 589.04, "start": 588.88, "text": "now"}, {"end": 589.2, "start": 589.04, "text": "I'm"}, {"end": 589.88, "start": 589.2, "text": "using"}, {"end": 590.52, "start": 589.88, "text": "LastPass,"}, {"end": 591.12, "start": 590.52, "text": "but"}, {"end": 591.48, "start": 591.12, "text": "every"}, {"end": 592.16, "start": 591.48, "text": "password"}, {"end": 592.72, "start": 592.16, "text": "manager"}, {"end": 592.88, "start": 592.72, "text": "will"}, {"end": 593.64, "start": 592.88, "text": "continue"}, {"end": 593.76, "start": 593.64, "text": "to"}, {"end": 594.32, "start": 593.76, "text": "suggest"}, {"end": 594.56, "start": 594.32, "text": "you"}, {"end": 594.72, "start": 594.56, "text": "the"}, {"end": 595.36, "start": 594.72, "text": "credential"}, {"end": 595.68, "start": 595.36, "text": "and"}, {"end": 596.04, "start": 595.68, "text": "when"}, {"end": 596.08, "start": 596.04, "text": "you"}, {"end": 596.48, "start": 596.08, "text": "click"}, {"end": 596.76, "start": 596.48, "text": "on"}, {"end": 596.88, "start": 596.76, "text": "it,"}, {"end": 597.04, "start": 596.88, "text": "you"}, {"end": 597.48, "start": 597.04, "text": "can"}, {"end": 598.12, "start": 597.48, "text": "steal"}, {"end": 598.2, "start": 598.12, "text": "the"}, {"end": 598.72, "start": 598.2, "text": "password."}, {"end": 598.8, "start": 598.72, "text": "And"}, {"end": 598.96, "start": 598.8, "text": "this"}, {"end": 599.36, "start": 598.96, "text": "is"}, {"end": 599.96, "start": 599.36, "text": "very"}], "text": " the situation can get worse. We were able to hide with several techniques the username field and this in the web world is no more possible, but here, yes, here it still works. Every password manager, now I'm using LastPass, but every password manager will continue to suggest you the credential and when you click on it, you can steal the password. And this is very"}, {"chunks": [{"end": 600.6, "start": 600.0, "text": "confusing"}, {"end": 600.92, "start": 600.6, "text": "for"}, {"end": 601.16, "start": 600.92, "text": "the"}, {"end": 601.56, "start": 601.16, "text": "user"}, {"end": 602.16, "start": 601.56, "text": "because"}, {"end": 602.48, "start": 602.16, "text": "the"}, {"end": 602.52, "start": 602.48, "text": "user"}, {"end": 602.96, "start": 602.52, "text": "thinks"}, {"end": 603.0, "start": 602.96, "text": "that"}, {"end": 603.2, "start": 603.0, "text": "he's"}, {"end": 603.6, "start": 603.2, "text": "just"}, {"end": 604.2, "start": 603.6, "text": "inserting"}, {"end": 604.56, "start": 604.2, "text": "his"}, {"end": 605.24, "start": 604.56, "text": "username"}, {"end": 605.76, "start": 605.24, "text": "but"}, {"end": 605.88, "start": 605.76, "text": "in"}, {"end": 606.12, "start": 605.88, "text": "the"}, {"end": 606.4, "start": 606.12, "text": "background"}, {"end": 606.52, "start": 606.4, "text": "you"}, {"end": 606.92, "start": 606.52, "text": "can"}, {"end": 607.28, "start": 606.92, "text": "steal"}, {"end": 607.64, "start": 607.28, "text": "his"}, {"end": 609.68, "start": 607.64, "text": "password."}, {"end": 610.52, "start": 609.68, "text": "Okay,"}, {"end": 610.84, "start": 610.52, "text": "I'm"}, {"end": 611.48, "start": 610.84, "text": "finished"}, {"end": 612.68, "start": 611.48, "text": "with"}, {"end": 613.12, "start": 612.68, "text": "the"}, {"end": 613.28, "start": 613.12, "text": "how"}, {"end": 613.32, "start": 613.28, "text": "to"}, {"end": 613.56, "start": 613.32, "text": "fill"}, {"end": 614.4, "start": 613.56, "text": "technologies."}, {"end": 614.92, "start": 614.4, "text": "Now"}, {"end": 615.12, "start": 614.92, "text": "we're"}, {"end": 615.16, "start": 615.12, "text": "moving"}, {"end": 615.24, "start": 615.16, "text": "to"}, {"end": 615.28, "start": 615.24, "text": "the"}, {"end": 615.72, "start": 615.28, "text": "instant"}, {"end": 616.68, "start": 615.72, "text": "apps."}, {"end": 616.76, "start": 616.68, "text": "As"}, {"end": 616.88, "start": 616.76, "text": "I"}, {"end": 617.28, "start": 616.88, "text": "said"}, {"end": 617.6, "start": 617.28, "text": "before,"}, {"end": 618.08, "start": 617.6, "text": "instant"}, {"end": 618.36, "start": 618.08, "text": "apps"}, {"end": 618.88, "start": 618.36, "text": "allows"}, {"end": 619.08, "start": 618.88, "text": "you"}, {"end": 619.28, "start": 619.08, "text": "to"}, {"end": 619.8, "start": 619.28, "text": "try"}, {"end": 620.44, "start": 619.8, "text": "application,"}, {"end": 621.0, "start": 620.44, "text": "a"}, {"end": 621.76, "start": 621.0, "text": "lightweight"}, {"end": 622.4, "start": 621.76, "text": "version"}, {"end": 622.4, "start": 622.4, "text": "of"}, {"end": 622.52, "start": 622.4, "text": "the"}, {"end": 623.44, "start": 622.52, "text": "application"}, {"end": 624.12, "start": 623.44, "text": "and"}, {"end": 624.4, "start": 624.12, "text": "another"}, {"end": 624.72, "start": 624.4, "text": "use"}, {"end": 625.28, "start": 624.72, "text": "case"}, {"end": 625.68, "start": 625.28, "text": "is"}, {"end": 626.6, "start": 625.68, "text": "when"}, {"end": 626.84, "start": 626.6, "text": "you"}, {"end": 628.2, "start": 626.84, "text": "visit"}, {"end": 628.56, "start": 628.2, "text": "a"}, {"end": 629.4, "start": 628.56, "text": "website"}, {"end": 629.96, "start": 629.4, "text": "that"}], "text": " confusing for the user because the user thinks that he's just inserting his username but in the background you can steal his password. Okay, I'm finished with the how to fill technologies. Now we're moving to the instant apps. As I said before, instant apps allows you to try application, a lightweight version of the application and another use case is when you visit a website that"}, {"chunks": [{"end": 630.0, "start": 630.0, "text": "that"}, {"end": 630.04, "start": 630.0, "text": "the"}, {"end": 630.72, "start": 630.04, "text": "developer"}, {"end": 630.84, "start": 630.72, "text": "of"}, {"end": 631.0, "start": 630.84, "text": "the"}, {"end": 631.72, "start": 631.0, "text": "website"}, {"end": 632.2, "start": 631.72, "text": "has"}, {"end": 632.48, "start": 632.2, "text": "an"}, {"end": 632.92, "start": 632.48, "text": "application"}, {"end": 633.04, "start": 632.92, "text": "which"}, {"end": 633.24, "start": 633.04, "text": "is"}, {"end": 634.2, "start": 633.24, "text": "compliant"}, {"end": 634.44, "start": 634.2, "text": "with"}, {"end": 634.56, "start": 634.44, "text": "the"}, {"end": 635.0, "start": 634.56, "text": "Instant"}, {"end": 635.16, "start": 635.0, "text": "App"}, {"end": 636.56, "start": 635.16, "text": "technology,"}, {"end": 637.12, "start": 636.56, "text": "a"}, {"end": 637.88, "start": 637.12, "text": "notification"}, {"end": 638.2, "start": 637.88, "text": "will"}, {"end": 639.12, "start": 638.2, "text": "appear."}, {"end": 639.24, "start": 639.12, "text": "You"}, {"end": 639.48, "start": 639.24, "text": "click"}, {"end": 639.68, "start": 639.48, "text": "on"}, {"end": 639.96, "start": 639.68, "text": "it,"}, {"end": 640.16, "start": 639.96, "text": "the"}, {"end": 641.04, "start": 640.16, "text": "Instant"}, {"end": 641.28, "start": 641.04, "text": "App"}, {"end": 641.88, "start": 641.28, "text": "loading"}, {"end": 642.44, "start": 641.88, "text": "screen"}, {"end": 643.04, "start": 642.44, "text": "appears,"}, {"end": 644.0, "start": 643.04, "text": "and"}, {"end": 644.44, "start": 644.0, "text": "a"}, {"end": 644.76, "start": 644.44, "text": "lightweight"}, {"end": 645.4, "start": 644.76, "text": "version"}, {"end": 645.6, "start": 645.4, "text": "of"}, {"end": 645.88, "start": 645.6, "text": "the"}, {"end": 645.88, "start": 645.88, "text": "app"}, {"end": 646.08, "start": 645.88, "text": "now"}, {"end": 646.24, "start": 646.08, "text": "is"}, {"end": 646.64, "start": 646.24, "text": "running"}, {"end": 647.12, "start": 646.64, "text": "on"}, {"end": 647.76, "start": 647.12, "text": "your"}, {"end": 648.96, "start": 647.76, "text": "phone."}, {"end": 649.2, "start": 648.96, "text": "But"}, {"end": 649.76, "start": 649.2, "text": "here,"}, {"end": 650.08, "start": 649.76, "text": "there"}, {"end": 650.76, "start": 650.08, "text": "is"}, {"end": 651.12, "start": 650.76, "text": "something"}, {"end": 651.44, "start": 651.12, "text": "really"}, {"end": 651.84, "start": 651.44, "text": "juicy"}, {"end": 651.92, "start": 651.84, "text": "for"}, {"end": 652.28, "start": 651.92, "text": "an"}, {"end": 654.12, "start": 652.28, "text": "attacker."}, {"end": 654.48, "start": 654.12, "text": "Here,"}, {"end": 654.6, "start": 654.48, "text": "an"}, {"end": 654.8, "start": 654.6, "text": "attacker"}, {"end": 655.2, "start": 654.8, "text": "has"}, {"end": 655.24, "start": 655.2, "text": "the"}, {"end": 655.72, "start": 655.24, "text": "full"}, {"end": 656.24, "start": 655.72, "text": "control"}, {"end": 656.24, "start": 656.24, "text": "of"}, {"end": 656.28, "start": 656.24, "text": "the"}, {"end": 656.68, "start": 656.28, "text": "user"}, {"end": 657.68, "start": 656.68, "text": "interface,"}, {"end": 658.2, "start": 657.68, "text": "and"}, {"end": 658.52, "start": 658.2, "text": "he"}, {"end": 658.8, "start": 658.52, "text": "can"}, {"end": 658.96, "start": 658.8, "text": "mimic"}, {"end": 659.08, "start": 658.96, "text": "the"}, {"end": 659.96, "start": 659.08, "text": "behavior"}], "text": " that the developer of the website has an application which is compliant with the Instant App technology, a notification will appear. You click on it, the Instant App loading screen appears, and a lightweight version of the app now is running on your phone. But here, there is something really juicy for an attacker. Here, an attacker has the full control of the user interface, and he can mimic the behavior"}, {"chunks": [{"end": 660.12, "start": 660.0, "text": "a"}, {"end": 660.56, "start": 660.12, "text": "browser,"}, {"end": 660.72, "start": 660.56, "text": "for"}, {"end": 663.44, "start": 660.72, "text": "example."}, {"end": 664.04, "start": 663.44, "text": "So"}, {"end": 665.12, "start": 664.04, "text": "takeaways"}, {"end": 665.2, "start": 665.12, "text": "of"}, {"end": 665.48, "start": 665.2, "text": "the"}, {"end": 665.84, "start": 665.48, "text": "Eastern"}, {"end": 666.24, "start": 665.84, "text": "apps"}, {"end": 666.72, "start": 666.24, "text": "user"}, {"end": 666.84, "start": 666.72, "text": "can"}, {"end": 667.36, "start": 666.84, "text": "try"}, {"end": 667.72, "start": 667.36, "text": "Android"}, {"end": 668.48, "start": 667.72, "text": "application."}, {"end": 668.92, "start": 668.48, "text": "They"}, {"end": 669.16, "start": 668.92, "text": "just"}, {"end": 669.28, "start": 669.16, "text": "need"}, {"end": 669.6, "start": 669.28, "text": "the"}, {"end": 670.12, "start": 669.6, "text": "one"}, {"end": 670.4, "start": 670.12, "text": "click"}, {"end": 670.48, "start": 670.4, "text": "on"}, {"end": 670.6, "start": 670.48, "text": "a"}, {"end": 671.04, "start": 670.6, "text": "URL."}, {"end": 671.6, "start": 671.04, "text": "So"}, {"end": 672.04, "start": 671.6, "text": "we"}, {"end": 672.32, "start": 672.04, "text": "are"}, {"end": 672.64, "start": 672.32, "text": "moving"}, {"end": 672.92, "start": 672.64, "text": "from"}, {"end": 673.12, "start": 672.92, "text": "the"}, {"end": 673.56, "start": 673.12, "text": "web"}, {"end": 674.16, "start": 673.56, "text": "word,"}, {"end": 674.4, "start": 674.16, "text": "sorry,"}, {"end": 674.72, "start": 674.4, "text": "from"}, {"end": 675.24, "start": 674.72, "text": "the"}, {"end": 675.52, "start": 675.24, "text": "web"}, {"end": 676.04, "start": 675.52, "text": "phishing"}, {"end": 676.24, "start": 676.04, "text": "to"}, {"end": 676.52, "start": 676.24, "text": "the"}, {"end": 676.92, "start": 676.52, "text": "mobile"}, {"end": 677.92, "start": 676.92, "text": "phishing"}, {"end": 678.48, "start": 677.92, "text": "when"}, {"end": 678.8, "start": 678.48, "text": "the"}, {"end": 678.96, "start": 678.8, "text": "attacker"}, {"end": 679.36, "start": 678.96, "text": "has"}, {"end": 679.48, "start": 679.36, "text": "the"}, {"end": 679.92, "start": 679.48, "text": "full"}, {"end": 680.44, "start": 679.92, "text": "control"}, {"end": 680.48, "start": 680.44, "text": "of"}, {"end": 680.8, "start": 680.48, "text": "the"}, {"end": 681.28, "start": 680.8, "text": "user"}, {"end": 682.32, "start": 681.28, "text": "interface."}, {"end": 682.96, "start": 682.32, "text": "And"}, {"end": 683.32, "start": 682.96, "text": "as"}, {"end": 683.6, "start": 683.32, "text": "I"}, {"end": 684.76, "start": 683.6, "text": "said"}, {"end": 685.16, "start": 684.76, "text": "before,"}, {"end": 685.4, "start": 685.16, "text": "the"}, {"end": 685.6, "start": 685.4, "text": "Eastern"}, {"end": 685.96, "start": 685.6, "text": "apps"}, {"end": 686.64, "start": 685.96, "text": "doesn't"}, {"end": 686.96, "start": 686.64, "text": "need"}, {"end": 687.0, "start": 686.96, "text": "an"}, {"end": 687.6, "start": 687.0, "text": "installation,"}, {"end": 687.8, "start": 687.6, "text": "but"}, {"end": 688.04, "start": 687.8, "text": "this"}, {"end": 688.6, "start": 688.04, "text": "is,"}, {"end": 689.0, "start": 688.6, "text": "this"}, {"end": 689.28, "start": 689.0, "text": "is"}, {"end": 689.44, "start": 689.28, "text": "not"}, {"end": 689.96, "start": 689.44, "text": "true."}], "text": " a browser, for example. So takeaways of the Eastern apps user can try Android application. They just need the one click on a URL. So we are moving from the web word, sorry, from the web phishing to the mobile phishing when the attacker has the full control of the user interface. And as I said before, the Eastern apps doesn't need an installation, but this is, this is not true."}, {"chunks": [{"end": 690.2, "start": 690.0, "text": "In"}, {"end": 690.76, "start": 690.2, "text": "reality,"}, {"end": 691.08, "start": 690.76, "text": "the"}, {"end": 691.24, "start": 691.08, "text": "Android"}, {"end": 691.64, "start": 691.24, "text": "operating"}, {"end": 692.04, "start": 691.64, "text": "system"}, {"end": 692.36, "start": 692.04, "text": "will"}, {"end": 693.08, "start": 692.36, "text": "install"}, {"end": 693.28, "start": 693.08, "text": "a"}, {"end": 693.68, "start": 693.28, "text": "lightweight"}, {"end": 694.08, "start": 693.68, "text": "version"}, {"end": 694.2, "start": 694.08, "text": "of"}, {"end": 694.4, "start": 694.2, "text": "the"}, {"end": 695.0, "start": 694.4, "text": "application"}, {"end": 695.4, "start": 695.0, "text": "on"}, {"end": 695.52, "start": 695.4, "text": "the"}, {"end": 696.32, "start": 695.52, "text": "device."}, {"end": 696.36, "start": 696.32, "text": "And"}, {"end": 696.8, "start": 696.36, "text": "as"}, {"end": 697.16, "start": 696.8, "text": "I"}, {"end": 697.44, "start": 697.16, "text": "said"}, {"end": 697.84, "start": 697.44, "text": "before,"}, {"end": 698.12, "start": 697.84, "text": "on"}, {"end": 698.44, "start": 698.12, "text": "the"}, {"end": 699.72, "start": 698.44, "text": "device"}, {"end": 700.28, "start": 699.72, "text": "application"}, {"end": 700.56, "start": 700.28, "text": "are"}, {"end": 700.96, "start": 700.56, "text": "indexed"}, {"end": 701.6, "start": 700.96, "text": "by"}, {"end": 701.8, "start": 701.6, "text": "the"}, {"end": 702.16, "start": 701.8, "text": "package"}, {"end": 702.52, "start": 702.16, "text": "name."}, {"end": 702.72, "start": 702.52, "text": "So"}, {"end": 703.32, "start": 702.72, "text": "they"}, {"end": 703.36, "start": 703.32, "text": "have"}, {"end": 703.48, "start": 703.36, "text": "a"}, {"end": 703.84, "start": 703.48, "text": "package"}, {"end": 704.28, "start": 703.84, "text": "name"}, {"end": 704.6, "start": 704.28, "text": "and"}, {"end": 704.96, "start": 704.6, "text": "the"}, {"end": 705.64, "start": 704.96, "text": "password"}, {"end": 706.32, "start": 705.64, "text": "manager"}, {"end": 706.56, "start": 706.32, "text": "will"}, {"end": 706.72, "start": 706.56, "text": "out"}, {"end": 707.36, "start": 706.72, "text": "to"}, {"end": 707.68, "start": 707.36, "text": "fill"}, {"end": 707.88, "start": 707.68, "text": "the"}, {"end": 708.52, "start": 707.88, "text": "instant"}, {"end": 709.0, "start": 708.52, "text": "apps"}, {"end": 709.2, "start": 709.0, "text": "as"}, {"end": 709.56, "start": 709.2, "text": "normal"}, {"end": 710.2, "start": 709.56, "text": "application."}, {"end": 712.6, "start": 710.2, "text": "So"}, {"end": 712.88, "start": 712.6, "text": "let's"}, {"end": 713.12, "start": 712.88, "text": "put"}, {"end": 713.4, "start": 713.12, "text": "them"}, {"end": 713.76, "start": 713.4, "text": "together."}, {"end": 714.32, "start": 713.76, "text": "The"}, {"end": 714.96, "start": 714.32, "text": "auto-fill"}, {"end": 715.92, "start": 714.96, "text": "vulnerabilities"}, {"end": 716.24, "start": 715.92, "text": "and"}, {"end": 716.28, "start": 716.24, "text": "the"}, {"end": 716.68, "start": 716.28, "text": "instant"}, {"end": 716.96, "start": 716.68, "text": "app."}, {"end": 718.44, "start": 716.96, "text": "And"}, {"end": 718.92, "start": 718.44, "text": "let's"}, {"end": 719.52, "start": 718.92, "text": "create"}, {"end": 719.96, "start": 719.52, "text": "a"}], "text": " In reality, the Android operating system will install a lightweight version of the application on the device. And as I said before, on the device application are indexed by the package name. So they have a package name and the password manager will out to fill the instant apps as normal application. So let's put them together. The auto-fill vulnerabilities and the instant app. And let's create a"}, {"chunks": [{"end": 720.4, "start": 720.0, "text": "phishing"}, {"end": 720.4, "start": 720.4, "text": "attack."}, {"end": 720.6, "start": 720.4, "text": "So"}, {"end": 720.88, "start": 720.6, "text": "it's"}, {"end": 721.16, "start": 720.88, "text": "a"}, {"end": 722.04, "start": 721.16, "text": "phishing"}, {"end": 722.28, "start": 722.04, "text": "attack."}, {"end": 722.64, "start": 722.28, "text": "So"}, {"end": 723.2, "start": 722.64, "text": "we"}, {"end": 724.08, "start": 723.2, "text": "start"}, {"end": 724.44, "start": 724.08, "text": "with"}, {"end": 725.04, "start": 724.44, "text": "an"}, {"end": 725.72, "start": 725.04, "text": "URL."}, {"end": 726.16, "start": 725.72, "text": "You"}, {"end": 726.4, "start": 726.16, "text": "are"}, {"end": 726.64, "start": 726.4, "text": "in"}, {"end": 726.96, "start": 726.64, "text": "the"}, {"end": 727.32, "start": 726.96, "text": "web"}, {"end": 727.92, "start": 727.32, "text": "world,"}, {"end": 728.16, "start": 727.92, "text": "in"}, {"end": 728.36, "start": 728.16, "text": "the"}, {"end": 728.64, "start": 728.36, "text": "mobile"}, {"end": 728.84, "start": 728.64, "text": "world,"}, {"end": 729.08, "start": 728.84, "text": "so"}, {"end": 729.08, "start": 729.08, "text": "you"}, {"end": 729.12, "start": 729.08, "text": "can"}, {"end": 729.44, "start": 729.12, "text": "send"}, {"end": 729.8, "start": 729.44, "text": "an"}, {"end": 730.32, "start": 729.8, "text": "email,"}, {"end": 730.4, "start": 730.32, "text": "an"}, {"end": 731.12, "start": 730.4, "text": "SMS,"}, {"end": 731.92, "start": 731.12, "text": "WhatsApp"}, {"end": 732.36, "start": 731.92, "text": "message,"}, {"end": 732.96, "start": 732.36, "text": "whatsoever."}, {"end": 734.0, "start": 732.96, "text": "The"}, {"end": 734.4, "start": 734.0, "text": "user"}, {"end": 735.0, "start": 734.4, "text": "clicks"}, {"end": 735.8, "start": 735.0, "text": "and"}, {"end": 736.56, "start": 735.8, "text": "it"}, {"end": 737.28, "start": 736.56, "text": "reaches"}, {"end": 737.56, "start": 737.28, "text": "a"}, {"end": 738.44, "start": 737.56, "text": "Borderless"}, {"end": 739.28, "start": 738.44, "text": "Doctor"}, {"end": 740.04, "start": 739.28, "text": "web"}, {"end": 742.2, "start": 740.04, "text": "page."}, {"end": 742.76, "start": 742.2, "text": "So"}, {"end": 743.0, "start": 742.76, "text": "the"}, {"end": 743.56, "start": 743.0, "text": "user"}, {"end": 744.0, "start": 743.56, "text": "says,"}, {"end": 744.44, "start": 744.0, "text": "okay,"}, {"end": 744.68, "start": 744.44, "text": "I"}, {"end": 744.84, "start": 744.68, "text": "want"}, {"end": 744.84, "start": 744.84, "text": "to"}, {"end": 745.04, "start": 744.84, "text": "pay,"}, {"end": 745.24, "start": 745.04, "text": "I"}, {"end": 745.28, "start": 745.24, "text": "want"}, {"end": 745.8, "start": 745.28, "text": "to"}, {"end": 746.08, "start": 745.8, "text": "donate"}, {"end": 746.28, "start": 746.08, "text": "some"}, {"end": 746.68, "start": 746.28, "text": "money."}, {"end": 747.24, "start": 746.68, "text": "And"}, {"end": 747.56, "start": 747.24, "text": "here"}, {"end": 747.96, "start": 747.56, "text": "the"}, {"end": 748.28, "start": 747.96, "text": "Stand"}, {"end": 748.36, "start": 748.28, "text": "Up"}, {"end": 748.96, "start": 748.36, "text": "Technology"}, {"end": 749.16, "start": 748.96, "text": "key"}, {"end": 749.56, "start": 749.16, "text": "kicks"}, {"end": 749.96, "start": 749.56, "text": "in."}], "text": " phishing attack. So it's a phishing attack. So we start with an URL. You are in the web world, in the mobile world, so you can send an email, an SMS, WhatsApp message, whatsoever. The user clicks and it reaches a Borderless Doctor web page. So the user says, okay, I want to pay, I want to donate some money. And here the Stand Up Technology key kicks in."}, {"chunks": [{"end": 750.32, "start": 750.0, "text": "And"}, {"end": 750.76, "start": 750.32, "text": "as"}, {"end": 750.96, "start": 750.76, "text": "you"}, {"end": 751.56, "start": 750.96, "text": "can"}, {"end": 752.4, "start": 751.56, "text": "see,"}, {"end": 752.6, "start": 752.4, "text": "the"}, {"end": 753.08, "start": 752.6, "text": "attacker"}, {"end": 753.28, "start": 753.08, "text": "can"}, {"end": 753.56, "start": 753.28, "text": "also"}, {"end": 754.24, "start": 753.56, "text": "control"}, {"end": 754.6, "start": 754.24, "text": "the,"}, {"end": 754.64, "start": 754.6, "text": "um,"}, {"end": 755.72, "start": 754.64, "text": "the"}, {"end": 756.4, "start": 755.72, "text": "icon."}, {"end": 756.64, "start": 756.4, "text": "So"}, {"end": 756.88, "start": 756.64, "text": "we"}, {"end": 757.24, "start": 756.88, "text": "replaced"}, {"end": 757.48, "start": 757.24, "text": "the"}, {"end": 757.8, "start": 757.48, "text": "icon"}, {"end": 758.2, "start": 757.8, "text": "with"}, {"end": 758.24, "start": 758.2, "text": "a"}, {"end": 758.48, "start": 758.24, "text": "blank"}, {"end": 758.92, "start": 758.48, "text": "image"}, {"end": 759.36, "start": 758.92, "text": "and"}, {"end": 759.8, "start": 759.36, "text": "we"}, {"end": 760.72, "start": 759.8, "text": "renamed"}, {"end": 761.08, "start": 760.72, "text": "our"}, {"end": 762.04, "start": 761.08, "text": "application"}, {"end": 762.28, "start": 762.04, "text": "with"}, {"end": 762.72, "start": 762.28, "text": "open"}, {"end": 762.88, "start": 762.72, "text": "with"}, {"end": 762.96, "start": 762.88, "text": "a"}, {"end": 763.52, "start": 762.96, "text": "confusing"}, {"end": 763.8, "start": 763.52, "text": "name,"}, {"end": 764.12, "start": 763.8, "text": "like"}, {"end": 764.68, "start": 764.12, "text": "open"}, {"end": 765.36, "start": 764.68, "text": "with"}, {"end": 766.28, "start": 765.36, "text": "the"}, {"end": 766.68, "start": 766.28, "text": "user"}, {"end": 766.96, "start": 766.68, "text": "clicks,"}, {"end": 767.76, "start": 766.96, "text": "they"}, {"end": 768.08, "start": 767.76, "text": "stand"}, {"end": 768.2, "start": 768.08, "text": "up"}, {"end": 769.2, "start": 768.2, "text": "triggers"}, {"end": 769.76, "start": 769.2, "text": "and"}, {"end": 770.08, "start": 769.76, "text": "the,"}, {"end": 770.08, "start": 770.08, "text": "uh,"}, {"end": 770.56, "start": 770.08, "text": "the"}, {"end": 771.28, "start": 770.56, "text": "user"}, {"end": 771.52, "start": 771.28, "text": "will"}, {"end": 771.72, "start": 771.52, "text": "reach"}, {"end": 771.96, "start": 771.72, "text": "the"}, {"end": 773.24, "start": 771.96, "text": "PayPal"}, {"end": 775.16, "start": 773.24, "text": "application."}, {"end": 775.76, "start": 775.16, "text": "Not"}, {"end": 776.0, "start": 775.76, "text": "because"}, {"end": 776.32, "start": 776.0, "text": "this"}, {"end": 776.6, "start": 776.32, "text": "is"}, {"end": 776.84, "start": 776.6, "text": "how"}, {"end": 777.12, "start": 776.84, "text": "our"}, {"end": 777.56, "start": 777.12, "text": "fake"}, {"end": 778.0, "start": 777.56, "text": "Facebook"}, {"end": 778.56, "start": 778.0, "text": "application,"}, {"end": 778.68, "start": 778.56, "text": "but"}, {"end": 778.76, "start": 778.68, "text": "the"}, {"end": 779.24, "start": 778.76, "text": "user"}, {"end": 779.36, "start": 779.24, "text": "is"}, {"end": 779.96, "start": 779.36, "text": "triggered."}], "text": " And as you can see, the attacker can also control the, um, the icon. So we replaced the icon with a blank image and we renamed our application with open with a confusing name, like open with the user clicks, they stand up triggers and the, uh, the user will reach the PayPal application. Not because this is how our fake Facebook application, but the user is triggered."}, {"chunks": [{"end": 780.48, "start": 780.0, "text": "And"}, {"end": 780.64, "start": 780.48, "text": "to"}, {"end": 781.0, "start": 780.64, "text": "believe"}, {"end": 781.0, "start": 781.0, "text": "that"}, {"end": 781.32, "start": 781.0, "text": "this"}, {"end": 781.6, "start": 781.32, "text": "is"}, {"end": 781.8, "start": 781.6, "text": "the"}, {"end": 782.2, "start": 781.8, "text": "real"}, {"end": 782.8, "start": 782.2, "text": "PayPal"}, {"end": 783.44, "start": 782.8, "text": "application"}, {"end": 783.84, "start": 783.44, "text": "because"}, {"end": 784.08, "start": 783.84, "text": "the"}, {"end": 784.8, "start": 784.08, "text": "password"}, {"end": 785.32, "start": 784.8, "text": "manager"}, {"end": 785.96, "start": 785.32, "text": "is"}, {"end": 786.32, "start": 785.96, "text": "suggesting"}, {"end": 786.48, "start": 786.32, "text": "to"}, {"end": 786.92, "start": 786.48, "text": "him"}, {"end": 787.52, "start": 786.92, "text": "his"}, {"end": 788.0, "start": 787.52, "text": "PayPal"}, {"end": 788.64, "start": 788.0, "text": "credential."}, {"end": 789.12, "start": 788.64, "text": "For"}, {"end": 789.6, "start": 789.12, "text": "the"}, {"end": 790.12, "start": 789.6, "text": "sake"}, {"end": 790.2, "start": 790.12, "text": "of"}, {"end": 790.76, "start": 790.2, "text": "precision,"}, {"end": 791.0, "start": 790.76, "text": "I'm"}, {"end": 791.36, "start": 791.0, "text": "always"}, {"end": 791.68, "start": 791.36, "text": "using"}, {"end": 791.76, "start": 791.68, "text": "the"}, {"end": 792.04, "start": 791.76, "text": "last"}, {"end": 792.72, "start": 792.04, "text": "password"}, {"end": 793.16, "start": 792.72, "text": "manager,"}, {"end": 793.52, "start": 793.16, "text": "but"}, {"end": 794.24, "start": 793.52, "text": "it"}, {"end": 794.6, "start": 794.24, "text": "works"}, {"end": 795.04, "start": 794.6, "text": "with"}, {"end": 796.44, "start": 795.04, "text": "everyone"}, {"end": 796.68, "start": 796.44, "text": "else"}, {"end": 797.24, "start": 796.68, "text": "password"}, {"end": 797.44, "start": 797.24, "text": "manager."}, {"end": 799.08, "start": 797.44, "text": "But"}, {"end": 799.4, "start": 799.08, "text": "there"}, {"end": 799.6, "start": 799.4, "text": "is"}, {"end": 799.88, "start": 799.6, "text": "a"}, {"end": 800.92, "start": 799.88, "text": "solution"}, {"end": 801.52, "start": 800.92, "text": "because"}, {"end": 801.52, "start": 801.52, "text": "Google"}, {"end": 802.16, "start": 801.52, "text": "already"}, {"end": 803.28, "start": 802.16, "text": "developed"}, {"end": 803.28, "start": 803.28, "text": "a"}, {"end": 803.88, "start": 803.28, "text": "protocol"}, {"end": 804.2, "start": 803.88, "text": "named"}, {"end": 804.44, "start": 804.2, "text": "the"}, {"end": 804.64, "start": 804.44, "text": "digital"}, {"end": 804.84, "start": 804.64, "text": "asset"}, {"end": 805.64, "start": 804.84, "text": "link"}, {"end": 806.08, "start": 805.64, "text": "that"}, {"end": 806.52, "start": 806.08, "text": "enabled"}, {"end": 807.24, "start": 806.52, "text": "to"}, {"end": 807.6, "start": 807.24, "text": "make"}, {"end": 808.4, "start": 807.6, "text": "verifiable"}, {"end": 809.08, "start": 808.4, "text": "statements."}, {"end": 809.72, "start": 809.08, "text": "So"}, {"end": 809.96, "start": 809.72, "text": "if"}], "text": " And to believe that this is the real PayPal application because the password manager is suggesting to him his PayPal credential. For the sake of precision, I'm always using the last password manager, but it works with everyone else password manager. But there is a solution because Google already developed a protocol named the digital asset link that enabled to make verifiable statements. So if"}, {"chunks": [{"end": 810.6, "start": 810.0, "text": "For"}, {"end": 811.04, "start": 810.6, "text": "a"}, {"end": 811.52, "start": 811.04, "text": "developer"}, {"end": 811.56, "start": 811.52, "text": "and"}, {"end": 811.64, "start": 811.56, "text": "you"}, {"end": 812.32, "start": 811.64, "text": "also"}, {"end": 812.64, "start": 812.32, "text": "own"}, {"end": 812.92, "start": 812.64, "text": "a"}, {"end": 813.32, "start": 812.92, "text": "website,"}, {"end": 813.44, "start": 813.32, "text": "you"}, {"end": 813.64, "start": 813.44, "text": "can"}, {"end": 814.56, "start": 813.64, "text": "associate"}, {"end": 814.96, "start": 814.56, "text": "the"}, {"end": 816.2, "start": 814.96, "text": "application"}, {"end": 816.48, "start": 816.2, "text": "with"}, {"end": 816.76, "start": 816.48, "text": "the"}, {"end": 817.28, "start": 816.76, "text": "website."}, {"end": 817.52, "start": 817.28, "text": "You"}, {"end": 818.2, "start": 817.52, "text": "specify"}, {"end": 818.36, "start": 818.2, "text": "in"}, {"end": 818.72, "start": 818.36, "text": "the"}, {"end": 819.36, "start": 818.72, "text": "Android"}, {"end": 819.72, "start": 819.36, "text": "manifest"}, {"end": 819.96, "start": 819.72, "text": "an"}, {"end": 820.48, "start": 819.96, "text": "URL"}, {"end": 821.0, "start": 820.48, "text": "pointing"}, {"end": 821.12, "start": 821.0, "text": "to"}, {"end": 821.28, "start": 821.12, "text": "a"}, {"end": 821.68, "start": 821.28, "text": "JSON"}, {"end": 823.24, "start": 821.68, "text": "file"}, {"end": 824.12, "start": 823.24, "text": "and"}, {"end": 824.44, "start": 824.12, "text": "in"}, {"end": 824.8, "start": 824.44, "text": "that"}, {"end": 825.16, "start": 824.8, "text": "JSON"}, {"end": 825.76, "start": 825.16, "text": "file"}, {"end": 825.88, "start": 825.76, "text": "you"}, {"end": 826.4, "start": 825.88, "text": "also"}, {"end": 827.48, "start": 826.4, "text": "specify"}, {"end": 827.8, "start": 827.48, "text": "the"}, {"end": 828.24, "start": 827.8, "text": "domain"}, {"end": 829.28, "start": 828.24, "text": "name"}, {"end": 829.6, "start": 829.28, "text": "and"}, {"end": 829.88, "start": 829.6, "text": "the"}, {"end": 830.64, "start": 829.88, "text": "fingerprint"}, {"end": 830.8, "start": 830.64, "text": "of"}, {"end": 831.12, "start": 830.8, "text": "the"}, {"end": 831.8, "start": 831.12, "text": "certificate."}, {"end": 832.36, "start": 831.8, "text": "So"}, {"end": 832.6, "start": 832.36, "text": "you"}, {"end": 832.64, "start": 832.6, "text": "can"}, {"end": 833.12, "start": 832.64, "text": "both"}, {"end": 833.44, "start": 833.12, "text": "map"}, {"end": 833.72, "start": 833.44, "text": "the"}, {"end": 834.44, "start": 833.72, "text": "domain"}, {"end": 834.84, "start": 834.44, "text": "with"}, {"end": 835.08, "start": 834.84, "text": "the"}, {"end": 835.48, "start": 835.08, "text": "package"}, {"end": 835.88, "start": 835.48, "text": "name"}, {"end": 836.08, "start": 835.88, "text": "and"}, {"end": 836.72, "start": 836.08, "text": "you"}, {"end": 837.24, "start": 836.72, "text": "can"}, {"end": 837.52, "start": 837.24, "text": "also"}, {"end": 838.08, "start": 837.52, "text": "verify"}, {"end": 838.28, "start": 838.08, "text": "the"}, {"end": 838.92, "start": 838.28, "text": "integrity"}, {"end": 839.04, "start": 838.92, "text": "of"}, {"end": 839.28, "start": 839.04, "text": "the"}, {"end": 839.96, "start": 839.28, "text": "application."}], "text": " For a developer and you also own a website, you can associate the application with the website. You specify in the Android manifest an URL pointing to a JSON file and in that JSON file you also specify the domain name and the fingerprint of the certificate. So you can both map the domain with the package name and you can also verify the integrity of the application."}, {"chunks": [{"end": 843.04, "start": 840.0, "text": "Unfortunately,"}, {"end": 843.48, "start": 843.04, "text": "we"}, {"end": 843.88, "start": 843.48, "text": "did"}, {"end": 844.12, "start": 843.88, "text": "an"}, {"end": 845.0, "start": 844.12, "text": "empirical"}, {"end": 845.48, "start": 845.0, "text": "study"}, {"end": 845.88, "start": 845.48, "text": "because"}, {"end": 846.24, "start": 845.88, "text": "while"}, {"end": 846.84, "start": 846.24, "text": "reversing"}, {"end": 847.6, "start": 846.84, "text": "password"}, {"end": 847.84, "start": 847.6, "text": "manager,"}, {"end": 848.12, "start": 847.84, "text": "we"}, {"end": 848.28, "start": 848.12, "text": "have"}, {"end": 848.96, "start": 848.28, "text": "found"}, {"end": 849.08, "start": 848.96, "text": "a"}, {"end": 849.24, "start": 849.08, "text": "lot"}, {"end": 849.36, "start": 849.24, "text": "of"}, {"end": 850.36, "start": 849.36, "text": "domains"}, {"end": 851.2, "start": 850.36, "text": "in"}, {"end": 851.92, "start": 851.2, "text": "some"}, {"end": 852.84, "start": 851.92, "text": "configuration"}, {"end": 853.04, "start": 852.84, "text": "on"}, {"end": 853.4, "start": 853.04, "text": "during"}, {"end": 854.2, "start": 853.4, "text": "some"}, {"end": 854.92, "start": 854.2, "text": "dance"}, {"end": 855.32, "start": 854.92, "text": "with"}, {"end": 855.68, "start": 855.32, "text": "the"}, {"end": 856.0, "start": 855.68, "text": "server."}, {"end": 856.24, "start": 856.0, "text": "And"}, {"end": 856.6, "start": 856.24, "text": "since"}, {"end": 856.84, "start": 856.6, "text": "they"}, {"end": 857.0, "start": 856.84, "text": "are"}, {"end": 858.12, "start": 857.0, "text": "extracted"}, {"end": 858.36, "start": 858.12, "text": "from"}, {"end": 858.68, "start": 858.36, "text": "password"}, {"end": 859.16, "start": 858.68, "text": "manager,"}, {"end": 859.64, "start": 859.16, "text": "we"}, {"end": 859.92, "start": 859.64, "text": "think"}, {"end": 860.12, "start": 859.92, "text": "that"}, {"end": 860.52, "start": 860.12, "text": "they"}, {"end": 861.0, "start": 860.52, "text": "host"}, {"end": 861.08, "start": 861.0, "text": "at"}, {"end": 861.36, "start": 861.08, "text": "least"}, {"end": 861.8, "start": 861.36, "text": "one"}, {"end": 862.12, "start": 861.8, "text": "page"}, {"end": 862.16, "start": 862.12, "text": "with"}, {"end": 862.28, "start": 862.16, "text": "a"}, {"end": 862.76, "start": 862.28, "text": "login"}, {"end": 863.2, "start": 862.76, "text": "form"}, {"end": 863.8, "start": 863.2, "text": "and"}, {"end": 864.04, "start": 863.8, "text": "we've"}, {"end": 864.92, "start": 864.04, "text": "found"}, {"end": 865.28, "start": 864.92, "text": "that"}, {"end": 865.96, "start": 865.28, "text": "just"}, {"end": 866.04, "start": 865.96, "text": "the"}, {"end": 866.52, "start": 866.04, "text": "2%"}, {"end": 866.68, "start": 866.52, "text": "of"}, {"end": 867.28, "start": 866.68, "text": "them"}, {"end": 868.56, "start": 867.28, "text": "specify"}, {"end": 869.0, "start": 868.56, "text": "the"}, {"end": 869.32, "start": 869.0, "text": "asset"}, {"end": 869.6, "start": 869.32, "text": "link"}, {"end": 869.96, "start": 869.6, "text": "JSON"}], "text": " Unfortunately, we did an empirical study because while reversing password manager, we have found a lot of domains in some configuration on during some dance with the server. And since they are extracted from password manager, we think that they host at least one page with a login form and we've found that just the 2% of them specify the asset link JSON"}, {"chunks": [{"end": 870.2, "start": 870.0, "text": "according"}, {"end": 870.68, "start": 870.2, "text": "to"}, {"end": 870.8, "start": 870.68, "text": "the"}, {"end": 871.36, "start": 870.8, "text": "Google"}, {"end": 872.88, "start": 871.36, "text": "documentation."}, {"end": 873.52, "start": 872.88, "text": "And"}, {"end": 873.84, "start": 873.52, "text": "so"}, {"end": 874.12, "start": 873.84, "text": "the"}, {"end": 875.32, "start": 874.12, "text": "98%"}, {"end": 875.52, "start": 875.32, "text": "of"}, {"end": 875.84, "start": 875.52, "text": "the"}, {"end": 876.32, "start": 875.84, "text": "other"}, {"end": 876.92, "start": 876.32, "text": "mapping"}, {"end": 877.56, "start": 876.92, "text": "is"}, {"end": 877.88, "start": 877.56, "text": "not"}, {"end": 878.24, "start": 877.88, "text": "secure,"}, {"end": 878.6, "start": 878.24, "text": "cannot"}, {"end": 878.84, "start": 878.6, "text": "be"}, {"end": 879.6, "start": 878.84, "text": "secure,"}, {"end": 880.4, "start": 879.6, "text": "verified."}, {"end": 881.28, "start": 880.4, "text": "So"}, {"end": 881.56, "start": 881.28, "text": "we"}, {"end": 881.72, "start": 881.56, "text": "have"}, {"end": 882.16, "start": 881.72, "text": "proposed"}, {"end": 882.24, "start": 882.16, "text": "a"}, {"end": 882.6, "start": 882.24, "text": "secure"}, {"end": 883.2, "start": 882.6, "text": "by"}, {"end": 883.56, "start": 883.2, "text": "design"}, {"end": 884.12, "start": 883.56, "text": "API."}, {"end": 884.76, "start": 884.12, "text": "Obviously"}, {"end": 885.08, "start": 884.76, "text": "more"}, {"end": 885.92, "start": 885.08, "text": "details"}, {"end": 885.96, "start": 885.92, "text": "are"}, {"end": 886.12, "start": 885.96, "text": "in"}, {"end": 886.36, "start": 886.12, "text": "the"}, {"end": 886.76, "start": 886.36, "text": "paper."}, {"end": 887.24, "start": 886.76, "text": "And"}, {"end": 887.36, "start": 887.24, "text": "I"}, {"end": 887.52, "start": 887.36, "text": "would"}, {"end": 887.72, "start": 887.52, "text": "like"}, {"end": 887.84, "start": 887.72, "text": "to"}, {"end": 888.16, "start": 887.84, "text": "point"}, {"end": 888.44, "start": 888.16, "text": "out"}, {"end": 888.76, "start": 888.44, "text": "that"}, {"end": 889.0, "start": 888.76, "text": "it"}, {"end": 889.96, "start": 889.0, "text": "uses"}, {"end": 890.04, "start": 889.96, "text": "a"}, {"end": 890.4, "start": 890.04, "text": "package"}, {"end": 891.0, "start": 890.4, "text": "name"}, {"end": 891.6, "start": 891.0, "text": "and"}, {"end": 891.84, "start": 891.6, "text": "it"}, {"end": 892.64, "start": 891.84, "text": "returns"}, {"end": 892.84, "start": 892.64, "text": "a"}, {"end": 893.2, "start": 892.84, "text": "domain"}, {"end": 893.68, "start": 893.2, "text": "name,"}, {"end": 894.12, "start": 893.68, "text": "a"}, {"end": 894.84, "start": 894.12, "text": "verified"}, {"end": 895.28, "start": 894.84, "text": "domain"}, {"end": 895.92, "start": 895.28, "text": "name."}, {"end": 896.52, "start": 895.92, "text": "Obviously"}, {"end": 896.76, "start": 896.52, "text": "is"}, {"end": 897.12, "start": 896.76, "text": "based"}, {"end": 897.4, "start": 897.12, "text": "on"}, {"end": 898.04, "start": 897.4, "text": "the"}, {"end": 898.52, "start": 898.04, "text": "digital"}, {"end": 899.24, "start": 898.52, "text": "asset"}, {"end": 899.96, "start": 899.24, "text": "link."}], "text": " according to the Google documentation. And so the 98% of the other mapping is not secure, cannot be secure, verified. So we have proposed a secure by design API. Obviously more details are in the paper. And I would like to point out that it uses a package name and it returns a domain name, a verified domain name. Obviously is based on the digital asset link."}, {"chunks": [{"end": 901.0, "start": 900.0, "text": "queries"}, {"end": 901.32, "start": 901.0, "text": "for"}, {"end": 901.56, "start": 901.32, "text": "domain"}, {"end": 901.84, "start": 901.56, "text": "name"}, {"end": 902.04, "start": 901.84, "text": "and"}, {"end": 902.12, "start": 902.04, "text": "no"}, {"end": 902.44, "start": 902.12, "text": "package"}, {"end": 902.84, "start": 902.44, "text": "name."}, {"end": 902.92, "start": 902.84, "text": "In"}, {"end": 903.32, "start": 902.92, "text": "this"}, {"end": 903.56, "start": 903.32, "text": "way,"}, {"end": 903.6, "start": 903.56, "text": "the"}, {"end": 904.04, "start": 903.6, "text": "developer"}, {"end": 904.48, "start": 904.04, "text": "is"}, {"end": 904.8, "start": 904.48, "text": "forced"}, {"end": 905.08, "start": 904.8, "text": "to"}, {"end": 905.68, "start": 905.08, "text": "use"}, {"end": 906.0, "start": 905.68, "text": "only"}, {"end": 906.48, "start": 906.0, "text": "validated"}, {"end": 906.72, "start": 906.48, "text": "domain"}, {"end": 907.4, "start": 906.72, "text": "names"}, {"end": 907.68, "start": 907.4, "text": "so"}, {"end": 907.84, "start": 907.68, "text": "it"}, {"end": 908.12, "start": 907.84, "text": "can"}, {"end": 908.48, "start": 908.12, "text": "easily"}, {"end": 908.8, "start": 908.48, "text": "map"}, {"end": 909.0, "start": 908.8, "text": "the"}, {"end": 910.32, "start": 909.0, "text": "credential"}, {"end": 910.48, "start": 910.32, "text": "with"}, {"end": 910.8, "start": 910.48, "text": "domain"}, {"end": 911.4, "start": 910.8, "text": "names."}, {"end": 911.6, "start": 911.4, "text": "And"}, {"end": 912.72, "start": 911.6, "text": "moreover,"}, {"end": 913.28, "start": 912.72, "text": "it"}, {"end": 913.52, "start": 913.28, "text": "also"}, {"end": 914.04, "start": 913.52, "text": "verified"}, {"end": 914.08, "start": 914.04, "text": "the"}, {"end": 914.84, "start": 914.08, "text": "integrity."}, {"end": 915.56, "start": 914.84, "text": "It"}, {"end": 916.08, "start": 915.56, "text": "follows"}, {"end": 916.24, "start": 916.08, "text": "the"}, {"end": 916.72, "start": 916.24, "text": "OpenYolo"}, {"end": 918.32, "start": 916.72, "text": "paradigm."}, {"end": 918.56, "start": 918.32, "text": "So"}, {"end": 918.88, "start": 918.56, "text": "it's"}, {"end": 919.28, "start": 918.88, "text": "another"}, {"end": 919.64, "start": 919.28, "text": "client"}, {"end": 920.16, "start": 919.64, "text": "server"}, {"end": 920.96, "start": 920.16, "text": "architecture,"}, {"end": 921.64, "start": 920.96, "text": "but"}, {"end": 921.92, "start": 921.64, "text": "we"}, {"end": 922.2, "start": 921.92, "text": "don't"}, {"end": 922.6, "start": 922.2, "text": "send"}, {"end": 923.16, "start": 922.6, "text": "broadcast"}, {"end": 923.56, "start": 923.16, "text": "intents"}, {"end": 923.72, "start": 923.56, "text": "to"}, {"end": 923.92, "start": 923.72, "text": "the"}, {"end": 924.52, "start": 923.92, "text": "password"}, {"end": 924.84, "start": 924.52, "text": "manager"}, {"end": 925.44, "start": 924.84, "text": "because"}, {"end": 925.84, "start": 925.44, "text": "the"}, {"end": 926.36, "start": 925.84, "text": "current"}, {"end": 926.72, "start": 926.36, "text": "OpenYolo"}, {"end": 927.2, "start": 926.72, "text": "client"}, {"end": 927.52, "start": 927.2, "text": "implementation"}, {"end": 928.08, "start": 927.52, "text": "sends"}, {"end": 928.88, "start": 928.08, "text": "broadcast"}, {"end": 929.96, "start": 928.88, "text": "intents"}], "text": " queries for domain name and no package name. In this way, the developer is forced to use only validated domain names so it can easily map the credential with domain names. And moreover, it also verified the integrity. It follows the OpenYolo paradigm. So it's another client server architecture, but we don't send broadcast intents to the password manager because the current OpenYolo client implementation sends broadcast intents"}, {"chunks": [{"end": 930.24, "start": 930.0, "text": "to"}, {"end": 930.24, "start": 930.24, "text": "the"}, {"end": 931.04, "start": 930.24, "text": "password"}, {"end": 931.44, "start": 931.04, "text": "manager"}, {"end": 931.68, "start": 931.44, "text": "and"}, {"end": 932.04, "start": 931.68, "text": "open"}, {"end": 932.2, "start": 932.04, "text": "apps"}, {"end": 932.64, "start": 932.2, "text": "to"}, {"end": 932.96, "start": 932.64, "text": "side"}, {"end": 933.28, "start": 932.96, "text": "channel"}, {"end": 933.68, "start": 933.28, "text": "attacks"}, {"end": 934.28, "start": 933.68, "text": "because"}, {"end": 934.48, "start": 934.28, "text": "a"}, {"end": 935.16, "start": 934.48, "text": "broadcast"}, {"end": 935.6, "start": 935.16, "text": "intent"}, {"end": 936.04, "start": 935.6, "text": "can"}, {"end": 936.32, "start": 936.04, "text": "be"}, {"end": 937.04, "start": 936.32, "text": "eavesdropped"}, {"end": 937.56, "start": 937.04, "text": "by"}, {"end": 937.76, "start": 937.56, "text": "every"}, {"end": 938.28, "start": 937.76, "text": "application"}, {"end": 938.8, "start": 938.28, "text": "installed"}, {"end": 939.2, "start": 938.8, "text": "on"}, {"end": 939.64, "start": 939.2, "text": "the"}, {"end": 941.36, "start": 939.64, "text": "phone."}, {"end": 941.96, "start": 941.36, "text": "We"}, {"end": 942.24, "start": 941.96, "text": "did"}, {"end": 942.6, "start": 942.24, "text": "a"}, {"end": 943.2, "start": 942.6, "text": "responsible"}, {"end": 944.0, "start": 943.2, "text": "disclosure."}, {"end": 944.24, "start": 944.0, "text": "We"}, {"end": 944.56, "start": 944.24, "text": "gave"}, {"end": 944.88, "start": 944.56, "text": "more"}, {"end": 945.36, "start": 944.88, "text": "than"}, {"end": 945.72, "start": 945.36, "text": "90"}, {"end": 946.12, "start": 945.72, "text": "days"}, {"end": 946.8, "start": 946.12, "text": "to"}, {"end": 946.92, "start": 946.8, "text": "each"}, {"end": 947.44, "start": 946.92, "text": "company"}, {"end": 948.88, "start": 947.44, "text": "involved"}, {"end": 949.32, "start": 948.88, "text": "and"}, {"end": 949.84, "start": 949.32, "text": "the"}, {"end": 950.48, "start": 949.84, "text": "reactions"}, {"end": 951.24, "start": 950.48, "text": "were"}, {"end": 951.68, "start": 951.24, "text": "different,"}, {"end": 952.68, "start": 951.68, "text": "obviously."}, {"end": 952.88, "start": 952.68, "text": "One"}, {"end": 953.28, "start": 952.88, "text": "password"}, {"end": 953.8, "start": 953.28, "text": "said,"}, {"end": 954.12, "start": 953.8, "text": "hey,"}, {"end": 954.48, "start": 954.12, "text": "no"}, {"end": 954.96, "start": 954.48, "text": "suggestion"}, {"end": 955.52, "start": 954.96, "text": "because"}, {"end": 955.64, "start": 955.52, "text": "they"}, {"end": 956.0, "start": 955.64, "text": "will"}, {"end": 956.2, "start": 956.0, "text": "be"}, {"end": 957.0, "start": 956.2, "text": "unreliable"}, {"end": 957.12, "start": 957.0, "text": "and"}, {"end": 957.88, "start": 957.12, "text": "they"}, {"end": 958.2, "start": 957.88, "text": "were"}, {"end": 959.96, "start": 958.2, "text": "right."}], "text": " to the password manager and open apps to side channel attacks because a broadcast intent can be eavesdropped by every application installed on the phone. We did a responsible disclosure. We gave more than 90 days to each company involved and the reactions were different, obviously. One password said, hey, no suggestion because they will be unreliable and they were right."}, {"chunks": [{"end": 960.56, "start": 960.0, "text": "Google"}, {"end": 960.96, "start": 960.56, "text": "said"}, {"end": 961.04, "start": 960.96, "text": "that"}, {"end": 961.36, "start": 961.04, "text": "it's"}, {"end": 961.56, "start": 961.36, "text": "a"}, {"end": 961.92, "start": 961.56, "text": "30-part"}, {"end": 962.08, "start": 961.92, "text": "app's"}, {"end": 963.12, "start": 962.08, "text": "problem,"}, {"end": 963.24, "start": 963.12, "text": "but"}, {"end": 963.64, "start": 963.24, "text": "they"}, {"end": 963.92, "start": 963.64, "text": "don't"}, {"end": 964.56, "start": 963.92, "text": "share"}, {"end": 964.72, "start": 964.56, "text": "the"}, {"end": 965.16, "start": 964.72, "text": "mapping."}, {"end": 966.28, "start": 965.16, "text": "Dashlane"}, {"end": 966.84, "start": 966.28, "text": "and"}, {"end": 967.52, "start": 966.84, "text": "LastPass"}, {"end": 968.24, "start": 967.52, "text": "gave"}, {"end": 968.76, "start": 968.24, "text": "us"}, {"end": 968.88, "start": 968.76, "text": "a"}, {"end": 969.6, "start": 968.88, "text": "reward."}, {"end": 970.88, "start": 969.6, "text": "So"}, {"end": 971.08, "start": 970.88, "text": "I"}, {"end": 971.32, "start": 971.08, "text": "will"}, {"end": 971.88, "start": 971.32, "text": "quit"}, {"end": 972.28, "start": 971.88, "text": "my"}, {"end": 972.6, "start": 972.28, "text": "PhD"}, {"end": 972.6, "start": 972.6, "text": "now"}, {"end": 972.72, "start": 972.6, "text": "I'm"}, {"end": 973.28, "start": 972.72, "text": "rich."}, {"end": 973.68, "start": 973.28, "text": "No"}, {"end": 974.04, "start": 973.68, "text": "joke."}, {"end": 974.16, "start": 974.04, "text": "And"}, {"end": 974.88, "start": 974.16, "text": "Keeper"}, {"end": 975.52, "start": 974.88, "text": "posted"}, {"end": 975.72, "start": 975.52, "text": "a"}, {"end": 976.16, "start": 975.72, "text": "blog"}, {"end": 976.96, "start": 976.16, "text": "post."}, {"end": 977.8, "start": 976.96, "text": "For"}, {"end": 978.28, "start": 977.8, "text": "the"}, {"end": 978.56, "start": 978.28, "text": "sake"}, {"end": 978.6, "start": 978.56, "text": "of"}, {"end": 979.4, "start": 978.6, "text": "precision,"}, {"end": 980.0, "start": 979.4, "text": "Dashlane,"}, {"end": 980.64, "start": 980.0, "text": "LastPass"}, {"end": 980.96, "start": 980.64, "text": "and"}, {"end": 981.2, "start": 980.96, "text": "Keeper,"}, {"end": 981.36, "start": 981.2, "text": "now"}, {"end": 981.92, "start": 981.36, "text": "they"}, {"end": 983.08, "start": 981.92, "text": "warn"}, {"end": 983.56, "start": 983.08, "text": "the"}, {"end": 984.2, "start": 983.56, "text": "user"}, {"end": 984.64, "start": 984.2, "text": "when"}, {"end": 984.96, "start": 984.64, "text": "the"}, {"end": 985.24, "start": 984.96, "text": "mapping"}, {"end": 985.8, "start": 985.24, "text": "cannot"}, {"end": 985.96, "start": 985.8, "text": "be"}, {"end": 986.68, "start": 985.96, "text": "verified."}, {"end": 986.72, "start": 986.68, "text": "And"}, {"end": 986.72, "start": 986.72, "text": "the"}, {"end": 988.28, "start": 986.72, "text": "conclusion"}, {"end": 988.88, "start": 988.28, "text": "with"}, {"end": 989.28, "start": 988.88, "text": "the"}, {"end": 989.96, "start": 989.28, "text": "main"}], "text": " Google said that it's a 30-part app's problem, but they don't share the mapping. Dashlane and LastPass gave us a reward. So I will quit my PhD now I'm rich. No joke. And Keeper posted a blog post. For the sake of precision, Dashlane, LastPass and Keeper, now they warn the user when the mapping cannot be verified. And the conclusion with the main"}, {"chunks": [{"end": 990.2, "start": 990.0, "text": "and"}, {"end": 991.0, "start": 990.2, "text": "takeaways."}, {"end": 991.52, "start": 991.0, "text": "So"}, {"end": 991.88, "start": 991.52, "text": "Google"}, {"end": 992.2, "start": 991.88, "text": "have"}, {"end": 992.68, "start": 992.2, "text": "introduced"}, {"end": 993.04, "start": 992.68, "text": "two"}, {"end": 993.36, "start": 993.04, "text": "features"}, {"end": 993.56, "start": 993.36, "text": "in"}, {"end": 994.56, "start": 993.56, "text": "the"}, {"end": 994.76, "start": 994.56, "text": "name"}, {"end": 994.76, "start": 994.76, "text": "of"}, {"end": 995.56, "start": 994.76, "text": "convenience,"}, {"end": 995.8, "start": 995.56, "text": "but"}, {"end": 996.28, "start": 995.8, "text": "we"}, {"end": 996.36, "start": 996.28, "text": "have"}, {"end": 996.88, "start": 996.36, "text": "exploited"}, {"end": 997.16, "start": 996.88, "text": "them"}, {"end": 997.32, "start": 997.16, "text": "to"}, {"end": 998.12, "start": 997.32, "text": "create"}, {"end": 998.44, "start": 998.12, "text": "a"}, {"end": 998.96, "start": 998.44, "text": "phishing,"}, {"end": 999.52, "start": 998.96, "text": "a"}, {"end": 1000.0, "start": 999.52, "text": "novel"}, {"end": 1000.52, "start": 1000.0, "text": "phishing"}, {"end": 1001.0, "start": 1000.52, "text": "attack"}, {"end": 1001.24, "start": 1001.0, "text": "and"}, {"end": 1001.8, "start": 1001.24, "text": "powerful."}, {"end": 1001.88, "start": 1001.8, "text": "There"}, {"end": 1002.64, "start": 1001.88, "text": "is"}, {"end": 1002.68, "start": 1002.64, "text": "the"}, {"end": 1003.48, "start": 1002.68, "text": "news"}, {"end": 1003.72, "start": 1003.48, "text": "of"}, {"end": 1003.72, "start": 1003.72, "text": "a"}, {"end": 1004.24, "start": 1003.72, "text": "push"}, {"end": 1004.72, "start": 1004.24, "text": "from"}, {"end": 1004.72, "start": 1004.72, "text": "the"}, {"end": 1004.96, "start": 1004.72, "text": "entire"}, {"end": 1005.48, "start": 1004.96, "text": "community"}, {"end": 1005.72, "start": 1005.48, "text": "into"}, {"end": 1006.2, "start": 1005.72, "text": "supporting"}, {"end": 1006.48, "start": 1006.2, "text": "DAL."}, {"end": 1006.6, "start": 1006.48, "text": "DAL"}, {"end": 1007.0, "start": 1006.6, "text": "is"}, {"end": 1007.2, "start": 1007.0, "text": "a"}, {"end": 1007.2, "start": 1007.2, "text": "very"}, {"end": 1007.6, "start": 1007.2, "text": "important"}, {"end": 1008.0, "start": 1007.6, "text": "thing,"}, {"end": 1008.04, "start": 1008.0, "text": "a"}, {"end": 1008.28, "start": 1008.04, "text": "very"}, {"end": 1008.6, "start": 1008.28, "text": "useful"}, {"end": 1008.84, "start": 1008.6, "text": "thing."}, {"end": 1009.32, "start": 1008.84, "text": "So"}, {"end": 1009.32, "start": 1009.32, "text": "we"}, {"end": 1009.64, "start": 1009.32, "text": "hope"}, {"end": 1010.04, "start": 1009.64, "text": "that"}, {"end": 1010.36, "start": 1010.04, "text": "this"}, {"end": 1010.68, "start": 1010.36, "text": "work"}, {"end": 1011.0, "start": 1010.68, "text": "will"}, {"end": 1011.52, "start": 1011.0, "text": "inspire"}, {"end": 1011.52, "start": 1011.52, "text": "the"}, {"end": 1011.92, "start": 1011.52, "text": "community."}, {"end": 1012.0, "start": 1011.92, "text": "And"}, {"end": 1012.16, "start": 1012.0, "text": "we"}, {"end": 1012.88, "start": 1012.16, "text": "also"}, {"end": 1013.76, "start": 1012.88, "text": "hope"}, {"end": 1014.36, "start": 1013.76, "text": "that"}, {"end": 1014.72, "start": 1014.36, "text": "Google"}, {"end": 1015.36, "start": 1014.72, "text": "will"}, {"end": 1015.76, "start": 1015.36, "text": "release"}, {"end": 1015.96, "start": 1015.76, "text": "this"}, {"end": 1016.12, "start": 1015.96, "text": "mapping."}, {"end": 1016.16, "start": 1016.12, "text": "It"}, {"end": 1016.68, "start": 1016.16, "text": "can"}, {"end": 1016.88, "start": 1016.68, "text": "be"}, {"end": 1017.44, "start": 1016.88, "text": "very"}, {"end": 1018.0, "start": 1017.44, "text": "helpful"}, {"end": 1018.36, "start": 1018.0, "text": "and"}, {"end": 1018.84, "start": 1018.36, "text": "they"}, {"end": 1019.16, "start": 1018.84, "text": "should"}, {"end": 1019.96, "start": 1019.16, "text": "integrate"}], "text": " and takeaways. So Google have introduced two features in the name of convenience, but we have exploited them to create a phishing, a novel phishing attack and powerful. There is the news of a push from the entire community into supporting DAL. DAL is a very important thing, a very useful thing. So we hope that this work will inspire the community. And we also hope that Google will release this mapping. It can be very helpful and they should integrate"}, {"chunks": [{"end": 1020.44, "start": 1020.0, "text": "our"}, {"end": 1021.44, "start": 1020.44, "text": "proposed"}, {"end": 1022.4, "start": 1021.44, "text": "API"}, {"end": 1022.84, "start": 1022.4, "text": "in"}, {"end": 1023.0, "start": 1022.84, "text": "the"}, {"end": 1025.08, "start": 1023.0, "text": "autofill"}, {"end": 1026.16, "start": 1025.08, "text": "framework."}, {"end": 1029.92, "start": 1026.16, "text": "Thank"}, {"end": 1030.4, "start": 1029.92, "text": "you."}, {"end": 1035.32, "start": 1030.4, "text": "MATT"}, {"end": 1036.08, "start": 1035.32, "text": "RIT,"}, {"end": 1037.0, "start": 1036.08, "text": "RIT."}, {"end": 1037.24, "start": 1037.0, "text": "Nice"}, {"end": 1037.8, "start": 1037.24, "text": "talk."}, {"end": 1037.84, "start": 1037.8, "text": "One"}, {"end": 1038.76, "start": 1037.84, "text": "thing"}, {"end": 1039.48, "start": 1038.76, "text": "I"}, {"end": 1040.04, "start": 1039.48, "text": "didn't"}, {"end": 1040.56, "start": 1040.04, "text": "quite"}, {"end": 1040.84, "start": 1040.56, "text": "follow,"}, {"end": 1041.0, "start": 1040.84, "text": "though,"}, {"end": 1041.44, "start": 1041.0, "text": "was"}, {"end": 1041.96, "start": 1041.44, "text": "the"}, {"end": 1043.12, "start": 1041.96, "text": "instant"}, {"end": 1043.68, "start": 1043.12, "text": "apps."}, {"end": 1044.24, "start": 1043.68, "text": "What"}, {"end": 1044.68, "start": 1044.24, "text": "is"}, {"end": 1044.68, "start": 1044.68, "text": "it"}, {"end": 1045.0, "start": 1044.68, "text": "that"}, {"end": 1045.2, "start": 1045.0, "text": "the"}, {"end": 1046.08, "start": 1045.2, "text": "attacker"}, {"end": 1046.36, "start": 1046.08, "text": "gains"}, {"end": 1046.84, "start": 1046.36, "text": "from"}, {"end": 1046.96, "start": 1046.84, "text": "having"}, {"end": 1047.24, "start": 1046.96, "text": "the"}, {"end": 1047.6, "start": 1047.24, "text": "instant"}, {"end": 1048.16, "start": 1047.6, "text": "apps"}, {"end": 1048.72, "start": 1048.16, "text": "over"}, {"end": 1048.92, "start": 1048.72, "text": "just"}, {"end": 1049.24, "start": 1048.92, "text": "having"}, {"end": 1049.36, "start": 1049.24, "text": "an"}, {"end": 1049.96, "start": 1049.36, "text": "app?"}], "text": " our proposed API in the autofill framework. Thank you. MATT RIT, RIT. Nice talk. One thing I didn't quite follow, though, was the instant apps. What is it that the attacker gains from having the instant apps over just having an app?"}, {"chunks": [{"end": 1050.68, "start": 1050.0, "text": "The"}, {"end": 1050.92, "start": 1050.68, "text": "difference"}, {"end": 1051.12, "start": 1050.92, "text": "is"}, {"end": 1051.76, "start": 1051.12, "text": "that"}, {"end": 1051.92, "start": 1051.76, "text": "with"}, {"end": 1052.2, "start": 1051.92, "text": "this"}, {"end": 1052.52, "start": 1052.2, "text": "stand"}, {"end": 1052.76, "start": 1052.52, "text": "up,"}, {"end": 1052.92, "start": 1052.76, "text": "you"}, {"end": 1053.24, "start": 1052.92, "text": "just"}, {"end": 1053.68, "start": 1053.24, "text": "tap"}, {"end": 1053.72, "start": 1053.68, "text": "on"}, {"end": 1054.08, "start": 1053.72, "text": "the"}, {"end": 1055.16, "start": 1054.08, "text": "URL"}, {"end": 1055.68, "start": 1055.16, "text": "and"}, {"end": 1055.88, "start": 1055.68, "text": "this"}, {"end": 1056.12, "start": 1055.88, "text": "stand"}, {"end": 1056.28, "start": 1056.12, "text": "up"}, {"end": 1057.28, "start": 1056.28, "text": "immediately"}, {"end": 1058.52, "start": 1057.28, "text": "appear."}, {"end": 1059.08, "start": 1058.52, "text": "Otherwise"}, {"end": 1059.24, "start": 1059.08, "text": "you"}, {"end": 1059.24, "start": 1059.24, "text": "have"}, {"end": 1059.48, "start": 1059.24, "text": "to"}, {"end": 1060.2, "start": 1059.48, "text": "install"}, {"end": 1060.28, "start": 1060.2, "text": "an"}, {"end": 1060.96, "start": 1060.28, "text": "application"}, {"end": 1061.2, "start": 1060.96, "text": "is"}, {"end": 1061.96, "start": 1061.2, "text": "faster"}, {"end": 1062.12, "start": 1061.96, "text": "is"}, {"end": 1066.2, "start": 1062.12, "text": "different."}, {"end": 1067.0, "start": 1066.2, "text": "Okay."}, {"end": 1067.32, "start": 1067.0, "text": "Jeffrey"}, {"end": 1067.84, "start": 1067.32, "text": "Goldberg"}, {"end": 1068.0, "start": 1067.84, "text": "from"}, {"end": 1068.24, "start": 1068.0, "text": "one"}, {"end": 1069.24, "start": 1068.24, "text": "password."}, {"end": 1070.28, "start": 1069.24, "text": "We've"}, {"end": 1070.92, "start": 1070.28, "text": "been"}, {"end": 1072.08, "start": 1070.92, "text": "corresponding."}, {"end": 1072.6, "start": 1072.08, "text": "And"}, {"end": 1073.2, "start": 1072.6, "text": "so"}, {"end": 1073.56, "start": 1073.2, "text": "thank"}, {"end": 1073.96, "start": 1073.56, "text": "you"}, {"end": 1074.24, "start": 1073.96, "text": "very"}, {"end": 1074.8, "start": 1074.24, "text": "much"}, {"end": 1075.36, "start": 1074.8, "text": "for"}, {"end": 1076.24, "start": 1075.36, "text": "this."}, {"end": 1077.32, "start": 1076.24, "text": "And"}, {"end": 1077.8, "start": 1077.32, "text": "as"}, {"end": 1078.32, "start": 1077.8, "text": "a"}, {"end": 1078.76, "start": 1078.32, "text": "result,"}, {"end": 1078.92, "start": 1078.76, "text": "we've"}, {"end": 1079.2, "start": 1078.92, "text": "taken"}, {"end": 1079.24, "start": 1079.2, "text": "another"}, {"end": 1079.32, "start": 1079.24, "text": "little"}, {"end": 1079.48, "start": 1079.32, "text": "bit"}, {"end": 1079.68, "start": 1079.48, "text": "of"}, {"end": 1079.96, "start": 1079.68, "text": "a"}], "text": " The difference is that with this stand up, you just tap on the URL and this stand up immediately appear. Otherwise you have to install an application is faster is different. Okay. Jeffrey Goldberg from one password. We've been corresponding. And so thank you very much for this. And as a result, we've taken another little bit of a"}, {"chunks": [{"end": 1080.6, "start": 1080.0, "text": "look"}, {"end": 1081.36, "start": 1080.6, "text": "at"}, {"end": 1081.76, "start": 1081.36, "text": "DAL,"}, {"end": 1082.12, "start": 1081.76, "text": "and"}, {"end": 1082.6, "start": 1082.12, "text": "there"}, {"end": 1084.36, "start": 1082.6, "text": "are"}, {"end": 1084.92, "start": 1084.36, "text": "some"}, {"end": 1085.6, "start": 1084.92, "text": "minor"}, {"end": 1086.48, "start": 1085.6, "text": "privacy"}, {"end": 1088.2, "start": 1086.48, "text": "issues"}, {"end": 1088.52, "start": 1088.2, "text": "in"}, {"end": 1088.96, "start": 1088.52, "text": "how"}, {"end": 1089.84, "start": 1088.96, "text": "Google"}, {"end": 1090.6, "start": 1089.84, "text": "handles"}, {"end": 1091.16, "start": 1090.6, "text": "that"}, {"end": 1091.84, "start": 1091.16, "text": "API."}, {"end": 1092.64, "start": 1091.84, "text": "So"}, {"end": 1092.88, "start": 1092.64, "text": "we're"}, {"end": 1093.48, "start": 1092.88, "text": "looking"}, {"end": 1094.32, "start": 1093.48, "text": "at"}, {"end": 1094.56, "start": 1094.32, "text": "it,"}, {"end": 1094.92, "start": 1094.56, "text": "but"}, {"end": 1094.96, "start": 1094.92, "text": "at"}, {"end": 1095.48, "start": 1094.96, "text": "the"}, {"end": 1096.12, "start": 1095.48, "text": "moment,"}, {"end": 1096.48, "start": 1096.12, "text": "as"}, {"end": 1096.48, "start": 1096.48, "text": "you"}, {"end": 1096.64, "start": 1096.48, "text": "point"}, {"end": 1096.96, "start": 1096.64, "text": "out,"}, {"end": 1097.08, "start": 1096.96, "text": "we're"}, {"end": 1097.32, "start": 1097.08, "text": "not"}, {"end": 1098.08, "start": 1097.32, "text": "going"}, {"end": 1098.32, "start": 1098.08, "text": "to"}, {"end": 1098.72, "start": 1098.32, "text": "make"}, {"end": 1099.64, "start": 1098.72, "text": "suggestions"}, {"end": 1100.16, "start": 1099.64, "text": "unless"}, {"end": 1100.28, "start": 1100.16, "text": "we"}, {"end": 1100.76, "start": 1100.28, "text": "know"}, {"end": 1101.28, "start": 1100.76, "text": "they're"}, {"end": 1102.32, "start": 1101.28, "text": "reliable,"}, {"end": 1103.64, "start": 1102.32, "text": "but"}, {"end": 1103.96, "start": 1103.64, "text": "we're"}, {"end": 1104.8, "start": 1103.96, "text": "slightly"}, {"end": 1105.52, "start": 1104.8, "text": "concerned"}, {"end": 1105.96, "start": 1105.52, "text": "about"}, {"end": 1106.84, "start": 1105.96, "text": "informing"}, {"end": 1108.44, "start": 1106.84, "text": "Google"}, {"end": 1109.96, "start": 1108.44, "text": "which"}], "text": " look at DAL, and there are some minor privacy issues in how Google handles that API. So we're looking at it, but at the moment, as you point out, we're not going to make suggestions unless we know they're reliable, but we're slightly concerned about informing Google which"}, {"chunks": [{"end": 1110.44, "start": 1110.0, "text": "items"}, {"end": 1110.48, "start": 1110.44, "text": "you're"}, {"end": 1110.72, "start": 1110.48, "text": "trying"}, {"end": 1110.84, "start": 1110.72, "text": "to"}, {"end": 1111.2, "start": 1110.84, "text": "fill"}, {"end": 1111.68, "start": 1111.2, "text": "with."}, {"end": 1112.2, "start": 1111.68, "text": "And"}, {"end": 1112.56, "start": 1112.2, "text": "so"}, {"end": 1112.96, "start": 1112.56, "text": "that's,"}, {"end": 1113.52, "start": 1112.96, "text": "that's"}, {"end": 1113.84, "start": 1113.52, "text": "just"}, {"end": 1114.24, "start": 1113.84, "text": "where"}, {"end": 1114.56, "start": 1114.24, "text": "we"}, {"end": 1114.68, "start": 1114.56, "text": "stand"}, {"end": 1114.84, "start": 1114.68, "text": "with"}, {"end": 1114.92, "start": 1114.84, "text": "DAA."}, {"end": 1115.2, "start": 1114.92, "text": "Okay."}, {"end": 1115.6, "start": 1115.2, "text": "Thank"}, {"end": 1115.8, "start": 1115.6, "text": "you."}, {"end": 1116.12, "start": 1115.8, "text": "Thank"}, {"end": 1116.2, "start": 1116.12, "text": "you"}, {"end": 1116.52, "start": 1116.2, "text": "very"}, {"end": 1120.44, "start": 1116.52, "text": "much."}, {"end": 1124.64, "start": 1120.44, "text": "A"}, {"end": 1125.04, "start": 1124.64, "text": "rather"}, {"end": 1125.32, "start": 1125.04, "text": "short"}, {"end": 1125.8, "start": 1125.32, "text": "question."}, {"end": 1126.0, "start": 1125.8, "text": "What"}, {"end": 1126.2, "start": 1126.0, "text": "about"}, {"end": 1126.68, "start": 1126.2, "text": "the"}, {"end": 1127.0, "start": 1126.68, "text": "Apple"}, {"end": 1128.16, "start": 1127.0, "text": "ecosystem?"}, {"end": 1128.4, "start": 1128.16, "text": "Okay."}, {"end": 1128.52, "start": 1128.4, "text": "I"}, {"end": 1128.56, "start": 1128.52, "text": "will"}, {"end": 1128.96, "start": 1128.56, "text": "respect"}, {"end": 1130.44, "start": 1128.96, "text": "this"}, {"end": 1131.0, "start": 1130.44, "text": "question."}, {"end": 1131.76, "start": 1131.0, "text": "The"}, {"end": 1132.64, "start": 1131.76, "text": "funny"}, {"end": 1133.04, "start": 1132.64, "text": "thing"}, {"end": 1133.36, "start": 1133.04, "text": "is"}, {"end": 1133.68, "start": 1133.36, "text": "that"}, {"end": 1134.04, "start": 1133.68, "text": "since"}, {"end": 1134.2, "start": 1134.04, "text": "we"}, {"end": 1134.76, "start": 1134.2, "text": "submitted"}, {"end": 1135.04, "start": 1134.76, "text": "our"}, {"end": 1135.56, "start": 1135.04, "text": "paper"}, {"end": 1136.16, "start": 1135.56, "text": "a"}, {"end": 1136.72, "start": 1136.16, "text": "few"}, {"end": 1137.32, "start": 1136.72, "text": "weeks"}, {"end": 1138.2, "start": 1137.32, "text": "ago,"}, {"end": 1138.48, "start": 1138.2, "text": "sorry,"}, {"end": 1139.16, "start": 1138.48, "text": "two"}, {"end": 1139.44, "start": 1139.16, "text": "weeks"}, {"end": 1139.96, "start": 1139.44, "text": "later,"}], "text": " items you're trying to fill with. And so that's, that's just where we stand with DAA. Okay. Thank you. Thank you very much. A rather short question. What about the Apple ecosystem? Okay. I will respect this question. The funny thing is that since we submitted our paper a few weeks ago, sorry, two weeks later,"}, {"chunks": [{"end": 1140.76, "start": 1140.0, "text": "they"}, {"end": 1141.52, "start": 1140.76, "text": "published"}, {"end": 1141.96, "start": 1141.52, "text": "their"}, {"end": 1142.88, "start": 1141.96, "text": "way"}, {"end": 1143.24, "start": 1142.88, "text": "of"}, {"end": 1143.52, "start": 1143.24, "text": "doing"}, {"end": 1144.12, "start": 1143.52, "text": "this"}, {"end": 1145.12, "start": 1144.12, "text": "and"}, {"end": 1145.48, "start": 1145.12, "text": "they"}, {"end": 1145.8, "start": 1145.48, "text": "are"}, {"end": 1146.2, "start": 1145.8, "text": "using"}, {"end": 1146.84, "start": 1146.2, "text": "exactly"}, {"end": 1148.04, "start": 1146.84, "text": "our"}, {"end": 1148.84, "start": 1148.04, "text": "API,"}, {"end": 1149.2, "start": 1148.84, "text": "not"}, {"end": 1149.6, "start": 1149.2, "text": "our"}, {"end": 1149.84, "start": 1149.6, "text": "API,"}, {"end": 1150.2, "start": 1149.84, "text": "but"}, {"end": 1150.68, "start": 1150.2, "text": "with"}, {"end": 1151.36, "start": 1150.68, "text": "the"}, {"end": 1152.36, "start": 1151.36, "text": "same"}, {"end": 1153.48, "start": 1152.36, "text": "design."}, {"end": 1153.84, "start": 1153.48, "text": "So"}, {"end": 1154.16, "start": 1153.84, "text": "we"}, {"end": 1154.76, "start": 1154.16, "text": "are"}, {"end": 1155.4, "start": 1154.76, "text": "right,"}, {"end": 1155.56, "start": 1155.4, "text": "we"}, {"end": 1156.16, "start": 1155.56, "text": "did"}, {"end": 1156.68, "start": 1156.16, "text": "it"}, {"end": 1156.88, "start": 1156.68, "text": "well."}, {"end": 1157.28, "start": 1156.88, "text": "A"}, {"end": 1158.08, "start": 1157.28, "text": "question"}, {"end": 1158.72, "start": 1158.08, "text": "that"}, {"end": 1159.04, "start": 1158.72, "text": "may"}, {"end": 1159.32, "start": 1159.04, "text": "make"}, {"end": 1159.92, "start": 1159.32, "text": "things"}, {"end": 1160.24, "start": 1159.92, "text": "even"}, {"end": 1160.88, "start": 1160.24, "text": "more"}, {"end": 1162.44, "start": 1160.88, "text": "scarier"}, {"end": 1162.56, "start": 1162.44, "text": "about"}, {"end": 1162.92, "start": 1162.56, "text": "the"}, {"end": 1163.4, "start": 1162.92, "text": "password"}, {"end": 1164.36, "start": 1163.4, "text": "managers"}, {"end": 1164.6, "start": 1164.36, "text": "pop"}, {"end": 1164.64, "start": 1164.6, "text": "up."}, {"end": 1165.12, "start": 1164.64, "text": "Somebody"}, {"end": 1165.6, "start": 1165.12, "text": "say"}, {"end": 1165.88, "start": 1165.6, "text": "you"}, {"end": 1166.84, "start": 1165.88, "text": "have"}, {"end": 1167.04, "start": 1166.84, "text": "to"}, {"end": 1167.16, "start": 1167.04, "text": "click"}, {"end": 1167.24, "start": 1167.16, "text": "on"}, {"end": 1167.8, "start": 1167.24, "text": "that,"}, {"end": 1168.84, "start": 1167.8, "text": "right?"}, {"end": 1169.28, "start": 1168.84, "text": "Sorry,"}, {"end": 1169.96, "start": 1169.28, "text": "someone?"}], "text": " they published their way of doing this and they are using exactly our API, not our API, but with the same design. So we are right, we did it well. A question that may make things even more scarier about the password managers pop up. Somebody say you have to click on that, right? Sorry, someone?"}, {"chunks": [{"end": 1170.32, "start": 1170.0, "text": "Apakah"}, {"end": 1171.12, "start": 1170.32, "text": "kamu"}, {"end": 1171.52, "start": 1171.12, "text": "memiliki"}, {"end": 1172.12, "start": 1171.52, "text": "hal"}, {"end": 1172.28, "start": 1172.12, "text": "yang"}, {"end": 1172.96, "start": 1172.28, "text": "seperti"}, {"end": 1174.2, "start": 1172.96, "text": "Facebook"}, {"end": 1174.52, "start": 1174.2, "text": "dan"}, {"end": 1175.0, "start": 1174.52, "text": "kamu"}, {"end": 1177.36, "start": 1175.0, "text": "memiliki"}, {"end": 1177.84, "start": 1177.36, "text": "paswara,"}, {"end": 1178.44, "start": 1177.84, "text": "paswara"}, {"end": 1178.76, "start": 1178.44, "text": "manager"}, {"end": 1179.04, "start": 1178.76, "text": "akan"}, {"end": 1180.2, "start": 1179.04, "text": "berkata,"}, {"end": 1181.0, "start": 1180.2, "text": "apakah"}, {"end": 1181.76, "start": 1181.0, "text": "itu"}, {"end": 1182.76, "start": 1181.76, "text": "akan"}, {"end": 1183.56, "start": 1182.76, "text": "melindungi"}, {"end": 1184.08, "start": 1183.56, "text": "melindungi"}, {"end": 1184.48, "start": 1184.08, "text": "dengan"}, {"end": 1185.24, "start": 1184.48, "text": "overlay?"}, {"end": 1185.92, "start": 1185.24, "text": "Saya"}, {"end": 1186.92, "start": 1185.92, "text": "tidak"}, {"end": 1188.76, "start": 1186.92, "text": "tahu."}, {"end": 1189.28, "start": 1188.76, "text": "Itu"}, {"end": 1190.36, "start": 1189.28, "text": "adalah"}, {"end": 1191.0, "start": 1190.36, "text": "kerja"}, {"end": 1191.6, "start": 1191.0, "text": "yang"}, {"end": 1193.2, "start": 1191.6, "text": "menarik."}], "text": " Apakah kamu memiliki hal yang seperti Facebook dan kamu memiliki paswara, paswara manager akan berkata, apakah itu akan melindungi melindungi dengan overlay? Saya tidak tahu. Itu adalah kerja yang menarik."}]}}