REST сервисы

AndrewVK AndrewVK
Поскольку ряд товарищей спрашивает про сабж, попытаюсь поддерживать более менее актуальный список того что есть.
Общие моменты: все сервисы на данный момент на вход принимают параметры в виде form data (url для Get, тело запроса для Post), на выходе отдают JSON. Если результат с ошибками, возвращается HTTP код ошибки и JSON вида { field: "error_field", message: "error_message"}. Поле field, если оно есть, указывает на ошибку в конкретном входном параметре, либо содержит all, если ошибка к конкретному параметру не относится.

Аутентификация и сессия — общая с остальным сайтом, т.е. форма //Users/Login.aspx для логина, затем куки .RSDNAUTH и ASP.NET_SessionId.

Часть сервисов поддерживает ETag/If-None-Match и умеет возвращать 304, так что крайне желательно чтобы клиенты, отличные от браузеров, это использовали.

Для некоторых сервисов есть демки — http://rsdn.ru/rs/demo
Сервис Состояние url Метод Параметры Результат Пример
Дерево навигации Beta //frames/navtreenodes GET string node — имя родительского узла. Для корня node=.
Все дочерние узлы, с учетом вложенности, до тех узлов, которые являются либо листьями, либо требуют загрузки по требованию.

GET http://rsdn.ru/frames/navtreenodes?node=./rsdnproject/forauthors

[
    {
        "id": "./rsdnproject/forauthors/requirements",
        "label": "Требования к оформлению материалов",
        "image": "/Images/article18.png",
        "url": "/article/authors/requirements.xml",
        "children": []
    },
    {
        "id": "./rsdnproject/forauthors/template",
        "label": "Шаблон для верстки статей",
        "image": "/Images/article18.png",
        "url": "/article/authors/template.xml",
        "children": []
    },
    {
        "id": "./rsdnproject/forauthors/codestyle",
        "label": "Соглашение по оформлению кода",
        "image": "/Images/article18.png",
        "url": "/article/mag/200401/codestyle.XML",
        "children": []
    },
    {
        "id": "./rsdnproject/forauthors/noway",
        "label": "Как не надо писать статьи",
        "image": "/Images/article18.png",
        "url": "/article/authors/HowNotTowrite.xml",
        "children": []
    }
]

Сообщение RSDN Team Production //about/askteam POST string name, string email, string subj, string message
пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Регистрация пользователя Production //account/doregister POST
string login,
string nick,
string email,
string pwd1,
string pwd2,
string recaptcha_challenge_field,
string recaptcha_response_field

пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Изменение емейла и пароля Production //account/dochangereg POST
int? uid,
string email,
string oldPwd,
string pwd1,
string pwd2

пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Отправка нового сообщения Alpha //forum/<forum_name> POST
string postingID,
string forum,
int msgID,
string subject,
string posterName,
string password,
string text,
bool noSmile,
string name,
string tags,
bool notifyAboutReplies

пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Оценка сообщения Production //rs/message/<messageId>/rate/<rateType> POST
string rateType, — Тип оценки: rate, smile или agree
int messageID,
int? value — Значение оценки. Для типа rate: 1-3, для типа agree: -4 согласен, 0 не согласен

пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Удаление оценок Production //rs/message/<messageId>/rate DELETE
int messageID,

пустой респонс с 204 кодом, если все хорошо, либо информацию об ошибке
Поиск профиля по подстроке Production //rsdnsearch/findauthor GET string name Список идентификаторов и имен пользователей
GET http://rsdn.ru/rsdnsearch/findauthor/?name=vladd

[
    {
        "id":73,
        "displayName":"VladD2"
    },
    {
        "id":39067,
        "displayName":"VladD"
    },
    {
        "id":93688,
        "displayName":"VladdT"
    },
    {
        "id":95381,
        "displayName":"vladdou"
    },
    {
        "id":108143,
        "displayName":"VladD2_PNH"
    },
    {
        "id":110977,
        "displayName":"VladDebil"
    }
]

Получение списка топиков форума Alpha //rs/forum/<forum_name>/topics GET
string forum,
int? from, // По умолчанию 0
int? len // По умолчанию размер страницы из профиля
Список топиков в порядке убывания даты
GET http://rsdn.ru/rs/forum/rsdn/topics?len=2

{
    "total":5637,
    "topics":[
        {
            "accountID":187,
            "answersCount":9,
            "createdOn":"\/Date(1407336643590)\/",
            "id":5728461,
            "isAlwayOnTop":false,
            "isClosed":null,
            "lastAnswerBy":"Ops",
            "name":null,
            "lastAnswerId":80747,
            "topicRate":0,
            "topicRateCount":0,
            "topicAgrees":0,
            "topicDisagrees":0,
            "topicSmiles":0,
            "rowVersion":"0000A37F01369035",
            "subject":"сбилась разметка",
            "lastUpdatedOn":"\/Date(1407342168280)\/",
            "authorNick":"Pavel Dvorkin"
        },
        {
            "accountID":100952,
            "answersCount":1,
            "createdOn":"\/Date(1407328363343)\/",
            "id":5728286,
            "isAlwayOnTop":false,
            "isClosed":null,
            "lastAnswerBy":"AndrewVK",
            "name":null,
            "lastAnswerId":80744,
            "topicRate":20,
            "topicRateCount":2,
            "topicAgrees":0,
            "topicDisagrees":0,
            "topicSmiles":0,
            "rowVersion":"0000A37F0110A8CB",
            "subject":"Новый embedded youtube",
            "lastUpdatedOn":"\/Date(1407332030580)\/",
            "authorNick":"Evgeny.Panasyuk"
        }
    ]
}

Получение списка ответов топика Alpha //rs/topic/<topicId>/replies GET int topicId Список ответов в порядке возрастания даты
GET http://rsdn.ru/rs/topic/5727307/replies

[
    {
        "accountID":5161,
        "createdOn":"\/Date(1407332097413)\/",
        "id":5728370,
        "isClosed":null,
        "name":null,
        "rate":0,
        "rateCount":0,
        "agrees":0,
        "disagrees":0,
        "smiles":0,
        "rowVersion":"0000A37F0121C0A8",
        "subject":"Re: Некоторые недочеты",
        "authorNick":"AndrewVK",
        "parentId":5727307
    },
    {
        "accountID":99637,
        "createdOn":"\/Date(1407345231857)\/",
        "id":5728657,
        "isClosed":null,
        "name":null,
        "rate":0,
        "rateCount":0,
        "agrees":0,
        "disagrees":0,
        "smiles":0,
        "rowVersion":"0000A37F015DE095",
        "subject":"Re[2]: Некоторые недочеты",
        "authorNick":"BrainSlug",
        "parentId":5728370
    },
    {
        "accountID":5161,
        "createdOn":"\/Date(1407346966247)\/",
        "id":5728717,
        "isClosed":null,
        "name":null,
        "rate":0,
        "rateCount":0,
        "agrees":0,
        "disagrees":0,
        "smiles":0,
        "rowVersion":"0000A37F0165D112",
        "subject":"Re[3]: Некоторые недочеты",
        "authorNick":"AndrewVK",
        "parentId":5728657
    }
]

Получение сообщения Alpha //rs/message/<messageId> GET
int messageId,
bool? formatted
Сообщение, включая его текст. В зависимости от значения formatted в качестве текста будет либо исходный код, либо готовый html для отображения
GET http://rsdn.ru/rs/message/5728645?formatted=true

{
    "accountID":78670,
    "createdOn":"\/Date(1407344805630)\/",
    "id":5728645,"isClosed":null,
    "name":null,
    "rate":20,
    "rateCount":10,
    "agrees":0,
    "disagrees":0,
    "smiles":0,
    "rowVersion":"0000A37F015BED19",
    "subject":"Теперь вы все мои гости",
    "authorNick":"Берсерк",
    "text":"\u003ctable\u003e\u003ctr\u003e\u003ctd class=
        \u0027m\u0027\u003e\u003cfont size=2\u003eВ
        догонку к истории с Лабиринтом:\u003cbr 
        /\u003e\n\u003cbr /\u003e\n\u003cblockquote
        class=\u0027q\u0027\u003e\u003cp\u003eРоссийские
        туристы ..."
}

Получение сообщений топика Alpha //rs/topic/<topicId>/messages GET
int topicId,
bool? formatted,
int? from,
int? len
Сообщения указанного топика, включая текст. В зависимости от значения formatted в качестве текста будет либо исходный код, либо готовый html для отображения
GET http://rsdn.ru/rs/topic/5727307/messages/?len=2&from=2

[
    {
        "accountId":99637,
        "createdOn":"2014-08-05T23:03:52.2700000",
        "id":5727307,
        "isClosed":null,
        "name":null,
        "rate":5,
        "rateCount":1,
        "agrees":0,
        "disagrees":0,
        "smiles":0,
        "rowVersion":"0000A37E017C1771",
        "subject":"Некоторые недочеты",
        "authorNick":"BrainSlug",
        "text":"В принципе ничего серьезного. Но у меня при голосовании (rsdn.ru/poll/5136) под анонимом ...",
        "gravatarHash":"35d4bb2787c66a855fdcf912d8f04ad6",
        "forum":"rsdn",
        "versions":[]
    },
    {
        "accountId":99637,
        "createdOn":"2014-08-06T21:13:51.8570000",
        "id":5728657,
        "isClosed":null,
        "name":null,
        "rate":0,
        "rateCount":0,
        "agrees":0,
        "disagrees":0,
        "smiles":0,
        "rowVersion":"0000A37F015DE095",
        "subject":"Re[2]: Некоторые недочеты",
        "authorNick":"BrainSlug",
        "text":"\r\nAVK\u003eНе воспроизвелось. У тебя воспроизводится?\r\nуже нет :)...",
        "gravatarHash":"35d4bb2787c66a855fdcf912d8f04ad6",
        "forum":"rsdn",
        "versions":[]
    }
]

koandrew
koandrew
06.08.2014 03:01
Здравствуйте, AndrewVK, Вы писали:

AVK>Поскольку ряд товарищей спрашивает про сабж, попытаюсь поддерживать более менее актуальный список того что есть.


Спасибо! А можно сделать самое важное — получение списка тем в форуме, и собственно сообщений? Я тут на досуге пилю метро-клиент для винпланшетов, и пока приходится врукопашную html обрабатывать, что очень геморно — особенно в свете того, что вы постоянно меняете вёрстку...
AndrewVK
AndrewVK
06.08.2014 05:55
Здравствуйте, koandrew, Вы писали:

K>Спасибо! А можно сделать самое важное — получение списка тем в форуме


Добавил.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
koandrew
koandrew
06.08.2014 08:08
Здравствуйте, AndrewVK, Вы писали:

AVK>Добавил.


Спасибо! С нетерпением жду вторую половину реквеста
AndrewVK
AndrewVK
06.08.2014 08:19
Здравствуйте, koandrew, Вы писали:

AVK>>Добавил.


K>Спасибо! С нетерпением жду вторую половину реквеста


2/3. Ты про список ответов топика забыл. Но ты пока попробуй этот использовать.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
koandrew
koandrew
07.08.2014 01:59
Здравствуйте, AndrewVK, Вы писали:

AVK>2/3. Ты про список ответов топика забыл. Но ты пока попробуй этот использовать.


Не, я на выходных этим занимаюсь — в будни некогда сейчас, на работе дурдом.
AndrewVK
AndrewVK
07.08.2014 04:22
Здравствуйте, koandrew, Вы писали:

K>Спасибо! С нетерпением жду вторую половину реквеста


Добавил получение ответов
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
koandrew
koandrew
07.08.2014 06:14
Здравствуйте, AndrewVK, Вы писали:

AVK>Добавил получение ответов


Спасибо! Вопросы (смотрю на вывод http://rsdn.ru/rs/topic/5728024/replies ):
1. Нужен ParentId, чтобы можно было построить дерево.
2. Что такое "name" (который null) и "rowVersion"?
3. дата "createdOn" я так понимаю в тиках?

Ну и ещё нужна третья "половина"
AndrewVK
AndrewVK
07.08.2014 06:39
Здравствуйте, koandrew, Вы писали:

K>1. Нужен ParentId, чтобы можно было построить дерево.


Упустил момент, поправлю

K>2. Что такое "name" (который null) и "rowVersion"?


У некоторых сообщений есть уникальное имя. Потом на них можно сослаться [#имя_сообщения].
RowVersion это равномерно возрастающее число, обновляющееся при каждом изменении сообщения.

K>3. дата "createdOn" я так понимаю в тиках?


https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date

Integer value representing the number of milliseconds since 1 January 1970 00:00:00 UTC (Unix Epoch).


K>Ну и ещё нужна третья "половина"


Так вроде уже.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
AndrewVK
AndrewVK
07.08.2014 06:06
Здравствуйте, koandrew, Вы писали:

K>Спасибо! С нетерпением жду вторую половину реквеста


Добавил получение сообщений. С возможностью форматирования. И есть демка.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Нахлобуч
Нахлобуч
07.08.2014 10:04
Здравствуйте, AndrewVK, Вы писали:

Не хочу показаться занудой, но это не совсем REST. Гораздо ближе к RPC-подобному API с JSON на выхлопе.
AndrewVK
AndrewVK
07.08.2014 11:08
Здравствуйте, Нахлобуч, Вы писали:

Н>Не хочу показаться занудой, но это не совсем REST. Гораздо ближе к RPC-подобному API с JSON на выхлопе.


Ну давай глянем вики:

Client–server
Stateless
Cacheable
Layered system
Code on demand (optional)
Uniform interface
Identification of resources
Manipulation of resources through these representations
Self-descriptive messages

Что из этого, кроме code on demand, принципиально не подходит?
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Нахлобуч
Нахлобуч
07.08.2014 03:44
Здравствуйте, AndrewVK, Вы писали:

AVK>Здравствуйте, Нахлобуч, Вы писали:


Н>>Не хочу показаться занудой, но это не совсем REST. Гораздо ближе к RPC-подобному API с JSON на выхлопе.


AVK>Ну давай глянем вики:


Мы академиев не кончали, но есть мнение, что ресурса "/f/ratemessage/{id}" (и подобных "/f/gettopics") не существует. А параметр "bool set" говорит о RPC-направленности. Как мне кажется, более тру было бы что-то типа "/forum/{name}/messages/{id}/rates" с операциями GET и POST (rate = 1|2|3|smile|upvote|downvote), а так же DELETE для "../rates/{rate}". С остальными "ресурсами" -- аналогично.

"Пустой респонс с 200 кодом" -- это 204. Всегда плеваться пятисотой ошибкой тоже не шибко канонично.

Ну и HATEOAS, но это совсем уже высший пилотаж.
AndrewVK
AndrewVK
07.08.2014 04:13
Здравствуйте, Нахлобуч, Вы писали:

Н>Мы академиев не кончали, но есть мнение, что ресурса "/f/ratemessage/{id}" (и подобных "/f/gettopics") не существует.


Почему ты так решил? Они вполне существуют, просто не все реализовано . Смутило get? Это просто для гарантии отсутствия конфликта с урлами страничек. Впрочем, уже переделано на /rs/forum/<forumname>/topics. <forumname>/topics — идентификатор ресурса.

Н> А параметр "bool set" говорит о RPC-направленности


Ничего подобного он не говорит, это тело POST запроса.

Н>. Как мне кажется, более тру было бы что-то типа "/forum/{name}/messages/{id}/rates" с операциями GET и POST (rate = 1|2|3|smile|upvote|downvote), а так же DELETE для "../rates/{rate}". С остальными "ресурсами" -- аналогично.


Это несложно переделать. Насчет DELETE так наверняка, заодно set выкинется.

Н>"Пустой респонс с 200 кодом" -- это 204.


В смысле?

Н> Всегда плеваться пятисотой ошибкой тоже не шибко канонично.


А оно там не всегда, я просто не описал. Бывает, как минимум, еще 400, 403 и 404.

Н>Ну и HATEOAS, но это совсем уже высший пилотаж.


Это в данном случае совсем без надобности.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Нахлобуч
Нахлобуч
08.08.2014 08:29
Здравствуйте, AndrewVK, Вы писали:

Н>>Мы академиев не кончали, но есть мнение, что ресурса "/f/ratemessage/{id}" (и подобных "/f/gettopics") не существует.

AVK>Почему ты так решил?

Потому, что наличие глагола в имени ресурса делает его не совсем ресурсом.

Н>> А параметр "bool set" говорит о RPC-направленности

AVK>Ничего подобного он не говорит, это тело POST запроса.

Да, это тело RPC-стайл POST-запроса. Если бы происходила манипуляция ресурсами, то было бы ровно так, как я описывал:

"/forum/{name}/messages/{id}/rates" с операциями GET и POST (rate = 1|2|3|smile|upvote|downvote), а так же DELETE для "../rates/{rate}"


Н>>"Пустой респонс с 200 кодом" -- это 204.

AVK>В смысле?

В смысле, по заветам HTTP каноничнее было бы в ответ на успешный POST-запрос возвращать не пустой ответ с HTTP 200, а пустой ответ с HTTP 204.

AVK>Это в данном случае совсем без надобности.


См. свой пассаж о "переделано". Если бы в результате переделок сервер научился бы выплевывать HTTP 301 для перенаправления со старых на новые URL'ы и эти URL'ы не формировались бы клиентом, а получались непосредственно из ответа, то жизнь клиентских приложений была бы тёплой и сухой.

И раз уж мы заговорили о REST и Stateless'ности -- может быть, подумать насчет какого-то альтернативного способа аутентификации и авторизации?
AndrewVK
AndrewVK
08.08.2014 09:04
Здравствуйте, Нахлобуч, Вы писали:

Н>Потому, что наличие глагола в имени ресурса делает его не совсем ресурсом.


Ну я так и подумал.

Н>См. свой пассаж о "переделано". Если бы в результате переделок сервер научился бы выплевывать HTTP 301 для перенаправления со старых на новые URL'ы и эти URL'ы не формировались бы клиентом, а получались непосредственно из ответа, то жизнь клиентских приложений была бы тёплой и сухой.


Пока никаких клиентских приложений для этих сервисов нет.

Н>И раз уж мы заговорили о REST и Stateless'ности -- может быть, подумать насчет какого-то альтернативного способа аутентификации и авторизации?


Может быть. Какого?
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Нахлобуч
Нахлобуч
08.08.2014 09:53
Здравствуйте, AndrewVK, Вы писали:

Н>>И раз уж мы заговорили о REST и Stateless'ности -- может быть, подумать насчет какого-то альтернативного способа аутентификации и авторизации?

AVK>Может быть. Какого?

Сам напрашивается Basic (и HTTPS, разумеется). Или что-то типа такого.
-n1l-
-n1l-
08.08.2014 10:39
Пользуясь случаем хочу попросить, что бы мне пояснили, в чем отличие между REST и RPC.
AndrewVK
AndrewVK
08.08.2014 10:45
Здравствуйте, -n1l-, Вы писали:

N>Пользуясь случаем хочу попросить, что бы мне пояснили, в чем отличие между REST и RPC.


Архитектурные подходы отличаются. В википедии довольно подробно расписано.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Sharov
Sharov
08.08.2014 11:45
Здравствуйте, -n1l-, Вы писали:

N>Пользуясь случаем хочу попросить, что бы мне пояснили, в чем отличие между REST и RPC.


http://rsdn.ru/forum/design/5520467.1

http://rsdn.ru/forum/design/5511534

http://rsdn.ru/forum/design/5008110.flat#5008110
Mamut
Mamut "createdOn":"\/Date(1407336643590)\/"
11.08.2014 10:51
"createdOn":"\/Date(1407754220)\/"


Я так понимаю, "\/Date(1407754220)\/" — это издержки сериализации из дотнета. МС в своем репертуаре — если можно что-то сделать криво, не согласуясь ни с какими стандартами, то они это сделают.

Если это — миллисекунды, то достаточно

"createdOn": 1407336643590


и указать в документации/комментариях (или не указывать ), что это миллисекунды

Самый правильный вариант был бы конечно ISO 8601
"createdOn": "2014-08-11T12:50:20+02:00"
ZloeBablo
ZloeBablo
11.08.2014 10:58
Здравствуйте, Mamut, Вы писали:

M>
M>"createdOn":"\/Date(1407754220)\/"
M>


M>Я так понимаю, "\/Date(1407754220)\/" — это издержки сериализации из дотнета. МС в своем репертуаре — если можно что-то сделать криво, не согласуясь ни с какими стандартами, то они это сделают.

Не сущетсвует стандарта по датам для Json.
Mamut
Mamut
11.08.2014 11:38
M>>Я так понимаю, "\/Date(1407754220)\/" — это издержки сериализации из дотнета. МС в своем репертуаре — если можно что-то сделать криво, не согласуясь ни с какими стандартами, то они это сделают.
ZB>Не сущетсвует стандарта по датам для Json.

Существуют стандарты отображения дат. Например, ISO 8601. Покажи мне стандарт на отображение даты в виде "/Date(int)/".
ZloeBablo
ZloeBablo
11.08.2014 12:02
M>Существуют стандарты отображения дат. Например, ISO 8601. Покажи мне стандарт на отображение даты в виде "/Date(int)/".

Существует и такой стандарт. Спору нет. Я думаю ты как программист справишься и распаршишь эту сложную строчку. Так как стандарта в json нет то все это отдано на откуп сериализатора.
К сведению..

"\"\\/Date(1335205592410)\\/\""         .Net JavaScriptSerializer
"\"\\/Date(1335205592410-0500)\\/\""    .Net DataContractJsonSerializer
"2012-04-23T18:25:43.511Z"              JavaScript built-in JSON object
"2012-04-21T18:25:43-05:00"             ISO8601
AndrewVK
AndrewVK
11.08.2014 12:20
Здравствуйте, ZloeBablo, Вы писали:

M>>Существуют стандарты отображения дат. Например, ISO 8601. Покажи мне стандарт на отображение даты в виде "/Date(int)/".

ZB>Существует и такой стандарт. Спору нет. Я думаю ты как программист справишься и распаршишь эту сложную строчку.

В демках же есть:
function fromJsonDate(dateStr) {
    var date = new Date(parseInt(dateStr.substr(6)));
    return date.getDate() + '.' + (date.getMonth() + 1) + "." + date.getFullYear()
        + ' ' + date.getHours() + ':' + date.getMinutes();
}


Впрочем, и на ISO8601 переделать не сложно, только ее ж тоже парсить, js то либо число миллисекунд умеет, либо rfc2822.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Anton Batenev
Anton Batenev
11.08.2014 06:33
Здравствуйте, AndrewVK, Вы писали:

AVK> Впрочем, и на ISO8601 переделать не сложно, только ее ж тоже парсить, js то либо число миллисекунд умеет, либо rfc2822.


Современный js тоже умеет ISO.
AndrewVK
AndrewVK
11.08.2014 08:22
Здравствуйте, Anton Batenev, Вы писали:

AB>Современный js тоже умеет ISO.


Ага, я уже нашел.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Mamut
Mamut
11.08.2014 12:35
M>>Существуют стандарты отображения дат. Например, ISO 8601. Покажи мне стандарт на отображение даты в виде "/Date(int)/".
ZB>Существует и такой стандарт. Спору нет.

Спору нет, а он продолжает спорить

ZB>Я думаю ты как программист справишься и распаршишь эту сложную строчку.


Думаю я, как программист, предпочту использовать то, на что есть стандарты, а не то, что придумано левой задней пяткой создателей .NET'а

О чем спор вообще? «Не плодите сущности без необходимости» и KISS:
— во всем API нет полей, которые требуют парсинга
— поле created_at — это числовое поле, содержащее milliseconds since epoch

Что-то мне подсказывает, что представление числового поля в виде "\/.NET-специфичное(int)\/" — это, как минмиум, создание новой сущности

Ну а то, что в JSON нет стандарта на дату, это не отмазка:
— в JSON много на что нет стандарта
— вне JSON'а есть стандарты на отображение дат (и много на что еще)
— если поле можно представить простым (например, int вместо строки, которую надо парсить) или стандартным способом, но следут представлять это поле простым/стандартным способом

ZloeBablo
ZloeBablo
11.08.2014 12:58
ZB>>Я думаю ты как программист справишься и распаршишь эту сложную строчку.
M>Думаю я, как программист, предпочту использовать то, на что есть стандарты, а не то, что придумано левой задней пяткой создателей .NET'а
Мне например всеравно. Я не понимаю твоего возмущения.
Mamut
Mamut
11.08.2014 04:31
ZB>>>Я думаю ты как программист справишься и распаршишь эту сложную строчку.
M>>Думаю я, как программист, предпочту использовать то, на что есть стандарты, а не то, что придумано левой задней пяткой создателей .NET'а
ZB>Мне например всеравно. Я не понимаю твоего возмущения.

Есть стандарт для отображения даты (ну или просто миллисекунды как целое число). Зачем использовать нестандартное и никем не поддерживаемое отображение?
AndrewVK
AndrewVK
11.08.2014 01:34
Здравствуйте, Mamut, Вы писали:

M>Думаю я, как программист, предпочту использовать то, на что есть стандарты


Стандартов на дату в JSON нет. В JSON вообще все очень плохо со стандартами. Хочешь стандарты — лучше использовать XML, там все качественно детализовано и есть XSD.

M>, а не то, что придумано левой задней пяткой создателей .NET'а


Еще раз — поменять — не проблема.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Mamut
Mamut
11.08.2014 04:29
M>>Думаю я, как программист, предпочту использовать то, на что есть стандарты

AVK>Стандартов на дату в JSON нет. В JSON вообще все очень плохо со стандартами.


Есть полно стандартов, которые можно и нужно использовать Для дат — ISO 8601, для стран и языков ISO 3166 и ISO 639-1/2, для IP-адресов RFC-1918, для банковских аккаунтов ISO 13616 и 9362 и так далее и тому подобное (это из тех, что только мы используем постоянно). Не описывать же все эти стандарты в стандарте JSON'а?

AVK>Хочешь стандарты — лучше использовать XML, там все качественно детализовано и есть XSD.


Что-то мне подсказывает, что половины из того, что я написал выше, в XSD не указано

M>>, а не то, что придумано левой задней пяткой создателей .NET'а


AVK>Еще раз — поменять — не проблема.


\o/
ionoy
ionoy
15.08.2014 10:16
Здравствуйте, AndrewVK, Вы писали:

Круто!
А можно добавить получение всех сообщений выбранной темы? А то тут некоторые темы за 700 ответов переваливают, делать 700 запросов как-то не хочется...
AndrewVK
AndrewVK
15.08.2014 11:12
Здравствуйте, ionoy, Вы писали:

I>А можно добавить получение всех сообщений выбранной темы? А то тут некоторые темы за 700 ответов переваливают, делать 700 запросов как-то не хочется...


http://rsdn.ru/ws/janusat.asmx
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
ionoy
ionoy
15.08.2014 11:16
Здравствуйте, AndrewVK, Вы писали:

AVK>Здравствуйте, ionoy, Вы писали:


I>>А можно добавить получение всех сообщений выбранной темы? А то тут некоторые темы за 700 ответов переваливают, делать 700 запросов как-то не хочется...


AVK>http://rsdn.ru/ws/janusat.asmx


А через новый REST нельзя будет?
AndrewVK
AndrewVK
15.08.2014 11:22
Здравствуйте, ionoy, Вы писали:

I>А через новый REST нельзя будет?


А зачем?
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
ionoy
ionoy
15.08.2014 11:25
Здравствуйте, AndrewVK, Вы писали:

AVK>Здравствуйте, ionoy, Вы писали:


I>>А через новый REST нельзя будет?


AVK>А зачем?


Ну мне, например, больше нравится читать сообщения когда они сразу развёрнуты. Дело вкуса
AndrewVK
AndrewVK
15.08.2014 11:32
Здравствуйте, ionoy, Вы писали:

I>Ну мне, например, больше нравится читать сообщения когда они сразу развёрнуты. Дело вкуса


Так подгружай по мере скроллинга.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
ionoy
ionoy
15.08.2014 11:34
Здравствуйте, AndrewVK, Вы писали:

AVK>Здравствуйте, ionoy, Вы писали:


I>>Ну мне, например, больше нравится читать сообщения когда они сразу развёрнуты. Дело вкуса


AVK>Так подгружай по мере скроллинга.


Это можно, но всё равно хотелось бы батчинга. Иначе слишком уж много запросов придётся делать, а это медленно.
ZloeBablo
ZloeBablo
17.08.2014 08:50
AVK>Аутентификация и сессия — общая с остальным сайтом, т.е. форма //Users/Login.aspx для логина, затем куки .RSDNAUTH и ASP.NET_SessionId.
Я правильно понял что подразумевается что приложение показывает WebView с формой пользователь авторизируется и я потом получаю эти куки или ручной POST тоже работает и там нет нкиаких Cross Site Request Forgery (CSRF)?
AndrewVK
AndrewVK
17.08.2014 01:07
Здравствуйте, ZloeBablo, Вы писали:

ZB>Я правильно понял что подразумевается что приложение показывает WebView с формой пользователь авторизируется и я потом получаю эти куки или ручной POST тоже работает и там нет нкиаких Cross Site Request Forgery (CSRF)?


Ручной пост тоже работает.
... << RSDN@Home 1.2.0 alpha 5 rev. 100 on Windows 8 6.2.9200.0>>
Quadri
Quadri
18.12.2016 03:54
Здравствуйте, AndrewVK, Вы писали:

а вот для этой страницы http://rsdn.org/forum/mainlist запроса нет?
AndrewVK
AndrewVK
18.12.2016 09:47
Здравствуйте, Quadri, Вы писали:

Q>а вот для этой страницы http://rsdn.org/forum/mainlist запроса нет?


Нет. А нужно?
... << RSDN@Home 1.0.0 alpha 5 rev. 0 on Windows 8 6.2.9200.0>>