servicing
This commit is contained in:
@ -38,9 +38,9 @@ namespace Yavsc.Services
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
_logger = loggerFactory.CreateLogger<MessageSender>();
|
_logger = loggerFactory.CreateLogger<MessageSender>();
|
||||||
siteSettings = sitesOptions.Value;
|
siteSettings = sitesOptions?.Value;
|
||||||
smtpSettings = smtpOptions.Value;
|
smtpSettings = smtpOptions?.Value;
|
||||||
googleSettings = googleOptions.Value;
|
googleSettings = googleOptions?.Value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task <MessageWithPayloadResponse> NotifyEvent<Event>
|
public async Task <MessageWithPayloadResponse> NotifyEvent<Event>
|
||||||
|
193
Yavsc/Services/Coding.cs
Normal file
193
Yavsc/Services/Coding.cs
Normal file
@ -0,0 +1,193 @@
|
|||||||
|
// // Coding.cs
|
||||||
|
// /*
|
||||||
|
// paul 26/06/2018 12:18 20182018 6 26
|
||||||
|
// */
|
||||||
|
using System;
|
||||||
|
using Microsoft.AspNet.Razor;
|
||||||
|
using Yavsc.Templates;
|
||||||
|
using Microsoft.CodeAnalysis;
|
||||||
|
using Microsoft.Extensions.Localization;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Microsoft.CSharp;
|
||||||
|
using Microsoft.AspNet.Identity.EntityFramework;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Microsoft.AspNet.Razor.Parser;
|
||||||
|
|
||||||
|
using Yavsc.Models;
|
||||||
|
using Yavsc.Models.Identity;
|
||||||
|
using Yavsc.Services;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.IO;
|
||||||
|
using System.Reflection;
|
||||||
|
using Microsoft.CodeAnalysis.CSharp;
|
||||||
|
using Microsoft.CodeAnalysis.Emit;
|
||||||
|
using Microsoft.Extensions.Logging.Console;
|
||||||
|
using Yavsc.Abstract.Templates;
|
||||||
|
|
||||||
|
namespace Yavsc.Lib
|
||||||
|
{
|
||||||
|
public class YaRazorEngineHost : RazorEngineHost
|
||||||
|
{
|
||||||
|
public YaRazorEngineHost() : base()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public class EMailer
|
||||||
|
{
|
||||||
|
const string DefaultBaseClassName = "ATemplate";
|
||||||
|
const string DefaultBaseClass = nameof(UserOrientedTemplate);
|
||||||
|
const string DefaultNamespace = "CompiledRazorTemplates";
|
||||||
|
|
||||||
|
RazorTemplateEngine razorEngine;
|
||||||
|
IStringLocalizer<EMailer> stringLocalizer;
|
||||||
|
|
||||||
|
ApplicationDbContext dbContext;
|
||||||
|
IEmailSender mailSender;
|
||||||
|
RazorEngineHost host;
|
||||||
|
ILogger logger;
|
||||||
|
|
||||||
|
public EMailer(ApplicationDbContext context, IEmailSender sender,
|
||||||
|
IStringLocalizer<EMailer> localizer,
|
||||||
|
ILoggerFactory loggerFactory)
|
||||||
|
{
|
||||||
|
stringLocalizer = localizer;
|
||||||
|
mailSender = sender;
|
||||||
|
|
||||||
|
logger = loggerFactory.CreateLogger<EMailer>();
|
||||||
|
|
||||||
|
var language = new CSharpRazorCodeLanguage();
|
||||||
|
|
||||||
|
host = new RazorEngineHost(language)
|
||||||
|
{
|
||||||
|
DefaultBaseClass = DefaultBaseClass,
|
||||||
|
DefaultClassName = DefaultBaseClassName,
|
||||||
|
DefaultNamespace = DefaultNamespace
|
||||||
|
};
|
||||||
|
|
||||||
|
host.NamespaceImports.Add("System");
|
||||||
|
host.NamespaceImports.Add("Yavsc.Templates");
|
||||||
|
host.NamespaceImports.Add("Yavsc.Models");
|
||||||
|
host.NamespaceImports.Add("Yavsc.Models.Identity");
|
||||||
|
host.NamespaceImports.Add("Microsoft.AspNet.Identity.EntityFramework");
|
||||||
|
host.InstrumentedSourceFilePath = ".";
|
||||||
|
host.StaticHelpers = true;
|
||||||
|
dbContext = context;
|
||||||
|
razorEngine = new RazorTemplateEngine(host);
|
||||||
|
}
|
||||||
|
|
||||||
|
public string GenerateTemplateObject(string baseclassName = DefaultBaseClassName)
|
||||||
|
{
|
||||||
|
throw new NotImplementedException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void SendMonthlyEmail(long templateCode, string baseclassName = DefaultBaseClassName)
|
||||||
|
{
|
||||||
|
string className = "Generated" + baseclassName;
|
||||||
|
|
||||||
|
string subtemp = stringLocalizer["MonthlySubjectTemplate"].Value;
|
||||||
|
|
||||||
|
logger.LogInformation($"Generating {subtemp}[{className}]");
|
||||||
|
|
||||||
|
|
||||||
|
var templateInfo = dbContext.MailingTemplate.FirstOrDefault(t => t.Id == templateCode);
|
||||||
|
|
||||||
|
logger.LogInformation($"Using code: {templateCode}, subject: {subtemp} ");
|
||||||
|
logger.LogInformation("And body:\n" + templateInfo.Body);
|
||||||
|
using (StringReader reader = new StringReader(templateInfo.Body))
|
||||||
|
{
|
||||||
|
|
||||||
|
// Generate code for the template
|
||||||
|
var razorResult = razorEngine.GenerateCode(reader, className, DefaultNamespace, DefaultNamespace + ".cs");
|
||||||
|
|
||||||
|
logger.LogInformation("Razor exited " + (razorResult.Success ? "Ok" : "Ko") + ".");
|
||||||
|
|
||||||
|
logger.LogInformation(razorResult.GeneratedCode);
|
||||||
|
SyntaxTree syntaxTree = CSharpSyntaxTree.ParseText(razorResult.GeneratedCode);
|
||||||
|
logger.LogInformation("CSharp parsed");
|
||||||
|
List<MetadataReference> references = new List<MetadataReference>();
|
||||||
|
|
||||||
|
foreach (var type in new Type[] {
|
||||||
|
typeof(object),
|
||||||
|
typeof(Enumerable),
|
||||||
|
typeof(IdentityUser),
|
||||||
|
typeof(ApplicationUser),
|
||||||
|
typeof(Template),
|
||||||
|
typeof(UserOrientedTemplate),
|
||||||
|
typeof(System.Threading.Tasks.TaskExtensions)
|
||||||
|
})
|
||||||
|
{
|
||||||
|
var location = type.Assembly.Location;
|
||||||
|
if (!string.IsNullOrWhiteSpace(location))
|
||||||
|
{
|
||||||
|
references.Add(
|
||||||
|
MetadataReference.CreateFromFile(location)
|
||||||
|
);
|
||||||
|
logger.LogInformation($"Assembly for {type.Name} found at {location}");
|
||||||
|
}
|
||||||
|
else logger.LogWarning($"Assembly Not found for {type.Name}");
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.LogInformation("Compilation creation ...");
|
||||||
|
|
||||||
|
var compilationOptions = new CSharpCompilationOptions(OutputKind.DynamicallyLinkedLibrary)
|
||||||
|
.WithAllowUnsafe(true).WithOptimizationLevel(OptimizationLevel.Debug)
|
||||||
|
.WithOutputKind(OutputKind.DynamicallyLinkedLibrary).WithPlatform(Platform.AnyCpu)
|
||||||
|
.WithUsings("Yavsc.Templates")
|
||||||
|
;
|
||||||
|
string assemblyName = DefaultNamespace;
|
||||||
|
CSharpCompilation compilation = CSharpCompilation.Create(
|
||||||
|
assemblyName,
|
||||||
|
syntaxTrees: new[] { syntaxTree },
|
||||||
|
references: references,
|
||||||
|
options: compilationOptions
|
||||||
|
);
|
||||||
|
|
||||||
|
using (var ms = new MemoryStream())
|
||||||
|
{
|
||||||
|
logger.LogInformation("Emitting result ...");
|
||||||
|
EmitResult result = compilation.Emit(ms);
|
||||||
|
foreach (Diagnostic diagnostic in result.Diagnostics.Where(diagnostic =>
|
||||||
|
diagnostic.Severity < DiagnosticSeverity.Error && !diagnostic.IsWarningAsError))
|
||||||
|
{
|
||||||
|
logger.LogWarning("{0}: {1}", diagnostic.Id, diagnostic.GetMessage());
|
||||||
|
logger.LogWarning("{0}: {1}", diagnostic.Id, diagnostic.Location.GetLineSpan());
|
||||||
|
}
|
||||||
|
if (!result.Success)
|
||||||
|
{
|
||||||
|
logger.LogInformation(razorResult.GeneratedCode);
|
||||||
|
IEnumerable<Diagnostic> failures = result.Diagnostics.Where(diagnostic =>
|
||||||
|
diagnostic.IsWarningAsError ||
|
||||||
|
diagnostic.Severity == DiagnosticSeverity.Error);
|
||||||
|
foreach (Diagnostic diagnostic in failures)
|
||||||
|
{
|
||||||
|
logger.LogCritical("{0}: {1}", diagnostic.Id, diagnostic.GetMessage());
|
||||||
|
logger.LogCritical("{0}: {1}", diagnostic.Id, diagnostic.Location.GetLineSpan());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
logger.LogInformation(razorResult.GeneratedCode);
|
||||||
|
ms.Seek(0, SeekOrigin.Begin);
|
||||||
|
Assembly assembly = Assembly.Load(ms.ToArray());
|
||||||
|
|
||||||
|
Type type = assembly.GetType(DefaultNamespace + "." + className);
|
||||||
|
var generatedtemplate = (UserOrientedTemplate)Activator.CreateInstance(type);
|
||||||
|
foreach (var user in dbContext.ApplicationUser.Where(
|
||||||
|
u => u.AllowMonthlyEmail
|
||||||
|
))
|
||||||
|
{
|
||||||
|
logger.LogInformation("Generation for " + user.UserName);
|
||||||
|
generatedtemplate.Init();
|
||||||
|
generatedtemplate.User = user;
|
||||||
|
generatedtemplate.ExecuteAsync();
|
||||||
|
logger.LogInformation(generatedtemplate.GeneratedText);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
58
Yavsc/Services/GitClone.cs
Normal file
58
Yavsc/Services/GitClone.cs
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
// // GitClone.cs
|
||||||
|
// /*
|
||||||
|
// paul 21/06/2018 11:27 20182018 6 21
|
||||||
|
// */
|
||||||
|
using System;
|
||||||
|
using Yavsc.Server.Models.IT.SourceCode;
|
||||||
|
using Yavsc.Server.Models.IT;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.IO;
|
||||||
|
|
||||||
|
namespace Yavsc.Lib
|
||||||
|
{
|
||||||
|
public class GitClone : Batch<Project>
|
||||||
|
{
|
||||||
|
string _repositoryRootPath;
|
||||||
|
|
||||||
|
public GitClone(string repoRoot)
|
||||||
|
{
|
||||||
|
_repositoryRootPath = repoRoot;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override void Launch(Project input)
|
||||||
|
{
|
||||||
|
WorkingDir = _repositoryRootPath;
|
||||||
|
LogPath = $"{input.Name}.git-clone.ansi.log";
|
||||||
|
// TODO honor Args property
|
||||||
|
// Model annotations => input.Repository!=null => input.Name == input.Repository.Path
|
||||||
|
var prjPath = Path.Combine(WorkingDir, input.Name);
|
||||||
|
var repoInfo = new DirectoryInfo(prjPath);
|
||||||
|
var gitCmd = repoInfo.Exists ? "pull" : "clone";
|
||||||
|
|
||||||
|
var cloneStart = new ProcessStartInfo
|
||||||
|
( gitCmd, $"{gitCmd} {input.Repository.Url} {input.Repository.Path}" )
|
||||||
|
{
|
||||||
|
WorkingDirectory = WorkingDir,
|
||||||
|
RedirectStandardOutput = true,
|
||||||
|
UseShellExecute = false
|
||||||
|
};
|
||||||
|
// TODO make `.ansi.log` a defined constant.
|
||||||
|
var logFile = new FileInfo
|
||||||
|
( Path.Combine
|
||||||
|
( _repositoryRootPath, $"{input.Name}.ansi.log" ));
|
||||||
|
using (var stream = logFile.Create())
|
||||||
|
using (var writer = new StreamWriter(stream))
|
||||||
|
{
|
||||||
|
var process = Process.Start(cloneStart);
|
||||||
|
// TODO announce ...
|
||||||
|
while (!process.HasExited)
|
||||||
|
{
|
||||||
|
if (process.StandardOutput.Peek() > -1)
|
||||||
|
writer.WriteLine(process.StandardOutput.ReadLine());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ResultHandler(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -68,10 +68,6 @@ namespace cli.Services
|
|||||||
razorEngine = new RazorTemplateEngine(host);
|
razorEngine = new RazorTemplateEngine(host);
|
||||||
}
|
}
|
||||||
|
|
||||||
public string GenerateTemplateObject(string baseclassName = DefaultBaseClassName)
|
|
||||||
{
|
|
||||||
throw new NotImplementedException();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void SendMonthlyEmail(long templateCode, string baseclassName = DefaultBaseClassName)
|
public void SendMonthlyEmail(long templateCode, string baseclassName = DefaultBaseClassName)
|
||||||
{
|
{
|
||||||
@ -162,7 +158,11 @@ namespace cli.Services
|
|||||||
Assembly assembly = Assembly.Load(ms.ToArray());
|
Assembly assembly = Assembly.Load(ms.ToArray());
|
||||||
|
|
||||||
Type type = assembly.GetType(DefaultNamespace + "." + className);
|
Type type = assembly.GetType(DefaultNamespace + "." + className);
|
||||||
var generatedtemplate = (UserOrientedTemplate)Activator.CreateInstance(type);
|
var generatedtemplate = (UserOrientedTemplate) Activator.CreateInstance(type);
|
||||||
|
if (generatedtemplate==null) {
|
||||||
|
logger.LogError("No generated template ... exiting.");
|
||||||
|
throw new InvalidOperationException("No generated template");
|
||||||
|
}
|
||||||
foreach (var user in dbContext.ApplicationUser.Where(
|
foreach (var user in dbContext.ApplicationUser.Where(
|
||||||
u => u.AllowMonthlyEmail
|
u => u.AllowMonthlyEmail
|
||||||
))
|
))
|
||||||
@ -172,6 +172,13 @@ namespace cli.Services
|
|||||||
generatedtemplate.User = user;
|
generatedtemplate.User = user;
|
||||||
generatedtemplate.ExecuteAsync();
|
generatedtemplate.ExecuteAsync();
|
||||||
logger.LogInformation(generatedtemplate.GeneratedText);
|
logger.LogInformation(generatedtemplate.GeneratedText);
|
||||||
|
var mailSentInfo = this.mailSender.SendEmailAsync
|
||||||
|
(user.UserName, user.Email, $"monthly email", generatedtemplate.GeneratedText).Result;
|
||||||
|
if (!mailSentInfo.Sent)
|
||||||
|
logger.LogError($"{mailSentInfo.ErrorMessage}");
|
||||||
|
else
|
||||||
|
logger.LogInformation($"mailId:{mailSentInfo.MessageId} \nto:{user.UserName}");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -3,34 +3,21 @@ using Microsoft.Extensions.Configuration;
|
|||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Microsoft.Extensions.Logging;
|
using Microsoft.Extensions.Logging;
|
||||||
using Microsoft.Extensions.OptionsModel;
|
using Microsoft.Extensions.OptionsModel;
|
||||||
|
|
||||||
using System.Globalization;
|
|
||||||
using System.Reflection;
|
|
||||||
// using Microsoft.AspNet.Authorization;
|
|
||||||
using Microsoft.AspNet.Builder;
|
using Microsoft.AspNet.Builder;
|
||||||
// using Microsoft.AspNet.Diagnostics;
|
|
||||||
using Microsoft.AspNet.Hosting;
|
using Microsoft.AspNet.Hosting;
|
||||||
using Microsoft.AspNet.Identity;
|
|
||||||
using Microsoft.AspNet.Identity.EntityFramework;
|
|
||||||
using Microsoft.AspNet.Localization;
|
|
||||||
using Microsoft.AspNet.Mvc;
|
|
||||||
using Microsoft.AspNet.Mvc.Filters;
|
|
||||||
using Microsoft.AspNet.Mvc.Razor;
|
|
||||||
using Microsoft.Net.Http.Headers;
|
|
||||||
using Microsoft.AspNet.Razor;
|
using Microsoft.AspNet.Razor;
|
||||||
using Microsoft.Extensions.DependencyInjection.Abstractions;
|
|
||||||
using Microsoft.Extensions.PlatformAbstractions;
|
using Microsoft.Extensions.PlatformAbstractions;
|
||||||
using cli.Services;
|
using cli.Services;
|
||||||
using Yavsc;
|
using Yavsc;
|
||||||
using Yavsc.Models;
|
using Yavsc.Models;
|
||||||
using Yavsc.Server.Helpers;
|
|
||||||
using Yavsc.Services;
|
using Yavsc.Services;
|
||||||
using Yavsc.Templates;
|
|
||||||
using Microsoft.Data.Entity;
|
using Microsoft.Data.Entity;
|
||||||
|
using Microsoft.AspNet.Authentication;
|
||||||
|
using Microsoft.Extensions.WebEncoders;
|
||||||
|
|
||||||
namespace cli
|
namespace cli
|
||||||
{
|
{
|
||||||
public class Startup
|
public class Startup
|
||||||
{
|
{
|
||||||
public string ConnectionString
|
public string ConnectionString
|
||||||
{
|
{
|
||||||
@ -86,6 +73,15 @@ namespace cli
|
|||||||
.AddDbContext<ApplicationDbContext>(
|
.AddDbContext<ApplicationDbContext>(
|
||||||
db => db.UseNpgsql(ConnectionString)
|
db => db.UseNpgsql(ConnectionString)
|
||||||
);
|
);
|
||||||
|
services.Configure<SharedAuthenticationOptions>(options =>
|
||||||
|
{
|
||||||
|
options.SignInScheme = "Bearer";
|
||||||
|
});
|
||||||
|
|
||||||
|
services.AddTransient<Microsoft.Extensions.WebEncoders.UrlEncoder, UrlEncoder>();
|
||||||
|
|
||||||
|
services.AddAuthentication();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Configure (IApplicationBuilder app, IHostingEnvironment env,
|
public void Configure (IApplicationBuilder app, IHostingEnvironment env,
|
||||||
@ -95,6 +91,9 @@ namespace cli
|
|||||||
loggerFactory.AddDebug();
|
loggerFactory.AddDebug();
|
||||||
logger = loggerFactory.CreateLogger<Startup>();
|
logger = loggerFactory.CreateLogger<Startup>();
|
||||||
logger.LogInformation(env.EnvironmentName);
|
logger.LogInformation(env.EnvironmentName);
|
||||||
|
var authConf = Configuration.GetSection("Authentication").GetSection("Yavsc");
|
||||||
|
var clientId = authConf.GetSection("ClientId").Value;
|
||||||
|
var clientSecret = authConf.GetSection("ClientSecret").Value;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,15 +44,15 @@
|
|||||||
"Microsoft.Framework.ConfigurationModel.Json": "1.0.0-beta4",
|
"Microsoft.Framework.ConfigurationModel.Json": "1.0.0-beta4",
|
||||||
"Newtonsoft.Json": "9.0.1",
|
"Newtonsoft.Json": "9.0.1",
|
||||||
"Yavsc": {
|
"Yavsc": {
|
||||||
"version": "1.0.5-rc21-beta5",
|
"version": "1.0.5-rc21-beta7",
|
||||||
"target": "package"
|
"target": "package"
|
||||||
},
|
},
|
||||||
"Yavsc.Abstract": {
|
"Yavsc.Abstract": {
|
||||||
"version": "1.0.5-rc21-beta5",
|
"version": "1.0.5-rc21-beta7",
|
||||||
"target": "package"
|
"target": "package"
|
||||||
},
|
},
|
||||||
"Yavsc.Server": {
|
"Yavsc.Server": {
|
||||||
"version": "1.0.5-rc21-beta5",
|
"version": "1.0.5-rc21-beta7",
|
||||||
"target": "package"
|
"target": "package"
|
||||||
},
|
},
|
||||||
"Yavsc.Lib.Portable": "1.0.2"
|
"Yavsc.Lib.Portable": "1.0.2"
|
||||||
|
@ -1 +1 @@
|
|||||||
21-beta6
|
21-beta7
|
||||||
|
46
test/src/YavscWorkInProgress.cs
Normal file
46
test/src/YavscWorkInProgress.cs
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
// // YavscWorkInProgress.cs
|
||||||
|
// /*
|
||||||
|
// paul 21/06/2018 10:11 20182018 6 21
|
||||||
|
// */
|
||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using Microsoft.AspNet.Builder;
|
||||||
|
using Microsoft.AspNet.Builder.Internal;
|
||||||
|
using Microsoft.Dnx.Compilation.CSharp;
|
||||||
|
using Microsoft.Dnx.Runtime;
|
||||||
|
using Microsoft.Extensions.Configuration;
|
||||||
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
|
using Microsoft.Extensions.Localization;
|
||||||
|
using Microsoft.Extensions.OptionsModel;
|
||||||
|
using Microsoft.Extensions.PlatformAbstractions;
|
||||||
|
using Xunit;
|
||||||
|
using Yavsc;
|
||||||
|
using Yavsc.Lib;
|
||||||
|
using Yavsc.Models;
|
||||||
|
|
||||||
|
namespace Test
|
||||||
|
{
|
||||||
|
[Collection("Yavsc Work In Progress")]
|
||||||
|
public class YavscWorkInProgress : BaseTestContext
|
||||||
|
{
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public void GitClone()
|
||||||
|
{
|
||||||
|
|
||||||
|
AppDomain.CurrentDomain.SetData("YAVSC_DB_CONNECTION", "Server=localhost;Port=5432;Database=YavscDev;Username=yavscdev;Password=admin;");
|
||||||
|
ServiceCollection services = new ServiceCollection();
|
||||||
|
|
||||||
|
YavscMandatory.ConfigureServices(services, testprojectAssetPath, out configuration, out provider);
|
||||||
|
|
||||||
|
var siteConfig = provider.GetRequiredService<IOptions<SiteSettings>>().Value;
|
||||||
|
var dbc = provider.GetRequiredService<ApplicationDbContext>();
|
||||||
|
|
||||||
|
var firstProject = dbc.Projects.FirstOrDefault();
|
||||||
|
Assert.NotNull (firstProject);
|
||||||
|
|
||||||
|
var clone = new GitClone(siteConfig.GitRepository);
|
||||||
|
clone.Launch(firstProject);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -80,7 +80,7 @@ namespace testOauthClient
|
|||||||
LoginPath = new PathString("/signin"),
|
LoginPath = new PathString("/signin"),
|
||||||
LogoutPath = new PathString("/signout")
|
LogoutPath = new PathString("/signout")
|
||||||
});
|
});
|
||||||
var host = "http://dev.pschneider.fr";
|
var host = "http://dev.pschneider.fr";
|
||||||
app.UseOAuthAuthentication(
|
app.UseOAuthAuthentication(
|
||||||
options =>
|
options =>
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user