Data Storage, Backup and Roaming

Slides:



Advertisements
Similar presentations
Building Scalable Web Apps with Windows Azure Name Title Microsoft Corporation.
Advertisements

Windows 7 demo.
© 2010 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered.
MIX 09 4/15/ :14 PM © 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered.
30 April 2014 Building Apps for Windows Phone 8.1 Jump Start WinRT Apps & Silverlight.
Connected Experiences
Session 1.
Built by Developers for Developers…. © 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names.
© 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered trademarks and/or.
Feature: Print Remaining Documents © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or.
© 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered trademarks and/or.
The Windows Runtime (WinRT) is the shared runtime and API space used by store apps across the Windows platform (phone and client) 5 Common WinRT.
Feature: Customer Combiner and Modifier © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are.
© 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or.

Storage Device Design Pattern JEFF MEISSNER; KEN HARDY Windows Program Management.
customer.
demo © 2008 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names.
Secure Windows App Development. Authentication.
demo Demo.
Feature: Void Historical/Open Transaction Updates © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product.
demo QueryForeign KeyInstance /sm:body()/x:Order/x:Delivery/y:TrackingId1Z
projekt202 © 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are.
© 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered trademarks.
App Package Folder App data Folders Local Roaming Temp Removable Storage (SD Card) Cloud Credential Locker B/ground Transfer Publishers Shared Folder.
© 2008 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or.

Office 365 Development July 2014.
Yochay Kiriaty Senior Technical Evangelist Microsoft® Corporation
Windows Phone 8.1 New Features
WebView: Bringing the web to your app
Build /4/2018 © 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks.
Build data-driven collection and list apps using XAML
SkyDrive Pro Chris Gideon Architect Microsoft 9/16/2018
Windows Store for Business
Office 365 Development.
Title of Presentation 11/22/2018 3:34 PM
Deep dive on app data roaming
A Developer's Guide to Windows 10 Andy & Jerry
MIX 09 11/23/2018 6:07 PM © 2009 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered.
Microsoft Build /24/2018 2:23 PM © 2016 Microsoft Corporation. All rights reserved. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY,
Windows 7 – Beyond the boundaries of your office
Tooling and Diagnostics
Version Binding UWP Apps & Driver Packages
Working with different JavaScript frameworks and libraries
Title of Presentation 12/2/2018 3:48 PM
What is OneDrive vs. OneDrive for Business??
Search: integrating into the Windows 8 search experience
Building event-driven, long-running apps with Windows workflow
Share: Your app powers the Windows 8 share experience
File Picker for OneDrive and OneDrive for Business
File type associations and AutoPlay
Create experiences that span devices
Tech·Ed North America /18/2019 4:15 PM
Feature: Document Attachment - Flow from Master Records
Microsoft Office 4/3/2019 Deep Dive into native Universal App development with the Office 365 APIs Speaker name Title Microsoft Corporation © 2012 Microsoft.
8/04/2019 9:13 PM © 2006 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered.
4/9/ | Contracts © 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks.
Виктор Хаджийски Катедра “Металургия на желязото и металолеене”
5/8/2019 3:20 AM bQuery-Tool 3.0 A new and elegant way to create queries and ad-hoc reports on your Baan/Infor ERP LN data. This Baan session is a query.
Title of Presentation 5/12/ :53 PM
Шитманов Дархан Қаражанұлы Тарих пәнінің
Build /20/2019 © 2012 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks.
Title of Presentation 5/24/2019 1:26 PM
Title of Presentation 7/24/2019 8:53 PM
Bringing existing managed code into Metro style apps
Erik Porter Program Manager ASP.NET Microsoft Corporation
03 | Async Programming & Networking Intro
Presentation transcript:

Data Storage, Backup and Roaming 11/15/2018 Windows XAML Building Apps for Windows Phone 8.1 Jump Start Data Storage, Backup and Roaming Matthias Shapiro @matthiasshap Andy Wigley @andy_wigley 29 April 2014 © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

This module… (50 minutes) Data Storage and Data Roaming Local Settings Roaming files and settings The Windows Storage API Serializing objects using the XML and Json serializers Using Compression Using the SD Card to store application data Known Folders

App Data Locations

Locations where apps can access data 11/15/2018 Locations where apps can access data Networks Credential Locker File Picker APIs File System B/ground Transfer r/w Temp App data Folders r/w r/w Roaming App data Folders Local Pictures Videos Music - Direct access needs manifest capabilities App data Folders App Known Folders r/w r/w Installation Folder SD Card r/o r/w © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

App Data Storage: Overview Installation Folder Package Manager installs all app files into the Installation Folder Read-only access from app Read-only reference database Apps store data in Local Folder Settings and properties in the app dictionary Unstructured data in Isolated Storage files Structured data in database files Package Manager Creates root folder sandboxed to App Install DB Files (r/o) App Data Folder App Creates/Manages files and settings WinRT Storage APIs DB Local or Roaming Settings File Application Files Database file

Data Storage Areas Windows.Storage.ApplicationData 11/15/2018 Data Storage Areas Windows.Storage.ApplicationData Windows.Security. Credentials Roaming Folder Settings Other devices can access what you put in here Data roamed cross-device Limited to 100kb per application Held in OneDrive storage Local Folder Settings Store local data here for use by your application Can store data up to the limit of the storage on the device Retained if the application is updated Temp Folder Use for temporary storage No guarantee it will still be here next time your program runs Cleaned up in a low storage condition PasswordVault Credentials Credential Locker Use for secure storage of PasswordCredential objects Data roamed cross-device © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Windows.Storage.ApplicationData 11/15/2018 Windows.Storage.ApplicationData This namespace provides access to the three storage folders in the app data store and the application settings containers: Windows.Storage.StorageFolder roam = Windows.Storage.ApplicationData.Current.RoamingFolder; Windows.Storage.StorageFolder local = Windows.Storage.ApplicationData.Current.LocalFolder; Windows.Storage.StorageFolder temp = Windows.Storage.ApplicationData.Current.TemporaryFolder; Windows.Storage.ApplicationDataContainer localSettings = Windows.Storage.ApplicationData.Current.LocalSettings; Windows.Storage.ApplicationDataContainer roamingSettings = Windows.Storage.ApplicationData.Current.RoamingSettings; The StorageFolder object represents a folder and is used to access the folder and its contents The ApplicationDataContainer object represents a key-value pair settings dictionary © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Local and Roaming Settings

Local Settings // Create a simple setting 11/15/2018 Local Settings // Create a simple setting localSettings.Values["exampleSetting"] = "Hello Windows"; // Read data from a simple setting Object value = localSettings.Values["exampleSetting"]; if (value == null) { // No data } else // Access data in value // Delete a simple setting localSettings.Values.Remove("exampleSetting"); © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Roaming Settings and the Roaming Folder 11/15/2018 Roaming Settings and the Roaming Folder If a user obtains your application and installs it on multiple devices it is nice if all the devices can share the same settings information Changes on one device are reflected on all the other devices owned by that user Roaming data is shared between Windows Phone 8.1 Store Apps and Windows 8.1 Store Apps that have the same Package Family Name (PFN) Roaming data provides a way that an application can synchronise data and/or settings across a number of different physical devices It takes the form of a folder and a settings dictionary which are automatically stored in the users’ OneDrive Roaming data is limited to value of ApplicationData.RoamingStorageQuota (usually 100KB) but do not count against the users’ OneDrive quote If your roaming data exceeds the quota, it won’t roam until its size is less than the quota again © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

11/15/2018 Roaming Data Other clients are notified of updated data via Windows Notification Service. If app is running when sync occurs, an event is raised. Sync engine transfers data periodically based on triggers (user idle, battery, network, etc.) PFN 12345 Roaming folder Roaming settings OneDrive stores up to 100kb of roaming data per app (not included in user quota). If app exceeds the limit, sync stops. WP 8.1 App – PFN 12345 Roaming Local Temp Windows App – PFN 12345 Roaming Local Temp App writes data using standard file/settings APIs. © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Using the Roaming settings private void name_TextChanged(object sender, TextChangedEventArgs e) { Windows.Storage.ApplicationDataContainer roamingSettings = Windows.Storage.ApplicationData.Current.RoamingSettings; roamingSettings.Values["userName"] = name.Text; } The RoamingSettings are exposed as a dictionary into which an application can save data The data is persisted on the device and also shared with other devices Note: On Windows 8.1, there is a special HighPriority setting. This has no effect on Windows Phone.

Reading the Roaming settings Windows.Storage.ApplicationDataContainer roamingSettings = Windows.Storage.ApplicationData.Current.RoamingSettings; if (roamingSettings.Values.ContainsKey("userName")) { name.Text = roamingSettings.Values["userName"].ToString(); } This code queries the roaming settings by using the key name The name will be reflected across multiple devices (including Windows 8.1 ones)

Receiving notification when roaming data changes The DataChanged event fires when the roaming data has changed Windows.Storage.ApplicationData.Current.DataChanged += Current_DataChanged; ... void Current_DataChanged(ApplicationData sender, object args) { // Refresh your settings... } The event is only fired if the application is active at the time of the change You should still load up all your data when your app starts

Tips on using roaming data Applications can store data in the roaming folder as they would any other folder on the device, or in roaming settings in the same way as local settings The synchronisation takes place in the background Good for app customisation settings, most recent activity, partially completed work Bad for synchronising large amounts of data or “instant syncing” scenarios Last writer wins HighPriority setting is available on Windows for quick sync, but has no effect on Windows Phone

Debugging apps using the Roaming Folder Developers can install an application on multiple unlocked devices You can debug the roaming folder with a device connect to your PC Locking a developer device will trigger the synchronisation If you have problems: Make sure that files are closed correctly Make sure that the devices are running the same version of the application

Roaming Settings demo 11/15/2018 © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

File Access

Different Methods For Addressing Storage Locations File Type/ API Installation Folder App data folder Example File access using Windows.Storage API via URIs ms-appx:/// ms-appdata:///local/ ms-appdata:///roaming/ ms-appdata:///temp/ var file = await Windows.StorageFile.GetFileFromApplicationUriAsync( new Uri("ms-appdata:///local/AppConfigSettings.xml")); File access using Windows.Storage API via StorageFolder references Windows. ApplicationModel.Package.Current. InstalledLocation Windows.Storage. ApplicationData. Current .LocalFolder / .RoamingFolder / .TempFolder var localFolder = Windows.Storage.ApplicationData.Current.LocalFolder; Windows.Storage.StorageFile storageFile = await localFolder.GetFileAsync("CaptainsLog.store");

Writing a complete file 11/15/2018 Writing a complete file This method will create a file from a string of text All the file operations are asynchronous private async void writeTextToLocalStorageFile(string filename, string text) { StorageFolder fold = Windows.Storage.ApplicationData.Current.LocalFolder; StorageFile file = await fold.CreateFileAsync(filename, CreationCollisionOption.ReplaceExisting); await FileIO.WriteTextAsync(file, text); } Sets the target folder Sets action if file already exists © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Reading a complete file This method will read a file into a string private async Task<string> readTextFromLocalStorage(string filename) { var fold = Windows.Storage.ApplicationData.Current.LocalFolder; StorageFile file = await fold.GetFileAsync(filename); string result = await FileIO.ReadTextAsync(file); return result; }

Writing a Complete File 11/15/2018 Writing a Complete File demo © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

11/15/2018 Using Streams As well as writing a complete file in one action using the FileIO API, you can also create a stream and write to this The read and write operations are asynchronous Streams handle the difference in latency between one type of storage (e.g. memory) and another (e.g. network or file system) Streams are used all over WinRT © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Writing to a file using a Stream private async void WriteToStreamButton_Click(object sender, RoutedEventArgs e) { StorageFolder localFolder = Windows.Storage.ApplicationData.Current.LocalFolder; StorageFile file = await localFolder.CreateFileAsync("JumpStart.txt"); string userContent = InputTextBox.Text; if (!String.IsNullOrEmpty(userContent)) using (StorageStreamTransaction transaction = await file.OpenTransactedWriteAsync()) using (DataWriter dataWriter = new DataWriter(transaction.Stream)) dataWriter.WriteString(userContent); transaction.Stream.Size = await dataWriter.StoreAsync(); // reset stream size to override the file await transaction.CommitAsync(); }

11/15/2018 Using a Stream demo © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Using XML and JSON serilializers

Storing Objects We have seen that it is easy to read and write settings and blocks of text However it is also useful to be able to store objects The serialization libraries in Windows Phone make it very easy to persist structured data using serialisation An application can serialise data into XML or JSON formats The data will be stored or transferred as text

Serialization Rules XML Serializer requires that the object must have a parameterless constructor Private and static members of the class will not be persisted Be careful of app upgrades: If you add members to the class in an app update and restore from a data file that was created by serializing using the previous class definition, you will have problems

Using a Serializer This code serializes a collection of customers using (Stream stream = await notesFolder.OpenStreamForWriteAsync(filename, CreationCollisionOption.OpenIfExists)) { DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Customer[])); serializer.WriteObject(stream, customers); } This code serializes a collection of customers

Using a Serializer This creates the serializer using (Stream stream = await notesFolder.OpenStreamForWriteAsync(filename, CreationCollisionOption.OpenIfExists)) { DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Customers)); serializer.WriteObject(stream, customers); } This creates the serializer The constructor is given the type of the object to store

Using a Serializer using (Stream stream = await notesFolder.OpenStreamForWriteAsync(filename, CreationCollisionOption.OpenIfExists)) { DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Customers)); serializer.WriteObject(stream, customers); } This writes the collection of customers to the output stream

Deserializing the data using (Stream stream = await notesFolder.OpenStreamForReadAsync(filename)) { DataContractJsonSerializer serializer = new DataContractJsonSerializer(typeof(Customers)); Customers result = serializer.ReadObject(stream) as Customers; } The read process is the reverse of the writing one Note that we have to cast the result of ReadObject(Stream) to the required type

XML Serialization This is how you save to an XML format file This is how you load from an XML format file XmlSerializer serializer = new XmlSerializer(typeof(Customers)); serializer.Serialize(stream, customers); XmlSerializer serializer = new XmlSerializer(typeof(Customers)); Customers result = serializer.Deserialize(stream) as Customers;

Compression

Using Windows.Storage.Compression.Compressor 11/15/2018 Using Windows.Storage.Compression.Compressor var s = await destFile.OpenAsync(FileAccessMode.ReadWrite); Compressor compressor = new Compressor(s.GetOutputStreamAt(0), CompressAlgorithm.Mszip, 0); An application can use compression when it saves and loads data The compression stream can be used as any other stream, but it compresses the data as it is transferred © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Compression Algorithms var s = await destFile.OpenAsync(FileAccessMode.ReadWrite); Compressor compressor = new Compressor(s.GetOutputStreamAt(0), CompressAlgorithm.Mszip, 0); There are a number of different algorithms available: Lzms Mszip Xpress XpressHuff You can also set the block size for the compression, the value 0 means use the default

Using Decompressor var s = await destFile.OpenAsync(FileAccessMode.ReadWrite); Compressor compressor = new Compressor(s.GetOutputStreamAt(0), CompressAlgorithm.Mszip, 0); The Decompressor complements the Compressor and provides an input stream that can be used to decompress files

Credential Locker securely store and roam user credentials

Overview APIs to store credentials (user name, password) securely Windows.Security.Credentials Benefits: Secure storage Credential isolation Roaming

Isolation Apps can only access their own credentials App A App B Locker App Sandbox Boundary App B

Roaming MSA Credentials roam across trusted devices App App 11/15/2018 © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Credential Locker sample void SaveCredential(string username, string password) { PasswordVault vault = new PasswordVault(); PasswordCredential cred = new PasswordCredential("MyAppResource", username, password); vault.Add(cred); } IReadOnlyList<PasswordCredential> RetrieveCredential(string resource) return vault.FindAllByResource(resource);

Credential Locker demo

Known Folders

KnownFolders KnownFolders is an API which simplifies the view the developer has of accessible user data on the phone Rather than searching through all the possible different locations on the device for a particular type of file a program can request a single list of all the files This includes files on the SD card (if inserted) along with files held on the device Files in KnownFolders are visible to all apps (that have registered the proper capabilities) Consider using the FileOpenPicker API as an alternative to allow users to select a file in these folders No capabilities required as consent is implied Covered in Session 10

KnownFolders Physical View Logical View Internal storage 11/15/2018 KnownFolders Physical View Logical View Internal storage KnownFolders.PicturesLibrary.GetFilesAsync() C:\Users\Public\Pictures\Seattle\ StorageFile: Pic01.jpg C:\Users\Public\Pictures\Birthday\ StorageFile: Pic01.jpg C:\Users\Public\Pictures\Pic01.jpg StorageFile: Pic02.jpg SD Card (if present) D:\Pictures\Portland\ D:\Pictures\Birthday\ D:\Pictures\Pic01.jpg D:\Pictures\Pic02.jpg D:\Pictures\Hawaii\Pic02.jpg © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Accessing User Content 11/15/2018 Accessing User Content var pictures = await Windows.Storage.KnownFolders.PicturesLibrary.GetFilesAsync(); KnownFolders provides access to: Pictures Videos Music © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Accessing Known Folders 11/15/2018 Accessing Known Folders demo © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.

Using the SD Card

The SD Card in Windows Phone 8.1 Phone applications now have read/write access to the SD Card Apps can store their own files and also make use of files already on the card This makes it possible for applications to share data amongst themselves There is full SD Card support provided by the emulator Maps to a local folder on your PC Because SD cards represent a “shared” resource, the application must declare file associations in the manifest for each file type it wants to access

Setting SD card capabilities Before an app can use the SD card you need to set some capabilities Removable Storage If you are using KnownFolders API, you may also need: Pictures Library Videos Library Music Library If these capabilities are not set the program will throw an exception when it runs

Applications and file associations A given application is not able to work with just any type of file stored on the SD card An application must declare associations with the file types that it works with An image processing program will work with files such as .jpg, .png, etc A sound processing program will work with .mp3 files You can add your own custom file types for your particular application if you wish The associations are set in the manifest Note that this is not required for applications accessing files in their own local/roaming/temporary storage This is the same mechanism used for app-to-app communications through file associations (See Session 10)

Setting file associations for your application The manifest for your application must specify the file types that are associated with it It will only be able to open files with that type This application can only work with .txt files

Getting an SD Card var devices = Windows.Storage.KnownFolders.RemovableDevices; var sdCards = await devices.GetFoldersAsync(); if (sdCards.Count == 0) return; StorageFolder firstCard = sdCards[0]; These statements get a reference to the SD card on the phone They are part of a method that creates a file on the SD card This method is part of the demo software we will be running later

Getting an SD Card var devices = Windows.Storage.KnownFolders.RemovableDevices; var sdCards = await devices.GetFoldersAsync(); if (sdCards.Count == 0) return; StorageFolder firstCard = sdCards[0]; We get a list of SD cards using the KnownFolders API There will only be 0 or 1

Getting an SD Card var devices = Windows.Storage.KnownFolders.RemovableDevices; var sdCards = await devices.GetFoldersAsync(); if (sdCards.Count == 0) return; StorageFolder firstCard = sdCards[0]; If there is not one present the value of the Count property will be 0 This method returns if there are no SD Cards on the device Your application must handle this eventuality gracefully Not all devices have an SD card slot The slot might not have a card fitted into it

Getting an SD Card var devices = Windows.Storage.KnownFolders.RemovableDevices; var sdCards = await devices.GetFoldersAsync(); if (sdCards.Count == 0) return; StorageFolder firstCard = sdCards[0]; The card is exposed as a StorageFolder, so we can use it in the same way the previous devices we have seen We can create folders and files But we can only work with files types for which we have declared a file association in the manifest

Inserting an SD card in the emulator The emulator provides support for SD cards You just map it to the folder that you are going to use When you press the Insert SD Card the emulator behaves exactly as if a card has been inserted into the phone

SD Cards in the Emulator The emulator will create the Documents, Music, Pictures and Videos folders in your SD card folder if they are not already present It can also use media from the folder This is a great way to get your content in the emulator for testing

Ejecting an SD Card from the emulator You can also eject an SD card Writes to the card may be synchronised when the card is ejected There is an option to select this We will use the SD card in the next section

Reading and Writing Json using the SD card storage 11/15/2018 Reading and Writing Json using the SD card storage demo © 2013 Microsoft Corporation. All rights reserved. Microsoft, Windows, and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.