Compare commits
2 Commits
Add-wol-te
...
minimal-se
| Author | SHA1 | Date | |
|---|---|---|---|
| bfcb895cb3 | |||
| c07a1c8ef3 |
36981
Client/package-lock.json
generated
36981
Client/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
13
Minimal-server/GotobedServer/GotobedServer.csproj
Normal file
13
Minimal-server/GotobedServer/GotobedServer.csproj
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk.Web">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<TargetFramework>net6.0</TargetFramework>
|
||||||
|
<Nullable>enable</Nullable>
|
||||||
|
<ImplicitUsings>enable</ImplicitUsings>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="Makaretu.Dns.Multicast" Version="0.27.0" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
||||||
20
Minimal-server/GotobedServer/Program.cs
Normal file
20
Minimal-server/GotobedServer/Program.cs
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
var builder = WebApplication.CreateBuilder(args);
|
||||||
|
var app = builder.Build();
|
||||||
|
var welcomeMessage = "Go to bed server.";
|
||||||
|
var status = handler.FirstRun.status("https://github.com/Myxelium/go-to-bed/");
|
||||||
|
handler.MdsService.Start();
|
||||||
|
|
||||||
|
app.MapGet("/", () => Results.Text(welcomeMessage + "Status: " + status, "text/html"));
|
||||||
|
|
||||||
|
app.MapPost("/go-to-bed/sleep", () => handler.ShutdownCommand.Hibernate());
|
||||||
|
|
||||||
|
app.MapPost("/go-to-bed/shutdown", () => handler.ShutdownCommand.Shutdown());
|
||||||
|
|
||||||
|
app.MapPost("/go-to-bed/reboot", () => handler.ShutdownCommand.Reboot());
|
||||||
|
|
||||||
|
app.MapPost("/go-to-bed/logout", () => handler.ShutdownCommand.Logout());
|
||||||
|
|
||||||
|
app.MapPost("/go-to-bed/lock", () => handler.ShutdownCommand.Lock());
|
||||||
|
|
||||||
|
|
||||||
|
app.Run();
|
||||||
28
Minimal-server/GotobedServer/Properties/launchSettings.json
Normal file
28
Minimal-server/GotobedServer/Properties/launchSettings.json
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
{
|
||||||
|
"iisSettings": {
|
||||||
|
"windowsAuthentication": false,
|
||||||
|
"anonymousAuthentication": true,
|
||||||
|
"iisExpress": {
|
||||||
|
"applicationUrl": "http://localhost:3916",
|
||||||
|
"sslPort": 44344
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"profiles": {
|
||||||
|
"TodoApi": {
|
||||||
|
"commandName": "Project",
|
||||||
|
"dotnetRunMessages": true,
|
||||||
|
"launchBrowser": true,
|
||||||
|
"applicationUrl": "https://localhost:7001;http://localhost:5230",
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"IIS Express": {
|
||||||
|
"commandName": "IISExpress",
|
||||||
|
"launchBrowser": true,
|
||||||
|
"environmentVariables": {
|
||||||
|
"ASPNETCORE_ENVIRONMENT": "Development"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
9
Minimal-server/GotobedServer/appsettings.json
Normal file
9
Minimal-server/GotobedServer/appsettings.json
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
{
|
||||||
|
"Logging": {
|
||||||
|
"LogLevel": {
|
||||||
|
"Default": "Information",
|
||||||
|
"Microsoft.AspNetCore": "Warning"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"AllowedHosts": "*"
|
||||||
|
}
|
||||||
235
Minimal-server/GotobedServer/handler.cs
Normal file
235
Minimal-server/GotobedServer/handler.cs
Normal file
@@ -0,0 +1,235 @@
|
|||||||
|
using System.Diagnostics;
|
||||||
|
using System.Net.NetworkInformation;
|
||||||
|
using System.Net.Sockets;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
using Makaretu.Dns;
|
||||||
|
using Microsoft.Win32;
|
||||||
|
|
||||||
|
namespace handler
|
||||||
|
{
|
||||||
|
public class MdsService
|
||||||
|
{
|
||||||
|
public static void Start()
|
||||||
|
{
|
||||||
|
var macAddress = (
|
||||||
|
from networkInterface in NetworkInterface.GetAllNetworkInterfaces()
|
||||||
|
where networkInterface.OperationalStatus == OperationalStatus.Up
|
||||||
|
select networkInterface.GetPhysicalAddress().ToString()).FirstOrDefault();
|
||||||
|
|
||||||
|
var addresses = MulticastService.GetIPAddresses()
|
||||||
|
.Where(ip => ip.AddressFamily == AddressFamily.InterNetwork).ToArray();
|
||||||
|
|
||||||
|
//TODO find macadress and send it
|
||||||
|
var serviceDiscovery = new ServiceDiscovery();
|
||||||
|
var service = new ServiceProfile("GoToBed-Server", "_gotobed._tcp", 13378);
|
||||||
|
service.AddProperty("mac", "macAddr");
|
||||||
|
service.AddProperty("protocol", "http");
|
||||||
|
service.AddProperty("ip", addresses[0].MapToIPv4().ToString());
|
||||||
|
serviceDiscovery.Advertise(service);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class FirstRun
|
||||||
|
{
|
||||||
|
public static readonly string configPath = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData) + "/go-to-bed-server-first-run";
|
||||||
|
|
||||||
|
public static void openGithubDocumentation(string uri)
|
||||||
|
{
|
||||||
|
Uri url = new Uri(uri);
|
||||||
|
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
Process.Start(new ProcessStartInfo(url.AbsoluteUri) { UseShellExecute = true });
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("xdg-open", url.AbsoluteUri);
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("open", url.AbsolutePath);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static bool status(string documentationPath)
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
RegistryKey key = Registry.CurrentUser.OpenSubKey(@"Software\GoToBed", true);
|
||||||
|
if (key == null)
|
||||||
|
{
|
||||||
|
key = Registry.CurrentUser.CreateSubKey(@"Software\GoToBed");
|
||||||
|
key.SetValue("FirstRun", true);
|
||||||
|
openGithubDocumentation(documentationPath);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
if (!File.Exists(configPath))
|
||||||
|
{
|
||||||
|
File.Create(configPath);
|
||||||
|
openGithubDocumentation(documentationPath);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
if (!File.Exists(configPath))
|
||||||
|
{
|
||||||
|
File.Create(configPath);
|
||||||
|
openGithubDocumentation(documentationPath);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ShutdownCommand
|
||||||
|
{
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
private static extern bool ExitWindowsEx(uint uFlags, uint dwReason);
|
||||||
|
|
||||||
|
// TODO: will clean only few are needed. Checked out what things does from documentation.
|
||||||
|
private const uint EWX_LOGOFF = 0x00000000;
|
||||||
|
private const uint EWX_SHUTDOWN = 0x00000001;
|
||||||
|
private const uint EWX_REBOOT = 0x00000002;
|
||||||
|
private const uint EWX_FORCE = 0x00000004;
|
||||||
|
private const uint EWX_POWEROFF = 0x00000008;
|
||||||
|
private const uint EWX_FORCEIFHUNG = 0x00000010;
|
||||||
|
private const uint EWX_QUICKRESOLVE = 0x00000020;
|
||||||
|
private const uint EWX_RESTARTAPPS = 0x00000040;
|
||||||
|
private const uint EWX_HYBRID_SHUTDOWN = 0x00400000;
|
||||||
|
private const uint EWX_BOOTOPTIONS = 0x01000000;
|
||||||
|
|
||||||
|
private const uint SHTDN_REASON_MAJOR_OTHER = 0x00000000;
|
||||||
|
private const uint SHTDN_REASON_MINOR_OTHER = 0x00000000;
|
||||||
|
private const uint SHTDN_REASON_FLAG_PLANNED = 0x80000000;
|
||||||
|
|
||||||
|
public static void Shutdown()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
ExitWindowsEx(EWX_SHUTDOWN | EWX_FORCE, SHTDN_REASON_MAJOR_OTHER | SHTDN_REASON_MINOR_OTHER | SHTDN_REASON_FLAG_PLANNED);
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-h now");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-h now");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Hibernate()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
ExitWindowsEx(EWX_HYBRID_SHUTDOWN | EWX_FORCE, SHTDN_REASON_MAJOR_OTHER | SHTDN_REASON_MINOR_OTHER | SHTDN_REASON_FLAG_PLANNED);
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("systemctl", "suspend");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("pmset", "sleepnow");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Abort()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
ExitWindowsEx(EWX_FORCEIFHUNG | EWX_FORCE, SHTDN_REASON_MAJOR_OTHER | SHTDN_REASON_MINOR_OTHER | SHTDN_REASON_FLAG_PLANNED);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Reboot()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
ExitWindowsEx(EWX_REBOOT | EWX_FORCE, SHTDN_REASON_MAJOR_OTHER | SHTDN_REASON_MINOR_OTHER | SHTDN_REASON_FLAG_PLANNED);
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-r now");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-r now");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void Logout()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
ExitWindowsEx(EWX_LOGOFF | EWX_FORCE, SHTDN_REASON_MAJOR_OTHER | SHTDN_REASON_MINOR_OTHER | SHTDN_REASON_FLAG_PLANNED);
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-l now");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("shutdown", "-l now");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void Lock()
|
||||||
|
{
|
||||||
|
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
|
||||||
|
{
|
||||||
|
Process.Start("rundll32.exe", "user32.dll,LockWorkStation");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
|
||||||
|
{
|
||||||
|
Process.Start("gnome-screensaver-command", "-l");
|
||||||
|
}
|
||||||
|
else if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX))
|
||||||
|
{
|
||||||
|
Process.Start("pmset", "displaysleepnow");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
throw new Exception("Unsupported OS!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
51
Minimal-server/GotobedServer/mdnsService.cs
Normal file
51
Minimal-server/GotobedServer/mdnsService.cs
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
using System.Net.NetworkInformation;
|
||||||
|
using Makaretu.Dns;
|
||||||
|
|
||||||
|
public class MdsService
|
||||||
|
{
|
||||||
|
|
||||||
|
public void Start()
|
||||||
|
{
|
||||||
|
var macAddr = (
|
||||||
|
from nic in NetworkInterface.GetAllNetworkInterfaces()
|
||||||
|
where nic.OperationalStatus == OperationalStatus.Up
|
||||||
|
select nic.GetPhysicalAddress().ToString()).FirstOrDefault();
|
||||||
|
|
||||||
|
var sd = new ServiceDiscovery();
|
||||||
|
var service = new ServiceProfile("x", "_foo._tcp", 1024);
|
||||||
|
service.AddProperty("mac", macAddr);
|
||||||
|
sd.Advertise(service);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
var sd = new ServiceDiscovery();
|
||||||
|
var service = new ServiceProfile("x", "_foo._tcp", 1024);
|
||||||
|
service.AddProperty("mac", "bar");
|
||||||
|
sd.Advertise(service);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
var service = "...";
|
||||||
|
var mdns = new MulticastService();
|
||||||
|
mdns.QueryReceived += (s, e) =>
|
||||||
|
{
|
||||||
|
var msg = e.Message;
|
||||||
|
if (msg.Questions.Any(q => q.Name == service))
|
||||||
|
{
|
||||||
|
var res = msg.CreateResponse();
|
||||||
|
var addresses = MulticastService.GetIPAddresses()
|
||||||
|
.Where(ip => ip.AddressFamily == AddressFamily.InterNetwork);
|
||||||
|
foreach (var address in addresses)
|
||||||
|
{
|
||||||
|
res.Answers.Add(new ARecord
|
||||||
|
{
|
||||||
|
Name = service,
|
||||||
|
Address = address
|
||||||
|
});
|
||||||
|
}
|
||||||
|
mdns.SendAnswer(res);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
mdns.Start();
|
||||||
|
|
||||||
|
*/
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
build
|
|
||||||
dist
|
|
||||||
61
wol/.gitignore
vendored
61
wol/.gitignore
vendored
@@ -1,61 +0,0 @@
|
|||||||
# node files
|
|
||||||
dist
|
|
||||||
node_modules
|
|
||||||
|
|
||||||
# iOS files
|
|
||||||
Pods
|
|
||||||
Podfile.lock
|
|
||||||
Build
|
|
||||||
xcuserdata
|
|
||||||
|
|
||||||
# macOS files
|
|
||||||
.DS_Store
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Based on Android gitignore template: https://github.com/github/gitignore/blob/HEAD/Android.gitignore
|
|
||||||
|
|
||||||
# Built application files
|
|
||||||
*.apk
|
|
||||||
*.ap_
|
|
||||||
|
|
||||||
# Files for the ART/Dalvik VM
|
|
||||||
*.dex
|
|
||||||
|
|
||||||
# Java class files
|
|
||||||
*.class
|
|
||||||
|
|
||||||
# Generated files
|
|
||||||
bin
|
|
||||||
gen
|
|
||||||
out
|
|
||||||
|
|
||||||
# Gradle files
|
|
||||||
.gradle
|
|
||||||
build
|
|
||||||
|
|
||||||
# Local configuration file (sdk path, etc)
|
|
||||||
local.properties
|
|
||||||
|
|
||||||
# Proguard folder generated by Eclipse
|
|
||||||
proguard
|
|
||||||
|
|
||||||
# Log Files
|
|
||||||
*.log
|
|
||||||
|
|
||||||
# Android Studio Navigation editor temp files
|
|
||||||
.navigation
|
|
||||||
|
|
||||||
# Android Studio captures folder
|
|
||||||
captures
|
|
||||||
|
|
||||||
# IntelliJ
|
|
||||||
*.iml
|
|
||||||
.idea
|
|
||||||
|
|
||||||
# Keystore files
|
|
||||||
# Uncomment the following line if you do not want to check your keystore files in.
|
|
||||||
#*.jks
|
|
||||||
|
|
||||||
# External native build folder generated in Android Studio 2.2 and later
|
|
||||||
.externalNativeBuild
|
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
build
|
|
||||||
dist
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
# Contributing
|
|
||||||
|
|
||||||
This guide provides instructions for contributing to this Capacitor plugin.
|
|
||||||
|
|
||||||
## Developing
|
|
||||||
|
|
||||||
### Local Setup
|
|
||||||
|
|
||||||
1. Fork and clone the repo.
|
|
||||||
1. Install the dependencies.
|
|
||||||
|
|
||||||
```shell
|
|
||||||
npm install
|
|
||||||
```
|
|
||||||
|
|
||||||
1. Install SwiftLint if you're on macOS.
|
|
||||||
|
|
||||||
```shell
|
|
||||||
brew install swiftlint
|
|
||||||
```
|
|
||||||
|
|
||||||
### Scripts
|
|
||||||
|
|
||||||
#### `npm run build`
|
|
||||||
|
|
||||||
Build the plugin web assets and generate plugin API documentation using [`@capacitor/docgen`](https://github.com/ionic-team/capacitor-docgen).
|
|
||||||
|
|
||||||
It will compile the TypeScript code from `src/` into ESM JavaScript in `dist/esm/`. These files are used in apps with bundlers when your plugin is imported.
|
|
||||||
|
|
||||||
Then, Rollup will bundle the code into a single file at `dist/plugin.js`. This file is used in apps without bundlers by including it as a script in `index.html`.
|
|
||||||
|
|
||||||
#### `npm run verify`
|
|
||||||
|
|
||||||
Build and validate the web and native projects.
|
|
||||||
|
|
||||||
This is useful to run in CI to verify that the plugin builds for all platforms.
|
|
||||||
|
|
||||||
#### `npm run lint` / `npm run fmt`
|
|
||||||
|
|
||||||
Check formatting and code quality, autoformat/autofix if possible.
|
|
||||||
|
|
||||||
This template is integrated with ESLint, Prettier, and SwiftLint. Using these tools is completely optional, but the [Capacitor Community](https://github.com/capacitor-community/) strives to have consistent code style and structure for easier cooperation.
|
|
||||||
|
|
||||||
## Publishing
|
|
||||||
|
|
||||||
There is a `prepublishOnly` hook in `package.json` which prepares the plugin before publishing, so all you need to do is run:
|
|
||||||
|
|
||||||
```shell
|
|
||||||
npm publish
|
|
||||||
```
|
|
||||||
|
|
||||||
> **Note**: The [`files`](https://docs.npmjs.com/cli/v7/configuring-npm/package-json#files) array in `package.json` specifies which files get published. If you rename files/directories or add files elsewhere, you may need to update it.
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
# wol
|
|
||||||
|
|
||||||
Wake on up lan
|
|
||||||
|
|
||||||
## Install
|
|
||||||
|
|
||||||
```bash
|
|
||||||
npm install wol
|
|
||||||
npx cap sync
|
|
||||||
```
|
|
||||||
|
|
||||||
## API
|
|
||||||
|
|
||||||
<docgen-index>
|
|
||||||
|
|
||||||
* [`echo(...)`](#echo)
|
|
||||||
|
|
||||||
</docgen-index>
|
|
||||||
|
|
||||||
<docgen-api>
|
|
||||||
<!--Update the source file JSDoc comments and rerun docgen to update the docs below-->
|
|
||||||
|
|
||||||
### echo(...)
|
|
||||||
|
|
||||||
```typescript
|
|
||||||
echo(options: { value: string; }) => Promise<{ value: string; }>
|
|
||||||
```
|
|
||||||
|
|
||||||
| Param | Type |
|
|
||||||
| ------------- | ------------------------------- |
|
|
||||||
| **`options`** | <code>{ value: string; }</code> |
|
|
||||||
|
|
||||||
**Returns:** <code>Promise<{ value: string; }></code>
|
|
||||||
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
</docgen-api>
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
require 'json'
|
|
||||||
|
|
||||||
package = JSON.parse(File.read(File.join(__dir__, 'package.json')))
|
|
||||||
|
|
||||||
Pod::Spec.new do |s|
|
|
||||||
s.name = 'Wol'
|
|
||||||
s.version = package['version']
|
|
||||||
s.summary = package['description']
|
|
||||||
s.license = package['license']
|
|
||||||
s.homepage = package['repository']['url']
|
|
||||||
s.author = package['author']
|
|
||||||
s.source = { :git => package['repository']['url'], :tag => s.version.to_s }
|
|
||||||
s.source_files = 'ios/Plugin/**/*.{swift,h,m,c,cc,mm,cpp}'
|
|
||||||
s.ios.deployment_target = '13.0'
|
|
||||||
s.dependency 'Capacitor'
|
|
||||||
s.swift_version = '5.1'
|
|
||||||
end
|
|
||||||
1
wol/android/.gitignore
vendored
1
wol/android/.gitignore
vendored
@@ -1 +0,0 @@
|
|||||||
/build
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
ext {
|
|
||||||
junitVersion = project.hasProperty('junitVersion') ? rootProject.ext.junitVersion : '4.13.2'
|
|
||||||
androidxAppCompatVersion = project.hasProperty('androidxAppCompatVersion') ? rootProject.ext.androidxAppCompatVersion : '1.4.2'
|
|
||||||
androidxJunitVersion = project.hasProperty('androidxJunitVersion') ? rootProject.ext.androidxJunitVersion : '1.1.3'
|
|
||||||
androidxEspressoCoreVersion = project.hasProperty('androidxEspressoCoreVersion') ? rootProject.ext.androidxEspressoCoreVersion : '3.4.0'
|
|
||||||
}
|
|
||||||
|
|
||||||
buildscript {
|
|
||||||
repositories {
|
|
||||||
google()
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
dependencies {
|
|
||||||
classpath 'com.android.tools.build:gradle:7.2.1'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
apply plugin: 'com.android.library'
|
|
||||||
|
|
||||||
android {
|
|
||||||
compileSdkVersion project.hasProperty('compileSdkVersion') ? rootProject.ext.compileSdkVersion : 32
|
|
||||||
defaultConfig {
|
|
||||||
minSdkVersion project.hasProperty('minSdkVersion') ? rootProject.ext.minSdkVersion : 22
|
|
||||||
targetSdkVersion project.hasProperty('targetSdkVersion') ? rootProject.ext.targetSdkVersion : 32
|
|
||||||
versionCode 1
|
|
||||||
versionName "1.0"
|
|
||||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
|
||||||
}
|
|
||||||
buildTypes {
|
|
||||||
release {
|
|
||||||
minifyEnabled false
|
|
||||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
lintOptions {
|
|
||||||
abortOnError false
|
|
||||||
}
|
|
||||||
compileOptions {
|
|
||||||
sourceCompatibility JavaVersion.VERSION_11
|
|
||||||
targetCompatibility JavaVersion.VERSION_11
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
repositories {
|
|
||||||
google()
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
dependencies {
|
|
||||||
implementation fileTree(dir: 'libs', include: ['*.jar'])
|
|
||||||
implementation project(':capacitor-android')
|
|
||||||
implementation "androidx.appcompat:appcompat:$androidxAppCompatVersion"
|
|
||||||
testImplementation "junit:junit:$junitVersion"
|
|
||||||
androidTestImplementation "androidx.test.ext:junit:$androidxJunitVersion"
|
|
||||||
androidTestImplementation "androidx.test.espresso:espresso-core:$androidxEspressoCoreVersion"
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
# Project-wide Gradle settings.
|
|
||||||
|
|
||||||
# IDE (e.g. Android Studio) users:
|
|
||||||
# Gradle settings configured through the IDE *will override*
|
|
||||||
# any settings specified in this file.
|
|
||||||
|
|
||||||
# For more details on how to configure your build environment visit
|
|
||||||
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
|
||||||
|
|
||||||
# Specifies the JVM arguments used for the daemon process.
|
|
||||||
# The setting is particularly useful for tweaking memory settings.
|
|
||||||
org.gradle.jvmargs=-Xmx1536m
|
|
||||||
|
|
||||||
# When configured, Gradle will run in incubating parallel mode.
|
|
||||||
# This option should only be used with decoupled projects. More details, visit
|
|
||||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
|
||||||
# org.gradle.parallel=true
|
|
||||||
|
|
||||||
# AndroidX package structure to make it clearer which packages are bundled with the
|
|
||||||
# Android operating system, and which are packaged with your app's APK
|
|
||||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn
|
|
||||||
android.useAndroidX=true
|
|
||||||
# Automatically convert third-party libraries to use AndroidX
|
|
||||||
android.enableJetifier=true
|
|
||||||
BIN
wol/android/gradle/wrapper/gradle-wrapper.jar
vendored
BIN
wol/android/gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
@@ -1,5 +0,0 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
|
||||||
distributionPath=wrapper/dists
|
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-all.zip
|
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
|
||||||
zipStorePath=wrapper/dists
|
|
||||||
234
wol/android/gradlew
vendored
234
wol/android/gradlew
vendored
@@ -1,234 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
#
|
|
||||||
# Copyright © 2015-2021 the original authors.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# https://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
#
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
#
|
|
||||||
# Gradle start up script for POSIX generated by Gradle.
|
|
||||||
#
|
|
||||||
# Important for running:
|
|
||||||
#
|
|
||||||
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
|
|
||||||
# noncompliant, but you have some other compliant shell such as ksh or
|
|
||||||
# bash, then to run this script, type that shell name before the whole
|
|
||||||
# command line, like:
|
|
||||||
#
|
|
||||||
# ksh Gradle
|
|
||||||
#
|
|
||||||
# Busybox and similar reduced shells will NOT work, because this script
|
|
||||||
# requires all of these POSIX shell features:
|
|
||||||
# * functions;
|
|
||||||
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
|
|
||||||
# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
|
|
||||||
# * compound commands having a testable exit status, especially «case»;
|
|
||||||
# * various built-in commands including «command», «set», and «ulimit».
|
|
||||||
#
|
|
||||||
# Important for patching:
|
|
||||||
#
|
|
||||||
# (2) This script targets any POSIX shell, so it avoids extensions provided
|
|
||||||
# by Bash, Ksh, etc; in particular arrays are avoided.
|
|
||||||
#
|
|
||||||
# The "traditional" practice of packing multiple parameters into a
|
|
||||||
# space-separated string is a well documented source of bugs and security
|
|
||||||
# problems, so this is (mostly) avoided, by progressively accumulating
|
|
||||||
# options in "$@", and eventually passing that to Java.
|
|
||||||
#
|
|
||||||
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
|
|
||||||
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
|
|
||||||
# see the in-line comments for details.
|
|
||||||
#
|
|
||||||
# There are tweaks for specific operating systems such as AIX, CygWin,
|
|
||||||
# Darwin, MinGW, and NonStop.
|
|
||||||
#
|
|
||||||
# (3) This script is generated from the Groovy template
|
|
||||||
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
|
||||||
# within the Gradle project.
|
|
||||||
#
|
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
|
||||||
#
|
|
||||||
##############################################################################
|
|
||||||
|
|
||||||
# Attempt to set APP_HOME
|
|
||||||
|
|
||||||
# Resolve links: $0 may be a link
|
|
||||||
app_path=$0
|
|
||||||
|
|
||||||
# Need this for daisy-chained symlinks.
|
|
||||||
while
|
|
||||||
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
|
|
||||||
[ -h "$app_path" ]
|
|
||||||
do
|
|
||||||
ls=$( ls -ld "$app_path" )
|
|
||||||
link=${ls#*' -> '}
|
|
||||||
case $link in #(
|
|
||||||
/*) app_path=$link ;; #(
|
|
||||||
*) app_path=$APP_HOME$link ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
|
||||||
|
|
||||||
APP_NAME="Gradle"
|
|
||||||
APP_BASE_NAME=${0##*/}
|
|
||||||
|
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
|
||||||
|
|
||||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
|
||||||
MAX_FD=maximum
|
|
||||||
|
|
||||||
warn () {
|
|
||||||
echo "$*"
|
|
||||||
} >&2
|
|
||||||
|
|
||||||
die () {
|
|
||||||
echo
|
|
||||||
echo "$*"
|
|
||||||
echo
|
|
||||||
exit 1
|
|
||||||
} >&2
|
|
||||||
|
|
||||||
# OS specific support (must be 'true' or 'false').
|
|
||||||
cygwin=false
|
|
||||||
msys=false
|
|
||||||
darwin=false
|
|
||||||
nonstop=false
|
|
||||||
case "$( uname )" in #(
|
|
||||||
CYGWIN* ) cygwin=true ;; #(
|
|
||||||
Darwin* ) darwin=true ;; #(
|
|
||||||
MSYS* | MINGW* ) msys=true ;; #(
|
|
||||||
NONSTOP* ) nonstop=true ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
|
||||||
|
|
||||||
|
|
||||||
# Determine the Java command to use to start the JVM.
|
|
||||||
if [ -n "$JAVA_HOME" ] ; then
|
|
||||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
||||||
# IBM's JDK on AIX uses strange locations for the executables
|
|
||||||
JAVACMD=$JAVA_HOME/jre/sh/java
|
|
||||||
else
|
|
||||||
JAVACMD=$JAVA_HOME/bin/java
|
|
||||||
fi
|
|
||||||
if [ ! -x "$JAVACMD" ] ; then
|
|
||||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
|
||||||
|
|
||||||
Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
location of your Java installation."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
JAVACMD=java
|
|
||||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
||||||
|
|
||||||
Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
location of your Java installation."
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Increase the maximum file descriptors if we can.
|
|
||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
|
||||||
case $MAX_FD in #(
|
|
||||||
max*)
|
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
|
||||||
warn "Could not query maximum file descriptor limit"
|
|
||||||
esac
|
|
||||||
case $MAX_FD in #(
|
|
||||||
'' | soft) :;; #(
|
|
||||||
*)
|
|
||||||
ulimit -n "$MAX_FD" ||
|
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Collect all arguments for the java command, stacking in reverse order:
|
|
||||||
# * args from the command line
|
|
||||||
# * the main class name
|
|
||||||
# * -classpath
|
|
||||||
# * -D...appname settings
|
|
||||||
# * --module-path (only if needed)
|
|
||||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
|
|
||||||
|
|
||||||
# For Cygwin or MSYS, switch paths to Windows format before running java
|
|
||||||
if "$cygwin" || "$msys" ; then
|
|
||||||
APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
|
|
||||||
CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
|
|
||||||
|
|
||||||
JAVACMD=$( cygpath --unix "$JAVACMD" )
|
|
||||||
|
|
||||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
|
||||||
for arg do
|
|
||||||
if
|
|
||||||
case $arg in #(
|
|
||||||
-*) false ;; # don't mess with options #(
|
|
||||||
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
|
|
||||||
[ -e "$t" ] ;; #(
|
|
||||||
*) false ;;
|
|
||||||
esac
|
|
||||||
then
|
|
||||||
arg=$( cygpath --path --ignore --mixed "$arg" )
|
|
||||||
fi
|
|
||||||
# Roll the args list around exactly as many times as the number of
|
|
||||||
# args, so each arg winds up back in the position where it started, but
|
|
||||||
# possibly modified.
|
|
||||||
#
|
|
||||||
# NB: a `for` loop captures its iteration list before it begins, so
|
|
||||||
# changing the positional parameters here affects neither the number of
|
|
||||||
# iterations, nor the values presented in `arg`.
|
|
||||||
shift # remove old arg
|
|
||||||
set -- "$@" "$arg" # push replacement arg
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Collect all arguments for the java command;
|
|
||||||
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
|
|
||||||
# shell script including quotes and variable substitutions, so put them in
|
|
||||||
# double quotes to make sure that they get re-expanded; and
|
|
||||||
# * put everything else in single quotes, so that it's not re-expanded.
|
|
||||||
|
|
||||||
set -- \
|
|
||||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \
|
|
||||||
-classpath "$CLASSPATH" \
|
|
||||||
org.gradle.wrapper.GradleWrapperMain \
|
|
||||||
"$@"
|
|
||||||
|
|
||||||
# Use "xargs" to parse quoted args.
|
|
||||||
#
|
|
||||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
|
|
||||||
#
|
|
||||||
# In Bash we could simply go:
|
|
||||||
#
|
|
||||||
# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
|
|
||||||
# set -- "${ARGS[@]}" "$@"
|
|
||||||
#
|
|
||||||
# but POSIX shell has neither arrays nor command substitution, so instead we
|
|
||||||
# post-process each arg (as a line of input to sed) to backslash-escape any
|
|
||||||
# character that might be a shell metacharacter, then use eval to reverse
|
|
||||||
# that process (while maintaining the separation between arguments), and wrap
|
|
||||||
# the whole thing up as a single "set" statement.
|
|
||||||
#
|
|
||||||
# This will of course break if any of these variables contains a newline or
|
|
||||||
# an unmatched quote.
|
|
||||||
#
|
|
||||||
|
|
||||||
eval "set -- $(
|
|
||||||
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
|
|
||||||
xargs -n1 |
|
|
||||||
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
|
|
||||||
tr '\n' ' '
|
|
||||||
)" '"$@"'
|
|
||||||
|
|
||||||
exec "$JAVACMD" "$@"
|
|
||||||
89
wol/android/gradlew.bat
vendored
89
wol/android/gradlew.bat
vendored
@@ -1,89 +0,0 @@
|
|||||||
@rem
|
|
||||||
@rem Copyright 2015 the original author or authors.
|
|
||||||
@rem
|
|
||||||
@rem Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
@rem you may not use this file except in compliance with the License.
|
|
||||||
@rem You may obtain a copy of the License at
|
|
||||||
@rem
|
|
||||||
@rem https://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
@rem
|
|
||||||
@rem Unless required by applicable law or agreed to in writing, software
|
|
||||||
@rem distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
@rem See the License for the specific language governing permissions and
|
|
||||||
@rem limitations under the License.
|
|
||||||
@rem
|
|
||||||
|
|
||||||
@if "%DEBUG%" == "" @echo off
|
|
||||||
@rem ##########################################################################
|
|
||||||
@rem
|
|
||||||
@rem Gradle startup script for Windows
|
|
||||||
@rem
|
|
||||||
@rem ##########################################################################
|
|
||||||
|
|
||||||
@rem Set local scope for the variables with windows NT shell
|
|
||||||
if "%OS%"=="Windows_NT" setlocal
|
|
||||||
|
|
||||||
set DIRNAME=%~dp0
|
|
||||||
if "%DIRNAME%" == "" set DIRNAME=.
|
|
||||||
set APP_BASE_NAME=%~n0
|
|
||||||
set APP_HOME=%DIRNAME%
|
|
||||||
|
|
||||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
|
|
||||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
|
|
||||||
|
|
||||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
||||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
|
|
||||||
|
|
||||||
@rem Find java.exe
|
|
||||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
|
||||||
|
|
||||||
set JAVA_EXE=java.exe
|
|
||||||
%JAVA_EXE% -version >NUL 2>&1
|
|
||||||
if "%ERRORLEVEL%" == "0" goto execute
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
||||||
echo.
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
echo location of your Java installation.
|
|
||||||
|
|
||||||
goto fail
|
|
||||||
|
|
||||||
:findJavaFromJavaHome
|
|
||||||
set JAVA_HOME=%JAVA_HOME:"=%
|
|
||||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
|
||||||
|
|
||||||
if exist "%JAVA_EXE%" goto execute
|
|
||||||
|
|
||||||
echo.
|
|
||||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
|
||||||
echo.
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
echo location of your Java installation.
|
|
||||||
|
|
||||||
goto fail
|
|
||||||
|
|
||||||
:execute
|
|
||||||
@rem Setup the command line
|
|
||||||
|
|
||||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
|
||||||
|
|
||||||
|
|
||||||
@rem Execute Gradle
|
|
||||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
|
|
||||||
|
|
||||||
:end
|
|
||||||
@rem End local scope for the variables with windows NT shell
|
|
||||||
if "%ERRORLEVEL%"=="0" goto mainEnd
|
|
||||||
|
|
||||||
:fail
|
|
||||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
|
||||||
rem the _cmd.exe /c_ return code!
|
|
||||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
|
||||||
exit /b 1
|
|
||||||
|
|
||||||
:mainEnd
|
|
||||||
if "%OS%"=="Windows_NT" endlocal
|
|
||||||
|
|
||||||
:omega
|
|
||||||
21
wol/android/proguard-rules.pro
vendored
21
wol/android/proguard-rules.pro
vendored
@@ -1,21 +0,0 @@
|
|||||||
# Add project specific ProGuard rules here.
|
|
||||||
# You can control the set of applied configuration files using the
|
|
||||||
# proguardFiles setting in build.gradle.
|
|
||||||
#
|
|
||||||
# For more details, see
|
|
||||||
# http://developer.android.com/guide/developing/tools/proguard.html
|
|
||||||
|
|
||||||
# If your project uses WebView with JS, uncomment the following
|
|
||||||
# and specify the fully qualified class name to the JavaScript interface
|
|
||||||
# class:
|
|
||||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
|
||||||
# public *;
|
|
||||||
#}
|
|
||||||
|
|
||||||
# Uncomment this to preserve the line number information for
|
|
||||||
# debugging stack traces.
|
|
||||||
#-keepattributes SourceFile,LineNumberTable
|
|
||||||
|
|
||||||
# If you keep the line number information, uncomment this to
|
|
||||||
# hide the original source file name.
|
|
||||||
#-renamesourcefileattribute SourceFile
|
|
||||||
@@ -1,2 +0,0 @@
|
|||||||
include ':capacitor-android'
|
|
||||||
project(':capacitor-android').projectDir = new File('../node_modules/@capacitor/android/capacitor')
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
package com.getcapacitor.android;
|
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
|
||||||
import androidx.test.platform.app.InstrumentationRegistry;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Instrumented test, which will execute on an Android device.
|
|
||||||
*
|
|
||||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
|
||||||
*/
|
|
||||||
@RunWith(AndroidJUnit4.class)
|
|
||||||
public class ExampleInstrumentedTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void useAppContext() throws Exception {
|
|
||||||
// Context of the app under test.
|
|
||||||
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
|
|
||||||
|
|
||||||
assertEquals("com.getcapacitor.android", appContext.getPackageName());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
package="com.mycompany.plugins.example">
|
|
||||||
</manifest>
|
|
||||||
@@ -1,97 +0,0 @@
|
|||||||
package com.mycompany.plugins.example;
|
|
||||||
import com.getcapacitor.Plugin;
|
|
||||||
import com.getcapacitor.PluginMethod;
|
|
||||||
import com.getcapacitor.annotation.CapacitorPlugin;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.DatagramPacket;
|
|
||||||
import java.net.DatagramSocket;
|
|
||||||
import java.net.InetAddress;
|
|
||||||
import java.net.SocketException;
|
|
||||||
|
|
||||||
// create a wake on lan plugin for ionic capactor (android)
|
|
||||||
@CapacitorPlugin(name = "wol")
|
|
||||||
public class WolPlugin extends Plugin {
|
|
||||||
|
|
||||||
// create a method to send the magic packet
|
|
||||||
|
|
||||||
@PluginMethod
|
|
||||||
public void sendMagicPacket(String macAddress, String ipAddress) throws IOException {
|
|
||||||
// create a new thread to send the magic packet
|
|
||||||
/*new Thread(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
try {
|
|
||||||
// create a new datagram socket
|
|
||||||
DatagramSocket socket = new DatagramSocket();
|
|
||||||
// set the broadcast address
|
|
||||||
socket.setBroadcast(true);
|
|
||||||
// create a new byte array
|
|
||||||
byte[] macBytes = getMacBytes(macAddress);
|
|
||||||
|
|
||||||
private byte[] getIpBytes byte[] ipBytes = getIpBytes(ipAdress);
|
|
||||||
// create a new byte array
|
|
||||||
byte[] bytes = new byte[6 + 16 * macBytes.length];
|
|
||||||
// loop through the byte array
|
|
||||||
for (int i = 0; i < 6; i++) {
|
|
||||||
// set the byte array to ff
|
|
||||||
bytes[i] = (byte) 0xff;
|
|
||||||
}
|
|
||||||
// loop through the byte array
|
|
||||||
for (int i = 6; i < bytes.length; i += macBytes.length) {
|
|
||||||
// copy the mac bytes to the byte array
|
|
||||||
System.arraycopy(macBytes, 0, bytes, i, macBytes.length);
|
|
||||||
}
|
|
||||||
// create a new datagram packet
|
|
||||||
DatagramPacket packet = new DatagramPacket(bytes, bytes.length, InetAddress.getByAddress(ipBytes), 9);
|
|
||||||
*/
|
|
||||||
// create a byte array to hold the mac address
|
|
||||||
byte[] macBytes = getMacBytes(macAddress);
|
|
||||||
// create a byte array to hold the ip address
|
|
||||||
byte[] ipBytes = getIpBytes(ipAddress);
|
|
||||||
// create a byte array to hold the magic packet
|
|
||||||
byte[] packet = new byte[102];
|
|
||||||
// fill the packet with 0xFF
|
|
||||||
for (int i = 0; i < 6; i++) {
|
|
||||||
packet[i] = (byte) 0xff;
|
|
||||||
}
|
|
||||||
// fill the packet with the mac address
|
|
||||||
for (int i = 6; i < 102; i += 6) {
|
|
||||||
System.arraycopy(macBytes, 0, packet, i, macBytes.length);
|
|
||||||
}
|
|
||||||
// create a datagram packet
|
|
||||||
DatagramPacket datagramPacket = new DatagramPacket(packet, packet.length, InetAddress.getByAddress(ipBytes), 9);
|
|
||||||
// create a datagram socket
|
|
||||||
DatagramSocket datagramSocket = new DatagramSocket();
|
|
||||||
// send the packet
|
|
||||||
datagramSocket.send(datagramPacket);
|
|
||||||
// close the socket
|
|
||||||
datagramSocket.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
private byte[] getMacBytes (String macAddress){
|
|
||||||
// create a byte array to hold the mac address
|
|
||||||
byte[] bytes = new byte[6];
|
|
||||||
// split the mac address into 6 parts
|
|
||||||
String[] hex = macAddress.split("(\\:|\\-)");
|
|
||||||
// convert each part into a byte
|
|
||||||
for (int i = 0; i < 6; i++) {
|
|
||||||
bytes[i] = (byte) Integer.parseInt(hex[i], 16);
|
|
||||||
}
|
|
||||||
// return the byte array
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
private byte[] getIpBytes (String ipAddress){
|
|
||||||
// create a byte array to hold the ip address
|
|
||||||
byte[] bytes = new byte[4];
|
|
||||||
// split the ip address into 4 parts
|
|
||||||
String[] hex = ipAddress.split("\\.");
|
|
||||||
// convert each part into a byte
|
|
||||||
for (int i = 0; i < 4; i++) {
|
|
||||||
bytes[i] = (byte) Integer.parseInt(hex[i]);
|
|
||||||
}
|
|
||||||
// return the byte array
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
package com.mycompany.plugins.example;
|
|
||||||
|
|
||||||
import com.getcapacitor.JSObject;
|
|
||||||
import com.getcapacitor.Plugin;
|
|
||||||
import com.getcapacitor.PluginCall;
|
|
||||||
import com.getcapacitor.PluginMethod;
|
|
||||||
import com.getcapacitor.annotation.CapacitorPlugin;
|
|
||||||
|
|
||||||
@CapacitorPlugin(name = "wol")
|
|
||||||
public class wolPlugin extends Plugin {
|
|
||||||
|
|
||||||
private wol implementation = new wol();
|
|
||||||
|
|
||||||
@PluginMethod
|
|
||||||
public void echo(PluginCall call) {
|
|
||||||
String value = call.getString("value");
|
|
||||||
|
|
||||||
JSObject ret = new JSObject();
|
|
||||||
ret.put("value", implementation.echo(value));
|
|
||||||
call.resolve(ret);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
package com.getcapacitor;
|
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Example local unit test, which will execute on the development machine (host).
|
|
||||||
*
|
|
||||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
|
||||||
*/
|
|
||||||
public class ExampleUnitTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void addition_isCorrect() throws Exception {
|
|
||||||
assertEquals(4, 2 + 2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
7
wol/example/.gitignore
vendored
7
wol/example/.gitignore
vendored
@@ -1,7 +0,0 @@
|
|||||||
.idea/
|
|
||||||
node_modules/
|
|
||||||
.vscode/
|
|
||||||
*.map
|
|
||||||
.DS_Store
|
|
||||||
.sourcemaps
|
|
||||||
dist/
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
## Created with Capacitor Create App
|
|
||||||
|
|
||||||
This app was created using [`@capacitor/create-app`](https://github.com/ionic-team/create-capacitor-app),
|
|
||||||
and comes with a very minimal shell for building an app.
|
|
||||||
|
|
||||||
### Running this example
|
|
||||||
|
|
||||||
To run the provided example, you can use `npm start` command.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
npm start
|
|
||||||
```
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
{
|
|
||||||
"appId": "com.example.plugin",
|
|
||||||
"appName": "example",
|
|
||||||
"bundledWebRuntime": false,
|
|
||||||
"webDir": "dist",
|
|
||||||
"plugins": {
|
|
||||||
"SplashScreen": {
|
|
||||||
"launchShowDuration": 0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "capacitor-app",
|
|
||||||
"version": "1.0.0",
|
|
||||||
"description": "An Amazing Capacitor App",
|
|
||||||
"main": "index.js",
|
|
||||||
"keywords": [
|
|
||||||
"capacitor",
|
|
||||||
"mobile"
|
|
||||||
],
|
|
||||||
"scripts": {
|
|
||||||
"start": "vite",
|
|
||||||
"build": "vite build",
|
|
||||||
"preview": "vite preview"
|
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
"@capacitor/core": "latest",
|
|
||||||
"@capacitor/camera": "latest",
|
|
||||||
"@capacitor/splash-screen": "latest",
|
|
||||||
"wol": "file:..",
|
|
||||||
"@capacitor/ios": "^4.0.0",
|
|
||||||
"@capacitor/android": "^4.0.0"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@capacitor/cli": "latest",
|
|
||||||
"vite": "^2.9.13"
|
|
||||||
},
|
|
||||||
"author": "",
|
|
||||||
"license": "ISC"
|
|
||||||
}
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 99 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 12 KiB |
@@ -1,5 +0,0 @@
|
|||||||
html,
|
|
||||||
body {
|
|
||||||
padding: 0;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
@@ -1,32 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en" dir="ltr">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<title>Awesome Capacitor App</title>
|
|
||||||
<meta
|
|
||||||
name="viewport"
|
|
||||||
content="viewport-fit=cover, width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"
|
|
||||||
/>
|
|
||||||
<meta name="format-detection" content="telephone=no" />
|
|
||||||
<meta name="msapplication-tap-highlight" content="no" />
|
|
||||||
|
|
||||||
<script
|
|
||||||
type="module"
|
|
||||||
src="https://unpkg.com/@ionic/pwa-elements@latest/dist/ionicpwaelements/ionicpwaelements.esm.js"
|
|
||||||
></script>
|
|
||||||
<script
|
|
||||||
nomodule
|
|
||||||
src="https://unpkg.com/@ionic/pwa-elements@latest/dist/ionicpwaelements/ionicpwaelements.js"
|
|
||||||
></script>
|
|
||||||
|
|
||||||
<link rel="icon" type="image/x-icon" href="./assets/icon/favicon.ico" />
|
|
||||||
<link rel="manifest" href="./manifest.json" />
|
|
||||||
<link rel="stylesheet" href="./css/style.css" />
|
|
||||||
<meta name="theme-color" content="#31d53d" />
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<capacitor-welcome></capacitor-welcome>
|
|
||||||
|
|
||||||
<script src="./js/capacitor-welcome.js" type="module"></script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
@@ -1,142 +0,0 @@
|
|||||||
import { SplashScreen } from '@capacitor/splash-screen';
|
|
||||||
import { Camera } from '@capacitor/camera';
|
|
||||||
|
|
||||||
window.customElements.define(
|
|
||||||
'capacitor-welcome',
|
|
||||||
class extends HTMLElement {
|
|
||||||
constructor() {
|
|
||||||
super();
|
|
||||||
|
|
||||||
SplashScreen.hide();
|
|
||||||
|
|
||||||
const root = this.attachShadow({ mode: 'open' });
|
|
||||||
|
|
||||||
root.innerHTML = `
|
|
||||||
<style>
|
|
||||||
:host {
|
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
|
|
||||||
display: block;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
h1, h2, h3, h4, h5 {
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
.button {
|
|
||||||
display: inline-block;
|
|
||||||
padding: 10px;
|
|
||||||
background-color: #73B5F6;
|
|
||||||
color: #fff;
|
|
||||||
font-size: 0.9em;
|
|
||||||
border: 0;
|
|
||||||
border-radius: 3px;
|
|
||||||
text-decoration: none;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
main {
|
|
||||||
padding: 15px;
|
|
||||||
}
|
|
||||||
main hr { height: 1px; background-color: #eee; border: 0; }
|
|
||||||
main h1 {
|
|
||||||
font-size: 1.4em;
|
|
||||||
text-transform: uppercase;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
}
|
|
||||||
main h2 {
|
|
||||||
font-size: 1.1em;
|
|
||||||
}
|
|
||||||
main h3 {
|
|
||||||
font-size: 0.9em;
|
|
||||||
}
|
|
||||||
main p {
|
|
||||||
color: #333;
|
|
||||||
}
|
|
||||||
main pre {
|
|
||||||
white-space: pre-line;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<div>
|
|
||||||
<capacitor-welcome-titlebar>
|
|
||||||
<h1>Capacitor</h1>
|
|
||||||
</capacitor-welcome-titlebar>
|
|
||||||
<main>
|
|
||||||
<p>
|
|
||||||
Capacitor makes it easy to build powerful apps for the app stores, mobile web (Progressive Web Apps), and desktop, all
|
|
||||||
with a single code base.
|
|
||||||
</p>
|
|
||||||
<h2>Getting Started</h2>
|
|
||||||
<p>
|
|
||||||
You'll probably need a UI framework to build a full-featured app. Might we recommend
|
|
||||||
<a target="_blank" href="http://ionicframework.com/">Ionic</a>?
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
Visit <a href="https://capacitorjs.com">capacitorjs.com</a> for information
|
|
||||||
on using native features, building plugins, and more.
|
|
||||||
</p>
|
|
||||||
<a href="https://capacitorjs.com" target="_blank" class="button">Read more</a>
|
|
||||||
<h2>Tiny Demo</h2>
|
|
||||||
<p>
|
|
||||||
This demo shows how to call Capacitor plugins. Say cheese!
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<button class="button" id="take-photo">Take Photo</button>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<img id="image" style="max-width: 100%">
|
|
||||||
</p>
|
|
||||||
</main>
|
|
||||||
</div>
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
|
|
||||||
connectedCallback() {
|
|
||||||
const self = this;
|
|
||||||
|
|
||||||
self.shadowRoot.querySelector('#take-photo').addEventListener('click', async function (e) {
|
|
||||||
try {
|
|
||||||
const photo = await Camera.getPhoto({
|
|
||||||
resultType: 'uri',
|
|
||||||
});
|
|
||||||
|
|
||||||
const image = self.shadowRoot.querySelector('#image');
|
|
||||||
if (!image) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
image.src = photo.webPath;
|
|
||||||
} catch (e) {
|
|
||||||
console.warn('User cancelled', e);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
window.customElements.define(
|
|
||||||
'capacitor-welcome-titlebar',
|
|
||||||
class extends HTMLElement {
|
|
||||||
constructor() {
|
|
||||||
super();
|
|
||||||
const root = this.attachShadow({ mode: 'open' });
|
|
||||||
root.innerHTML = `
|
|
||||||
<style>
|
|
||||||
:host {
|
|
||||||
position: relative;
|
|
||||||
display: block;
|
|
||||||
padding: 15px 15px 15px 15px;
|
|
||||||
text-align: center;
|
|
||||||
background-color: #73B5F6;
|
|
||||||
}
|
|
||||||
::slotted(h1) {
|
|
||||||
margin: 0;
|
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
|
|
||||||
font-size: 0.9em;
|
|
||||||
font-weight: 600;
|
|
||||||
color: #fff;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<slot></slot>
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "App",
|
|
||||||
"short_name": "App",
|
|
||||||
"start_url": "index.html",
|
|
||||||
"display": "standalone",
|
|
||||||
"icons": [{
|
|
||||||
"src": "assets/imgs/logo.png",
|
|
||||||
"sizes": "512x512",
|
|
||||||
"type": "image/png"
|
|
||||||
}],
|
|
||||||
"background_color": "#31d53d",
|
|
||||||
"theme_color": "#31d53d"
|
|
||||||
}
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
import { defineConfig } from 'vite';
|
|
||||||
|
|
||||||
export default defineConfig({
|
|
||||||
root: './src',
|
|
||||||
build: {
|
|
||||||
outDir: '../dist',
|
|
||||||
minify: false,
|
|
||||||
emptyOutDir: true,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
@@ -1,571 +0,0 @@
|
|||||||
// !$*UTF8*$!
|
|
||||||
{
|
|
||||||
archiveVersion = 1;
|
|
||||||
classes = {
|
|
||||||
};
|
|
||||||
objectVersion = 48;
|
|
||||||
objects = {
|
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
|
||||||
03FC29A292ACC40490383A1F /* Pods_Plugin.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3B2A61DA5A1F2DD4F959604D /* Pods_Plugin.framework */; };
|
|
||||||
20C0B05DCFC8E3958A738AF2 /* Pods_PluginTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = F6753A823D3815DB436415E3 /* Pods_PluginTests.framework */; };
|
|
||||||
2F98D68224C9AAE500613A4C /* wol.swift in Sources */ = {isa = PBXBuildFile; fileRef = 2F98D68124C9AAE400613A4C /* wol.swift */; };
|
|
||||||
50ADFF92201F53D600D50D53 /* Plugin.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 50ADFF88201F53D600D50D53 /* Plugin.framework */; };
|
|
||||||
50ADFF97201F53D600D50D53 /* wolTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 50ADFF96201F53D600D50D53 /* wolTests.swift */; };
|
|
||||||
50ADFF99201F53D600D50D53 /* wolPlugin.h in Headers */ = {isa = PBXBuildFile; fileRef = 50ADFF8B201F53D600D50D53 /* wolPlugin.h */; settings = {ATTRIBUTES = (Public, ); }; };
|
|
||||||
50ADFFA42020D75100D50D53 /* Capacitor.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 50ADFFA52020D75100D50D53 /* Capacitor.framework */; };
|
|
||||||
50ADFFA82020EE4F00D50D53 /* wolPlugin.m in Sources */ = {isa = PBXBuildFile; fileRef = 50ADFFA72020EE4F00D50D53 /* wolPlugin.m */; };
|
|
||||||
50E1A94820377CB70090CE1A /* wolPlugin.swift in Sources */ = {isa = PBXBuildFile; fileRef = 50E1A94720377CB70090CE1A /* wolPlugin.swift */; };
|
|
||||||
/* End PBXBuildFile section */
|
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
|
||||||
50ADFF93201F53D600D50D53 /* PBXContainerItemProxy */ = {
|
|
||||||
isa = PBXContainerItemProxy;
|
|
||||||
containerPortal = 50ADFF7F201F53D600D50D53 /* Project object */;
|
|
||||||
proxyType = 1;
|
|
||||||
remoteGlobalIDString = 50ADFF87201F53D600D50D53;
|
|
||||||
remoteInfo = Plugin;
|
|
||||||
};
|
|
||||||
/* End PBXContainerItemProxy section */
|
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
|
||||||
2F98D68124C9AAE400613A4C /* wol.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = wol.swift; sourceTree = "<group>"; };
|
|
||||||
3B2A61DA5A1F2DD4F959604D /* Pods_Plugin.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Plugin.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
50ADFF88201F53D600D50D53 /* Plugin.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Plugin.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
50ADFF8B201F53D600D50D53 /* wolPlugin.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = wolPlugin.h; sourceTree = "<group>"; };
|
|
||||||
50ADFF8C201F53D600D50D53 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
|
||||||
50ADFF91201F53D600D50D53 /* PluginTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = PluginTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
50ADFF96201F53D600D50D53 /* wolTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = wolTests.swift; sourceTree = "<group>"; };
|
|
||||||
50ADFF98201F53D600D50D53 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
|
||||||
50ADFFA52020D75100D50D53 /* Capacitor.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; path = Capacitor.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
50ADFFA72020EE4F00D50D53 /* wolPlugin.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = wolPlugin.m; sourceTree = "<group>"; };
|
|
||||||
50E1A94720377CB70090CE1A /* wolPlugin.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = wolPlugin.swift; sourceTree = "<group>"; };
|
|
||||||
5E23F77F099397094342571A /* Pods-Plugin.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Plugin.debug.xcconfig"; path = "Pods/Target Support Files/Pods-Plugin/Pods-Plugin.debug.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
91781294A431A2A7CC6EB714 /* Pods-Plugin.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Plugin.release.xcconfig"; path = "Pods/Target Support Files/Pods-Plugin/Pods-Plugin.release.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
96ED1B6440D6672E406C8D19 /* Pods-PluginTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-PluginTests.debug.xcconfig"; path = "Pods/Target Support Files/Pods-PluginTests/Pods-PluginTests.debug.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
F65BB2953ECE002E1EF3E424 /* Pods-PluginTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-PluginTests.release.xcconfig"; path = "Pods/Target Support Files/Pods-PluginTests/Pods-PluginTests.release.xcconfig"; sourceTree = "<group>"; };
|
|
||||||
F6753A823D3815DB436415E3 /* Pods_PluginTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_PluginTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
||||||
/* End PBXFileReference section */
|
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
|
||||||
50ADFF84201F53D600D50D53 /* Frameworks */ = {
|
|
||||||
isa = PBXFrameworksBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
50ADFFA42020D75100D50D53 /* Capacitor.framework in Frameworks */,
|
|
||||||
03FC29A292ACC40490383A1F /* Pods_Plugin.framework in Frameworks */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
50ADFF8E201F53D600D50D53 /* Frameworks */ = {
|
|
||||||
isa = PBXFrameworksBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
50ADFF92201F53D600D50D53 /* Plugin.framework in Frameworks */,
|
|
||||||
20C0B05DCFC8E3958A738AF2 /* Pods_PluginTests.framework in Frameworks */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXFrameworksBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXGroup section */
|
|
||||||
50ADFF7E201F53D600D50D53 = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
50ADFF8A201F53D600D50D53 /* Plugin */,
|
|
||||||
50ADFF95201F53D600D50D53 /* PluginTests */,
|
|
||||||
50ADFF89201F53D600D50D53 /* Products */,
|
|
||||||
8C8E7744173064A9F6D438E3 /* Pods */,
|
|
||||||
A797B9EFA3DCEFEA1FBB66A9 /* Frameworks */,
|
|
||||||
);
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
50ADFF89201F53D600D50D53 /* Products */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
50ADFF88201F53D600D50D53 /* Plugin.framework */,
|
|
||||||
50ADFF91201F53D600D50D53 /* PluginTests.xctest */,
|
|
||||||
);
|
|
||||||
name = Products;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
50ADFF8A201F53D600D50D53 /* Plugin */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
50E1A94720377CB70090CE1A /* wolPlugin.swift */,
|
|
||||||
2F98D68124C9AAE400613A4C /* wol.swift */,
|
|
||||||
50ADFF8B201F53D600D50D53 /* wolPlugin.h */,
|
|
||||||
50ADFFA72020EE4F00D50D53 /* wolPlugin.m */,
|
|
||||||
50ADFF8C201F53D600D50D53 /* Info.plist */,
|
|
||||||
);
|
|
||||||
path = Plugin;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
50ADFF95201F53D600D50D53 /* PluginTests */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
50ADFF96201F53D600D50D53 /* wolTests.swift */,
|
|
||||||
50ADFF98201F53D600D50D53 /* Info.plist */,
|
|
||||||
);
|
|
||||||
path = PluginTests;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
8C8E7744173064A9F6D438E3 /* Pods */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
5E23F77F099397094342571A /* Pods-Plugin.debug.xcconfig */,
|
|
||||||
91781294A431A2A7CC6EB714 /* Pods-Plugin.release.xcconfig */,
|
|
||||||
96ED1B6440D6672E406C8D19 /* Pods-PluginTests.debug.xcconfig */,
|
|
||||||
F65BB2953ECE002E1EF3E424 /* Pods-PluginTests.release.xcconfig */,
|
|
||||||
);
|
|
||||||
name = Pods;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
A797B9EFA3DCEFEA1FBB66A9 /* Frameworks */ = {
|
|
||||||
isa = PBXGroup;
|
|
||||||
children = (
|
|
||||||
50ADFFA52020D75100D50D53 /* Capacitor.framework */,
|
|
||||||
3B2A61DA5A1F2DD4F959604D /* Pods_Plugin.framework */,
|
|
||||||
F6753A823D3815DB436415E3 /* Pods_PluginTests.framework */,
|
|
||||||
);
|
|
||||||
name = Frameworks;
|
|
||||||
sourceTree = "<group>";
|
|
||||||
};
|
|
||||||
/* End PBXGroup section */
|
|
||||||
|
|
||||||
/* Begin PBXHeadersBuildPhase section */
|
|
||||||
50ADFF85201F53D600D50D53 /* Headers */ = {
|
|
||||||
isa = PBXHeadersBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
50ADFF99201F53D600D50D53 /* wolPlugin.h in Headers */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXHeadersBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
|
||||||
50ADFF87201F53D600D50D53 /* Plugin */ = {
|
|
||||||
isa = PBXNativeTarget;
|
|
||||||
buildConfigurationList = 50ADFF9C201F53D600D50D53 /* Build configuration list for PBXNativeTarget "Plugin" */;
|
|
||||||
buildPhases = (
|
|
||||||
AB5B3E54B4E897F32C2279DA /* [CP] Check Pods Manifest.lock */,
|
|
||||||
50ADFF83201F53D600D50D53 /* Sources */,
|
|
||||||
50ADFF84201F53D600D50D53 /* Frameworks */,
|
|
||||||
50ADFF85201F53D600D50D53 /* Headers */,
|
|
||||||
50ADFF86201F53D600D50D53 /* Resources */,
|
|
||||||
);
|
|
||||||
buildRules = (
|
|
||||||
);
|
|
||||||
dependencies = (
|
|
||||||
);
|
|
||||||
name = Plugin;
|
|
||||||
productName = Plugin;
|
|
||||||
productReference = 50ADFF88201F53D600D50D53 /* Plugin.framework */;
|
|
||||||
productType = "com.apple.product-type.framework";
|
|
||||||
};
|
|
||||||
50ADFF90201F53D600D50D53 /* PluginTests */ = {
|
|
||||||
isa = PBXNativeTarget;
|
|
||||||
buildConfigurationList = 50ADFF9F201F53D600D50D53 /* Build configuration list for PBXNativeTarget "PluginTests" */;
|
|
||||||
buildPhases = (
|
|
||||||
0596884F929ED6F1DE134961 /* [CP] Check Pods Manifest.lock */,
|
|
||||||
50ADFF8D201F53D600D50D53 /* Sources */,
|
|
||||||
50ADFF8E201F53D600D50D53 /* Frameworks */,
|
|
||||||
50ADFF8F201F53D600D50D53 /* Resources */,
|
|
||||||
8E97F58B69A94C6503FC9C85 /* [CP] Embed Pods Frameworks */,
|
|
||||||
);
|
|
||||||
buildRules = (
|
|
||||||
);
|
|
||||||
dependencies = (
|
|
||||||
50ADFF94201F53D600D50D53 /* PBXTargetDependency */,
|
|
||||||
);
|
|
||||||
name = PluginTests;
|
|
||||||
productName = PluginTests;
|
|
||||||
productReference = 50ADFF91201F53D600D50D53 /* PluginTests.xctest */;
|
|
||||||
productType = "com.apple.product-type.bundle.unit-test";
|
|
||||||
};
|
|
||||||
/* End PBXNativeTarget section */
|
|
||||||
|
|
||||||
/* Begin PBXProject section */
|
|
||||||
50ADFF7F201F53D600D50D53 /* Project object */ = {
|
|
||||||
isa = PBXProject;
|
|
||||||
attributes = {
|
|
||||||
LastSwiftUpdateCheck = 0920;
|
|
||||||
LastUpgradeCheck = 1160;
|
|
||||||
ORGANIZATIONNAME = "Max Lynch";
|
|
||||||
TargetAttributes = {
|
|
||||||
50ADFF87201F53D600D50D53 = {
|
|
||||||
CreatedOnToolsVersion = 9.2;
|
|
||||||
LastSwiftMigration = 1100;
|
|
||||||
ProvisioningStyle = Automatic;
|
|
||||||
};
|
|
||||||
50ADFF90201F53D600D50D53 = {
|
|
||||||
CreatedOnToolsVersion = 9.2;
|
|
||||||
LastSwiftMigration = 1100;
|
|
||||||
ProvisioningStyle = Automatic;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
buildConfigurationList = 50ADFF82201F53D600D50D53 /* Build configuration list for PBXProject "Plugin" */;
|
|
||||||
compatibilityVersion = "Xcode 8.0";
|
|
||||||
developmentRegion = en;
|
|
||||||
hasScannedForEncodings = 0;
|
|
||||||
knownRegions = (
|
|
||||||
en,
|
|
||||||
Base,
|
|
||||||
);
|
|
||||||
mainGroup = 50ADFF7E201F53D600D50D53;
|
|
||||||
productRefGroup = 50ADFF89201F53D600D50D53 /* Products */;
|
|
||||||
projectDirPath = "";
|
|
||||||
projectRoot = "";
|
|
||||||
targets = (
|
|
||||||
50ADFF87201F53D600D50D53 /* Plugin */,
|
|
||||||
50ADFF90201F53D600D50D53 /* PluginTests */,
|
|
||||||
);
|
|
||||||
};
|
|
||||||
/* End PBXProject section */
|
|
||||||
|
|
||||||
/* Begin PBXResourcesBuildPhase section */
|
|
||||||
50ADFF86201F53D600D50D53 /* Resources */ = {
|
|
||||||
isa = PBXResourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
50ADFF8F201F53D600D50D53 /* Resources */ = {
|
|
||||||
isa = PBXResourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXResourcesBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXShellScriptBuildPhase section */
|
|
||||||
0596884F929ED6F1DE134961 /* [CP] Check Pods Manifest.lock */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
|
||||||
"${PODS_ROOT}/Manifest.lock",
|
|
||||||
);
|
|
||||||
name = "[CP] Check Pods Manifest.lock";
|
|
||||||
outputPaths = (
|
|
||||||
"$(DERIVED_FILE_DIR)/Pods-PluginTests-checkManifestLockResult.txt",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
8E97F58B69A94C6503FC9C85 /* [CP] Embed Pods Frameworks */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
"${PODS_ROOT}/Target Support Files/Pods-PluginTests/Pods-PluginTests-frameworks.sh",
|
|
||||||
"${BUILT_PRODUCTS_DIR}/Capacitor/Capacitor.framework",
|
|
||||||
"${BUILT_PRODUCTS_DIR}/CapacitorCordova/Cordova.framework",
|
|
||||||
);
|
|
||||||
name = "[CP] Embed Pods Frameworks";
|
|
||||||
outputPaths = (
|
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Capacitor.framework",
|
|
||||||
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Cordova.framework",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-PluginTests/Pods-PluginTests-frameworks.sh\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
AB5B3E54B4E897F32C2279DA /* [CP] Check Pods Manifest.lock */ = {
|
|
||||||
isa = PBXShellScriptBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
);
|
|
||||||
inputPaths = (
|
|
||||||
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
|
||||||
"${PODS_ROOT}/Manifest.lock",
|
|
||||||
);
|
|
||||||
name = "[CP] Check Pods Manifest.lock";
|
|
||||||
outputPaths = (
|
|
||||||
"$(DERIVED_FILE_DIR)/Pods-Plugin-checkManifestLockResult.txt",
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
shellPath = /bin/sh;
|
|
||||||
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
|
||||||
showEnvVarsInLog = 0;
|
|
||||||
};
|
|
||||||
/* End PBXShellScriptBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXSourcesBuildPhase section */
|
|
||||||
50ADFF83201F53D600D50D53 /* Sources */ = {
|
|
||||||
isa = PBXSourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
50E1A94820377CB70090CE1A /* wolPlugin.swift in Sources */,
|
|
||||||
2F98D68224C9AAE500613A4C /* wol.swift in Sources */,
|
|
||||||
50ADFFA82020EE4F00D50D53 /* wolPlugin.m in Sources */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
50ADFF8D201F53D600D50D53 /* Sources */ = {
|
|
||||||
isa = PBXSourcesBuildPhase;
|
|
||||||
buildActionMask = 2147483647;
|
|
||||||
files = (
|
|
||||||
50ADFF97201F53D600D50D53 /* wolTests.swift in Sources */,
|
|
||||||
);
|
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
|
||||||
};
|
|
||||||
/* End PBXSourcesBuildPhase section */
|
|
||||||
|
|
||||||
/* Begin PBXTargetDependency section */
|
|
||||||
50ADFF94201F53D600D50D53 /* PBXTargetDependency */ = {
|
|
||||||
isa = PBXTargetDependency;
|
|
||||||
target = 50ADFF87201F53D600D50D53 /* Plugin */;
|
|
||||||
targetProxy = 50ADFF93201F53D600D50D53 /* PBXContainerItemProxy */;
|
|
||||||
};
|
|
||||||
/* End PBXTargetDependency section */
|
|
||||||
|
|
||||||
/* Begin XCBuildConfiguration section */
|
|
||||||
50ADFF9A201F53D600D50D53 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
buildSettings = {
|
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
|
||||||
CLANG_ANALYZER_NONNULL = YES;
|
|
||||||
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
|
|
||||||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
|
|
||||||
CLANG_CXX_LIBRARY = "libc++";
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CLANG_ENABLE_OBJC_ARC = YES;
|
|
||||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
|
|
||||||
CLANG_WARN_BOOL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_COMMA = YES;
|
|
||||||
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
|
|
||||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
|
||||||
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
|
|
||||||
CLANG_WARN_EMPTY_BODY = YES;
|
|
||||||
CLANG_WARN_ENUM_CONVERSION = YES;
|
|
||||||
CLANG_WARN_INFINITE_RECURSION = YES;
|
|
||||||
CLANG_WARN_INT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
|
||||||
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
|
||||||
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
|
|
||||||
CLANG_WARN_UNREACHABLE_CODE = YES;
|
|
||||||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "iPhone Developer";
|
|
||||||
COPY_PHASE_STRIP = NO;
|
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
|
||||||
DEBUG_INFORMATION_FORMAT = dwarf;
|
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
|
||||||
ENABLE_TESTABILITY = YES;
|
|
||||||
FRAMEWORK_SEARCH_PATHS = (
|
|
||||||
"\"${BUILT_PRODUCTS_DIR}/Capacitor\"",
|
|
||||||
"\"${BUILT_PRODUCTS_DIR}/CapacitorCordova\"",
|
|
||||||
);
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu11;
|
|
||||||
GCC_DYNAMIC_NO_PIC = NO;
|
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
|
||||||
GCC_OPTIMIZATION_LEVEL = 0;
|
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = (
|
|
||||||
"DEBUG=1",
|
|
||||||
"$(inherited)",
|
|
||||||
);
|
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
|
||||||
GCC_WARN_UNDECLARED_SELECTOR = YES;
|
|
||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
|
||||||
MTL_ENABLE_DEBUG_INFO = YES;
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
SDKROOT = iphoneos;
|
|
||||||
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
|
||||||
VERSIONING_SYSTEM = "apple-generic";
|
|
||||||
VERSION_INFO_PREFIX = "";
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
50ADFF9B201F53D600D50D53 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
buildSettings = {
|
|
||||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
|
||||||
CLANG_ANALYZER_NONNULL = YES;
|
|
||||||
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
|
|
||||||
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
|
|
||||||
CLANG_CXX_LIBRARY = "libc++";
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CLANG_ENABLE_OBJC_ARC = YES;
|
|
||||||
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
|
|
||||||
CLANG_WARN_BOOL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_COMMA = YES;
|
|
||||||
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
|
|
||||||
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
|
||||||
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
|
|
||||||
CLANG_WARN_EMPTY_BODY = YES;
|
|
||||||
CLANG_WARN_ENUM_CONVERSION = YES;
|
|
||||||
CLANG_WARN_INFINITE_RECURSION = YES;
|
|
||||||
CLANG_WARN_INT_CONVERSION = YES;
|
|
||||||
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
|
|
||||||
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
|
|
||||||
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
|
||||||
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
|
|
||||||
CLANG_WARN_STRICT_PROTOTYPES = YES;
|
|
||||||
CLANG_WARN_SUSPICIOUS_MOVE = YES;
|
|
||||||
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
|
|
||||||
CLANG_WARN_UNREACHABLE_CODE = YES;
|
|
||||||
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "iPhone Developer";
|
|
||||||
COPY_PHASE_STRIP = NO;
|
|
||||||
CURRENT_PROJECT_VERSION = 1;
|
|
||||||
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
|
||||||
ENABLE_NS_ASSERTIONS = NO;
|
|
||||||
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
|
||||||
FRAMEWORK_SEARCH_PATHS = (
|
|
||||||
"\"${BUILT_PRODUCTS_DIR}/Capacitor\"",
|
|
||||||
"\"${BUILT_PRODUCTS_DIR}/CapacitorCordova\"",
|
|
||||||
);
|
|
||||||
GCC_C_LANGUAGE_STANDARD = gnu11;
|
|
||||||
GCC_NO_COMMON_BLOCKS = YES;
|
|
||||||
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
|
||||||
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
|
||||||
GCC_WARN_UNDECLARED_SELECTOR = YES;
|
|
||||||
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
|
||||||
GCC_WARN_UNUSED_FUNCTION = YES;
|
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
|
||||||
MTL_ENABLE_DEBUG_INFO = NO;
|
|
||||||
SDKROOT = iphoneos;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule";
|
|
||||||
VALIDATE_PRODUCT = YES;
|
|
||||||
VERSIONING_SYSTEM = "apple-generic";
|
|
||||||
VERSION_INFO_PREFIX = "";
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
50ADFF9D201F53D600D50D53 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 5E23F77F099397094342571A /* Pods-Plugin.debug.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "";
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
DEFINES_MODULE = YES;
|
|
||||||
DYLIB_COMPATIBILITY_VERSION = 1;
|
|
||||||
DYLIB_CURRENT_VERSION = 1;
|
|
||||||
DYLIB_INSTALL_NAME_BASE = "@rpath";
|
|
||||||
INFOPLIST_FILE = Plugin/Info.plist;
|
|
||||||
INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
|
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks $(FRAMEWORK_SEARCH_PATHS)\n$(FRAMEWORK_SEARCH_PATHS)\n$(FRAMEWORK_SEARCH_PATHS)";
|
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.getcapacitor.Plugin;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)";
|
|
||||||
SKIP_INSTALL = YES;
|
|
||||||
SUPPORTS_MACCATALYST = NO;
|
|
||||||
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
50ADFF9E201F53D600D50D53 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 91781294A431A2A7CC6EB714 /* Pods-Plugin.release.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
CLANG_ENABLE_MODULES = YES;
|
|
||||||
CODE_SIGN_IDENTITY = "";
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
DEFINES_MODULE = YES;
|
|
||||||
DYLIB_COMPATIBILITY_VERSION = 1;
|
|
||||||
DYLIB_CURRENT_VERSION = 1;
|
|
||||||
DYLIB_INSTALL_NAME_BASE = "@rpath";
|
|
||||||
INFOPLIST_FILE = Plugin/Info.plist;
|
|
||||||
INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
|
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 13.0;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks $(FRAMEWORK_SEARCH_PATHS)";
|
|
||||||
ONLY_ACTIVE_ARCH = NO;
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.getcapacitor.Plugin;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)";
|
|
||||||
SKIP_INSTALL = YES;
|
|
||||||
SUPPORTS_MACCATALYST = NO;
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
50ADFFA0201F53D600D50D53 /* Debug */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = 96ED1B6440D6672E406C8D19 /* Pods-PluginTests.debug.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
INFOPLIST_FILE = PluginTests/Info.plist;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.getcapacitor.PluginTests;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
|
||||||
};
|
|
||||||
name = Debug;
|
|
||||||
};
|
|
||||||
50ADFFA1201F53D600D50D53 /* Release */ = {
|
|
||||||
isa = XCBuildConfiguration;
|
|
||||||
baseConfigurationReference = F65BB2953ECE002E1EF3E424 /* Pods-PluginTests.release.xcconfig */;
|
|
||||||
buildSettings = {
|
|
||||||
CODE_SIGN_STYLE = Automatic;
|
|
||||||
INFOPLIST_FILE = PluginTests/Info.plist;
|
|
||||||
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
|
|
||||||
PRODUCT_BUNDLE_IDENTIFIER = com.getcapacitor.PluginTests;
|
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
|
||||||
SWIFT_VERSION = 5.0;
|
|
||||||
TARGETED_DEVICE_FAMILY = "1,2";
|
|
||||||
};
|
|
||||||
name = Release;
|
|
||||||
};
|
|
||||||
/* End XCBuildConfiguration section */
|
|
||||||
|
|
||||||
/* Begin XCConfigurationList section */
|
|
||||||
50ADFF82201F53D600D50D53 /* Build configuration list for PBXProject "Plugin" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
50ADFF9A201F53D600D50D53 /* Debug */,
|
|
||||||
50ADFF9B201F53D600D50D53 /* Release */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
50ADFF9C201F53D600D50D53 /* Build configuration list for PBXNativeTarget "Plugin" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
50ADFF9D201F53D600D50D53 /* Debug */,
|
|
||||||
50ADFF9E201F53D600D50D53 /* Release */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
50ADFF9F201F53D600D50D53 /* Build configuration list for PBXNativeTarget "PluginTests" */ = {
|
|
||||||
isa = XCConfigurationList;
|
|
||||||
buildConfigurations = (
|
|
||||||
50ADFFA0201F53D600D50D53 /* Debug */,
|
|
||||||
50ADFFA1201F53D600D50D53 /* Release */,
|
|
||||||
);
|
|
||||||
defaultConfigurationIsVisible = 0;
|
|
||||||
defaultConfigurationName = Release;
|
|
||||||
};
|
|
||||||
/* End XCConfigurationList section */
|
|
||||||
};
|
|
||||||
rootObject = 50ADFF7F201F53D600D50D53 /* Project object */;
|
|
||||||
}
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Workspace
|
|
||||||
version = "1.0">
|
|
||||||
<FileRef
|
|
||||||
location = "self:">
|
|
||||||
</FileRef>
|
|
||||||
</Workspace>
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>IDEDidComputeMac32BitWarning</key>
|
|
||||||
<true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@@ -1,77 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Scheme
|
|
||||||
LastUpgradeVersion = "1150"
|
|
||||||
version = "1.3">
|
|
||||||
<BuildAction
|
|
||||||
parallelizeBuildables = "YES"
|
|
||||||
buildImplicitDependencies = "YES">
|
|
||||||
<BuildActionEntries>
|
|
||||||
<BuildActionEntry
|
|
||||||
buildForTesting = "YES"
|
|
||||||
buildForRunning = "YES"
|
|
||||||
buildForProfiling = "YES"
|
|
||||||
buildForArchiving = "YES"
|
|
||||||
buildForAnalyzing = "YES">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "50ADFF87201F53D600D50D53"
|
|
||||||
BuildableName = "Plugin.framework"
|
|
||||||
BlueprintName = "Plugin"
|
|
||||||
ReferencedContainer = "container:Plugin.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</BuildActionEntry>
|
|
||||||
</BuildActionEntries>
|
|
||||||
</BuildAction>
|
|
||||||
<TestAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES">
|
|
||||||
<Testables>
|
|
||||||
<TestableReference
|
|
||||||
skipped = "NO">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "50ADFF90201F53D600D50D53"
|
|
||||||
BuildableName = "PluginTests.xctest"
|
|
||||||
BlueprintName = "PluginTests"
|
|
||||||
ReferencedContainer = "container:Plugin.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</TestableReference>
|
|
||||||
</Testables>
|
|
||||||
</TestAction>
|
|
||||||
<LaunchAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
launchStyle = "0"
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
ignoresPersistentStateOnLaunch = "NO"
|
|
||||||
debugDocumentVersioning = "YES"
|
|
||||||
debugServiceExtension = "internal"
|
|
||||||
allowLocationSimulation = "YES">
|
|
||||||
</LaunchAction>
|
|
||||||
<ProfileAction
|
|
||||||
buildConfiguration = "Release"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES"
|
|
||||||
savedToolIdentifier = ""
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
debugDocumentVersioning = "YES">
|
|
||||||
<MacroExpansion>
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "50ADFF87201F53D600D50D53"
|
|
||||||
BuildableName = "Plugin.framework"
|
|
||||||
BlueprintName = "Plugin"
|
|
||||||
ReferencedContainer = "container:Plugin.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</MacroExpansion>
|
|
||||||
</ProfileAction>
|
|
||||||
<AnalyzeAction
|
|
||||||
buildConfiguration = "Debug">
|
|
||||||
</AnalyzeAction>
|
|
||||||
<ArchiveAction
|
|
||||||
buildConfiguration = "Release"
|
|
||||||
revealArchiveInOrganizer = "YES">
|
|
||||||
</ArchiveAction>
|
|
||||||
</Scheme>
|
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<Scheme
|
|
||||||
LastUpgradeVersion = "1150"
|
|
||||||
version = "1.3">
|
|
||||||
<BuildAction
|
|
||||||
parallelizeBuildables = "YES"
|
|
||||||
buildImplicitDependencies = "YES">
|
|
||||||
<BuildActionEntries>
|
|
||||||
<BuildActionEntry
|
|
||||||
buildForTesting = "YES"
|
|
||||||
buildForRunning = "NO"
|
|
||||||
buildForProfiling = "NO"
|
|
||||||
buildForArchiving = "NO"
|
|
||||||
buildForAnalyzing = "NO">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "50ADFF90201F53D600D50D53"
|
|
||||||
BuildableName = "PluginTests.xctest"
|
|
||||||
BlueprintName = "PluginTests"
|
|
||||||
ReferencedContainer = "container:Plugin.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</BuildActionEntry>
|
|
||||||
</BuildActionEntries>
|
|
||||||
</BuildAction>
|
|
||||||
<TestAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES">
|
|
||||||
<Testables>
|
|
||||||
<TestableReference
|
|
||||||
skipped = "NO">
|
|
||||||
<BuildableReference
|
|
||||||
BuildableIdentifier = "primary"
|
|
||||||
BlueprintIdentifier = "50ADFF90201F53D600D50D53"
|
|
||||||
BuildableName = "PluginTests.xctest"
|
|
||||||
BlueprintName = "PluginTests"
|
|
||||||
ReferencedContainer = "container:Plugin.xcodeproj">
|
|
||||||
</BuildableReference>
|
|
||||||
</TestableReference>
|
|
||||||
</Testables>
|
|
||||||
</TestAction>
|
|
||||||
<LaunchAction
|
|
||||||
buildConfiguration = "Debug"
|
|
||||||
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
|
|
||||||
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
|
|
||||||
launchStyle = "0"
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
ignoresPersistentStateOnLaunch = "NO"
|
|
||||||
debugDocumentVersioning = "YES"
|
|
||||||
debugServiceExtension = "internal"
|
|
||||||
allowLocationSimulation = "YES">
|
|
||||||
</LaunchAction>
|
|
||||||
<ProfileAction
|
|
||||||
buildConfiguration = "Release"
|
|
||||||
shouldUseLaunchSchemeArgsEnv = "YES"
|
|
||||||
savedToolIdentifier = ""
|
|
||||||
useCustomWorkingDirectory = "NO"
|
|
||||||
debugDocumentVersioning = "YES">
|
|
||||||
</ProfileAction>
|
|
||||||
<AnalyzeAction
|
|
||||||
buildConfiguration = "Debug">
|
|
||||||
</AnalyzeAction>
|
|
||||||
<ArchiveAction
|
|
||||||
buildConfiguration = "Release"
|
|
||||||
revealArchiveInOrganizer = "YES">
|
|
||||||
</ArchiveAction>
|
|
||||||
</Scheme>
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>IDEDidComputeMac32BitWarning</key>
|
|
||||||
<true/>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>CFBundleDevelopmentRegion</key>
|
|
||||||
<string>$(DEVELOPMENT_LANGUAGE)</string>
|
|
||||||
<key>CFBundleExecutable</key>
|
|
||||||
<string>$(EXECUTABLE_NAME)</string>
|
|
||||||
<key>CFBundleIdentifier</key>
|
|
||||||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
|
|
||||||
<key>CFBundleInfoDictionaryVersion</key>
|
|
||||||
<string>6.0</string>
|
|
||||||
<key>CFBundleName</key>
|
|
||||||
<string>$(PRODUCT_NAME)</string>
|
|
||||||
<key>CFBundlePackageType</key>
|
|
||||||
<string>FMWK</string>
|
|
||||||
<key>CFBundleShortVersionString</key>
|
|
||||||
<string>1.0</string>
|
|
||||||
<key>CFBundleVersion</key>
|
|
||||||
<string>$(CURRENT_PROJECT_VERSION)</string>
|
|
||||||
<key>NSPrincipalClass</key>
|
|
||||||
<string></string>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
import Foundation
|
|
||||||
|
|
||||||
@objc public class wol: NSObject {
|
|
||||||
@objc public func echo(_ value: String) -> String {
|
|
||||||
print(value)
|
|
||||||
return value
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
#import <UIKit/UIKit.h>
|
|
||||||
|
|
||||||
//! Project version number for Plugin.
|
|
||||||
FOUNDATION_EXPORT double PluginVersionNumber;
|
|
||||||
|
|
||||||
//! Project version string for Plugin.
|
|
||||||
FOUNDATION_EXPORT const unsigned char PluginVersionString[];
|
|
||||||
|
|
||||||
// In this header, you should import all the public headers of your framework using statements like #import <Plugin/PublicHeader.h>
|
|
||||||
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
#import <Foundation/Foundation.h>
|
|
||||||
#import <Capacitor/Capacitor.h>
|
|
||||||
|
|
||||||
// Define the plugin using the CAP_PLUGIN Macro, and
|
|
||||||
// each method the plugin supports using the CAP_PLUGIN_METHOD macro.
|
|
||||||
CAP_PLUGIN(wolPlugin, "wol",
|
|
||||||
CAP_PLUGIN_METHOD(echo, CAPPluginReturnPromise);
|
|
||||||
)
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
import Foundation
|
|
||||||
import Capacitor
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Please read the Capacitor iOS Plugin Development Guide
|
|
||||||
* here: https://capacitorjs.com/docs/plugins/ios
|
|
||||||
*/
|
|
||||||
@objc(wolPlugin)
|
|
||||||
public class wolPlugin: CAPPlugin {
|
|
||||||
private let implementation = wol()
|
|
||||||
|
|
||||||
@objc func echo(_ call: CAPPluginCall) {
|
|
||||||
let value = call.getString("value") ?? ""
|
|
||||||
call.resolve([
|
|
||||||
"value": implementation.echo(value)
|
|
||||||
])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
||||||
<plist version="1.0">
|
|
||||||
<dict>
|
|
||||||
<key>CFBundleDevelopmentRegion</key>
|
|
||||||
<string>$(DEVELOPMENT_LANGUAGE)</string>
|
|
||||||
<key>CFBundleExecutable</key>
|
|
||||||
<string>$(EXECUTABLE_NAME)</string>
|
|
||||||
<key>CFBundleIdentifier</key>
|
|
||||||
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
|
|
||||||
<key>CFBundleInfoDictionaryVersion</key>
|
|
||||||
<string>6.0</string>
|
|
||||||
<key>CFBundleName</key>
|
|
||||||
<string>$(PRODUCT_NAME)</string>
|
|
||||||
<key>CFBundlePackageType</key>
|
|
||||||
<string>BNDL</string>
|
|
||||||
<key>CFBundleShortVersionString</key>
|
|
||||||
<string>1.0</string>
|
|
||||||
<key>CFBundleVersion</key>
|
|
||||||
<string>1</string>
|
|
||||||
</dict>
|
|
||||||
</plist>
|
|
||||||
@@ -1,25 +0,0 @@
|
|||||||
import XCTest
|
|
||||||
@testable import Plugin
|
|
||||||
|
|
||||||
class wolTests: XCTestCase {
|
|
||||||
override func setUp() {
|
|
||||||
super.setUp()
|
|
||||||
// Put setup code here. This method is called before the invocation of each test method in the class.
|
|
||||||
}
|
|
||||||
|
|
||||||
override func tearDown() {
|
|
||||||
// Put teardown code here. This method is called after the invocation of each test method in the class.
|
|
||||||
super.tearDown()
|
|
||||||
}
|
|
||||||
|
|
||||||
func testEcho() {
|
|
||||||
// This is an example of a functional test case for a plugin.
|
|
||||||
// Use XCTAssert and related functions to verify your tests produce the correct results.
|
|
||||||
|
|
||||||
let implementation = wol()
|
|
||||||
let value = "Hello, World!"
|
|
||||||
let result = implementation.echo(value)
|
|
||||||
|
|
||||||
XCTAssertEqual(value, result)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
platform :ios, '13.0'
|
|
||||||
|
|
||||||
def capacitor_pods
|
|
||||||
# Comment the next line if you're not using Swift and don't want to use dynamic frameworks
|
|
||||||
use_frameworks!
|
|
||||||
pod 'Capacitor', :path => '../node_modules/@capacitor/ios'
|
|
||||||
pod 'CapacitorCordova', :path => '../node_modules/@capacitor/ios'
|
|
||||||
end
|
|
||||||
|
|
||||||
target 'Plugin' do
|
|
||||||
capacitor_pods
|
|
||||||
end
|
|
||||||
|
|
||||||
target 'PluginTests' do
|
|
||||||
capacitor_pods
|
|
||||||
end
|
|
||||||
@@ -1,78 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "wol",
|
|
||||||
"version": "0.0.1",
|
|
||||||
"description": "Wake on up lan",
|
|
||||||
"main": "dist/plugin.cjs.js",
|
|
||||||
"module": "dist/esm/index.js",
|
|
||||||
"types": "dist/esm/index.d.ts",
|
|
||||||
"unpkg": "dist/plugin.js",
|
|
||||||
"files": [
|
|
||||||
"android/src/main/",
|
|
||||||
"android/build.gradle",
|
|
||||||
"dist/",
|
|
||||||
"ios/Plugin/",
|
|
||||||
"Wol.podspec"
|
|
||||||
],
|
|
||||||
"author": "me",
|
|
||||||
"license": "Apache-2.0",
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "git+https://github.com/myxelium/go-to-bed.git"
|
|
||||||
},
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/myxelium/go-to-bed/issues"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"capacitor",
|
|
||||||
"plugin",
|
|
||||||
"native"
|
|
||||||
],
|
|
||||||
"scripts": {
|
|
||||||
"verify": "npm run verify:ios && npm run verify:android && npm run verify:web",
|
|
||||||
"verify:ios": "cd ios && pod install && xcodebuild -workspace Plugin.xcworkspace -scheme Plugin -destination generic/platform=iOS && cd ..",
|
|
||||||
"verify:android": "cd android && ./gradlew clean build test && cd ..",
|
|
||||||
"verify:web": "npm run build",
|
|
||||||
"lint": "npm run eslint && npm run prettier -- --check && npm run swiftlint -- lint",
|
|
||||||
"fmt": "npm run eslint -- --fix && npm run prettier -- --write && npm run swiftlint -- --fix --format",
|
|
||||||
"eslint": "eslint . --ext ts",
|
|
||||||
"prettier": "prettier \"**/*.{css,html,ts,js,java}\"",
|
|
||||||
"swiftlint": "node-swiftlint",
|
|
||||||
"docgen": "docgen --api wolPlugin --output-readme README.md --output-json dist/docs.json",
|
|
||||||
"build": "npm run clean && npm run docgen && tsc && rollup -c rollup.config.js",
|
|
||||||
"clean": "rimraf ./dist",
|
|
||||||
"watch": "tsc --watch",
|
|
||||||
"prepublishOnly": "npm run build"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@capacitor/android": "^4.0.0",
|
|
||||||
"@capacitor/core": "^4.0.0",
|
|
||||||
"@capacitor/docgen": "^0.0.18",
|
|
||||||
"@capacitor/ios": "^4.0.0",
|
|
||||||
"@ionic/eslint-config": "^0.3.0",
|
|
||||||
"@ionic/prettier-config": "^1.0.1",
|
|
||||||
"@ionic/swiftlint-config": "^1.1.2",
|
|
||||||
"eslint": "^7.11.0",
|
|
||||||
"prettier": "~2.3.0",
|
|
||||||
"prettier-plugin-java": "~1.0.2",
|
|
||||||
"rimraf": "^3.0.2",
|
|
||||||
"rollup": "^2.32.0",
|
|
||||||
"swiftlint": "^1.0.1",
|
|
||||||
"typescript": "~4.1.5"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"@capacitor/core": "^4.0.0"
|
|
||||||
},
|
|
||||||
"prettier": "@ionic/prettier-config",
|
|
||||||
"swiftlint": "@ionic/swiftlint-config",
|
|
||||||
"eslintConfig": {
|
|
||||||
"extends": "@ionic/eslint-config/recommended"
|
|
||||||
},
|
|
||||||
"capacitor": {
|
|
||||||
"ios": {
|
|
||||||
"src": "ios"
|
|
||||||
},
|
|
||||||
"android": {
|
|
||||||
"src": "android"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,22 +0,0 @@
|
|||||||
export default {
|
|
||||||
input: 'dist/esm/index.js',
|
|
||||||
output: [
|
|
||||||
{
|
|
||||||
file: 'dist/plugin.js',
|
|
||||||
format: 'iife',
|
|
||||||
name: 'capacitorwol',
|
|
||||||
globals: {
|
|
||||||
'@capacitor/core': 'capacitorExports',
|
|
||||||
},
|
|
||||||
sourcemap: true,
|
|
||||||
inlineDynamicImports: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/plugin.cjs.js',
|
|
||||||
format: 'cjs',
|
|
||||||
sourcemap: true,
|
|
||||||
inlineDynamicImports: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
external: ['@capacitor/core'],
|
|
||||||
};
|
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
export interface wolPlugin {
|
|
||||||
echo(options: { value: string }): Promise<{ value: string }>;
|
|
||||||
}
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
import { registerPlugin } from '@capacitor/core';
|
|
||||||
|
|
||||||
import type { wolPlugin } from './definitions';
|
|
||||||
|
|
||||||
const wol = registerPlugin<wolPlugin>('wol', {
|
|
||||||
web: () => import('./web').then(m => new m.wolWeb()),
|
|
||||||
});
|
|
||||||
|
|
||||||
export * from './definitions';
|
|
||||||
export { wol };
|
|
||||||
@@ -1,10 +0,0 @@
|
|||||||
import { WebPlugin } from '@capacitor/core';
|
|
||||||
|
|
||||||
import type { wolPlugin } from './definitions';
|
|
||||||
|
|
||||||
export class wolWeb extends WebPlugin implements wolPlugin {
|
|
||||||
async echo(options: { value: string }): Promise<{ value: string }> {
|
|
||||||
console.log('ECHO', options);
|
|
||||||
return options;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
{
|
|
||||||
"compilerOptions": {
|
|
||||||
"allowUnreachableCode": false,
|
|
||||||
"declaration": true,
|
|
||||||
"esModuleInterop": true,
|
|
||||||
"inlineSources": true,
|
|
||||||
"lib": ["dom", "es2017"],
|
|
||||||
"module": "esnext",
|
|
||||||
"moduleResolution": "node",
|
|
||||||
"noFallthroughCasesInSwitch": true,
|
|
||||||
"noUnusedLocals": true,
|
|
||||||
"noUnusedParameters": true,
|
|
||||||
"outDir": "dist/esm",
|
|
||||||
"pretty": true,
|
|
||||||
"sourceMap": true,
|
|
||||||
"strict": true,
|
|
||||||
"target": "es2017"
|
|
||||||
},
|
|
||||||
"files": ["src/index.ts"]
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user