From 88bbe840617b601dad3aa226283e5549c728fc9c Mon Sep 17 00:00:00 2001 From: FN Date: Sat, 9 Nov 2024 13:44:07 +0700 Subject: [PATCH] First commit --- .../Systems/AdminVerbSystem.Antags.cs | 19 ++++++++++++ .../GameTicking/Rules/ThiefRuleSystem.cs | 20 ++++++++++-- .../Components/StealConditionComponent.cs | 4 +++ .../Systems/StealConditionSystem.cs | 7 +++++ Resources/Locale/ru-RU/_CorvaxNext/api.ftl | 21 +++++++++++++ .../Entities/Mobs/Player/silicon.yml | 2 ++ .../_CorvaxNext/Catalog/api_toolbox_sets.yml | 11 +++++++ .../Entities/Objects/Tools/api_toolbox.yml | 21 +++++++++++++ .../Prototypes/_CorvaxNext/GameRules/api.yml | 29 +++++++++++++++++ .../Objectives/ai_steal_target_group.yml | 6 ++++ .../Prototypes/_CorvaxNext/Objectives/api.yml | 31 +++++++++++++++++++ .../Objectives/api_objective_groups.yml | 9 ++++++ .../_CorvaxNext/Roles/Antags/api.yml | 18 +++++++++++ .../Roles/MindRoles/api_mind_role.yml | 10 ++++++ 14 files changed, 205 insertions(+), 3 deletions(-) create mode 100644 Resources/Locale/ru-RU/_CorvaxNext/api.ftl create mode 100644 Resources/Prototypes/_CorvaxNext/Catalog/api_toolbox_sets.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Entities/Objects/Tools/api_toolbox.yml create mode 100644 Resources/Prototypes/_CorvaxNext/GameRules/api.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Objectives/ai_steal_target_group.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Objectives/api.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Objectives/api_objective_groups.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Roles/Antags/api.yml create mode 100644 Resources/Prototypes/_CorvaxNext/Roles/MindRoles/api_mind_role.yml diff --git a/Content.Server/Administration/Systems/AdminVerbSystem.Antags.cs b/Content.Server/Administration/Systems/AdminVerbSystem.Antags.cs index 28918e960e5..a39ff1d8ec0 100644 --- a/Content.Server/Administration/Systems/AdminVerbSystem.Antags.cs +++ b/Content.Server/Administration/Systems/AdminVerbSystem.Antags.cs @@ -33,6 +33,10 @@ public sealed partial class AdminVerbSystem [ValidatePrototypeId] private const string DefaultThiefRule = "Thief"; + // Corvax-Next-Api + [ValidatePrototypeId] + private const string DefaultApiRule = "Api"; + [ValidatePrototypeId] private const string PirateGearId = "PirateGear"; @@ -151,5 +155,20 @@ private void AddAntagVerbs(GetVerbsEvent args) Message = Loc.GetString("admin-verb-make-thief"), }; args.Verbs.Add(thief); + + // Corvax-Next-Api + Verb api = new() + { + Text = Loc.GetString("admin-verb-text-make-api"), + Category = VerbCategory.Antag, + Icon = new SpriteSpecifier.Rsi(new ResPath("/Textures/Mobs/Silicon/station_ai.rsi"), "ai"), + Act = () => + { + _antag.ForceMakeAntag(targetPlayer, DefaultApiRule); + }, + Impact = LogImpact.High, + Message = Loc.GetString("admin-verb-make-api"), + }; + args.Verbs.Add(api); } } diff --git a/Content.Server/GameTicking/Rules/ThiefRuleSystem.cs b/Content.Server/GameTicking/Rules/ThiefRuleSystem.cs index b00ed386363..06b7226e9cf 100644 --- a/Content.Server/GameTicking/Rules/ThiefRuleSystem.cs +++ b/Content.Server/GameTicking/Rules/ThiefRuleSystem.cs @@ -2,6 +2,7 @@ using Content.Server.GameTicking.Rules.Components; using Content.Server.Roles; using Content.Shared.Humanoid; +using Content.Shared.Roles; namespace Content.Server.GameTicking.Rules; @@ -22,7 +23,7 @@ public override void Initialize() private void AfterAntagSelected(Entity mindId, ref AfterAntagEntitySelectedEvent args) { var ent = args.EntityUid; - _antag.SendBriefing(ent, MakeBriefing(ent), null, null); + _antag.SendBriefing(ent, MakeBriefing(ent, args.Def.PrefRoles.Contains("Api")), null, null); // Corvax-Next-Api } // Character screen briefing @@ -32,11 +33,24 @@ private void OnGetBriefing(Entity role, ref GetBriefingEvent if (ent is null) return; - args.Append(MakeBriefing(ent.Value)); + + // Corvax-Next-Api + var api = false; + + foreach (var id in args.Mind.Comp.MindRoles) + if (TryComp(id, out var mindRole)) + if (mindRole.AntagPrototype == "Api") + api = true; + + args.Append(MakeBriefing(ent.Value, api)); } - private string MakeBriefing(EntityUid ent) + // Corvax-Next-Api + private string MakeBriefing(EntityUid ent, bool api) { + if (api) + return Loc.GetString("api-role-greeting"); + var isHuman = HasComp(ent); var briefing = isHuman ? Loc.GetString("thief-role-greeting-human") diff --git a/Content.Server/Objectives/Components/StealConditionComponent.cs b/Content.Server/Objectives/Components/StealConditionComponent.cs index cdade8cc8d7..fb62c497e8e 100644 --- a/Content.Server/Objectives/Components/StealConditionComponent.cs +++ b/Content.Server/Objectives/Components/StealConditionComponent.cs @@ -34,6 +34,10 @@ public sealed partial class StealConditionComponent : Component [DataField] public bool CheckAlive = false; + // Corvax-Next-Api + [DataField] + public bool CheckHasAi = false; + /// /// The minimum number of items you need to steal to fulfill a objective /// diff --git a/Content.Server/Objectives/Systems/StealConditionSystem.cs b/Content.Server/Objectives/Systems/StealConditionSystem.cs index 48814e7ba3c..c48635093ec 100644 --- a/Content.Server/Objectives/Systems/StealConditionSystem.cs +++ b/Content.Server/Objectives/Systems/StealConditionSystem.cs @@ -13,6 +13,7 @@ using Content.Shared.Mobs.Components; using Content.Shared.Movement.Pulling.Components; using Content.Shared.Stacks; +using Content.Shared.Silicons.StationAi; namespace Content.Server.Objectives.Systems; @@ -196,6 +197,12 @@ private int CheckStealTarget(EntityUid entity, StealConditionComponent condition } } + // Corvax-Next-Api + if (condition.CheckHasAi) + if (TryComp(entity, out var holder)) + if (holder.Slot.Item is null) + return 0; + return TryComp(entity, out var stack) ? stack.Count : 1; } } diff --git a/Resources/Locale/ru-RU/_CorvaxNext/api.ftl b/Resources/Locale/ru-RU/_CorvaxNext/api.ftl new file mode 100644 index 00000000000..28cd2d0f889 --- /dev/null +++ b/Resources/Locale/ru-RU/_CorvaxNext/api.ftl @@ -0,0 +1,21 @@ +admin-verb-text-make-api = Сделать АПИИ +admin-verb-make-api = Сделать цель агентом похищения искуственного интеллекта. + +api-backpack-category-utilities-name = Набор Утилит +api-backpack-category-utilities-description = Набор полезных вещей, содержащий имплантеры хранилища и голопаразита, а также лазерный кинжал. + +ent-ToolboxApi = ящик воровских инструментов неопределённости + .desc = Здесь лежат ваши излюбленные воровские штучки. Осталось вспомнить, какие именно. + +api-round-end-agent-name = агент похищения искуственного интеллекта + +roles-antag-api-objective = Украдите станционный ИИ, действуя скрытно. + +objective-condition-api-description = То, зачем я сюда прилетел. Осталось найти интелкарту и пробраться к нему. + +steal-target-groups-ai = станционный ИИ, помещённый на интелкарту + +api-role-greeting = + Вы агент похищения искуственного интеллекта, также известный как АПИИ. + У вас здесь одна цель: украсть станционный ИИ с помощью интелкарты. + Старайтесь действовать скрытно, вы это любите. diff --git a/Resources/Prototypes/Entities/Mobs/Player/silicon.yml b/Resources/Prototypes/Entities/Mobs/Player/silicon.yml index 98cfd5a8a12..9022a5e229c 100644 --- a/Resources/Prototypes/Entities/Mobs/Player/silicon.yml +++ b/Resources/Prototypes/Entities/Mobs/Player/silicon.yml @@ -301,6 +301,8 @@ unshaded: Empty: { state: empty } Occupied: { state: full } + - type: StealTarget # Corvax-Next-Api + stealGroup: Ai - type: entity id: PlayerStationAiEmpty diff --git a/Resources/Prototypes/_CorvaxNext/Catalog/api_toolbox_sets.yml b/Resources/Prototypes/_CorvaxNext/Catalog/api_toolbox_sets.yml new file mode 100644 index 00000000000..7636bed77c7 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Catalog/api_toolbox_sets.yml @@ -0,0 +1,11 @@ +- type: thiefBackpackSet + id: UtilitiesSet + name: api-backpack-category-utilities-name + description: api-backpack-category-utilities-description + sprite: + sprite: /Textures/Objects/Tools/Toolboxes/toolbox_syn.rsi + state: icon + content: + - StorageImplanter + - BoxHoloparasite + - EnergyDaggerBox diff --git a/Resources/Prototypes/_CorvaxNext/Entities/Objects/Tools/api_toolbox.yml b/Resources/Prototypes/_CorvaxNext/Entities/Objects/Tools/api_toolbox.yml new file mode 100644 index 00000000000..9848ab84792 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Entities/Objects/Tools/api_toolbox.yml @@ -0,0 +1,21 @@ +- type: entity + id: ToolboxApi + name: api undetermined toolbox + description: This is where your favorite api's supplies lie. Try to remember which ones. + parent: [ BaseItem, BaseMinorContraband ] + components: + - type: Sprite + sprite: Objects/Tools/Toolboxes/toolbox_thief.rsi + state: icon + - type: ThiefUndeterminedBackpack + maxSelectedSets: 3 + possibleSets: + - ChameleonSet + - SyndieSet + - UtilitiesSet + - type: ActivatableUI + key: enum.ThiefBackpackUIKey.Key + - type: UserInterface + interfaces: + enum.ThiefBackpackUIKey.Key: + type: ThiefBackpackBoundUserInterface diff --git a/Resources/Prototypes/_CorvaxNext/GameRules/api.yml b/Resources/Prototypes/_CorvaxNext/GameRules/api.yml new file mode 100644 index 00000000000..ff361c53751 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/GameRules/api.yml @@ -0,0 +1,29 @@ +- type: entity + parent: BaseGameRule + id: Api + components: + - type: ThiefRule + - type: AntagObjectives + objectives: + - EscapeThiefShuttleObjective + - type: AntagRandomObjectives + sets: + - groups: ApiObjectiveGroups + maxPicks: 1 + maxDifficulty: 1 + - type: AntagSelection + agentName: api-round-end-agent-name + definitions: + - prefRoles: [ Api ] + max: 1 + playerRatio: 15 + lateJoinAdditional: true + allowNonHumans: true + multiAntagSetting: NotExclusive + startingGear: ApiGear +# components: # Corvax-MRP +# - type: Pacified + mindRoles: + - MindRoleApi + briefing: + sound: "/Audio/Misc/thief_greeting.ogg" diff --git a/Resources/Prototypes/_CorvaxNext/Objectives/ai_steal_target_group.yml b/Resources/Prototypes/_CorvaxNext/Objectives/ai_steal_target_group.yml new file mode 100644 index 00000000000..df26a8b227f --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Objectives/ai_steal_target_group.yml @@ -0,0 +1,6 @@ +- type: stealTargetGroup + id: Ai + name: steal-target-groups-ai + sprite: + sprite: Mobs/Silicon/station_ai.rsi + state: ai diff --git a/Resources/Prototypes/_CorvaxNext/Objectives/api.yml b/Resources/Prototypes/_CorvaxNext/Objectives/api.yml new file mode 100644 index 00000000000..862195a1702 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Objectives/api.yml @@ -0,0 +1,31 @@ +- type: entity + abstract: true + parent: BaseObjective + id: BaseApiObjective + components: + - type: Objective + issuer: objective-issuer-thief + - type: RoleRequirement + roles: + mindRoles: + - ThiefRole + +- type: entity + abstract: true + parent: [BaseApiObjective, BaseStealObjective] + id: BaseApiStealObjective + components: + - type: StealCondition + verifyMapExistence: false + descriptionText: objective-condition-api-description + checkStealAreas: true + +- type: entity + parent: BaseApiStealObjective + id: AiStealObjective + components: + - type: StealCondition + stealGroup: Ai + checkHasAi: true + - type: Objective + difficulty: 1 diff --git a/Resources/Prototypes/_CorvaxNext/Objectives/api_objective_groups.yml b/Resources/Prototypes/_CorvaxNext/Objectives/api_objective_groups.yml new file mode 100644 index 00000000000..5ec96791a28 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Objectives/api_objective_groups.yml @@ -0,0 +1,9 @@ +- type: weightedRandom + id: ApiObjectiveGroups + weights: + ApiObjectiveGroupAi: 1 + +- type: weightedRandom + id: ApiObjectiveGroupAi + weights: + AiStealObjective: 1 diff --git a/Resources/Prototypes/_CorvaxNext/Roles/Antags/api.yml b/Resources/Prototypes/_CorvaxNext/Roles/Antags/api.yml new file mode 100644 index 00000000000..0d76b8fb684 --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Roles/Antags/api.yml @@ -0,0 +1,18 @@ +- type: antag + id: Api + name: roles-antag-thief-name + antagonist: true + setPreference: true + objective: roles-antag-api-objective + guides: [ Thieves ] + requirements: + - !type:OverallPlaytimeRequirement + time: 108000 # 30h # Corvax-RoleTime + +- type: startingGear + id: ApiGear + storage: + back: + - ToolboxApi + - ClothingHandsChameleonThief + - ThiefBeacon diff --git a/Resources/Prototypes/_CorvaxNext/Roles/MindRoles/api_mind_role.yml b/Resources/Prototypes/_CorvaxNext/Roles/MindRoles/api_mind_role.yml new file mode 100644 index 00000000000..9ee673e979f --- /dev/null +++ b/Resources/Prototypes/_CorvaxNext/Roles/MindRoles/api_mind_role.yml @@ -0,0 +1,10 @@ +# Thief +- type: entity + parent: BaseMindRoleAntag + id: MindRoleApi + name: Api Role +# description: mind-role-api-description + components: + - type: MindRole + antagPrototype: Api + - type: ThiefRole