-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.py
165 lines (126 loc) · 4.75 KB
/
server.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
import os
import json
import time
import bottle
from bottle import route, run, request, static_file, response
import pyaudio
from utils import log
############################### URL ##################################
# STATIC PATH REQUESTS
@route('/static/:path#.+#', name='static')
def static(path):
return static_file(path, root='static')
# INDEX
@route('/')
def root():
return static_file('demo.html', root='./static/')
# AUDIO STREAM
@route('/stream')
def stream():
CHUNK_SIZE = 1024
SAMPLE_RATE = 44100
# Setup pyaudio
paudio = pyaudio.PyAudio()
# Stream Settings
stream = paudio.open(format=pyaudio.paInt16,
channels=1,
rate=SAMPLE_RATE,
input=True,
frames_per_buffer=CHUNK_SIZE)
# Calculate datasize
datasize = (CHUNK_SIZE * 1 * 16) // 8
# Create wav header Python2
h = 'RIFF'.encode('ascii')
h += to_bytes((datasize + 36), 4,'little')
h += 'WAVE'.encode('ascii')
# Create wav header Python3
#h = bytes("RIFF ",'ascii')
#h += (datasize + 36).to_bytes(4,'little')
#h += bytes("WAVE ",'ascii')
# Create response header
response.headers['Content-Type'] = 'audio/x-wav'
response.headers['Cache-Control'] = 'no-cache'
response.headers['Pragma'] = 'no-cache'
response.headers['Connection'] = 'close'
# Read from stream
loops = 0
while True:
data = stream.read(CHUNK_SIZE)
ch = chunkHeader2(SAMPLE_RATE, 16, 1, datasize)
if loops == 0:
r = h + ch + data
loops = 1
else:
r = ch + data
yield r
def chunkHeader(sampleRate, bitsPerSample, channels, datasize):
o = bytes("fmt ",'ascii') # (4byte) Format Chunk Marker
o += (16).to_bytes(4,'little') # (4byte) Length of above format data
o += (1).to_bytes(2,'little') # (2byte) Format type (1 - PCM)
o += (channels).to_bytes(2,'little') # (2byte)
o += (sampleRate).to_bytes(4,'little') # (4byte)
o += (sampleRate * channels * bitsPerSample // 8).to_bytes(4,'little') # (4byte)
o += (channels * bitsPerSample // 8).to_bytes(2,'little') # (2byte)
o += (bitsPerSample).to_bytes(2,'little') # (2byte)
o += bytes("data",'ascii') # (4byte) Data Chunk Marker
o += (datasize).to_bytes(4,'little') # (4byte) Data size in bytes
return o
def chunkHeader2(sampleRate, bitsPerSample, channels, datasize):
o = 'fmt '.encode('ascii')
o += to_bytes(16, 4, 'little')
o += to_bytes(1, 2, 'little')
o += to_bytes(channels, 2, 'little')
o += to_bytes(sampleRate, 4, 'little')
o += to_bytes(sampleRate * channels * bitsPerSample // 8, 4, 'little')
o += to_bytes(channels * bitsPerSample // 8, 2, 'little')
o += to_bytes(bitsPerSample, 2, 'little')
o += 'data'.encode('ascii')
o += to_bytes(datasize, 4, 'little')
return o
def to_bytes(n, length, endianess='big'):
h = '%x' % n
s = ('0'*(len(h) % 2) + h).zfill(length*2).decode('hex')
return s if endianess == 'big' else s[::-1]
# JSON ACTION
@route('/process', method='POST')
def process():
ip = request.environ.get('REMOTE_ADDR')
data = json.loads(request.forms.get('json'))
data['ip'] = ip
return execute(data)
# REQUEST RESPONSE
def make_response(data, success=True):
try:
if success:
data['response'] = 'success'
else:
data['response'] = 'error'
return json.dumps(data, ensure_ascii=False, encoding='iso-8859-1')
except:
log.e(('Response Error!', data), discard=True)
data = {}
data['response'] = 'error'
return json.dumps(data)
# EXECUTE ACTION
def execute(json_data):
# Init
data = {}
# Parse Array
action = json_data['action']
ip = str(json_data['ip'])
# Status
log.p((ip, '|', 'action =', action), discard=True)
########## TEST NEURAL NET #############
try:
if action == 'analysis':
with open('stream_analysis.json', 'r') as jfile:
data = json.load(jfile)
except:
data['response'] = 'error'
return make_response(data)
############################## SERVER ################################
if __name__ == '__main__':
# RUN SERVER
log.p('STREAM SERVER UP AND RUNNING!')
run(host='localhost', port=8080, server='paste')
#run(host='innonuc.informatik.tu-chemnitz.de', port=8080, server='paste')