Exemplo n.º 1
0
        public Models.PackageAbility Load(GomObjectData gomObj)
        {
            GomObjectData obj = gomObj;

            Models.PackageAbility result = new Models.PackageAbility();
            result.AbilityId   = obj.ValueOrDefault <ulong>("ablAbilityDataSpec", 0);
            result.AutoAcquire = gomObj.ValueOrDefault <bool>("ablAbilityDataAutoAcquire", false);
            // result.CategoryName =
            // result.CategoryNameId

            // result.IsTalent
            result.PackageId = obj.ValueOrDefault <ulong>("ablAbilityDataPackage", 0);
            List <object> ranks = obj.ValueOrDefault <List <object> >("ablAbilityDataRanks", null);

            foreach (var rank in ranks)
            {
                result.Levels.Add((int)(long)rank);
            }
            if (result.Levels.Count > 0)
            {
                result.Level = result.Levels[0];
            }
            result.Scales = (result.Levels.Count == 50);
            // result.Rank =
            // result.Toughness =

            result.Ability = AbilityLoader.Load(result.AbilityId);
            return(result);
        }
Exemplo n.º 2
0
        private static string TryGetString(string fqn, GomObjectData textRetriever)
        {
            string locBucket  = textRetriever.ValueOrDefault <string>("strLocalizedTextRetrieverBucket", null);
            long   strId      = textRetriever.ValueOrDefault <long>("strLocalizedTextRetrieverStringID", -1);
            string defaultStr = textRetriever.ValueOrDefault <string>("strLocalizedTextRetrieverDesignModeText", String.Empty);

            if ((locBucket == null) || (strId == -1))
            {
                return(defaultStr);
            }

            StringTable strTable = null;

            try
            {
                strTable = StringTable.Find(locBucket);
            }
            catch
            {
                strTable = null;
            }

            if (strTable == null)
            {
                return(defaultStr);
            }

            string result = strTable.GetText(strId, fqn);

            return(result ?? defaultStr);
        }
Exemplo n.º 3
0
        public static Models.ItemSet Load(Models.ItemSet set, GomObjectData obj)
        {
            if (obj == null)
            {
                return(set);
            }
            if (set == null)
            {
                return(null);
            }

            set.Id     = (ulong)obj.ValueOrDefault <long>("itmSetBonusDisplayName", 0);
            set.NameId = (int)obj.ValueOrDefault <long>("itmSetBonusDisplayName", 0);
            set.Name   = strTable.GetText(NameOffset + set.NameId, "ItemSet." + set.Id);
            set.Count  = (int)obj.ValueOrDefault <long>("itmSetBonusItemCount", 0);

            Dictionary <object, object> setItems = obj.ValueOrDefault <Dictionary <object, object> >("itmSetBonusSetItems", null);

            set.SetItems = new List <ItemSetItem>();
            foreach (var itm_itm in setItems)
            {
                ulong itmId         = (ulong)itm_itm.Key;
                ulong primaryItemId = (ulong)itm_itm.Value;

                var itm  = ItemLoader.Load(itmId);
                var pItm = ItemLoader.Load(primaryItemId);

                var setItm = new ItemSetItem();
                setItm.Item        = itm;
                setItm.PrimaryItem = pItm;
                setItm.ItemSet     = set;
                set.SetItems.Add(setItm);
            }

            //List<object> primaryItems = obj.itmSetBonusPrimaryItems;
            //set.PrimaryItems = new List<Item>();
            //foreach (ulong itemNodeId in primaryItems)
            //{
            //    var itm = ItemLoader.Load(itemNodeId);
            //    set.PrimaryItems.Add(itm);
            //}

            Dictionary <object, object> bonusAbilities = obj.ValueOrDefault <Dictionary <object, object> >("itmSetBonusBonuses", null);

            set.Abilities = new List <ItemSetAbility>();
            foreach (var cnt_abl in bonusAbilities)
            {
                int   cnt       = (int)(long)cnt_abl.Key;
                ulong ablNodeId = (ulong)cnt_abl.Value;

                var abl = AbilityLoader.Load(ablNodeId);

                ItemSetAbility setAbl = new ItemSetAbility();
                setAbl.Ability   = abl;
                setAbl.ItemCount = cnt;
                setAbl.ItemSet   = set;
                set.Abilities.Add(setAbl);
            }
            return(set);
        }
Exemplo n.º 4
0
        public static QuestStep Load(GomObjectData obj, QuestBranch branch)
        {
            QuestStep step = new QuestStep();

            step.Id          = (int)obj.ValueOrDefault <long>("qstStepId", 0);
            step.Branch      = branch;
            step.IsShareable = obj.ValueOrDefault <bool>("qstStepIsShareable", false);

            step.Tasks = new List <QuestTask>();
            var tasks = (List <object>)obj.ValueOrDefault <List <object> >("qstTasks", null);

            if (tasks != null)
            {
                foreach (var taskDef in tasks)
                {
                    var tsk = QuestTaskLoader.Load((GomObjectData)taskDef, step);
                    step.Tasks.Add(tsk);
                }
            }

            var stringIds = (List <object>)obj.ValueOrDefault <List <object> >("qstStepJournalEntryStringIdList", null);
            var strings   = new List <string>();

            if (stringIds != null)
            {
                var txtLookup = branch.Quest.TextLookup;
                foreach (var strId in stringIds)
                {
                    long key = (long)(ulong)strId;
                    if (txtLookup.ContainsKey(key))
                    {
                        strings.Add(StringTable.TryGetString(branch.Quest.Fqn, (GomObjectData)txtLookup[key]));
                    }
                    else
                    {
                        strings.Add(String.Empty);
                    }
                }
            }

            step.JournalText = String.Join("\n\n", strings.ToArray());

            return(step);
        }
Exemplo n.º 5
0
        public static QuestBranch Load(GomObjectData obj, Quest qst)
        {
            QuestBranch branch = new QuestBranch();

            branch.Quest = qst;
            branch.Id    = (int)obj.ValueOrDefault <long>("qstBranchId", 0);

            var qstSteps = obj.ValueOrDefault <List <object> >("qstSteps", null);

            branch.Steps = new List <QuestStep>();
            if (qstSteps != null)
            {
                foreach (var step in qstSteps)
                {
                    branch.Steps.Add(QuestStepLoader.Load((GomObjectData)step, branch));
                }
            }

            return(branch);
        }
Exemplo n.º 6
0
        public static Models.Area Load(Models.Area area, GomObjectData obj)
        {
            if (obj == null)
            {
                return(area);
            }
            if (area == null)
            {
                return(null);
            }

            IDictionary <string, object> objAsDict = obj.Dictionary;

            if (objAsDict.ContainsKey("mapAreasDataDisplayNameId") && objAsDict.ContainsKey("mapAreasDataDefaultZoneName"))
            {
                area.DisplayNameId = obj.ValueOrDefault <long>("mapAreasDataDisplayNameId", 0);
                area.Id            = (int)(area.DisplayNameId & 0x7FFFFFFF);
                area.CommentableId = Guid.NewGuid();
                area.Name          = strTable.GetText(area.DisplayNameId, "MapArea." + area.DisplayNameId);
                area.AreaId        = obj.ValueOrDefault <ulong>("mapAreasDataAreaId", 0);
                area.ZoneName      = obj.ValueOrDefault <string>("mapAreasDataDefaultZoneName", null);

                string mapDataPath = String.Format("world.areas.{0}.mapdata", area.AreaId);
                var    mapDataObj  = DataObjectModel.GetObject(mapDataPath);
                if (mapDataObj != null)
                {
                    LoadMapdata(area, mapDataObj);
                }
                else
                {
                    Console.WriteLine("No MapData for " + area.Name);
                    area.Id = 0;
                }
            }
            else
            {
                area.Id = 0;
            }

            return(area);
        }
Exemplo n.º 7
0
        public static QuestTask Load(GomObjectData obj, QuestStep step)
        {
            QuestTask task = new QuestTask();

            task.Step = step;
            task.Id   = (int)obj.ValueOrDefault <long>("qstTaskId", 0);

            task.CountMax     = (int)obj.ValueOrDefault <long>("qstTaskCountMax", 0);
            task.ShowTracking = obj.ValueOrDefault <bool>("qstTaskShowTracking", false);
            task.ShowCount    = obj.ValueOrDefault <bool>("qstTaskShowTrackingCount", false);
            task.Hook         = QuestHookExtensions.ToQuestHook((string)obj.ValueOrDefault <string>("qstHook", null));
            long stringId = 0;

            long.TryParse(obj.ValueOrDefault <string>("qstTaskStringid", null), out stringId);

            var txtLookup = step.Branch.Quest.TextLookup;

            if (txtLookup.ContainsKey(stringId))
            {
                task.String = StringTable.TryGetString(step.Branch.Quest.Fqn, (GomObjectData)txtLookup[stringId]);
            }

            task.TaskQuests = new List <Quest>();
            task.TaskNpcs   = new List <Npc>();
            var qstTaskObjects = (Dictionary <object, object>)obj.ValueOrDefault <Dictionary <object, object> >("qstTaskObjects", null);

            if (qstTaskObjects != null)
            {
                foreach (var taskObj in qstTaskObjects)
                {
                    string fqn = (string)taskObj.Key;
                    if (fqn.StartsWith("qst."))
                    {
                        var qst = QuestLoader.Load(fqn);
                        task.TaskQuests.Add(qst);
                    }
                    else if (fqn.StartsWith("npc."))
                    {
                        var npc = NpcLoader.Load(fqn);
                        task.TaskNpcs.Add(npc);
                    }
                    else if (fqn.StartsWith("plc."))
                    {
                    }
                }
            }

            return(task);
        }
Exemplo n.º 8
0
        static DialogNode LoadDialogNode(Conversation cnv, GomObjectData data)
        {
            DialogNode result = new DialogNode();

            result.NodeId    = (int)data.Get <long>("cnvNodeNumber");
            result.MinLevel  = (int)data.ValueOrDefault <long>("cnvLevelConditionMin", -1);
            result.MaxLevel  = (int)data.ValueOrDefault <long>("cnvLevelConditionMax", -1);
            result.IsEmpty   = data.ValueOrDefault <bool>("cnvIsEmpty", false);
            result.IsAmbient = data.ValueOrDefault <bool>("cnvIsAmbient", false);
            result.JoinDisabledForHolocom   = data.ValueOrDefault <bool>("cnvIsJoinDisabledForHolocom", false);
            result.ChoiceDisabledForHolocom = data.ValueOrDefault <bool>("cnvIsVoteWinDisabledForHolocom", false);
            result.AbortsConversation       = data.ValueOrDefault <bool>("cnvAbortConversation", false);
            result.IsPlayerNode             = data.ValueOrDefault <bool>("cnvIsPcNode", false);

            result.ActionHook = QuestHookExtensions.ToQuestHook(data.ValueOrDefault <string>("cnvActionHook", null));

            // Load Alignment Results
            long alignmentAmount = data.ValueOrDefault <long>("cnvRewardForceAmount", 0);

            if (alignmentAmount != 0)
            {
                string forceType = data.Get <ScriptEnum>("cnvRewardForceType").ToString();
                result.AlignmentGain = ConversationAlignmentExtensions.ToConversationAlignment(alignmentAmount, forceType);
            }

            // Load Companion Affection Results
            var affectionGains = data.ValueOrDefault <Dictionary <object, object> >("cnvRewardAffectionRewards", null);

            result.AffectionRewards = new Dictionary <Npc, ConversationAffection>();
            if (affectionGains != null)
            {
                foreach (var companionGain in affectionGains)
                {
                    long companionShortNameId           = (long)companionGain.Key;
                    ConversationAffection affectionGain = ConversationAffectionExtensions.ToConversationAffection((long)companionGain.Value);
                    Npc companion = CompanionBySimpleNameId(companionShortNameId);
                    result.AffectionRewards[companion] = affectionGain;
                }
            }

            // Get Text
            var           textMap = data.Get <Dictionary <object, object> >("locTextRetrieverMap");
            GomObjectData txtData = (GomObjectData)textMap[(long)result.NodeId];

            result.Text = StringTable.TryGetString(cnv.Fqn, txtData);

            result.ChildIds = new List <int>();
            foreach (long childId in data.Get <List <object> >("cnvChildNodes"))
            {
                result.ChildIds.Add((int)childId);
            }

            // Load Quests
            var actionQuest = data.ValueOrDefault <ulong>("cnvActionQuest", 0);

            if (actionQuest > 0)
            {
                result.ActionQuest = QuestLoader.Load(actionQuest);
            }

            var questReward = data.ValueOrDefault <ulong>("cnvRewardQuest", 0);

            if (questReward > 0)
            {
                result.QuestReward = QuestLoader.Load(questReward);
            }

            var questGrants = data.Get <Dictionary <object, object> >("cnvNodeQuestGrants");

            result.QuestsGranted = new List <Quest>();
            foreach (var grant in questGrants)
            {
                if ((bool)grant.Value)
                {
                    Quest q = QuestLoader.Load((ulong)grant.Key);
                    result.QuestsGranted.Add(q);
                }
            }

            var questEnds = data.Get <Dictionary <object, object> >("cnvNodeQuestEnds");

            result.QuestsEnded = new List <Quest>();
            foreach (var ends in questEnds)
            {
                if ((bool)ends.Value)
                {
                    Quest q = QuestLoader.Load((ulong)ends.Key);
                    result.QuestsEnded.Add(q);
                }
            }

            var questProgress = data.Get <Dictionary <object, object> >("cnvNodeQuestProgress");

            result.QuestsProgressed = new List <Quest>();
            foreach (var prog in questProgress)
            {
                if ((bool)prog.Value)
                {
                    Quest q = QuestLoader.Load((ulong)prog.Key);
                    result.QuestsProgressed.Add(q);
                }
            }

            return(result);
        }
Exemplo n.º 9
0
        private static string LoadParamHealing(GomObjectData tokDesc, List <object> abilityEffectList)
        {
            int   tokEffIndex    = (int)tokDesc.ValueOrDefault <long>("ablDescriptionTokenEffect", 0);
            int   tokSubEffIndex = (int)tokDesc.ValueOrDefault <long>("ablDescriptionTokenSubEffect", 0);
            float multi          = (float)tokDesc.ValueOrDefault <float>("ablDescriptionTokenMultiplier", 0f);

            if (tokEffIndex < abilityEffectList.Count)
            {
                // Effect is in-range, find the coefficients for healing formula
                var tokEff = DataObjectModel.GetObject((ulong)abilityEffectList[tokEffIndex]);
                if (tokEff == null)
                {
                    return("healing");
                }

                var           tokSubEffects = (List <object>)tokEff.Data.ValueOrDefault <List <object> >("effSubEffects", null);
                GomObjectData action        = null;
                // Loop through subEffects
                if ((tokSubEffIndex >= 0) && (tokSubEffIndex < tokSubEffects.Count))
                {
                    GomObjectData subEff = (GomObjectData)tokSubEffects[tokSubEffIndex];
                    foreach (GomObjectData a in subEff.ValueOrDefault <List <object> >("effActions", null))
                    {
                        if (((ScriptEnum)a.ValueOrDefault <ScriptEnum>("effActionName", null)).ToString() == "effAction_Heal")
                        {
                            action = a;
                            break;
                        }
                    }
                }
                else
                {
                    foreach (GomObjectData subEff in tokSubEffects)
                    {
                        var effActions = (List <object>)subEff.ValueOrDefault <List <object> >("effActions", null);
                        foreach (GomObjectData a in effActions)
                        {
                            if (((ScriptEnum)a.ValueOrDefault <ScriptEnum>("effActionName", null)).ToString() == "effAction_Heal")
                            {
                                action = a;
                                break;
                            }
                        }
                        if (action != null)
                        {
                            break;
                        }
                    }
                }

                if (action == null)
                {
                    return("healing");
                }

                var   floatParams = (Dictionary <object, object>)action.ValueOrDefault <Dictionary <object, object> >("effFloatParams", null);
                float amtMin      = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_AmountMin").Value;
                float amtMax      = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_AmountMax").Value;
                float amtPct      = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_AmountPercent").Value;
                float stdHpMin    = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_StandardHealthPercentMin").Value;
                float stdHpMax    = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_StandardHealthPercentMax").Value;
                float coeff       = (float)floatParams.First(kvp => ((ScriptEnum)kvp.Key).ToString() == "effParam_HealingPowerCoefficient").Value;

                if (amtMin != 0)
                {
                    return(String.Format("healing,{0},{1},{2}", multi, amtMin, amtMax));
                }
                else
                {
                    return(String.Format("healing,{0},{1},{2},{3}", multi, coeff, stdHpMin, stdHpMax));
                }
            }

            return("healing");
        }
Exemplo n.º 10
0
        private static List <string> LoadParamDamage(GomObjectData tokDesc, List <object> abilityEffectList)
        {
            int   tokEffIndex    = (int)tokDesc.ValueOrDefault <long>("ablDescriptionTokenEffect", 0);
            int   tokSubEffIndex = (int)tokDesc.ValueOrDefault <long>("ablDescriptionTokenSubEffect", 0);
            float multi          = (float)tokDesc.ValueOrDefault <float>("ablDescriptionTokenMultiplier", 0f);

            if (!(tokEffIndex < abilityEffectList.Count))
            {
                return(new List <string>()
                {
                    "damage"
                });
            }
            // Effect is in-range, find the coefficients for dmg formula
            GomObject tokEff = null;

            if (tokEffIndex >= 0)
            {
                tokEff = DataObjectModel.GetObject((ulong)abilityEffectList[tokEffIndex]);
            }
            else
            {
                foreach (ulong ablEffId in abilityEffectList)
                {
                    tokEff = DataObjectModel.GetObject(ablEffId);
                    if (tokEff == null)
                    {
                        continue;
                    }
                    if (HasDamageAction(tokEff))
                    {
                        break;
                    }
                    else
                    {
                        tokEff = null;
                    }
                }
            }
            if (tokEff == null)
            {
                return(new List <string>()
                {
                    "damage"
                });
            }

            var tokSubEffects             = (List <object>)tokEff.Data.ValueOrDefault <List <object> >("effSubEffects", null);
            List <GomObjectData> actions  = new List <GomObjectData>();
            List <bool>          isWeapon = new List <bool>();

            // Loop through subEffects
            if ((tokSubEffIndex >= 0) && (tokSubEffIndex < tokSubEffects.Count))
            {
                GomObjectData subEff = (GomObjectData)tokSubEffects[tokSubEffIndex];
                foreach (GomObjectData a in subEff.ValueOrDefault <List <object> >("effActions", null))
                {
                    switch (((ScriptEnum)a.ValueOrDefault <ScriptEnum>("effActionName", null)).ToString())
                    {
                    case "effAction_WeaponDamage": { actions.Add(a); isWeapon.Add(true); break; }

                    case "effAction_SpellDamage": { actions.Add(a); isWeapon.Add(false); break; }
                    }
                }
            }
            else
            {
                foreach (GomObjectData subEff in tokSubEffects)
                {
                    var effActions = (List <object>)subEff.Get <List <object> >("effActions");
                    foreach (GomObjectData a in effActions)
                    {
                        var b = ((ScriptEnum)a.Get <ScriptEnum>("effActionName")).ToString();
                        switch (b)
                        {
                        case "effAction_WeaponDamage": { actions.Add(a); isWeapon.Add(true); break; }

                        case "effAction_SpellDamage": { actions.Add(a); isWeapon.Add(false); break; }
                        }
                    }
                    //if (actions != null) { break; }
                }
            }

            if (actions == null || actions.Count <= 0)
            {
                return(new List <string>()
                {
                    "damage"
                });
            }
            var retVal = new List <string>();

            for (int i = 0; i < actions.Count; i++)
            {
                retVal.Add(LoadParamDamageChild(multi, actions[i], isWeapon[i]));
            }

            return(retVal);
        }
Exemplo n.º 11
0
        public static Models.Npc Load(Models.Npc npc, GomObject obj)
        {
            if (obj == null)
            {
                return(npc);
            }
            if (npc == null)
            {
                return(null);
            }

            ulong baseNpcId = obj.Data.ValueOrDefault <ulong>("npcParentSpecId", 0);
            Npc   baseNpc;

            if (baseNpcId > 0)
            {
                baseNpc = Load(baseNpcId);
            }
            else
            {
                baseNpc = new Npc();
            }

            npc.Fqn    = obj.Name;
            npc.NodeId = obj.Id;

            var           textLookup     = obj.Data.ValueOrDefault <Dictionary <object, object> >("locTextRetrieverMap", null);
            GomObjectData nameLookupData = (GomObjectData)textLookup[NameLookupKey];
            var           nameId         = nameLookupData.ValueOrDefault <long>("strLocalizedTextRetrieverStringID", 0);

            npc.Name = StringTable.TryGetString(npc.Fqn, nameLookupData);

            if (textLookup.ContainsKey(TitleLookupKey))
            {
                var titleLookupData = (GomObjectData)textLookup[TitleLookupKey];
                npc.Title = StringTable.TryGetString(npc.Fqn, titleLookupData);
            }

            npc.Id = (ulong)(nameId >> 32);

            //if (objIdMap.ContainsKey(npc.Id))
            //{
            //    Npc otherNpc = objIdMap[npc.Id];
            //    if (!String.Equals(otherNpc.Fqn, npc.Fqn))
            //    {
            //        throw new InvalidOperationException(String.Format("Duplicate NPC Ids: {0} and {1}", otherNpc.Fqn, npc.Fqn));
            //    }
            //}
            //else
            //{
            //    objIdMap[npc.Id] = npc;
            //}

            npc.MinLevel = (int)obj.Data.ValueOrDefault <long>("field_4000000027BDA14B", (long)baseNpc.MinLevel);
            npc.MaxLevel = (int)obj.Data.ValueOrDefault <long>("field_4000000027BDA14C", (long)baseNpc.MaxLevel);

            // Load Toughness
            var toughnessEnum = (ScriptEnum)obj.Data.ValueOrDefault <ScriptEnum>("field_40000005618EC27C", null);

            if (toughnessEnum == null)
            {
                npc.Toughness = baseNpc.Toughness;
            }
            else
            {
                npc.Toughness = ToughnessExtensions.ToToughness(toughnessEnum);
            }

            // Load Faction
            long factionId = obj.Data.ValueOrDefault <long>("npcFaction", 0);

            if (factionId == 0)
            {
                npc.Faction = baseNpc.Faction;
            }
            else
            {
                npc.Faction = FactionExtensions.ToFaction(factionId);
            }

            npc.DifficultyFlags = (int)obj.Data.ValueOrDefault <long>("spnDifficultyLevelFlags", baseNpc.DifficultyFlags);

            npc.LootTableId = obj.Data.ValueOrDefault <long>("field_40000009AF9F1222", baseNpc.LootTableId);

            ulong npcClass = obj.Data.ValueOrDefault <ulong>("npcClassPackage", 0);

            if (npcClass == 0)
            {
                npc.ClassSpec = baseNpc.ClassSpec;
            }
            else
            {
                npc.ClassSpec = ClassSpecLoader.Load(npcClass);
            }

            ulong cdxNodeId = obj.Data.ValueOrDefault <ulong>("npcCodexSpec", 0);

            if (cdxNodeId > 0)
            {
                npc.Codex = CodexLoader.Load(cdxNodeId);
            }
            else
            {
                npc.Codex = baseNpc.Codex;
            }

            var profTrained = (ScriptEnum)obj.Data.ValueOrDefault <ScriptEnum>("prfTrainerProfession", null);

            if (profTrained == null)
            {
                npc.ProfessionTrained = baseNpc.ProfessionTrained;
            }
            else
            {
                npc.ProfessionTrained = ProfessionExtensions.ToProfession(profTrained);
            }

            List <object> trainedPackages = obj.Data.ValueOrDefault <List <object> >("field_4000000A1D72EA38", null);

            if (trainedPackages == null)
            {
                npc.IsClassTrainer = baseNpc.IsClassTrainer;
            }
            else
            {
                npc.IsClassTrainer = trainedPackages.Count > 0;
            }

            npc.ConversationFqn = obj.Data.ValueOrDefault <string>("cnvConversationName", baseNpc.ConversationFqn);

            List <object> vendorPackages = obj.Data.ValueOrDefault <List <object> >("field_400000037C4DE713", null);

            if (vendorPackages != null)
            {
                foreach (string pkg in vendorPackages)
                {
                    npc.VendorPackages.Add(pkg.ToLower());
                }
            }
            else
            {
                npc.VendorPackages = baseNpc.VendorPackages;
            }

            return(npc);
        }