k5sat/app.py
2024-02-25 16:12:24 +08:00

77 lines
2.7 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import head
from datetime import datetime, timedelta
from flask import Flask, request, jsonify
from flask_cors import cross_origin
import ephem
import redis
import uuid
app = Flask(__name__)
r = redis.Redis(host='127.0.0.1', port=6379, db=0)
def local2utc(local_dtm):
# 本地时间转 UTC 时间( -8:00
return datetime.utcfromtimestamp(local_dtm.timestamp())
@app.route("/lol", methods=['POST'])
@cross_origin()
def lol():
func = request.json.get('func', 0)
_uuid = request.json.get('uuid', str(uuid.uuid4()))
_cache = request.json.get('cache', '')
if func == 0:
r.set(_uuid, _cache, 600)
else:
_cache = r.get(_uuid)
return jsonify({'code': 200, 'uuid': _uuid, 'cache': _cache})
@app.route("/pass", methods=['POST'])
@cross_origin()
def satpass():
sat = request.json.get('sat', '')
sat_line_1 = request.json.get('sat_line_1', '')
sat_line_2 = request.json.get('sat_line_2', '')
lat = request.json.get('lat', 0)
lng = request.json.get('lng', 0)
alt = request.json.get('alt', 0)
target_satellite, find_flag = head.FIND_SATE(sat_line_1, sat_line_2, sat)
pass_times, departure_times = head.CAL_PASS_TIME(target_satellite,
float(lat), float(lng),
float(alt))
return jsonify({
'code': 200,
'pass_times': pass_times,
'departure_times': departure_times
})
@app.route("/doppler", methods=['POST'])
@cross_origin()
def doppler():
sat = request.json.get('sat', '')
sat_line_1 = request.json.get('sat_line_1', '')
sat_line_2 = request.json.get('sat_line_2', '')
lat = request.json.get('lat', 0)
lng = request.json.get('lng', 0)
alt = request.json.get('alt', 0)
tx = request.json.get('tx', 0)
rx = request.json.get('rx', 0)
format = "%Y-%m-%d %H:%M:%S"
pass_time = datetime.strptime(request.json.get('pass_time', ''), format)
departure_time = datetime.strptime(request.json.get('departure_time', ''),
format)
satellite = ephem.readtle(sat, sat_line_1, sat_line_2)
# print(str(pass_time) + " " + str(local2utc(pass_time)))
shift_array = []
while pass_time < departure_time + timedelta(seconds=1):
AZ, EI, SHITF_UP, SHIFT_DOWN, DIS = head.CAL_DATA(
satellite, sat_line_1, sat_line_2, float(lng), float(lat),
float(alt), local2utc(pass_time),
float(tx) * 1000000,
float(rx) * 1000000)
shift_array.append([SHITF_UP, SHIFT_DOWN])
pass_time = pass_time + timedelta(seconds=1)
return jsonify({'code': 200, 'shift_array': shift_array})