Activities of "falsharif"

And btw thanks alot , you always provide timely and great support, much appreciated :)

Update : I figured it out , it was the names of the functions , the name convention needed the word Async at the end of function names !

Update : I got the JWT token to work but i am having a weird issue while generating the proxies using : abp generate-proxy -t csharp -u https://localhost:44358

some of the proxies generated have this issue for some of the functions, i cant see anything in common with those functions :

public virtual GroupDto GetByFriendlyUrl(string url, Guid pmnId) { //Client Proxy does not support the synchronization method, you should always use asynchronous methods as a best practice throw new System.NotImplementedException(); }

However , my function is actually Async as can be seen here :

public interface IGroupAppService : IApplicationService { Task<PagedResultDto<GroupDto>> GetListAsync(GetGroupsInput input);

    Task&lt;GroupDto&gt; GetAsync(Guid id);

    Task DeleteAsync(Guid id);

    Task&lt;GroupDto&gt; CreateAsync(CreateOrUpdateGroupInput input);

    Task&lt;GroupDto&gt;  UpdateAsync(CreateOrUpdateGroupInput input);

    Task&lt;List&lt;GroupDto&gt;> GetMyGroups(Guid pmnId);
    Task&lt;GroupDto&gt; GetByFriendlyUrl(string url, Guid pmnId);
    Task SetAllGroupsFullPath();
}

Hello, thanks for the advice, ok so now its calling the api endpoint but the token isnt being passed and my endpoints returns Unauthorized:

I have my own login page which was implemented and working on my original blazor UI project. i copied the same config to this project as follows

public override void ConfigureServices(ServiceConfigurationContext context) { var environment = context.Services.GetSingletonInstance<IWebAssemblyHostEnvironment>(); var builder = context.Services.GetSingletonInstance<WebAssemblyHostBuilder>();

        ConfigureAuthentication(builder);
        ConfigureHttpClient(context, environment);
        ConfigureBlazorise(context);
        ConfigureRouter(context);
        ConfigureUI(builder);
        ConfigureAutoMapper(context);
        
        context.Services.AddScoped&lt;TokenServerAuthenticationStateProvider&gt;();
        context.Services.AddScoped&lt;AuthenticationStateProvider&gt;(provider => provider.GetRequiredService&lt;TokenServerAuthenticationStateProvider&gt;());
    }

Would it be possible to create a working example project ? would really appreciate it , already my application is down to 1.9 seconds load now, just need to fix the token header.

But in the Blazor app provided by the ABP framework, you have CurrentUser and CurrentTenant objects that can immediately be used to determine which user is logged in somehow using the token, how is that achieved ? and how come you are telling me that this has nothing to do with the ABP framework when its the abp framework that has all of this wired up ?

Very poor answer for commercial support to be honest ! What do you mean just google it ?! I am not stupid, just needed some guidance but you are obviously not willing to guide me in the right direction.

You should google to find out how to be better at supporting your clients.

Anyway thanks for nothing

Ok so i have the current test environment for my web app which cab be accessed on https://uat.promailnet.com/ when you land on https://uat.promailnet.com/ , the system will redirect the user to the auth server page on

https://uatserver.promailnet.com/Account/Login?ReturnUrl=%2Fconnect%2Fauthorize%2Fcallback%3Fclient_id%3DProMailNet_Blazor%26redirect_uri%3Dhttps%253A%252F%252Fuat.promailnet.com%252Fauthentication%252Flogin-callback%26response_type%3Dcode%26scope%3Dopenid%2520profile%2520ProMailNet%2520role%2520email%2520phone%26state%3De70063b5d57f46bfa630aa54a85e65af%26code_challenge%3DXddk2O1otOqY3v3KD8z5E1m1GneF1YEzopU-YitQZdM%26code_challenge_method%3DS256%26response_mode%3Dquery

once the user logs in, it will redirect back to https://uat.promailnet.com/ with the user authenticated and the JTW token available in the header of every http request which is currently working fine.

My issue is that customizing the Authorization page is hectic and limited, i also dont like the whole Single sign on Redirect mechanism .

What i want is to be able to create my own login page from scratch as part of my blazor project and authenticate, get the token and attach it to my header without having to use the current authentication page of Microsoft Identity.

For example when i create a mobile app, i use the https://uatserver/connect/token endpoint with grant type password and this generates a JWT token which is then used throughout the app on every Api request. I want to be able to do the same with my blazor application so i can avoid using the Microsoft identity login page created by the ABP framework.

I hope this explains my scenario , I essentially want to create my own login page from scratch and have it in my blazor app instead of having it on my server application.

Would really appreciate your answer and a solution that i can actually implement :)

Cheers !

Hello,

I have only Team License. Is there any way to get the source code of this specific module ?

Answer

Hey Albert, appreciate your help and willininges to help me, you are right , this was more of an EFCORE problem, here is how i managed to do it :

public virtual async Task<IQueryable<ShopWithNavigationProperties>> GetQueryForNavigationPropertiesAsync() {

        var query = from shop in (await GetDbSetAsync()).DefaultIfEmpty()
            join invoice in (await GetDbContextAsync()).Invoices.DefaultIfEmpty() on shop.Id equals invoice.TenantId into invoices
            from invoice in invoices.DefaultIfEmpty()
            group invoice by new { shop.Id, shop.StoreName, shop.Name,
                shop.IsOnlineStoreEnabled, shop.ImgUrl, 
                shop.Latitude,shop.Longitude,shop.OpeningHour, 
                shop.ClosingHour,shop.DeliveryProximity } into g
            select new  ShopWithNavigationProperties
            {
                Id = g.Key.Id,
                StoreName = g.Key.StoreName, 
                Name = g.Key.Name,
                IsOnlineStoreEnabled = g.Key.IsOnlineStoreEnabled,
                Longitude = g.Key.Longitude,
                Latitude = g.Key.Latitude,
                ClosingHour = g.Key.ClosingHour,
                OpeningHour = g.Key.OpeningHour,
                DeliveryProximity = g.Key.DeliveryProximity,
                ImgUrl = g.Key.ImgUrl,
                TotalOrders = g.Count() , 
                TotalTransactions= g.Sum(c=>c.GrandTotal)
            } into shops
            orderby shops.TotalTransactions descending 
            select shops;;

     
        return query;

        


    }
Answer

to disable tenant filter use ( https://docs.abp.io/en/abp/latest/Data-Filtering )

 using (_dataFilter.Disable<IMultiTenant>()) 
{ 
    return await _bookRepository.GetListAsync(); 
} 

and as I understand you created Shop entity via Suite. If so you can write an overload method for GetListWithNavigationPropertiesAsync so that you can pass null values to MaxResultCount and SkipCount

Shop Entity is the equivleant of Tenant Like the way AppUser Extends Identity User

I know about disable the multitenant filter , but that is not my question here. .

How do i show a table where i can display for each tenant , the total transactions like the screenshot below .

Invoices is an AUDITEDAGGREGATEROOT and so is TENANT

so how can i do one to many between tenant and Invoice to display sums like this :

hi

Dear team, is there a faster way to run DBMigrator on 1000+ Tenants ?

You can try to execute the migration concurrently, such as creating multiple threads to execute the migration separately.

Is there a way to keep the system running while migration is running ?

This is similar to system running when changing the database, which may be difficult or impossible.

can i migrate them back to a single database ?

You can back to use the Host database by deleting the tenant's connection string.

"You can back to use the Host database by deleting the tenant's connection string."

does the script move the data back to the host database ?

Showing 1 to 10 of 14 entries
Made with ❤️ on ABP v9.1.0-rc.1. Updated on January 17, 2025, 14:13