|
I think that is a brilliant idea! I will consider it.
The difficult we do right away...
...the impossible takes slightly longer.
|
|
|
|
|
Is it possible to open a browser with Process.Start("www.someplace.com") and wait for a callback?
If so, what would that look like? I need to call Google People API in the default browser and wait for the redirect URL.
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
Ya can't fix stupid.
|
|
|
|
|
Callback? What callback?
No. You're "fire and forget" launching a new process that runs independently from your code. There is no callback or notification of anything completing in the browser.
You can call the Google API using an HttpClient and you'll have much greater control over the request and response process.
|
|
|
|
|
Ya, I was just hoping.
Thanks anyhow
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
Ya can't fix stupid.
|
|
|
|
|
This?
Window: DOMContentLoaded event - Web APIs | MDN
"Before entering on an understanding, I have meditated for a long time, and have foreseen what might happen. It is not genius which reveals to me suddenly, secretly, what I have to say or to do in a circumstance unexpected by other people; it is reflection, it is meditation." - Napoleon I
|
|
|
|
|
That fires inside the browser. It's not raised, or even exposed, to a separate process that launched the browser.
|
|
|
|
|
|
You'd have to use the WebView2 control or the WebBrowser in your own app to get at the event.
For one launched though the Process class, not so much.
He never said why he's launching it through Process or anything else related to it so until he does, suggestion after suggestion is a moot point.
|
|
|
|
|
Sorry I didn't clarify...
I need to call Google's People API from a WPF app and wait for authentication. Once authentication is complete, then my app will get contact info. The requirement from Google is that the app not use an embedded browser, so I have to figure out if the user authenticated before continuing.
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
Ya can't fix stupid.
modified 22-May-23 19:54pm.
|
|
|
|
|
OK, so does the Google API have an alternate way to authenticate using credentials the user enters in your app instead of using the Google login page?
|
|
|
|
|
Rather than using a Web browser, you would be better interacting directly with the API.
If you have to use the browser, you could always use a Web driver and Selenium. This should be of interest. How to automate web browser in C# - CODE-AI[^]
|
|
|
|
|
Is it possible to use the same void between multiple forms in the same project?
If it possible, how is it done?
|
|
|
|
|
No idea what that question means.
'void' is a keyword used in C# code.
The most frequent usage is to specify the return type of a method.
A much less frequent usage is as a void pointer in unsafe code usage.
|
|
|
|
|
If you mean a method as in:
void Foo() { ... } And you want to access it from a different form, then there are two things you need to consider:
1) If it is not declared as static then you need an instance of the containing form in order to call it:
MyContainingForm form = new MyContainingForm();
...
form.TheMethodYouWantToCall(); If it is declared as static then you prefix it with the containing form class name:
MyContainingForm.TheMethodYouWantToCall();
2) In both cases, the appropriate access modifiers must be used when declaring both the containing class and the method: Access Modifiers - C# Programming Guide | Microsoft Learn[^]
You may also need to explicitly prefix the namespace name as well.
"I have no idea what I did, but I'm taking full credit for it." - ThisOldTony
"Common sense is so rare these days, it should be classified as a super power" - Random T-shirt
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
Let's say that I have this Worker class which uses a Func to process data
public class Worker
{
public Func<int, List<string>> DataSource { get; set; }
public void Execute(int num)
{
var data = DataSource(num);
data.ForEach(x => Console.WriteLine(x));
}
}
I want to call a repository method using the func. Here's the repo method
public class Repo
{
public List<string> GetData(int num)
{
var results = new List<string>();
for (int x = 0; x < num; x++)
{
results.Add($"Result{x}");
}
return results;
}
}
And here's the class that fires it all
internal class Program
{
static void Main(string[] args)
{
var repo = new Repo();
var myClass = new Worker();
myClass.DataSource = repo.GetData;
myClass.Execute(10);
Console.ReadLine();
}
}
Here's the question...
How would I code this so that I wouldn't have to pass in the param to Execute? Can I define the Func with the param as part of it? Maybe something like:
myClass.DataSource = repo.GetData(10);
I don't want to have to pass any parameters into the Worker class. Can the func somehow accept parameters?
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
Ya can't fix stupid.
modified 4-May-23 0:58am.
|
|
|
|
|
Sounds like you're looking for "partial application":
Currying vs partial function application | Jon Skeet's coding blog[^]
For example:
public static class Functional
{
public static Func<TResult> Apply<TArg, TResult>(this Func<TArg, TResult> fn, TArg arg)
{
return () => fn(arg);
}
}
public class Worker
{
public Func<List<string>> DataSource { get; set; }
public void Execute()
{
var data = DataSource();
data.ForEach(x => Console.WriteLine(x));
}
}
internal class Program
{
static void Main(string[] args)
{
var repo = new Repo();
var myClass = new Worker();
myClass.DataSource = Functional.Apply(repo.GetData, 10);
myClass.Execute();
Console.ReadLine();
}
}
"These people looked deep within my soul and assigned me a number based on the order in which I joined."
- Homer
|
|
|
|
|
That's exactly what I need.
Thank you
If it's not broken, fix it until it is.
Everything makes sense in someone's mind.
Ya can't fix stupid.
|
|
|
|
|
Make 'num an optional parameter that provides a default value which the caller can override:
public static int defaultNumValue = 10;
public class Repo
{
public List<string> GetData(int num = defaultNumValue)
{
var results = new List<string>();
for (int x = 0; x < num; x++)
{
results.Add($"Result{x}");
}
return results;
}
}
«The mind is not a vessel to be filled but a fire to be kindled» Plutarch
|
|
|
|
|
Greetings,
Do you know of any C#/NET libraries to validate an XML file with Schematron.
I searched but couldn't find anything.
Thanks for your help.
Anthony
|
|
|
|
|
|
I have a project that will end up language dependent. I am also fairly new to XML in terms of reading it from files. I need to use XML for information used by the project and that information will be available in several languages. So the basic structure of the XML is this:
<InfoNode>
<Language ID="enUS">
<DataClassNode>
<Name>SomeName</Name>
<Abbrev>SN</Abbrev>
<Description>Some Description of what this represents</Description>
</DataClassNode>
</Language>
</InfoNode>
The code that does this and then the code that deserializes the information is this:
public static DataClassNode Deserialize(XmlReader reader, CultureInfo culturalLanguage)
{
XmlReader found = null;
XmlReader _default = null;
while (found == null)
{
if (reader.ReadToFollowing("Language"))
{
if (reader.MoveToAttribute("ID"))
{
string id = reader.ReadContentAsString();
reader.MoveToElement();
if (id.Equals(culturalLanguage.Name))
{
found = XmlReader.Create(reader.ReadElementContentAsString());
}
else if (id.Equals(DefaultCulture.Name))
{
_default = XmlReader.Create(reader.ReadInnerXml().ToStream());
}
}
}
else
break;
}
if (found == null)
{
if (_default == null)
throw new Exception("Default Language Not Found!");
else
found = _default;
}
DataContractSerializer serializer = new DataContractSerializer(typeof(DataClassNode));
DataClassNode flagtag = (DataClassNode)serializer.ReadObject(found);
if (flagtag == null)
throw new Exception("Cannot deserialize DataClassNode Object!");
return flagtag;
}
I have been able to navigate to the language and make sure the one needed is found. Now I need to populate a class instance with the data inside the language node. I am using DataContractSerializer so I want a new XMLreader instance that contains the content of the language node ONLY. Not sure how to do this though. I know how to read strings etc... just not sure how to read the contents of the language node. I have tried what is above. I have tried InnerXML and OuterXML. Both of these return "None" as my XML. My comments point to where my knowledge falls short.
modified 20-Apr-23 10:00am.
|
|
|
|
|
I think you should be using "XPath navigation".
Select Nodes Using XPath Navigation | Microsoft Learn
"Before entering on an understanding, I have meditated for a long time, and have foreseen what might happen. It is not genius which reveals to me suddenly, secretly, what I have to say or to do in a circumstance unexpected by other people; it is reflection, it is meditation." - Napoleon I
|
|
|
|
|
The XmlReader is pretty low level, and I would not recommend you use it.
Better options:
- Use XDocument[^]. The examples on the page are focusing on creating the document, but use the static Load or Create methods when you already have the file.
- Make a full C# class representing your XML and use the DataContract serializer - then get your data from there using standard C# code.
XmlReader is very good at dealing with XML where you do not want to keep everything in memory - if that is a requirement, then you might have made a mistake somewhere earlier in the project.
That said, the XmlNodeReader[^] is doing what you are asking for.
|
|
|
|
|
Thanks,
I used a mix of XmlReader and XmlDocument to resolve it so it is similar to your suggestion.
|
|
|
|
|
Banging my head on a likely simple problem...
I'm getting a 405 on a WebSocket connection with WSS but not WS.
Vanilla project in VS with this code. Starting with HTTP works. Starting under HTTPS faults 405.
public static class Program {
public static void Main (string [] args) {
var builder = WebApplication.CreateBuilder ( args );
var app = builder.Build ();
app.UseWebSockets ();
app.MapGet ( "/" , (HttpContext http)
=> http.Response.WriteAsync ($$"""
<script>
self.Socket = new WebSocket(`${location.origin.replace("http", "ws")}/socket`);
</script>
""" ) );
app.MapGet ( "/socket" , Connect);
app.Run ();
}
static void Connect (HttpContext HttpContext) {
_ = HttpContext.WebSockets.AcceptWebSocketAsync ().Result;
}
}
modified 14-Apr-23 11:30am.
|
|
|
|