Giter Club home page Giter Club logo

filmstund's Issues

Confirm payment done

  • Let admin mark payment for individual user
  • Let admin mark showing as payed for (complete)

Expand README

Describe necessary steps for getting a new developer up and running.

Generate payment summery for admin

Admin must be able to easily perform the payment and thus needs all information available, bioklubbkortsnummer, företagsbiljetter mm

Remove Opera "movies"?

Would people be opposed if we filtered/removed movies from SF that are operas?

Vote with thumbs up or down I guess.

UX + Design for MVP

  • Select time slots
  • Confirm showing
  • Confirm payment
  • Saving profile (if successful or not)
  • Make site look okay on desktop

Confirm showing

  • Let admin mark as confirmed
    • Prevent further slot-picking
  • Notify users confirmed

/api/movies error 500

exception: "#<NoMethodError: undefined method `split' for :"user-agent":Symbol>"

0: {id: 16, trace: "app/models/movie.rb:85:in 'download_data'"}
1: {id: 17, trace: "app/models/movie.rb:81:in 'request'"}
2: {id: 18, trace: "app/models/movie.rb:68:in 'current'"}
3: {id: 19, trace: "app/controllers/movies_controller.rb:6:in 'index'"}

Unable to login

When trying to login with either google or facebook I get this error message
2017-02-16-105454_1527x130_scrot

Notifications to users

Email

  • On new showing/invite
  • On showing confirmation

Push

  • On new showing/invite
  • On showing confirmation

Handle case when movie does not exist in TMDb

I kind of assumed that if we have a valid IMDb ID it would exist in TMDb as well.

The below stacktrace is generated when searching for IMDb ID=tt5879988

Jul 07 03:10:40 jupiter java[27505]: org.springframework.web.client.RestClientException: Error while extracting response for type [class rocks.didit.sefilm.domain.dto.TmdbFindExternalResults] and content type [application/json;chars
Jul 07 03:10:40 jupiter java[27505]:  at [Source: (PushbackInputStream); line: 1, column: 356] (through reference chain: rocks.didit.sefilm.domain.dto.TmdbFindExternalResults["movie_results"]->java.util.ArrayList[0]->rocks.didit.sef
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.HttpMessageConverterExtractor.extractData(HttpMessageConverterExtractor.java:113) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.RestTemplate$ResponseEntityResponseExtractor.extractData(RestTemplate.java:954) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.RestTemplate$ResponseEntityResponseExtractor.extractData(RestTemplate.java:938) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:687) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:644) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.RestTemplate.exchange(RestTemplate.java:562) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.clients.ImdbClient.lookupTmdbIdFromImdbId(ImdbClient.kt:113) ~[classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.clients.ImdbClient.movieDetails(ImdbClient.kt:77) ~[classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater.updateFromTmdbByImdbId(AsyncMovieUpdater.kt:124) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater.fetchExtendedInfoForMovie(AsyncMovieUpdater.kt:81) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater.updateInfo(AsyncMovieUpdater.kt:70) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater.synchronousExtendMovieInfo(AsyncMovieUpdater.kt:48) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater.scheduledMovieUpdates(AsyncMovieUpdater.kt:35) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater$$FastClassBySpringCGLIB$$686c8073.invoke(<generated>) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) [spring-core-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:676) [spring-aop-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at rocks.didit.sefilm.schedulers.AsyncMovieUpdater$$EnhancerBySpringCGLIB$$7465cee8.scheduledMovieUpdates(<generated>) [classes!/:na]
Jul 07 03:10:40 jupiter java[27505]:         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:65) [spring-context-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) [spring-context-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.FutureTask.runAndReset(FutureTask.java:308) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(ScheduledThreadPoolExecutor.java:180) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:294) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]:         at java.lang.Thread.run(Thread.java:745) [na:1.8.0_121]
Jul 07 03:10:40 jupiter java[27505]: Caused by: org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Instantiation of [simple type, class rocks.didit.sefilm.domain.dto.TmdbMovieResult] value failed f
Jul 07 03:10:40 jupiter java[27505]:  at [Source: (PushbackInputStream); line: 1, column: 356] (through reference chain: rocks.didit.sefilm.domain.dto.TmdbFindExternalResults["movie_results"]->java.util.ArrayList[0]->rocks.didit.sef
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.readJavaType(AbstractJackson2HttpMessageConverter.java:247) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.read(AbstractJackson2HttpMessageConverter.java:229) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.web.client.HttpMessageConverterExtractor.extractData(HttpMessageConverterExtractor.java:98) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         ... 29 common frames omitted
Jul 07 03:10:40 jupiter java[27505]: Caused by: com.fasterxml.jackson.module.kotlin.MissingKotlinParameterException: Instantiation of [simple type, class rocks.didit.sefilm.domain.dto.TmdbMovieResult] value failed for JSON property 
Jul 07 03:10:40 jupiter java[27505]:  at [Source: (PushbackInputStream); line: 1, column: 356] (through reference chain: rocks.didit.sefilm.domain.dto.TmdbFindExternalResults["movie_results"]->java.util.ArrayList[0]->rocks.didit.sef
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.module.kotlin.KotlinValueInstantiator.createFromObjectWith(KotlinValueInstantiator.kt:44) ~[jackson-module-kotlin-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.impl.PropertyBasedCreator.build(PropertyBasedCreator.java:189) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer._deserializeUsingPropertyBased(BeanDeserializer.java:421) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializerBase.deserializeFromObjectUsingNonDefault(BeanDeserializerBase.java:1266) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:325) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:159) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:285) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:244) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:27) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.SettableBeanProperty.deserialize(SettableBeanProperty.java:519) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer._deserializeWithErrorWrapping(BeanDeserializer.java:527) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer._deserializeUsingPropertyBased(BeanDeserializer.java:416) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializerBase.deserializeFromObjectUsingNonDefault(BeanDeserializerBase.java:1266) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:325) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:159) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:3999) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3060) ~[jackson-databind-2.9.0.pr3.jar!/:2.9.0.pr3]
Jul 07 03:10:40 jupiter java[27505]:         at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.readJavaType(AbstractJackson2HttpMessageConverter.java:241) ~[spring-web-5.0.0.RC2.jar!/:5.0.0.RC2]
Jul 07 03:10:40 jupiter java[27505]:         ... 31 common frames omitted

GÅ PÅ BIO

När vi väl kan använda systemet för det... :)

Admin confirm order

Ingen ska kunna ändra sin besöks-status efter att admin har utfört confirm
Ingen kan gå med, ingen kan lämna.

Filter meta info from titles

Currently when fetching movies from SF they include stuff like "- Klassiker" and " - Bollywood" which makes it difficult to lookup external info about the movie.

I propose we create a currated list of stuff they include, that we simply remove.

Remember target url after logging in

At the moment, after logging in you get redirected to the profile page always. It would be neat to land on the url you tried to enter before the login prompt.

Validate first match on IMDb before assigning a movie the ID

Currently there are some weird matches.

Case in point:

Jul 07 03:07:20 jupiter java[27505]: 2017-07-07 03:07:20.599  INFO 27505 --- [pool-1-thread-1] r.d.sefilm.schedulers.AsyncMovieUpdater  : Fetching extended info for 'Raula - Bollywood' with id=9294dac3-3699-41ce-ab6a-a24cb259f452
Jul 07 03:07:20 jupiter java[27505]: 2017-07-07 03:07:20.600  INFO 27505 --- [pool-1-thread-1] r.d.sefilm.schedulers.AsyncMovieUpdater  : [TMDb] Fetching movie details by IMDb ID=tt1003021
Jul 07 03:07:20 jupiter java[27505]: 2017-07-07 03:07:20.990  WARN 27505 --- [pool-1-thread-1] r.d.sefilm.schedulers.AsyncMovieUpdater  : An error occurred when updating 'Raula - Bollywood' ID=9294dac3-3699-41ce-ab6a-a24cb259f452, S

Mark booking as done.

Markera bokning som färdig (Done, admin har fått in pengar mm, bokningen behövs inte synas publikt längre)

404 - page

  • Image asset
  • 3D asset
  • 3D rendering of cinema

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.