My flawless cross-platform data sync experiences

In this article, I would like to share my own experience of how I use different service providers to make sure that my files, music, passwords, emails are available on all my devices. Be it macOS, Windows, Android or iOS. The services detailed below reflect my personal preferences. It is possible that there are better providers that are cheaper or that offer more functionality. If you know of such, help readers by writing in to tell us what works for you. I personally do not like Google’s services. I will not recommend Google Drive, Authenticator and other services in this article, but I am sure that their solutions can solve the architecture I consider to be proven.

What I’d like to show you is how I manage in my daily life to make sure that all my data is in sync and accessible on all my devices, almost without exception.

File Storage and e-mail account. Notes, Calendar, Contacts.

I personally chose Microsoft’s OneDrive technology as my storage and email provider. They give you 5GB of cloud storage space in their free plan, and an extra 15 GB for emails. For a very long time I subscribed to Microsoft OneDrive +100GB for $2 per month, which is fair, but then recently I decided to subscribe to Microsoft Office 365. Partly so I could have a licensed Microsoft Office subscription of my own to access important files on my personal computer, and partly because they are increasing the cloud storage to 1TB. On top of that, we also get support for recovering our deleted, lost files, or if a file encryption caused by a ransomware virus happens, it can detect and stop the operation. The one terabyte package runs around $60 for a year (+VAT, which is 27% in Hungary). If you buy it, you’ll also no longer have to watch the notifications on the outlook.com web interface. You also get the desktop versions of these in addition to the web versions of Excel, Word, Powerpoint. You can install the desktop version of Microsoft Office on 5 computers with one license key.

OneDrive use pretty serious file encryption, so you can feel safe with your files here, but if you have something really personal in your cloud, there’s the safe feature, which uses an extra encryption algorithm in addition to a number of security requirements

On Windows the OneDrive client is integrated, on macOS it can be installed separately, it integrates quite nicely into the system. You can configure them not to download the entire cloud content to your computer unnecessarily, but to have a file available in the file structure in case you want to store it. What it does is download the file to the physical hard disk before use. This saves a lot of space.
On Android, the OneDrive client also integrates quite well with the operating system, but I don’t use an Android device on a daily basis, just an iPhone.
Mobile clients can automatically back up your camera roll. The upload is an interesting solution for iOS, as they couldn’t do it in the background: they developed a screen called “Night Backup”, which basically layers a wakelock on the display and takes the brightness off the phone. You can view files on your mobile “without downloading”. Handles the web client for the iPhone HEIC format.

Your Outlook email address can be accessed via an Exchange server, which also allows you to save Calendar and Reminders, Notes, Contacts. Personally, I have all syncing turned off in iCloud because I sync my notes to my Outlook account. If you set macOS and iOS to take your outlook email address as your Internet account, the built-in Notes, Email, Calendar app can handle it. This is good because in Windows it’s also built-in to sync everything to the outlook account, so you get a Notepad and Calendar on top of the emails. So if you add a meeting to your calendar, it’ll show up immediately on your iOS/Android device, and also on macOS. Of course it works in all directions. The only downside to the notepad is that on macOS you can’t bold letters, insert a diagram, etc. in the notes app. So if you have an iPad and an Apple Penciled, you’ll have to choose a different way to draw.

Plus one thing besides Outlook that I haven’t seen with any other provider: you can assign aliases to your email address. So you don’t have to register a new email address if you get bored of your old email, you can simply add another address to the account and use up to 10 email addresses with one mailbox.
You can find out more about the packages and their services here: https://www.microsoft.com/en-us/microsoft-365/onedrive/compare-onedrive-plans?activetab=tab%3aprimaryr1

Music

This is probably the subject I have dealt with the least. I spend about 80,000 minutes a year listening to music. I clearly chose an online music service provider. My choice was Spotify. Since then, I have tried a service called Tidal once, which is quasi the same as Spotify, but lossless music, but I didn’t feel it was worth the extra money, I couldn’t take advantage of it.
Spotify has the ability to sync playlists between all platforms. It has a relatively good algorithm for recommending music. You can download tracks of reasonable quality for offline listening on its mobile app. The radio in my car supports it natively. Of course, the 1TB of storage space could hold a lot of music, but you don’t have to worry about downloading it

More information about Spotify: https://www.spotify.com/us/premium/

Password management and two-factor authentication

I never use the same password on any service. In fact, it could be said that I don’t even use passwords, because I don’t know any of them by memory. This is because I let the computer generate super long and complicated passwords. That’s pretty much how to use a password manager effectively, and how to perhaps exist one step more securely on the Internet.

What was important to me was to make the password manager work on macOS and windows, and to be able to add passwords to iOS not only in safari, but also in the apps.

Microsoft Authenticator could have been the perfect solution, but it wasn’t. (https://www.microsoft.com/en-us/security/mobile-authenticator-app) As I am logged in to my work account on my devices, where the password storage functionality of the Authenticator application is disabled by policy, I cannot add passwords to my personal account. But maybe that’s okay, it’s less responsibility on my Microsoft account. After much searching, I found LastPass to be the most sensible password management application. It works on mac on windows, in all browsers, and integrates with iOS. And it can also fill in passwords in apps. https://www.lastpass.com/pricing.

Another very important thing is to protect your account from unauthorised access. Almost all websites can be set up with two-factor authentication, be it Instagram, Facebook, GitHub, etc. Lastpass also has an Authenticator application that can generate such two-factor passcodes. Just like Microsoft authenticator. I’ve set up two-factor authentication everywhere.

This content has 2 years. Some of the information in this post may be out of date or no longer work. Please, read this page keeping its age in your mind.

Update: Moved banditoth.hu to banditoth.net

dotnet-bot (dotnet bot) · GitHub

Some weeks ago i decided to purchase my .hu domain’s .net version. How funny is that i do love .NET stuff to develop, and the domain associated to my blog is .net? 😀 From today, you will access my blog through https://www.banditoth.net/ instead of the .hu version. No worries, you will have time to rearrange your bookmarks, because banditoth.hu is available for almost two year from now, and it redirects users to the .net version of the site.

This content has 2 years. Some of the information in this post may be out of date or no longer work. Please, read this page keeping its age in your mind.

Sourcetree + Azure DevOps error

If you are facing the issue with Sourcetree, that you can not push to your Azure DevOps repository, because it fails with the following error:

Pushing to https://bitfoxhungary.visualstudio.com/someProject/_git/someProject
fatal: unable to access 'https://bitfoxhungary.visualstudio.com/someProject/_git/someProject/': The requested URL returned error: 403

Copy the URL returned by the error, and browse it with a web browser.

If needed, provide your login credentials in the browser, then try again.

This content has 3 years. Some of the information in this post may be out of date or no longer work. Please, read this page keeping its age in your mind.

D365 BC OData: Filtering for boolean fields in the correct way

Somehow, Microsoft’s documentation for using OData service in Business Central does not give enough information for the proper usage of the OData’s filter for boolean fields. That’s when Postman becomes your best friend, and you are starting arguing about how to compare equality to a boolean field using filters. Oh, have you looked up stackoverflow already? Some say, that you will need to make a new column in the page, and put the boolean value as a string, to be able to use it in filter with string compare!! 😀 Others say, you will need to send the equality compare statement with binary marks, 1 for true and 0 for false.
None of the solutions mentioned will work. I mean the string compare method should work, but I recommend to use it for no one.

My test results

// Request 1
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq 'Yes'

"code": "BadRequest",
        "message": "A binary operator with incompatible types was detected. Found operand types 'Edm.Boolean' and 'Edm.String' for operator kind 'Equal'.  CorrelationId:  c409ac25-b53a-4fcd-ac7d-c87fe6999666."

// Request 2
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq Yes

 "code": "BadRequest",
        "message": "Could not find a property named 'Yes' on type 'NAV.<<TABLENAME>>'.  CorrelationId:  beb9f4bb-cec5-4d40-84b9-9802d45a5fa9."

// Request 3
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq yes

        "code": "BadRequest",
        "message": "Could not find a property named 'yes' on type 'NAV.<<TABLENAME>>'.  CorrelationId:  3f96be5e-f489-43fe-a24c-ea8255cc1cc1."

// Request 4
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq 1

 "code": "BadRequest",
        "message": "A binary operator with incompatible types was detected. Found operand types 'Edm.Boolean' and 'Edm.Int32' for operator kind 'Equal'.  CorrelationId:  d9f9a696-0f6d-48c4-89f5-60d784126810."

// Request 5
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq True

    "error": {
        "code": "BadRequest",
        "message": "Could not find a property named 'True' on type 'NAV.<<TABLENAME>>'.  CorrelationId:  b567a22c-6fa8-4333-801d-1b3deb42a7fb."

// Request 6
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq 'True'

        "code": "BadRequest",
        "message": "A binary operator with incompatible types was detected. Found operand types 'Edm.Boolean' and 'Edm.String' for operator kind 'Equal'.  CorrelationId:  94ae066f-8a9f-4c39-8c4e-667c8d15579f."

// Request 7
https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq 'true'

        "code": "BadRequest",
        "message": "A binary operator with incompatible types was detected. Found operand types 'Edm.Boolean' and 'Edm.String' for operator kind 'Equal'.  CorrelationId:  f08024a2-00f1-474c-957d-8ce1c15bf452."

The solution

The boolean operators in OData filters are CASE SENSITIVE, and marked with true and false. You won’t need to put in single quotation marks, or use binary marks like 1 or 0. The solution is simple:

// Request 8: 

https://<<HOST>>/ODataV4/Company('CRONUS International Ltd.')/<<TABLENAME>>?$select=Entry_No,Item_No,Lot_No,Positive,Qty_to_Handle_Base,Quantity_Base,Serial_No,Source_ID,Source_Ref_No&$filter=Entry_No eq 10 and Positive eq true

// Response 8:

    "value": [
        {
            "Entry_No": 10,
            "Positive": true,
            "Serial_No": "555",
            "Lot_No": "555",
            "Quantity_Base": 1,
            "Qty_to_Handle_Base": 1,
            "Item_No": "1",
            "Source_Ref_No": 10000,
            "Source_ID": "1001"
        }

This content has 3 years. Some of the information in this post may be out of date or no longer work. Please, read this page keeping its age in your mind.

Visual Studio: Azure DevOps Git – The pull operation failed

When trying to sync or pull our repository from remote, it fails with the following error:

The pull operation failed, see Output Window for details.

In the output window, the error is the following:

Cannot determine the organization name for this 'dev.azure.com' remote URL. Ensure the `credential.useHttpPath` configuration value is set, or set the organization name as the user in the remote URL '{org}@dev.azure.com'.

Go to Visual Studio’s Tools, and then Options, search for ‘Git’ in the searchbar.

Select the Git Global Settings option, and find the ‘Credential helper’ setting, and set it from ‘Unset’ to:

GCM For Windows

This should solve your problem.

This content has 3 years. Some of the information in this post may be out of date or no longer work. Please, read this page keeping its age in your mind.