initial commit
This commit is contained in:
commit
ec290e067d
10 changed files with 276 additions and 0 deletions
12
.editorconfig
Normal file
12
.editorconfig
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
# http://editorconfig.org
|
||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
charset = utf-8
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
insert_final_newline = true
|
||||||
|
|
||||||
|
[*.md]
|
||||||
|
trim_trailing_whitespace = false
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
/node_modules
|
11
.travis.yml
Normal file
11
.travis.yml
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
language: node_js
|
||||||
|
node_js:
|
||||||
|
- "0.12"
|
||||||
|
- "0.10"
|
||||||
|
- "iojs"
|
||||||
|
sudo: false
|
||||||
|
cache:
|
||||||
|
directories:
|
||||||
|
- node_modules
|
||||||
|
notifications:
|
||||||
|
email: false
|
33
Gruntfile.js
Normal file
33
Gruntfile.js
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
module.exports = function (grunt) {
|
||||||
|
|
||||||
|
grunt.initConfig({
|
||||||
|
mochaTest: {
|
||||||
|
test: {
|
||||||
|
options: {
|
||||||
|
reporter: 'spec',
|
||||||
|
require: 'coffee-script'
|
||||||
|
},
|
||||||
|
src: ['test/**/*.coffee']
|
||||||
|
}
|
||||||
|
},
|
||||||
|
release: {
|
||||||
|
options: {
|
||||||
|
tagName: 'v<%= version %>',
|
||||||
|
commitMessage: 'Prepared to release <%= version %>.'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
files: ['Gruntfile.js', 'src/**/*.coffee', 'test/**/*.coffee'],
|
||||||
|
tasks: ['test']
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// load all grunt tasks
|
||||||
|
require('matchdep').filterDev(['grunt-*', '!grunt-cli']).forEach(grunt.loadNpmTasks);
|
||||||
|
|
||||||
|
grunt.registerTask('test', ['mochaTest']);
|
||||||
|
grunt.registerTask('test:watch', ['watch']);
|
||||||
|
grunt.registerTask('default', ['test']);
|
||||||
|
};
|
26
README.md
Normal file
26
README.md
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
# hubot-raumgirl-new
|
||||||
|
|
||||||
|
ctdo raumgirl
|
||||||
|
|
||||||
|
See [`src/raumgirl-new.coffee`](src/raumgirl-new.coffee) for full documentation.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
In hubot project repo, run:
|
||||||
|
|
||||||
|
`npm install hubot-raumgirl-new --save`
|
||||||
|
|
||||||
|
Then add **hubot-raumgirl-new** to your `external-scripts.json`:
|
||||||
|
|
||||||
|
```json
|
||||||
|
[
|
||||||
|
"hubot-raumgirl-new"
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
## Sample Interaction
|
||||||
|
|
||||||
|
```
|
||||||
|
user1>> hubot hello
|
||||||
|
hubot>> hello!
|
||||||
|
```
|
11
index.coffee
Normal file
11
index.coffee
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
fs = require 'fs'
|
||||||
|
path = require 'path'
|
||||||
|
|
||||||
|
module.exports = (robot, scripts) ->
|
||||||
|
scriptsPath = path.resolve(__dirname, 'src')
|
||||||
|
if fs.existsSync scriptsPath
|
||||||
|
for script in fs.readdirSync(scriptsPath).sort()
|
||||||
|
if scripts? and '*' not in scripts
|
||||||
|
robot.loadFile(scriptsPath, script) if script in scripts
|
||||||
|
else
|
||||||
|
robot.loadFile(scriptsPath, script)
|
46
package.json
Normal file
46
package.json
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
{
|
||||||
|
"name": "hubot-raumgirl-new",
|
||||||
|
"description": "ctdo raumgirl",
|
||||||
|
"version": "0.0.0",
|
||||||
|
"author": "henne@ctdo.de",
|
||||||
|
"license": "MIT",
|
||||||
|
|
||||||
|
"keywords": "hubot, hubot-scripts",
|
||||||
|
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git://github.com/hubot-scripts/hubot-raumgirl-new.git"
|
||||||
|
},
|
||||||
|
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/hubot-scripts/hubot-raumgirl-new/issues"
|
||||||
|
},
|
||||||
|
|
||||||
|
"dependencies": {
|
||||||
|
},
|
||||||
|
|
||||||
|
"peerDependencies": {
|
||||||
|
"hubot": "2.x"
|
||||||
|
},
|
||||||
|
|
||||||
|
"devDependencies": {
|
||||||
|
"chai": "^2.1.1",
|
||||||
|
"coffee-script": "1.6.3",
|
||||||
|
"grunt": "^0.4.5",
|
||||||
|
"grunt-cli": "^0.1.13",
|
||||||
|
"grunt-contrib-watch": "~0.6.1",
|
||||||
|
"grunt-mocha-test": "~0.12.7",
|
||||||
|
"grunt-release": "~0.11.0",
|
||||||
|
"hubot": "2.x",
|
||||||
|
"matchdep": "~0.3.0",
|
||||||
|
"mocha": "^2.1.0",
|
||||||
|
"sinon": "^1.13.0",
|
||||||
|
"sinon-chai": "^2.7.0"
|
||||||
|
},
|
||||||
|
|
||||||
|
"main": "index.coffee",
|
||||||
|
|
||||||
|
"scripts": {
|
||||||
|
"test": "grunt test"
|
||||||
|
}
|
||||||
|
}
|
18
script/bootstrap
Executable file
18
script/bootstrap
Executable file
|
@ -0,0 +1,18 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Make sure everything is development forever
|
||||||
|
export NODE_ENV=development
|
||||||
|
|
||||||
|
# Load environment specific environment variables
|
||||||
|
if [ -f .env ]; then
|
||||||
|
source .env
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f .env.${NODE_ENV} ]; then
|
||||||
|
source .env.${NODE_ENV}
|
||||||
|
fi
|
||||||
|
|
||||||
|
npm install
|
||||||
|
|
||||||
|
# Make sure coffee and mocha are on the path
|
||||||
|
export PATH="node_modules/.bin:$PATH"
|
6
script/test
Executable file
6
script/test
Executable file
|
@ -0,0 +1,6 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# bootstrap environment
|
||||||
|
source script/bootstrap
|
||||||
|
|
||||||
|
mocha --compilers coffee:coffee-script
|
112
src/ctdo.js
Normal file
112
src/ctdo.js
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
const net = require('net');
|
||||||
|
|
||||||
|
module.exports = function(robot) {
|
||||||
|
// old stuff
|
||||||
|
// lampel
|
||||||
|
function setLampel(r,ge,gr) {
|
||||||
|
var x = 0;
|
||||||
|
if(r)
|
||||||
|
x+=4;
|
||||||
|
if(ge)
|
||||||
|
x+=2;
|
||||||
|
if(gr)
|
||||||
|
x+=1;
|
||||||
|
var command = "io set port 2 0"+x+"\n";
|
||||||
|
var client = net.createConnection({port: 2701, host: 'lampel.raum.ctdo.de'}, function() {
|
||||||
|
client.end(command);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
robot.hear(/^rot$/i, function(r) {
|
||||||
|
setLampel(1,0,0);
|
||||||
|
});
|
||||||
|
robot.hear(/^gruen$/i, function(r) {
|
||||||
|
setLampel(0,0,1);
|
||||||
|
});
|
||||||
|
robot.hear(/^gelb$/i, function(r) {
|
||||||
|
setLampel(0,1,0);
|
||||||
|
});
|
||||||
|
robot.hear(/^(all|alle)$/i, function(r) {
|
||||||
|
setLampel(1,1,1);
|
||||||
|
});
|
||||||
|
robot.hear(/^(rotgelb|gelbrot)$/i, function(r) {
|
||||||
|
setLampel(1,1,0);
|
||||||
|
});
|
||||||
|
robot.hear(/^(gruengelb|gelbgruen)$/i, function(r) {
|
||||||
|
setLampel(0,1,1);
|
||||||
|
});
|
||||||
|
robot.hear(/^(rotgruen|gruenrot)$/i, function(r) {
|
||||||
|
setLampel(1,0,1);
|
||||||
|
});
|
||||||
|
// topic
|
||||||
|
robot.adapter.bot.addListener('topic', function(channel, topic) {
|
||||||
|
if(typeof(robot.brain.data.topics) !== 'Object') {
|
||||||
|
robot.brain.data.topics = {}
|
||||||
|
}
|
||||||
|
robot.brain.data.topics[channel] = topic
|
||||||
|
setTopic(topic);
|
||||||
|
});
|
||||||
|
|
||||||
|
function setTopic(currentTopic) {
|
||||||
|
robot.http("http://status.ctdo.de/api/simple/v2")
|
||||||
|
.header('Accept', 'application/json')
|
||||||
|
.get()(function(err, res, body) {
|
||||||
|
var data = JSON.parse(body);
|
||||||
|
var raum_offen = /(raum: |r: )(auf|offen|open)/ig;
|
||||||
|
var raum_zu = /(raum: |r: )(zu|geschlossen|closed)/ig
|
||||||
|
var currentState = data.state;
|
||||||
|
var newTopic = currentTopic;
|
||||||
|
if(currentTopic.match(raum_offen)) {
|
||||||
|
// wenn raum auf drinsteht
|
||||||
|
if(!data.state) {
|
||||||
|
newTopic = currentTopic.replace(raum_offen, 'Raum: zu');
|
||||||
|
}
|
||||||
|
} else if(currentTopic.match(raum_zu)) {
|
||||||
|
// wenn raum zu drinsteht
|
||||||
|
if(data.state) {
|
||||||
|
newTopic = currentTopic.replace(raum_zu, 'Raum: auf');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// wenn nix drinsteht
|
||||||
|
if(data.state) {
|
||||||
|
newTopic = "Raum: auf | " + currentTopic;
|
||||||
|
} else {
|
||||||
|
newTopic = "Raum: zu | " + currentTopic;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(newTopic !== currentTopic) {
|
||||||
|
robot.brain.data.topics[process.env['HUBOT_IRC_ROOMS']] = newTopic;
|
||||||
|
robot.adapter.topic({room: process.env['HUBOT_IRC_ROOMS']}, newTopic);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// topic interval
|
||||||
|
setInterval(function() {
|
||||||
|
setTopic(robot.brain.data.topics[process.env['HUBOT_IRC_ROOMS']]);
|
||||||
|
}, 5000);
|
||||||
|
// gem
|
||||||
|
var gem = false;
|
||||||
|
robot.respond(/gem$/i, function(r) {
|
||||||
|
if(gem) {
|
||||||
|
gem = false;
|
||||||
|
r.reply("Gem Deactivated");
|
||||||
|
} else {
|
||||||
|
gem = true;
|
||||||
|
var c = Math.floor(Math.random() * 100) + 1;
|
||||||
|
if(c>99) {
|
||||||
|
r.reply('Mooooooooooooo!');
|
||||||
|
} else {
|
||||||
|
r.reply("Gem Activated");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
// new stuff
|
||||||
|
robot.respond(/status$/i, function(r) {
|
||||||
|
robot.http("http://status.ctdo.de/api/simple/v2")
|
||||||
|
.header('Accept', 'application/json')
|
||||||
|
.get()(function(err, res, body) {
|
||||||
|
var data = JSON.parse(body);
|
||||||
|
r.reply("Derzeit im Treff: " + data.names.join(', '));
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue