diff --git a/EveCalc.Shared/AssemblyInfo.cs b/EveCalc.Shared/AssemblyInfo.cs
new file mode 100644
index 0000000..8b5504e
--- /dev/null
+++ b/EveCalc.Shared/AssemblyInfo.cs
@@ -0,0 +1,10 @@
+using System.Windows;
+
+[assembly: ThemeInfo(
+ ResourceDictionaryLocation.None, //where theme specific resource dictionaries are located
+ //(used if a resource is not found in the page,
+ // or application resource dictionaries)
+ ResourceDictionaryLocation.SourceAssembly //where the generic resource dictionary is located
+ //(used if a resource is not found in the page,
+ // app, or any theme specific resource dictionaries)
+)]
diff --git a/EveCalc.Shared/Enums.cs b/EveCalc.Shared/Enums.cs
new file mode 100644
index 0000000..c5fa106
--- /dev/null
+++ b/EveCalc.Shared/Enums.cs
@@ -0,0 +1,19 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace EveCalc.Shared
+{
+ public enum Materials
+ {
+ Tritanium = 34,
+ Pyerite = 35,
+ Mexallon = 36,
+ Isogen = 37,
+ Nocxium = 38,
+ Zydrine = 39,
+ Megacyte = 40
+ }
+}
diff --git a/EveCalc.Shared/EveCalc.Shared.csproj b/EveCalc.Shared/EveCalc.Shared.csproj
new file mode 100644
index 0000000..92c0f14
--- /dev/null
+++ b/EveCalc.Shared/EveCalc.Shared.csproj
@@ -0,0 +1,25 @@
+
+
+
+ Library
+ net5.0-windows
+ true
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/EveCalc.Shared/Logic/EsiClientWrapper.cs b/EveCalc.Shared/Logic/EsiClientWrapper.cs
new file mode 100644
index 0000000..8122472
--- /dev/null
+++ b/EveCalc.Shared/Logic/EsiClientWrapper.cs
@@ -0,0 +1,201 @@
+using ESI.NET;
+using ESI.NET.Enumerations;
+using ESI.NET.Models.SSO;
+using EveCalc.Shared.ObjectModel;
+using Microsoft.Extensions.Options;
+using Newtonsoft.Json;
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Threading.Tasks;
+
+namespace EveCalc.Shared.Logic
+{
+ public partial class EsiClientWrapper
+ {
+ private readonly EsiClient client;
+ private AuthorizedCharacterData charData;
+ private string loginState = "guguseli123";
+
+ public EsiClientWrapper()
+ {
+ IOptions config = Options.Create(new EsiConfig()
+ {
+ EsiUrl = "https://esi.evetech.net/",
+ DataSource = DataSource.Tranquility,
+ ClientId = "f6892ca208364df1b0b8984773e16a2f",
+ SecretKey = "u5SqGF6ZkEdvjLBRn5rzU1Lz3oaFcpsGDX8Ki6Jn",
+ CallbackUrl = "https://localhost/evecalc",
+ UserAgent = "EveCalc.Test",
+ AuthVersion = AuthVersion.v2
+ });
+
+ this.client = new EsiClient(config);
+
+ // Init existsing token
+ if (File.Exists("token.json"))
+ {
+ var json = File.ReadAllText("token.json");
+ this.charData = JsonConvert.DeserializeObject(json);
+ this.client.SetCharacterData(this.charData);
+ if (this.charData.ExpiresOn.AddHours(1) < DateTime.Now)
+ {
+ this.RefreshToken();
+ }
+ }
+
+ // Init cache
+ this.LoadNameCache();
+ }
+
+ public string GetLoginUrl()
+ {
+ var scopes = new List
+ {
+ "publicData",
+ //"esi-calendar.respond_calendar_events.v1",
+ //"esi-calendar.read_calendar_events.v1",
+ //"esi-location.read_location.v1",
+ //"esi-location.read_ship_type.v1",
+ //"esi-mail.organize_mail.v1",
+ //"esi-mail.read_mail.v1",
+ //"esi-mail.send_mail.v1",
+ //"esi-skills.read_skills.v1",
+ //"esi-skills.read_skillqueue.v1",
+ "esi-wallet.read_character_wallet.v1",
+ "esi-wallet.read_corporation_wallet.v1",
+ //"esi-search.search_structures.v1",
+ //"esi-clones.read_clones.v1",
+ //"esi-characters.read_contacts.v1",
+ "esi-universe.read_structures.v1",
+ //"esi-bookmarks.read_character_bookmarks.v1",
+ //"esi-killmails.read_killmails.v1",
+ "esi-corporations.read_corporation_membership.v1",
+ "esi-assets.read_assets.v1",
+ //"esi-planets.manage_planets.v1",
+ //"esi-fleets.read_fleet.v1",
+ //"esi-fleets.write_fleet.v1",
+ //"esi-ui.open_window.v1",
+ //"esi-ui.write_waypoint.v1",
+ //"esi-characters.write_contacts.v1",
+ //"esi-fittings.read_fittings.v1",
+ //"esi-fittings.write_fittings.v1",
+ "esi-markets.structure_markets.v1",
+ "esi-corporations.read_structures.v1",
+ //"esi-characters.read_loyalty.v1",
+ //"esi-characters.read_opportunities.v1",
+ //"esi-characters.read_chat_channels.v1",
+ //"esi-characters.read_medals.v1",
+ //"esi-characters.read_standings.v1",
+ //"esi-characters.read_agents_research.v1",
+ //"esi-industry.read_character_jobs.v1",
+ "esi-markets.read_character_orders.v1",
+ "esi-characters.read_blueprints.v1",
+ //"esi-characters.read_corporation_roles.v1",
+ //"esi-location.read_online.v1",
+ //"esi-contracts.read_character_contracts.v1",
+ //"esi-clones.read_implants.v1",
+ //"esi-characters.read_fatigue.v1",
+ //"esi-killmails.read_corporation_killmails.v1",
+ //"esi-corporations.track_members.v1",
+ "esi-wallet.read_corporation_wallets.v1",
+ //"esi-characters.read_notifications.v1",
+ //"esi-corporations.read_divisions.v1",
+ //"esi-corporations.read_contacts.v1",
+ "esi-assets.read_corporation_assets.v1",
+ //"esi-corporations.read_titles.v1",
+ "esi-corporations.read_blueprints.v1",
+ //"esi-bookmarks.read_corporation_bookmarks.v1",
+ //"esi-contracts.read_corporation_contracts.v1",
+ //"esi-corporations.read_standings.v1",
+ //"esi-corporations.read_starbases.v1",
+ //"esi-industry.read_corporation_jobs.v1",
+ "esi-markets.read_corporation_orders.v1",
+ //"esi-corporations.read_container_logs.v1",
+ //"esi-industry.read_character_mining.v1",
+ //"esi-industry.read_corporation_mining.v1",
+ //"esi-planets.read_customs_offices.v1",
+ //"esi-corporations.read_facilities.v1",
+ //"esi-corporations.read_medals.v1",
+ //"esi-characters.read_titles.v1",
+ //"esi-alliances.read_contacts.v1",
+ //"esi-characters.read_fw_stats.v1",
+ //"esi-corporations.read_fw_stats.v1",
+ //"esi-characterstats.read.v1"
+ };
+ return client.SSO.CreateAuthenticationUrl(scopes, this.loginState);
+ }
+
+ public async void SetAuthCode(string code)
+ {
+ SsoToken token = await this.client.SSO.GetToken(GrantType.AuthorizationCode, code);
+ this.charData = await client.SSO.Verify(token);
+ this.client.SetCharacterData(this.charData);
+
+ var json = JsonConvert.SerializeObject(this.charData);
+ File.WriteAllText("token.json", json);
+ }
+
+ public async void RefreshToken()
+ {
+ var token = await this.client.SSO.GetToken(GrantType.RefreshToken, this.charData.RefreshToken);
+ this.charData = await client.SSO.Verify(token);
+ this.client.SetCharacterData(this.charData);
+ }
+
+ public async void Test()
+ {
+ var response = await client.Universe.Names(new List()
+ {
+ 1590304510,
+ 99006319,
+ 20000006
+ });
+ }
+
+ public async Task> GetCorpBlueprints()
+ {
+ var response = await this.client.Corporation.Blueprints();
+
+ var result = new List();
+ foreach (var blueprint in response.Data)
+ {
+ var blueprint2 = new Blueprint(blueprint);
+ blueprint2.TypeName = await this.GetFromNameCache(blueprint2.TypeId);
+ result.Add(blueprint2);
+ }
+
+ return result;
+ }
+
+ public async Task