SlideShare a Scribd company logo
1 of 11
Download to read offline
Safari App Extensions

Cleared up
Sanaa Squalli macOS Developer

@Dashlane
CocoaHeads October 2016

@sanaasqualli
@sanaasqualli
2010 2011 2012 2014
Safari 5
History
Extensions in Safari
JS CSS HTML
Safari Extension Gallery
Automatic Updates
Popover 

Extension Menu
Windows
Safari 6 App Extensions
iOS & OS XOS X & Windows
New events
Share
Photo
Today
Custom Keyboard
Finder
Action
@sanaasqualli
App Extensions
Native code
Distributed within an app, not standalone
One loop Life Cycle
Safari Custom Action Extension only on iOS
@sanaasqualli
2010 2011 2012 2014 2015 2016
Safari 5
History
JS CSS HTML
Safari Extension Gallery
Automatic Updates
Popover 

Extension Menu
Windows
Safari 6 App Extensions
iOS & OS X
Safari App Extensions
macOSOS X & Windows Paid program
Auto Updates

only for gallery
Content BlockerNew events
Share
Photo
Today
Custom Keyboard
Finder
Action
@sanaasqualli
Safari App Extensions
What’s new and what are the benefits?
Compatibility: Safari 10 on El Capitan or Sierra
Built using: JavaScript, CSS and Swift / Objective-C
Safari App Extension is bundled inside a macOS app
Distributed via Mac App Store
No mismatch revision between app and extension
Securely communicates with the app using the shared ressources
Possibility to check if the extension is enabled
@sanaasqualli
Migrate To Safari App Extensions
Old Extensions
Background
Popover
Injected
JS
JS, HTML, CSS
JS
Extension
@sanaasqualli
Migrate To Safari App Extensions
Apple Developer Docs
Use Xcode to create an app extension
Global page must be now done in native code
Popovers are created in Native code
Few changes between the extension and the injected script
Cannot create multiple menu items
Cannot create extension bar
@sanaasqualli
Background
Migrate To Safari App Extensions
Dashlane Extension Example
Popover
Injected
Dashlane
JS
JS, HTML, CSS
JS
Dashlane Extension
@sanaasqualli
sendToHost()
receiveFromHost()
Background (JS)
macOS Safari App Extension (Swift)
Migrate To Safari App Extensions
Hacking Safari App Extensions
Basic Architecture (2-way communication) using JavaScript Core Framework
@sanaasqualli
Demo
Hacking Safari App Extensions
@sanaasqualli
Q&A

More Related Content

What's hot

CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...
CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...
CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...CodeFest
 
Owasp API Security top 10 - The need of enterprise solutions for managing API...
Owasp API Security top 10 - The need of enterprise solutions for managing API...Owasp API Security top 10 - The need of enterprise solutions for managing API...
Owasp API Security top 10 - The need of enterprise solutions for managing API...Tharindu Edirisinghe
 
State of the Evernote Platform
State of the Evernote PlatformState of the Evernote Platform
State of the Evernote PlatformChris Traganos
 
Voice interfaces
Voice interfacesVoice interfaces
Voice interfacesSam Machin
 
Approck dealer portal
Approck dealer portalApprock dealer portal
Approck dealer portalAppRock
 
Datanyze Office Hours: Advanced Targeting Reports
Datanyze Office Hours: Advanced Targeting ReportsDatanyze Office Hours: Advanced Targeting Reports
Datanyze Office Hours: Advanced Targeting ReportsDatanyze
 
API Lifecycle Management
API Lifecycle ManagementAPI Lifecycle Management
API Lifecycle ManagementPostman
 
Postman Webinar: "API Governance with Postman"
Postman Webinar: "API Governance with Postman"Postman Webinar: "API Governance with Postman"
Postman Webinar: "API Governance with Postman"Postman
 

What's hot (12)

CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...
CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...
CodeFest 2013. François Reynaud. — Tools for mobile automation are nothing sp...
 
Owasp API Security top 10 - The need of enterprise solutions for managing API...
Owasp API Security top 10 - The need of enterprise solutions for managing API...Owasp API Security top 10 - The need of enterprise solutions for managing API...
Owasp API Security top 10 - The need of enterprise solutions for managing API...
 
State of the Evernote Platform
State of the Evernote PlatformState of the Evernote Platform
State of the Evernote Platform
 
Lex vs alexa
Lex vs alexaLex vs alexa
Lex vs alexa
 
Voice interfaces
Voice interfacesVoice interfaces
Voice interfaces
 
Approck dealer portal
Approck dealer portalApprock dealer portal
Approck dealer portal
 
Iphone mcx app
Iphone mcx appIphone mcx app
Iphone mcx app
 
Datanyze Office Hours: Advanced Targeting Reports
Datanyze Office Hours: Advanced Targeting ReportsDatanyze Office Hours: Advanced Targeting Reports
Datanyze Office Hours: Advanced Targeting Reports
 
Dhanyawaad zendcloud app
Dhanyawaad zendcloud appDhanyawaad zendcloud app
Dhanyawaad zendcloud app
 
API Lifecycle Management
API Lifecycle ManagementAPI Lifecycle Management
API Lifecycle Management
 
Postman Webinar: "API Governance with Postman"
Postman Webinar: "API Governance with Postman"Postman Webinar: "API Governance with Postman"
Postman Webinar: "API Governance with Postman"
 
Datasource application
Datasource applicationDatasource application
Datasource application
 

Viewers also liked

левский николай. оценка рисков мобильного пользователя и рекомендации по их ...
левский николай. оценка рисков мобильного пользователя  и рекомендации по их ...левский николай. оценка рисков мобильного пользователя  и рекомендации по их ...
левский николай. оценка рисков мобильного пользователя и рекомендации по их ...elenae00
 
Cara kompail kernel debian
Cara kompail kernel debianCara kompail kernel debian
Cara kompail kernel debianAnwarMuhammad1
 
дэниэл коуэн 3 doodler
 дэниэл коуэн 3 doodler дэниэл коуэн 3 doodler
дэниэл коуэн 3 doodlerelenae00
 
100 Trường đại học hàng đầu thế giới 2013-2014
100 Trường đại học hàng đầu thế giới 2013-2014100 Trường đại học hàng đầu thế giới 2013-2014
100 Trường đại học hàng đầu thế giới 2013-2014Duhoc_Vietsail
 
Mr kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...
Mr   kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...Mr   kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...
Mr kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...Srđan Stefanovic
 
EQB Minnesota and Climate Change
EQB Minnesota and Climate ChangeEQB Minnesota and Climate Change
EQB Minnesota and Climate ChangeAnna Henderson
 
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capitalelenae00
 
Membuat desain sistem keamananjaringan
Membuat desain sistem  keamananjaringanMembuat desain sistem  keamananjaringan
Membuat desain sistem keamananjaringanAnwarMuhammad1
 
Call as a method
Call as a methodCall as a method
Call as a methodfarahjef
 
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.90% Of People Can't Pronounce This Whole Poem. You Have To Try It.
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.Duhoc_Vietsail
 
Chetan QA & MR resume
Chetan QA & MR resumeChetan QA & MR resume
Chetan QA & MR resumechetan naidu
 
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdf
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdfπρογραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdf
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdfrkpd2014
 
13 sự thật thú vị về các trường đại học Mỹ
13 sự thật thú vị về các trường đại học Mỹ13 sự thật thú vị về các trường đại học Mỹ
13 sự thật thú vị về các trường đại học MỹDuhoc_Vietsail
 

Viewers also liked (20)

левский николай. оценка рисков мобильного пользователя и рекомендации по их ...
левский николай. оценка рисков мобильного пользователя  и рекомендации по их ...левский николай. оценка рисков мобильного пользователя  и рекомендации по их ...
левский николай. оценка рисков мобильного пользователя и рекомендации по их ...
 
Cara kompail kernel debian
Cara kompail kernel debianCara kompail kernel debian
Cara kompail kernel debian
 
Tugas
TugasTugas
Tugas
 
дэниэл коуэн 3 doodler
 дэниэл коуэн 3 doodler дэниэл коуэн 3 doodler
дэниэл коуэн 3 doodler
 
100 Trường đại học hàng đầu thế giới 2013-2014
100 Trường đại học hàng đầu thế giới 2013-2014100 Trường đại học hàng đầu thế giới 2013-2014
100 Trường đại học hàng đầu thế giới 2013-2014
 
Mr kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...
Mr   kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...Mr   kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...
Mr kvantitativni aspekt fundamentalne analize na nivou kompanije i industri...
 
EQB Minnesota and Climate Change
EQB Minnesota and Climate ChangeEQB Minnesota and Climate Change
EQB Minnesota and Climate Change
 
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital
11+апреля+инвестиции+в+электронной+торговле+сергей+айрапетов+aspring+capital
 
Membuat desain sistem keamananjaringan
Membuat desain sistem  keamananjaringanMembuat desain sistem  keamananjaringan
Membuat desain sistem keamananjaringan
 
Tantrasex
TantrasexTantrasex
Tantrasex
 
Call as a method
Call as a methodCall as a method
Call as a method
 
question 1
question 1question 1
question 1
 
Naturaleza
NaturalezaNaturaleza
Naturaleza
 
History clearOS
History clearOSHistory clearOS
History clearOS
 
Arabe
ArabeArabe
Arabe
 
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.90% Of People Can't Pronounce This Whole Poem. You Have To Try It.
90% Of People Can't Pronounce This Whole Poem. You Have To Try It.
 
Chetan QA & MR resume
Chetan QA & MR resumeChetan QA & MR resume
Chetan QA & MR resume
 
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdf
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdfπρογραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdf
προγραμματικές θέσεις Ριζοσπαστική Κίνηση Πολιτών Δήμος Παύλου Μελά.Pdf
 
13 sự thật thú vị về các trường đại học Mỹ
13 sự thật thú vị về các trường đại học Mỹ13 sự thật thú vị về các trường đại học Mỹ
13 sự thật thú vị về các trường đại học Mỹ
 
Cartilha Reserva Legal
Cartilha Reserva LegalCartilha Reserva Legal
Cartilha Reserva Legal
 

Similar to Safari App extensions cleared up

Improving Dashboards with open content sharing
Improving Dashboards with open content sharingImproving Dashboards with open content sharing
Improving Dashboards with open content sharingLachlan Hardy
 
Flex update - August, 2012
Flex update - August, 2012Flex update - August, 2012
Flex update - August, 2012Alan Greenblatt
 
Alfresco Mobile - new Alfresco Mobile app features
Alfresco Mobile - new Alfresco Mobile app featuresAlfresco Mobile - new Alfresco Mobile app features
Alfresco Mobile - new Alfresco Mobile app featuresAlfresco Software
 
Open Web Apps - State of the Browser 2014
Open Web Apps - State of the Browser 2014Open Web Apps - State of the Browser 2014
Open Web Apps - State of the Browser 2014Christian Heilmann
 
Introduction of Monaca
Introduction of MonacaIntroduction of Monaca
Introduction of MonacaHideshi Ogoshi
 
Introduction to SharePoint 2013 Apps
Introduction to SharePoint 2013 AppsIntroduction to SharePoint 2013 Apps
Introduction to SharePoint 2013 AppsRushi Waghmare
 
Top 9 Frameworks that would disrupt the mobile app development in 2022
Top 9 Frameworks that would disrupt the mobile app development in 2022Top 9 Frameworks that would disrupt the mobile app development in 2022
Top 9 Frameworks that would disrupt the mobile app development in 2022Inexture Solutions
 
Developing cross platforms mobile applications using the Apache Cordova
Developing cross platforms mobile applications using the Apache CordovaDeveloping cross platforms mobile applications using the Apache Cordova
Developing cross platforms mobile applications using the Apache CordovaMahmoud Tolba
 
Which Backend Is Best For Flutter.pdf
Which Backend Is Best For Flutter.pdfWhich Backend Is Best For Flutter.pdf
Which Backend Is Best For Flutter.pdfAppdeveloper10
 
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...Amazon Web Services
 
Best frameworks for mobile app development in 2022
Best frameworks for mobile app development in 2022Best frameworks for mobile app development in 2022
Best frameworks for mobile app development in 2022Pixel Values Technolabs
 
Ashish_Android_Resume
Ashish_Android_ResumeAshish_Android_Resume
Ashish_Android_ResumeAshish Bangar
 
Open Source examples from Adobe : Oscon kiosk
Open Source examples from Adobe : Oscon kioskOpen Source examples from Adobe : Oscon kiosk
Open Source examples from Adobe : Oscon kioskDave McAllister
 
Preparing for Growth - Architecting Giant Apps for Scalability and Build Speed
Preparing for Growth - Architecting Giant Apps for Scalability and Build SpeedPreparing for Growth - Architecting Giant Apps for Scalability and Build Speed
Preparing for Growth - Architecting Giant Apps for Scalability and Build SpeedBruno Rocha
 
Confessions of-a-gadget-holic
Confessions of-a-gadget-holicConfessions of-a-gadget-holic
Confessions of-a-gadget-holicTyrell Perera
 
Hybrid app development
Hybrid app developmentHybrid app development
Hybrid app developmentHarshul Shah
 
Cordova and PhoneGap Insights
Cordova and PhoneGap InsightsCordova and PhoneGap Insights
Cordova and PhoneGap InsightsMonaca
 

Similar to Safari App extensions cleared up (20)

Improving Dashboards with open content sharing
Improving Dashboards with open content sharingImproving Dashboards with open content sharing
Improving Dashboards with open content sharing
 
Flex update - August, 2012
Flex update - August, 2012Flex update - August, 2012
Flex update - August, 2012
 
Alfresco Mobile - new Alfresco Mobile app features
Alfresco Mobile - new Alfresco Mobile app featuresAlfresco Mobile - new Alfresco Mobile app features
Alfresco Mobile - new Alfresco Mobile app features
 
Appium ppt
Appium pptAppium ppt
Appium ppt
 
Open Web Apps - State of the Browser 2014
Open Web Apps - State of the Browser 2014Open Web Apps - State of the Browser 2014
Open Web Apps - State of the Browser 2014
 
Introduction of Monaca
Introduction of MonacaIntroduction of Monaca
Introduction of Monaca
 
Hybrid HTML5 Apps
Hybrid HTML5 AppsHybrid HTML5 Apps
Hybrid HTML5 Apps
 
Introduction to SharePoint 2013 Apps
Introduction to SharePoint 2013 AppsIntroduction to SharePoint 2013 Apps
Introduction to SharePoint 2013 Apps
 
Top 9 Frameworks that would disrupt the mobile app development in 2022
Top 9 Frameworks that would disrupt the mobile app development in 2022Top 9 Frameworks that would disrupt the mobile app development in 2022
Top 9 Frameworks that would disrupt the mobile app development in 2022
 
Developing cross platforms mobile applications using the Apache Cordova
Developing cross platforms mobile applications using the Apache CordovaDeveloping cross platforms mobile applications using the Apache Cordova
Developing cross platforms mobile applications using the Apache Cordova
 
Which Backend Is Best For Flutter.pdf
Which Backend Is Best For Flutter.pdfWhich Backend Is Best For Flutter.pdf
Which Backend Is Best For Flutter.pdf
 
Google App indexing
Google App indexingGoogle App indexing
Google App indexing
 
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...
Adding Analytics to a Web & Mobile Applications with Amazon Pinpoint & AWS Am...
 
Best frameworks for mobile app development in 2022
Best frameworks for mobile app development in 2022Best frameworks for mobile app development in 2022
Best frameworks for mobile app development in 2022
 
Ashish_Android_Resume
Ashish_Android_ResumeAshish_Android_Resume
Ashish_Android_Resume
 
Open Source examples from Adobe : Oscon kiosk
Open Source examples from Adobe : Oscon kioskOpen Source examples from Adobe : Oscon kiosk
Open Source examples from Adobe : Oscon kiosk
 
Preparing for Growth - Architecting Giant Apps for Scalability and Build Speed
Preparing for Growth - Architecting Giant Apps for Scalability and Build SpeedPreparing for Growth - Architecting Giant Apps for Scalability and Build Speed
Preparing for Growth - Architecting Giant Apps for Scalability and Build Speed
 
Confessions of-a-gadget-holic
Confessions of-a-gadget-holicConfessions of-a-gadget-holic
Confessions of-a-gadget-holic
 
Hybrid app development
Hybrid app developmentHybrid app development
Hybrid app development
 
Cordova and PhoneGap Insights
Cordova and PhoneGap InsightsCordova and PhoneGap Insights
Cordova and PhoneGap Insights
 

Recently uploaded

AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsMemoori
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machinePadma Pradeep
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsMark Billinghurst
 
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphSIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphNeo4j
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhisoniya singh
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking MenDelhi Call girls
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?XfilesPro
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...shyamraj55
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Scott Keck-Warren
 
Next-generation AAM aircraft unveiled by Supernal, S-A2
Next-generation AAM aircraft unveiled by Supernal, S-A2Next-generation AAM aircraft unveiled by Supernal, S-A2
Next-generation AAM aircraft unveiled by Supernal, S-A2Hyundai Motor Group
 
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptx
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptxMaking_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptx
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptxnull - The Open Security Community
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationSafe Software
 

Recently uploaded (20)

AI as an Interface for Commercial Buildings
AI as an Interface for Commercial BuildingsAI as an Interface for Commercial Buildings
AI as an Interface for Commercial Buildings
 
Install Stable Diffusion in windows machine
Install Stable Diffusion in windows machineInstall Stable Diffusion in windows machine
Install Stable Diffusion in windows machine
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
Vulnerability_Management_GRC_by Sohang Sengupta.pptx
Vulnerability_Management_GRC_by Sohang Sengupta.pptxVulnerability_Management_GRC_by Sohang Sengupta.pptx
Vulnerability_Management_GRC_by Sohang Sengupta.pptx
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR Systems
 
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge GraphSIEMENS: RAPUNZEL – A Tale About Knowledge Graph
SIEMENS: RAPUNZEL – A Tale About Knowledge Graph
 
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | DelhiFULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
FULL ENJOY 🔝 8264348440 🔝 Call Girls in Diplomatic Enclave | Delhi
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men08448380779 Call Girls In Friends Colony Women Seeking Men
08448380779 Call Girls In Friends Colony Women Seeking Men
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?How to Remove Document Management Hurdles with X-Docs?
How to Remove Document Management Hurdles with X-Docs?
 
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
Automating Business Process via MuleSoft Composer | Bangalore MuleSoft Meetup...
 
Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024Advanced Test Driven-Development @ php[tek] 2024
Advanced Test Driven-Development @ php[tek] 2024
 
Next-generation AAM aircraft unveiled by Supernal, S-A2
Next-generation AAM aircraft unveiled by Supernal, S-A2Next-generation AAM aircraft unveiled by Supernal, S-A2
Next-generation AAM aircraft unveiled by Supernal, S-A2
 
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptx
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptxMaking_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptx
Making_way_through_DLL_hollowing_inspite_of_CFG_by_Debjeet Banerjee.pptx
 
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry InnovationBeyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
Beyond Boundaries: Leveraging No-Code Solutions for Industry Innovation
 

Safari App extensions cleared up

  • 1. Safari App Extensions
 Cleared up Sanaa Squalli macOS Developer
 @Dashlane CocoaHeads October 2016
 @sanaasqualli
  • 2. @sanaasqualli 2010 2011 2012 2014 Safari 5 History Extensions in Safari JS CSS HTML Safari Extension Gallery Automatic Updates Popover 
 Extension Menu Windows Safari 6 App Extensions iOS & OS XOS X & Windows New events Share Photo Today Custom Keyboard Finder Action
  • 3. @sanaasqualli App Extensions Native code Distributed within an app, not standalone One loop Life Cycle Safari Custom Action Extension only on iOS
  • 4. @sanaasqualli 2010 2011 2012 2014 2015 2016 Safari 5 History JS CSS HTML Safari Extension Gallery Automatic Updates Popover 
 Extension Menu Windows Safari 6 App Extensions iOS & OS X Safari App Extensions macOSOS X & Windows Paid program Auto Updates
 only for gallery Content BlockerNew events Share Photo Today Custom Keyboard Finder Action
  • 5. @sanaasqualli Safari App Extensions What’s new and what are the benefits? Compatibility: Safari 10 on El Capitan or Sierra Built using: JavaScript, CSS and Swift / Objective-C Safari App Extension is bundled inside a macOS app Distributed via Mac App Store No mismatch revision between app and extension Securely communicates with the app using the shared ressources Possibility to check if the extension is enabled
  • 6. @sanaasqualli Migrate To Safari App Extensions Old Extensions Background Popover Injected JS JS, HTML, CSS JS Extension
  • 7. @sanaasqualli Migrate To Safari App Extensions Apple Developer Docs Use Xcode to create an app extension Global page must be now done in native code Popovers are created in Native code Few changes between the extension and the injected script Cannot create multiple menu items Cannot create extension bar
  • 8. @sanaasqualli Background Migrate To Safari App Extensions Dashlane Extension Example Popover Injected Dashlane JS JS, HTML, CSS JS Dashlane Extension
  • 9. @sanaasqualli sendToHost() receiveFromHost() Background (JS) macOS Safari App Extension (Swift) Migrate To Safari App Extensions Hacking Safari App Extensions Basic Architecture (2-way communication) using JavaScript Core Framework