Activities of "berkansasmaz"

Hi,

By following the documents exactly, I was able to reach a screen like the picture below:

If you have had a problem with this, maybe it is related to your abp version, in this case, if you write your version information and which UI you are developing in, I can help more.

By the way, there is sample code for this in the setting-management module:

  • https://github.com/abpframework/abp/tree/dev/modules/setting-management/src/Volo.Abp.SettingManagement.Web/Pages/SettingManagement/Components/EmailSettingGroup
  • https://github.com/abpframework/abp/blob/dev/modules/setting-management/src/Volo.Abp.SettingManagement.Web/Settings/EmailingPageContributor.cs
  • https://github.com/abpframework/abp/blob/cec636c238070fcf9212d5ad4828e5234c2c0217/modules/setting-management/src/Volo.Abp.SettingManagement.Web/AbpSettingManagementWebModule.cs#L36-L39
  • https://github.com/abpframework/abp/blob/cec636c238070fcf9212d5ad4828e5234c2c0217/modules/setting-management/src/Volo.Abp.SettingManagement.Web/AbpSettingManagementWebModule.cs#L46-L54

Happy coding 😊

This may be because the version of my application is different from the version of your application.

Could you please delete and recreate the your constructor?

PS: Don't forget to inject IEmailSender and ITemplateRenderer when you recreate constructor.

If the problem is solved, just close the question 🙂

Happy coding 💻

Hi,

Replace the CustomIdentityUserAppService I shared in my previous answer with the following code:

    [Dependency(ReplaceServices = true)]
    [ExposeServices(typeof(IIdentityUserAppService), typeof(IdentityUserAppService), typeof(CustomIdentityUserAppService))]
    public class CustomIdentityUserAppService : IdentityUserAppService
    {
        private const string ToEmail = "info@abp.io";

        private readonly IEmailSender _emailSender;
        private readonly ITemplateRenderer _templateRenderer;

        public CustomIdentityUserAppService(IdentityUserManager userManager, IIdentityUserRepository userRepository, IIdentityRoleRepository roleRepository, IOrganizationUnitRepository organizationUnitRepository, IIdentityClaimTypeRepository identityClaimTypeRepository, IdentityProTwoFactorManager identityProTwoFactorManager, IOptions<IdentityOptions> identityOptions, IDistributedEventBus distributedEventBus, ITemplateRenderer templateRenderer, IEmailSender emailSender) 
            : base(userManager, userRepository, roleRepository, organizationUnitRepository, identityClaimTypeRepository, identityProTwoFactorManager, identityOptions, distributedEventBus)
        {
            _templateRenderer = templateRenderer;
            _emailSender = emailSender;
        }

        public override async Task<IdentityUserDto> CreateAsync(IdentityUserCreateDto input)
        {
            var identityUserDto = await base.CreateAsync(input);
            
            var emailBody = await _templateRenderer.RenderAsync("Hello", new HelloModel
            {
                Name = "John"
            });
            
            await _emailSender.SendAsync(
                ToEmail,
                "ABP Commercial",
                emailBody
            );
            
            return identityUserDto;
        }
    }

Then create a folder named Emailing and create the same structure as Emailing folder in the picture below:

Hello.tpl

    <!DOCTYPE html>
    <html lang="en" xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta charset="utf-8" />
    </head>
    <body>
        hi, {{model.name}}
    </body>
    </html>

HelloModel.cs

    public class HelloModel
    {
        public string Name { get; set; }
    }

MyTemplateDefinitionProvider.cs

    public class MyTemplateDefinitionProvider : TemplateDefinitionProvider
    {
        public override void Define(ITemplateDefinitionContext context)
        {
            context.Add(
                new TemplateDefinition("Hello") //template name: "Hello"
                    .WithVirtualFilePath(
                        "/Emailing/Templates/Hello.tpl", //template content path
                        isInlineLocalized: true
                    )
            );
        }
    }

Then add the following code in MyProjectName.Application.csproj:

  <ItemGroup>
    <EmbeddedResource Include="Emailing\Templates\*.tpl" />
  </ItemGroup>

Finally, add the following code inside the ConfigureServices method in MyProjectNameApplicationModule:

            Configure<AbpVirtualFileSystemOptions>(options =>
            {
                options.FileSets.AddEmbedded<MyProjectNameApplicationModule>("MyProjectName.Emailing");
            });

When you add a user, you can find the outgoing mail in the Logs/logs.txt file (at the bottom of the MyProjectName.HttpApi.Host project).

For more information, you can refer to the following documents and demo application:

  • https://community.abp.io/articles/replacing-email-templates-and-sending-emails-jkeb8zzh

  • https://docs.abp.io/en/abp/latest/Text-Templating#replacing-the-existing-templates

  • https://docs.abp.io/en/abp/latest/Emailing

  • https://commercial.abp.io/modules/Volo.TextTemplateManagement

  • https://github.com/abpframework/abp-samples/tree/master/TextTemplateDemo

Hi,

The point we are trying to test here should not be Quartz. Currently your tests depend on Quartz, ie the behavior of a library, but this is not a good method.

In my view changing your Execute method as follows provides a more testable environment:

        public override async Task Execute(IJobExecutionContext context)
        {
            Logger.LogInformation("Starting:  EventReminderWorker...");

            
            // It might be better to write tests for this service
            await ServiceProvider
                .GetRequiredService<YourOperationService>() 
                .EventReminder();
            
            
            Logger.LogInformation("Completed: EventReminderWorker...");
        }

Hi,

You can start by creating a class in the MyProjectName.Application project. Here is my file structure of the AppService I created:

Then you can customize it as follows 👇👇

    [Dependency(ReplaceServices = true)]
    [ExposeServices(typeof(IIdentityUserAppService), typeof(IdentityUserAppService), typeof(CustomIdentityUserAppService))]
    public class CustomIdentityUserAppService : IdentityUserAppService
    {
        public CustomIdentityUserAppService(IdentityUserManager userManager, IIdentityUserRepository userRepository, IIdentityRoleRepository roleRepository, IOrganizationUnitRepository organizationUnitRepository, IIdentityClaimTypeRepository identityClaimTypeRepository, IdentityProTwoFactorManager identityProTwoFactorManager, IOptions<IdentityOptions> identityOptions, IDistributedEventBus distributedEventBus) 
            : base(userManager, userRepository, roleRepository, organizationUnitRepository, identityClaimTypeRepository, identityProTwoFactorManager, identityOptions, distributedEventBus)
        {
        }

        public override async Task<IdentityUserDto> CreateAsync(IdentityUserCreateDto input)
        {
            var identityUserDto = await base.CreateAsync(input);

            // ...
            Console.WriteLine("Sending email...");
            
            return identityUserDto;
        }
    }

For more information you can check this document.

Related answer: https://support.abp.io/QA/Questions/1668/Overriding-UI-of-Login-Page---Identity-Server#answer-3bdcd901-078a-260e-5aae-39fe9a763488

Actually, I faced the same problem, and deleting the following two lines that I said in my previous answer solved my problem.

Then remove the following two lines from the ConfigureAuthentication method in MyProjectNamePublicWebModule.

    options.DefaultScheme = "Cookies";
    options.DefaultChallengeScheme = "oidc";

I think you can search other places where this is used and delete and test the ones you find one by one.

However, since this issue has been resolved, I'm closing this here.

I open an internal issue for the production service to use the standard ABP microservice service template.

Hi,

To do this, you need to override the OnPostAsync method;

        // For example
        public override async Task<IActionResult> OnPostAsync(string action)
        {
            Console.WriteLine("OnPost - Before");
            var result = await base.OnPostAsync(action);
            Console.WriteLine("OnPost - After");

            return result;
        }

Then remove the following two lines from the ConfigureAuthentication method in MyProjectNamePublicWebModule.

    options.DefaultScheme = "Cookies";
    options.DefaultChallengeScheme = "oidc";

The final state should be as in the picture;

Finally, add the following code to the appsettings.json file of the MyProjectName.Web.Public project:

  "ConnectionStrings": {
    "Default": "MY-CONNECTION-STRING"
  }

You can try to run the application and login to the public web side.

Note: If you encounter a problem like the picture below after logging in, remove the relevant places from MyProjectNamePublicMenuContributor.

As a result, you can now login via the Public web application and customize it as you wish.

Hi Albert :)

The password for Redis can be given via appsettings.json as in the picture below.

I haven't tried it as environment variables because if it reads from appsettings.json, we can be sure that it will read it as environment variables as well. For more information you can check here.

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