parent
68934624dd
commit
a1f4504497
|
@ -0,0 +1 @@
|
||||||
|
spaceapikey.txt
|
|
@ -13,8 +13,11 @@ do
|
||||||
then
|
then
|
||||||
for plugin in "$0".d/*
|
for plugin in "$0".d/*
|
||||||
do
|
do
|
||||||
|
if [ -x "$plugin" ]
|
||||||
|
then
|
||||||
"$plugin" pushed
|
"$plugin" pushed
|
||||||
logger -t $(basename $0) "called '$plugin pushed' with ret=$?"
|
logger -t $(basename $0) "called '$plugin pushed' with ret=$?"
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
state="pushed"
|
state="pushed"
|
||||||
else
|
else
|
||||||
|
@ -22,8 +25,11 @@ do
|
||||||
then
|
then
|
||||||
for plugin in "$0".d/*
|
for plugin in "$0".d/*
|
||||||
do
|
do
|
||||||
|
if [ -x "$plugin" ]
|
||||||
|
then
|
||||||
"$plugin" released
|
"$plugin" released
|
||||||
logger -t $(basename $0) "called '$plugin released' with ret=$?"
|
logger -t $(basename $0) "called '$plugin released' with ret=$?"
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
state="released"
|
state="released"
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
#put scripts here which are called the moment the lockbutton changes state
|
|
@ -1,6 +1,7 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# changes level2 state by the state of the main door
|
# changes level2 state by the state of the main door
|
||||||
# i.e. people have to leave it open to keep status open
|
# i.e. people have to leave it open to keep status open
|
||||||
|
sleep 1 # silly way to debounce
|
||||||
if [ "$1" = "pushed" ] &&
|
if [ "$1" = "pushed" ] &&
|
||||||
[ "$(cat /run/spacestatus)" = "open" ]
|
[ "$(cat /run/spacestatus)" = "open" ]
|
||||||
then
|
then
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
IGNORE_DOORLOCKBUTTON="no"
|
IGNORE_DOORLOCKBUTTON="no"
|
||||||
LockDir="/run/$(basename "$0").run"
|
LockDir="/run/$(basename "$0").run"
|
||||||
|
spaceapikey="$(cat "$(dirname $0)"/spaceapikey.txt)"
|
||||||
P() {
|
P() {
|
||||||
while ! mkdir "$LockDir" 2>/dev/null
|
while ! mkdir "$LockDir" 2>/dev/null
|
||||||
do
|
do
|
||||||
|
@ -34,18 +35,22 @@ then
|
||||||
chown www-data /run/spacestatus
|
chown www-data /run/spacestatus
|
||||||
fi
|
fi
|
||||||
|
|
||||||
status=$(cat /run/spacestatus)
|
status="$(cat /run/spacestatus)"
|
||||||
doorlockbutton=$(cat /run/doorlockbutton)
|
oldstatus="$(cat /root/var/spacestatus)"
|
||||||
|
doorlockbutton="$(cat /run/doorlockbutton)"
|
||||||
nai=$(stat -c "%Y" /run/spacestatus) # get mtime as status change time
|
nai=$(stat -c "%Y" /run/spacestatus) # get mtime as status change time
|
||||||
if [ "$status" = "open" ]
|
if [ "$status" = "open" ]
|
||||||
then
|
then
|
||||||
/usr/bin/curl --max-time 1 --silent --data key=96f7896f97asdf89u0a9s7d7fdasgsda88af --data-urlencode sensors='{"state":{"open":true,"lastchange":'"$nai"'}}' http://spaceapi.syn2cat.lu/sensor/set
|
/usr/bin/curl --max-time 1 --silent --data key="$spaceapikey" --data-urlencode sensors='{"state":{"open":true,"lastchange":'"$nai"'}}' http://spaceapi.syn2cat.lu/sensor/set
|
||||||
#logger -t $(basename $0) "sending status $status to spacapi ret=$?"
|
#logger -t $(basename $0) "sending status $status to spacapi ret=$?"
|
||||||
fi
|
fi
|
||||||
for plugin in $(ls "$0".d)
|
for plugin in $(ls "$0".d)
|
||||||
do
|
do
|
||||||
"$0".d/"$plugin" "$status"
|
if [ -x "$0".d/"$plugin" ]
|
||||||
# logger -t $(basename $0) "called $plugin '$status'. ret=$?"
|
then
|
||||||
|
"$0".d/"$plugin" "$status" "$oldstatus"
|
||||||
|
logger -t $(basename $0) "called $plugin '$status' '$oldstatus'. ret=$?"
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "$status" = "closed" ] && (
|
if [ "$status" = "closed" ] && (
|
||||||
|
@ -54,7 +59,7 @@ then
|
||||||
# problem: if closing state but not actually shuting door for a longer time, the status in spaceapi
|
# problem: if closing state but not actually shuting door for a longer time, the status in spaceapi
|
||||||
# will be the time of closing but not that of actually shutting the door
|
# will be the time of closing but not that of actually shutting the door
|
||||||
# but the status will only be updated once the door is shut
|
# but the status will only be updated once the door is shut
|
||||||
/usr/bin/curl --max-time 1 --silent --data key=96f7896f97asdf89u0a9s7d7fdasgsda88af --data-urlencode sensors='{"state":{"open":false,"lastchange":'"$nai"'}}' http://spaceapi.syn2cat.lu/sensor/set
|
/usr/bin/curl --max-time 1 --silent --data key="$spaceapikey" --data-urlencode sensors='{"state":{"open":false,"lastchange":'"$nai"'}}' http://spaceapi.syn2cat.lu/sensor/set
|
||||||
#logger -t $(basename $0) "sending status $status to spacapi ret=$?"
|
#logger -t $(basename $0) "sending status $status to spacapi ret=$?"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -68,5 +73,5 @@ if [ "$status" = "closed" ]
|
||||||
then
|
then
|
||||||
presency=0
|
presency=0
|
||||||
fi
|
fi
|
||||||
/usr/bin/curl --max-time 1 --silent --data key=96f7896f97asdf89u0a9s7d7fdasgsda88af --data-urlencode sensors='{"sensors":{"people_now_present":[{"value":'"$presency"'}]}}' http://spaceapi.syn2cat.lu/sensor/set
|
/usr/bin/curl --max-time 1 --silent --data key="$spaceapikey" --data-urlencode sensors='{"sensors":{"people_now_present":[{"value":'"$presency"'}]}}' http://spaceapi.syn2cat.lu/sensor/set
|
||||||
V
|
V
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
twittertokens.php
|
|
@ -0,0 +1,7 @@
|
||||||
|
put script here which are called once per minute
|
||||||
|
parameters to script are:
|
||||||
|
scriptname current_status previous_status
|
||||||
|
where current_status and previous_status are either "open" or "closed"
|
||||||
|
|
||||||
|
the script must have the executable bit.
|
||||||
|
parameter files can be here but must not have the execute bit
|
|
@ -0,0 +1,263 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Twitter-API-PHP : Simple PHP wrapper for the v1.1 API
|
||||||
|
*
|
||||||
|
* PHP version 5.3.10
|
||||||
|
*
|
||||||
|
* @category Awesomeness
|
||||||
|
* @package Twitter-API-PHP
|
||||||
|
* @author James Mallison <me@j7mbo.co.uk>
|
||||||
|
* @license MIT License
|
||||||
|
* @link http://github.com/j7mbo/twitter-api-php
|
||||||
|
*/
|
||||||
|
class TwitterAPIExchange
|
||||||
|
{
|
||||||
|
private $oauth_access_token;
|
||||||
|
private $oauth_access_token_secret;
|
||||||
|
private $consumer_key;
|
||||||
|
private $consumer_secret;
|
||||||
|
private $postfields;
|
||||||
|
private $getfield;
|
||||||
|
protected $oauth;
|
||||||
|
public $url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create the API access object. Requires an array of settings::
|
||||||
|
* oauth access token, oauth access token secret, consumer key, consumer secret
|
||||||
|
* These are all available by creating your own application on dev.twitter.com
|
||||||
|
* Requires the cURL library
|
||||||
|
*
|
||||||
|
* @param array $settings
|
||||||
|
*/
|
||||||
|
public function __construct(array $settings)
|
||||||
|
{
|
||||||
|
if (!in_array('curl', get_loaded_extensions()))
|
||||||
|
{
|
||||||
|
throw new Exception('You need to install cURL, see: http://curl.haxx.se/docs/install.html');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($settings['oauth_access_token'])
|
||||||
|
|| !isset($settings['oauth_access_token_secret'])
|
||||||
|
|| !isset($settings['consumer_key'])
|
||||||
|
|| !isset($settings['consumer_secret']))
|
||||||
|
{
|
||||||
|
throw new Exception('Make sure you are passing in the correct parameters');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->oauth_access_token = $settings['oauth_access_token'];
|
||||||
|
$this->oauth_access_token_secret = $settings['oauth_access_token_secret'];
|
||||||
|
$this->consumer_key = $settings['consumer_key'];
|
||||||
|
$this->consumer_secret = $settings['consumer_secret'];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set postfields array, example: array('screen_name' => 'J7mbo')
|
||||||
|
*
|
||||||
|
* @param array $array Array of parameters to send to API
|
||||||
|
*
|
||||||
|
* @return TwitterAPIExchange Instance of self for method chaining
|
||||||
|
*/
|
||||||
|
public function setPostfields(array $array)
|
||||||
|
{
|
||||||
|
if (!is_null($this->getGetfield()))
|
||||||
|
{
|
||||||
|
throw new Exception('You can only choose get OR post fields.');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($array['status']) && substr($array['status'], 0, 1) === '@')
|
||||||
|
{
|
||||||
|
$array['status'] = sprintf("\0%s", $array['status']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->postfields = $array;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set getfield string, example: '?screen_name=J7mbo'
|
||||||
|
*
|
||||||
|
* @param string $string Get key and value pairs as string
|
||||||
|
*
|
||||||
|
* @return \TwitterAPIExchange Instance of self for method chaining
|
||||||
|
*/
|
||||||
|
public function setGetfield($string)
|
||||||
|
{
|
||||||
|
if (!is_null($this->getPostfields()))
|
||||||
|
{
|
||||||
|
throw new Exception('You can only choose get OR post fields.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$search = array('#', ',', '+', ':');
|
||||||
|
$replace = array('%23', '%2C', '%2B', '%3A');
|
||||||
|
$string = str_replace($search, $replace, $string);
|
||||||
|
|
||||||
|
$this->getfield = $string;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get getfield string (simple getter)
|
||||||
|
*
|
||||||
|
* @return string $this->getfields
|
||||||
|
*/
|
||||||
|
public function getGetfield()
|
||||||
|
{
|
||||||
|
return $this->getfield;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get postfields array (simple getter)
|
||||||
|
*
|
||||||
|
* @return array $this->postfields
|
||||||
|
*/
|
||||||
|
public function getPostfields()
|
||||||
|
{
|
||||||
|
return $this->postfields;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build the Oauth object using params set in construct and additionals
|
||||||
|
* passed to this method. For v1.1, see: https://dev.twitter.com/docs/api/1.1
|
||||||
|
*
|
||||||
|
* @param string $url The API url to use. Example: https://api.twitter.com/1.1/search/tweets.json
|
||||||
|
* @param string $requestMethod Either POST or GET
|
||||||
|
* @return \TwitterAPIExchange Instance of self for method chaining
|
||||||
|
*/
|
||||||
|
public function buildOauth($url, $requestMethod)
|
||||||
|
{
|
||||||
|
if (!in_array(strtolower($requestMethod), array('post', 'get')))
|
||||||
|
{
|
||||||
|
throw new Exception('Request method must be either POST or GET');
|
||||||
|
}
|
||||||
|
|
||||||
|
$consumer_key = $this->consumer_key;
|
||||||
|
$consumer_secret = $this->consumer_secret;
|
||||||
|
$oauth_access_token = $this->oauth_access_token;
|
||||||
|
$oauth_access_token_secret = $this->oauth_access_token_secret;
|
||||||
|
|
||||||
|
$oauth = array(
|
||||||
|
'oauth_consumer_key' => $consumer_key,
|
||||||
|
'oauth_nonce' => time(),
|
||||||
|
'oauth_signature_method' => 'HMAC-SHA1',
|
||||||
|
'oauth_token' => $oauth_access_token,
|
||||||
|
'oauth_timestamp' => time(),
|
||||||
|
'oauth_version' => '1.0'
|
||||||
|
);
|
||||||
|
|
||||||
|
$getfield = $this->getGetfield();
|
||||||
|
|
||||||
|
if (!is_null($getfield))
|
||||||
|
{
|
||||||
|
$getfields = str_replace('?', '', explode('&', $getfield));
|
||||||
|
foreach ($getfields as $g)
|
||||||
|
{
|
||||||
|
$split = explode('=', $g);
|
||||||
|
$oauth[$split[0]] = $split[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$base_info = $this->buildBaseString($url, $requestMethod, $oauth);
|
||||||
|
$composite_key = rawurlencode($consumer_secret) . '&' . rawurlencode($oauth_access_token_secret);
|
||||||
|
$oauth_signature = base64_encode(hash_hmac('sha1', $base_info, $composite_key, true));
|
||||||
|
$oauth['oauth_signature'] = $oauth_signature;
|
||||||
|
|
||||||
|
$this->url = $url;
|
||||||
|
$this->oauth = $oauth;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Perform the actual data retrieval from the API
|
||||||
|
*
|
||||||
|
* @param boolean $return If true, returns data.
|
||||||
|
*
|
||||||
|
* @return string json If $return param is true, returns json data.
|
||||||
|
*/
|
||||||
|
public function performRequest($return = true)
|
||||||
|
{
|
||||||
|
if (!is_bool($return))
|
||||||
|
{
|
||||||
|
throw new Exception('performRequest parameter must be true or false');
|
||||||
|
}
|
||||||
|
|
||||||
|
$header = array($this->buildAuthorizationHeader($this->oauth), 'Expect:');
|
||||||
|
|
||||||
|
$getfield = $this->getGetfield();
|
||||||
|
$postfields = $this->getPostfields();
|
||||||
|
|
||||||
|
$options = array(
|
||||||
|
CURLOPT_HTTPHEADER => $header,
|
||||||
|
CURLOPT_HEADER => false,
|
||||||
|
CURLOPT_URL => $this->url,
|
||||||
|
CURLOPT_RETURNTRANSFER => true,
|
||||||
|
CURLOPT_TIMEOUT => 10,
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!is_null($postfields))
|
||||||
|
{
|
||||||
|
$options[CURLOPT_POSTFIELDS] = $postfields;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ($getfield !== '')
|
||||||
|
{
|
||||||
|
$options[CURLOPT_URL] .= $getfield;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$feed = curl_init();
|
||||||
|
curl_setopt_array($feed, $options);
|
||||||
|
$json = curl_exec($feed);
|
||||||
|
curl_close($feed);
|
||||||
|
|
||||||
|
if ($return) { return $json; }
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Private method to generate the base string used by cURL
|
||||||
|
*
|
||||||
|
* @param string $baseURI
|
||||||
|
* @param string $method
|
||||||
|
* @param array $params
|
||||||
|
*
|
||||||
|
* @return string Built base string
|
||||||
|
*/
|
||||||
|
private function buildBaseString($baseURI, $method, $params)
|
||||||
|
{
|
||||||
|
$return = array();
|
||||||
|
ksort($params);
|
||||||
|
|
||||||
|
foreach($params as $key=>$value)
|
||||||
|
{
|
||||||
|
$return[] = "$key=" . $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $method . "&" . rawurlencode($baseURI) . '&' . rawurlencode(implode('&', $return));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Private method to generate authorization header used by cURL
|
||||||
|
*
|
||||||
|
* @param array $oauth Array of oauth data generated by buildOauth()
|
||||||
|
*
|
||||||
|
* @return string $return Header used by cURL for request
|
||||||
|
*/
|
||||||
|
private function buildAuthorizationHeader($oauth)
|
||||||
|
{
|
||||||
|
$return = 'Authorization: OAuth ';
|
||||||
|
$values = array();
|
||||||
|
|
||||||
|
foreach($oauth as $key => $value)
|
||||||
|
{
|
||||||
|
$values[] = "$key=\"" . rawurlencode($value) . "\"";
|
||||||
|
}
|
||||||
|
|
||||||
|
$return .= implode(', ', $values);
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,57 @@
|
||||||
|
#!/usr/bin/php
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tezza
|
||||||
|
* https://github.com/J7mbo/twitter-api-php
|
||||||
|
* */
|
||||||
|
|
||||||
|
require_once('TwitterAPIExchange.php');
|
||||||
|
|
||||||
|
/** Set access tokens here - see: https://dev.twitter.com/apps/ **/
|
||||||
|
/*
|
||||||
|
$settings = array(
|
||||||
|
'oauth_access_token' => 'xxxx',
|
||||||
|
'oauth_access_token_secret' => 'yyyy',
|
||||||
|
'consumer_key' => 'xxxxx',
|
||||||
|
'consumer_secret' => 'yyyyy'
|
||||||
|
);
|
||||||
|
*/
|
||||||
|
require_once('twittertokens.php'); /* put the tokens inside separate file which is in .gitignore */
|
||||||
|
|
||||||
|
/** URL for REST request, see: https://dev.twitter.com/docs/api/1.1/ **/
|
||||||
|
$url = 'https://api.twitter.com/1.1/statuses/update.json';
|
||||||
|
$requestMethod = 'POST';
|
||||||
|
|
||||||
|
file_put_contents( '/var/test.txt', $argv );
|
||||||
|
/*
|
||||||
|
if ( $spaceAPI ) {
|
||||||
|
$level2status = $spaceAPI['state']['open'];
|
||||||
|
|
||||||
|
var_dump( $level2status );
|
||||||
|
|
||||||
|
if ( $level2status != file_get_contents('/var/cronjobs/lvl2_tweet/lastKnownState.txt') ) {
|
||||||
|
if ( $level2status ) {
|
||||||
|
$status = 'It\'s ' . date( 'H:i', $spaceAPI['state']['lastchange'] ) . ' and we are open \o/, come in and create something awesome =) #statusUpdate';
|
||||||
|
file_put_contents( '/var/cronjobs/lvl2_tweet/lastKnownState.txt', '1' );
|
||||||
|
} else {
|
||||||
|
$status = 'We just closed our doors at ' . date( 'H:i', $spaceAPI['state']['lastchange'] ) . '. See you very soon... #statusUpdate';
|
||||||
|
file_put_contents( '/var/cronjobs/lvl2_tweet/lastKnownState.txt', '0');
|
||||||
|
}
|
||||||
|
|
||||||
|
var_dump( $status );
|
||||||
|
|
||||||
|
// POST fields required by the URL above. See relevant docs as above
|
||||||
|
$postfields = array(
|
||||||
|
'status' => $status
|
||||||
|
);
|
||||||
|
|
||||||
|
// Perform a POST request and echo the response
|
||||||
|
$twitter = new TwitterAPIExchange($settings);
|
||||||
|
echo $twitter->buildOauth($url, $requestMethod)
|
||||||
|
->setPostfields($postfields)
|
||||||
|
->performRequest();
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
Loading…
Reference in New Issue