Hi,
If you go through all the above mentioned issue, I was finally able to create users in Project B. But now in Project B all unit test cases are failing and all have the same error as below :
Message:
Volo.Abp.AbpInitializationException : An error occurred during the initialize Volo.Abp.Modularity.OnApplicationInitializationModuleLifecycleContributor phase of the module Volo.Abp.AspNetCore.Mvc.AbpAspNetCoreMvcModule, Volo.Abp.AspNetCore.Mvc, Version=3.0.4.0, Culture=neutral, PublicKeyToken=null: Could not find singleton service: Microsoft.AspNetCore.Hosting.IWebHostEnvironment, Microsoft.AspNetCore.Hosting.Abstractions, Version=3.1.12.0, Culture=neutral, PublicKeyToken=adb9793829ddae60. See the inner exception for details.
---- System.InvalidOperationException : Could not find singleton service: Microsoft.AspNetCore.Hosting.IWebHostEnvironment, Microsoft.AspNetCore.Hosting.Abstractions, Version=3.1.12.0, Culture=neutral, PublicKeyToken=adb9793829ddae60
Stack Trace:
ModuleManager.InitializeModules(ApplicationInitializationContext context)
AbpApplicationBase.InitializeModules()
AbpApplicationWithExternalServiceProvider.Initialize(IServiceProvider serviceProvider)
AbpIntegratedTest`1.ctor()
ProfileManagementTestBase`1.ctor()
ProfileManagementApplicationTestBase.ctor()
XYZAppServiceTests.ctor() line 12
----- Inner Stack Trace -----
ServiceCollectionCommonExtensions.GetSingletonInstance[T](IServiceCollection services)
AbpAspNetCoreServiceCollectionExtensions.GetHostingEnvironment(IServiceCollection services)
<>c__DisplayClass1_0.<ConfigureServices>b__2(AbpAspNetCoreMvcOptions options)
PostConfigureOptions`1.PostConfigure(String name, TOptions options)
OptionsFactory`1.Create(String name)
<>c__DisplayClass5_0.<Get>b__0()
Lazy`1.ViaFactory(LazyThreadSafetyMode mode)
Lazy`1.ExecutionAndPublication(LazyHelper executionAndPublication, Boolean useDefaultConstructor)
Lazy`1.CreateValue()
Lazy`1.get_Value()
OptionsCache`1.GetOrAdd(String name, Func`1 createOptions)
OptionsManager`1.Get(String name)
OptionsManager`1.get_Value()
AbpAspNetCoreMvcModule.AddApplicationParts(ApplicationInitializationContext context)
AbpAspNetCoreMvcModule.OnApplicationInitialization(ApplicationInitializationContext context)
OnApplicationInitializationModuleLifecycleContributor.Initialize(ApplicationInitializationContext context, IAbpModule module)
ModuleManager.InitializeModules(ApplicationInitializationContext context)
Sorry to reopen the ticket, but to understand the issue I thought It would be better to mention it here itself.
@gterdem
Yup only Module Dependencies part was missing, once I added those dependencies it worked. Thanks alot !!! Appreciate your quick response.
Hi @gterdem ,
Sorry my bad, copy paste issue.
These are the packages
<PackageReference Include="Volo.Abp.Identity.Application" Version="3.0.4" />
<PackageReference Include="Volo.Abp.Identity.EntityFrameworkCore" Version="3.0.4" />
<PackageReference Include="Volo.Abp.Identity.HttpApi" Version="3.0.4" />
Still facing same issues
Hi
I installed these packages from nuget manager as below
<PackageReference Include="Identity.EntityFrameworkCore" Version="1.2.7" />
<PackageReference Include="Volo.Abp.Auditing" Version="3.0.4" />
<PackageReference Include="Volo.Abp.AuditLogging.Domain" Version="3.0.4" />
My AppService.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Identity;
using Microsoft.Extensions.Localization;
using Volo.Abp;
using Volo.Abp.Application.Dtos;
using Volo.Abp.Identity;
public class SupplierRegistrationAppService : ProfileManagementAppService, ISupplierRegistrationAppService
{
private readonly IdentityUserManager _identityUserManager;
private readonly IIdentityRoleRepository _identityRoleRepository;
public SupplierRegistrationAppService(
IdentityUserManager identityUserManager,
IIdentityRoleRepository identityRoleRepository
)
{
_identityUserManager = identityUserManager;
_identityRoleRepository = identityRoleRepository;
}
public async Task<LitmusUserOutputDto> CreateUserAsync(LitmusUserCreateDto input)
{
var output = new LitmusUserOutputDto();
if (input.TenantId.HasValue)
{
using (CurrentTenant.Change(input.TenantId))
{
//User
var user = new Volo.Abp.Identity.IdentityUser(GuidGenerator.Create(), input.UserName, input.EmailAddress, CurrentTenant.Id);
(await _identityUserManager.CreateAsync(user, input.Password)).CheckErrors();
await _identityUserManager.SetEmailAsync(user, input.EmailAddress);
user.Name = input.FirstName;
user.Surname = input.LastName;
//Role
IEnumerable<string> rolesIEnum = await GetRoleNames(input.RoleName);
await _identityUserManager.SetRolesAsync(user, rolesIEnum);
//Output
output.EmailId = user.Email;
output.Password = input.Password;
output.UserId = user.Id;
}
}
else
throw new Exception("Tenant Id cannot be empty in CreateAsync()");
return output;
}
private async Task<IEnumerable<string>> GetRoleNames(string RoleName)
{
var roles = await _identityRoleRepository.GetListAsync();
var role = roles.Where(x => x.Name.Equals(RoleName)).FirstOrDefault();
var rolesList = new List<string>() { role.Name };
IEnumerable<string> rolesIEnum = rolesList;
return rolesIEnum;
}
}
My Controller.cs
using System;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Volo.Abp;
using Volo.Abp.Application.Dtos;
namespace SCV.Litmus.ProfileManagement.SupplierRegistrations
{
[RemoteService]
[Route("profile/api/ProfileManagement")]
public class SupplierRegistrationController : ProfileManagementController, ISupplierRegistrationAppService
{
private readonly ISupplierRegistrationAppService _SupplierRegistrationAppService;
public SupplierRegistrationController(ISupplierRegistrationAppService SupplierRegistrationAppService)
{
_SupplierRegistrationAppService = SupplierRegistrationAppService;
}
[HttpPost]
[Route("createUser")]
public virtual Task<LitmusUserOutputDto> CreateUserAsync(LitmusUserCreateDto input)
{
return _SupplierRegistrationAppService.CreateUserAsync(input);
}
}
}
I was able to get references, but now executing this method I am getting the below error :
2021-03-22 16:31:36.999 +05:30 [ERR] An exception was thrown while activating SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationController -> SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationAppService.
Autofac.Core.DependencyResolutionException: An exception was thrown while activating SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationController -> SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationAppService.
---> Autofac.Core.DependencyResolutionException: None of the constructors found with 'Autofac.Core.Activators.Reflection.DefaultConstructorFinder' on type 'SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationAppService' can be invoked with the available services and parameters:
Cannot resolve parameter 'Volo.Abp.Identity.IdentityUserManager identityUserManager' of constructor 'Void .ctor(SCV.Litmus.ProfileManagement.SupplierRegistrations.ISupplierRegistrationRepository, SCV.Litmus.ProfileManagement.Suppliers.ISupplierRepository, SCV.Litmus.ProfileManagement.Suppliers.ISupplierCodeRepository, SCV.Litmus.ProfileManagement.BusinessEntities.IBusinessEntityRepository, SCV.Litmus.ProfileManagement.SupplierUserProfiles.ISupplierUserProfileRepository, SCV.Litmus.ProfileManagement.SharedServices.ISharedAppService, Volo.Abp.Identity.IdentityUserManager, Volo.Abp.Identity.IIdentityRoleRepository)'.
at Autofac.Core.Activators.Reflection.ReflectionActivator.GetValidConstructorBindings(ConstructorInfo[] availableConstructors, IComponentContext context, IEnumerable`1 parameters)
at Autofac.Core.Activators.Reflection.ReflectionActivator.ActivateInstance(IComponentContext context, IEnumerable`1 parameters)
at Autofac.Core.Resolving.InstanceLookup.CreateInstance(IEnumerable`1 parameters)
--- End of inner exception stack trace ---
at Autofac.Core.Resolving.InstanceLookup.CreateInstance(IEnumerable`1 parameters)
at Autofac.Core.Resolving.InstanceLookup.Execute()
at Autofac.Core.Resolving.ResolveOperation.GetOrCreateInstance(ISharingLifetimeScope currentOperationScope, ResolveRequest request)
at Autofac.Core.Resolving.ResolveOperation.ResolveComponent(ResolveRequest request)
at Autofac.Core.Resolving.ResolveOperation.Execute(ResolveRequest request)
at Autofac.Core.Lifetime.LifetimeScope.ResolveComponent(ResolveRequest request)
at Autofac.ResolutionExtensions.TryResolveService(IComponentContext context, Service service, IEnumerable`1 parameters, Object& instance)
at Autofac.ResolutionExtensions.ResolveService(IComponentContext context, Service service, IEnumerable`1 parameters)
at Autofac.ResolutionExtensions.Resolve(IComponentContext context, Type serviceType, IEnumerable`1 parameters)
at Autofac.ResolutionExtensions.Resolve(IComponentContext context, Type serviceType)
at Autofac.Extensions.DependencyInjection.AutofacServiceProvider.GetRequiredService(Type serviceType)
at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService(IServiceProvider provider, Type serviceType)
at Microsoft.AspNetCore.Mvc.Controllers.ServiceBasedControllerActivator.Create(ControllerContext actionContext)
at Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProvider.<>c__DisplayClass5_0.<CreateControllerFactory>g__CreateController|0(ControllerContext controllerContext)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeInnerFilterAsync()
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.<InvokeNextExceptionFilterAsync>g__Awaited|25_0(ResourceInvoker invoker, Task lastTask, State next, Scope scope, Object state, Boolean isCompleted)
2021-03-22 16:31:37.043 +05:30 [ERR] ---------- Exception Data ----------
2021-03-22 16:31:37.044 +05:30 [ERR] ActivatorChain = SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationController -> SCV.Litmus.ProfileManagement.SupplierRegistrations.SupplierRegistrationAppService
Hi @bunyamin,
I tried this observe: 'response'
but I was getting header as null, Is there any other way ?
Cause as I said before If I try abp.io rest service then I am getting json parsing error
and if I try by angular http approach I am able download the file but I am not able to get access of Content-Disposition where I am getting name of the file. Please check my code above once for your reference.
Thank you @gterdem !!!
Hi,
This is the angular service code as below :
selectedInvoicesToExcelDownloadByInput(body: any): Observable<any> {
let url = `${this.apiUrl.url}/api/InvoiceManagement/AR/invoice/selectedInvoicesToExcelDownload`
return this.http.post(url, body, {
responseType: 'blob'
})
}
Thie is the method where service method is called, code as below :
this.Invoiceservice.selectedInvoicesToExcelDownloadByInput(program).subscribe((res) => {
var blob = new Blob([res], { type: res.type.toString() });
var url = window.URL.createObjectURL(blob);
var anchor = document.createElement("a");
anchor.download = this.fileformatName();
anchor.href = url;
anchor.click();
});
What I need is to get access of the below marked blue rectangle :
How do I access this ? If I go with normal approach of state as per document I get parsing error where I cant prase my returned blob to excel file. The only way I was able to generate excel file is by implementation done above, but now I cannot access the name of the file.
Code sample will help alot !!!
Hi @alper,
Below code is for Executing SP on SQL server:
public async Task UpdateEmail(Guid id, string email, CancellationToken cancellationToken = default)
{
await DbContext.Database.ExecuteSqlRawAsync(
"EXEC UpdateEmailById @email, @id",
new List<object> {new SqlParameter("id", id), new SqlParameter("email", email)},
cancellationToken);
}
I am using PostgreSQL 13 , Is this the same way to execute it on PostgreSQL and even I am not able to find SqlParameter i.e. new SqlParameter("id", id)
do I need to install any package for same ?
Hi @alper,
As stated above my custom repo method performs 2 operations
public virtual async Task CreateQuote()
{
using (var uow = _unitOfWorkManager.Begin(requiresNew: true, isTransactional: true))
{
//...my code
//custom repository bulk update called
//ERROR OCCURED
await uow.CompleteAsync();
}
}
So as per what you are saying all the updates and inserts will be roll backed in the above cenario right ?
Hi @hikalkan
My method is POST method, So it's starting transaction. If you are sure that your UOW is transactional, then we will try to reproduce it in our side -- YES I AM SURE
My custom repository method is performing 2 operations at a time.
My Requirement ->
1st operation : To update table XYZ_1 where I update status of some records in bulk. 2nd operation : Is to insert the id's of updated records and the changed status in another XYZ_2 table which I later on use for auditing and other operations.
Issue : Even if my update fails I found that, from almost 40k records very small amount of records got inserted in 2nd operation (around 10-20 records)
Hi @liangshiwei,
My code is almost same as your code. Even I thought it was working fine, while trying to recreate the same issue I was able to recreate it only once in 9-10 attempts. If you can read the comments for ExecuteSqlRawAsync in it's Interface it says :
Executes the given SQL against the database and returns the number of rows affected.
Note that this method does not start a transaction. To use this method with a
transaction, first call Microsoft.EntityFrameworkCore.RelationalDatabaseFacadeExtensions.BeginTransaction(Microsoft.EntityFrameworkCore.Infrastructure.DatabaseFacade,System.Data.IsolationLevel)
or Microsoft.EntityFrameworkCore.RelationalDatabaseFacadeExtensions.UseTransaction(Microsoft.EntityFrameworkCore.Infrastructure.DatabaseFacade,System.Data.Common.DbTransaction).
Note that the current Microsoft.EntityFrameworkCore.Storage.ExecutionStrategy
is not used by this method since the SQL may not be idempotent and does not run
in a transaction. An ExecutionStrategy can be used explicitly, making sure to
also use a transaction if the SQL is not idempotent.
My question here is how can I use this in my cenario so I can use my methods transaction or in anyway I can able to execute my SQL in same transaction or something : Microsoft.EntityFrameworkCore.RelationalDatabaseFacadeExtensions.UseTransaction(Microsoft.EntityFrameworkCore.Infrastructure.DatabaseFacade,System.Data.Common.DbTransaction)