Mystery setup

This commit is contained in:
2026-05-25 00:23:10 -05:00
parent bceff701bf
commit 3fae7e5b4c
7 changed files with 70 additions and 22 deletions

View File

@@ -24,8 +24,9 @@
await BlobClient.UploadBlobAsync(name, data);
}
public async Task UploadFile(string name, BinaryData data) {
await BlobClient.UploadBlobAsync(name, data);
public async Task UploadFile(string name, BinaryData data, bool overwrite = false) {
var client = BlobClient.GetBlobClient(name);
await client.UploadAsync(data, overwrite);
}
public async Task UploadFileFromSource(string name, string filepath) {

View File

@@ -14,6 +14,9 @@
[NoSettingName]
public RaceMode Race { get; set; } = RaceMode.Normal;
[NoSettingName]
public MysteryMode Mystery { get; set; } = MysteryMode.Normal;
[ForbiddenSetting([Apr2025], Mode.Inverted)]
[RequiredSetting([Pikit], Mode.Open)]
public Mode Mode { get; set; } = Mode.Open;
@@ -204,6 +207,12 @@
[NoSettingName]
public Hints Hints { get; set; } = Hints.Off;
public SeedSettings Clone() {
var newSettings = (SeedSettings) this.MemberwiseClone();
return newSettings;
}
}
public enum RandomizerInstance {
@@ -218,6 +227,11 @@
[AdditionalSetting("--securerandom")] Race,
}
public enum MysteryMode {
Normal,
[AdditionalSetting("--mystery")] Mystery,
}
public enum Mode {
Open,
Standard,

View File

@@ -113,7 +113,7 @@
};
}
public async Task Randomize(string id, SeedSettings settings, bool uploadSettings = true) {
public async Task Randomize(string id, SeedSettings settings, bool uploadSettings = true, MysterySettings? mysterySettings = null) {
Logger.LogDebug("Recieved request for id {id} to randomize settings {@settings}", id, settings);
var args = this.GetArgs(settings);
@@ -133,10 +133,16 @@
}
});
if (mysterySettings != null) {
var mysteryJson = JsonSerializer.SerializeToDocument(mysterySettings, JsonOptions.Default);
var mysteryOut = string.Format("{0}/mystery.json", id);
await AzureStorage.UploadFile(mysteryOut, new BinaryData(mysteryJson));
}
if (uploadSettings) {
var settingsJson = JsonSerializer.SerializeToDocument(settings, JsonOptions.Default);
var settingsOut = string.Format("{0}/settings.json", id);
await AzureStorage.UploadFile(settingsOut, new BinaryData(settingsJson));
await AzureStorage.UploadFile(settingsOut, new BinaryData(settingsJson), true);
}
}

View File

@@ -5,6 +5,6 @@
public interface IRandomizer {
public void Validate(SeedSettings settings);
public Task Randomize(string id, SeedSettings settings, bool uploadSettings = true);
public Task Randomize(string id, SeedSettings settings, bool uploadSettings = true, MysterySettings? mysterySettings = null);
}
}

View File

@@ -14,28 +14,16 @@
public class SeedController : Controller {
public SeedController(
RandomizeService randomizeService,
MysteryRandomizer mysteryRandomizer,
SeedService seedService,
ILogger<SeedController> logger) {
this.RandomizeService = randomizeService;
this.MysteryRandomizer = mysteryRandomizer;
this.SeedService = seedService;
this.Logger = logger;
this.YamlSerializer =
new SerializerBuilder()
.WithNamingConvention(UnderscoredNamingConvention.Instance)
.WithTypeConverter(new YamlStringEnumConverter())
.WithTypeConverter(new RandomizableWeightsYamlConverters())
.ConfigureDefaultValuesHandling(DefaultValuesHandling.OmitNull | DefaultValuesHandling.OmitEmptyCollections)
.Build();
}
private RandomizeService RandomizeService { get; }
private MysteryRandomizer MysteryRandomizer { get; }
private SeedService SeedService { get; }
private ILogger<SeedController> Logger { get; }
private ISerializer YamlSerializer { get; }
[Route("/generate")]
[HttpPost]
@@ -43,6 +31,7 @@
if (!ModelState.IsValid) {
return BadRequest(ModelState);
}
try {
var id = await this.RandomizeService.RandomizeSeed(settings);
var url = string.Format("/seed/{0}", id);
@@ -54,15 +43,24 @@
[Route("/mystery/{randomizer}")]
[HttpPost]
public ActionResult RollMystery([FromBody] MysterySettings mysterySettings, RandomizerInstance randomizer) {
public async Task<ObjectResult> RollMystery([FromBody] MysterySettings mysterySettings, RandomizerInstance randomizer, bool race) {
if (!ModelState.IsValid) {
return BadRequest(ModelState);
}
var seedSettings = new SeedSettings() { Randomizer = randomizer };
this.MysteryRandomizer.Roll(mysterySettings, seedSettings);
var baseSettings = new SeedSettings() {
Randomizer = randomizer,
Race = race ? RaceMode.Race : RaceMode.Normal,
Mystery = MysteryMode.Mystery,
};
return StatusCode(200, this.YamlSerializer.Serialize(mysterySettings));
try {
var id = await this.RandomizeService.RandomizeMystery(mysterySettings, baseSettings);
var url = string.Format("/seed/{0}", id);
return Accepted(url, id);
} catch (InvalidSettingsException ex) {
return BadRequest(ex.Message);
}
}
[Route("/multiworld")]

View File

@@ -2,6 +2,7 @@
using ALttPRandomizer.Azure;
using ALttPRandomizer.Model;
using ALttPRandomizer.Randomizers;
using ALttPRandomizer.Settings;
using Microsoft.Extensions.Logging;
using System.Collections.Generic;
using System.Text.Json;
@@ -11,10 +12,12 @@
public RandomizeService(
IdGenerator idGenerator,
BaseRandomizer baseRandomizer,
MysteryRandomizer mysteryRandomizer,
AzureStorage azureStorage,
ILogger<RandomizeService> logger) {
this.IdGenerator = idGenerator;
this.BaseRandomizer = baseRandomizer;
this.MysteryRandomizer = mysteryRandomizer;
this.AzureStorage = azureStorage;
this.Logger = logger;
}
@@ -23,6 +26,7 @@
private IdGenerator IdGenerator { get; }
private BaseRandomizer BaseRandomizer { get; }
private MysteryRandomizer MysteryRandomizer { get; }
private AzureStorage AzureStorage { get; }
public async Task<string> RandomizeSeed(SeedSettings settings, string? seedId = null) {
@@ -35,6 +39,31 @@
return id;
}
public async Task<string> RandomizeMystery(MysterySettings mysterySettings, SeedSettings baseSettings, string? seedId = null) {
var id = seedId ?? this.IdGenerator.GenerateId();
this.Logger.LogDebug("Rolling mystery seed {seedId} with mystery {@settings}", id, mysterySettings);
SeedSettings seedSettings;
for (var i = 0; i < 10; i++) {
seedSettings = baseSettings.Clone();
this.MysteryRandomizer.Roll(mysterySettings, seedSettings);
this.Logger.LogInformation("Mystery seed {seedId} rolled settings {@settings}", id, seedSettings);
try {
this.BaseRandomizer.Validate(seedSettings);
} catch (InvalidSettingsException) {
this.Logger.LogWarning("Mystery seed {seedId} settings {@settings} failed validation; retrying", id, seedSettings);
continue;
}
await this.BaseRandomizer.Randomize(id, seedSettings, true, seedId == null ? mysterySettings : null);
return id;
}
throw new InvalidSettingsException("Could not roll settings that pass validation");
}
public async Task<string> RandomizeMultiworld(IList<SeedSettings> settings, string? multiId = null) {
var id = multiId ?? this.IdGenerator.GenerateId();
this.Logger.LogInformation("Generating multiworld {seedId} with settings {@settings}", id, settings);