Files
caotek_monaa/caotek_mesavoirs/views/actifs.py

380 lines
13 KiB
Python

# -*- coding: utf8 -*-
from pyramid.response import Response
from pyramid.renderers import render, get_renderer
from pyramid.view import (
view_config,
forbidden_view_config,
)
from pyramid.security import (
authenticated_userid,
remember,
forget,
)
from pyramid.httpexceptions import (
HTTPFound,
HTTPNotFound,
HTTPForbidden,
)
from pyramid_mailer import get_mailer
from pyramid_mailer.message import Message, Attachment
from datetime import *
import hashlib
from sqlalchemy.exc import DBAPIError
from ..security import groupfinder
from ..models.default import *
from ..models.actifs import *
from ..models.members import (
get_member_by_email,
)
from ..views.default import (
to_euro,
to_usd,
to_decimal,
)
import json
import time
import urllib2
from bs4 import BeautifulSoup
def getYahooQuote(ticker):
# specify the url
quote_page = 'https://finance.yahoo.com/quote/%s/history/' % ticker
# query & parse the html using beautiful soap and store in variable `soup`
soup = BeautifulSoup(urllib2.urlopen(quote_page), 'html.parser')
data = []
# get the quote price
rows = soup.findAll('table')[0].tbody.findAll('tr')
for each_row in rows:
divs = each_row.findAll('td')
if divs[1].span.text != 'Dividend': #Ignore this row in the table
#I'm only interested in 'Close' price;
data.append({'Date': divs[0].span.text, 'Close': float(divs[5].span.text.replace(',',''))})
# retourne la prière ligne
return data[0]
def getCurrencyRate(currency):
# specify the url
quote_page = 'http://www.finances.net/devises/courseuro'
# query & parse the html using beautiful soap and store in variable `soup`
soup = BeautifulSoup(urllib2.urlopen(quote_page), 'html.parser')
# get the history table
rows = soup.find('table', attrs={'class': 'news_table'}).tbody.findAll('tr')
divs = rows[1].findAll('td')
rate = divs[1].span.text
return float(rate.replace(',','.'))
@view_config(route_name='actifs_list', renderer='../templates/actifs/actifs_list.pt', permission='view')
def actifs_list(request):
url = request.route_url('actifs_list')
logged_in = authenticated_userid(request)
message = ''
# lire les actifs
items = get_actifs(request, '0')
# MAJ du prtefeuille
if 'form.submitted' in request.params:
# maj des parités des devises d'après Yahoo finance
update_actif_devise(request, 'USD', getCurrencyRate('USD'))
for item in items:
if item.type == 'ACTION':
# get yahoo price
quote_price = getYahooQuote(item.symbole)
if quote_price:
update_actif_valeur(request, item.symbole, quote_price['Close'])
time.sleep(2) # attendre 2 secondes
# update du portefeuille
update_portefeuille(request, logged_in)
# relire les actifs
items = get_actifs(request, '0')
message = u'Le portefeuille est mis à jour avec succès.'
total_valeur = 0
total_pv = 0
for item in items:
total_valeur += item.valeur
total_pv += item.plus_value
total_pc_value = total_pv / total_valeur * 100
return {
'page_title': u"Mes actifs",
'url': url,
'items': items,
'message': message,
'total_valeur': total_valeur,
'total_pv': total_pv,
'total_pc_value': total_pc_value,
}
@view_config(route_name='actif_edit', renderer='../templates/actifs/actif_edit.pt', permission='view')
def actif_edit(request):
no_id = request.matchdict['no_id']
url = request.route_url('actif_edit', no_id=no_id)
message = ''
allocation_list = get_allocation_bytype(request,'ACTION')
if no_id == '0':
# nouveau
actif = {}
actif['no_id'] = '0'
actif['symbole'] = ''
actif['classe'] = ''
actif['nombre'] = '0'
actif['pru'] = '0'
actif['ter'] = '0'
actif['pc_rdt'] = '0'
page_title= 'Nouvel actif ACTION'
else:
# lire la fiche du actif
actif = get_actifs(request, no_id)
if not actif:
request.session.flash(u"Actif non trouvé : %s" % no_id, 'warning')
return HTTPFound(location=request.route_url('actifs_list'))
page_title= u"Actif ACTION : %s" % (actif.libelle)
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in actif.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
# récupérer les infos du symbole de Yahoo finance
if 'symbole' in request.params:
symbole = request.params['symbole']
else:
symbole = actif.symbole
quote_price = getYahooQuote(symbole)
if quote_price:
new_values['cours'] = quote_price['Close']
update_actif(request, no_id, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('actifs_list'))
else:
message = 'Symbole inconnu. Veuillez ressaisir.'
if 'form.deleted' in request.params:
delete_actif(request, no_id)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('actifs_list'))
return {
'page_title': page_title,
'url': url,
'actif': actif,
'allocation_list': allocation_list,
'message': message,
}
@view_config(route_name='actif2_edit', renderer='../templates/actifs/actif2_edit.pt', permission='view')
def actif2_edit(request):
no_id = request.matchdict['no_id']
url = request.route_url('actif2_edit', no_id=no_id)
message = ''
allocation_list = get_allocation_bytype(request,'AUTRE')
if no_id == '0':
# nouveau
actif = {}
actif['no_id'] = '0'
actif['symbole'] = ''
actif['classe'] = ''
actif['libelle'] = ''
actif['pru'] = '0'
actif['cours'] = '0'
actif['ter'] = '0'
actif['pc_rdt'] = '0'
page_title= 'Nouvel actif'
else:
# lire la fiche du actif
actif = get_actifs(request, no_id)
if not actif:
request.session.flash(u"Actif non trouvé : %s" % no_id, 'warning')
return HTTPFound(location=request.route_url('actifs_list'))
page_title= u"Actif : %s" % (actif.symbole)
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in actif.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
new_values['nombre'] = 1000
new_values['devise'] = 'EUR'
update_actif(request, no_id, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('actifs_list'))
if 'form.deleted' in request.params:
delete_actif(request, no_id)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('actifs_list'))
return {
'page_title': page_title,
'url': url,
'actif': actif,
'allocation_list': allocation_list,
'message': message,
}
@view_config(route_name='allocation_list', renderer='../templates/actifs/allocation_list.pt', permission='view')
def allocation_list(request):
message = ''
# lire les allocation
items = get_allocation(request, '0')
# calculer % total
total = 0
donut_data=[]
donut_data.append(('Allocation', 'Pourcent'))
for item in items:
# totaliser les pourcentages
total += item.pc_cible
# construire la liste pour donut
d = (item.classe, item.pc_cible)
donut_data.append(d)
if total <> 100:
message = u'Attention, le total de votre répartition cible ne fait pas 100%.'
return {
'page_title': u"Allocation cible",
'message': message,
'items': items,
'total': total,
'donut_data': json.dumps(donut_data),
}
@view_config(route_name='allocation_edit', renderer='../templates/actifs/allocation_edit.pt', permission='view')
def allocation_edit(request):
no_cat = request.matchdict['no_cat']
url = request.route_url('allocation_edit', no_cat=no_cat)
message = ''
# lire les classes
classes_list = get_classes(request, '0')
if no_cat == '0':
# nouveau
allocation = {}
allocation['no_cat'] = '0'
allocation['classe'] = ''
allocation['type'] = 'ACTION'
allocation['pc_cible'] = '0'
page_title= u'Nouvelle classe'
else:
# lire la fiche de la categorie
allocation = get_allocation(request, no_cat)
if not allocation:
request.session.flash(u"Classe non trouvé : %s" % no_cat, 'warning')
return HTTPFound(location=request.route_url('allocation_list'))
page_title= u"Classe : %s" % (allocation.classe)
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in allocation.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
update_allocation(request, no_cat, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('allocation_list'))
if 'form.deleted' in request.params:
delete_allocation(request, no_cat)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('allocation_list'))
return {
'page_title': page_title,
'url': url,
'allocation': allocation,
'classes_list': classes_list,
'message': message,
}
@view_config(route_name='histo_list', renderer='../templates/actifs/histo_list.pt', permission='manage')
def histo_list(request):
# lire l historique
items = get_histo(request, '0')
liste=[]
for item in items:
# construire la liste pour datatable
d = (item.date.strftime('%d/%m/%Y'), to_euro(item.mvt_cash), to_euro(item.valeur_pf), to_euro(item.nb_part),
to_euro(item.val_part), to_euro(item.cours_ref), to_euro(item.val_part_ref), str(item.no_id).zfill(4))
liste.append(d)
return {
'page_title': u'Historique',
'dt_data': json.dumps(liste),
}
@view_config(route_name='histo_edit', renderer='../templates/actifs/histo_edit.pt', permission='view')
def histo_edit(request):
no_id = request.matchdict['no_id']
url = request.route_url('histo_edit', no_id=no_id)
message = ''
today = datetime.today()
if no_id == '0':
# nouveau
item = {}
item['no_id'] = 0
item['date'] = today
item['mvt_cash'] = 0.0
item['nb_part'] = 0.0
page_title= u'Nouvelle valeur part'
else:
# lire la fiche de la categorie
item = get_histo(request, no_id)
if not item:
request.session.flash(u"Histo non trouvé : %s" % no_id, 'warning')
return HTTPFound(location=request.route_url('histo_list'))
page_title= u"Valeur part au %s" % (item.date.strftime('%d/%m/%Y'))
if 'form.submitted' in request.params:
new_values = {}
for param, db_value in item.items():
if param in request.params and request.params[param] != db_value:
new_values[param] = request.params[param]
if new_values:
# lire le cours de l'indice de réfence : Carmignac Investissement A EUR Acc
sym = Share('FR0010148981.PA')
new_values['cours_ref'] = sym.get_price()
update_histo(request, no_id, new_values)
request.session.flash(u"La fiche a été mise à jour avec succès.", 'success')
return HTTPFound(location=request.route_url('histo_list'))
if 'form.deleted' in request.params:
delete_histo(request, no_id)
request.session.flash(u"La fiche a été supprimée avec succès.", 'success')
return HTTPFound(location=request.route_url('histo_list'))
return {
'page_title': page_title,
'url': url,
'item': item,
'today': today,
'message': message,
}