[wip]
This commit is contained in:
parent
6cf8f4c8ca
commit
81875e455e
41 changed files with 4750 additions and 93 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -3,3 +3,4 @@ vendor/*
|
||||||
storage/*
|
storage/*
|
||||||
logs/*
|
logs/*
|
||||||
.idea
|
.idea
|
||||||
|
.vagrant
|
||||||
|
|
23
Vagrantfile
vendored
Normal file
23
Vagrantfile
vendored
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
# -*- mode: ruby -*-
|
||||||
|
# vi: set ft=ruby :
|
||||||
|
|
||||||
|
Vagrant.configure(2) do |config|
|
||||||
|
config.vm.define "web" do |web|
|
||||||
|
web.vm.box = "ubuntu/wily64"
|
||||||
|
web.vm.network "private_network", ip: "192.168.50.4"
|
||||||
|
web.vm.provision :shell, inline: <<installphp
|
||||||
|
add-apt-repository -y ppa:ondrej/php >/dev/null
|
||||||
|
apt-get -qq update 2>/dev/null
|
||||||
|
apt-get -qq install php7.0-cli php7.0-sqlite3 2>/dev/null >/dev/null;
|
||||||
|
start-stop-daemon -bS --quiet --make-pidfile --pidfile /var/run/zerooo.pid --startas /bin/bash -- -c "exec php -S 0:8888 -t /vagrant/public/ /vagrant/public/index.php > /var/log/zerooo.log 2>&1";
|
||||||
|
installphp
|
||||||
|
web.vm.network "forwarded_port", guest: 8888, host: 8888
|
||||||
|
end
|
||||||
|
|
||||||
|
config.vm.define "vpn" do |vpn|
|
||||||
|
vpn.vm.box = "ubuntu/wily64"
|
||||||
|
vpn.vm.network "private_network", ip: "192.168.50.8"
|
||||||
|
vpn.vm.synced_folder "../zer.ooo-server", "/server"
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
2
bin/get-fingerprint
Executable file
2
bin/get-fingerprint
Executable file
|
@ -0,0 +1,2 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
openssl rsa -in $1 -pubin -pubout -outform DER 2>/dev/null | openssl md5 -c | awk '{print $2}'
|
|
@ -1,3 +1,4 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
DIR=$(dirname $(realpath $0));
|
DIR=$(dirname $(realpath $0));
|
||||||
|
cd $DIR/..;
|
||||||
openssl ca -config "$DIR/../etc/openssl.conf" -revoke "$1";
|
openssl ca -config "$DIR/../etc/openssl.conf" -revoke "$1";
|
||||||
|
|
|
@ -3,4 +3,4 @@ DIR=$(dirname $(realpath $0));
|
||||||
CSR=$(realpath $1);
|
CSR=$(realpath $1);
|
||||||
CRT=$(realpath $2);
|
CRT=$(realpath $2);
|
||||||
cd $DIR/../;
|
cd $DIR/../;
|
||||||
openssl ca -in $CSR -out $CRT -config $DIR/../etc/openssl.conf -md sha256 -days 3650 -extensions server_ext;
|
openssl ca -in $CSR -out $CRT -config $DIR/../etc/openssl.conf -md sha256 -days 3650 -extensions server_ext -batch -notext;
|
|
@ -16,7 +16,8 @@
|
||||||
"twig/twig": "v1.24.0",
|
"twig/twig": "v1.24.0",
|
||||||
"hassankhan/config": "0.10.0",
|
"hassankhan/config": "0.10.0",
|
||||||
"monolog/monolog": "1.18.1",
|
"monolog/monolog": "1.18.1",
|
||||||
"aura/session": "2.0.1"
|
"aura/session": "2.0.1",
|
||||||
|
"guzzlehttp/guzzle": "^6.2"
|
||||||
},
|
},
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
|
|
175
composer.lock
generated
175
composer.lock
generated
|
@ -4,8 +4,8 @@
|
||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"hash": "90f9c8a046e4ae9bac938f1d6005bbce",
|
"hash": "95b6dc2302dd6086dbc2b7248a1f5768",
|
||||||
"content-hash": "950c616fbb471647626c3d42e91c7d20",
|
"content-hash": "61847eefe53610226629206b81b6f8b5",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "aura/session",
|
"name": "aura/session",
|
||||||
|
@ -98,6 +98,177 @@
|
||||||
"description": "Promoting the interoperability of container objects (DIC, SL, etc.)",
|
"description": "Promoting the interoperability of container objects (DIC, SL, etc.)",
|
||||||
"time": "2014-12-30 15:22:37"
|
"time": "2014-12-30 15:22:37"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "guzzlehttp/guzzle",
|
||||||
|
"version": "6.2.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/guzzle/guzzle.git",
|
||||||
|
"reference": "d094e337976dff9d8e2424e8485872194e768662"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/guzzle/guzzle/zipball/d094e337976dff9d8e2424e8485872194e768662",
|
||||||
|
"reference": "d094e337976dff9d8e2424e8485872194e768662",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"guzzlehttp/promises": "~1.0",
|
||||||
|
"guzzlehttp/psr7": "~1.1",
|
||||||
|
"php": ">=5.5.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"ext-curl": "*",
|
||||||
|
"phpunit/phpunit": "~4.0",
|
||||||
|
"psr/log": "~1.0"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "6.2-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"files": [
|
||||||
|
"src/functions_include.php"
|
||||||
|
],
|
||||||
|
"psr-4": {
|
||||||
|
"GuzzleHttp\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Michael Dowling",
|
||||||
|
"email": "mtdowling@gmail.com",
|
||||||
|
"homepage": "https://github.com/mtdowling"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Guzzle is a PHP HTTP client library",
|
||||||
|
"homepage": "http://guzzlephp.org/",
|
||||||
|
"keywords": [
|
||||||
|
"client",
|
||||||
|
"curl",
|
||||||
|
"framework",
|
||||||
|
"http",
|
||||||
|
"http client",
|
||||||
|
"rest",
|
||||||
|
"web service"
|
||||||
|
],
|
||||||
|
"time": "2016-03-21 20:02:09"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "guzzlehttp/promises",
|
||||||
|
"version": "1.2.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/guzzle/promises.git",
|
||||||
|
"reference": "c10d860e2a9595f8883527fa0021c7da9e65f579"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/guzzle/promises/zipball/c10d860e2a9595f8883527fa0021c7da9e65f579",
|
||||||
|
"reference": "c10d860e2a9595f8883527fa0021c7da9e65f579",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.5.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "~4.0"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.0-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"GuzzleHttp\\Promise\\": "src/"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"src/functions_include.php"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Michael Dowling",
|
||||||
|
"email": "mtdowling@gmail.com",
|
||||||
|
"homepage": "https://github.com/mtdowling"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Guzzle promises library",
|
||||||
|
"keywords": [
|
||||||
|
"promise"
|
||||||
|
],
|
||||||
|
"time": "2016-05-18 16:56:05"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "guzzlehttp/psr7",
|
||||||
|
"version": "1.3.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/guzzle/psr7.git",
|
||||||
|
"reference": "31382fef2889136415751badebbd1cb022a4ed72"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/guzzle/psr7/zipball/31382fef2889136415751badebbd1cb022a4ed72",
|
||||||
|
"reference": "31382fef2889136415751badebbd1cb022a4ed72",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.4.0",
|
||||||
|
"psr/http-message": "~1.0"
|
||||||
|
},
|
||||||
|
"provide": {
|
||||||
|
"psr/http-message-implementation": "1.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "~4.0"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-master": "1.0-dev"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"GuzzleHttp\\Psr7\\": "src/"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"src/functions_include.php"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Michael Dowling",
|
||||||
|
"email": "mtdowling@gmail.com",
|
||||||
|
"homepage": "https://github.com/mtdowling"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "PSR-7 message implementation",
|
||||||
|
"keywords": [
|
||||||
|
"http",
|
||||||
|
"message",
|
||||||
|
"stream",
|
||||||
|
"uri"
|
||||||
|
],
|
||||||
|
"time": "2016-04-13 19:56:01"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "hassankhan/config",
|
"name": "hassankhan/config",
|
||||||
"version": "0.10.0",
|
"version": "0.10.0",
|
||||||
|
|
|
@ -13,3 +13,4 @@ core:
|
||||||
twig: Eater\Glim\Service\Twig
|
twig: Eater\Glim\Service\Twig
|
||||||
twig-vars: Eater\Glim\Service\TwigVars
|
twig-vars: Eater\Glim\Service\TwigVars
|
||||||
ca: Eater\Glim\Service\CA
|
ca: Eater\Glim\Service\CA
|
||||||
|
server: Eater\Glim\Service\Server
|
|
@ -8,6 +8,7 @@ routes:
|
||||||
get: Register\Show
|
get: Register\Show
|
||||||
post: Register\Action
|
post: Register\Action
|
||||||
/logout: Logout
|
/logout: Logout
|
||||||
|
/ca: CA
|
||||||
/panel:
|
/panel:
|
||||||
get: Panel
|
get: Panel
|
||||||
/certificates:
|
/certificates:
|
||||||
|
@ -15,3 +16,14 @@ routes:
|
||||||
get: Panel\Certificates\_New\Show
|
get: Panel\Certificates\_New\Show
|
||||||
post: Panel\Certificates\_New\Action
|
post: Panel\Certificates\_New\Action
|
||||||
/download/{name}: Panel\Certificates\Download
|
/download/{name}: Panel\Certificates\Download
|
||||||
|
/revoke:
|
||||||
|
post: Panel\Certificates\Revoke
|
||||||
|
/server:
|
||||||
|
/sign:
|
||||||
|
post: Panel\Servers\Sign
|
||||||
|
/{fingerprint}:
|
||||||
|
get: Panel\Servers\Edit\Show
|
||||||
|
post: Panel\Servers\Edit\Action
|
||||||
|
/server:
|
||||||
|
/register:
|
||||||
|
post: Server\Register
|
|
@ -20,6 +20,7 @@
|
||||||
<column name="user_id" type="integer" />
|
<column name="user_id" type="integer" />
|
||||||
<column name="name" type="varchar" size="64" />
|
<column name="name" type="varchar" size="64" />
|
||||||
<column name="certificate" type="longvarchar" />
|
<column name="certificate" type="longvarchar" />
|
||||||
|
<column name="private_key" type="longvarchar" />
|
||||||
<column name="expires_on" type="timestamp" />
|
<column name="expires_on" type="timestamp" />
|
||||||
<column name="revoked" type="boolean" default="false" />
|
<column name="revoked" type="boolean" default="false" />
|
||||||
<column name="serial" type="varchar" size="64" />
|
<column name="serial" type="varchar" size="64" />
|
||||||
|
@ -46,4 +47,34 @@
|
||||||
<column name="id" type="integer" primaryKey="true" autoIncrement="true" />
|
<column name="id" type="integer" primaryKey="true" autoIncrement="true" />
|
||||||
<column name="invite" type="varchar" size="64" />
|
<column name="invite" type="varchar" size="64" />
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
<table name="Server">
|
||||||
|
<column name="id" type="integer" primaryKey="true" autoIncrement="true" />
|
||||||
|
<column name="fqdn" type="varchar" size="64" />
|
||||||
|
<column name="fingerprint" type="varchar" size="64"/>
|
||||||
|
<column name="public_key" type="longvarchar" />
|
||||||
|
<column name="certificate" type="longvarchar" />
|
||||||
|
<column name="location" type="varchar" size="64" default="Unknown" />
|
||||||
|
<column name="speed" type="integer" default="-1" />
|
||||||
|
<column name="external_ip" type="varchar" size="128" />
|
||||||
|
<column name="internal_ip" type="varchar" size="128" default="10.24.0.0" />
|
||||||
|
<column name="netmask" type="integer" size="4" default="16" />
|
||||||
|
<column name="first_dns" type="varchar" size="128" />
|
||||||
|
<column name="second_dns" type="varchar" size="128" />
|
||||||
|
<column name="port" type="integer" default="1194" />
|
||||||
|
<column name="protocol" type="enum" valueSet="udp,tcp" default="udp" />
|
||||||
|
<column name="status" type="enum" default="registered" valueSet="registered,signed,revoked" />
|
||||||
|
|
||||||
|
<index>
|
||||||
|
<index-column name="fqdn" />
|
||||||
|
</index>
|
||||||
|
|
||||||
|
<index>
|
||||||
|
<index-column name="status" />
|
||||||
|
</index>
|
||||||
|
|
||||||
|
<unique>
|
||||||
|
<unique-column name="fingerprint" />
|
||||||
|
</unique>
|
||||||
|
</table>
|
||||||
</database>
|
</database>
|
||||||
|
|
|
@ -2,3 +2,12 @@ body {
|
||||||
padding-top: 50px;
|
padding-top: 50px;
|
||||||
padding-bottom: 20px;
|
padding-bottom: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.modal-top-alert {
|
||||||
|
margin-top: -15px;
|
||||||
|
border-radius: 0;
|
||||||
|
margin-left: -15px;
|
||||||
|
margin-right: -15px;
|
||||||
|
border-left: 0;
|
||||||
|
border-right: 0;
|
||||||
|
}
|
42
public/js/edit_server.js
Normal file
42
public/js/edit_server.js
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
$(function () {
|
||||||
|
var error = $('<div class="alert alert-danger" role="alert"></div>');
|
||||||
|
|
||||||
|
$('.save').click(function () {
|
||||||
|
save(function(){});
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.save-and-sign').click(function () {
|
||||||
|
save(function () {
|
||||||
|
sign();
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
function save(callback) {
|
||||||
|
var fingerprint = $('.server-form').data('fingerprint');
|
||||||
|
|
||||||
|
var data = $('.server-form input').serializeArray();
|
||||||
|
|
||||||
|
$.post('/panel/server/' + fingerprint, data, function (data) {
|
||||||
|
if (!data.success) {
|
||||||
|
$('h2').after(error.text(data.error));
|
||||||
|
}
|
||||||
|
|
||||||
|
callback();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function sign() {
|
||||||
|
var fingerprint = $('.server-form').data('fingerprint');
|
||||||
|
$.post(
|
||||||
|
'/panel/server/sign',
|
||||||
|
{
|
||||||
|
fingerprint: fingerprint
|
||||||
|
},
|
||||||
|
function (data) {
|
||||||
|
if (!data.success) {
|
||||||
|
$('h2').after(error.text(data.error));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
|
@ -3,6 +3,17 @@ $(function () {
|
||||||
|
|
||||||
$('.magic-csr').click(function () {
|
$('.magic-csr').click(function () {
|
||||||
var name = $('#name').val();
|
var name = $('#name').val();
|
||||||
|
|
||||||
|
if (name.length === 0) {
|
||||||
|
$('h2').after(error.text("Name can't be empty"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!/^[A-Za-z0-9_-]+$/.test(name)) {
|
||||||
|
$('h2').after(error.text("Only alphanumeric, _ and - allowed in name"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
var user = $('.user').text();
|
var user = $('.user').text();
|
||||||
|
|
||||||
var keys = forge.pki.rsa.generateKeyPair(1024);
|
var keys = forge.pki.rsa.generateKeyPair(1024);
|
||||||
|
@ -15,19 +26,31 @@ $(function () {
|
||||||
value: commonName
|
value: commonName
|
||||||
}]);
|
}]);
|
||||||
csr.sign(keys.privateKey);
|
csr.sign(keys.privateKey);
|
||||||
var pem = forge.pki.certificationRequestToPem(csr);
|
var csrPem = forge.pki.certificationRequestToPem(csr);
|
||||||
|
|
||||||
$.post('/panel/certificates/new', {
|
var newCertParams = {
|
||||||
csr: pem,
|
csr: csrPem,
|
||||||
name: name
|
name: name
|
||||||
}, function (data) {
|
};
|
||||||
|
|
||||||
|
var keyPem = "";
|
||||||
|
|
||||||
|
if ($('#wantsPassword').prop('checked')) {
|
||||||
|
keyPem = forge.pki.encryptRsaPrivateKey(keys.privateKey, $('#password').val());
|
||||||
|
newCertParams.key = keyPem;
|
||||||
|
} else {
|
||||||
|
keyPem = forge.pki.privateKeyToPem(keys.privateKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
$.post('/panel/certificates/new', newCertParams, function (data) {
|
||||||
if (data.success) {
|
if (data.success) {
|
||||||
var zip = new JSZip();
|
var zip = new JSZip();
|
||||||
zip.file(commonName + '.key', pem);
|
zip.file(commonName + '.key', keyPem);
|
||||||
|
|
||||||
for(var file in data.zip) {
|
for(var file in data.zip) {
|
||||||
zip.file(file, data.zip[file]);
|
zip.file(file, data.zip[file]);
|
||||||
}
|
}
|
||||||
|
|
||||||
var content = zip.generate({type:"blob"});
|
var content = zip.generate({type:"blob"});
|
||||||
saveAs(content, commonName + '-vpn.zip');
|
saveAs(content, commonName + '-vpn.zip');
|
||||||
location.href = '/panel';
|
location.href = '/panel';
|
||||||
|
@ -36,4 +59,8 @@ $(function () {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$("#wantsPassword").change(function () {
|
||||||
|
$('#password, #saveOnline').prop('disabled', !this.checked);
|
||||||
|
});
|
||||||
});
|
});
|
29
public/js/panel.js
Normal file
29
public/js/panel.js
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
$(function(){
|
||||||
|
var error = $('<div class="alert alert-danger" role="alert"></div>');
|
||||||
|
var success = $('<div class="alert alert-success alert-dismissable" role="alert"></div>');
|
||||||
|
var selected = false;
|
||||||
|
|
||||||
|
$('.revoke').click(function () {
|
||||||
|
selected = $(this).data('name');
|
||||||
|
|
||||||
|
$('.revoke-modal').modal('show');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.revoke-confirm').click(function () {
|
||||||
|
var selectedSnapshot = selected;
|
||||||
|
|
||||||
|
$.post('/panel/certificates/revoke', {
|
||||||
|
name: selectedSnapshot,
|
||||||
|
password: $('.revoke-password').val()
|
||||||
|
}, function(data) {
|
||||||
|
if (data.success) {
|
||||||
|
$('#certificates').after(success.text("Successfully revoked '" + selectedSnapshot + "'"));
|
||||||
|
$('.revoke-modal').modal('hide');
|
||||||
|
} else {
|
||||||
|
$('#revoke-put-error-after-me').after(error.text(data.error));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.revoke-password').val('');
|
||||||
|
});
|
||||||
|
});
|
14
src/Handler/CA.php
Normal file
14
src/Handler/CA.php
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler;
|
||||||
|
|
||||||
|
class CA extends Session
|
||||||
|
{
|
||||||
|
function handle()
|
||||||
|
{
|
||||||
|
return$this->getResponse()
|
||||||
|
->withHeader('Content-Type', 'plain/text')
|
||||||
|
->withHeader('Content-Disposition', 'attachment; filename="ca.crt"')
|
||||||
|
->write(file_get_contents($this->getCore()->getBaseDir() . '/storage/ca/ca.crt'));
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,10 +1,4 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
|
||||||
* Created by PhpStorm.
|
|
||||||
* User: eater
|
|
||||||
* Date: 3/30/16
|
|
||||||
* Time: 12:10 AM
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace Eater\Glim\Handler;
|
namespace Eater\Glim\Handler;
|
||||||
|
|
||||||
|
|
|
@ -9,12 +9,31 @@
|
||||||
namespace Eater\Glim\Handler;
|
namespace Eater\Glim\Handler;
|
||||||
|
|
||||||
|
|
||||||
|
use Eater\Glim\Model\Server;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
|
||||||
class Panel extends Session
|
class Panel extends Session
|
||||||
{
|
{
|
||||||
protected $shouldHaveUser = true;
|
protected $shouldHaveUser = true;
|
||||||
|
|
||||||
public function handle()
|
public function handle()
|
||||||
{
|
{
|
||||||
return $this->render('panel.html.twig');
|
$superuser = $this->getUser()->getSuperuser();
|
||||||
|
|
||||||
|
$vars = [
|
||||||
|
'superuser' => $superuser,
|
||||||
|
'servers' => $this->fetchServers()
|
||||||
|
];
|
||||||
|
|
||||||
|
if ($superuser) {
|
||||||
|
$vars['registeredServers'] = $this->fetchServers('registered');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render('panel.html.twig', $vars);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fetchServers($status = "signed")
|
||||||
|
{
|
||||||
|
return ServerQuery::create()->filterByStatus($status)->find();
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -21,9 +21,7 @@ class Download extends Session
|
||||||
$name = $this->attr('name');
|
$name = $this->attr('name');
|
||||||
|
|
||||||
$cert = CertificateQuery::create()
|
$cert = CertificateQuery::create()
|
||||||
->filterByName($name)
|
->findOneByUserAndName($this->getUser(), $name);
|
||||||
->filterByUser($this->getUser())
|
|
||||||
->findOne();
|
|
||||||
|
|
||||||
if ($cert === null) {
|
if ($cert === null) {
|
||||||
return $this->getResponse()->withStatus(404)->write("Couldn't find your Certificate with the name '{$name}'");
|
return $this->getResponse()->withStatus(404)->write("Couldn't find your Certificate with the name '{$name}'");
|
||||||
|
|
69
src/Handler/Panel/Certificates/Revoke.php
Normal file
69
src/Handler/Panel/Certificates/Revoke.php
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Created by PhpStorm.
|
||||||
|
* User: eater
|
||||||
|
* Date: 4/6/16
|
||||||
|
* Time: 11:30 PM
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler\Panel\Certificates;
|
||||||
|
|
||||||
|
use Eater\Glim\Handler\Session;
|
||||||
|
use Eater\Glim\Model\CertificateQuery;
|
||||||
|
use Eater\Glim\Service\CA;
|
||||||
|
use Slim\Http\Response;
|
||||||
|
|
||||||
|
class Revoke extends Session
|
||||||
|
{
|
||||||
|
protected $shouldHaveUser = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Response
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$user = $this->getUser();
|
||||||
|
$name = $this->post('name');
|
||||||
|
$password = $this->post('password');
|
||||||
|
|
||||||
|
$cert = CertificateQuery::create()
|
||||||
|
->filterByName($name)
|
||||||
|
->filterByUser($user)
|
||||||
|
->findOne();
|
||||||
|
|
||||||
|
if ($cert === null) {
|
||||||
|
return $this->json([
|
||||||
|
"success" => false,
|
||||||
|
"error" => 'Certificate with the name "' . $name . '" doesn\'t exist'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!password_verify($password, $user->getPassword())) {
|
||||||
|
return $this->json([
|
||||||
|
'success' => false,
|
||||||
|
'error' => 'Invalid password'
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var CA $ca
|
||||||
|
*/
|
||||||
|
$ca = $this->get('ca');
|
||||||
|
|
||||||
|
try {
|
||||||
|
$ca->revoke($cert->getCertificate());
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return $this->json([
|
||||||
|
"success" => false,
|
||||||
|
"error" => $e->getMessage()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$cert->setRevoked(true);
|
||||||
|
$cert->save();
|
||||||
|
|
||||||
|
return $this->json([
|
||||||
|
"success" => true
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -69,6 +69,11 @@ class Action extends Session
|
||||||
$certificate->setName($name);
|
$certificate->setName($name);
|
||||||
$certificate->setCertificate($crt);
|
$certificate->setCertificate($crt);
|
||||||
$certificate->setExpiresOn(new \DateTime('@' . $details['validTo_time_t']));
|
$certificate->setExpiresOn(new \DateTime('@' . $details['validTo_time_t']));
|
||||||
|
|
||||||
|
if (!empty($this->post('key'))) {
|
||||||
|
$certificate->setPrivateKey($this->post('key'));
|
||||||
|
}
|
||||||
|
|
||||||
$certificate->setSerial($details['serialNumber']);
|
$certificate->setSerial($details['serialNumber']);
|
||||||
|
|
||||||
$user->addCertificate($certificate);
|
$user->addCertificate($certificate);
|
||||||
|
|
35
src/Handler/Panel/Servers/Edit/Action.php
Normal file
35
src/Handler/Panel/Servers/Edit/Action.php
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler\Panel\Servers\Edit;
|
||||||
|
|
||||||
|
use Eater\Glim\Handler\Session;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
|
||||||
|
class Action extends Session
|
||||||
|
{
|
||||||
|
protected $shouldHaveSuperuser = true;
|
||||||
|
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$server = ServerQuery::create()->findOneByFingerprint($this->attr('fingerprint'));
|
||||||
|
|
||||||
|
$server->setFqdn($this->post('fqdn'));
|
||||||
|
$server->setExternalIp($this->post('external-ip'));
|
||||||
|
|
||||||
|
# Details
|
||||||
|
$server->setLocation($this->post('location'));
|
||||||
|
$server->setSpeed($this->post('speed'));
|
||||||
|
|
||||||
|
# Config
|
||||||
|
$server->setInternalIp($this->post('internal-ip'));
|
||||||
|
$server->setNetmask($this->post('netmask'));
|
||||||
|
$server->setPort($this->post('post'));
|
||||||
|
$server->setProtocol($this->post('protocol'));
|
||||||
|
$server->setFirstDns($this->post('first-dns'));
|
||||||
|
$server->setSecondDns($this->post('second-dns'));
|
||||||
|
|
||||||
|
$server->save();
|
||||||
|
|
||||||
|
$this->json([ 'success'=> true ]);
|
||||||
|
}
|
||||||
|
}
|
34
src/Handler/Panel/Servers/Edit/Show.php
Normal file
34
src/Handler/Panel/Servers/Edit/Show.php
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Created by PhpStorm.
|
||||||
|
* User: eater
|
||||||
|
* Date: 4/10/16
|
||||||
|
* Time: 9:30 PM
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler\Panel\Servers\Edit;
|
||||||
|
|
||||||
|
|
||||||
|
use Eater\Glim\Handler\Session;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
|
||||||
|
class Show extends Session
|
||||||
|
{
|
||||||
|
protected $shouldHaveSuperuser = true;
|
||||||
|
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$server = ServerQuery::create()->findOneByFingerprint($this->attr('fingerprint'));
|
||||||
|
|
||||||
|
if ($server === null) {
|
||||||
|
return $this->getResponse()->withStatus(404);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->render(
|
||||||
|
"panel/servers/edit.html.twig",
|
||||||
|
[
|
||||||
|
'server' => $server
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
50
src/Handler/Panel/Servers/Sign.php
Normal file
50
src/Handler/Panel/Servers/Sign.php
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler\Panel\Servers;
|
||||||
|
|
||||||
|
use Eater\Glim\Handler\Session;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
use Eater\Glim\Service\CA;
|
||||||
|
use Eater\Glim\Service\Server;
|
||||||
|
use Symfony\Component\Config\Definition\Exception\Exception;
|
||||||
|
|
||||||
|
class Sign extends Session
|
||||||
|
{
|
||||||
|
protected $shouldHaveSuperuser = true;
|
||||||
|
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
/** @var CA $ca */
|
||||||
|
$ca = $this->get('ca');
|
||||||
|
$server = ServerQuery::create()->findOneByFingerprint($this->post('fingerprint'));
|
||||||
|
$publicKey = $server->getPublicKey();
|
||||||
|
|
||||||
|
try {
|
||||||
|
$crt = $ca->signServerKey($publicKey, $server->getFqdn());
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return $this->json([
|
||||||
|
'success' => false,
|
||||||
|
'error' => $e->getMessage()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
$server->setCertificate($crt);
|
||||||
|
$server->save();
|
||||||
|
|
||||||
|
/** @var Server $serverManager */
|
||||||
|
$serverManager = $this->get('server');
|
||||||
|
|
||||||
|
try {
|
||||||
|
$serverManager->deliverSignedCertificate($server);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return $this->json([
|
||||||
|
'success' => false,
|
||||||
|
'error' => 'Failed to deliver certificate to server: ' . $e->__toString()
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->json([
|
||||||
|
'success' => true
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
72
src/Handler/Server/Register.php
Normal file
72
src/Handler/Server/Register.php
Normal file
|
@ -0,0 +1,72 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Handler\Server;
|
||||||
|
|
||||||
|
use Eater\Glim\Handler\Main;
|
||||||
|
use Eater\Glim\Model\Server;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
use Eater\Glim\Service\CA;
|
||||||
|
|
||||||
|
class Register extends Main
|
||||||
|
{
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
|
||||||
|
/** @var CA $ca */
|
||||||
|
$ca = $this->get('ca');
|
||||||
|
|
||||||
|
$publicKey = $this->post('publicKey');
|
||||||
|
$hexSignature = $this->post('signature');
|
||||||
|
$fingerprint = $ca->getFingerprintFromPublicKey($publicKey);
|
||||||
|
|
||||||
|
if (empty($publicKey)) {
|
||||||
|
return $this->bash(false, "no PublicKey was provided\n" . var_export($_POST, true) . "\n" . var_export($_FILES, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($hexSignature)) {
|
||||||
|
return $this->bash(false, "no signature was provided\n" . var_export($_POST));
|
||||||
|
}
|
||||||
|
|
||||||
|
$serverQuery = ServerQuery::create();
|
||||||
|
$server = $serverQuery->findOneByFingerprint($fingerprint);
|
||||||
|
|
||||||
|
$signature = hex2bin($hexSignature);
|
||||||
|
|
||||||
|
if ($server !== null) {
|
||||||
|
return $this->bash(false, "Server with this fingerprint already exists, if you want to change IP please use /server/update-ip or regenerate your public key");
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
$result = $ca->verify($fingerprint, $signature, $publicKey);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return $this->bash(false, "Verifying went into error: " . $e->getMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($result) {
|
||||||
|
return $this->bash(false, "Signature is erroneous\nSignature: {$hexSignature}\nFingerprint: {$fingerprint}\nOpenSSL: " . openssl_error_string());
|
||||||
|
}
|
||||||
|
|
||||||
|
$ip = $_SERVER['REMOTE_ADDR'];
|
||||||
|
$originalIp = $ip;
|
||||||
|
$fqdn = gethostbyaddr($ip);
|
||||||
|
$ipOfFqdn = gethostbyname($fqdn);
|
||||||
|
|
||||||
|
if ($ip === $ipOfFqdn) {
|
||||||
|
$ip = $fqdn;
|
||||||
|
}
|
||||||
|
|
||||||
|
$server = new Server();
|
||||||
|
$server->setFingerprint($fingerprint);
|
||||||
|
$server->setFqdn($ip);
|
||||||
|
$server->setExternalIp($originalIp);
|
||||||
|
$server->setPublicKey($publicKey);
|
||||||
|
$server->save();
|
||||||
|
|
||||||
|
return $this->bash(true, "Good job, skeleton");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function bash($result, $message)
|
||||||
|
{
|
||||||
|
return $this->getResponse()->write(($result ? 0 : 1) . "\n" . $message);
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,6 +19,11 @@ class Session extends Main
|
||||||
*/
|
*/
|
||||||
protected $shouldHaveUser = false;
|
protected $shouldHaveUser = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
protected $shouldHaveSuperuser = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var User
|
* @var User
|
||||||
*/
|
*/
|
||||||
|
@ -55,8 +60,10 @@ class Session extends Main
|
||||||
|
|
||||||
$this->setUser($user);
|
$this->setUser($user);
|
||||||
|
|
||||||
if ($user === null && $this->shouldHaveUser) {
|
if ($user === null && ($this->shouldHaveUser || $this->shouldHaveSuperuser)) {
|
||||||
return $this->redirect('/login');
|
return $this->redirect('/login');
|
||||||
|
} elseif ($this->shouldHaveSuperuser && !$user->getSuperuser()) {
|
||||||
|
return $this->redirect('/panel');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -87,6 +87,12 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
*/
|
*/
|
||||||
protected $certificate;
|
protected $certificate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The value for the private_key field.
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $private_key;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The value for the expires_on field.
|
* The value for the expires_on field.
|
||||||
* @var \DateTime
|
* @var \DateTime
|
||||||
|
@ -389,6 +395,16 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
return $this->certificate;
|
return $this->certificate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the [private_key] column value.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getPrivateKey()
|
||||||
|
{
|
||||||
|
return $this->private_key;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the [optionally formatted] temporal [expires_on] column value.
|
* Get the [optionally formatted] temporal [expires_on] column value.
|
||||||
*
|
*
|
||||||
|
@ -523,6 +539,26 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
return $this;
|
return $this;
|
||||||
} // setCertificate()
|
} // setCertificate()
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the value of [private_key] column.
|
||||||
|
*
|
||||||
|
* @param string $v new value
|
||||||
|
* @return $this|\Eater\Glim\Model\Certificate The current object (for fluent API support)
|
||||||
|
*/
|
||||||
|
public function setPrivateKey($v)
|
||||||
|
{
|
||||||
|
if ($v !== null) {
|
||||||
|
$v = (string) $v;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->private_key !== $v) {
|
||||||
|
$this->private_key = $v;
|
||||||
|
$this->modifiedColumns[CertificateTableMap::COL_PRIVATE_KEY] = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
} // setPrivateKey()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the value of [expires_on] column to a normalized version of the date/time value specified.
|
* Sets the value of [expires_on] column to a normalized version of the date/time value specified.
|
||||||
*
|
*
|
||||||
|
@ -643,13 +679,16 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$col = $row[TableMap::TYPE_NUM == $indexType ? 3 + $startcol : CertificateTableMap::translateFieldName('Certificate', TableMap::TYPE_PHPNAME, $indexType)];
|
$col = $row[TableMap::TYPE_NUM == $indexType ? 3 + $startcol : CertificateTableMap::translateFieldName('Certificate', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
$this->certificate = (null !== $col) ? (string) $col : null;
|
$this->certificate = (null !== $col) ? (string) $col : null;
|
||||||
|
|
||||||
$col = $row[TableMap::TYPE_NUM == $indexType ? 4 + $startcol : CertificateTableMap::translateFieldName('ExpiresOn', TableMap::TYPE_PHPNAME, $indexType)];
|
$col = $row[TableMap::TYPE_NUM == $indexType ? 4 + $startcol : CertificateTableMap::translateFieldName('PrivateKey', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
|
$this->private_key = (null !== $col) ? (string) $col : null;
|
||||||
|
|
||||||
|
$col = $row[TableMap::TYPE_NUM == $indexType ? 5 + $startcol : CertificateTableMap::translateFieldName('ExpiresOn', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
$this->expires_on = (null !== $col) ? PropelDateTime::newInstance($col, null, 'DateTime') : null;
|
$this->expires_on = (null !== $col) ? PropelDateTime::newInstance($col, null, 'DateTime') : null;
|
||||||
|
|
||||||
$col = $row[TableMap::TYPE_NUM == $indexType ? 5 + $startcol : CertificateTableMap::translateFieldName('Revoked', TableMap::TYPE_PHPNAME, $indexType)];
|
$col = $row[TableMap::TYPE_NUM == $indexType ? 6 + $startcol : CertificateTableMap::translateFieldName('Revoked', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
$this->revoked = (null !== $col) ? (boolean) $col : null;
|
$this->revoked = (null !== $col) ? (boolean) $col : null;
|
||||||
|
|
||||||
$col = $row[TableMap::TYPE_NUM == $indexType ? 6 + $startcol : CertificateTableMap::translateFieldName('Serial', TableMap::TYPE_PHPNAME, $indexType)];
|
$col = $row[TableMap::TYPE_NUM == $indexType ? 7 + $startcol : CertificateTableMap::translateFieldName('Serial', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
$this->serial = (null !== $col) ? (string) $col : null;
|
$this->serial = (null !== $col) ? (string) $col : null;
|
||||||
$this->resetModified();
|
$this->resetModified();
|
||||||
|
|
||||||
|
@ -659,7 +698,7 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$this->ensureConsistency();
|
$this->ensureConsistency();
|
||||||
}
|
}
|
||||||
|
|
||||||
return $startcol + 7; // 7 = CertificateTableMap::NUM_HYDRATE_COLUMNS.
|
return $startcol + 8; // 8 = CertificateTableMap::NUM_HYDRATE_COLUMNS.
|
||||||
|
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
throw new PropelException(sprintf('Error populating %s object', '\\Eater\\Glim\\Model\\Certificate'), 0, $e);
|
throw new PropelException(sprintf('Error populating %s object', '\\Eater\\Glim\\Model\\Certificate'), 0, $e);
|
||||||
|
@ -884,6 +923,9 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
if ($this->isColumnModified(CertificateTableMap::COL_CERTIFICATE)) {
|
if ($this->isColumnModified(CertificateTableMap::COL_CERTIFICATE)) {
|
||||||
$modifiedColumns[':p' . $index++] = 'certificate';
|
$modifiedColumns[':p' . $index++] = 'certificate';
|
||||||
}
|
}
|
||||||
|
if ($this->isColumnModified(CertificateTableMap::COL_PRIVATE_KEY)) {
|
||||||
|
$modifiedColumns[':p' . $index++] = 'private_key';
|
||||||
|
}
|
||||||
if ($this->isColumnModified(CertificateTableMap::COL_EXPIRES_ON)) {
|
if ($this->isColumnModified(CertificateTableMap::COL_EXPIRES_ON)) {
|
||||||
$modifiedColumns[':p' . $index++] = 'expires_on';
|
$modifiedColumns[':p' . $index++] = 'expires_on';
|
||||||
}
|
}
|
||||||
|
@ -916,6 +958,9 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
case 'certificate':
|
case 'certificate':
|
||||||
$stmt->bindValue($identifier, $this->certificate, PDO::PARAM_STR);
|
$stmt->bindValue($identifier, $this->certificate, PDO::PARAM_STR);
|
||||||
break;
|
break;
|
||||||
|
case 'private_key':
|
||||||
|
$stmt->bindValue($identifier, $this->private_key, PDO::PARAM_STR);
|
||||||
|
break;
|
||||||
case 'expires_on':
|
case 'expires_on':
|
||||||
$stmt->bindValue($identifier, $this->expires_on ? $this->expires_on->format("Y-m-d H:i:s") : null, PDO::PARAM_STR);
|
$stmt->bindValue($identifier, $this->expires_on ? $this->expires_on->format("Y-m-d H:i:s") : null, PDO::PARAM_STR);
|
||||||
break;
|
break;
|
||||||
|
@ -1000,12 +1045,15 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
return $this->getCertificate();
|
return $this->getCertificate();
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
return $this->getExpiresOn();
|
return $this->getPrivateKey();
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
return $this->getRevoked();
|
return $this->getExpiresOn();
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
|
return $this->getRevoked();
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
return $this->getSerial();
|
return $this->getSerial();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1042,16 +1090,17 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$keys[1] => $this->getUserId(),
|
$keys[1] => $this->getUserId(),
|
||||||
$keys[2] => $this->getName(),
|
$keys[2] => $this->getName(),
|
||||||
$keys[3] => $this->getCertificate(),
|
$keys[3] => $this->getCertificate(),
|
||||||
$keys[4] => $this->getExpiresOn(),
|
$keys[4] => $this->getPrivateKey(),
|
||||||
$keys[5] => $this->getRevoked(),
|
$keys[5] => $this->getExpiresOn(),
|
||||||
$keys[6] => $this->getSerial(),
|
$keys[6] => $this->getRevoked(),
|
||||||
|
$keys[7] => $this->getSerial(),
|
||||||
);
|
);
|
||||||
|
|
||||||
$utc = new \DateTimeZone('utc');
|
$utc = new \DateTimeZone('utc');
|
||||||
if ($result[$keys[4]] instanceof \DateTime) {
|
if ($result[$keys[5]] instanceof \DateTime) {
|
||||||
// When changing timezone we don't want to change existing instances
|
// When changing timezone we don't want to change existing instances
|
||||||
$dateTime = clone $result[$keys[4]];
|
$dateTime = clone $result[$keys[5]];
|
||||||
$result[$keys[4]] = $dateTime->setTimezone($utc)->format('Y-m-d\TH:i:s\Z');
|
$result[$keys[5]] = $dateTime->setTimezone($utc)->format('Y-m-d\TH:i:s\Z');
|
||||||
}
|
}
|
||||||
|
|
||||||
$virtualColumns = $this->virtualColumns;
|
$virtualColumns = $this->virtualColumns;
|
||||||
|
@ -1122,12 +1171,15 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$this->setCertificate($value);
|
$this->setCertificate($value);
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
$this->setExpiresOn($value);
|
$this->setPrivateKey($value);
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
$this->setRevoked($value);
|
$this->setExpiresOn($value);
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
|
$this->setRevoked($value);
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
$this->setSerial($value);
|
$this->setSerial($value);
|
||||||
break;
|
break;
|
||||||
} // switch()
|
} // switch()
|
||||||
|
@ -1169,13 +1221,16 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$this->setCertificate($arr[$keys[3]]);
|
$this->setCertificate($arr[$keys[3]]);
|
||||||
}
|
}
|
||||||
if (array_key_exists($keys[4], $arr)) {
|
if (array_key_exists($keys[4], $arr)) {
|
||||||
$this->setExpiresOn($arr[$keys[4]]);
|
$this->setPrivateKey($arr[$keys[4]]);
|
||||||
}
|
}
|
||||||
if (array_key_exists($keys[5], $arr)) {
|
if (array_key_exists($keys[5], $arr)) {
|
||||||
$this->setRevoked($arr[$keys[5]]);
|
$this->setExpiresOn($arr[$keys[5]]);
|
||||||
}
|
}
|
||||||
if (array_key_exists($keys[6], $arr)) {
|
if (array_key_exists($keys[6], $arr)) {
|
||||||
$this->setSerial($arr[$keys[6]]);
|
$this->setRevoked($arr[$keys[6]]);
|
||||||
|
}
|
||||||
|
if (array_key_exists($keys[7], $arr)) {
|
||||||
|
$this->setSerial($arr[$keys[7]]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1230,6 +1285,9 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
if ($this->isColumnModified(CertificateTableMap::COL_CERTIFICATE)) {
|
if ($this->isColumnModified(CertificateTableMap::COL_CERTIFICATE)) {
|
||||||
$criteria->add(CertificateTableMap::COL_CERTIFICATE, $this->certificate);
|
$criteria->add(CertificateTableMap::COL_CERTIFICATE, $this->certificate);
|
||||||
}
|
}
|
||||||
|
if ($this->isColumnModified(CertificateTableMap::COL_PRIVATE_KEY)) {
|
||||||
|
$criteria->add(CertificateTableMap::COL_PRIVATE_KEY, $this->private_key);
|
||||||
|
}
|
||||||
if ($this->isColumnModified(CertificateTableMap::COL_EXPIRES_ON)) {
|
if ($this->isColumnModified(CertificateTableMap::COL_EXPIRES_ON)) {
|
||||||
$criteria->add(CertificateTableMap::COL_EXPIRES_ON, $this->expires_on);
|
$criteria->add(CertificateTableMap::COL_EXPIRES_ON, $this->expires_on);
|
||||||
}
|
}
|
||||||
|
@ -1328,6 +1386,7 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$copyObj->setUserId($this->getUserId());
|
$copyObj->setUserId($this->getUserId());
|
||||||
$copyObj->setName($this->getName());
|
$copyObj->setName($this->getName());
|
||||||
$copyObj->setCertificate($this->getCertificate());
|
$copyObj->setCertificate($this->getCertificate());
|
||||||
|
$copyObj->setPrivateKey($this->getPrivateKey());
|
||||||
$copyObj->setExpiresOn($this->getExpiresOn());
|
$copyObj->setExpiresOn($this->getExpiresOn());
|
||||||
$copyObj->setRevoked($this->getRevoked());
|
$copyObj->setRevoked($this->getRevoked());
|
||||||
$copyObj->setSerial($this->getSerial());
|
$copyObj->setSerial($this->getSerial());
|
||||||
|
@ -1424,6 +1483,7 @@ abstract class Certificate implements ActiveRecordInterface
|
||||||
$this->user_id = null;
|
$this->user_id = null;
|
||||||
$this->name = null;
|
$this->name = null;
|
||||||
$this->certificate = null;
|
$this->certificate = null;
|
||||||
|
$this->private_key = null;
|
||||||
$this->expires_on = null;
|
$this->expires_on = null;
|
||||||
$this->revoked = null;
|
$this->revoked = null;
|
||||||
$this->serial = null;
|
$this->serial = null;
|
||||||
|
|
|
@ -24,6 +24,7 @@ use Propel\Runtime\Exception\PropelException;
|
||||||
* @method ChildCertificateQuery orderByUserId($order = Criteria::ASC) Order by the user_id column
|
* @method ChildCertificateQuery orderByUserId($order = Criteria::ASC) Order by the user_id column
|
||||||
* @method ChildCertificateQuery orderByName($order = Criteria::ASC) Order by the name column
|
* @method ChildCertificateQuery orderByName($order = Criteria::ASC) Order by the name column
|
||||||
* @method ChildCertificateQuery orderByCertificate($order = Criteria::ASC) Order by the certificate column
|
* @method ChildCertificateQuery orderByCertificate($order = Criteria::ASC) Order by the certificate column
|
||||||
|
* @method ChildCertificateQuery orderByPrivateKey($order = Criteria::ASC) Order by the private_key column
|
||||||
* @method ChildCertificateQuery orderByExpiresOn($order = Criteria::ASC) Order by the expires_on column
|
* @method ChildCertificateQuery orderByExpiresOn($order = Criteria::ASC) Order by the expires_on column
|
||||||
* @method ChildCertificateQuery orderByRevoked($order = Criteria::ASC) Order by the revoked column
|
* @method ChildCertificateQuery orderByRevoked($order = Criteria::ASC) Order by the revoked column
|
||||||
* @method ChildCertificateQuery orderBySerial($order = Criteria::ASC) Order by the serial column
|
* @method ChildCertificateQuery orderBySerial($order = Criteria::ASC) Order by the serial column
|
||||||
|
@ -32,6 +33,7 @@ use Propel\Runtime\Exception\PropelException;
|
||||||
* @method ChildCertificateQuery groupByUserId() Group by the user_id column
|
* @method ChildCertificateQuery groupByUserId() Group by the user_id column
|
||||||
* @method ChildCertificateQuery groupByName() Group by the name column
|
* @method ChildCertificateQuery groupByName() Group by the name column
|
||||||
* @method ChildCertificateQuery groupByCertificate() Group by the certificate column
|
* @method ChildCertificateQuery groupByCertificate() Group by the certificate column
|
||||||
|
* @method ChildCertificateQuery groupByPrivateKey() Group by the private_key column
|
||||||
* @method ChildCertificateQuery groupByExpiresOn() Group by the expires_on column
|
* @method ChildCertificateQuery groupByExpiresOn() Group by the expires_on column
|
||||||
* @method ChildCertificateQuery groupByRevoked() Group by the revoked column
|
* @method ChildCertificateQuery groupByRevoked() Group by the revoked column
|
||||||
* @method ChildCertificateQuery groupBySerial() Group by the serial column
|
* @method ChildCertificateQuery groupBySerial() Group by the serial column
|
||||||
|
@ -53,6 +55,7 @@ use Propel\Runtime\Exception\PropelException;
|
||||||
* @method ChildCertificate findOneByUserId(int $user_id) Return the first ChildCertificate filtered by the user_id column
|
* @method ChildCertificate findOneByUserId(int $user_id) Return the first ChildCertificate filtered by the user_id column
|
||||||
* @method ChildCertificate findOneByName(string $name) Return the first ChildCertificate filtered by the name column
|
* @method ChildCertificate findOneByName(string $name) Return the first ChildCertificate filtered by the name column
|
||||||
* @method ChildCertificate findOneByCertificate(string $certificate) Return the first ChildCertificate filtered by the certificate column
|
* @method ChildCertificate findOneByCertificate(string $certificate) Return the first ChildCertificate filtered by the certificate column
|
||||||
|
* @method ChildCertificate findOneByPrivateKey(string $private_key) Return the first ChildCertificate filtered by the private_key column
|
||||||
* @method ChildCertificate findOneByExpiresOn(string $expires_on) Return the first ChildCertificate filtered by the expires_on column
|
* @method ChildCertificate findOneByExpiresOn(string $expires_on) Return the first ChildCertificate filtered by the expires_on column
|
||||||
* @method ChildCertificate findOneByRevoked(boolean $revoked) Return the first ChildCertificate filtered by the revoked column
|
* @method ChildCertificate findOneByRevoked(boolean $revoked) Return the first ChildCertificate filtered by the revoked column
|
||||||
* @method ChildCertificate findOneBySerial(string $serial) Return the first ChildCertificate filtered by the serial column *
|
* @method ChildCertificate findOneBySerial(string $serial) Return the first ChildCertificate filtered by the serial column *
|
||||||
|
@ -64,6 +67,7 @@ use Propel\Runtime\Exception\PropelException;
|
||||||
* @method ChildCertificate requireOneByUserId(int $user_id) Return the first ChildCertificate filtered by the user_id column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneByUserId(int $user_id) Return the first ChildCertificate filtered by the user_id column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
* @method ChildCertificate requireOneByName(string $name) Return the first ChildCertificate filtered by the name column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneByName(string $name) Return the first ChildCertificate filtered by the name column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
* @method ChildCertificate requireOneByCertificate(string $certificate) Return the first ChildCertificate filtered by the certificate column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneByCertificate(string $certificate) Return the first ChildCertificate filtered by the certificate column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildCertificate requireOneByPrivateKey(string $private_key) Return the first ChildCertificate filtered by the private_key column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
* @method ChildCertificate requireOneByExpiresOn(string $expires_on) Return the first ChildCertificate filtered by the expires_on column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneByExpiresOn(string $expires_on) Return the first ChildCertificate filtered by the expires_on column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
* @method ChildCertificate requireOneByRevoked(boolean $revoked) Return the first ChildCertificate filtered by the revoked column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneByRevoked(boolean $revoked) Return the first ChildCertificate filtered by the revoked column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
* @method ChildCertificate requireOneBySerial(string $serial) Return the first ChildCertificate filtered by the serial column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
* @method ChildCertificate requireOneBySerial(string $serial) Return the first ChildCertificate filtered by the serial column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
@ -73,6 +77,7 @@ use Propel\Runtime\Exception\PropelException;
|
||||||
* @method ChildCertificate[]|ObjectCollection findByUserId(int $user_id) Return ChildCertificate objects filtered by the user_id column
|
* @method ChildCertificate[]|ObjectCollection findByUserId(int $user_id) Return ChildCertificate objects filtered by the user_id column
|
||||||
* @method ChildCertificate[]|ObjectCollection findByName(string $name) Return ChildCertificate objects filtered by the name column
|
* @method ChildCertificate[]|ObjectCollection findByName(string $name) Return ChildCertificate objects filtered by the name column
|
||||||
* @method ChildCertificate[]|ObjectCollection findByCertificate(string $certificate) Return ChildCertificate objects filtered by the certificate column
|
* @method ChildCertificate[]|ObjectCollection findByCertificate(string $certificate) Return ChildCertificate objects filtered by the certificate column
|
||||||
|
* @method ChildCertificate[]|ObjectCollection findByPrivateKey(string $private_key) Return ChildCertificate objects filtered by the private_key column
|
||||||
* @method ChildCertificate[]|ObjectCollection findByExpiresOn(string $expires_on) Return ChildCertificate objects filtered by the expires_on column
|
* @method ChildCertificate[]|ObjectCollection findByExpiresOn(string $expires_on) Return ChildCertificate objects filtered by the expires_on column
|
||||||
* @method ChildCertificate[]|ObjectCollection findByRevoked(boolean $revoked) Return ChildCertificate objects filtered by the revoked column
|
* @method ChildCertificate[]|ObjectCollection findByRevoked(boolean $revoked) Return ChildCertificate objects filtered by the revoked column
|
||||||
* @method ChildCertificate[]|ObjectCollection findBySerial(string $serial) Return ChildCertificate objects filtered by the serial column
|
* @method ChildCertificate[]|ObjectCollection findBySerial(string $serial) Return ChildCertificate objects filtered by the serial column
|
||||||
|
@ -168,7 +173,7 @@ abstract class CertificateQuery extends ModelCriteria
|
||||||
*/
|
*/
|
||||||
protected function findPkSimple($key, ConnectionInterface $con)
|
protected function findPkSimple($key, ConnectionInterface $con)
|
||||||
{
|
{
|
||||||
$sql = 'SELECT id, user_id, name, certificate, expires_on, revoked, serial FROM Certificate WHERE id = :p0';
|
$sql = 'SELECT id, user_id, name, certificate, private_key, expires_on, revoked, serial FROM Certificate WHERE id = :p0';
|
||||||
try {
|
try {
|
||||||
$stmt = $con->prepare($sql);
|
$stmt = $con->prepare($sql);
|
||||||
$stmt->bindValue(':p0', $key, PDO::PARAM_INT);
|
$stmt->bindValue(':p0', $key, PDO::PARAM_INT);
|
||||||
|
@ -400,6 +405,35 @@ abstract class CertificateQuery extends ModelCriteria
|
||||||
return $this->addUsingAlias(CertificateTableMap::COL_CERTIFICATE, $certificate, $comparison);
|
return $this->addUsingAlias(CertificateTableMap::COL_CERTIFICATE, $certificate, $comparison);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the private_key column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByPrivateKey('fooValue'); // WHERE private_key = 'fooValue'
|
||||||
|
* $query->filterByPrivateKey('%fooValue%'); // WHERE private_key LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $privateKey The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildCertificateQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByPrivateKey($privateKey = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($privateKey)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $privateKey)) {
|
||||||
|
$privateKey = str_replace('*', '%', $privateKey);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(CertificateTableMap::COL_PRIVATE_KEY, $privateKey, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Filter the query on the expires_on column
|
* Filter the query on the expires_on column
|
||||||
*
|
*
|
||||||
|
|
1996
src/Model/Base/Server.php
Normal file
1996
src/Model/Base/Server.php
Normal file
File diff suppressed because it is too large
Load diff
862
src/Model/Base/ServerQuery.php
Normal file
862
src/Model/Base/ServerQuery.php
Normal file
|
@ -0,0 +1,862 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Model\Base;
|
||||||
|
|
||||||
|
use \Exception;
|
||||||
|
use \PDO;
|
||||||
|
use Eater\Glim\Model\Server as ChildServer;
|
||||||
|
use Eater\Glim\Model\ServerQuery as ChildServerQuery;
|
||||||
|
use Eater\Glim\Model\Map\ServerTableMap;
|
||||||
|
use Propel\Runtime\Propel;
|
||||||
|
use Propel\Runtime\ActiveQuery\Criteria;
|
||||||
|
use Propel\Runtime\ActiveQuery\ModelCriteria;
|
||||||
|
use Propel\Runtime\Collection\ObjectCollection;
|
||||||
|
use Propel\Runtime\Connection\ConnectionInterface;
|
||||||
|
use Propel\Runtime\Exception\PropelException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class that represents a query for the 'Server' table.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* @method ChildServerQuery orderById($order = Criteria::ASC) Order by the id column
|
||||||
|
* @method ChildServerQuery orderByFqdn($order = Criteria::ASC) Order by the fqdn column
|
||||||
|
* @method ChildServerQuery orderByFingerprint($order = Criteria::ASC) Order by the fingerprint column
|
||||||
|
* @method ChildServerQuery orderByPublicKey($order = Criteria::ASC) Order by the public_key column
|
||||||
|
* @method ChildServerQuery orderByCertificate($order = Criteria::ASC) Order by the certificate column
|
||||||
|
* @method ChildServerQuery orderByLocation($order = Criteria::ASC) Order by the location column
|
||||||
|
* @method ChildServerQuery orderBySpeed($order = Criteria::ASC) Order by the speed column
|
||||||
|
* @method ChildServerQuery orderByExternalIp($order = Criteria::ASC) Order by the external_ip column
|
||||||
|
* @method ChildServerQuery orderByInternalIp($order = Criteria::ASC) Order by the internal_ip column
|
||||||
|
* @method ChildServerQuery orderByNetmask($order = Criteria::ASC) Order by the netmask column
|
||||||
|
* @method ChildServerQuery orderByFirstDns($order = Criteria::ASC) Order by the first_dns column
|
||||||
|
* @method ChildServerQuery orderBySecondDns($order = Criteria::ASC) Order by the second_dns column
|
||||||
|
* @method ChildServerQuery orderByPort($order = Criteria::ASC) Order by the port column
|
||||||
|
* @method ChildServerQuery orderByProtocol($order = Criteria::ASC) Order by the protocol column
|
||||||
|
* @method ChildServerQuery orderByStatus($order = Criteria::ASC) Order by the status column
|
||||||
|
*
|
||||||
|
* @method ChildServerQuery groupById() Group by the id column
|
||||||
|
* @method ChildServerQuery groupByFqdn() Group by the fqdn column
|
||||||
|
* @method ChildServerQuery groupByFingerprint() Group by the fingerprint column
|
||||||
|
* @method ChildServerQuery groupByPublicKey() Group by the public_key column
|
||||||
|
* @method ChildServerQuery groupByCertificate() Group by the certificate column
|
||||||
|
* @method ChildServerQuery groupByLocation() Group by the location column
|
||||||
|
* @method ChildServerQuery groupBySpeed() Group by the speed column
|
||||||
|
* @method ChildServerQuery groupByExternalIp() Group by the external_ip column
|
||||||
|
* @method ChildServerQuery groupByInternalIp() Group by the internal_ip column
|
||||||
|
* @method ChildServerQuery groupByNetmask() Group by the netmask column
|
||||||
|
* @method ChildServerQuery groupByFirstDns() Group by the first_dns column
|
||||||
|
* @method ChildServerQuery groupBySecondDns() Group by the second_dns column
|
||||||
|
* @method ChildServerQuery groupByPort() Group by the port column
|
||||||
|
* @method ChildServerQuery groupByProtocol() Group by the protocol column
|
||||||
|
* @method ChildServerQuery groupByStatus() Group by the status column
|
||||||
|
*
|
||||||
|
* @method ChildServerQuery leftJoin($relation) Adds a LEFT JOIN clause to the query
|
||||||
|
* @method ChildServerQuery rightJoin($relation) Adds a RIGHT JOIN clause to the query
|
||||||
|
* @method ChildServerQuery innerJoin($relation) Adds a INNER JOIN clause to the query
|
||||||
|
*
|
||||||
|
* @method ChildServer findOne(ConnectionInterface $con = null) Return the first ChildServer matching the query
|
||||||
|
* @method ChildServer findOneOrCreate(ConnectionInterface $con = null) Return the first ChildServer matching the query, or a new ChildServer object populated from the query conditions when no match is found
|
||||||
|
*
|
||||||
|
* @method ChildServer findOneById(int $id) Return the first ChildServer filtered by the id column
|
||||||
|
* @method ChildServer findOneByFqdn(string $fqdn) Return the first ChildServer filtered by the fqdn column
|
||||||
|
* @method ChildServer findOneByFingerprint(string $fingerprint) Return the first ChildServer filtered by the fingerprint column
|
||||||
|
* @method ChildServer findOneByPublicKey(string $public_key) Return the first ChildServer filtered by the public_key column
|
||||||
|
* @method ChildServer findOneByCertificate(string $certificate) Return the first ChildServer filtered by the certificate column
|
||||||
|
* @method ChildServer findOneByLocation(string $location) Return the first ChildServer filtered by the location column
|
||||||
|
* @method ChildServer findOneBySpeed(int $speed) Return the first ChildServer filtered by the speed column
|
||||||
|
* @method ChildServer findOneByExternalIp(string $external_ip) Return the first ChildServer filtered by the external_ip column
|
||||||
|
* @method ChildServer findOneByInternalIp(string $internal_ip) Return the first ChildServer filtered by the internal_ip column
|
||||||
|
* @method ChildServer findOneByNetmask(int $netmask) Return the first ChildServer filtered by the netmask column
|
||||||
|
* @method ChildServer findOneByFirstDns(string $first_dns) Return the first ChildServer filtered by the first_dns column
|
||||||
|
* @method ChildServer findOneBySecondDns(string $second_dns) Return the first ChildServer filtered by the second_dns column
|
||||||
|
* @method ChildServer findOneByPort(int $port) Return the first ChildServer filtered by the port column
|
||||||
|
* @method ChildServer findOneByProtocol(int $protocol) Return the first ChildServer filtered by the protocol column
|
||||||
|
* @method ChildServer findOneByStatus(int $status) Return the first ChildServer filtered by the status column *
|
||||||
|
|
||||||
|
* @method ChildServer requirePk($key, ConnectionInterface $con = null) Return the ChildServer by primary key and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOne(ConnectionInterface $con = null) Return the first ChildServer matching the query and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
*
|
||||||
|
* @method ChildServer requireOneById(int $id) Return the first ChildServer filtered by the id column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByFqdn(string $fqdn) Return the first ChildServer filtered by the fqdn column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByFingerprint(string $fingerprint) Return the first ChildServer filtered by the fingerprint column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByPublicKey(string $public_key) Return the first ChildServer filtered by the public_key column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByCertificate(string $certificate) Return the first ChildServer filtered by the certificate column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByLocation(string $location) Return the first ChildServer filtered by the location column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneBySpeed(int $speed) Return the first ChildServer filtered by the speed column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByExternalIp(string $external_ip) Return the first ChildServer filtered by the external_ip column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByInternalIp(string $internal_ip) Return the first ChildServer filtered by the internal_ip column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByNetmask(int $netmask) Return the first ChildServer filtered by the netmask column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByFirstDns(string $first_dns) Return the first ChildServer filtered by the first_dns column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneBySecondDns(string $second_dns) Return the first ChildServer filtered by the second_dns column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByPort(int $port) Return the first ChildServer filtered by the port column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByProtocol(int $protocol) Return the first ChildServer filtered by the protocol column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
* @method ChildServer requireOneByStatus(int $status) Return the first ChildServer filtered by the status column and throws \Propel\Runtime\Exception\EntityNotFoundException when not found
|
||||||
|
*
|
||||||
|
* @method ChildServer[]|ObjectCollection find(ConnectionInterface $con = null) Return ChildServer objects based on current ModelCriteria
|
||||||
|
* @method ChildServer[]|ObjectCollection findById(int $id) Return ChildServer objects filtered by the id column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByFqdn(string $fqdn) Return ChildServer objects filtered by the fqdn column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByFingerprint(string $fingerprint) Return ChildServer objects filtered by the fingerprint column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByPublicKey(string $public_key) Return ChildServer objects filtered by the public_key column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByCertificate(string $certificate) Return ChildServer objects filtered by the certificate column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByLocation(string $location) Return ChildServer objects filtered by the location column
|
||||||
|
* @method ChildServer[]|ObjectCollection findBySpeed(int $speed) Return ChildServer objects filtered by the speed column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByExternalIp(string $external_ip) Return ChildServer objects filtered by the external_ip column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByInternalIp(string $internal_ip) Return ChildServer objects filtered by the internal_ip column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByNetmask(int $netmask) Return ChildServer objects filtered by the netmask column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByFirstDns(string $first_dns) Return ChildServer objects filtered by the first_dns column
|
||||||
|
* @method ChildServer[]|ObjectCollection findBySecondDns(string $second_dns) Return ChildServer objects filtered by the second_dns column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByPort(int $port) Return ChildServer objects filtered by the port column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByProtocol(int $protocol) Return ChildServer objects filtered by the protocol column
|
||||||
|
* @method ChildServer[]|ObjectCollection findByStatus(int $status) Return ChildServer objects filtered by the status column
|
||||||
|
* @method ChildServer[]|\Propel\Runtime\Util\PropelModelPager paginate($page = 1, $maxPerPage = 10, ConnectionInterface $con = null) Issue a SELECT query based on the current ModelCriteria and uses a page and a maximum number of results per page to compute an offset and a limit
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
abstract class ServerQuery extends ModelCriteria
|
||||||
|
{
|
||||||
|
protected $entityNotFoundExceptionClass = '\\Propel\\Runtime\\Exception\\EntityNotFoundException';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes internal state of \Eater\Glim\Model\Base\ServerQuery object.
|
||||||
|
*
|
||||||
|
* @param string $dbName The database name
|
||||||
|
* @param string $modelName The phpName of a model, e.g. 'Book'
|
||||||
|
* @param string $modelAlias The alias for the model in this query, e.g. 'b'
|
||||||
|
*/
|
||||||
|
public function __construct($dbName = 'default', $modelName = '\\Eater\\Glim\\Model\\Server', $modelAlias = null)
|
||||||
|
{
|
||||||
|
parent::__construct($dbName, $modelName, $modelAlias);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a new ChildServerQuery object.
|
||||||
|
*
|
||||||
|
* @param string $modelAlias The alias of a model in the query
|
||||||
|
* @param Criteria $criteria Optional Criteria to build the query from
|
||||||
|
*
|
||||||
|
* @return ChildServerQuery
|
||||||
|
*/
|
||||||
|
public static function create($modelAlias = null, Criteria $criteria = null)
|
||||||
|
{
|
||||||
|
if ($criteria instanceof ChildServerQuery) {
|
||||||
|
return $criteria;
|
||||||
|
}
|
||||||
|
$query = new ChildServerQuery();
|
||||||
|
if (null !== $modelAlias) {
|
||||||
|
$query->setModelAlias($modelAlias);
|
||||||
|
}
|
||||||
|
if ($criteria instanceof Criteria) {
|
||||||
|
$query->mergeWith($criteria);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $query;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find object by primary key.
|
||||||
|
* Propel uses the instance pool to skip the database if the object exists.
|
||||||
|
* Go fast if the query is untouched.
|
||||||
|
*
|
||||||
|
* <code>
|
||||||
|
* $obj = $c->findPk(12, $con);
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param mixed $key Primary key to use for the query
|
||||||
|
* @param ConnectionInterface $con an optional connection object
|
||||||
|
*
|
||||||
|
* @return ChildServer|array|mixed the result, formatted by the current formatter
|
||||||
|
*/
|
||||||
|
public function findPk($key, ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if ($key === null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
if ((null !== ($obj = ServerTableMap::getInstanceFromPool((string) $key))) && !$this->formatter) {
|
||||||
|
// the object is already in the instance pool
|
||||||
|
return $obj;
|
||||||
|
}
|
||||||
|
if ($con === null) {
|
||||||
|
$con = Propel::getServiceContainer()->getReadConnection(ServerTableMap::DATABASE_NAME);
|
||||||
|
}
|
||||||
|
$this->basePreSelect($con);
|
||||||
|
if ($this->formatter || $this->modelAlias || $this->with || $this->select
|
||||||
|
|| $this->selectColumns || $this->asColumns || $this->selectModifiers
|
||||||
|
|| $this->map || $this->having || $this->joins) {
|
||||||
|
return $this->findPkComplex($key, $con);
|
||||||
|
} else {
|
||||||
|
return $this->findPkSimple($key, $con);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find object by primary key using raw SQL to go fast.
|
||||||
|
* Bypass doSelect() and the object formatter by using generated code.
|
||||||
|
*
|
||||||
|
* @param mixed $key Primary key to use for the query
|
||||||
|
* @param ConnectionInterface $con A connection object
|
||||||
|
*
|
||||||
|
* @throws \Propel\Runtime\Exception\PropelException
|
||||||
|
*
|
||||||
|
* @return ChildServer A model object, or null if the key is not found
|
||||||
|
*/
|
||||||
|
protected function findPkSimple($key, ConnectionInterface $con)
|
||||||
|
{
|
||||||
|
$sql = 'SELECT id, fqdn, fingerprint, public_key, certificate, location, speed, external_ip, internal_ip, netmask, first_dns, second_dns, port, protocol, status FROM Server WHERE id = :p0';
|
||||||
|
try {
|
||||||
|
$stmt = $con->prepare($sql);
|
||||||
|
$stmt->bindValue(':p0', $key, PDO::PARAM_INT);
|
||||||
|
$stmt->execute();
|
||||||
|
} catch (Exception $e) {
|
||||||
|
Propel::log($e->getMessage(), Propel::LOG_ERR);
|
||||||
|
throw new PropelException(sprintf('Unable to execute SELECT statement [%s]', $sql), 0, $e);
|
||||||
|
}
|
||||||
|
$obj = null;
|
||||||
|
if ($row = $stmt->fetch(\PDO::FETCH_NUM)) {
|
||||||
|
/** @var ChildServer $obj */
|
||||||
|
$obj = new ChildServer();
|
||||||
|
$obj->hydrate($row);
|
||||||
|
ServerTableMap::addInstanceToPool($obj, (string) $key);
|
||||||
|
}
|
||||||
|
$stmt->closeCursor();
|
||||||
|
|
||||||
|
return $obj;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find object by primary key.
|
||||||
|
*
|
||||||
|
* @param mixed $key Primary key to use for the query
|
||||||
|
* @param ConnectionInterface $con A connection object
|
||||||
|
*
|
||||||
|
* @return ChildServer|array|mixed the result, formatted by the current formatter
|
||||||
|
*/
|
||||||
|
protected function findPkComplex($key, ConnectionInterface $con)
|
||||||
|
{
|
||||||
|
// As the query uses a PK condition, no limit(1) is necessary.
|
||||||
|
$criteria = $this->isKeepQuery() ? clone $this : $this;
|
||||||
|
$dataFetcher = $criteria
|
||||||
|
->filterByPrimaryKey($key)
|
||||||
|
->doSelect($con);
|
||||||
|
|
||||||
|
return $criteria->getFormatter()->init($criteria)->formatOne($dataFetcher);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Find objects by primary key
|
||||||
|
* <code>
|
||||||
|
* $objs = $c->findPks(array(12, 56, 832), $con);
|
||||||
|
* </code>
|
||||||
|
* @param array $keys Primary keys to use for the query
|
||||||
|
* @param ConnectionInterface $con an optional connection object
|
||||||
|
*
|
||||||
|
* @return ObjectCollection|array|mixed the list of results, formatted by the current formatter
|
||||||
|
*/
|
||||||
|
public function findPks($keys, ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if (null === $con) {
|
||||||
|
$con = Propel::getServiceContainer()->getReadConnection($this->getDbName());
|
||||||
|
}
|
||||||
|
$this->basePreSelect($con);
|
||||||
|
$criteria = $this->isKeepQuery() ? clone $this : $this;
|
||||||
|
$dataFetcher = $criteria
|
||||||
|
->filterByPrimaryKeys($keys)
|
||||||
|
->doSelect($con);
|
||||||
|
|
||||||
|
return $criteria->getFormatter()->init($criteria)->format($dataFetcher);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query by primary key
|
||||||
|
*
|
||||||
|
* @param mixed $key Primary key to use for the query
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByPrimaryKey($key)
|
||||||
|
{
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_ID, $key, Criteria::EQUAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query by a list of primary keys
|
||||||
|
*
|
||||||
|
* @param array $keys The list of primary key to use for the query
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByPrimaryKeys($keys)
|
||||||
|
{
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_ID, $keys, Criteria::IN);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the id column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterById(1234); // WHERE id = 1234
|
||||||
|
* $query->filterById(array(12, 34)); // WHERE id IN (12, 34)
|
||||||
|
* $query->filterById(array('min' => 12)); // WHERE id > 12
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param mixed $id The value to use as filter.
|
||||||
|
* Use scalar values for equality.
|
||||||
|
* Use array values for in_array() equivalent.
|
||||||
|
* Use associative array('min' => $minValue, 'max' => $maxValue) for intervals.
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterById($id = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (is_array($id)) {
|
||||||
|
$useMinMax = false;
|
||||||
|
if (isset($id['min'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_ID, $id['min'], Criteria::GREATER_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if (isset($id['max'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_ID, $id['max'], Criteria::LESS_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if ($useMinMax) {
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_ID, $id, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the fqdn column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByFqdn('fooValue'); // WHERE fqdn = 'fooValue'
|
||||||
|
* $query->filterByFqdn('%fooValue%'); // WHERE fqdn LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $fqdn The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByFqdn($fqdn = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($fqdn)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $fqdn)) {
|
||||||
|
$fqdn = str_replace('*', '%', $fqdn);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_FQDN, $fqdn, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the fingerprint column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByFingerprint('fooValue'); // WHERE fingerprint = 'fooValue'
|
||||||
|
* $query->filterByFingerprint('%fooValue%'); // WHERE fingerprint LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $fingerprint The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByFingerprint($fingerprint = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($fingerprint)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $fingerprint)) {
|
||||||
|
$fingerprint = str_replace('*', '%', $fingerprint);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_FINGERPRINT, $fingerprint, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the public_key column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByPublicKey('fooValue'); // WHERE public_key = 'fooValue'
|
||||||
|
* $query->filterByPublicKey('%fooValue%'); // WHERE public_key LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $publicKey The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByPublicKey($publicKey = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($publicKey)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $publicKey)) {
|
||||||
|
$publicKey = str_replace('*', '%', $publicKey);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_PUBLIC_KEY, $publicKey, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the certificate column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByCertificate('fooValue'); // WHERE certificate = 'fooValue'
|
||||||
|
* $query->filterByCertificate('%fooValue%'); // WHERE certificate LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $certificate The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByCertificate($certificate = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($certificate)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $certificate)) {
|
||||||
|
$certificate = str_replace('*', '%', $certificate);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_CERTIFICATE, $certificate, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the location column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByLocation('fooValue'); // WHERE location = 'fooValue'
|
||||||
|
* $query->filterByLocation('%fooValue%'); // WHERE location LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $location The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByLocation($location = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($location)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $location)) {
|
||||||
|
$location = str_replace('*', '%', $location);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_LOCATION, $location, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the speed column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterBySpeed(1234); // WHERE speed = 1234
|
||||||
|
* $query->filterBySpeed(array(12, 34)); // WHERE speed IN (12, 34)
|
||||||
|
* $query->filterBySpeed(array('min' => 12)); // WHERE speed > 12
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param mixed $speed The value to use as filter.
|
||||||
|
* Use scalar values for equality.
|
||||||
|
* Use array values for in_array() equivalent.
|
||||||
|
* Use associative array('min' => $minValue, 'max' => $maxValue) for intervals.
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterBySpeed($speed = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (is_array($speed)) {
|
||||||
|
$useMinMax = false;
|
||||||
|
if (isset($speed['min'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_SPEED, $speed['min'], Criteria::GREATER_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if (isset($speed['max'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_SPEED, $speed['max'], Criteria::LESS_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if ($useMinMax) {
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_SPEED, $speed, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the external_ip column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByExternalIp('fooValue'); // WHERE external_ip = 'fooValue'
|
||||||
|
* $query->filterByExternalIp('%fooValue%'); // WHERE external_ip LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $externalIp The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByExternalIp($externalIp = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($externalIp)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $externalIp)) {
|
||||||
|
$externalIp = str_replace('*', '%', $externalIp);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_EXTERNAL_IP, $externalIp, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the internal_ip column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByInternalIp('fooValue'); // WHERE internal_ip = 'fooValue'
|
||||||
|
* $query->filterByInternalIp('%fooValue%'); // WHERE internal_ip LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $internalIp The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByInternalIp($internalIp = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($internalIp)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $internalIp)) {
|
||||||
|
$internalIp = str_replace('*', '%', $internalIp);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_INTERNAL_IP, $internalIp, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the netmask column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByNetmask(1234); // WHERE netmask = 1234
|
||||||
|
* $query->filterByNetmask(array(12, 34)); // WHERE netmask IN (12, 34)
|
||||||
|
* $query->filterByNetmask(array('min' => 12)); // WHERE netmask > 12
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param mixed $netmask The value to use as filter.
|
||||||
|
* Use scalar values for equality.
|
||||||
|
* Use array values for in_array() equivalent.
|
||||||
|
* Use associative array('min' => $minValue, 'max' => $maxValue) for intervals.
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByNetmask($netmask = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (is_array($netmask)) {
|
||||||
|
$useMinMax = false;
|
||||||
|
if (isset($netmask['min'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_NETMASK, $netmask['min'], Criteria::GREATER_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if (isset($netmask['max'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_NETMASK, $netmask['max'], Criteria::LESS_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if ($useMinMax) {
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_NETMASK, $netmask, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the first_dns column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByFirstDns('fooValue'); // WHERE first_dns = 'fooValue'
|
||||||
|
* $query->filterByFirstDns('%fooValue%'); // WHERE first_dns LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $firstDns The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByFirstDns($firstDns = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($firstDns)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $firstDns)) {
|
||||||
|
$firstDns = str_replace('*', '%', $firstDns);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_FIRST_DNS, $firstDns, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the second_dns column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterBySecondDns('fooValue'); // WHERE second_dns = 'fooValue'
|
||||||
|
* $query->filterBySecondDns('%fooValue%'); // WHERE second_dns LIKE '%fooValue%'
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param string $secondDns The value to use as filter.
|
||||||
|
* Accepts wildcards (* and % trigger a LIKE)
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterBySecondDns($secondDns = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (null === $comparison) {
|
||||||
|
if (is_array($secondDns)) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
} elseif (preg_match('/[\%\*]/', $secondDns)) {
|
||||||
|
$secondDns = str_replace('*', '%', $secondDns);
|
||||||
|
$comparison = Criteria::LIKE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_SECOND_DNS, $secondDns, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the port column
|
||||||
|
*
|
||||||
|
* Example usage:
|
||||||
|
* <code>
|
||||||
|
* $query->filterByPort(1234); // WHERE port = 1234
|
||||||
|
* $query->filterByPort(array(12, 34)); // WHERE port IN (12, 34)
|
||||||
|
* $query->filterByPort(array('min' => 12)); // WHERE port > 12
|
||||||
|
* </code>
|
||||||
|
*
|
||||||
|
* @param mixed $port The value to use as filter.
|
||||||
|
* Use scalar values for equality.
|
||||||
|
* Use array values for in_array() equivalent.
|
||||||
|
* Use associative array('min' => $minValue, 'max' => $maxValue) for intervals.
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByPort($port = null, $comparison = null)
|
||||||
|
{
|
||||||
|
if (is_array($port)) {
|
||||||
|
$useMinMax = false;
|
||||||
|
if (isset($port['min'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_PORT, $port['min'], Criteria::GREATER_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if (isset($port['max'])) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_PORT, $port['max'], Criteria::LESS_EQUAL);
|
||||||
|
$useMinMax = true;
|
||||||
|
}
|
||||||
|
if ($useMinMax) {
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_PORT, $port, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the protocol column
|
||||||
|
*
|
||||||
|
* @param mixed $protocol The value to use as filter
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByProtocol($protocol = null, $comparison = null)
|
||||||
|
{
|
||||||
|
$valueSet = ServerTableMap::getValueSet(ServerTableMap::COL_PROTOCOL);
|
||||||
|
if (is_scalar($protocol)) {
|
||||||
|
if (!in_array($protocol, $valueSet)) {
|
||||||
|
throw new PropelException(sprintf('Value "%s" is not accepted in this enumerated column', $protocol));
|
||||||
|
}
|
||||||
|
$protocol = array_search($protocol, $valueSet);
|
||||||
|
} elseif (is_array($protocol)) {
|
||||||
|
$convertedValues = array();
|
||||||
|
foreach ($protocol as $value) {
|
||||||
|
if (!in_array($value, $valueSet)) {
|
||||||
|
throw new PropelException(sprintf('Value "%s" is not accepted in this enumerated column', $value));
|
||||||
|
}
|
||||||
|
$convertedValues []= array_search($value, $valueSet);
|
||||||
|
}
|
||||||
|
$protocol = $convertedValues;
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_PROTOCOL, $protocol, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filter the query on the status column
|
||||||
|
*
|
||||||
|
* @param mixed $status The value to use as filter
|
||||||
|
* @param string $comparison Operator to use for the column comparison, defaults to Criteria::EQUAL
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function filterByStatus($status = null, $comparison = null)
|
||||||
|
{
|
||||||
|
$valueSet = ServerTableMap::getValueSet(ServerTableMap::COL_STATUS);
|
||||||
|
if (is_scalar($status)) {
|
||||||
|
if (!in_array($status, $valueSet)) {
|
||||||
|
throw new PropelException(sprintf('Value "%s" is not accepted in this enumerated column', $status));
|
||||||
|
}
|
||||||
|
$status = array_search($status, $valueSet);
|
||||||
|
} elseif (is_array($status)) {
|
||||||
|
$convertedValues = array();
|
||||||
|
foreach ($status as $value) {
|
||||||
|
if (!in_array($value, $valueSet)) {
|
||||||
|
throw new PropelException(sprintf('Value "%s" is not accepted in this enumerated column', $value));
|
||||||
|
}
|
||||||
|
$convertedValues []= array_search($value, $valueSet);
|
||||||
|
}
|
||||||
|
$status = $convertedValues;
|
||||||
|
if (null === $comparison) {
|
||||||
|
$comparison = Criteria::IN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->addUsingAlias(ServerTableMap::COL_STATUS, $status, $comparison);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Exclude object from result
|
||||||
|
*
|
||||||
|
* @param ChildServer $server Object to remove from the list of results
|
||||||
|
*
|
||||||
|
* @return $this|ChildServerQuery The current query, for fluid interface
|
||||||
|
*/
|
||||||
|
public function prune($server = null)
|
||||||
|
{
|
||||||
|
if ($server) {
|
||||||
|
$this->addUsingAlias(ServerTableMap::COL_ID, $server->getId(), Criteria::NOT_EQUAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes all rows from the Server table.
|
||||||
|
*
|
||||||
|
* @param ConnectionInterface $con the connection to use
|
||||||
|
* @return int The number of affected rows (if supported by underlying database driver).
|
||||||
|
*/
|
||||||
|
public function doDeleteAll(ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if (null === $con) {
|
||||||
|
$con = Propel::getServiceContainer()->getWriteConnection(ServerTableMap::DATABASE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
// use transaction because $criteria could contain info
|
||||||
|
// for more than one table or we could emulating ON DELETE CASCADE, etc.
|
||||||
|
return $con->transaction(function () use ($con) {
|
||||||
|
$affectedRows = 0; // initialize var to track total num of affected rows
|
||||||
|
$affectedRows += parent::doDeleteAll($con);
|
||||||
|
// Because this db requires some delete cascade/set null emulation, we have to
|
||||||
|
// clear the cached instance *after* the emulation has happened (since
|
||||||
|
// instances get re-added by the select statement contained therein).
|
||||||
|
ServerTableMap::clearInstancePool();
|
||||||
|
ServerTableMap::clearRelatedInstancePool();
|
||||||
|
|
||||||
|
return $affectedRows;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs a DELETE on the database based on the current ModelCriteria
|
||||||
|
*
|
||||||
|
* @param ConnectionInterface $con the connection to use
|
||||||
|
* @return int The number of affected rows (if supported by underlying database driver). This includes CASCADE-related rows
|
||||||
|
* if supported by native driver or if emulated using Propel.
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public function delete(ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if (null === $con) {
|
||||||
|
$con = Propel::getServiceContainer()->getWriteConnection(ServerTableMap::DATABASE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
$criteria = $this;
|
||||||
|
|
||||||
|
// Set the correct dbName
|
||||||
|
$criteria->setDbName(ServerTableMap::DATABASE_NAME);
|
||||||
|
|
||||||
|
// use transaction because $criteria could contain info
|
||||||
|
// for more than one table or we could emulating ON DELETE CASCADE, etc.
|
||||||
|
return $con->transaction(function () use ($con, $criteria) {
|
||||||
|
$affectedRows = 0; // initialize var to track total num of affected rows
|
||||||
|
|
||||||
|
ServerTableMap::removeInstanceFromPool($criteria);
|
||||||
|
|
||||||
|
$affectedRows += ModelCriteria::delete($con);
|
||||||
|
ServerTableMap::clearRelatedInstancePool();
|
||||||
|
|
||||||
|
return $affectedRows;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
} // ServerQuery
|
|
@ -16,5 +16,16 @@ use Eater\Glim\Model\Base\CertificateQuery as BaseCertificateQuery;
|
||||||
*/
|
*/
|
||||||
class CertificateQuery extends BaseCertificateQuery
|
class CertificateQuery extends BaseCertificateQuery
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* @param User $user
|
||||||
|
* @param string $name
|
||||||
|
* @throws \Propel\Runtime\Exception\PropelException
|
||||||
|
* @return Certificate
|
||||||
|
*/
|
||||||
|
public function findOneByUserAndName($user, $name)
|
||||||
|
{
|
||||||
|
return $this->filterByName($name)
|
||||||
|
->filterByUser($user)
|
||||||
|
->findOne();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,7 +59,7 @@ class CertificateTableMap extends TableMap
|
||||||
/**
|
/**
|
||||||
* The total number of columns
|
* The total number of columns
|
||||||
*/
|
*/
|
||||||
const NUM_COLUMNS = 7;
|
const NUM_COLUMNS = 8;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The number of lazy-loaded columns
|
* The number of lazy-loaded columns
|
||||||
|
@ -69,7 +69,7 @@ class CertificateTableMap extends TableMap
|
||||||
/**
|
/**
|
||||||
* The number of columns to hydrate (NUM_COLUMNS - NUM_LAZY_LOAD_COLUMNS)
|
* The number of columns to hydrate (NUM_COLUMNS - NUM_LAZY_LOAD_COLUMNS)
|
||||||
*/
|
*/
|
||||||
const NUM_HYDRATE_COLUMNS = 7;
|
const NUM_HYDRATE_COLUMNS = 8;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the column name for the id field
|
* the column name for the id field
|
||||||
|
@ -91,6 +91,11 @@ class CertificateTableMap extends TableMap
|
||||||
*/
|
*/
|
||||||
const COL_CERTIFICATE = 'Certificate.certificate';
|
const COL_CERTIFICATE = 'Certificate.certificate';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the private_key field
|
||||||
|
*/
|
||||||
|
const COL_PRIVATE_KEY = 'Certificate.private_key';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the column name for the expires_on field
|
* the column name for the expires_on field
|
||||||
*/
|
*/
|
||||||
|
@ -118,11 +123,11 @@ class CertificateTableMap extends TableMap
|
||||||
* e.g. self::$fieldNames[self::TYPE_PHPNAME][0] = 'Id'
|
* e.g. self::$fieldNames[self::TYPE_PHPNAME][0] = 'Id'
|
||||||
*/
|
*/
|
||||||
protected static $fieldNames = array (
|
protected static $fieldNames = array (
|
||||||
self::TYPE_PHPNAME => array('Id', 'UserId', 'Name', 'Certificate', 'ExpiresOn', 'Revoked', 'Serial', ),
|
self::TYPE_PHPNAME => array('Id', 'UserId', 'Name', 'Certificate', 'PrivateKey', 'ExpiresOn', 'Revoked', 'Serial', ),
|
||||||
self::TYPE_CAMELNAME => array('id', 'userId', 'name', 'certificate', 'expiresOn', 'revoked', 'serial', ),
|
self::TYPE_CAMELNAME => array('id', 'userId', 'name', 'certificate', 'privateKey', 'expiresOn', 'revoked', 'serial', ),
|
||||||
self::TYPE_COLNAME => array(CertificateTableMap::COL_ID, CertificateTableMap::COL_USER_ID, CertificateTableMap::COL_NAME, CertificateTableMap::COL_CERTIFICATE, CertificateTableMap::COL_EXPIRES_ON, CertificateTableMap::COL_REVOKED, CertificateTableMap::COL_SERIAL, ),
|
self::TYPE_COLNAME => array(CertificateTableMap::COL_ID, CertificateTableMap::COL_USER_ID, CertificateTableMap::COL_NAME, CertificateTableMap::COL_CERTIFICATE, CertificateTableMap::COL_PRIVATE_KEY, CertificateTableMap::COL_EXPIRES_ON, CertificateTableMap::COL_REVOKED, CertificateTableMap::COL_SERIAL, ),
|
||||||
self::TYPE_FIELDNAME => array('id', 'user_id', 'name', 'certificate', 'expires_on', 'revoked', 'serial', ),
|
self::TYPE_FIELDNAME => array('id', 'user_id', 'name', 'certificate', 'private_key', 'expires_on', 'revoked', 'serial', ),
|
||||||
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, )
|
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, 7, )
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -132,11 +137,11 @@ class CertificateTableMap extends TableMap
|
||||||
* e.g. self::$fieldKeys[self::TYPE_PHPNAME]['Id'] = 0
|
* e.g. self::$fieldKeys[self::TYPE_PHPNAME]['Id'] = 0
|
||||||
*/
|
*/
|
||||||
protected static $fieldKeys = array (
|
protected static $fieldKeys = array (
|
||||||
self::TYPE_PHPNAME => array('Id' => 0, 'UserId' => 1, 'Name' => 2, 'Certificate' => 3, 'ExpiresOn' => 4, 'Revoked' => 5, 'Serial' => 6, ),
|
self::TYPE_PHPNAME => array('Id' => 0, 'UserId' => 1, 'Name' => 2, 'Certificate' => 3, 'PrivateKey' => 4, 'ExpiresOn' => 5, 'Revoked' => 6, 'Serial' => 7, ),
|
||||||
self::TYPE_CAMELNAME => array('id' => 0, 'userId' => 1, 'name' => 2, 'certificate' => 3, 'expiresOn' => 4, 'revoked' => 5, 'serial' => 6, ),
|
self::TYPE_CAMELNAME => array('id' => 0, 'userId' => 1, 'name' => 2, 'certificate' => 3, 'privateKey' => 4, 'expiresOn' => 5, 'revoked' => 6, 'serial' => 7, ),
|
||||||
self::TYPE_COLNAME => array(CertificateTableMap::COL_ID => 0, CertificateTableMap::COL_USER_ID => 1, CertificateTableMap::COL_NAME => 2, CertificateTableMap::COL_CERTIFICATE => 3, CertificateTableMap::COL_EXPIRES_ON => 4, CertificateTableMap::COL_REVOKED => 5, CertificateTableMap::COL_SERIAL => 6, ),
|
self::TYPE_COLNAME => array(CertificateTableMap::COL_ID => 0, CertificateTableMap::COL_USER_ID => 1, CertificateTableMap::COL_NAME => 2, CertificateTableMap::COL_CERTIFICATE => 3, CertificateTableMap::COL_PRIVATE_KEY => 4, CertificateTableMap::COL_EXPIRES_ON => 5, CertificateTableMap::COL_REVOKED => 6, CertificateTableMap::COL_SERIAL => 7, ),
|
||||||
self::TYPE_FIELDNAME => array('id' => 0, 'user_id' => 1, 'name' => 2, 'certificate' => 3, 'expires_on' => 4, 'revoked' => 5, 'serial' => 6, ),
|
self::TYPE_FIELDNAME => array('id' => 0, 'user_id' => 1, 'name' => 2, 'certificate' => 3, 'private_key' => 4, 'expires_on' => 5, 'revoked' => 6, 'serial' => 7, ),
|
||||||
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, )
|
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, 7, )
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -160,6 +165,7 @@ class CertificateTableMap extends TableMap
|
||||||
$this->addForeignKey('user_id', 'UserId', 'INTEGER', 'User', 'id', false, null, null);
|
$this->addForeignKey('user_id', 'UserId', 'INTEGER', 'User', 'id', false, null, null);
|
||||||
$this->addColumn('name', 'Name', 'VARCHAR', false, 64, null);
|
$this->addColumn('name', 'Name', 'VARCHAR', false, 64, null);
|
||||||
$this->addColumn('certificate', 'Certificate', 'LONGVARCHAR', false, null, null);
|
$this->addColumn('certificate', 'Certificate', 'LONGVARCHAR', false, null, null);
|
||||||
|
$this->addColumn('private_key', 'PrivateKey', 'LONGVARCHAR', false, null, null);
|
||||||
$this->addColumn('expires_on', 'ExpiresOn', 'TIMESTAMP', false, null, null);
|
$this->addColumn('expires_on', 'ExpiresOn', 'TIMESTAMP', false, null, null);
|
||||||
$this->addColumn('revoked', 'Revoked', 'BOOLEAN', false, null, false);
|
$this->addColumn('revoked', 'Revoked', 'BOOLEAN', false, null, false);
|
||||||
$this->addColumn('serial', 'Serial', 'VARCHAR', false, 64, null);
|
$this->addColumn('serial', 'Serial', 'VARCHAR', false, 64, null);
|
||||||
|
@ -324,6 +330,7 @@ class CertificateTableMap extends TableMap
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_USER_ID);
|
$criteria->addSelectColumn(CertificateTableMap::COL_USER_ID);
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_NAME);
|
$criteria->addSelectColumn(CertificateTableMap::COL_NAME);
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_CERTIFICATE);
|
$criteria->addSelectColumn(CertificateTableMap::COL_CERTIFICATE);
|
||||||
|
$criteria->addSelectColumn(CertificateTableMap::COL_PRIVATE_KEY);
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_EXPIRES_ON);
|
$criteria->addSelectColumn(CertificateTableMap::COL_EXPIRES_ON);
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_REVOKED);
|
$criteria->addSelectColumn(CertificateTableMap::COL_REVOKED);
|
||||||
$criteria->addSelectColumn(CertificateTableMap::COL_SERIAL);
|
$criteria->addSelectColumn(CertificateTableMap::COL_SERIAL);
|
||||||
|
@ -332,6 +339,7 @@ class CertificateTableMap extends TableMap
|
||||||
$criteria->addSelectColumn($alias . '.user_id');
|
$criteria->addSelectColumn($alias . '.user_id');
|
||||||
$criteria->addSelectColumn($alias . '.name');
|
$criteria->addSelectColumn($alias . '.name');
|
||||||
$criteria->addSelectColumn($alias . '.certificate');
|
$criteria->addSelectColumn($alias . '.certificate');
|
||||||
|
$criteria->addSelectColumn($alias . '.private_key');
|
||||||
$criteria->addSelectColumn($alias . '.expires_on');
|
$criteria->addSelectColumn($alias . '.expires_on');
|
||||||
$criteria->addSelectColumn($alias . '.revoked');
|
$criteria->addSelectColumn($alias . '.revoked');
|
||||||
$criteria->addSelectColumn($alias . '.serial');
|
$criteria->addSelectColumn($alias . '.serial');
|
||||||
|
|
564
src/Model/Map/ServerTableMap.php
Normal file
564
src/Model/Map/ServerTableMap.php
Normal file
|
@ -0,0 +1,564 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Model\Map;
|
||||||
|
|
||||||
|
use Eater\Glim\Model\Server;
|
||||||
|
use Eater\Glim\Model\ServerQuery;
|
||||||
|
use Propel\Runtime\Propel;
|
||||||
|
use Propel\Runtime\ActiveQuery\Criteria;
|
||||||
|
use Propel\Runtime\ActiveQuery\InstancePoolTrait;
|
||||||
|
use Propel\Runtime\Connection\ConnectionInterface;
|
||||||
|
use Propel\Runtime\DataFetcher\DataFetcherInterface;
|
||||||
|
use Propel\Runtime\Exception\PropelException;
|
||||||
|
use Propel\Runtime\Map\RelationMap;
|
||||||
|
use Propel\Runtime\Map\TableMap;
|
||||||
|
use Propel\Runtime\Map\TableMapTrait;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class defines the structure of the 'Server' table.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* This map class is used by Propel to do runtime db structure discovery.
|
||||||
|
* For example, the createSelectSql() method checks the type of a given column used in an
|
||||||
|
* ORDER BY clause to know whether it needs to apply SQL to make the ORDER BY case-insensitive
|
||||||
|
* (i.e. if it's a text column type).
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class ServerTableMap extends TableMap
|
||||||
|
{
|
||||||
|
use InstancePoolTrait;
|
||||||
|
use TableMapTrait;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The (dot-path) name of this class
|
||||||
|
*/
|
||||||
|
const CLASS_NAME = '.Map.ServerTableMap';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default database name for this class
|
||||||
|
*/
|
||||||
|
const DATABASE_NAME = 'default';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The table name for this class
|
||||||
|
*/
|
||||||
|
const TABLE_NAME = 'Server';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The related Propel class for this table
|
||||||
|
*/
|
||||||
|
const OM_CLASS = '\\Eater\\Glim\\Model\\Server';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A class that can be returned by this tableMap
|
||||||
|
*/
|
||||||
|
const CLASS_DEFAULT = 'Server';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The total number of columns
|
||||||
|
*/
|
||||||
|
const NUM_COLUMNS = 15;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of lazy-loaded columns
|
||||||
|
*/
|
||||||
|
const NUM_LAZY_LOAD_COLUMNS = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of columns to hydrate (NUM_COLUMNS - NUM_LAZY_LOAD_COLUMNS)
|
||||||
|
*/
|
||||||
|
const NUM_HYDRATE_COLUMNS = 15;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the id field
|
||||||
|
*/
|
||||||
|
const COL_ID = 'Server.id';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the fqdn field
|
||||||
|
*/
|
||||||
|
const COL_FQDN = 'Server.fqdn';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the fingerprint field
|
||||||
|
*/
|
||||||
|
const COL_FINGERPRINT = 'Server.fingerprint';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the public_key field
|
||||||
|
*/
|
||||||
|
const COL_PUBLIC_KEY = 'Server.public_key';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the certificate field
|
||||||
|
*/
|
||||||
|
const COL_CERTIFICATE = 'Server.certificate';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the location field
|
||||||
|
*/
|
||||||
|
const COL_LOCATION = 'Server.location';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the speed field
|
||||||
|
*/
|
||||||
|
const COL_SPEED = 'Server.speed';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the external_ip field
|
||||||
|
*/
|
||||||
|
const COL_EXTERNAL_IP = 'Server.external_ip';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the internal_ip field
|
||||||
|
*/
|
||||||
|
const COL_INTERNAL_IP = 'Server.internal_ip';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the netmask field
|
||||||
|
*/
|
||||||
|
const COL_NETMASK = 'Server.netmask';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the first_dns field
|
||||||
|
*/
|
||||||
|
const COL_FIRST_DNS = 'Server.first_dns';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the second_dns field
|
||||||
|
*/
|
||||||
|
const COL_SECOND_DNS = 'Server.second_dns';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the port field
|
||||||
|
*/
|
||||||
|
const COL_PORT = 'Server.port';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the protocol field
|
||||||
|
*/
|
||||||
|
const COL_PROTOCOL = 'Server.protocol';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the column name for the status field
|
||||||
|
*/
|
||||||
|
const COL_STATUS = 'Server.status';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default string format for model objects of the related table
|
||||||
|
*/
|
||||||
|
const DEFAULT_STRING_FORMAT = 'YAML';
|
||||||
|
|
||||||
|
/** The enumerated values for the protocol field */
|
||||||
|
const COL_PROTOCOL_UDP = 'udp';
|
||||||
|
const COL_PROTOCOL_TCP = 'tcp';
|
||||||
|
|
||||||
|
/** The enumerated values for the status field */
|
||||||
|
const COL_STATUS_REGISTERED = 'registered';
|
||||||
|
const COL_STATUS_SIGNED = 'signed';
|
||||||
|
const COL_STATUS_REVOKED = 'revoked';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* holds an array of fieldnames
|
||||||
|
*
|
||||||
|
* first dimension keys are the type constants
|
||||||
|
* e.g. self::$fieldNames[self::TYPE_PHPNAME][0] = 'Id'
|
||||||
|
*/
|
||||||
|
protected static $fieldNames = array (
|
||||||
|
self::TYPE_PHPNAME => array('Id', 'Fqdn', 'Fingerprint', 'PublicKey', 'Certificate', 'Location', 'Speed', 'ExternalIp', 'InternalIp', 'Netmask', 'FirstDns', 'SecondDns', 'Port', 'Protocol', 'Status', ),
|
||||||
|
self::TYPE_CAMELNAME => array('id', 'fqdn', 'fingerprint', 'publicKey', 'certificate', 'location', 'speed', 'externalIp', 'internalIp', 'netmask', 'firstDns', 'secondDns', 'port', 'protocol', 'status', ),
|
||||||
|
self::TYPE_COLNAME => array(ServerTableMap::COL_ID, ServerTableMap::COL_FQDN, ServerTableMap::COL_FINGERPRINT, ServerTableMap::COL_PUBLIC_KEY, ServerTableMap::COL_CERTIFICATE, ServerTableMap::COL_LOCATION, ServerTableMap::COL_SPEED, ServerTableMap::COL_EXTERNAL_IP, ServerTableMap::COL_INTERNAL_IP, ServerTableMap::COL_NETMASK, ServerTableMap::COL_FIRST_DNS, ServerTableMap::COL_SECOND_DNS, ServerTableMap::COL_PORT, ServerTableMap::COL_PROTOCOL, ServerTableMap::COL_STATUS, ),
|
||||||
|
self::TYPE_FIELDNAME => array('id', 'fqdn', 'fingerprint', 'public_key', 'certificate', 'location', 'speed', 'external_ip', 'internal_ip', 'netmask', 'first_dns', 'second_dns', 'port', 'protocol', 'status', ),
|
||||||
|
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, )
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* holds an array of keys for quick access to the fieldnames array
|
||||||
|
*
|
||||||
|
* first dimension keys are the type constants
|
||||||
|
* e.g. self::$fieldKeys[self::TYPE_PHPNAME]['Id'] = 0
|
||||||
|
*/
|
||||||
|
protected static $fieldKeys = array (
|
||||||
|
self::TYPE_PHPNAME => array('Id' => 0, 'Fqdn' => 1, 'Fingerprint' => 2, 'PublicKey' => 3, 'Certificate' => 4, 'Location' => 5, 'Speed' => 6, 'ExternalIp' => 7, 'InternalIp' => 8, 'Netmask' => 9, 'FirstDns' => 10, 'SecondDns' => 11, 'Port' => 12, 'Protocol' => 13, 'Status' => 14, ),
|
||||||
|
self::TYPE_CAMELNAME => array('id' => 0, 'fqdn' => 1, 'fingerprint' => 2, 'publicKey' => 3, 'certificate' => 4, 'location' => 5, 'speed' => 6, 'externalIp' => 7, 'internalIp' => 8, 'netmask' => 9, 'firstDns' => 10, 'secondDns' => 11, 'port' => 12, 'protocol' => 13, 'status' => 14, ),
|
||||||
|
self::TYPE_COLNAME => array(ServerTableMap::COL_ID => 0, ServerTableMap::COL_FQDN => 1, ServerTableMap::COL_FINGERPRINT => 2, ServerTableMap::COL_PUBLIC_KEY => 3, ServerTableMap::COL_CERTIFICATE => 4, ServerTableMap::COL_LOCATION => 5, ServerTableMap::COL_SPEED => 6, ServerTableMap::COL_EXTERNAL_IP => 7, ServerTableMap::COL_INTERNAL_IP => 8, ServerTableMap::COL_NETMASK => 9, ServerTableMap::COL_FIRST_DNS => 10, ServerTableMap::COL_SECOND_DNS => 11, ServerTableMap::COL_PORT => 12, ServerTableMap::COL_PROTOCOL => 13, ServerTableMap::COL_STATUS => 14, ),
|
||||||
|
self::TYPE_FIELDNAME => array('id' => 0, 'fqdn' => 1, 'fingerprint' => 2, 'public_key' => 3, 'certificate' => 4, 'location' => 5, 'speed' => 6, 'external_ip' => 7, 'internal_ip' => 8, 'netmask' => 9, 'first_dns' => 10, 'second_dns' => 11, 'port' => 12, 'protocol' => 13, 'status' => 14, ),
|
||||||
|
self::TYPE_NUM => array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, )
|
||||||
|
);
|
||||||
|
|
||||||
|
/** The enumerated values for this table */
|
||||||
|
protected static $enumValueSets = array(
|
||||||
|
ServerTableMap::COL_PROTOCOL => array(
|
||||||
|
self::COL_PROTOCOL_UDP,
|
||||||
|
self::COL_PROTOCOL_TCP,
|
||||||
|
),
|
||||||
|
ServerTableMap::COL_STATUS => array(
|
||||||
|
self::COL_STATUS_REGISTERED,
|
||||||
|
self::COL_STATUS_SIGNED,
|
||||||
|
self::COL_STATUS_REVOKED,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the list of values for all ENUM columns
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function getValueSets()
|
||||||
|
{
|
||||||
|
return static::$enumValueSets;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the list of values for an ENUM column
|
||||||
|
* @param string $colname
|
||||||
|
* @return array list of possible values for the column
|
||||||
|
*/
|
||||||
|
public static function getValueSet($colname)
|
||||||
|
{
|
||||||
|
$valueSets = self::getValueSets();
|
||||||
|
|
||||||
|
return $valueSets[$colname];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the table attributes and columns
|
||||||
|
* Relations are not initialized by this method since they are lazy loaded
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
* @throws PropelException
|
||||||
|
*/
|
||||||
|
public function initialize()
|
||||||
|
{
|
||||||
|
// attributes
|
||||||
|
$this->setName('Server');
|
||||||
|
$this->setPhpName('Server');
|
||||||
|
$this->setIdentifierQuoting(false);
|
||||||
|
$this->setClassName('\\Eater\\Glim\\Model\\Server');
|
||||||
|
$this->setPackage('');
|
||||||
|
$this->setUseIdGenerator(true);
|
||||||
|
// columns
|
||||||
|
$this->addPrimaryKey('id', 'Id', 'INTEGER', true, null, null);
|
||||||
|
$this->addColumn('fqdn', 'Fqdn', 'VARCHAR', false, 64, null);
|
||||||
|
$this->addColumn('fingerprint', 'Fingerprint', 'VARCHAR', false, 64, null);
|
||||||
|
$this->addColumn('public_key', 'PublicKey', 'LONGVARCHAR', false, null, null);
|
||||||
|
$this->addColumn('certificate', 'Certificate', 'LONGVARCHAR', false, null, null);
|
||||||
|
$this->addColumn('location', 'Location', 'VARCHAR', false, 64, 'Unknown');
|
||||||
|
$this->addColumn('speed', 'Speed', 'INTEGER', false, null, -1);
|
||||||
|
$this->addColumn('external_ip', 'ExternalIp', 'VARCHAR', false, 128, null);
|
||||||
|
$this->addColumn('internal_ip', 'InternalIp', 'VARCHAR', false, 128, '10.24.0.0');
|
||||||
|
$this->addColumn('netmask', 'Netmask', 'INTEGER', false, 4, 16);
|
||||||
|
$this->addColumn('first_dns', 'FirstDns', 'VARCHAR', false, 128, null);
|
||||||
|
$this->addColumn('second_dns', 'SecondDns', 'VARCHAR', false, 128, null);
|
||||||
|
$this->addColumn('port', 'Port', 'INTEGER', false, null, 1194);
|
||||||
|
$this->addColumn('protocol', 'Protocol', 'ENUM', false, null, 'udp');
|
||||||
|
$this->getColumn('protocol')->setValueSet(array (
|
||||||
|
0 => 'udp',
|
||||||
|
1 => 'tcp',
|
||||||
|
));
|
||||||
|
$this->addColumn('status', 'Status', 'ENUM', false, null, 'registered');
|
||||||
|
$this->getColumn('status')->setValueSet(array (
|
||||||
|
0 => 'registered',
|
||||||
|
1 => 'signed',
|
||||||
|
2 => 'revoked',
|
||||||
|
));
|
||||||
|
} // initialize()
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build the RelationMap objects for this table relationships
|
||||||
|
*/
|
||||||
|
public function buildRelations()
|
||||||
|
{
|
||||||
|
} // buildRelations()
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves a string version of the primary key from the DB resultset row that can be used to uniquely identify a row in this table.
|
||||||
|
*
|
||||||
|
* For tables with a single-column primary key, that simple pkey value will be returned. For tables with
|
||||||
|
* a multi-column primary key, a serialize()d version of the primary key will be returned.
|
||||||
|
*
|
||||||
|
* @param array $row resultset row.
|
||||||
|
* @param int $offset The 0-based offset for reading from the resultset row.
|
||||||
|
* @param string $indexType One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_CAMELNAME
|
||||||
|
* TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM
|
||||||
|
*
|
||||||
|
* @return string The primary key hash of the row
|
||||||
|
*/
|
||||||
|
public static function getPrimaryKeyHashFromRow($row, $offset = 0, $indexType = TableMap::TYPE_NUM)
|
||||||
|
{
|
||||||
|
// If the PK cannot be derived from the row, return NULL.
|
||||||
|
if ($row[TableMap::TYPE_NUM == $indexType ? 0 + $offset : static::translateFieldName('Id', TableMap::TYPE_PHPNAME, $indexType)] === null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (string) $row[TableMap::TYPE_NUM == $indexType ? 0 + $offset : static::translateFieldName('Id', TableMap::TYPE_PHPNAME, $indexType)];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieves the primary key from the DB resultset row
|
||||||
|
* For tables with a single-column primary key, that simple pkey value will be returned. For tables with
|
||||||
|
* a multi-column primary key, an array of the primary key columns will be returned.
|
||||||
|
*
|
||||||
|
* @param array $row resultset row.
|
||||||
|
* @param int $offset The 0-based offset for reading from the resultset row.
|
||||||
|
* @param string $indexType One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_CAMELNAME
|
||||||
|
* TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM
|
||||||
|
*
|
||||||
|
* @return mixed The primary key of the row
|
||||||
|
*/
|
||||||
|
public static function getPrimaryKeyFromRow($row, $offset = 0, $indexType = TableMap::TYPE_NUM)
|
||||||
|
{
|
||||||
|
return (int) $row[
|
||||||
|
$indexType == TableMap::TYPE_NUM
|
||||||
|
? 0 + $offset
|
||||||
|
: self::translateFieldName('Id', TableMap::TYPE_PHPNAME, $indexType)
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class that the tableMap will make instances of.
|
||||||
|
*
|
||||||
|
* If $withPrefix is true, the returned path
|
||||||
|
* uses a dot-path notation which is translated into a path
|
||||||
|
* relative to a location on the PHP include_path.
|
||||||
|
* (e.g. path.to.MyClass -> 'path/to/MyClass.php')
|
||||||
|
*
|
||||||
|
* @param boolean $withPrefix Whether or not to return the path with the class name
|
||||||
|
* @return string path.to.ClassName
|
||||||
|
*/
|
||||||
|
public static function getOMClass($withPrefix = true)
|
||||||
|
{
|
||||||
|
return $withPrefix ? ServerTableMap::CLASS_DEFAULT : ServerTableMap::OM_CLASS;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Populates an object of the default type or an object that inherit from the default.
|
||||||
|
*
|
||||||
|
* @param array $row row returned by DataFetcher->fetch().
|
||||||
|
* @param int $offset The 0-based offset for reading from the resultset row.
|
||||||
|
* @param string $indexType The index type of $row. Mostly DataFetcher->getIndexType().
|
||||||
|
One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_CAMELNAME
|
||||||
|
* TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM.
|
||||||
|
*
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
* @return array (Server object, last column rank)
|
||||||
|
*/
|
||||||
|
public static function populateObject($row, $offset = 0, $indexType = TableMap::TYPE_NUM)
|
||||||
|
{
|
||||||
|
$key = ServerTableMap::getPrimaryKeyHashFromRow($row, $offset, $indexType);
|
||||||
|
if (null !== ($obj = ServerTableMap::getInstanceFromPool($key))) {
|
||||||
|
// We no longer rehydrate the object, since this can cause data loss.
|
||||||
|
// See http://www.propelorm.org/ticket/509
|
||||||
|
// $obj->hydrate($row, $offset, true); // rehydrate
|
||||||
|
$col = $offset + ServerTableMap::NUM_HYDRATE_COLUMNS;
|
||||||
|
} else {
|
||||||
|
$cls = ServerTableMap::OM_CLASS;
|
||||||
|
/** @var Server $obj */
|
||||||
|
$obj = new $cls();
|
||||||
|
$col = $obj->hydrate($row, $offset, false, $indexType);
|
||||||
|
ServerTableMap::addInstanceToPool($obj, $key);
|
||||||
|
}
|
||||||
|
|
||||||
|
return array($obj, $col);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The returned array will contain objects of the default type or
|
||||||
|
* objects that inherit from the default.
|
||||||
|
*
|
||||||
|
* @param DataFetcherInterface $dataFetcher
|
||||||
|
* @return array
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public static function populateObjects(DataFetcherInterface $dataFetcher)
|
||||||
|
{
|
||||||
|
$results = array();
|
||||||
|
|
||||||
|
// set the class once to avoid overhead in the loop
|
||||||
|
$cls = static::getOMClass(false);
|
||||||
|
// populate the object(s)
|
||||||
|
while ($row = $dataFetcher->fetch()) {
|
||||||
|
$key = ServerTableMap::getPrimaryKeyHashFromRow($row, 0, $dataFetcher->getIndexType());
|
||||||
|
if (null !== ($obj = ServerTableMap::getInstanceFromPool($key))) {
|
||||||
|
// We no longer rehydrate the object, since this can cause data loss.
|
||||||
|
// See http://www.propelorm.org/ticket/509
|
||||||
|
// $obj->hydrate($row, 0, true); // rehydrate
|
||||||
|
$results[] = $obj;
|
||||||
|
} else {
|
||||||
|
/** @var Server $obj */
|
||||||
|
$obj = new $cls();
|
||||||
|
$obj->hydrate($row);
|
||||||
|
$results[] = $obj;
|
||||||
|
ServerTableMap::addInstanceToPool($obj, $key);
|
||||||
|
} // if key exists
|
||||||
|
}
|
||||||
|
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Add all the columns needed to create a new object.
|
||||||
|
*
|
||||||
|
* Note: any columns that were marked with lazyLoad="true" in the
|
||||||
|
* XML schema will not be added to the select list and only loaded
|
||||||
|
* on demand.
|
||||||
|
*
|
||||||
|
* @param Criteria $criteria object containing the columns to add.
|
||||||
|
* @param string $alias optional table alias
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public static function addSelectColumns(Criteria $criteria, $alias = null)
|
||||||
|
{
|
||||||
|
if (null === $alias) {
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_ID);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_FQDN);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_FINGERPRINT);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_PUBLIC_KEY);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_CERTIFICATE);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_LOCATION);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_SPEED);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_EXTERNAL_IP);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_INTERNAL_IP);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_NETMASK);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_FIRST_DNS);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_SECOND_DNS);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_PORT);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_PROTOCOL);
|
||||||
|
$criteria->addSelectColumn(ServerTableMap::COL_STATUS);
|
||||||
|
} else {
|
||||||
|
$criteria->addSelectColumn($alias . '.id');
|
||||||
|
$criteria->addSelectColumn($alias . '.fqdn');
|
||||||
|
$criteria->addSelectColumn($alias . '.fingerprint');
|
||||||
|
$criteria->addSelectColumn($alias . '.public_key');
|
||||||
|
$criteria->addSelectColumn($alias . '.certificate');
|
||||||
|
$criteria->addSelectColumn($alias . '.location');
|
||||||
|
$criteria->addSelectColumn($alias . '.speed');
|
||||||
|
$criteria->addSelectColumn($alias . '.external_ip');
|
||||||
|
$criteria->addSelectColumn($alias . '.internal_ip');
|
||||||
|
$criteria->addSelectColumn($alias . '.netmask');
|
||||||
|
$criteria->addSelectColumn($alias . '.first_dns');
|
||||||
|
$criteria->addSelectColumn($alias . '.second_dns');
|
||||||
|
$criteria->addSelectColumn($alias . '.port');
|
||||||
|
$criteria->addSelectColumn($alias . '.protocol');
|
||||||
|
$criteria->addSelectColumn($alias . '.status');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the TableMap related to this object.
|
||||||
|
* This method is not needed for general use but a specific application could have a need.
|
||||||
|
* @return TableMap
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public static function getTableMap()
|
||||||
|
{
|
||||||
|
return Propel::getServiceContainer()->getDatabaseMap(ServerTableMap::DATABASE_NAME)->getTable(ServerTableMap::TABLE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a TableMap instance to the database for this tableMap class.
|
||||||
|
*/
|
||||||
|
public static function buildTableMap()
|
||||||
|
{
|
||||||
|
$dbMap = Propel::getServiceContainer()->getDatabaseMap(ServerTableMap::DATABASE_NAME);
|
||||||
|
if (!$dbMap->hasTable(ServerTableMap::TABLE_NAME)) {
|
||||||
|
$dbMap->addTableObject(new ServerTableMap());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs a DELETE on the database, given a Server or Criteria object OR a primary key value.
|
||||||
|
*
|
||||||
|
* @param mixed $values Criteria or Server object or primary key or array of primary keys
|
||||||
|
* which is used to create the DELETE statement
|
||||||
|
* @param ConnectionInterface $con the connection to use
|
||||||
|
* @return int The number of affected rows (if supported by underlying database driver). This includes CASCADE-related rows
|
||||||
|
* if supported by native driver or if emulated using Propel.
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public static function doDelete($values, ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if (null === $con) {
|
||||||
|
$con = Propel::getServiceContainer()->getWriteConnection(ServerTableMap::DATABASE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($values instanceof Criteria) {
|
||||||
|
// rename for clarity
|
||||||
|
$criteria = $values;
|
||||||
|
} elseif ($values instanceof \Eater\Glim\Model\Server) { // it's a model object
|
||||||
|
// create criteria based on pk values
|
||||||
|
$criteria = $values->buildPkeyCriteria();
|
||||||
|
} else { // it's a primary key, or an array of pks
|
||||||
|
$criteria = new Criteria(ServerTableMap::DATABASE_NAME);
|
||||||
|
$criteria->add(ServerTableMap::COL_ID, (array) $values, Criteria::IN);
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = ServerQuery::create()->mergeWith($criteria);
|
||||||
|
|
||||||
|
if ($values instanceof Criteria) {
|
||||||
|
ServerTableMap::clearInstancePool();
|
||||||
|
} elseif (!is_object($values)) { // it's a primary key, or an array of pks
|
||||||
|
foreach ((array) $values as $singleval) {
|
||||||
|
ServerTableMap::removeInstanceFromPool($singleval);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $query->delete($con);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes all rows from the Server table.
|
||||||
|
*
|
||||||
|
* @param ConnectionInterface $con the connection to use
|
||||||
|
* @return int The number of affected rows (if supported by underlying database driver).
|
||||||
|
*/
|
||||||
|
public static function doDeleteAll(ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
return ServerQuery::create()->doDeleteAll($con);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs an INSERT on the database, given a Server or Criteria object.
|
||||||
|
*
|
||||||
|
* @param mixed $criteria Criteria or Server object containing data that is used to create the INSERT statement.
|
||||||
|
* @param ConnectionInterface $con the ConnectionInterface connection to use
|
||||||
|
* @return mixed The new primary key.
|
||||||
|
* @throws PropelException Any exceptions caught during processing will be
|
||||||
|
* rethrown wrapped into a PropelException.
|
||||||
|
*/
|
||||||
|
public static function doInsert($criteria, ConnectionInterface $con = null)
|
||||||
|
{
|
||||||
|
if (null === $con) {
|
||||||
|
$con = Propel::getServiceContainer()->getWriteConnection(ServerTableMap::DATABASE_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($criteria instanceof Criteria) {
|
||||||
|
$criteria = clone $criteria; // rename for clarity
|
||||||
|
} else {
|
||||||
|
$criteria = $criteria->buildCriteria(); // build Criteria from Server object
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($criteria->containsKey(ServerTableMap::COL_ID) && $criteria->keyContainsValue(ServerTableMap::COL_ID) ) {
|
||||||
|
throw new PropelException('Cannot insert a value for auto-increment primary key ('.ServerTableMap::COL_ID.')');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Set the correct dbName
|
||||||
|
$query = ServerQuery::create()->mergeWith($criteria);
|
||||||
|
|
||||||
|
// use transaction because $criteria could contain info
|
||||||
|
// for more than one table (I guess, conceivably)
|
||||||
|
return $con->transaction(function () use ($con, $query) {
|
||||||
|
return $query->doInsert($con);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
} // ServerTableMap
|
||||||
|
// This is the static code needed to register the TableMap for this table with the main Propel class.
|
||||||
|
//
|
||||||
|
ServerTableMap::buildTableMap();
|
20
src/Model/Server.php
Normal file
20
src/Model/Server.php
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Model;
|
||||||
|
|
||||||
|
use Eater\Glim\Model\Base\Server as BaseServer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Skeleton subclass for representing a row from the 'Server' table.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* You should add additional methods to this class to meet the
|
||||||
|
* application requirements. This class will only be generated as
|
||||||
|
* long as it does not already exist in the output directory.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class Server extends BaseServer
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
20
src/Model/ServerQuery.php
Normal file
20
src/Model/ServerQuery.php
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Eater\Glim\Model;
|
||||||
|
|
||||||
|
use Eater\Glim\Model\Base\ServerQuery as BaseServerQuery;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Skeleton subclass for performing query and update operations on the 'Server' table.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* You should add additional methods to this class to meet the
|
||||||
|
* application requirements. This class will only be generated as
|
||||||
|
* long as it does not already exist in the output directory.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class ServerQuery extends BaseServerQuery
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
|
@ -30,6 +30,7 @@ class CA extends Main
|
||||||
* Signs a client certificate and returns the signed certificate
|
* Signs a client certificate and returns the signed certificate
|
||||||
* @param string $csr
|
* @param string $csr
|
||||||
* @return string
|
* @return string
|
||||||
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public function signClientCsr($csr)
|
public function signClientCsr($csr)
|
||||||
{
|
{
|
||||||
|
@ -55,6 +56,69 @@ class CA extends Main
|
||||||
return $crt;
|
return $crt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $publicKey
|
||||||
|
* @param string $fqdn
|
||||||
|
* @return string
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function createCSRForKeyAndFqdn($publicKey, $fqdn)
|
||||||
|
{
|
||||||
|
/** @var Core $core */
|
||||||
|
$core = $this->get('core');
|
||||||
|
|
||||||
|
$csrPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
$pubPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
|
||||||
|
file_put_contents($pubPath, $publicKey);
|
||||||
|
|
||||||
|
exec(escapeshellcmd($core->getBaseDir() . '/bin/create-csr') . ' ' . escapeshellarg($fqdn) . ' ' . escapeshellarg($csrPath) . ' ' . escapeshellarg($pubPath) . ' 2>&1', $output, $exitCode);
|
||||||
|
|
||||||
|
if ($exitCode !== 0) {
|
||||||
|
throw new \Exception("Failed creating CSR: " . implode("\n", $output));
|
||||||
|
}
|
||||||
|
|
||||||
|
$csr = file_get_contents($csrPath);
|
||||||
|
|
||||||
|
unlink($pubPath);
|
||||||
|
unlink($csrPath);
|
||||||
|
|
||||||
|
return $csr;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Signs a client certificate and returns the signed certificate
|
||||||
|
* @param string $publicKey
|
||||||
|
* @param string $fqdn
|
||||||
|
* @return string
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function signServerKey($publicKey, $fqdn)
|
||||||
|
{
|
||||||
|
$csr = $this->createCSRForKeyAndFqdn($publicKey, $fqdn);
|
||||||
|
|
||||||
|
/** @var Core $core */
|
||||||
|
$core = $this->get('core');
|
||||||
|
|
||||||
|
$csrPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
$crtPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
|
||||||
|
file_put_contents($csrPath, $csr);
|
||||||
|
|
||||||
|
exec(escapeshellcmd($core->getBaseDir() . '/bin/sign-server-csr') . ' ' . escapeshellarg($csrPath) . ' ' . escapeshellarg($crtPath) . ' 2>&1', $output, $exitCode);
|
||||||
|
|
||||||
|
if ($exitCode !== 0) {
|
||||||
|
throw new \Exception("Failed signing CSR: " . implode("\n", $output));
|
||||||
|
}
|
||||||
|
|
||||||
|
$crt = file_get_contents($crtPath);
|
||||||
|
|
||||||
|
unlink($crtPath);
|
||||||
|
unlink($csrPath);
|
||||||
|
|
||||||
|
return $crt;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $csr
|
* @param string $csr
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
|
@ -70,4 +134,81 @@ class CA extends Main
|
||||||
return $subject["CN"];
|
return $subject["CN"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $certificate
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function revoke($certificate)
|
||||||
|
{
|
||||||
|
/** @var Core $core */
|
||||||
|
$core = $this->get('core');
|
||||||
|
|
||||||
|
$crtPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
|
||||||
|
file_put_contents($crtPath, $certificate);
|
||||||
|
|
||||||
|
exec(escapeshellcmd($core->getBaseDir() . '/bin/revoke-cert') . ' ' . escapeshellarg($crtPath) . ' 2>&1', $output, $exitCode);
|
||||||
|
|
||||||
|
if ($exitCode !== 0) {
|
||||||
|
throw new \Exception("Failed signing CSR: " . implode("\n", $output));
|
||||||
|
}
|
||||||
|
|
||||||
|
unlink($crtPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $pubKey
|
||||||
|
* @return string
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function getFingerprintFromPublicKey($pubKey)
|
||||||
|
{
|
||||||
|
/** @var Core $core */
|
||||||
|
$core = $this->get('core');
|
||||||
|
|
||||||
|
$pubPath = tempnam(sys_get_temp_dir(), '0.');
|
||||||
|
|
||||||
|
file_put_contents($pubPath, $pubKey);
|
||||||
|
|
||||||
|
exec(escapeshellcmd($core->getBaseDir() . '/bin/get-fingerprint') . ' ' . escapeshellarg($pubPath) . ' 2>&1', $output, $exitCode);
|
||||||
|
|
||||||
|
if ($exitCode !== 0) {
|
||||||
|
throw new \Exception("Failed getting fingerprint from public key: " . implode("\n", $output));
|
||||||
|
}
|
||||||
|
|
||||||
|
unlink($pubPath);
|
||||||
|
|
||||||
|
return $output[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function verify($data, $signature, $publicKey)
|
||||||
|
{
|
||||||
|
$publicKeyResource = openssl_pkey_get_public($publicKey);
|
||||||
|
|
||||||
|
$result = openssl_verify($data, $signature, $publicKeyResource);
|
||||||
|
|
||||||
|
if ($result === 1) {
|
||||||
|
return true;
|
||||||
|
} else if ($result === 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new \Exception("Verify failed: " . $this->getOpenSslError());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function signWithCA($data) {
|
||||||
|
/** @var Core $core */
|
||||||
|
$core = $this->get('core');
|
||||||
|
|
||||||
|
$privateKeyPlain = file_get_contents($core->getBaseDir() . '/storage/ca/ca.key');
|
||||||
|
$privateKey = openssl_get_privatekey($privateKeyPlain);
|
||||||
|
|
||||||
|
$result = openssl_sign($data, $signature, $privateKey);
|
||||||
|
|
||||||
|
if ($result) {
|
||||||
|
return $signature;
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new \Exception("Signing failed: " . $this->getOpenSslError());
|
||||||
|
}
|
||||||
}
|
}
|
66
src/Service/Server.php
Normal file
66
src/Service/Server.php
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
<?php
|
||||||
|
namespace Eater\Glim\Service;
|
||||||
|
|
||||||
|
|
||||||
|
use Eater\Glim\Model\Server as ServerModel;
|
||||||
|
use GuzzleHttp\Client as HttpClient;
|
||||||
|
use Eater\Glim\Core;
|
||||||
|
|
||||||
|
class Server extends Main
|
||||||
|
{
|
||||||
|
const MANAGEMENT_PORT = 7864;
|
||||||
|
|
||||||
|
private $httpClient = null;
|
||||||
|
|
||||||
|
private function getHttpClient() {
|
||||||
|
if ($this->httpClient === null) {
|
||||||
|
$this->httpClient = new HttpClient();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->httpClient;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param ServerModel $server
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function deliverSignedCertificate(ServerModel $server) {
|
||||||
|
$response = $this->doSignedRequest($server, '/deliver-crt', [
|
||||||
|
'certficate' => $server->getCertificate()
|
||||||
|
]);
|
||||||
|
|
||||||
|
if ($response->getStatusCode() !== 200) {
|
||||||
|
throw new \Exception('Delivering signed certificate failed (' . $response->getStatusCode() . '): ' . $response->getBody()->getContents());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param ServerModel $server
|
||||||
|
* @param string $path
|
||||||
|
* @param string $data
|
||||||
|
* @return \Psr\Http\Message\ResponseInterface
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public function doSignedRequest(ServerModel $server, $path, $data) {
|
||||||
|
$client = $this->getHttpClient();
|
||||||
|
|
||||||
|
/** @var CA $ca */
|
||||||
|
$ca = $this->get('ca');
|
||||||
|
|
||||||
|
$data['signature'] = $ca->signWithCA($server->getFingerprint());
|
||||||
|
|
||||||
|
$json = json_encode($data);
|
||||||
|
|
||||||
|
$pubKey = openssl_get_publickey($server->getPublicKey());
|
||||||
|
|
||||||
|
$success = openssl_public_encrypt($json, $crypted, $pubKey, OPENSSL_NO_PADDING);
|
||||||
|
|
||||||
|
if (!$success) {
|
||||||
|
throw new \Exception('Encrypting data failed: ' . openssl_error_string() . openssl_error_string());
|
||||||
|
}
|
||||||
|
|
||||||
|
return $client->post('http://' . $server->getExternalIp() . ':' . static::MANAGEMENT_PORT . $path, [
|
||||||
|
'body' => $crypted
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -10,6 +10,7 @@
|
||||||
{% block head %}
|
{% block head %}
|
||||||
<script src="/js/jquery.min.js"></script>
|
<script src="/js/jquery.min.js"></script>
|
||||||
<script src="/js/bootstrap.js"></script>
|
<script src="/js/bootstrap.js"></script>
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -1,8 +1,14 @@
|
||||||
{% extends "base.html.twig" %}
|
{% extends "base.html.twig" %}
|
||||||
|
|
||||||
|
{% block head %}
|
||||||
|
{{ parent() }}
|
||||||
|
|
||||||
|
<script src="/js/panel.js"></script>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h2>Certificates</h2>
|
<h2 id="certificates">Certificates</h2>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<table class="table">
|
<table class="table">
|
||||||
<thead>
|
<thead>
|
||||||
|
@ -11,12 +17,12 @@
|
||||||
<th>Name</th>
|
<th>Name</th>
|
||||||
<th>Expires on</th>
|
<th>Expires on</th>
|
||||||
<th>
|
<th>
|
||||||
<a href="/panel/certificates/new" class="button">Create new certificate</a>
|
<a href="/panel/certificates/new" class="btn btn-default pull-right">Create new certificate</a>
|
||||||
</th>
|
</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{% for certificate in user.getCertificates() %}
|
{% for certificate in user.getCertificates() if certificate.getRevoked() == 0 %}
|
||||||
<tr>
|
<tr>
|
||||||
<td>
|
<td>
|
||||||
{{ certificate.getSerial() }}
|
{{ certificate.getSerial() }}
|
||||||
|
@ -28,21 +34,126 @@
|
||||||
{{ certificate.getExpiresOn().format('Y-m-d H:i:s') }}
|
{{ certificate.getExpiresOn().format('Y-m-d H:i:s') }}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<div class="div pull-right">
|
<div class="pull-right">
|
||||||
<button class="revoke btn btn-warning">Revoke</button>
|
<button data-name="{{ certificate.getName() }}" class="revoke btn btn-warning">Revoke
|
||||||
<a target="_blank" href="/panel/certificates/download/{{ certificate.getName() }}" class="download btn btn-default">Download certificate</a>
|
</button>
|
||||||
|
<a target="_blank" href="/panel/certificates/download/{{ certificate.getName() }}"
|
||||||
|
class="download btn btn-default">Download certificate</a>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% else %}
|
{% else %}
|
||||||
<tr>
|
<tr>
|
||||||
<td colspan="4">
|
<td colspan="4">
|
||||||
You don't seem to have any certificates yet, <a href="/panel/certificates/new">want to create one?</a>
|
You don't seem to have any certificates yet, <a href="/panel/certificates/new">want to
|
||||||
|
create one?</a>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
|
<h2>Servers</h2>
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Hostname</th>
|
||||||
|
<th>Fingerprint</th>
|
||||||
|
<th>Location</th>
|
||||||
|
<th>Speed</th>
|
||||||
|
<th>Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for server in servers %}\
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
{{ server.getFqdn() }}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{{ server.getFingerprint() }}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{{ server.getLocation() }}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{{ server.getSpeed() }} MB/s
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<div class="pull-right">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% else %}
|
||||||
|
<tr>
|
||||||
|
<td colspan="5">
|
||||||
|
There don't seem to be any servers yet :(
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{% if user.getSuperuser() %}
|
||||||
|
<h2>Registered servers</h2>
|
||||||
|
<table class="table">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Hostname</th>
|
||||||
|
<th>Fingerprint</th>
|
||||||
|
<th>Actions</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for server in registeredServers %}
|
||||||
|
<tr>
|
||||||
|
<td>
|
||||||
|
{{ server.getFqdn() }}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
{{ server.getFingerprint() }}
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
<div class="pull-right">
|
||||||
|
<a href="/panel/server/{{ server.getFingerprint() }}" class="btn btn-default">Details</a>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% else %}
|
||||||
|
<tr>
|
||||||
|
<td colspan="5">
|
||||||
|
There don't seem to be any servers yet :(
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
<div class="modal fade in revoke-modal" tabindex="-1" role="dialog">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span
|
||||||
|
aria-hidden="true">×</span></button>
|
||||||
|
<h4 class="modal-title">Are you sure?</h4>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<div id="revoke-put-error-after-me" class="alert alert-danger modal-top-alert">
|
||||||
|
<h4>This may not be what you want!</h4>
|
||||||
|
<p>Revoking the certificate means that you <b>can't use</b> the VPN anymore with that
|
||||||
|
certificate</p>
|
||||||
|
</div>
|
||||||
|
<p>If you're really sure that you want to do this please enter your <b>password</b></p>
|
||||||
|
<div>
|
||||||
|
<input type="password" class="revoke-password form-control">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
|
||||||
|
<button type="button" class="btn btn-warning revoke-confirm">Revoke</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
|
@ -2,10 +2,11 @@
|
||||||
|
|
||||||
{% block head %}
|
{% block head %}
|
||||||
{{ parent() }}
|
{{ parent() }}
|
||||||
|
|
||||||
<script src="/js/forge.min.js"></script>
|
<script src="/js/forge.min.js"></script>
|
||||||
<script src="/js/jszip.min.js"></script>
|
<script src="/js/jszip.min.js"></script>
|
||||||
<script src="/js/FileSaver.min.js"></script>
|
<script src="/js/FileSaver.min.js"></script>
|
||||||
<script src="/js/main.js"></script>
|
<script src="/js/new_certificate.js"></script>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
@ -15,19 +16,40 @@
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<h2>New Certificate</h2>
|
<h2>New Certificate</h2>
|
||||||
</div>
|
</div>
|
||||||
<form class="form-horizontal" action="/panel/certificates/new">
|
<div class="form-horizontal">
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label class="control-label col-md-2" for="name">Name</label>
|
<label class="control-label col-md-4" for="name">Name</label>
|
||||||
<div class="col-md-10">
|
<div class="col-md-8">
|
||||||
<input name="name" id="name" type="text" class="form-control">
|
<input name="name" id="name" type="text" class="form-control">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4">Private Key password</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<div class="input-group">
|
||||||
|
<div class="input-group-addon">
|
||||||
|
<input id="wantsPassword" type="checkbox" />
|
||||||
|
</div>
|
||||||
|
<input type="password" disabled class="form-control" id="password" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4">Save private key online</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<div class="checkbox">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" id="saveOnline" disabled /> This may be a security risk.
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
<button type="button" class="magic-csr btn btn-primary pull-right">Create certificate</button>
|
<button type="button" class="magic-csr btn btn-primary pull-right">Create certificate</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
94
views/panel/servers/edit.html.twig
Normal file
94
views/panel/servers/edit.html.twig
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
{% extends "base.html.twig" %}
|
||||||
|
|
||||||
|
{% block head %}
|
||||||
|
{{ parent() }}
|
||||||
|
|
||||||
|
<script src="/js/edit_server.js"></script>
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<div class="container">
|
||||||
|
<div data-fingerprint="{{ server.getFingerprint() }}" class="row server-form">
|
||||||
|
<div class="col-md-6 col-md-offset-3">
|
||||||
|
<div class="row">
|
||||||
|
<h2>Editing server '{{ server.getFqdn() }}'</h2>
|
||||||
|
</div>
|
||||||
|
<div class="form-horizontal">
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="fqdn">Hostname</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="fqdn" id="fqdn" type="text" class="form-control" value="{{ server.getFqdn() }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="external-ip">External IP</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="external-ip" id="external-ip" type="text" min="-1" class="form-control" value="{{ server.getExternalIp() }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<h3>Details</h3>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="location">Location</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="location" id="location" type="text" class="form-control" value="{{ server.getLocation() }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="speed">Speed</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="speed" id="speed" type="number" min="-1" class="form-control" value="{{ server.getSpeed() }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<h3>Config</h3>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="internal-ip">Internal IP</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="internal-ip" id="internal-ip" type="text" min="-1" class="form-control" value="{{ server.getInternalIp() ?: '10.24.0.0' }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="speed">Netmask</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="netmask" id="netmask" type="number" min="8" max="24" class="form-control" value="{{ server.getNetmask() ?: 16 }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="port">Port</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="port" id="port" type="number" class="form-control" value="{{ server.getPort() ?: 1194 }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="protocol">Protocol</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<select name="protocol" id="protocol" class="form-control">
|
||||||
|
<option value="udp" {{ server.getProtocol() == 'udp' ? 'selected' }}>UDP</option>
|
||||||
|
<option value="tcp" {{ server.getProtocol() == 'tcp' ? 'selected' }}>TCP</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="first-dns">First DNS</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="first-dns" id="first-dns" type="text" class="form-control" value="{{ server.getFirstDns() ?: '8.8.8.8' }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label class="control-label col-md-4" for="second-dns">second DNS</label>
|
||||||
|
<div class="col-md-8">
|
||||||
|
<input name="second-dns" id="first-dns" type="text" class="form-control" value="{{ server.getSecondDns() ?: '8.8.4.4' }}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-md-12">
|
||||||
|
<div class="pull-right">
|
||||||
|
<button type="button" class="btn save">Save</button>
|
||||||
|
<button type="button" class="btn btn-primary save-and-sign">Sign and save</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endblock %}
|
Loading…
Reference in a new issue