1. Куча / Говнокод #25384

    0

    1. 1
    2. 2
    3. 3
    Заметили, что во всех рекламных роликах (всякие fonbet, delivery club, заказ пиццы, и прочие)
    используется именно "iPhone"?
    Теперь это особо заметно из-за характерной хероты на "iPhone X".

    3oJloTou_nemyx, 17 Февраля 2019

    Комментарии (37)
  2. Куча / Говнокод #25382

    +1

    1. 1
    thispersondoesnotexist.com

    Лицовореций тред. Интересные и упоротые портреты, сгенерированные нейропитухами.

    Предлагаю челлендж: жмём F5 и постим сюда лица, похожие, по вашему мнению, на обитателей ГК. Разумеется, если вы не знали пользователя в лицо или давно видели мутную фотографию и уже забыли, как он выглядит.
    Для чистоты эксперимента рекомендуется не смотреть чужие представления о местных жителях до того, как запостили свои.

    1024--, 15 Февраля 2019

    Комментарии (142)
  3. Куча / Говнокод #25379

    0

    1. 1
    https://www.bellingcat.com/resources/how-tos/2019/02/14/creating-your-own-citizen-database/

    Новые веяния - код в виде скриншотов, сырцы скачать нельзя.

    syoma, 15 Февраля 2019

    Комментарии (205)
  4. Куча / Говнокод #25374

    0

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    Офигеть, sql-дамп говнокода весит всего 240Мб.
    
    Может переписать на "C++" и держать все индексы в памяти?
    А на фронте будет только обращение к JSON API. И можно хоть мобильное приложение делать на "Electron.js".
    Клиент будет подписан на интересующие его события, например на сток и на ответы на его коменты.
    Никто не хочет заняться по фану?

    guestinxo, 12 Февраля 2019

    Комментарии (49)
  5. Куча / Говнокод #25357

    0

    1. 1
    2. 2
    3. 3
    4. 4
    5. 5
    6. 6
    Как вы думаете, чем отличаются эти два параметра в Django?
    
    use_tls: EMAIL_USE_TLS
    use_ssl: EMAIL_USE_SSL
    
    ответ в комменте

    EMAIL_USE_TLS
    Whether to use a TLS (secure) connection when talking to the SMTP server

    EMAIL_USE_SSL
    Whether to use an implicit TLS (secure) connection when talking to the SMTP server

    gueest8, 05 Февраля 2019

    Комментарии (41)
  6. Куча / Говнокод #25340

    0

    1. 1
    https://i.imgur.com/7uRLULs.mp4

    Аппаратная нейросеть в мозгах петуха совершила ошибку классификации.

    j123123, 30 Января 2019

    Комментарии (47)
  7. Куча / Говнокод #25331

    −2

    1. 1
    2. 2
    3. 3
    Кому тут надо вертуху крутануть чтобы добавили больше языков?
    Нынче не 2000й год. Народ уже во всю ебашит на котлинах, скалах (не путать с горными образованиями), го всяких там, расте, эрланге, форте и прочей поеботе.
    В конце то концов, сколько можно ждать? Одмен, пидр, запили языки!!11!

    Lorip1971, 27 Января 2019

    Комментарии (29)
  8. Куча / Говнокод #25329

    0

    1. 1
    Просто оффтоп #2

    #1: http://govnokod.xyz/_20162 https://govnokod.ru/20162

    syoma, 26 Января 2019

    Комментарии (621)
  9. Куча / Говнокод #25328

    0

    1. 1
    IT Оффтоп #10

    #1: http://govnokod.ru/18142 http://govnokod.xyz/_18142
    #2: http://govnokod.ru/18378 http://govnokod.xyz/_18378
    #3: http://govnokod.ru/19667 http://govnokod.xyz/_19667
    #4: http://govnokod.ru/21160 http://govnokod.xyz/_21160
    #5: http://govnokod.ru/21772 http://govnokod.xyz/_21772
    #6: http://govnokod.ru/24063 http://govnokod.xyz/_24063
    #7: http://govnokod.ru/24538 http://govnokod.xyz/_24538
    #8: http://govnokod.ru/24815 (потёр пидор сракер) http://govnokod.xyz/_24815
    #9: http://govnokod.ru/24867 http://govnokod.xyz/_24867

    syoma, 26 Января 2019

    Комментарии (1239)
  10. Куча / Говнокод #25304

    0

    1. 01
    2. 02
    3. 03
    4. 04
    5. 05
    6. 06
    7. 07
    8. 08
    9. 09
    10. 10
    11. 11
    12. 12
    13. 13
    14. 14
    15. 15
    16. 16
    17. 17
    18. 18
    19. 19
    20. 20
    21. 21
    22. 22
    23. 23
    24. 24
    25. 25
    26. 26
    27. 27
    28. 28
    29. 29
    30. 30
    31. 31
    32. 32
    33. 33
    34. 34
    35. 35
    36. 36
    37. 37
    38. 38
    39. 39
    40. 40
    41. 41
    42. 42
    43. 43
    44. 44
    45. 45
    46. 46
    47. 47
    48. 48
    49. 49
    50. 50
    51. 51
    52. 52
    53. 53
    54. 54
    55. 55
    56. 56
    57. 57
    58. 58
    59. 59
    60. 60
    61. 61
    62. 62
    63. 63
    64. 64
    65. 65
    66. 66
    67. 67
    68. 68
    69. 69
    70. 70
    71. 71
    72. 72
    73. 73
    74. 74
    75. 75
    76. 76
    77. 77
    78. 78
    79. 79
    80. 80
    81. 81
    82. 82
    83. 83
    84. 84
    85. 85
    86. 86
    87. 87
    88. 88
    89. 89
    90. 90
    fn do_get_summary(req: &HttpRequest<AppState>) -> SummaryFuture {
        let token = req.token().expect("ISE: token not verified during AuthMiddleware stage");
    
        let datetime = req.match_info()
            .get("timestamp")
            .and_then(|s| i64::from_str(s).ok())
            .map(|ts| NaiveDateTime::from_timestamp(ts, 0));
    
        let datetime = match datetime {
            Some(dt) => dt,
            None => return Box::new(future::result(Err(ServiceError::InvalidSetting {
                key: "timestamp".into(),
                hint: "local time in seconds since Unix Epoch".into()
            }.into())))
        };
    
        let db = req.state().db.clone();
    
        let settings = req.state().db
            .send(db::GetSettings(token.clone()))
            .map_err(failure::Error::from)
            // flatten error
            .and_then(|res| match res {
                Ok(settings) => Ok(settings),
                Err(err) => Err(err)
            });
    
        let fitbit = req.state().db
            .send(db::GetSettingsFitbit(token))
            .map_err(failure::Error::from)
            // Check if there is token and flatten error
            .and_then(|res| match res {
                Ok(fitbit) => {
                    if fitbit.client_token.is_none() {
                        Err(ServiceError::TokenExpired.into())
                    } else {
                        Ok(fitbit)
                    }
                },
                Err(err) => Err(err)
            });
    
        let headmaster = req.state().headmaster.clone();
    
        let summary_and_token = settings.join(fitbit)
            .and_then(move |(settings, fitbit)| -> Box<dyn Future<Item = (Summary, FitbitToken), Error = failure::Error>> {
                // Deserialize token
                let token = fitbit.client_token.expect("ISE: token option is not cleared");
                let fitbit_token = match FitbitToken::from_json(&token) {
                    Ok(token) => token,
                    Err(err) => return Box::new(future::err(ServiceError::TokenExpired.into()))
                };
    
                let headmaster_config = master::HeadmasterConfig {
                    minimum_active_time: settings.hourly_activity_goal,
                    max_accounted_active_minutes: settings.hourly_activity_limit.unwrap_or(settings.hourly_activity_goal * 3),
                    debt_limit: settings.hourly_debt_limit.unwrap_or(settings.hourly_activity_goal * 3),
                    day_begins_at: settings.day_starts_at,
                    day_ends_at: settings.day_ends_at,
                    day_length: settings.day_length.unwrap_or((settings.day_ends_at.hour() - settings.day_starts_at.hour()) as i32),
                    user_date_time: datetime,
                };
    
                let auth_data = FitbitAuthData {
                    id: fitbit.client_id,
                    secret: fitbit.client_secret,
                    token: fitbit_token,
                };
    
                let future = headmaster.send(master::GetSummary::<FitbitActivityGrabber>::new(headmaster_config, auth_data))
                    .map_err(failure::Error::from)
                    // flatten error
                    .and_then(|res| res);
    
                Box::new(future)
            });
    
        let summary = summary_and_token
            .and_then(move |(summary, fitbit_token)| {
                db.send(db::UpdateSettingsFitbit::new(
                    token, db::models::UpdateFitbitCredentials {
                        client_token: Some(Some(fitbit_token.to_json())),
                        ..Default::default()
                    }))
                    .map_err(failure::Error::from)
                    .and_then(|_| Ok(summary))
            });
    
        Box::new(summary)
    }

    Фьючи в Rust до рефакторинга -- тот еще говнокод

    mersinvald, 12 Января 2019

    Комментарии (3)