Bug 189846

Summary: [Win][WebKit] Implement authentication dialog on MiniBrowser.
Product: WebKit Reporter: Basuke Suzuki <basuke>
Component: Tools / TestsAssignee: Basuke Suzuki <basuke>
Status: RESOLVED FIXED    
Severity: Normal CC: achristensen, basuke, bfulgham, commit-queue, don.olmstead, ews-watchlist, Hironori.Fujii, lforschler, pvollan, stephan.szabo, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=174662
Attachments:
Description Flags
PATCH
none
PATCH
none
FIX
none
PATCH none

Description Basuke Suzuki 2018-09-21 12:02:39 PDT
It was implemented for WebKitLegacy, but not for WebKit.
Comment 1 Basuke Suzuki 2018-09-21 14:42:47 PDT
Created attachment 350431 [details]
PATCH
Comment 2 EWS Watchlist 2018-09-21 14:46:18 PDT
Attachment 350431 [details] did not pass style-queue:


ERROR: Tools/MiniBrowser/win/WebKitBrowserWindow.cpp:31:  Alphabetical sorting problem.  [build/include_order] [4]
ERROR: Tools/MiniBrowser/win/MiniBrowserLibResource.h:0:  No copyright message found.  You should have a line: "Copyright [year] <Copyright Owner>"  [legal/copyright] [5]
Total errors found: 2 in 8 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 3 Basuke Suzuki 2018-09-21 16:44:32 PDT
Created attachment 350454 [details]
PATCH
Comment 4 EWS Watchlist 2018-09-21 16:47:15 PDT
Attachment 350454 [details] did not pass style-queue:


ERROR: Tools/MiniBrowser/win/WebKitBrowserWindow.cpp:31:  Alphabetical sorting problem.  [build/include_order] [4]
ERROR: Tools/MiniBrowser/win/WebKitBrowserWindow.cpp:84:  create_bstr_t is incorrectly named. Don't use underscores in your identifier names.  [readability/naming/underscores] [4]
ERROR: Tools/MiniBrowser/win/MiniBrowserLibResource.h:0:  No copyright message found.  You should have a line: "Copyright [year] <Copyright Owner>"  [legal/copyright] [5]
Total errors found: 3 in 8 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 5 Basuke Suzuki 2018-09-24 15:52:36 PDT
Created attachment 350706 [details]
FIX

Fix style. Didn't fix those in the tool generated files.
Comment 6 EWS Watchlist 2018-09-24 15:54:23 PDT
Attachment 350706 [details] did not pass style-queue:


ERROR: Tools/MiniBrowser/win/MiniBrowserLibResource.h:0:  No copyright message found.  You should have a line: "Copyright [year] <Copyright Owner>"  [legal/copyright] [5]
Total errors found: 1 in 8 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 7 Fujii Hironori 2018-09-24 19:40:36 PDT
Comment on attachment 350706 [details]
FIX

View in context: https://bugs.webkit.org/attachment.cgi?id=350706&action=review

> Tools/MiniBrowser/win/Common.cpp:125
> +    _bstr_t& password;

The reason why I don't like this patch is I don't want to use
_bstr_t in common code and modern WebKit part becuase _bstr_t is
a string type for COM. This is not problem for WebKitLegacy
because it is a COM API.

I was using std::wstring for modern WebKit part in my original
patch (Bug 184770 Comment 1). But, I'm not confident std::wstring
is the best choice for them. How do you think?
Comment 8 Basuke Suzuki 2018-09-25 11:37:12 PDT
(In reply to Fujii Hironori from comment #7)
> Comment on attachment 350706 [details]
> FIX
> 
> View in context:
> https://bugs.webkit.org/attachment.cgi?id=350706&action=review
> 
> > Tools/MiniBrowser/win/Common.cpp:125
> > +    _bstr_t& password;
> 
> The reason why I don't like this patch is I don't want to use
> _bstr_t in common code and modern WebKit part becuase _bstr_t is
> a string type for COM. This is not problem for WebKitLegacy
> because it is a COM API.
> 
> I was using std::wstring for modern WebKit part in my original
> patch (Bug 184770 Comment 1). But, I'm not confident std::wstring
> is the best choice for them. How do you think?

I'm still very beginner programmer for Win32 platform. I've asked to my team mate what is BSTR. I've used wstring on my previous implementation for legacy, but I found that was converted to _bstr_t at the end so that I decided to use _bstr_t.

I cannot believe why MS uses _ for such a public API even if it is a wrapper. Also it's not easy to manipulate. I want to minimize the usage of _bstr_t, limiting to the very far end of passing Win32 API.

If you agree, I want to stick with std::wstring for Win app coding as much as possible.
Comment 9 Stephan Szabo 2018-09-25 11:47:43 PDT
I would say that wstring makes sense for at least these kinds of uses in the shared code in minibrowser. The other option that may make sense in some cases is WKStringRef if we're going primarily from one WK api to another, rather than converting to wstring and then back.
Comment 10 Basuke Suzuki 2018-09-25 13:04:30 PDT
(In reply to Stephan Szabo from comment #9)
> I would say that wstring makes sense for at least these kinds of uses in the
> shared code in minibrowser. The other option that may make sense in some
> cases is WKStringRef if we're going primarily from one WK api to another,
> rather than converting to wstring and then back.

Converting from WKStringRef to _bstr_t is not possible directly. _bstr_t  constructors requires null terminated string, not data + length. So at least some sort of simple buffer is required to get string contents from WKStringRef and to pass _bstr_t. std::wstring satisfies those requirements.
Comment 11 Stephan Szabo 2018-09-25 13:12:06 PDT
The side part of that was less for this case specifically, but more for a case where we have something like:

Call WKFoo() to get a string (as WKStringRef) and store that for later on an object.

<on some later user interaction>
Call WKBar(str) with that string

Where the only/primary way the string is used is to pass back to another WK API, it may make sense to keep that as a WKStringRef rather than converting it into a wstring.
Comment 12 Fujii Hironori 2018-09-25 18:28:00 PDT
(In reply to Basuke Suzuki from comment #8)
> I'm still very beginner programmer for Win32 platform. I've asked to my team
> mate what is BSTR. I've used wstring on my previous implementation for
> legacy, but I found that was converted to _bstr_t at the end so that I
> decided to use _bstr_t.
> 
> I cannot believe why MS uses _ for such a public API even if it is a
> wrapper. Also it's not easy to manipulate. I want to minimize the usage of
> _bstr_t, limiting to the very far end of passing Win32 API.
> 
> If you agree, I want to stick with std::wstring for Win app coding as much
> as possible.

_bstr_t is a useful wrapper class for BSTR. I'd like to use it in
WebKitLegacyBrowserWindow. In C++, any names prefixed with _ are
preserved for the system. It is safe for the system to introduce
a new name with prefix _ without breaking existing code. I think
this is the reason _bstr_t is _-prefixed.

There is another BSTR.
Source/WebCore/platform/win/BString.h
But, I don't like the idea using this in MiniBrowser.
I'd like MiniBrowser use only public WebKit API (WK1 and WK2).

But, this is just my opition. MiniBrowser already is using WebCore header.
#include <WebCore/COMPtr.h>
https://github.com/WebKit/webkit/blob/907de274451932ef356129302afef6208ff21ce5/Tools/MiniBrowser/win/ResourceLoadDelegate.cpp#L31
Comment 13 Basuke Suzuki 2018-09-26 12:58:38 PDT
Created attachment 350886 [details]
PATCH

Use std::wstring more.
Comment 14 EWS Watchlist 2018-09-26 13:01:30 PDT
Attachment 350886 [details] did not pass style-queue:


ERROR: Tools/MiniBrowser/win/MiniBrowserLibResource.h:0:  No copyright message found.  You should have a line: "Copyright [year] <Copyright Owner>"  [legal/copyright] [5]
Total errors found: 1 in 8 files


If any of these errors are false positives, please file a bug against check-webkit-style.
Comment 15 Fujii Hironori 2018-09-26 21:05:45 PDT
Comment on attachment 350886 [details]
PATCH

View in context: https://bugs.webkit.org/attachment.cgi?id=350886&action=review

> Tools/MiniBrowser/win/Common.cpp:163
> +std::optional<Credential> askCredential(HWND hwnd, const std::wstring& realm)

askCredential is a strange name for me because Credential is a piece of information provided by server.
https://en.wikipedia.org/wiki/Credential

> Tools/MiniBrowser/win/WebKitBrowserWindow.cpp:41
> +    size_t actualLength = WKStringGetCharacters(wkString, str.data(), maxSize);

str.data() can not be modified in C++14 which we are using. This is the reason why Chris uses std::vector<char> (Bug 187167).
But, it seems OK in C++17.
https://en.cppreference.com/w/cpp/string/basic_string/data
I am OK if this doesn't emit a compiler warning.
Comment 16 Fujii Hironori 2018-09-26 21:09:56 PDT
(In reply to Fujii Hironori from comment #15)
> askCredential is a strange name for me because Credential is a piece of
> information provided by server.

Never mind this my comment. WK2 API has a API WKCredentialCreate.
WKCredentialCreate(WKStringRef username, WKStringRef password, WKCredentialPersistence);
Comment 17 WebKit Commit Bot 2018-09-27 09:27:45 PDT
Comment on attachment 350886 [details]
PATCH

Clearing flags on attachment: 350886

Committed r236549: <https://trac.webkit.org/changeset/236549>
Comment 18 WebKit Commit Bot 2018-09-27 09:27:47 PDT
All reviewed patches have been landed.  Closing bug.
Comment 19 Radar WebKit Bug Importer 2018-09-27 09:28:24 PDT
<rdar://problem/44832874>