Implement info tables for individual song completions. Fixed bugs with uploading songs that were considered invalid

This commit is contained in:
sigonasr2 2020-08-09 10:31:36 -05:00
parent 1a87505c87
commit 4e6df0beb6
11 changed files with 1309 additions and 112 deletions

View File

@ -12,6 +12,10 @@ services:
- ./server:/server
env_file:
- ./server/.env.twitter
logging:
options:
max-size: "1m"
max-file: "3"
postgres:
image: postgres:10.4
@ -24,6 +28,10 @@ services:
environment:
POSTGRES_USER: postgres
POSTGRES_DB: divar
logging:
options:
max-size: "1m"
max-file: "3"
frontend:
build:
@ -42,6 +50,10 @@ services:
volumes:
- /app/node_modules
- ./frontend:/frontend
logging:
options:
max-size: "1m"
max-file: "3"
# prod-frontend:

View File

@ -4,6 +4,10 @@ badge-success {hard}
badge-warning {ex}
badge-danger {exex}*/
.highest{
z-index:1000001;
}
.display-tooltip{
position:absolute;
z-index:1000000;
@ -11,6 +15,12 @@ badge-danger {exex}*/
font-size:12px;
}
.display-tooltipside{
position:absolute;
z-index:1000000;
font-size:12px;
top:-6px;
}
.easy-background{
background-color:#d6f1ff;
}
@ -48,6 +58,15 @@ body {
0 0 8px #999
}
.nostyle{
color: #333;
}
.nostyle:hover{
color: #333;
text-decoration:none;
background: #eef;
}
table th {
position: -webkit-sticky; /* this is for all Safari (Desktop & iOS), not for Chrome*/
position: sticky;

View File

@ -302,81 +302,141 @@ function Difficulty(p) {
function Play(p) {
function GetModifiedDiff(name) {
switch (name) {
case "E":{
return "easy";
}
case "N":{
return "normal";
}
case "H":{
return "hard";
}
case "EX":{
return "ex";
}
case "EXEX":{
return "exex";
}
}
}
function GetDateDiff() {
var hours = Math.floor((Date.now()-new Date(p.play.date))/1000/60/60);
var days = Math.floor(hours/24)
if (hours<24) {return <>{hours} {"hour"+((hours!==1)?"s":"")} ago</>}
return <>{days} {"day"+((days!==1)?"s":"")} ago</>
}
return (
<>
<div className={"row align-middle "+((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"pfc":(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"fc":"")}>
{(p.index!==undefined)?<div className=" col-md-1 text-center border-right align-middle text-nowrap overflow-hidden"><span className="d-none d-md-block">{p.index+1}</span>{((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge pfc">PFC</span>:(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge fc">FC</span>:<></>)}</div>:<></>}
<div className="col-md-3 text-center border-right align-middle text-nowrap overflow-hidden"><SongName song={p.song}/><span className="tinytime">{GetDateDiff()}</span></div>
<div className="col-md-2 text-center border-right align-middle text-nowrap overflow-hidden">{Math.floor(p.play.score)} pts<br/><Difficulty play={p.play} song={p.song}/></div>
<div className="col-md-6">
<div className="row">
<div className="order-1 order-md-1 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_cool.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.cool}
</div>
function GetDateDisplay() {
var date = new Date(p.play.date);
var months = ["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]
return <>{months[date.getMonth()]+" "+date.getDate()+" "+date.getFullYear()+" "+date.getHours()+":"+((date.getMinutes()<10)?"0"+date.getMinutes():date.getMinutes())}<span className="tinytime">{GetDateDiff()}</span></>
}
if (p.mini) {
return (
<>
<div className={"row align-middle "+((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"pfc":(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"fc":"")}>
<div className="col-md-2 order-1 order-md-1 text-center border-right align-middle text-nowrap overflow-hidden">{Math.floor(p.play.score)} pts<br/>{((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge pfc">PFC</span>:(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge fc">FC</span>:<></>)}<Difficulty play={p.play} song={p.song}/></div>
<div className="col-md-3 order-3 order-md-2 text-center border-right align-middle text-nowrap overflow-hidden">{GetDateDisplay()}</div>
<div className="col-md-5 order-2 order-md-3">
<div className="row">
<div className="col-12 order-1 order-md-1 col-md-6 text-center">
{p.play.cool+"/"+p.play.fine+"/"+p.play.safe+"/"+p.play.sad+"/"+p.play.worst}
</div>
<div className="col-6 order-3 order-md-2 col-md-3 text-left text-md-left">
{(p.play.mod!==null&&p.play.mod.length>0)?
<ModDisplay side={true} badge={CalculateBadge(p.play.difficulty)} diff={GetModifiedDiff(p.play.difficulty)}
hs={p.play.mod=="HS"?1:0} hd={p.play.mod=="HD"?1:0} sd={p.play.mod=="SD"?1:0}/>
:<></>
}
</div>
<div className="col-6 order-2 order-md-3 col-md-3 text-right text-md-left">
<b>{p.play.percent}%</b>
</div>
</div>
<div className="order-3 order-md-2 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_safe.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.safe}
</div>
</div></div>
<div className="order-5 order-md-3 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_worst.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.worst}
</div>
</div></div>
<div className="order-2 order-md-4 order-sm-2 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_fine.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.fine}
</div>
</div></div>
<div className="order-4 order-md-5 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_sad.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.sad}
</div>
</div></div>
<div className="order-6 order-md-6 col-md-4 numbers text-center"><b>{p.play.percent}%</b></div>
</div>
</div>
</div>
</>
);
</>
);
} else {
return (
<>
<div className={"row align-middle "+((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"pfc":(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?"fc":"")}>
{(p.index!==undefined)?<div className=" col-md-1 text-center border-right align-middle text-nowrap overflow-hidden"><span className="d-none d-md-block">{p.index+1}</span>{((p.play.fine==0&&p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge pfc">PFC</span>:(p.play.safe==0&&p.play.sad==0&&p.play.worst==0)?<span className="badge fc">FC</span>:<></>)}</div>:<></>}
<div className="col-md-3 text-center border-right align-middle text-nowrap overflow-hidden"><SongName song={p.song}/><span className="tinytime">{GetDateDiff()}</span></div>
<div className="col-md-2 text-center border-right align-middle text-nowrap overflow-hidden">{Math.floor(p.play.score)} pts<br/><Difficulty play={p.play} song={p.song}/></div>
<div className="col-md-6">
<div className="row">
<div className="order-1 order-md-1 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_cool.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.cool}
</div>
</div>
</div>
<div className="order-3 order-md-2 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_safe.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.safe}
</div>
</div></div>
<div className="order-5 order-md-3 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_worst.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.worst}
</div>
</div></div>
<div className="order-2 order-md-4 order-sm-2 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_fine.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.fine}
</div>
</div></div>
<div className="order-4 order-md-5 col-md-4 numbers text-center">
<div className="row justify-content-center">
<div className="col-4 col-md-5">
<img src={RATING_sad.src} className="pr-2" height="16"/>
</div>
<div className="col-4 col-md-7">
{p.play.sad}
</div>
</div></div>
<div className="order-6 order-md-6 col-md-4 numbers text-center"><b>{p.play.percent}%</b></div>
</div>
</div>
</div>
</>
);
}
}
function BestPlaysPanel(p) {
var [bestPlays,setBestPlays] = useState([])
useEffect(()=>{
axios.get("http://www.projectdivar.com/bestplays/"+p.username+"?fails=false&limit=5&offset=0")
.then((data)=>{setBestPlays(data.data);})
})
return (
<>
<div className="d-none d-md-block row">
<div className="col-md-12 mt-3 mb-3">
<ul className="list-group list-group-flush overflow-auto border border-danger rounded-lg" style={{height:"320px"}}>
{p.bestplays.map((play,i)=>{return <li key={play.id} className={"list-group-item list-group-item-action "+(i%2==0?"background-list-1":"background-list-2")}>
{bestPlays.map((play,i)=>{return <li key={play.id} className={"list-group-item list-group-item-action "+(i%2==0?"background-list-1":"background-list-2")}>
<Play index={i} play={play} song={p.songs[play.songid]}/>
</li>})}
</ul>
@ -385,7 +445,7 @@ function BestPlaysPanel(p) {
<div className="d-block d-sm-block d-md-none row ml-3 mr-3">
<div className="col-md-12 mt-3 mb-3">
<ul className="list-group list-group-flush overflow-auto border border-danger rounded-lg" style={{height:"320px"}}>
{p.bestplays.map((play,i)=>{return <li key={play.id} className={"list-group-item list-group-item-action "+(i%2==0?"background-list-1":"background-list-2")}>
{bestPlays.map((play,i)=>{return <li key={play.id} className={"list-group-item list-group-item-action "+(i%2==0?"background-list-1":"background-list-2")}>
<Play index={i} play={play} song={p.songs[play.songid]}/>
</li>})}
</ul>
@ -404,7 +464,7 @@ function ModDisplay(p) {
{(p.hs>0)?<span style={{color:"#b33"}} onMouseOver={()=>{setTooltip("High Speed - "+p.diff.toUpperCase());setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}></span>:<></>}
{(p.hd>0)?<span onMouseOver={()=>{setTooltip("Hidden - "+p.diff.toUpperCase());setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}} style={{color:"#968a0e"}}></span>:<></>}
{(p.sd>0)?<span onMouseOver={()=>{setTooltip("Sudden - "+p.diff.toUpperCase());setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}} style={{color:"#49b"}}></span>:<></>}
{(visibility)?<span style={{position:"absolute"}} className={"display-tooltip alert alert-dark "+p.diff+"-background"}>{tooltip}</span>:<></>}
{(visibility)?<span style={{position:"absolute"}} className={((p.side)?"display-tooltipside":"display-tooltip")+" alert alert-dark "+p.diff+"-background"}>{tooltip}</span>:<></>}
</span>
)
}
@ -426,11 +486,11 @@ function PlayDetail(p) {
{(p.song.report.rank>0)?<>{p.song.report.percent}%</>:""}
</td>
<td>
{p.song.report.ecount>0?<span className="badge badge-primary" onMouseOver={()=>{setTooltip(p.song.report.eclearcount+" / "+p.song.report.ecount+" ("+(Math.floor(p.song.report.eclearcount/p.song.report.ecount)*100)+"% pass rate)");setStyle("easy");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.epfccount>0?"✪":p.song.report.efccount>0?"★":""}{p.song.report.ecount}</span>:<></>}
{p.song.report.ncount>0?<span className="badge badge-info" onMouseOver={()=>{setTooltip(p.song.report.nclearcount+" / "+p.song.report.ncount+" ("+(Math.floor(p.song.report.nclearcount/p.song.report.ncount)*100)+"% pass rate)");setStyle("normal");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.npfccount>0?"✪":p.song.report.nfccount>0?"★":""}{p.song.report.ncount}</span>:<></>}
{p.song.report.hcount>0?<span className="badge badge-success" onMouseOver={()=>{setTooltip(p.song.report.hclearcount+" / "+p.song.report.hcount+" ("+(Math.floor(p.song.report.hclearcount/p.song.report.hcount)*100)+"% pass rate)");setStyle("hard");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.hpfccount>0?"✪":p.song.report.hfccount>0?"★":""}{p.song.report.hcount}</span>:<></>}
{p.song.report.excount>0?<span className="badge badge-warning" onMouseOver={()=>{setTooltip(p.song.report.exclearcount+" / "+p.song.report.excount+" ("+(Math.floor((p.song.report.exclearcount/p.song.report.excount)*100))+"% pass rate)");setStyle("ex");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.expfccount>0?"✪":p.song.report.exfccount>0?"★":""}{p.song.report.excount}</span>:<></>}
{p.song.report.exexcount>0?<span className="badge badge-danger" onMouseOver={()=>{setTooltip(p.song.report.exexclearcount+" / "+p.song.report.exexcount+" ("+(Math.floor(p.song.report.exexclearcount/p.song.report.exexcount)*100)+"% pass rate)");setStyle("exex");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.exexpfccount>0?"✪":p.song.report.exexfccount>0?"★":""}{p.song.report.exexcount}</span>:<></>}
{p.song.report.ecount>0?<span className="badge badge-primary" onMouseOver={()=>{setTooltip(<>{p.song.report.eclearcount+" / "+p.song.report.ecount+" ("+(Math.floor((p.song.report.eclearcount/p.song.report.ecount)*100))+"% pass rate)"}{(p.song.report.efccount>0)?<><br/>{"★FC'd "+p.song.report.efccount+" time"+(p.song.report.efccount!=1?"s":"")}</>:<></>}{(p.song.report.epfccount>0)?<><br/>{"✪Perfected "+p.song.report.epfccount+" time"+(p.song.report.epfccount!=1?"s":"")}</>:<></>}</>);setStyle("easy");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.epfccount>0?"":p.song.report.efccount>0?"":""}{p.song.report.ecount}</span>:<></>}
{p.song.report.ncount>0?<span className="badge badge-info" onMouseOver={()=>{setTooltip(<>{p.song.report.nclearcount+" / "+p.song.report.ncount+" ("+(Math.floor((p.song.report.nclearcount/p.song.report.ncount)*100))+"% pass rate)"}{(p.song.report.nfccount>0)?<><br/>{"★FC'd "+p.song.report.nfccount+" time"+(p.song.report.nfccount!=1?"s":"")}</>:<></>}{(p.song.report.npfccount>0)?<><br/>{"✪Perfected "+p.song.report.npfccount+" time"+(p.song.report.npfccount!=1?"s":"")}</>:<></>}</>);setStyle("normal");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.npfccount>0?"":p.song.report.nfccount>0?"":""}{p.song.report.ncount}</span>:<></>}
{p.song.report.hcount>0?<span className="badge badge-success" onMouseOver={()=>{setTooltip(<>{p.song.report.hclearcount+" / "+p.song.report.hcount+" ("+(Math.floor((p.song.report.hclearcount/p.song.report.hcount)*100))+"% pass rate)"}{(p.song.report.hfccount>0)?<><br/>{"★FC'd "+p.song.report.hfccount+" time"+(p.song.report.hfccount!=1?"s":"")}</>:<></>}{(p.song.report.hpfccount>0)?<><br/>{"✪Perfected "+p.song.report.hpfccount+" time"+(p.song.report.hpfccount!=1?"s":"")}</>:<></>}</>);setStyle("hard");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.hpfccount>0?"":p.song.report.hfccount>0?"":""}{p.song.report.hcount}</span>:<></>}
{p.song.report.excount>0?<span className="badge badge-warning" onMouseOver={()=>{setTooltip(<>{p.song.report.exclearcount+" / "+p.song.report.excount+" ("+(Math.floor((p.song.report.exclearcount/p.song.report.excount)*100))+"% pass rate)"}{(p.song.report.exfccount>0)?<><br/>{"★FC'd "+p.song.report.exfccount+" time"+(p.song.report.exfccount!=1?"s":"")}</>:<></>}{(p.song.report.expfccount>0)?<><br/>{"✪Perfected "+p.song.report.expfccount+" time"+(p.song.report.expfccount!=1?"s":"")}</>:<></>}</>);setStyle("ex");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.expfccount>0?"":p.song.report.exfccount>0?"":""}{p.song.report.excount}</span>:<></>}
{p.song.report.exexcount>0?<span className="badge badge-danger" onMouseOver={()=>{setTooltip(<>{p.song.report.exexclearcount+" / "+p.song.report.exexcount+" ("+(Math.floor((p.song.report.exexclearcount/p.song.report.exexcount)*100))+"% pass rate)"}{(p.song.report.exexfccount>0)?<><br/>{"★FC'd "+p.song.report.exexfccount+" time"+(p.song.report.exexfccount!=1?"s":"")}</>:<></>}{(p.song.report.exexpfccount>0)?<><br/>{"✪Perfected "+p.song.report.exexpfccount+" time"+(p.song.report.exexpfccount!=1?"s":"")}</>:<></>}</>);setStyle("exex");setVisibility(true)}} onMouseOut={()=>{setVisibility(false)}}>{p.song.report.exexpfccount>0?"":p.song.report.exexfccount>0?"":""}{p.song.report.exexcount}</span>:<></>}
{(visibility)?<span style={{position:"absolute"}} className={"display-tooltip alert alert-dark "+style+"-background"}>{tooltip}</span>:<></>}
</td>
<td>
@ -464,15 +524,49 @@ function PlayDetail(p) {
);
}
function HoverSongName(p) {
const [name,setName] = useState(p.song.name)
function PlayData(p) {
var [data,setData] = useState([])
var [update,setUpdate] = useState(false)
useEffect(()=>{
axios.get("http://projectdivar.com/plays/"+p.username+"/"+p.song.id)
.then((data)=>{setData(data.data)})
},[update])
return (
<tr key={p.song.id} className="lighthover" onMouseOver={()=>{setName((p.song.romanized_name.length>0)?p.song.romanized_name:p.song.english_name)}} onMouseOut={()=>{setName(p.song.name)}}>
<td>
{name}
</td>
<PlayDetail song={p.song}/>
</tr>
<>
<div className="overflow-auto text-center" style={{height:"160px",width:"90%"}}>
{data.map((play,i)=><Play key={i} play={play} mini={true} song={p.song}/>)}
</div>
</>
)
}
function HoverSongName(p) {
var [name,setName] = useState(p.song.name)
var [expand,setExpand] = useState(<></>)
var [toggle,setToggle] = useState(false)
return (
<>
<tr key={p.song.id} className="lighthover" onMouseOver={()=>{setName((p.song.romanized_name.length>0)?p.song.romanized_name:p.song.english_name)}} onMouseOut={()=>{setName(p.song.name)}}
data-toggle="collapse" data-target={"#collapse"+p.song.id} aria-expanded="false" aria-controls="collapseExample" onClick={()=>{
if (!toggle) {
setExpand(<PlayData song={p.song} username={p.username}/>)
setToggle(true)
} else {
setToggle(false)
}
}
}>
<td>
{name}
</td>
<PlayDetail song={p.song}/>
</tr>
<tr className="collapse" id={"collapse"+p.song.id}>
<td colSpan="6">{expand}</td>
</tr>
</>
)
}
@ -511,7 +605,7 @@ function CompletionPanel(p) {
</tr>
</thead>
<tbody>
{report.map((song,i)=>{return <HoverSongName song={song} key={song.id}/>
{report.map((song,i)=>{return <HoverSongName song={song} key={song.id} username={p.username}/>
})}
</tbody>
<tfoot>
@ -538,6 +632,24 @@ const CalculateAccuracy=(cool,fine,safe,sad,worst)=>{
return Math.round((sum/noteCount)*10000)/100+"%";
}
function ClearBadge(p) {
var [display,setDisplay] = useState(<></>)
/*<span className="badge badge-primary">{easy}/{diffs.E}
{(fcdata&&fcdata.E>0)?<><br/>{fcdata.E}</>:<></>}
{(pfcdata&&pfcdata.E>0)?<><br/>{pfcdata.E}</>:<></>}</span>*/
return(
<>
<span className={"badge badge-"+CalculateBadge(p.diff)} onMouseOver={()=>{
setDisplay(<>{((p.fcdata&&p.fcdata[p.diff]>0)?<><br/>{p.fcdata[p.diff]}</>:<></>)}
{((p.pfcdata&&p.pfcdata[p.diff]>0)?<><br/>{p.pfcdata[p.diff]}</>:<></>)}</>)
}} onMouseOut={()=>{
setDisplay(<></>)
}}>{p.count}/{p.diffs[p.diff]}{display}</span>
</>
)
}
function Profile(p){
let { username } = useParams();
let match = useRouteMatch();
@ -551,11 +663,16 @@ function Profile(p){
var [update,setUpdate] = useState(false);
var [diffs,setDiffs] = useState({});
var [user,setUserData] = useState({});
var [bestPlays,setBestPlays] = useState([]);
var [render,setRender] = useState(false);
function CalculateClear(easy,normal,hard,ex,exex) {
return <><span className="badge badge-primary">{easy}/{diffs.E}</span><span className="badge badge-info">{normal}/{diffs.N}</span><span className="badge badge-success">{hard}/{diffs.H}</span><span className="badge badge-warning">{ex}/{diffs.EX}</span><span className="badge badge-danger">{exex}/{diffs.EXEX}</span></>;
function CalculateClear(easy,normal,hard,ex,exex,fcdata,pfcdata) {
return <>
<ClearBadge diff="E" count={easy} diffs={diffs} fcdata={fcdata} pfcdata={pfcdata}/>
<ClearBadge diff="N" count={normal} diffs={diffs} fcdata={fcdata} pfcdata={pfcdata}/>
<ClearBadge diff="H" count={hard} diffs={diffs} fcdata={fcdata} pfcdata={pfcdata}/>
<ClearBadge diff="EX" count={ex} diffs={diffs} fcdata={fcdata} pfcdata={pfcdata}/>
<ClearBadge diff="EXEX" count={exex} diffs={diffs} fcdata={fcdata} pfcdata={pfcdata}/>
</>
}
useEffect(()=>{
@ -563,17 +680,17 @@ function Profile(p){
.then((data)=>{setUserData(data.data);setPlayCount(data.data.playcount);setFCCount(data.data.fccount);setRating(data.data.rating);setLastPlayed(data.data.last_played);setAccuracy(CalculateAccuracy(data.data.cool,data.data.fine,data.data.safe,data.data.sad,data.data.worst))});
axios.get("http://projectdivar.com:4501/songdiffs")
.then((data)=>{setDiffs(data.data)})
axios.get("http://www.projectdivar.com/bestplays/"+username+"?fails=false")
.then((data)=>{setBestPlays(data.data);})
},[update])
useEffect(()=>{
setClear(CalculateClear(user.eclear,user.nclear,user.hclear,user.exclear,user.exexclear))
if (user!={}) {
setClear(CalculateClear(user.eclear,user.nclear,user.hclear,user.exclear,user.exexclear,user.fcdata,user.pfcdata))
}
},[diffs,user])
useEffect(()=>{
setRender(user&&playcount&&fccount&&rating&&lastPlayed&&accuracy&&diffs&&bestPlays&&cleared)
},[user,playcount,fccount,rating,lastPlayed,accuracy,diffs,bestPlays,cleared])
setRender(user&&playcount&&fccount&&rating&&lastPlayed&&accuracy&&diffs&&cleared)
},[user,playcount,fccount,rating,lastPlayed,accuracy,diffs,cleared])
return (
<>
@ -581,7 +698,7 @@ function Profile(p){
{(render)?<>
<StatisticsPanel name="Statistics" username={username} playcount={playcount} fccount={fccount} cleared={cleared} accuracy={accuracy}/>
<HitCountsPanel name="Hit Counts" username={username} user={user}/>
<BestPlaysPanel name="Best Plays" username={username} bestplays={bestPlays} songs={p.songs}/>
<BestPlaysPanel name="Best Plays" username={username} songs={p.songs}/>
<CompletionPanel name="Progress" username={username} songs={p.songs}/>
<Panel name="Activity" username={username}/>
</>
@ -632,7 +749,7 @@ function Rankings(){
);
}
function Submit(p) {
function ImageUpload(p) {
var [file,setFile] = useState(null);
var [fileProcess,setFileProcess] = useState(0);
var [error,setError] = useState(null);
@ -654,7 +771,7 @@ function Submit(p) {
}
const data = new FormData()
data.append('file', file)
data.append("username","sigonasr2");
data.append("username","The Internet");
data.append("authentication_token","sig");
if (!data.has("username") || !data.has("authentication_token")) {setError("Authentication failed!");return;}
@ -704,6 +821,104 @@ function Submit(p) {
}
}
function SongSearch(p) {
//Requires: p.song / p.setSong
const [song,setSong] = useState("")
const [focused,setFocused] = useState(false)
return (
<>
<input className="form-control form-control-lg" value={song} placeholder={p.song} onFocus={()=>{setFocused(true)}} onChange={(e)=>{
setSong(e.target.value)
}
}/>
{(focused)?
<div className="overflow-auto rounded-lg" style={{background:"#eef",position:"absolute",width:"95%",height:"240px"}}>{Object.keys(p.songs).filter((key)=>
{
var s = p.songs[key]
return s.name.toLowerCase().includes(song.toLowerCase())||s.romanized_name.toLowerCase().includes(song.toLowerCase())||s.english_name.toLowerCase().includes(song.toLowerCase())||s.artist.toLowerCase().includes(song.toLowerCase())||s.vocaloid.toLowerCase().includes(song.toLowerCase())
}).map((key)=><div className="pb-1 homelink" onClick={()=>{setSong(p.songs[key].name);setFocused(false)}}><h4>{p.songs[key].name}</h4>{(p.songs[key].romanized_name)?p.songs[key].romanized_name:p.songs[key].english_name}</div>)}</div>:<></>}
More stuff goes here.
</>
)
}
function SimpleUpload(p){
const [song,setSong] = useState("Catch the Wave")
return (
<>
<SongSearch song={song} setSong={setSong} songs={p.songs}/>
</>
)
}
function Submit(p) {
return (
<div className="row">
<div className="col-12 col-md-8">
<Switch>
<Route path="/submitplay/simple">
<SimpleUpload songs={p.songs}/>
</Route>
<Route path="/submitplay/detail">
Detailed
</Route>
<Route path="/submitplay/switch">
Switch
</Route>
<Route path="/submitplay/image">
<ImageUpload/>
</Route>
<Route path="/submitplay">
<h2>Select a submission method</h2>
<div className="card">
<Link to="/submitplay/simple" className="nostyle">
<div className="card-body">
<h5 className="card-title">Simple Submit</h5>
<p className="card-text">Submit your plays by entering the clear % of a song</p>
<p className="card-text"><small className="text-muted">The simplest way to submit plays, it won't be entirely accurate, but it lets you submit plays very quickly.</small></p>
</div>
</Link>
</div>
<br/>
<div className="card">
<Link to="/submitplay/detail" className="nostyle">
<div className="card-body">
<h5 className="card-title">Detailed Submit</h5>
<p className="card-text">Submit your plays by entering all the information about a play</p>
<p className="card-text"><small className="text-muted">You can submit as many songs as you like, but you will have to provide details for each play.</small></p>
</div>
</Link>
</div>
<br/>
<div className="card">
<Link to="/submitplay/image" className="nostyle">
<div className="card-body">
<h5 className="card-title">Image Upload</h5>
<p className="card-text">Upload images from your Nintendo Switch for automatic processing/scoring!</p>
<p className="card-text"><small className="text-muted">Put up to 50 images in a zip file to mass-upload your screenshotted plays to your profile. You will need to extract them from your microSD card from your Nintendo Switch.</small></p>
</div>
</Link>
</div>
<br/>
<div className="card">
<Link to="/submitplay/switch" className="nostyle">
<div className="card-body">
<h5 className="card-title">Nintendo Switch/Twitter Upload</h5>
<p className="card-text">Setup your account for uploading through Twitter using your Nintendo Switch!</p>
<p className="card-text"><small className="text-muted">You can select up to 4 images to post to Twitter at one time.</small></p>
</div>
</Link>
</div>
</Route>
</Switch>
</div>
</div>
)
}
function Website() {
const [songs,setSongs] = useState([])
const [update,setUpdate] = useState(false)
@ -719,7 +934,7 @@ function Website() {
return (
<div className="row">
<div className="col-md-2 pt-3 pb-3 overflow-hidden text-center">
<h3>Sidebar Contents</h3>
<h3 className="d-none d-md-block">Sidebar Contents</h3>
<Link to="/rankings/rating/desc">Rankings</Link><br/>
Item 2<br/>
Item 3<br/>
@ -736,7 +951,7 @@ function Website() {
}
</Route>
<Route path="/submitplay">
<Submit/>
<Submit songs={songs}/>
</Route>
<Route path="/">
<h1 className="title">Project DivaR</h1>

View File

@ -1,6 +1,20 @@
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
"/plays/:username/:songname",
createProxyMiddleware({
target: 'http://server:4501',
changeOrigin: true,
})
);
app.use(
"/song/:songname/:difficulty",
createProxyMiddleware({
target: 'http://server:4501',
changeOrigin: true,
})
);
app.use(
"/ratings/:songname",
createProxyMiddleware({

View File

@ -102,7 +102,7 @@ app.delete('/remove',(req,res)=>{
db.query("select id,authentication_token,playcount,fccount,cool,fine,safe,sad,worst,eclear,nclear,hclear,exclear,exexclear from users where username=$1 limit 1",[req.body.username])
.then((data)=>{if(data && data.rows.length>0){userObj=data.rows[0];if (req.body.authentication_token===userObj.authentication_token){return db.query("delete from plays where id=$1 and userid=$2 returning *",[req.body.playid,userObj.id])}else{throw new Error("Could not authenticate user!")}}else{throw new Error("Cannot find user!")}})
.then((data)=>{if(data && data.rows.length>0){songObj=data.rows[0];return CalculateRating(req.body.username)}else{throw new Error("Could not find play!")}})
.then((data)=>{rating=data;return db.query("select * from plays where songid=$1 and userid=$2 and difficulty=$3 limit 1",[songObj.songid,userObj.id,songObj.difficulty])})
.then((data)=>{rating=data;return db.query("select * from plays where songid=$1 and userid=$2 and difficulty=$3 and score>0 limit 1",[songObj.songid,userObj.id,songObj.difficulty])})
.then((data)=>{if(data && data.rows.length===0){isFirstClear=true;}/*console.log([data,userObj.playcount-1,(songObj.safe==0&&songObj.sad==0&&songObj.worst==0)?userObj.fccount-1:userObj.fccount,userObj.cool-songObj.cool,userObj.fine-songObj.fine,userObj.safe-songObj.safe,userObj.sad-songObj.sad,userObj.worst-songObj.worst,(songObj.difficulty=="E")?userObj.ecount-1:userObj.ecount,(songObj.difficulty=="N")?userObj.ncount-1:userObj.ncount,(songObj.difficulty=="H")?userObj.hcount-1:userObj.hcount,(songObj.difficulty=="EX")?userObj.excount-1:userObj.excount,(songObj.difficulty=="EXEX")?userObj.exexcount-1:userObj.exexcount]);*/return db.query("update users set rating=$1,playcount=$2,fccount=$3,cool=$4,fine=$5,safe=$6,sad=$7,worst=$8,eclear=$9,nclear=$10,hclear=$11,exclear=$12,exexclear=$13 where id=$14 returning rating,playcount,fccount,cool,fine,safe,sad,worst,eclear,nclear,hclear,exclear,exexclear",[rating,userObj.playcount-1,(songObj.safe==0&&songObj.sad==0&&songObj.worst==0)?userObj.fccount-1:userObj.fccount,userObj.cool-songObj.cool,userObj.fine-songObj.fine,userObj.safe-songObj.safe,userObj.sad-songObj.sad,userObj.worst-songObj.worst,(songObj.difficulty=="E" && isFirstClear)?userObj.eclear-1:userObj.eclear,(songObj.difficulty=="N" && isFirstClear)?userObj.nclear-1:userObj.nclear,(songObj.difficulty=="H" && isFirstClear)?userObj.hclear-1:userObj.hclear,(songObj.difficulty=="EX" && isFirstClear)?userObj.exclear-1:userObj.exclear,(songObj.difficulty=="EXEX" && isFirstClear)?userObj.exexclear-1:userObj.exexclear,userObj.id])})
.then((data)=>{if(data && data.rows.length>0){res.status(200).json({user:data.rows[0],song:songObj})}else{throw new Error("Could not update user information, but song is deleted!")}})
.catch((err)=>{res.status(500).json(err.message)})
@ -207,7 +207,13 @@ app.post('/upload', function(req, res) {
app.post('/submit', (req, res) => {
if (req.body &&
req.body.username!==undefined && req.body.authentication_token!==undefined && req.body.song!==undefined && req.body.difficulty!==undefined && req.body.cool!==undefined && req.body.fine!==undefined && req.body.safe!==undefined && req.body.sad!==undefined && req.body.worst!==undefined && req.body.percent!==undefined) {
req.body.username!==undefined && req.body.authentication_token!==undefined && req.body.song!==undefined && req.body.difficulty!==undefined && req.body.cool!==undefined && req.body.fine!==undefined && req.body.safe!==undefined && req.body.sad!==undefined && req.body.worst!==undefined && req.body.fail!==undefined && req.body.percent!==undefined) {
if (req.body.cool==-1||req.body.fine==-1||req.body.safe==-1||req.body.sad==-1||req.body.worst==-1) {
fs.writeFileSync("invalidSongs",JSON.stringify(req.body)+"\n","a");
res.status(400).json("Invalid note parameters!");
}
var fail = true;
if (req.body.fail!==undefined) {
fail = (req.body.fail=='true');
@ -263,8 +269,11 @@ app.post('/submit', (req, res) => {
CalculateSongScore=(song)=>{
if (song.fail==true){return 0;}
var noteCount=song.cool+song.fine+song.safe+song.sad+song.worst;
var comboBreaks=song.safe+song.sad+song.worst;
var noteCount=Number(song.cool)+Number(song.fine)+Number(song.safe)+Number(song.sad)+Number(song.worst);
var comboBreaks=Number(song.safe)+Number(song.sad)+Number(song.worst);
/*console.log("Combo Breaks: "+comboBreaks)
console.log("Is FC? "+(comboBreaks===0))
console.log("Is PFC? "+(song.fine===0&&song.safe===0&&song.sad===0&&song.worst===0))*/
var scoreMult=1;
var percentMult=1;
if (song.fine===0&&song.safe===0&&song.sad===0&&song.worst===0){scoreMult=3}else if(comboBreaks===0){scoreMult=2}else{scoreMult=1}
@ -278,6 +287,8 @@ CalculateSongScore=(song)=>{
if(song.percent<60){percentMult=0}else{percentMult=1+(0.4*((song.percent-60)/40.0))}
}
}
/*console.log("Score mult: "+scoreMult)
console.log("Percent mult: "+percentMult)*/
var score = ((song.cool*100+song.fine*50+song.safe*10+song.sad*5)/1000.0)*percentMult*scoreMult
if (scoreMult>0 && percentMult>0) {
score += Math.pow(song.rating,3)/5
@ -345,7 +356,8 @@ app.get('/recalculatescore/:playid',(req,res)=>{
.then((data)=>res.status(200).json(data)).catch((err)=>{console.log(err);res.status(500).json(err.message);})
});
/*app.get('/playdata',(req,res)=>{
/*
app.get('/playdata',(req,res)=>{
db.query('select * from plays')
.then((data)=>{res.status(200).json(data.rows)})
.catch((err)=>res.status(500).json(err.message))
@ -430,9 +442,33 @@ app.get('/bestplay/:username/:songname/:difficulty',(req,res)=>{
})
app.get('/userdata/:username',(req,res)=>{
var songId=-1,userId=-1;
var songId=-1,userId=-1,finalData={};
db.query('select playcount,fccount,rating,last_played,cool,fine,safe,sad,worst,eclear,nclear,hclear,exclear,exexclear from users where username=$1 limit 1',[req.params.username])
.then((data)=>{if(data && data.rows.length>0){res.status(200).json(data.rows[0])}})
.then((data)=>{if(data && data.rows.length>0){finalData=data.rows[0];return db.query("select t.difficulty,COUNT(t.difficulty) from (select distinct on(songid) songid,*,users.id from plays join users on userid=users.id where users.username=$1 and plays.safe=0 and plays.worst=0 and plays.sad=0)t group by t.difficulty",[req.params.username])}else{throw new Error("Could not retrieve user data!")}})
.then((data)=>{
if (data) {
var fcData={}
data.rows.forEach((fc)=>{fcData[fc.difficulty]=fc.count})
finalData={...{fcdata:fcData},...finalData}
return db.query("select t.difficulty,COUNT(t.difficulty) from (select distinct on(songid) songid,*,users.id from plays join users on userid=users.id where users.username=$1 and plays.fine=0 and plays.safe=0 and plays.worst=0 and plays.sad=0)t group by t.difficulty",[req.params.username])
}else{throw new Error("Could not retrieve user data!")}
})
.then((data)=>{
if (data) {
var fcData={}
data.rows.forEach((fc)=>{fcData[fc.difficulty]=fc.count})
finalData={...{pfcdata:fcData},...finalData}
res.status(200).json(finalData)
}else{throw new Error("Could not retrieve user data!")}
})
.catch((err)=>{res.status(500).json(err.message)})
})
app.get('/plays/:username/:songid',(req,res)=>{
db.query("select plays.* from plays join users on users.id=plays.userid where users.username=$1 and plays.songid=$2 order by score desc,date desc limit 100",[req.params.username,req.params.songid])
.then((data)=>{
res.status(200).json(data.rows)
})
.catch((err)=>{res.status(500).json(err.message)})
})
@ -519,6 +555,135 @@ app.get('/users/:orderby/:sortorder',(req,res)=>{
res.status(400).json("Invalid query!")
}
})
function ValidateToken(username,token) {
return db.query('select authentication_token from users where username=$1 limit 1',[username])
.then((data)=>{
if (data.rows.length>0) {
return token===data.rows[0].authentication_token;
} else {
return false;
}
})
}
function GetSongId(songname) {
return db.query("select id from songs where name=$1 or romanized_name=$1 or english_name=$1 limit 1",[songname])
.then((data)=>{
if (data.rows.length>0) {
return data.rows[0].id;
} else {
throw new Error("Could not get song ID for song '"+songname+"'")
}
})
}
function GetNoteCount(songname,difficulty) {
var songID=-1;
return GetSongId(songname)
.then((id)=>{songID=id;return db.query("select notecount from songdata where songid=$1 and difficulty=$2 limit 1",[songID,difficulty])})
.then((data)=>{
if (data.rows.length>0) {
return data.rows[0].notecount;
} else {
throw new Error("Could not get note count for song '"+songname+"' on difficulty '"+difficulty+"'")
}
})
}
app.post('/song/:songname/:difficulty',(req,res)=>{
if (req.body&&req.params.songname&&req.params.difficulty&&req.body.username&&req.body.percent&&req.body.authentication_token) {
var noteCount=0,songID=0,fail=false;
ValidateToken(req.body.username,req.body.authentication_token)
.then((allowed)=>{
if (allowed) {
return GetSongId(req.params.songname)
}else{throw new Error("Could not authenticate!")}
})
.then((songId)=>{
if (songId) {
songID=songId;
return GetNoteCount(req.params.songname,req.params.difficulty)
}else{throw new Error("Could not find song ID!")}
})
.then((noteCount)=>{
var percentThreshold=(req.params.difficulty==="E"?100:107)/100.0
var percent=(req.params.difficulty==="E"?100:107)?Math.min(req.body.percent/100.0,percentThreshold):Math.min(req.body.percent/107.0,percentThreshold);
var cool = 0;
var fine = 0;
var safe = 0;
var sad = 0;
var worst = 0;
for (var i=0;i<noteCount;i++) {
if (req.body.isFC) {
if (Math.random()<percent) {
cool++;
} else {
fine++;
}
} else
{
if (Math.random()<percent) {
cool++;
continue;
} else
if (Math.random()<percent) {
fine++;
continue;
} else
if (Math.random()<percent) {
worst++;
continue;
} else
if (Math.random()<percent) {
safe++;
continue;
} else
if (Math.random()<percent) {
sad++;
continue;
} else {
worst++;
}
}
}
switch (req.params.difficulty){
case "E":{
if (req.body.percent<30){fail=true;}
}break;
case "N":{
if (req.body.percent<50){fail=true;}
}break;
case "H":{
if (req.body.percent<60){fail=true;}
}break;
case "EX":
case "EXEX":{
if (req.body.percent<70){fail=true;}
}break;
default:{
if (req.body.percent<60){fail=true;}
}break;
}
if (req.body.fail) {
fail=req.body.fail
}
//res.status(200).json({cool:cool,fine:fine,safe:safe,sad:sad,worst:worst,percent:req.body.percent})
return axios.post("http://projectdivar.com/submit",{
username:req.body.username,authentication_token:req.body.authentication_token,song:req.params.songname,difficulty:req.params.difficulty,cool:cool,fine:fine,safe:safe,sad:sad,worst:worst,percent:req.body.percent,fail:String(fail)
})
})
.then((data)=>{
res.status(200).json(data.data)
})
.catch((err)=>{res.status(400).json(err.message)})
} else {
res.status(400).json("Invalid query!")
}
})
/*
app.get('/twitter/mentions', function(req, res) {
if (req.query.data) {

View File

@ -1,3 +1,5 @@
const INVALID_KEYS = ['__proto__', 'constructor'];
module.exports = function(data){
if (!data || data.length < 1) return {};
@ -15,6 +17,12 @@ module.exports = function(data){
for (let index = 0; index < keyParts.length; index++){
let k = keyParts[index];
// Ensure we don't allow prototype pollution
if (INVALID_KEYS.includes(k)) {
continue;
}
if (index >= keyParts.length - 1){
current[k] = value;
} else {

View File

@ -1,27 +1,27 @@
{
"_from": "express-fileupload",
"_id": "express-fileupload@1.1.7-alpha.4",
"_from": "express-fileupload@1.1.9",
"_id": "express-fileupload@1.1.9",
"_inBundle": false,
"_integrity": "sha512-uNl/TB3adUH25cDRp1gDoXQ38SdIZXOAVzC54G/xnOAa4M3maBWiZTVz39cnoQ7TXhmYXYpnOfMDMbqSelXFmQ==",
"_integrity": "sha512-f2w0aoe7lj3NeD8a4MXmYQsqir3Z66I08l9AKq04QbFUAjeZNmPwTlR5Lx2NGwSu/PslsAjGC38MWzo5tTjoBg==",
"_location": "/express-fileupload",
"_phantomChildren": {},
"_requested": {
"type": "tag",
"type": "version",
"registry": true,
"raw": "express-fileupload",
"raw": "express-fileupload@1.1.9",
"name": "express-fileupload",
"escapedName": "express-fileupload",
"rawSpec": "",
"rawSpec": "1.1.9",
"saveSpec": null,
"fetchSpec": "latest"
"fetchSpec": "1.1.9"
},
"_requiredBy": [
"#USER",
"/"
],
"_resolved": "https://registry.npmjs.org/express-fileupload/-/express-fileupload-1.1.7-alpha.4.tgz",
"_shasum": "c87dcb7880fe2e5a1d15ea97a225719c5ac0a30d",
"_spec": "express-fileupload",
"_resolved": "https://registry.npmjs.org/express-fileupload/-/express-fileupload-1.1.9.tgz",
"_shasum": "e798e9318394ed5083e56217ad6cda576da465d2",
"_spec": "express-fileupload@1.1.9",
"_where": "/home/sigonasr2/divar/server",
"author": {
"name": "Richard Girges",
@ -39,11 +39,11 @@
"devDependencies": {
"body-parser": "^1.19.0",
"coveralls": "^3.0.14",
"eslint": "^6.8.0",
"eslint": "^7.5.0",
"express": "^4.17.1",
"istanbul": "^0.4.5",
"md5": "^2.2.1",
"mocha": "^7.2.0",
"mocha": "^8.0.1",
"rimraf": "^3.0.2",
"supertest": "^4.0.2"
},
@ -73,5 +73,5 @@
"lint": "eslint ./",
"test": "istanbul cover node_modules/mocha/bin/_mocha -- -R spec"
},
"version": "1.1.7-alpha.4"
"version": "1.1.9"
}

View File

@ -45,4 +45,15 @@ describe('Test Convert Flatten object to Nested object', function() {
assert.deepEqual(processed, excerpt);
});
it('Do not allow prototype pollution', () => {
const pollutionOb1 = JSON.parse(`{"__proto__.POLLUTED1": "FOOBAR"}`);
const pollutionOb2 = JSON.parse(`{"constructor.prototype.POLLUTED2": "FOOBAR"}`);
processNested(pollutionOb1);
processNested(pollutionOb2);
assert.equal(global.POLLUTED1, undefined);
assert.equal(global.POLLUTED2, undefined);
});
});

View File

@ -517,9 +517,9 @@
}
},
"express-fileupload": {
"version": "1.1.7-alpha.4",
"resolved": "https://registry.npmjs.org/express-fileupload/-/express-fileupload-1.1.7-alpha.4.tgz",
"integrity": "sha512-uNl/TB3adUH25cDRp1gDoXQ38SdIZXOAVzC54G/xnOAa4M3maBWiZTVz39cnoQ7TXhmYXYpnOfMDMbqSelXFmQ==",
"version": "1.1.9",
"resolved": "https://registry.npmjs.org/express-fileupload/-/express-fileupload-1.1.9.tgz",
"integrity": "sha512-f2w0aoe7lj3NeD8a4MXmYQsqir3Z66I08l9AKq04QbFUAjeZNmPwTlR5Lx2NGwSu/PslsAjGC38MWzo5tTjoBg==",
"requires": {
"busboy": "^0.3.1"
}

View File

@ -13,7 +13,7 @@
"connect-timeout": "^1.9.0",
"crypto": "^1.0.1",
"express": "^4.17.1",
"express-fileupload": "^1.1.7-alpha.4",
"express-fileupload": "^1.1.9",
"get-pixels": "^3.3.2",
"image-pixels": "^2.2.2",
"pg": "^8.2.1",

753
updateNoteCounts.sql Normal file
View File

@ -0,0 +1,753 @@
update songdata set notecount=290 where songid=1 and difficulty='E';
update songdata set notecount=253 where songid=2 and difficulty='E';
update songdata set notecount=312 where songid=3 and difficulty='E';
update songdata set notecount=350 where songid=4 and difficulty='E';
update songdata set notecount=400 where songid=5 and difficulty='E';
update songdata set notecount=263 where songid=6 and difficulty='E';
update songdata set notecount=370 where songid=7 and difficulty='E';
update songdata set notecount=236 where songid=8 and difficulty='E';
update songdata set notecount=310 where songid=9 and difficulty='E';
update songdata set notecount=287 where songid=10 and difficulty='E';
update songdata set notecount=322 where songid=11 and difficulty='E';
update songdata set notecount=305 where songid=12 and difficulty='E';
update songdata set notecount=199 where songid=14 and difficulty='E';
update songdata set notecount=273 where songid=15 and difficulty='E';
update songdata set notecount=147 where songid=17 and difficulty='E';
update songdata set notecount=346 where songid=18 and difficulty='E';
update songdata set notecount=305 where songid=19 and difficulty='E';
update songdata set notecount=225 where songid=20 and difficulty='E';
update songdata set notecount=345 where songid=21 and difficulty='E';
update songdata set notecount=276 where songid=22 and difficulty='E';
update songdata set notecount=310 where songid=23 and difficulty='E';
update songdata set notecount=300 where songid=24 and difficulty='E';
update songdata set notecount=276 where songid=25 and difficulty='E';
update songdata set notecount=250 where songid=26 and difficulty='E';
update songdata set notecount=260 where songid=27 and difficulty='E';
update songdata set notecount=343 where songid=28 and difficulty='E';
update songdata set notecount=216 where songid=29 and difficulty='E';
update songdata set notecount=340 where songid=31 and difficulty='E';
update songdata set notecount=279 where songid=32 and difficulty='E';
update songdata set notecount=389 where songid=33 and difficulty='E';
update songdata set notecount=316 where songid=34 and difficulty='E';
update songdata set notecount=282 where songid=39 and difficulty='E';
update songdata set notecount=275 where songid=40 and difficulty='E';
update songdata set notecount=381 where songid=41 and difficulty='E';
update songdata set notecount=374 where songid=42 and difficulty='E';
update songdata set notecount=394 where songid=44 and difficulty='E';
update songdata set notecount=268 where songid=45 and difficulty='E';
update songdata set notecount=157 where songid=46 and difficulty='E';
update songdata set notecount=315 where songid=48 and difficulty='E';
update songdata set notecount=289 where songid=49 and difficulty='E';
update songdata set notecount=302 where songid=50 and difficulty='E';
update songdata set notecount=416 where songid=51 and difficulty='E';
update songdata set notecount=233 where songid=52 and difficulty='E';
update songdata set notecount=371 where songid=53 and difficulty='E';
update songdata set notecount=318 where songid=54 and difficulty='E';
update songdata set notecount=362 where songid=57 and difficulty='E';
update songdata set notecount=275 where songid=60 and difficulty='E';
update songdata set notecount=212 where songid=61 and difficulty='E';
update songdata set notecount=204 where songid=62 and difficulty='E';
update songdata set notecount=246 where songid=64 and difficulty='E';
update songdata set notecount=414 where songid=65 and difficulty='E';
update songdata set notecount=216 where songid=66 and difficulty='E';
update songdata set notecount=399 where songid=68 and difficulty='E';
update songdata set notecount=337 where songid=69 and difficulty='E';
update songdata set notecount=406 where songid=70 and difficulty='E';
update songdata set notecount=288 where songid=71 and difficulty='E';
update songdata set notecount=339 where songid=72 and difficulty='E';
update songdata set notecount=251 where songid=73 and difficulty='E';
update songdata set notecount=280 where songid=74 and difficulty='E';
update songdata set notecount=226 where songid=75 and difficulty='E';
update songdata set notecount=274 where songid=76 and difficulty='E';
update songdata set notecount=299 where songid=77 and difficulty='E';
update songdata set notecount=377 where songid=78 and difficulty='E';
update songdata set notecount=330 where songid=79 and difficulty='E';
update songdata set notecount=322 where songid=80 and difficulty='E';
update songdata set notecount=261 where songid=81 and difficulty='E';
update songdata set notecount=231 where songid=82 and difficulty='E';
update songdata set notecount=265 where songid=84 and difficulty='E';
update songdata set notecount=404 where songid=85 and difficulty='E';
update songdata set notecount=363 where songid=86 and difficulty='E';
update songdata set notecount=368 where songid=87 and difficulty='E';
update songdata set notecount=250 where songid=88 and difficulty='E';
update songdata set notecount=164 where songid=89 and difficulty='E';
update songdata set notecount=246 where songid=90 and difficulty='E';
update songdata set notecount=420 where songid=91 and difficulty='E';
update songdata set notecount=416 where songid=92 and difficulty='E';
update songdata set notecount=361 where songid=93 and difficulty='E';
update songdata set notecount=348 where songid=94 and difficulty='E';
update songdata set notecount=199 where songid=95 and difficulty='E';
update songdata set notecount=392 where songid=97 and difficulty='E';
update songdata set notecount=321 where songid=99 and difficulty='E';
update songdata set notecount=388 where songid=100 and difficulty='E';
update songdata set notecount=388 where songid=101 and difficulty='E';
update songdata set notecount=276 where songid=102 and difficulty='E';
update songdata set notecount=369 where songid=103 and difficulty='E';
update songdata set notecount=336 where songid=104 and difficulty='E';
update songdata set notecount=330 where songid=105 and difficulty='E';
update songdata set notecount=284 where songid=107 and difficulty='E';
update songdata set notecount=305 where songid=108 and difficulty='E';
update songdata set notecount=363 where songid=109 and difficulty='E';
update songdata set notecount=213 where songid=110 and difficulty='E';
update songdata set notecount=208 where songid=111 and difficulty='E';
update songdata set notecount=340 where songid=112 and difficulty='E';
update songdata set notecount=292 where songid=116 and difficulty='E';
update songdata set notecount=291 where songid=118 and difficulty='E';
update songdata set notecount=228 where songid=119 and difficulty='E';
update songdata set notecount=348 where songid=120 and difficulty='E';
update songdata set notecount=270 where songid=121 and difficulty='E';
update songdata set notecount=239 where songid=122 and difficulty='E';
update songdata set notecount=332 where songid=124 and difficulty='E';
update songdata set notecount=227 where songid=125 and difficulty='E';
update songdata set notecount=286 where songid=126 and difficulty='E';
update songdata set notecount=358 where songid=127 and difficulty='E';
update songdata set notecount=251 where songid=130 and difficulty='E';
update songdata set notecount=249 where songid=131 and difficulty='E';
update songdata set notecount=329 where songid=132 and difficulty='E';
update songdata set notecount=335 where songid=133 and difficulty='E';
update songdata set notecount=288 where songid=134 and difficulty='E';
update songdata set notecount=285 where songid=135 and difficulty='E';
update songdata set notecount=327 where songid=136 and difficulty='E';
update songdata set notecount=285 where songid=137 and difficulty='E';
update songdata set notecount=265 where songid=139 and difficulty='E';
update songdata set notecount=346 where songid=140 and difficulty='E';
update songdata set notecount=174 where songid=141 and difficulty='E';
update songdata set notecount=328 where songid=142 and difficulty='E';
update songdata set notecount=241 where songid=143 and difficulty='E';
update songdata set notecount=135 where songid=145 and difficulty='E';
update songdata set notecount=310 where songid=147 and difficulty='E';
update songdata set notecount=291 where songid=149 and difficulty='E';
update songdata set notecount=290 where songid=1 and difficulty='N';
update songdata set notecount=253 where songid=2 and difficulty='N';
update songdata set notecount=312 where songid=3 and difficulty='N';
update songdata set notecount=350 where songid=4 and difficulty='N';
update songdata set notecount=400 where songid=5 and difficulty='N';
update songdata set notecount=263 where songid=6 and difficulty='N';
update songdata set notecount=370 where songid=7 and difficulty='N';
update songdata set notecount=236 where songid=8 and difficulty='N';
update songdata set notecount=310 where songid=9 and difficulty='N';
update songdata set notecount=287 where songid=10 and difficulty='N';
update songdata set notecount=322 where songid=11 and difficulty='N';
update songdata set notecount=305 where songid=12 and difficulty='N';
update songdata set notecount= where songid=13 and difficulty='N';
update songdata set notecount=199 where songid=14 and difficulty='N';
update songdata set notecount=273 where songid=15 and difficulty='N';
update songdata set notecount= where songid=16 and difficulty='N';
update songdata set notecount=147 where songid=17 and difficulty='N';
update songdata set notecount=346 where songid=18 and difficulty='N';
update songdata set notecount=305 where songid=19 and difficulty='N';
update songdata set notecount=225 where songid=20 and difficulty='N';
update songdata set notecount=345 where songid=21 and difficulty='N';
update songdata set notecount=276 where songid=22 and difficulty='N';
update songdata set notecount=310 where songid=23 and difficulty='N';
update songdata set notecount=300 where songid=24 and difficulty='N';
update songdata set notecount=276 where songid=25 and difficulty='N';
update songdata set notecount=250 where songid=26 and difficulty='N';
update songdata set notecount=260 where songid=27 and difficulty='N';
update songdata set notecount=343 where songid=28 and difficulty='N';
update songdata set notecount=216 where songid=29 and difficulty='N';
update songdata set notecount= where songid=30 and difficulty='N';
update songdata set notecount=340 where songid=31 and difficulty='N';
update songdata set notecount=279 where songid=32 and difficulty='N';
update songdata set notecount=389 where songid=33 and difficulty='N';
update songdata set notecount=316 where songid=34 and difficulty='N';
update songdata set notecount= where songid=35 and difficulty='N';
update songdata set notecount= where songid=36 and difficulty='N';
update songdata set notecount= where songid=37 and difficulty='N';
update songdata set notecount= where songid=38 and difficulty='N';
update songdata set notecount=282 where songid=39 and difficulty='N';
update songdata set notecount=275 where songid=40 and difficulty='N';
update songdata set notecount=381 where songid=41 and difficulty='N';
update songdata set notecount=374 where songid=42 and difficulty='N';
update songdata set notecount= where songid=43 and difficulty='N';
update songdata set notecount=394 where songid=44 and difficulty='N';
update songdata set notecount=268 where songid=45 and difficulty='N';
update songdata set notecount=157 where songid=46 and difficulty='N';
update songdata set notecount= where songid=47 and difficulty='N';
update songdata set notecount=315 where songid=48 and difficulty='N';
update songdata set notecount=289 where songid=49 and difficulty='N';
update songdata set notecount=302 where songid=50 and difficulty='N';
update songdata set notecount=416 where songid=51 and difficulty='N';
update songdata set notecount=233 where songid=52 and difficulty='N';
update songdata set notecount=371 where songid=53 and difficulty='N';
update songdata set notecount=318 where songid=54 and difficulty='N';
update songdata set notecount= where songid=55 and difficulty='N';
update songdata set notecount= where songid=56 and difficulty='N';
update songdata set notecount=362 where songid=57 and difficulty='N';
update songdata set notecount= where songid=58 and difficulty='N';
update songdata set notecount= where songid=59 and difficulty='N';
update songdata set notecount=275 where songid=60 and difficulty='N';
update songdata set notecount=212 where songid=61 and difficulty='N';
update songdata set notecount=204 where songid=62 and difficulty='N';
update songdata set notecount= where songid=63 and difficulty='N';
update songdata set notecount=246 where songid=64 and difficulty='N';
update songdata set notecount=414 where songid=65 and difficulty='N';
update songdata set notecount=216 where songid=66 and difficulty='N';
update songdata set notecount= where songid=67 and difficulty='N';
update songdata set notecount=399 where songid=68 and difficulty='N';
update songdata set notecount=337 where songid=69 and difficulty='N';
update songdata set notecount=406 where songid=70 and difficulty='N';
update songdata set notecount=288 where songid=71 and difficulty='N';
update songdata set notecount=339 where songid=72 and difficulty='N';
update songdata set notecount=251 where songid=73 and difficulty='N';
update songdata set notecount=280 where songid=74 and difficulty='N';
update songdata set notecount=226 where songid=75 and difficulty='N';
update songdata set notecount=274 where songid=76 and difficulty='N';
update songdata set notecount=299 where songid=77 and difficulty='N';
update songdata set notecount=377 where songid=78 and difficulty='N';
update songdata set notecount=330 where songid=79 and difficulty='N';
update songdata set notecount=322 where songid=80 and difficulty='N';
update songdata set notecount=261 where songid=81 and difficulty='N';
update songdata set notecount=231 where songid=82 and difficulty='N';
update songdata set notecount= where songid=83 and difficulty='N';
update songdata set notecount=265 where songid=84 and difficulty='N';
update songdata set notecount=404 where songid=85 and difficulty='N';
update songdata set notecount=363 where songid=86 and difficulty='N';
update songdata set notecount=368 where songid=87 and difficulty='N';
update songdata set notecount=250 where songid=88 and difficulty='N';
update songdata set notecount=164 where songid=89 and difficulty='N';
update songdata set notecount=246 where songid=90 and difficulty='N';
update songdata set notecount=420 where songid=91 and difficulty='N';
update songdata set notecount=416 where songid=92 and difficulty='N';
update songdata set notecount=361 where songid=93 and difficulty='N';
update songdata set notecount=348 where songid=94 and difficulty='N';
update songdata set notecount=199 where songid=95 and difficulty='N';
update songdata set notecount= where songid=96 and difficulty='N';
update songdata set notecount=392 where songid=97 and difficulty='N';
update songdata set notecount= where songid=98 and difficulty='N';
update songdata set notecount=321 where songid=99 and difficulty='N';
update songdata set notecount=388 where songid=100 and difficulty='N';
update songdata set notecount=388 where songid=101 and difficulty='N';
update songdata set notecount=276 where songid=102 and difficulty='N';
update songdata set notecount=369 where songid=103 and difficulty='N';
update songdata set notecount=336 where songid=104 and difficulty='N';
update songdata set notecount=330 where songid=105 and difficulty='N';
update songdata set notecount= where songid=106 and difficulty='N';
update songdata set notecount=284 where songid=107 and difficulty='N';
update songdata set notecount=305 where songid=108 and difficulty='N';
update songdata set notecount=363 where songid=109 and difficulty='N';
update songdata set notecount=213 where songid=110 and difficulty='N';
update songdata set notecount=208 where songid=111 and difficulty='N';
update songdata set notecount=340 where songid=112 and difficulty='N';
update songdata set notecount= where songid=113 and difficulty='N';
update songdata set notecount= where songid=114 and difficulty='N';
update songdata set notecount= where songid=115 and difficulty='N';
update songdata set notecount=292 where songid=116 and difficulty='N';
update songdata set notecount= where songid=117 and difficulty='N';
update songdata set notecount=291 where songid=118 and difficulty='N';
update songdata set notecount=348 where songid=120 and difficulty='N';
update songdata set notecount=270 where songid=121 and difficulty='N';
update songdata set notecount=239 where songid=122 and difficulty='N';
update songdata set notecount= where songid=123 and difficulty='N';
update songdata set notecount=332 where songid=124 and difficulty='N';
update songdata set notecount=286 where songid=126 and difficulty='N';
update songdata set notecount=358 where songid=127 and difficulty='N';
update songdata set notecount= where songid=128 and difficulty='N';
update songdata set notecount= where songid=129 and difficulty='N';
update songdata set notecount=251 where songid=130 and difficulty='N';
update songdata set notecount=249 where songid=131 and difficulty='N';
update songdata set notecount=329 where songid=132 and difficulty='N';
update songdata set notecount=335 where songid=133 and difficulty='N';
update songdata set notecount=288 where songid=134 and difficulty='N';
update songdata set notecount=285 where songid=135 and difficulty='N';
update songdata set notecount=327 where songid=136 and difficulty='N';
update songdata set notecount=285 where songid=137 and difficulty='N';
update songdata set notecount= where songid=138 and difficulty='N';
update songdata set notecount=265 where songid=139 and difficulty='N';
update songdata set notecount=346 where songid=140 and difficulty='N';
update songdata set notecount=174 where songid=141 and difficulty='N';
update songdata set notecount=328 where songid=142 and difficulty='N';
update songdata set notecount=241 where songid=143 and difficulty='N';
update songdata set notecount= where songid=144 and difficulty='N';
update songdata set notecount=135 where songid=145 and difficulty='N';
update songdata set notecount= where songid=146 and difficulty='N';
update songdata set notecount=310 where songid=147 and difficulty='N';
update songdata set notecount= where songid=148 and difficulty='N';
update songdata set notecount=291 where songid=149 and difficulty='N';
update songdata set notecount= where songid=150 and difficulty='N';
update songdata set notecount= where songid=151 and difficulty='N';
update songdata set notecount=290 where songid=1 and difficulty='H';
update songdata set notecount=253 where songid=2 and difficulty='H';
update songdata set notecount=312 where songid=3 and difficulty='H';
update songdata set notecount=350 where songid=4 and difficulty='H';
update songdata set notecount=400 where songid=5 and difficulty='H';
update songdata set notecount=263 where songid=6 and difficulty='H';
update songdata set notecount=370 where songid=7 and difficulty='H';
update songdata set notecount=236 where songid=8 and difficulty='H';
update songdata set notecount=310 where songid=9 and difficulty='H';
update songdata set notecount=287 where songid=10 and difficulty='H';
update songdata set notecount=322 where songid=11 and difficulty='H';
update songdata set notecount=305 where songid=12 and difficulty='H';
update songdata set notecount= where songid=13 and difficulty='H';
update songdata set notecount=199 where songid=14 and difficulty='H';
update songdata set notecount=273 where songid=15 and difficulty='H';
update songdata set notecount= where songid=16 and difficulty='H';
update songdata set notecount=147 where songid=17 and difficulty='H';
update songdata set notecount=346 where songid=18 and difficulty='H';
update songdata set notecount=305 where songid=19 and difficulty='H';
update songdata set notecount=225 where songid=20 and difficulty='H';
update songdata set notecount=345 where songid=21 and difficulty='H';
update songdata set notecount=276 where songid=22 and difficulty='H';
update songdata set notecount=310 where songid=23 and difficulty='H';
update songdata set notecount=300 where songid=24 and difficulty='H';
update songdata set notecount=276 where songid=25 and difficulty='H';
update songdata set notecount=250 where songid=26 and difficulty='H';
update songdata set notecount=260 where songid=27 and difficulty='H';
update songdata set notecount=343 where songid=28 and difficulty='H';
update songdata set notecount=216 where songid=29 and difficulty='H';
update songdata set notecount= where songid=30 and difficulty='H';
update songdata set notecount=340 where songid=31 and difficulty='H';
update songdata set notecount=279 where songid=32 and difficulty='H';
update songdata set notecount=389 where songid=33 and difficulty='H';
update songdata set notecount=316 where songid=34 and difficulty='H';
update songdata set notecount= where songid=35 and difficulty='H';
update songdata set notecount= where songid=36 and difficulty='H';
update songdata set notecount= where songid=37 and difficulty='H';
update songdata set notecount= where songid=38 and difficulty='H';
update songdata set notecount=282 where songid=39 and difficulty='H';
update songdata set notecount=275 where songid=40 and difficulty='H';
update songdata set notecount=381 where songid=41 and difficulty='H';
update songdata set notecount=374 where songid=42 and difficulty='H';
update songdata set notecount= where songid=43 and difficulty='H';
update songdata set notecount=394 where songid=44 and difficulty='H';
update songdata set notecount=268 where songid=45 and difficulty='H';
update songdata set notecount=157 where songid=46 and difficulty='H';
update songdata set notecount= where songid=47 and difficulty='H';
update songdata set notecount=315 where songid=48 and difficulty='H';
update songdata set notecount=289 where songid=49 and difficulty='H';
update songdata set notecount=302 where songid=50 and difficulty='H';
update songdata set notecount=416 where songid=51 and difficulty='H';
update songdata set notecount=233 where songid=52 and difficulty='H';
update songdata set notecount=371 where songid=53 and difficulty='H';
update songdata set notecount=318 where songid=54 and difficulty='H';
update songdata set notecount= where songid=55 and difficulty='H';
update songdata set notecount= where songid=56 and difficulty='H';
update songdata set notecount=362 where songid=57 and difficulty='H';
update songdata set notecount= where songid=58 and difficulty='H';
update songdata set notecount= where songid=59 and difficulty='H';
update songdata set notecount=275 where songid=60 and difficulty='H';
update songdata set notecount=212 where songid=61 and difficulty='H';
update songdata set notecount=204 where songid=62 and difficulty='H';
update songdata set notecount= where songid=63 and difficulty='H';
update songdata set notecount=246 where songid=64 and difficulty='H';
update songdata set notecount=414 where songid=65 and difficulty='H';
update songdata set notecount=216 where songid=66 and difficulty='H';
update songdata set notecount= where songid=67 and difficulty='H';
update songdata set notecount=399 where songid=68 and difficulty='H';
update songdata set notecount=337 where songid=69 and difficulty='H';
update songdata set notecount=406 where songid=70 and difficulty='H';
update songdata set notecount=288 where songid=71 and difficulty='H';
update songdata set notecount=339 where songid=72 and difficulty='H';
update songdata set notecount=251 where songid=73 and difficulty='H';
update songdata set notecount=280 where songid=74 and difficulty='H';
update songdata set notecount=226 where songid=75 and difficulty='H';
update songdata set notecount=274 where songid=76 and difficulty='H';
update songdata set notecount=299 where songid=77 and difficulty='H';
update songdata set notecount=377 where songid=78 and difficulty='H';
update songdata set notecount=330 where songid=79 and difficulty='H';
update songdata set notecount=322 where songid=80 and difficulty='H';
update songdata set notecount=261 where songid=81 and difficulty='H';
update songdata set notecount=231 where songid=82 and difficulty='H';
update songdata set notecount= where songid=83 and difficulty='H';
update songdata set notecount=265 where songid=84 and difficulty='H';
update songdata set notecount=404 where songid=85 and difficulty='H';
update songdata set notecount=363 where songid=86 and difficulty='H';
update songdata set notecount=368 where songid=87 and difficulty='H';
update songdata set notecount=250 where songid=88 and difficulty='H';
update songdata set notecount=164 where songid=89 and difficulty='H';
update songdata set notecount=246 where songid=90 and difficulty='H';
update songdata set notecount=420 where songid=91 and difficulty='H';
update songdata set notecount=416 where songid=92 and difficulty='H';
update songdata set notecount=361 where songid=93 and difficulty='H';
update songdata set notecount=348 where songid=94 and difficulty='H';
update songdata set notecount=199 where songid=95 and difficulty='H';
update songdata set notecount= where songid=96 and difficulty='H';
update songdata set notecount=392 where songid=97 and difficulty='H';
update songdata set notecount= where songid=98 and difficulty='H';
update songdata set notecount=321 where songid=99 and difficulty='H';
update songdata set notecount=388 where songid=100 and difficulty='H';
update songdata set notecount=388 where songid=101 and difficulty='H';
update songdata set notecount=276 where songid=102 and difficulty='H';
update songdata set notecount=369 where songid=103 and difficulty='H';
update songdata set notecount=336 where songid=104 and difficulty='H';
update songdata set notecount=330 where songid=105 and difficulty='H';
update songdata set notecount= where songid=106 and difficulty='H';
update songdata set notecount=284 where songid=107 and difficulty='H';
update songdata set notecount=305 where songid=108 and difficulty='H';
update songdata set notecount=363 where songid=109 and difficulty='H';
update songdata set notecount=213 where songid=110 and difficulty='H';
update songdata set notecount=208 where songid=111 and difficulty='H';
update songdata set notecount=340 where songid=112 and difficulty='H';
update songdata set notecount= where songid=113 and difficulty='H';
update songdata set notecount= where songid=114 and difficulty='H';
update songdata set notecount= where songid=115 and difficulty='H';
update songdata set notecount=292 where songid=116 and difficulty='H';
update songdata set notecount= where songid=117 and difficulty='H';
update songdata set notecount=291 where songid=118 and difficulty='H';
update songdata set notecount=228 where songid=119 and difficulty='H';
update songdata set notecount=348 where songid=120 and difficulty='H';
update songdata set notecount=270 where songid=121 and difficulty='H';
update songdata set notecount=239 where songid=122 and difficulty='H';
update songdata set notecount= where songid=123 and difficulty='H';
update songdata set notecount=332 where songid=124 and difficulty='H';
update songdata set notecount=227 where songid=125 and difficulty='H';
update songdata set notecount=286 where songid=126 and difficulty='H';
update songdata set notecount=358 where songid=127 and difficulty='H';
update songdata set notecount= where songid=128 and difficulty='H';
update songdata set notecount= where songid=129 and difficulty='H';
update songdata set notecount=251 where songid=130 and difficulty='H';
update songdata set notecount=249 where songid=131 and difficulty='H';
update songdata set notecount=329 where songid=132 and difficulty='H';
update songdata set notecount=335 where songid=133 and difficulty='H';
update songdata set notecount=288 where songid=134 and difficulty='H';
update songdata set notecount=285 where songid=135 and difficulty='H';
update songdata set notecount=327 where songid=136 and difficulty='H';
update songdata set notecount=285 where songid=137 and difficulty='H';
update songdata set notecount= where songid=138 and difficulty='H';
update songdata set notecount=265 where songid=139 and difficulty='H';
update songdata set notecount=346 where songid=140 and difficulty='H';
update songdata set notecount=174 where songid=141 and difficulty='H';
update songdata set notecount=328 where songid=142 and difficulty='H';
update songdata set notecount=241 where songid=143 and difficulty='H';
update songdata set notecount= where songid=144 and difficulty='H';
update songdata set notecount=135 where songid=145 and difficulty='H';
update songdata set notecount= where songid=146 and difficulty='H';
update songdata set notecount=310 where songid=147 and difficulty='H';
update songdata set notecount= where songid=148 and difficulty='H';
update songdata set notecount=291 where songid=149 and difficulty='H';
update songdata set notecount= where songid=150 and difficulty='H';
update songdata set notecount= where songid=151 and difficulty='H';
update songdata set notecount=290 where songid=1 and difficulty='EX';
update songdata set notecount=253 where songid=2 and difficulty='EX';
update songdata set notecount=312 where songid=3 and difficulty='EX';
update songdata set notecount=350 where songid=4 and difficulty='EX';
update songdata set notecount=400 where songid=5 and difficulty='EX';
update songdata set notecount=263 where songid=6 and difficulty='EX';
update songdata set notecount=370 where songid=7 and difficulty='EX';
update songdata set notecount=236 where songid=8 and difficulty='EX';
update songdata set notecount=310 where songid=9 and difficulty='EX';
update songdata set notecount=287 where songid=10 and difficulty='EX';
update songdata set notecount=322 where songid=11 and difficulty='EX';
update songdata set notecount=305 where songid=12 and difficulty='EX';
update songdata set notecount= where songid=13 and difficulty='EX';
update songdata set notecount=199 where songid=14 and difficulty='EX';
update songdata set notecount=273 where songid=15 and difficulty='EX';
update songdata set notecount= where songid=16 and difficulty='EX';
update songdata set notecount=147 where songid=17 and difficulty='EX';
update songdata set notecount=346 where songid=18 and difficulty='EX';
update songdata set notecount=305 where songid=19 and difficulty='EX';
update songdata set notecount=225 where songid=20 and difficulty='EX';
update songdata set notecount=345 where songid=21 and difficulty='EX';
update songdata set notecount=276 where songid=22 and difficulty='EX';
update songdata set notecount=310 where songid=23 and difficulty='EX';
update songdata set notecount=300 where songid=24 and difficulty='EX';
update songdata set notecount=276 where songid=25 and difficulty='EX';
update songdata set notecount=250 where songid=26 and difficulty='EX';
update songdata set notecount=260 where songid=27 and difficulty='EX';
update songdata set notecount=343 where songid=28 and difficulty='EX';
update songdata set notecount=216 where songid=29 and difficulty='EX';
update songdata set notecount= where songid=30 and difficulty='EX';
update songdata set notecount=340 where songid=31 and difficulty='EX';
update songdata set notecount=279 where songid=32 and difficulty='EX';
update songdata set notecount=389 where songid=33 and difficulty='EX';
update songdata set notecount=316 where songid=34 and difficulty='EX';
update songdata set notecount= where songid=35 and difficulty='EX';
update songdata set notecount= where songid=36 and difficulty='EX';
update songdata set notecount= where songid=37 and difficulty='EX';
update songdata set notecount= where songid=38 and difficulty='EX';
update songdata set notecount=282 where songid=39 and difficulty='EX';
update songdata set notecount=275 where songid=40 and difficulty='EX';
update songdata set notecount=381 where songid=41 and difficulty='EX';
update songdata set notecount=374 where songid=42 and difficulty='EX';
update songdata set notecount= where songid=43 and difficulty='EX';
update songdata set notecount=394 where songid=44 and difficulty='EX';
update songdata set notecount=268 where songid=45 and difficulty='EX';
update songdata set notecount=157 where songid=46 and difficulty='EX';
update songdata set notecount= where songid=47 and difficulty='EX';
update songdata set notecount=315 where songid=48 and difficulty='EX';
update songdata set notecount=289 where songid=49 and difficulty='EX';
update songdata set notecount=302 where songid=50 and difficulty='EX';
update songdata set notecount=416 where songid=51 and difficulty='EX';
update songdata set notecount=233 where songid=52 and difficulty='EX';
update songdata set notecount=371 where songid=53 and difficulty='EX';
update songdata set notecount=318 where songid=54 and difficulty='EX';
update songdata set notecount= where songid=55 and difficulty='EX';
update songdata set notecount= where songid=56 and difficulty='EX';
update songdata set notecount=362 where songid=57 and difficulty='EX';
update songdata set notecount= where songid=58 and difficulty='EX';
update songdata set notecount= where songid=59 and difficulty='EX';
update songdata set notecount=275 where songid=60 and difficulty='EX';
update songdata set notecount=212 where songid=61 and difficulty='EX';
update songdata set notecount=204 where songid=62 and difficulty='EX';
update songdata set notecount= where songid=63 and difficulty='EX';
update songdata set notecount=246 where songid=64 and difficulty='EX';
update songdata set notecount=414 where songid=65 and difficulty='EX';
update songdata set notecount=216 where songid=66 and difficulty='EX';
update songdata set notecount= where songid=67 and difficulty='EX';
update songdata set notecount=399 where songid=68 and difficulty='EX';
update songdata set notecount=337 where songid=69 and difficulty='EX';
update songdata set notecount=406 where songid=70 and difficulty='EX';
update songdata set notecount=288 where songid=71 and difficulty='EX';
update songdata set notecount=339 where songid=72 and difficulty='EX';
update songdata set notecount=251 where songid=73 and difficulty='EX';
update songdata set notecount=280 where songid=74 and difficulty='EX';
update songdata set notecount=226 where songid=75 and difficulty='EX';
update songdata set notecount=274 where songid=76 and difficulty='EX';
update songdata set notecount=299 where songid=77 and difficulty='EX';
update songdata set notecount=377 where songid=78 and difficulty='EX';
update songdata set notecount=330 where songid=79 and difficulty='EX';
update songdata set notecount=322 where songid=80 and difficulty='EX';
update songdata set notecount=261 where songid=81 and difficulty='EX';
update songdata set notecount=231 where songid=82 and difficulty='EX';
update songdata set notecount= where songid=83 and difficulty='EX';
update songdata set notecount=265 where songid=84 and difficulty='EX';
update songdata set notecount=404 where songid=85 and difficulty='EX';
update songdata set notecount=363 where songid=86 and difficulty='EX';
update songdata set notecount=368 where songid=87 and difficulty='EX';
update songdata set notecount=250 where songid=88 and difficulty='EX';
update songdata set notecount=164 where songid=89 and difficulty='EX';
update songdata set notecount=246 where songid=90 and difficulty='EX';
update songdata set notecount=420 where songid=91 and difficulty='EX';
update songdata set notecount=416 where songid=92 and difficulty='EX';
update songdata set notecount=361 where songid=93 and difficulty='EX';
update songdata set notecount=348 where songid=94 and difficulty='EX';
update songdata set notecount=199 where songid=95 and difficulty='EX';
update songdata set notecount= where songid=96 and difficulty='EX';
update songdata set notecount=392 where songid=97 and difficulty='EX';
update songdata set notecount= where songid=98 and difficulty='EX';
update songdata set notecount=321 where songid=99 and difficulty='EX';
update songdata set notecount=388 where songid=100 and difficulty='EX';
update songdata set notecount=388 where songid=101 and difficulty='EX';
update songdata set notecount=276 where songid=102 and difficulty='EX';
update songdata set notecount=369 where songid=103 and difficulty='EX';
update songdata set notecount=336 where songid=104 and difficulty='EX';
update songdata set notecount=330 where songid=105 and difficulty='EX';
update songdata set notecount= where songid=106 and difficulty='EX';
update songdata set notecount=284 where songid=107 and difficulty='EX';
update songdata set notecount=305 where songid=108 and difficulty='EX';
update songdata set notecount=363 where songid=109 and difficulty='EX';
update songdata set notecount=213 where songid=110 and difficulty='EX';
update songdata set notecount=208 where songid=111 and difficulty='EX';
update songdata set notecount=340 where songid=112 and difficulty='EX';
update songdata set notecount= where songid=113 and difficulty='EX';
update songdata set notecount= where songid=114 and difficulty='EX';
update songdata set notecount= where songid=115 and difficulty='EX';
update songdata set notecount=292 where songid=116 and difficulty='EX';
update songdata set notecount= where songid=117 and difficulty='EX';
update songdata set notecount=291 where songid=118 and difficulty='EX';
update songdata set notecount=228 where songid=119 and difficulty='EX';
update songdata set notecount=348 where songid=120 and difficulty='EX';
update songdata set notecount=270 where songid=121 and difficulty='EX';
update songdata set notecount=239 where songid=122 and difficulty='EX';
update songdata set notecount= where songid=123 and difficulty='EX';
update songdata set notecount=332 where songid=124 and difficulty='EX';
update songdata set notecount=227 where songid=125 and difficulty='EX';
update songdata set notecount=286 where songid=126 and difficulty='EX';
update songdata set notecount=358 where songid=127 and difficulty='EX';
update songdata set notecount= where songid=128 and difficulty='EX';
update songdata set notecount= where songid=129 and difficulty='EX';
update songdata set notecount=251 where songid=130 and difficulty='EX';
update songdata set notecount=249 where songid=131 and difficulty='EX';
update songdata set notecount=329 where songid=132 and difficulty='EX';
update songdata set notecount=335 where songid=133 and difficulty='EX';
update songdata set notecount=288 where songid=134 and difficulty='EX';
update songdata set notecount=285 where songid=135 and difficulty='EX';
update songdata set notecount=327 where songid=136 and difficulty='EX';
update songdata set notecount=285 where songid=137 and difficulty='EX';
update songdata set notecount= where songid=138 and difficulty='EX';
update songdata set notecount=265 where songid=139 and difficulty='EX';
update songdata set notecount=346 where songid=140 and difficulty='EX';
update songdata set notecount=174 where songid=141 and difficulty='EX';
update songdata set notecount=328 where songid=142 and difficulty='EX';
update songdata set notecount=241 where songid=143 and difficulty='EX';
update songdata set notecount= where songid=144 and difficulty='EX';
update songdata set notecount=135 where songid=145 and difficulty='EX';
update songdata set notecount= where songid=146 and difficulty='EX';
update songdata set notecount=310 where songid=147 and difficulty='EX';
update songdata set notecount= where songid=148 and difficulty='EX';
update songdata set notecount=291 where songid=149 and difficulty='EX';
update songdata set notecount= where songid=150 and difficulty='EX';
update songdata set notecount= where songid=151 and difficulty='EX';
update songdata set notecount=322 where songid=11 and difficulty='EXEX';
update songdata set notecount=305 where songid=12 and difficulty='EXEX';
update songdata set notecount= where songid=13 and difficulty='EXEX';
update songdata set notecount=273 where songid=15 and difficulty='EXEX';
update songdata set notecount= where songid=16 and difficulty='EXEX';
update songdata set notecount=147 where songid=17 and difficulty='EXEX';
update songdata set notecount=346 where songid=18 and difficulty='EXEX';
update songdata set notecount=305 where songid=19 and difficulty='EXEX';
update songdata set notecount=225 where songid=20 and difficulty='EXEX';
update songdata set notecount=345 where songid=21 and difficulty='EXEX';
update songdata set notecount=276 where songid=22 and difficulty='EXEX';
update songdata set notecount=310 where songid=23 and difficulty='EXEX';
update songdata set notecount=300 where songid=24 and difficulty='EXEX';
update songdata set notecount=250 where songid=26 and difficulty='EXEX';
update songdata set notecount=260 where songid=27 and difficulty='EXEX';
update songdata set notecount=343 where songid=28 and difficulty='EXEX';
update songdata set notecount=216 where songid=29 and difficulty='EXEX';
update songdata set notecount= where songid=30 and difficulty='EXEX';
update songdata set notecount=279 where songid=32 and difficulty='EXEX';
update songdata set notecount=389 where songid=33 and difficulty='EXEX';
update songdata set notecount= where songid=35 and difficulty='EXEX';
update songdata set notecount= where songid=36 and difficulty='EXEX';
update songdata set notecount= where songid=38 and difficulty='EXEX';
update songdata set notecount=275 where songid=40 and difficulty='EXEX';
update songdata set notecount=374 where songid=42 and difficulty='EXEX';
update songdata set notecount=394 where songid=44 and difficulty='EXEX';
update songdata set notecount=315 where songid=48 and difficulty='EXEX';
update songdata set notecount=318 where songid=54 and difficulty='EXEX';
update songdata set notecount= where songid=55 and difficulty='EXEX';
update songdata set notecount=362 where songid=57 and difficulty='EXEX';
update songdata set notecount= where songid=58 and difficulty='EXEX';
update songdata set notecount=204 where songid=62 and difficulty='EXEX';
update songdata set notecount= where songid=63 and difficulty='EXEX';
update songdata set notecount=368 where songid=87 and difficulty='EXEX';
update songdata set notecount= where songid=96 and difficulty='EXEX';
update songdata set notecount=392 where songid=97 and difficulty='EXEX';
update songdata set notecount= where songid=98 and difficulty='EXEX';
update songdata set notecount=369 where songid=103 and difficulty='EXEX';
update songdata set notecount=336 where songid=104 and difficulty='EXEX';
update songdata set notecount=330 where songid=105 and difficulty='EXEX';
update songdata set notecount= where songid=106 and difficulty='EXEX';
update songdata set notecount=305 where songid=108 and difficulty='EXEX';
update songdata set notecount=363 where songid=109 and difficulty='EXEX';
update songdata set notecount=213 where songid=110 and difficulty='EXEX';
update songdata set notecount=340 where songid=112 and difficulty='EXEX';
update songdata set notecount= where songid=113 and difficulty='EXEX';
update songdata set notecount= where songid=114 and difficulty='EXEX';
update songdata set notecount= where songid=115 and difficulty='EXEX';
update songdata set notecount=291 where songid=118 and difficulty='EXEX';
update songdata set notecount=228 where songid=119 and difficulty='EXEX';
update songdata set notecount=348 where songid=120 and difficulty='EXEX';
update songdata set notecount=239 where songid=122 and difficulty='EXEX';
update songdata set notecount= where songid=123 and difficulty='EXEX';
update songdata set notecount=227 where songid=125 and difficulty='EXEX';
update songdata set notecount=358 where songid=127 and difficulty='EXEX';
update songdata set notecount=251 where songid=130 and difficulty='EXEX';
update songdata set notecount=249 where songid=131 and difficulty='EXEX';
update songdata set notecount=335 where songid=133 and difficulty='EXEX';
update songdata set notecount=285 where songid=135 and difficulty='EXEX';
update songdata set notecount=265 where songid=139 and difficulty='EXEX';
update songdata set notecount=241 where songid=143 and difficulty='EXEX';
update songdata set notecount= where songid=144 and difficulty='EXEX';
update songdata set notecount= where songid=146 and difficulty='EXEX';
update songdata set notecount= where songid=148 and difficulty='EXEX';